mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-05 21:27:35 +03:00
use a high resolution timestamp in the token
This commit is contained in:
parent
aa9ab41560
commit
002b36abf5
2 changed files with 7 additions and 15 deletions
|
@ -17,17 +17,15 @@ const (
|
||||||
// A Token is derived from the client address and can be used to verify the ownership of this address.
|
// A Token is derived from the client address and can be used to verify the ownership of this address.
|
||||||
type Token struct {
|
type Token struct {
|
||||||
RemoteAddr string
|
RemoteAddr string
|
||||||
|
SentTime time.Time
|
||||||
OriginalDestConnectionID protocol.ConnectionID
|
OriginalDestConnectionID protocol.ConnectionID
|
||||||
// The time that the Token was issued (resolution 1 second)
|
|
||||||
SentTime time.Time
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// token is the struct that is used for ASN1 serialization and deserialization
|
// token is the struct that is used for ASN1 serialization and deserialization
|
||||||
type token struct {
|
type token struct {
|
||||||
RemoteAddr []byte
|
RemoteAddr []byte
|
||||||
|
Timestamp int64
|
||||||
OriginalDestConnectionID []byte
|
OriginalDestConnectionID []byte
|
||||||
|
|
||||||
Timestamp int64
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// A TokenGenerator generates tokens
|
// A TokenGenerator generates tokens
|
||||||
|
@ -51,7 +49,7 @@ func (g *TokenGenerator) NewToken(raddr net.Addr, origConnID protocol.Connection
|
||||||
data, err := asn1.Marshal(token{
|
data, err := asn1.Marshal(token{
|
||||||
RemoteAddr: encodeRemoteAddr(raddr),
|
RemoteAddr: encodeRemoteAddr(raddr),
|
||||||
OriginalDestConnectionID: origConnID,
|
OriginalDestConnectionID: origConnID,
|
||||||
Timestamp: time.Now().Unix(),
|
Timestamp: time.Now().UnixNano(),
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -80,7 +78,7 @@ func (g *TokenGenerator) DecodeToken(encrypted []byte) (*Token, error) {
|
||||||
}
|
}
|
||||||
token := &Token{
|
token := &Token{
|
||||||
RemoteAddr: decodeRemoteAddr(t.RemoteAddr),
|
RemoteAddr: decodeRemoteAddr(t.RemoteAddr),
|
||||||
SentTime: time.Unix(t.Timestamp, 0),
|
SentTime: time.Unix(0, t.Timestamp),
|
||||||
}
|
}
|
||||||
if len(t.OriginalDestConnectionID) > 0 {
|
if len(t.OriginalDestConnectionID) > 0 {
|
||||||
token.OriginalDestConnectionID = protocol.ConnectionID(t.OriginalDestConnectionID)
|
token.OriginalDestConnectionID = protocol.ConnectionID(t.OriginalDestConnectionID)
|
||||||
|
|
|
@ -43,9 +43,7 @@ var _ = Describe("Token Generator", func() {
|
||||||
token, err := tokenGen.DecodeToken(tokenEnc)
|
token, err := tokenGen.DecodeToken(tokenEnc)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
Expect(token.RemoteAddr).To(Equal("192.168.0.1"))
|
Expect(token.RemoteAddr).To(Equal("192.168.0.1"))
|
||||||
// the time resolution of the token is just 1 second
|
Expect(token.SentTime).To(BeTemporally("~", time.Now(), 10*time.Millisecond))
|
||||||
// if token generation and this check happen in "different seconds", the difference will be between 1 and 2 seconds
|
|
||||||
Expect(token.SentTime).To(BeTemporally("~", time.Now(), 2*time.Second))
|
|
||||||
Expect(token.OriginalDestConnectionID).To(BeNil())
|
Expect(token.OriginalDestConnectionID).To(BeNil())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -108,9 +106,7 @@ var _ = Describe("Token Generator", func() {
|
||||||
token, err := tokenGen.DecodeToken(tokenEnc)
|
token, err := tokenGen.DecodeToken(tokenEnc)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
Expect(token.RemoteAddr).To(Equal(ip.String()))
|
Expect(token.RemoteAddr).To(Equal(ip.String()))
|
||||||
// the time resolution of the token is just 1 second
|
Expect(token.SentTime).To(BeTemporally("~", time.Now(), 10*time.Millisecond))
|
||||||
// if token generation and this check happen in "different seconds", the difference will be between 1 and 2 seconds
|
|
||||||
Expect(token.SentTime).To(BeTemporally("~", time.Now(), 2*time.Second))
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -121,8 +117,6 @@ var _ = Describe("Token Generator", func() {
|
||||||
token, err := tokenGen.DecodeToken(tokenEnc)
|
token, err := tokenGen.DecodeToken(tokenEnc)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
Expect(token.RemoteAddr).To(Equal("192.168.13.37:1337"))
|
Expect(token.RemoteAddr).To(Equal("192.168.13.37:1337"))
|
||||||
// the time resolution of the token is just 1 second
|
Expect(token.SentTime).To(BeTemporally("~", time.Now(), 10*time.Millisecond))
|
||||||
// if token generation and this check happen in "different seconds", the difference will be between 1 and 2 seconds
|
|
||||||
Expect(token.SentTime).To(BeTemporally("~", time.Now(), 2*time.Second))
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue