1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2024-11-16 17:38:45 -05:00
v2fly/common/protocol/id.go

70 lines
1.3 KiB
Go
Raw Normal View History

package protocol
2015-09-05 11:48:38 -04:00
import (
2016-02-25 15:50:10 -05:00
"crypto/hmac"
2015-09-07 17:48:37 -04:00
"crypto/md5"
2016-02-25 15:50:10 -05:00
"hash"
2017-09-27 15:09:47 -04:00
"v2ray.com/core/common"
2016-08-20 14:55:45 -04:00
"v2ray.com/core/common/uuid"
2015-09-05 11:48:38 -04:00
)
2015-09-14 12:19:17 -04:00
const (
IDBytesLen = 16
)
2016-02-25 15:50:10 -05:00
type IDHash func(key []byte) hash.Hash
func DefaultIDHash(key []byte) hash.Hash {
return hmac.New(md5.New, key)
}
2018-04-02 03:52:16 -04:00
// The ID of en entity, in the form of a UUID.
2015-09-14 12:19:17 -04:00
type ID struct {
2018-01-18 17:25:48 -05:00
uuid uuid.UUID
2015-09-26 16:32:45 -04:00
cmdKey [IDBytesLen]byte
2015-09-14 12:19:17 -04:00
}
2016-12-07 07:13:48 -05:00
// Equals returns true if this ID equals to the other one.
2017-09-27 15:09:47 -04:00
func (id *ID) Equals(another *ID) bool {
2018-01-18 17:25:48 -05:00
return id.uuid.Equals(&(another.uuid))
}
2017-09-27 15:09:47 -04:00
func (id *ID) Bytes() []byte {
return id.uuid.Bytes()
2015-12-12 15:40:16 -05:00
}
2017-09-27 15:09:47 -04:00
func (id *ID) String() string {
return id.uuid.String()
2015-12-12 15:40:16 -05:00
}
2015-09-15 18:06:22 -04:00
2018-01-18 17:25:48 -05:00
func (id *ID) UUID() uuid.UUID {
2017-09-27 15:09:47 -04:00
return id.uuid
2016-01-08 18:10:57 -05:00
}
2017-09-27 15:09:47 -04:00
func (id ID) CmdKey() []byte {
return id.cmdKey[:]
}
2017-09-27 15:09:47 -04:00
// NewID returns an ID with given UUID.
2018-01-18 17:25:48 -05:00
func NewID(uuid uuid.UUID) *ID {
id := &ID{uuid: uuid}
2015-09-15 18:06:22 -04:00
md5hash := md5.New()
2017-09-27 15:09:47 -04:00
common.Must2(md5hash.Write(uuid.Bytes()))
common.Must2(md5hash.Write([]byte("c48619fe-8f02-49e0-b9e9-edf763e17e21")))
2016-01-20 11:45:50 -05:00
md5hash.Sum(id.cmdKey[:0])
return id
2015-09-07 17:48:19 -04:00
}
2016-05-07 15:07:46 -04:00
func NewAlterIDs(primary *ID, alterIDCount uint16) []*ID {
alterIDs := make([]*ID, alterIDCount)
prevID := primary.UUID()
for idx := range alterIDs {
newid := prevID.Next()
// TODO: check duplicates
alterIDs[idx] = NewID(newid)
prevID = newid
}
return alterIDs
}