| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | package vmessimport (	"crypto/md5"	"encoding/hex"	"errors"	"github.com/v2ray/v2ray-core/common/log")const (	IDBytesLen = 16)var (	InvalidID = errors.New("Invalid ID."))// The ID of en entity, in the form of an UUID.type ID struct {	String string	Bytes  [IDBytesLen]byte	cmdKey [IDBytesLen]byte}func NewID(id string) (*ID, error) {	idBytes, err := UUIDToID(id)	if err != nil {		log.Error("Failed to parse id %s", id)		return &ID{}, InvalidID	}	md5hash := md5.New()	md5hash.Write(idBytes[:])	md5hash.Write([]byte("c48619fe-8f02-49e0-b9e9-edf763e17e21"))	cmdKey := md5.Sum(nil)	return &ID{		String: id,		Bytes:  idBytes,		cmdKey: cmdKey,	}, nil}func (v ID) CmdKey() []byte {	return v.cmdKey[:]}var byteGroups = []int{8, 4, 4, 4, 12}// TODO: leverage a full functional UUID libraryfunc UUIDToID(uuid string) (v [IDBytesLen]byte, err error) {	text := []byte(uuid)	if len(text) < 32 {		log.Error("uuid: invalid UUID string: %s", text)		err = InvalidID		return	}	b := v[:]	for _, byteGroup := range byteGroups {		if text[0] == '-' {			text = text[1:]		}		_, err = hex.Decode(b[:byteGroup/2], text[:byteGroup])		if err != nil {			return		}		text = text[byteGroup:]		b = b[byteGroup/2:]	}	return}
 |