mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-12 11:04:25 +00:00
fc6154cffc
* fix: try using only user session if no user is set (id_token_hint) on prompt none * fix caos errors As implementation * implement request mode * return explicit error on invalid refresh token use * begin token revocation * token revocation * tests * tests * cleanup * set op config * add revocation endpoint to config * add revocation endpoint to config * migration version * error handling in token revocation * migration version * update oidc lib to 1.0.0
98 lines
2.8 KiB
Go
98 lines
2.8 KiB
Go
package view
|
|
|
|
import (
|
|
"github.com/caos/zitadel/internal/errors"
|
|
"github.com/caos/zitadel/internal/eventstore/v1/models"
|
|
usr_view "github.com/caos/zitadel/internal/user/repository/view"
|
|
"github.com/caos/zitadel/internal/user/repository/view/model"
|
|
"github.com/caos/zitadel/internal/view/repository"
|
|
)
|
|
|
|
const (
|
|
tokenTable = "auth.tokens"
|
|
)
|
|
|
|
func (v *View) TokenByID(tokenID string) (*model.TokenView, error) {
|
|
return usr_view.TokenByID(v.Db, tokenTable, tokenID)
|
|
}
|
|
|
|
func (v *View) TokensByUserID(userID string) ([]*model.TokenView, error) {
|
|
return usr_view.TokensByUserID(v.Db, tokenTable, userID)
|
|
}
|
|
|
|
func (v *View) PutToken(token *model.TokenView, event *models.Event) error {
|
|
err := usr_view.PutToken(v.Db, tokenTable, token)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) PutTokens(token []*model.TokenView, event *models.Event) error {
|
|
err := usr_view.PutTokens(v.Db, tokenTable, token...)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) DeleteToken(tokenID string, event *models.Event) error {
|
|
err := usr_view.DeleteToken(v.Db, tokenTable, tokenID)
|
|
if err != nil && !errors.IsNotFound(err) {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) DeleteSessionTokens(agentID, userID string, event *models.Event) error {
|
|
err := usr_view.DeleteSessionTokens(v.Db, tokenTable, agentID, userID)
|
|
if err != nil && !errors.IsNotFound(err) {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) DeleteUserTokens(userID string, event *models.Event) error {
|
|
err := usr_view.DeleteUserTokens(v.Db, tokenTable, userID)
|
|
if err != nil && !errors.IsNotFound(err) {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) DeleteApplicationTokens(event *models.Event, ids ...string) error {
|
|
err := usr_view.DeleteApplicationTokens(v.Db, tokenTable, ids)
|
|
if err != nil && !errors.IsNotFound(err) {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) DeleteTokensFromRefreshToken(refreshTokenID string, event *models.Event) error {
|
|
err := usr_view.DeleteTokensFromRefreshToken(v.Db, tokenTable, refreshTokenID)
|
|
if err != nil && !errors.IsNotFound(err) {
|
|
return err
|
|
}
|
|
return v.ProcessedTokenSequence(event)
|
|
}
|
|
|
|
func (v *View) GetLatestTokenSequence() (*repository.CurrentSequence, error) {
|
|
return v.latestSequence(tokenTable)
|
|
}
|
|
|
|
func (v *View) ProcessedTokenSequence(event *models.Event) error {
|
|
return v.saveCurrentSequence(tokenTable, event)
|
|
}
|
|
|
|
func (v *View) UpdateTokenSpoolerRunTimestamp() error {
|
|
return v.updateSpoolerRunSequence(tokenTable)
|
|
}
|
|
|
|
func (v *View) GetLatestTokenFailedEvent(sequence uint64) (*repository.FailedEvent, error) {
|
|
return v.latestFailedEvent(tokenTable, sequence)
|
|
}
|
|
|
|
func (v *View) ProcessedTokenFailedEvent(failedEvent *repository.FailedEvent) error {
|
|
return v.saveFailedEvent(failedEvent)
|
|
}
|