2021-05-20 11:33:35 +00:00
|
|
|
package view
|
|
|
|
|
|
|
|
import (
|
2023-04-28 14:28:13 +00:00
|
|
|
"context"
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
"github.com/zitadel/zitadel/internal/api/authz"
|
|
|
|
"github.com/zitadel/zitadel/internal/eventstore"
|
2022-04-26 23:01:45 +00:00
|
|
|
"github.com/zitadel/zitadel/internal/eventstore/v1/models"
|
2023-10-19 10:19:10 +00:00
|
|
|
"github.com/zitadel/zitadel/internal/query"
|
2022-04-26 23:01:45 +00:00
|
|
|
user_model "github.com/zitadel/zitadel/internal/user/model"
|
|
|
|
usr_view "github.com/zitadel/zitadel/internal/user/repository/view"
|
|
|
|
"github.com/zitadel/zitadel/internal/user/repository/view/model"
|
2023-12-08 14:30:55 +00:00
|
|
|
"github.com/zitadel/zitadel/internal/zerrors"
|
2021-05-20 11:33:35 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
refreshTokenTable = "auth.refresh_tokens"
|
|
|
|
)
|
|
|
|
|
2022-04-19 06:26:12 +00:00
|
|
|
func (v *View) RefreshTokenByID(tokenID, instanceID string) (*model.RefreshTokenView, error) {
|
|
|
|
return usr_view.RefreshTokenByID(v.Db, refreshTokenTable, tokenID, instanceID)
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
2022-04-19 06:26:12 +00:00
|
|
|
func (v *View) RefreshTokensByUserID(userID, instanceID string) ([]*model.RefreshTokenView, error) {
|
|
|
|
return usr_view.RefreshTokensByUserID(v.Db, refreshTokenTable, userID, instanceID)
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (v *View) SearchRefreshTokens(request *user_model.RefreshTokenSearchRequest) ([]*model.RefreshTokenView, uint64, error) {
|
|
|
|
return usr_view.SearchRefreshTokens(v.Db, refreshTokenTable, request)
|
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) PutRefreshToken(token *model.RefreshTokenView) error {
|
|
|
|
return usr_view.PutRefreshToken(v.Db, refreshTokenTable, token)
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) PutRefreshTokens(token []*model.RefreshTokenView) error {
|
|
|
|
return usr_view.PutRefreshTokens(v.Db, refreshTokenTable, token...)
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) DeleteRefreshToken(tokenID, instanceID string) error {
|
2022-04-19 06:26:12 +00:00
|
|
|
err := usr_view.DeleteRefreshToken(v.Db, refreshTokenTable, tokenID, instanceID)
|
2023-12-08 14:30:55 +00:00
|
|
|
if err != nil && !zerrors.IsNotFound(err) {
|
2021-05-20 11:33:35 +00:00
|
|
|
return err
|
|
|
|
}
|
2023-10-19 10:19:10 +00:00
|
|
|
return nil
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) DeleteUserRefreshTokens(userID, instanceID string) error {
|
2022-04-19 06:26:12 +00:00
|
|
|
err := usr_view.DeleteUserRefreshTokens(v.Db, refreshTokenTable, userID, instanceID)
|
2023-12-08 14:30:55 +00:00
|
|
|
if err != nil && !zerrors.IsNotFound(err) {
|
2021-05-20 11:33:35 +00:00
|
|
|
return err
|
|
|
|
}
|
2023-10-19 10:19:10 +00:00
|
|
|
return nil
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (v *View) DeleteApplicationRefreshTokens(event *models.Event, ids ...string) error {
|
2022-04-19 06:26:12 +00:00
|
|
|
err := usr_view.DeleteApplicationTokens(v.Db, refreshTokenTable, event.InstanceID, ids)
|
2023-12-08 14:30:55 +00:00
|
|
|
if err != nil && !zerrors.IsNotFound(err) {
|
2022-10-26 13:06:48 +00:00
|
|
|
return err
|
|
|
|
}
|
2023-10-19 10:19:10 +00:00
|
|
|
return nil
|
2022-10-26 13:06:48 +00:00
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) DeleteInstanceRefreshTokens(instanceID string) error {
|
|
|
|
err := usr_view.DeleteInstanceRefreshTokens(v.Db, refreshTokenTable, instanceID)
|
2023-12-08 14:30:55 +00:00
|
|
|
if err != nil && !zerrors.IsNotFound(err) {
|
2022-11-30 16:01:17 +00:00
|
|
|
return err
|
|
|
|
}
|
2023-10-19 10:19:10 +00:00
|
|
|
return nil
|
2022-11-30 16:01:17 +00:00
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) DeleteOrgRefreshTokens(event eventstore.Event) error {
|
|
|
|
err := usr_view.DeleteOrgRefreshTokens(v.Db, refreshTokenTable, event.Aggregate().InstanceID, event.Aggregate().ResourceOwner)
|
2023-12-08 14:30:55 +00:00
|
|
|
if err != nil && !zerrors.IsNotFound(err) {
|
2021-05-20 11:33:35 +00:00
|
|
|
return err
|
|
|
|
}
|
2023-10-19 10:19:10 +00:00
|
|
|
return nil
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|
|
|
|
|
2023-10-19 10:19:10 +00:00
|
|
|
func (v *View) GetLatestRefreshTokenSequence(ctx context.Context) (_ *query.CurrentState, err error) {
|
|
|
|
q := &query.CurrentStateSearchQueries{
|
|
|
|
Queries: make([]query.SearchQuery, 2),
|
|
|
|
}
|
|
|
|
q.Queries[0], err = query.NewCurrentStatesInstanceIDSearchQuery(authz.GetInstance(ctx).InstanceID())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
q.Queries[1], err = query.NewCurrentStatesProjectionSearchQuery(refreshTokenTable)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
states, err := v.query.SearchCurrentStates(ctx, q)
|
|
|
|
if err != nil || states.SearchResponse.Count == 0 {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return states.CurrentStates[0], nil
|
2021-05-20 11:33:35 +00:00
|
|
|
}
|