mirror of
https://github.com/goharbor/harbor.git
synced 2025-01-21 07:01:25 +01:00
Check return from token.DefaultTokenOptions()
Signed-off-by: Josh Soref <jsoref@users.noreply.github.com>
This commit is contained in:
parent
7039e0d2fe
commit
5be895cb39
@ -9,13 +9,20 @@ import (
|
|||||||
|
|
||||||
func TestNewOptions(t *testing.T) {
|
func TestNewOptions(t *testing.T) {
|
||||||
defaultOpt := DefaultTokenOptions()
|
defaultOpt := DefaultTokenOptions()
|
||||||
|
if defaultOpt == nil {
|
||||||
assert.NotNil(t, defaultOpt)
|
assert.NotNil(t, defaultOpt)
|
||||||
|
return
|
||||||
|
}
|
||||||
assert.Equal(t, defaultOpt.SignMethod, jwt.GetSigningMethod("RS256"))
|
assert.Equal(t, defaultOpt.SignMethod, jwt.GetSigningMethod("RS256"))
|
||||||
assert.Equal(t, defaultOpt.Issuer, "harbor-token-defaultIssuer")
|
assert.Equal(t, defaultOpt.Issuer, "harbor-token-defaultIssuer")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetKey(t *testing.T) {
|
func TestGetKey(t *testing.T) {
|
||||||
defaultOpt := DefaultTokenOptions()
|
defaultOpt := DefaultTokenOptions()
|
||||||
|
if defaultOpt == nil {
|
||||||
|
assert.NotNil(t, defaultOpt)
|
||||||
|
return
|
||||||
|
}
|
||||||
key, err := defaultOpt.GetKey()
|
key, err := defaultOpt.GetKey()
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.NotNil(t, key)
|
assert.NotNil(t, key)
|
||||||
|
@ -41,7 +41,12 @@ func TestNew(t *testing.T) {
|
|||||||
ExpiresAt: expiresAt,
|
ExpiresAt: expiresAt,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
token, err := New(DefaultTokenOptions(), robot)
|
defaultOpt := DefaultTokenOptions()
|
||||||
|
if defaultOpt == nil {
|
||||||
|
assert.NotNil(t, defaultOpt)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
token, err := New(defaultOpt, robot)
|
||||||
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.Equal(t, token.Header["alg"], "RS256")
|
assert.Equal(t, token.Header["alg"], "RS256")
|
||||||
@ -70,7 +75,12 @@ func TestRaw(t *testing.T) {
|
|||||||
ExpiresAt: expiresAt,
|
ExpiresAt: expiresAt,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
token, err := New(DefaultTokenOptions(), robot)
|
defaultOpt := DefaultTokenOptions()
|
||||||
|
if defaultOpt == nil {
|
||||||
|
assert.NotNil(t, defaultOpt)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
token, err := New(defaultOpt, robot)
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
|
|
||||||
rawTk, err := token.Raw()
|
rawTk, err := token.Raw()
|
||||||
@ -81,8 +91,12 @@ func TestRaw(t *testing.T) {
|
|||||||
func TestParseWithClaims(t *testing.T) {
|
func TestParseWithClaims(t *testing.T) {
|
||||||
rawTk := "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJJRCI6MTIzLCJQcm9qZWN0SUQiOjAsIkFjY2VzcyI6W3siUmVzb3VyY2UiOiIvcHJvamVjdC9saWJyYXkvcmVwb3NpdG9yeSIsIkFjdGlvbiI6InB1bGwiLCJFZmZlY3QiOiIifV0sIlN0YW5kYXJkQ2xhaW1zIjp7ImV4cCI6MTU0ODE0MDIyOSwiaXNzIjoiaGFyYm9yLXRva2VuLWlzc3VlciJ9fQ.Jc3qSKN4SJVUzAvBvemVpRcSOZaHlu0Avqms04qzPm4ru9-r9IRIl3mnSkI6m9XkzLUeJ7Kiwyw63ghngnVKw_PupeclOGC6s3TK5Cfmo4h-lflecXjZWwyy-dtH_e7Us_ItS-R3nXDJtzSLEpsGHCcAj-1X2s93RB2qD8LNSylvYeDezVkTzqRzzfawPJheKKh9JTrz-3eUxCwQard9-xjlwvfUYULoHTn9npNAUq4-jqhipW4uE8HL-ym33AGF57la8U0RO11hmDM5K8-PiYknbqJ_oONeS3HBNym2pEFeGjtTv2co213wl4T5lemlg4SGolMBuJ03L7_beVZ0o-MKTkKDqDwJalb6_PM-7u3RbxC9IzJMiwZKIPnD3FvV10iPxUUQHaH8Jz5UZ2pFIhi_8BNnlBfT0JOPFVYATtLjHMczZelj2YvAeR1UHBzq3E0jPpjjwlqIFgaHCaN_KMwEvadTo_Fi2sEH4pNGP7M3yehU_72oLJQgF4paJarsmEoij6ZtPs6xekBz1fccVitq_8WNIz9aeCUdkUBRwI5QKw1RdW4ua-w74ld5MZStWJA8veyoLkEb_Q9eq2oAj5KWFjJbW5-ltiIfM8gxKflsrkWAidYGcEIYcuXr7UdqEKXxtPiWM0xb3B91ovYvO5402bn3f9-UGtlcestxNHA"
|
rawTk := "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJJRCI6MTIzLCJQcm9qZWN0SUQiOjAsIkFjY2VzcyI6W3siUmVzb3VyY2UiOiIvcHJvamVjdC9saWJyYXkvcmVwb3NpdG9yeSIsIkFjdGlvbiI6InB1bGwiLCJFZmZlY3QiOiIifV0sIlN0YW5kYXJkQ2xhaW1zIjp7ImV4cCI6MTU0ODE0MDIyOSwiaXNzIjoiaGFyYm9yLXRva2VuLWlzc3VlciJ9fQ.Jc3qSKN4SJVUzAvBvemVpRcSOZaHlu0Avqms04qzPm4ru9-r9IRIl3mnSkI6m9XkzLUeJ7Kiwyw63ghngnVKw_PupeclOGC6s3TK5Cfmo4h-lflecXjZWwyy-dtH_e7Us_ItS-R3nXDJtzSLEpsGHCcAj-1X2s93RB2qD8LNSylvYeDezVkTzqRzzfawPJheKKh9JTrz-3eUxCwQard9-xjlwvfUYULoHTn9npNAUq4-jqhipW4uE8HL-ym33AGF57la8U0RO11hmDM5K8-PiYknbqJ_oONeS3HBNym2pEFeGjtTv2co213wl4T5lemlg4SGolMBuJ03L7_beVZ0o-MKTkKDqDwJalb6_PM-7u3RbxC9IzJMiwZKIPnD3FvV10iPxUUQHaH8Jz5UZ2pFIhi_8BNnlBfT0JOPFVYATtLjHMczZelj2YvAeR1UHBzq3E0jPpjjwlqIFgaHCaN_KMwEvadTo_Fi2sEH4pNGP7M3yehU_72oLJQgF4paJarsmEoij6ZtPs6xekBz1fccVitq_8WNIz9aeCUdkUBRwI5QKw1RdW4ua-w74ld5MZStWJA8veyoLkEb_Q9eq2oAj5KWFjJbW5-ltiIfM8gxKflsrkWAidYGcEIYcuXr7UdqEKXxtPiWM0xb3B91ovYvO5402bn3f9-UGtlcestxNHA"
|
||||||
rClaims := &robot_claim.Claim{}
|
rClaims := &robot_claim.Claim{}
|
||||||
_, _ = Parse(DefaultTokenOptions(), rawTk, rClaims)
|
defaultOpt := DefaultTokenOptions()
|
||||||
assert.Equal(t, int64(123), rClaims.TokenID)
|
if defaultOpt == nil {
|
||||||
|
assert.NotNil(t, defaultOpt)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
_, _ = Parse(defaultOpt, rawTk, rClaims)
|
||||||
assert.Equal(t, int64(0), rClaims.ProjectID)
|
assert.Equal(t, int64(0), rClaims.ProjectID)
|
||||||
assert.Equal(t, "/project/libray/repository", rClaims.Access[0].Resource.String())
|
assert.Equal(t, "/project/libray/repository", rClaims.Access[0].Resource.String())
|
||||||
}
|
}
|
||||||
|
@ -39,8 +39,12 @@ func (r *robot) Generate(req *http.Request) security.Context {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
rClaims := &robot_claim.Claim{}
|
rClaims := &robot_claim.Claim{}
|
||||||
opt := pkg_token.DefaultTokenOptions()
|
defaultOpt := pkg_token.DefaultTokenOptions()
|
||||||
rtk, err := pkg_token.Parse(opt, robotTk, rClaims)
|
if defaultOpt == nil {
|
||||||
|
log.Error("failed to get default token options")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
rtk, err := pkg_token.Parse(defaultOpt, robotTk, rClaims)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("failed to decrypt robot token: %v", err)
|
log.Errorf("failed to decrypt robot token: %v", err)
|
||||||
return nil
|
return nil
|
||||||
|
@ -41,9 +41,13 @@ func (vt *v2Token) Generate(req *http.Request) security.Context {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
opt := token.DefaultTokenOptions()
|
defaultOpt := token.DefaultTokenOptions()
|
||||||
|
if defaultOpt == nil {
|
||||||
|
logger.Warningf("failed to get default options")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
cl := &v2TokenClaims{}
|
cl := &v2TokenClaims{}
|
||||||
t, err := token.Parse(opt, tokenStr, cl)
|
t, err := token.Parse(defaultOpt, tokenStr, cl)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Warningf("failed to decode bearer token: %v", err)
|
logger.Warningf("failed to decode bearer token: %v", err)
|
||||||
return nil
|
return nil
|
||||||
|
Loading…
Reference in New Issue
Block a user