zitadel/internal/query/query.go

65 lines
1.6 KiB
Go
Raw Normal View History

package query
import (
"context"
2020-11-26 12:14:07 +00:00
sd "github.com/caos/zitadel/internal/config/systemdefaults"
"github.com/caos/zitadel/internal/config/types"
2020-11-26 12:14:07 +00:00
"github.com/caos/zitadel/internal/crypto"
"github.com/caos/zitadel/internal/eventstore"
iam_model "github.com/caos/zitadel/internal/iam/model"
2020-11-26 12:14:07 +00:00
"github.com/caos/zitadel/internal/id"
iam_repo "github.com/caos/zitadel/internal/repository/iam"
usr_repo "github.com/caos/zitadel/internal/repository/user"
2020-12-03 09:21:00 +00:00
"github.com/caos/zitadel/internal/telemetry/tracing"
)
type Queries struct {
iamID string
2020-11-26 12:14:07 +00:00
eventstore *eventstore.Eventstore
idGenerator id.Generator
secretCrypto crypto.Crypto
}
type Config struct {
Eventstore types.SQLUser
}
func StartQueries(eventstore *eventstore.Eventstore, defaults sd.SystemDefaults) (repo *Queries, err error) {
repo = &Queries{
iamID: defaults.IamID,
eventstore: eventstore,
2020-11-26 12:14:07 +00:00
idGenerator: id.SonyFlakeGenerator,
}
2020-11-30 07:53:08 +00:00
iam_repo.RegisterEventMappers(repo.eventstore)
usr_repo.RegisterEventMappers(repo.eventstore)
2020-11-26 12:14:07 +00:00
repo.secretCrypto, err = crypto.NewAESCrypto(defaults.IDPConfigVerificationKey)
2020-11-26 12:14:07 +00:00
if err != nil {
return nil, err
}
return repo, nil
}
func (r *Queries) IAMByID(ctx context.Context, id string) (_ *iam_model.IAM, err error) {
readModel, err := r.iamByID(ctx, id)
if err != nil {
return nil, err
}
return readModelToIAM(readModel), nil
}
func (r *Queries) iamByID(ctx context.Context, id string) (_ *ReadModel, err error) {
ctx, span := tracing.NewSpan(ctx)
defer func() { span.EndWithError(err) }()
readModel := NewReadModel(id)
2020-11-25 13:12:44 +00:00
err = r.eventstore.FilterToQueryReducer(ctx, readModel)
if err != nil {
return nil, err
}
return readModel, nil
}