zitadel/internal/v2/query/query.go

63 lines
1.5 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/crypto"
"github.com/caos/zitadel/internal/eventstore/v2"
iam_model "github.com/caos/zitadel/internal/iam/model"
2020-11-26 12:14:07 +00:00
"github.com/caos/zitadel/internal/id"
2020-12-03 09:21:00 +00:00
"github.com/caos/zitadel/internal/telemetry/tracing"
iam_repo "github.com/caos/zitadel/internal/v2/repository/iam"
)
type QuerySide struct {
iamID string
2020-11-26 12:14:07 +00:00
eventstore *eventstore.Eventstore
idGenerator id.Generator
secretCrypto crypto.Crypto
}
type Config struct {
2020-11-26 12:14:07 +00:00
Eventstore *eventstore.Eventstore
SystemDefaults sd.SystemDefaults
}
func StartQuerySide(config *Config) (repo *QuerySide, err error) {
repo = &QuerySide{
iamID: config.SystemDefaults.IamID,
2020-11-26 12:14:07 +00:00
eventstore: config.Eventstore,
idGenerator: id.SonyFlakeGenerator,
}
2020-11-30 07:53:08 +00:00
iam_repo.RegisterEventMappers(repo.eventstore)
2020-11-26 12:14:07 +00:00
repo.secretCrypto, err = crypto.NewAESCrypto(config.SystemDefaults.IDPConfigVerificationKey)
if err != nil {
return nil, err
}
return repo, nil
}
func (r *QuerySide) 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 *QuerySide) 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
}