mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 13:29:28 +00:00 
			
		
		
		
	fix(auth): optimise user sessions (#7199)
* fix(auth): start optimise user sessions * reduce and query user sessions directly without gorm statements * cleanup * cleanup * fix requested changes --------- Co-authored-by: Livio Spring <livio.a@gmail.com>
This commit is contained in:
		| @@ -23,16 +23,20 @@ const ( | ||||
| ) | ||||
|  | ||||
| type UserSessionView struct { | ||||
| 	CreationDate                 time.Time `json:"-" gorm:"column:creation_date"` | ||||
| 	ChangeDate                   time.Time `json:"-" gorm:"column:change_date"` | ||||
| 	ResourceOwner                string    `json:"-" gorm:"column:resource_owner"` | ||||
| 	State                        int32     `json:"-" gorm:"column:state"` | ||||
| 	UserAgentID                  string    `json:"userAgentID" gorm:"column:user_agent_id;primary_key"` | ||||
| 	UserID                       string    `json:"userID" gorm:"column:user_id;primary_key"` | ||||
| 	UserName                     string    `json:"-" gorm:"column:user_name"` | ||||
| 	LoginName                    string    `json:"-" gorm:"column:login_name"` | ||||
| 	DisplayName                  string    `json:"-" gorm:"column:user_display_name"` | ||||
| 	AvatarKey                    string    `json:"-" gorm:"column:avatar_key"` | ||||
| 	CreationDate  time.Time `json:"-" gorm:"column:creation_date"` | ||||
| 	ChangeDate    time.Time `json:"-" gorm:"column:change_date"` | ||||
| 	ResourceOwner string    `json:"-" gorm:"column:resource_owner"` | ||||
| 	State         int32     `json:"-" gorm:"column:state"` | ||||
| 	UserAgentID   string    `json:"userAgentID" gorm:"column:user_agent_id;primary_key"` | ||||
| 	UserID        string    `json:"userID" gorm:"column:user_id;primary_key"` | ||||
| 	// As of https://github.com/zitadel/zitadel/pull/7199 the following 4 attributes | ||||
| 	// are not projected in the user session handler anymore | ||||
| 	// and are therefore annotated with a `gorm:"-"`. | ||||
| 	// They will be read from the corresponding projection directly. | ||||
| 	UserName                     string    `json:"-" gorm:"-"` | ||||
| 	LoginName                    string    `json:"-" gorm:"-"` | ||||
| 	DisplayName                  string    `json:"-" gorm:"-"` | ||||
| 	AvatarKey                    string    `json:"-" gorm:"-"` | ||||
| 	SelectedIDPConfigID          string    `json:"selectedIDPConfigID" gorm:"column:selected_idp_config_id"` | ||||
| 	PasswordVerification         time.Time `json:"-" gorm:"column:password_verification"` | ||||
| 	PasswordlessVerification     time.Time `json:"-" gorm:"column:passwordless_verification"` | ||||
| @@ -190,14 +194,6 @@ func (v *UserSessionView) AppendEvent(event eventstore.Event) error { | ||||
| 	case user.UserIDPLinkRemovedType, user.UserIDPLinkCascadeRemovedType: | ||||
| 		v.ExternalLoginVerification = time.Time{} | ||||
| 		v.SelectedIDPConfigID = "" | ||||
| 	case user.HumanAvatarAddedType: | ||||
| 		key, err := avatarKeyFromEvent(event) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		v.AvatarKey = key | ||||
| 	case user.HumanAvatarRemovedType: | ||||
| 		v.AvatarKey = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| @@ -208,15 +204,6 @@ func (v *UserSessionView) setSecondFactorVerification(verificationTime time.Time | ||||
| 	v.State = int32(domain.UserSessionStateActive) | ||||
| } | ||||
|  | ||||
| func avatarKeyFromEvent(event eventstore.Event) (string, error) { | ||||
| 	data := make(map[string]string) | ||||
| 	if err := event.Unmarshal(&data); err != nil { | ||||
| 		logging.Log("EVEN-Sfew2").WithError(err).Error("could not unmarshal event data") | ||||
| 		return "", zerrors.ThrowInternal(err, "MODEL-SFw2q", "could not unmarshal event") | ||||
| 	} | ||||
| 	return data["storeKey"], nil | ||||
| } | ||||
|  | ||||
| func (v *UserSessionView) EventTypes() []eventstore.EventType { | ||||
| 	return []eventstore.EventType{ | ||||
| 		user.UserV1PasswordCheckSucceededType, | ||||
| @@ -250,7 +237,5 @@ func (v *UserSessionView) EventTypes() []eventstore.EventType { | ||||
| 		user.UserDeactivatedType, | ||||
| 		user.UserIDPLinkRemovedType, | ||||
| 		user.UserIDPLinkCascadeRemovedType, | ||||
| 		user.HumanAvatarAddedType, | ||||
| 		user.HumanAvatarRemovedType, | ||||
| 	} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Silvan
					Silvan