mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-12 19:14:23 +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
60 lines
1.8 KiB
Go
60 lines
1.8 KiB
Go
package view
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/jinzhu/gorm"
|
|
"github.com/lib/pq"
|
|
|
|
"github.com/caos/zitadel/internal/errors"
|
|
token_model "github.com/caos/zitadel/internal/token/model"
|
|
"github.com/caos/zitadel/internal/token/repository/view/model"
|
|
"github.com/caos/zitadel/internal/view"
|
|
)
|
|
|
|
func TokenByID(db *gorm.DB, table, tokenID string) (*model.Token, error) {
|
|
token := new(model.Token)
|
|
query := view.PrepareGetByKey(table, model.TokenSearchKey(token_model.TOKENSEARCHKEY_TOKEN_ID), tokenID)
|
|
err := query(db, token)
|
|
return token, err
|
|
}
|
|
|
|
func IsTokenValid(db *gorm.DB, table, tokenID string) (bool, error) {
|
|
token, err := TokenByID(db, table, tokenID)
|
|
if err == nil {
|
|
return token.Expiration.After(time.Now().UTC()), nil
|
|
}
|
|
if errors.IsNotFound(err) {
|
|
return false, nil
|
|
}
|
|
return false, err
|
|
}
|
|
|
|
func PutToken(db *gorm.DB, table string, token *model.Token) error {
|
|
save := view.PrepareSave(table)
|
|
return save(db, token)
|
|
}
|
|
|
|
func DeleteToken(db *gorm.DB, table, tokenID string) error {
|
|
delete := view.PrepareDeleteByKey(table, model.TokenSearchKey(token_model.TOKENSEARCHKEY_TOKEN_ID), tokenID)
|
|
return delete(db)
|
|
}
|
|
|
|
func DeleteSessionTokens(db *gorm.DB, table, agentID, userID string) error {
|
|
delete := view.PrepareDeleteByKeys(table,
|
|
view.Key{Key: model.TokenSearchKey(token_model.TOKENSEARCHKEY_USER_AGENT_ID), Value: agentID},
|
|
view.Key{Key: model.TokenSearchKey(token_model.TOKENSEARCHKEY_USER_ID), Value: userID},
|
|
)
|
|
return delete(db)
|
|
}
|
|
|
|
func DeleteUserTokens(db *gorm.DB, table, userID string) error {
|
|
delete := view.PrepareDeleteByKey(table, model.TokenSearchKey(token_model.TOKENSEARCHKEY_USER_ID), userID)
|
|
return delete(db)
|
|
}
|
|
|
|
func DeleteApplicationTokens(db *gorm.DB, table string, appIDs []string) error {
|
|
delete := view.PrepareDeleteByKey(table, model.TokenSearchKey(token_model.TOKENSEARCHKEY_APPLICATION_ID), pq.StringArray(appIDs))
|
|
return delete(db)
|
|
}
|