Merge pull request from GHSA-6rrr-78xp-5jp8

This commit is contained in:
Livio Spring 2023-01-10 15:58:10 +01:00 committed by GitHub
parent 0a85dd822f
commit 2482bb8700
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 106 additions and 6 deletions

View File

@ -261,7 +261,7 @@ func (c *Commands) addUserToken(ctx context.Context, userWriteModel *UserWriteMo
if err != nil { if err != nil {
return nil, nil, err return nil, nil, err
} }
if !isUserStateExists(userWriteModel.UserState) { if userWriteModel.UserState != domain.UserStateActive {
return nil, nil, errors.ThrowNotFound(nil, "COMMAND-1d6Gg", "Errors.User.NotFound") return nil, nil, errors.ThrowNotFound(nil, "COMMAND-1d6Gg", "Errors.User.NotFound")
} }

View File

@ -18,6 +18,7 @@ type HumanRefreshTokenWriteModel struct {
UserState domain.UserState UserState domain.UserState
IdleExpiration time.Time IdleExpiration time.Time
Expiration time.Time Expiration time.Time
UserAgentID string
} }
func NewHumanRefreshTokenWriteModel(userID, resourceOwner, tokenID string) *HumanRefreshTokenWriteModel { func NewHumanRefreshTokenWriteModel(userID, resourceOwner, tokenID string) *HumanRefreshTokenWriteModel {
@ -48,6 +49,8 @@ func (wm *HumanRefreshTokenWriteModel) AppendEvents(events ...eventstore.Event)
continue continue
} }
wm.WriteModel.AppendEvents(e) wm.WriteModel.AppendEvents(e)
default:
wm.WriteModel.AppendEvents(e)
} }
} }
} }
@ -61,14 +64,18 @@ func (wm *HumanRefreshTokenWriteModel) Reduce() error {
wm.IdleExpiration = e.CreationDate().Add(e.IdleExpiration) wm.IdleExpiration = e.CreationDate().Add(e.IdleExpiration)
wm.Expiration = e.CreationDate().Add(e.Expiration) wm.Expiration = e.CreationDate().Add(e.Expiration)
wm.UserState = domain.UserStateActive wm.UserState = domain.UserStateActive
wm.UserAgentID = e.UserAgentID
case *user.HumanRefreshTokenRenewedEvent: case *user.HumanRefreshTokenRenewedEvent:
if wm.UserState == domain.UserStateActive { if wm.UserState == domain.UserStateActive {
wm.RefreshToken = e.RefreshToken wm.RefreshToken = e.RefreshToken
} }
wm.RefreshToken = e.RefreshToken wm.RefreshToken = e.RefreshToken
wm.IdleExpiration = e.CreationDate().Add(e.IdleExpiration) wm.IdleExpiration = e.CreationDate().Add(e.IdleExpiration)
case *user.HumanSignedOutEvent:
if wm.UserAgentID == e.UserAgentID {
wm.UserState = domain.UserStateDeleted
}
case *user.HumanRefreshTokenRemovedEvent, case *user.HumanRefreshTokenRemovedEvent,
*user.HumanSignedOutEvent,
*user.UserLockedEvent, *user.UserLockedEvent,
*user.UserDeactivatedEvent, *user.UserDeactivatedEvent,
*user.UserRemovedEvent: *user.UserRemovedEvent:

View File

@ -64,10 +64,16 @@ func TestCommands_AddAccessAndRefreshToken(t *testing.T) {
}, },
}, },
{ {
name: "add refresh token, user inactive, error", name: "add refresh token, user deactivated, error",
fields: fields{ fields: fields{
eventstore: eventstoreExpect(t, eventstore: eventstoreExpect(t,
expectFilter(), expectFilter(
eventFromEventPusher(
user.NewUserDeactivatedEvent(context.Background(),
&user.NewAggregate("userID", "orgID").Aggregate,
),
),
),
), ),
idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "refreshTokenID1"), idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "refreshTokenID1"),
}, },
@ -912,6 +918,87 @@ func TestCommands_renewRefreshToken(t *testing.T) {
err: caos_errs.IsErrorInvalidArgument, err: caos_errs.IsErrorInvalidArgument,
}, },
}, },
{
name: "user deactivated, error",
fields: fields{
eventstore: eventstoreExpect(t,
expectFilter(
eventFromEventPusherWithCreationDateNow(user.NewHumanRefreshTokenAddedEvent(
context.Background(),
&user.NewAggregate("userID", "orgID").Aggregate,
"tokenID",
"applicationID",
"userAgentID",
"de",
[]string{"clientID1"},
[]string{oidc.ScopeOpenID, oidc.ScopeProfile, oidc.ScopeEmail, oidc.ScopeOfflineAccess},
[]string{"password"},
time.Now(),
1*time.Hour,
24*time.Hour,
)),
eventFromEventPusher(
user.NewUserDeactivatedEvent(
context.Background(),
&user.NewAggregate("userID", "orgID").Aggregate,
),
),
),
),
keyAlgorithm: refreshTokenEncryptionAlgorithm(gomock.NewController(t)),
},
args: args{
ctx: context.Background(),
userID: "userID",
orgID: "orgID",
refreshToken: base64.RawURLEncoding.EncodeToString([]byte("userID:tokenID:tokenID")),
idleExpiration: 1 * time.Hour,
},
res: res{
err: caos_errs.IsErrorInvalidArgument,
},
},
{
name: "user signedout, error",
fields: fields{
eventstore: eventstoreExpect(t,
expectFilter(
eventFromEventPusherWithCreationDateNow(user.NewHumanRefreshTokenAddedEvent(
context.Background(),
&user.NewAggregate("userID", "orgID").Aggregate,
"tokenID",
"applicationID",
"userAgentID",
"de",
[]string{"clientID1"},
[]string{oidc.ScopeOpenID, oidc.ScopeProfile, oidc.ScopeEmail, oidc.ScopeOfflineAccess},
[]string{"password"},
time.Now(),
1*time.Hour,
24*time.Hour,
)),
eventFromEventPusher(
user.NewHumanSignedOutEvent(
context.Background(),
&user.NewAggregate("userID", "orgID").Aggregate,
"userAgentID",
),
),
),
),
keyAlgorithm: refreshTokenEncryptionAlgorithm(gomock.NewController(t)),
},
args: args{
ctx: context.Background(),
userID: "userID",
orgID: "orgID",
refreshToken: base64.RawURLEncoding.EncodeToString([]byte("userID:tokenID:tokenID")),
idleExpiration: 1 * time.Hour,
},
res: res{
err: caos_errs.IsErrorInvalidArgument,
},
},
{ {
name: "token renewed, ok", name: "token renewed, ok",
fields: fields{ fields: fields{

View File

@ -396,7 +396,13 @@ func NewHumanSignedOutEvent(
} }
func HumanSignedOutEventMapper(event *repository.Event) (eventstore.Event, error) { func HumanSignedOutEventMapper(event *repository.Event) (eventstore.Event, error) {
return &HumanSignedOutEvent{ signedOut := &HumanSignedOutEvent{
BaseEvent: *eventstore.BaseEventFromRepo(event), BaseEvent: *eventstore.BaseEventFromRepo(event),
}, nil }
err := json.Unmarshal(event.Data, signedOut)
if err != nil {
return nil, errors.ThrowInternal(err, "USER-WFS3g", "unable to unmarshal human signed out")
}
return signedOut, nil
} }