session: Add public key to the constructor of new private token
Private token based on the token with private key. Therefore it must inherit public key field through constructor parameter.
This commit is contained in:
parent
e945525510
commit
01b910fd31
3 changed files with 13 additions and 2 deletions
|
@ -33,6 +33,7 @@ type (
|
||||||
LastEpoch uint64
|
LastEpoch uint64
|
||||||
ObjectID []ObjectID
|
ObjectID []ObjectID
|
||||||
OwnerID OwnerID
|
OwnerID OwnerID
|
||||||
|
PublicKeys [][]byte
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -54,6 +54,7 @@ func (s *simpleStore) New(p TokenParams) *PToken {
|
||||||
LastEpoch: p.LastEpoch,
|
LastEpoch: p.LastEpoch,
|
||||||
ObjectID: p.ObjectID,
|
ObjectID: p.ObjectID,
|
||||||
OwnerID: p.OwnerID,
|
OwnerID: p.OwnerID,
|
||||||
|
PublicKeys: p.PublicKeys,
|
||||||
},
|
},
|
||||||
PrivateKey: key,
|
PrivateKey: key,
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,9 +57,14 @@ func TestTokenStore(t *testing.T) {
|
||||||
|
|
||||||
c := newTestClient(t)
|
c := newTestClient(t)
|
||||||
require.NotNil(t, c)
|
require.NotNil(t, c)
|
||||||
|
pk := [][]byte{crypto.MarshalPublicKey(&c.PublicKey)}
|
||||||
|
|
||||||
// create new token
|
// create new token
|
||||||
token := s.New(TokenParams{ObjectID: []ObjectID{oid}, OwnerID: c.OwnerID})
|
token := s.New(TokenParams{
|
||||||
|
ObjectID: []ObjectID{oid},
|
||||||
|
OwnerID: c.OwnerID,
|
||||||
|
PublicKeys: pk,
|
||||||
|
})
|
||||||
signToken(t, token, c)
|
signToken(t, token, c)
|
||||||
|
|
||||||
// check that it can be fetched
|
// check that it can be fetched
|
||||||
|
@ -68,7 +73,11 @@ func TestTokenStore(t *testing.T) {
|
||||||
require.Equal(t, token, t1)
|
require.Equal(t, token, t1)
|
||||||
|
|
||||||
// create and sign another token by the same client
|
// create and sign another token by the same client
|
||||||
t1 = s.New(TokenParams{ObjectID: []ObjectID{oid}, OwnerID: c.OwnerID})
|
t1 = s.New(TokenParams{
|
||||||
|
ObjectID: []ObjectID{oid},
|
||||||
|
OwnerID: c.OwnerID,
|
||||||
|
PublicKeys: pk})
|
||||||
|
|
||||||
signToken(t, t1, c)
|
signToken(t, t1, c)
|
||||||
|
|
||||||
data := []byte{1, 2, 3}
|
data := []byte{1, 2, 3}
|
||||||
|
|
Loading…
Reference in a new issue