mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-12 00:03:58 +00:00
e653eaab86
* password in init user only if needed * reactivate user session * set context AuthorizeClientIDSecret * fix qr code for light * fix copy * check user and org active in auth * add org view provider * handle inactive projects * translate error messages
100 lines
2.6 KiB
Go
100 lines
2.6 KiB
Go
package view
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/caos/zitadel/internal/token/repository/view"
|
|
"github.com/caos/zitadel/internal/token/repository/view/model"
|
|
global_view "github.com/caos/zitadel/internal/view"
|
|
)
|
|
|
|
const (
|
|
tokenTable = "auth.tokens"
|
|
)
|
|
|
|
func (v *View) TokenByID(tokenID string) (*model.Token, error) {
|
|
return view.TokenByID(v.Db, tokenTable, tokenID)
|
|
}
|
|
|
|
func (v *View) IsTokenValid(tokenID string) (bool, error) {
|
|
return view.IsTokenValid(v.Db, tokenTable, tokenID)
|
|
}
|
|
|
|
func (v *View) CreateToken(agentID, applicationID, userID string, audience, scopes []string, lifetime time.Duration) (*model.Token, error) {
|
|
id, err := v.idGenerator.Next()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
now := time.Now().UTC()
|
|
token := &model.Token{
|
|
ID: id,
|
|
CreationDate: now,
|
|
UserID: userID,
|
|
ApplicationID: applicationID,
|
|
UserAgentID: agentID,
|
|
Scopes: scopes,
|
|
Audience: audience,
|
|
Expiration: now.Add(lifetime),
|
|
}
|
|
if err := view.PutToken(v.Db, tokenTable, token); err != nil {
|
|
return nil, err
|
|
}
|
|
return token, nil
|
|
}
|
|
|
|
func (v *View) PutToken(token *model.Token) error {
|
|
err := view.PutToken(v.Db, tokenTable, token)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(token.Sequence)
|
|
}
|
|
|
|
func (v *View) DeleteToken(tokenID string, eventSequence uint64) error {
|
|
err := view.DeleteToken(v.Db, tokenTable, tokenID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedTokenSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) DeleteSessionTokens(agentID, userID string, eventSequence uint64) error {
|
|
err := view.DeleteSessionTokens(v.Db, tokenTable, agentID, userID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedTokenSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) DeleteUserTokens(userID string, eventSequence uint64) error {
|
|
err := view.DeleteUserTokens(v.Db, tokenTable, userID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedTokenSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) DeleteApplicationTokens(eventSequence uint64, ids ...string) error {
|
|
err := view.DeleteApplicationTokens(v.Db, tokenTable, ids)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedTokenSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) GetLatestTokenSequence() (uint64, error) {
|
|
return v.latestSequence(tokenTable)
|
|
}
|
|
|
|
func (v *View) ProcessedTokenSequence(eventSequence uint64) error {
|
|
return v.saveCurrentSequence(tokenTable, eventSequence)
|
|
}
|
|
|
|
func (v *View) GetLatestTokenFailedEvent(sequence uint64) (*global_view.FailedEvent, error) {
|
|
return v.latestFailedEvent(tokenTable, sequence)
|
|
}
|
|
|
|
func (v *View) ProcessedTokenFailedEvent(failedEvent *global_view.FailedEvent) error {
|
|
return v.saveFailedEvent(failedEvent)
|
|
}
|