mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 04:19:03 +00:00 
			
		
		
		
	fix(app): move queries to query package (#2612)
* fix: move queries to query package * fix(auth): switch project role requests to query pkg * refactor: delete unused project role code * remove repo * implement sql queries * fix(database): oidc config change type to int2 * fix(queries): implement app queries * refactor: simplify code * fix: correct app query * Update app.go * fix token check * fix mock * test: app prepares * test: oidc compliance * test: OIDCOriginAllowList * fix: converter * resolve unsupported oidc version Co-authored-by: Livio Amstutz <livio.a@gmail.com>
This commit is contained in:
		| @@ -93,63 +93,6 @@ func (repo *ProjectRepo) ProjectChanges(ctx context.Context, id string, lastSequ | ||||
| 	return changes, nil | ||||
| } | ||||
|  | ||||
| func (repo *ProjectRepo) ApplicationByID(ctx context.Context, projectID, appID string) (*proj_model.ApplicationView, error) { | ||||
| 	app, viewErr := repo.View.ApplicationByID(projectID, appID) | ||||
| 	if viewErr != nil && !caos_errs.IsNotFound(viewErr) { | ||||
| 		return nil, viewErr | ||||
| 	} | ||||
| 	if caos_errs.IsNotFound(viewErr) { | ||||
| 		app = new(model.ApplicationView) | ||||
| 		app.ID = appID | ||||
| 	} | ||||
|  | ||||
| 	events, esErr := repo.getProjectEvents(ctx, projectID, app.Sequence) | ||||
| 	if caos_errs.IsNotFound(viewErr) && len(events) == 0 { | ||||
| 		return nil, caos_errs.ThrowNotFound(nil, "EVENT-Fshu8", "Errors.Application.NotFound") | ||||
| 	} | ||||
|  | ||||
| 	if esErr != nil { | ||||
| 		logging.Log("EVENT-SLCo9").WithError(viewErr).Debug("error retrieving new events") | ||||
| 		return model.ApplicationViewToModel(app), nil | ||||
| 	} | ||||
|  | ||||
| 	viewApp := *app | ||||
| 	for _, event := range events { | ||||
| 		err := app.AppendEventIfMyApp(event) | ||||
| 		if err != nil { | ||||
| 			return model.ApplicationViewToModel(&viewApp), nil | ||||
| 		} | ||||
| 		if app.State == int32(proj_model.AppStateRemoved) { | ||||
| 			return nil, caos_errs.ThrowNotFound(nil, "EVENT-Msl96", "Errors.Application.NotFound") | ||||
| 		} | ||||
| 	} | ||||
| 	return model.ApplicationViewToModel(app), nil | ||||
| } | ||||
|  | ||||
| func (repo *ProjectRepo) SearchApplications(ctx context.Context, request *proj_model.ApplicationSearchRequest) (*proj_model.ApplicationSearchResponse, error) { | ||||
| 	err := request.EnsureLimit(repo.SearchLimit) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	sequence, sequenceErr := repo.View.GetLatestApplicationSequence() | ||||
| 	logging.Log("EVENT-SKe8s").OnError(sequenceErr).Warn("could not read latest application sequence") | ||||
| 	apps, count, err := repo.View.SearchApplications(request) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	result := &proj_model.ApplicationSearchResponse{ | ||||
| 		Offset:      request.Offset, | ||||
| 		Limit:       request.Limit, | ||||
| 		TotalResult: count, | ||||
| 		Result:      model.ApplicationViewsToModel(apps), | ||||
| 	} | ||||
| 	if sequenceErr == nil { | ||||
| 		result.Sequence = sequence.CurrentSequence | ||||
| 		result.Timestamp = sequence.LastSuccessfulSpoolerRun | ||||
| 	} | ||||
| 	return result, nil | ||||
| } | ||||
|  | ||||
| func (repo *ProjectRepo) ApplicationChanges(ctx context.Context, projectID string, appID string, lastSequence uint64, limit uint64, sortAscending bool, retention time.Duration) (*proj_model.ApplicationChanges, error) { | ||||
| 	changes, err := repo.getApplicationChanges(ctx, projectID, appID, lastSequence, limit, sortAscending, retention) | ||||
| 	if err != nil { | ||||
|   | ||||
| @@ -1,167 +0,0 @@ | ||||
| package handler | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/caos/zitadel/internal/eventstore/v1" | ||||
|  | ||||
| 	"github.com/caos/logging" | ||||
|  | ||||
| 	"github.com/caos/zitadel/internal/errors" | ||||
| 	"github.com/caos/zitadel/internal/eventstore/v1/models" | ||||
| 	"github.com/caos/zitadel/internal/eventstore/v1/query" | ||||
| 	es_sdk "github.com/caos/zitadel/internal/eventstore/v1/sdk" | ||||
| 	"github.com/caos/zitadel/internal/eventstore/v1/spooler" | ||||
| 	proj_model "github.com/caos/zitadel/internal/project/model" | ||||
| 	es_model "github.com/caos/zitadel/internal/project/repository/eventsourcing/model" | ||||
| 	proj_view "github.com/caos/zitadel/internal/project/repository/view" | ||||
| 	view_model "github.com/caos/zitadel/internal/project/repository/view/model" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	applicationTable = "management.applications" | ||||
| ) | ||||
|  | ||||
| type Application struct { | ||||
| 	handler | ||||
| 	subscription *v1.Subscription | ||||
| } | ||||
|  | ||||
| func newApplication( | ||||
| 	handler handler, | ||||
| ) *Application { | ||||
| 	h := &Application{ | ||||
| 		handler: handler, | ||||
| 	} | ||||
|  | ||||
| 	h.subscribe() | ||||
|  | ||||
| 	return h | ||||
| } | ||||
|  | ||||
| func (a *Application) subscribe() { | ||||
| 	a.subscription = a.es.Subscribe(a.AggregateTypes()...) | ||||
| 	go func() { | ||||
| 		for event := range a.subscription.Events { | ||||
| 			query.ReduceEvent(a, event) | ||||
| 		} | ||||
| 	}() | ||||
| } | ||||
|  | ||||
| func (a *Application) ViewModel() string { | ||||
| 	return applicationTable | ||||
| } | ||||
|  | ||||
| func (a *Application) Subscription() *v1.Subscription { | ||||
| 	return a.subscription | ||||
| } | ||||
|  | ||||
| func (_ *Application) AggregateTypes() []models.AggregateType { | ||||
| 	return []models.AggregateType{es_model.ProjectAggregate} | ||||
| } | ||||
|  | ||||
| func (a *Application) CurrentSequence() (uint64, error) { | ||||
| 	sequence, err := a.view.GetLatestApplicationSequence() | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	return sequence.CurrentSequence, nil | ||||
| } | ||||
|  | ||||
| func (a *Application) EventQuery() (*models.SearchQuery, error) { | ||||
| 	sequence, err := a.view.GetLatestApplicationSequence() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return proj_view.ProjectQuery(sequence.CurrentSequence), nil | ||||
| } | ||||
|  | ||||
| func (a *Application) Reduce(event *models.Event) (err error) { | ||||
| 	app := new(view_model.ApplicationView) | ||||
| 	switch event.Type { | ||||
| 	case es_model.ApplicationAdded: | ||||
| 		project, err := a.getProjectByID(context.Background(), event.AggregateID) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		app.ProjectRoleCheck = project.ProjectRoleCheck | ||||
| 		app.HasProjectCheck = project.HasProjectCheck | ||||
| 		app.ProjectRoleAssertion = project.ProjectRoleAssertion | ||||
| 		app.PrivateLabelingSetting = project.PrivateLabelingSetting | ||||
|  | ||||
| 		err = app.AppendEvent(event) | ||||
| 	case es_model.ApplicationChanged, | ||||
| 		es_model.OIDCConfigAdded, | ||||
| 		es_model.OIDCConfigChanged, | ||||
| 		es_model.APIConfigAdded, | ||||
| 		es_model.APIConfigChanged, | ||||
| 		es_model.ApplicationDeactivated, | ||||
| 		es_model.ApplicationReactivated: | ||||
| 		err = app.SetData(event) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		app, err = a.view.ApplicationByID(event.AggregateID, app.ID) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		err = app.AppendEvent(event) | ||||
| 	case es_model.ApplicationRemoved: | ||||
| 		err = app.SetData(event) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		return a.view.DeleteApplication(app.ID, event) | ||||
| 	case es_model.ProjectChanged: | ||||
| 		apps, err := a.view.ApplicationsByProjectID(event.AggregateID) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		if len(apps) == 0 { | ||||
| 			return a.view.ProcessedApplicationSequence(event) | ||||
| 		} | ||||
| 		for _, app := range apps { | ||||
| 			if err := app.AppendEvent(event); err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 		} | ||||
| 		return a.view.PutApplications(apps, event) | ||||
| 	case es_model.ProjectRemoved: | ||||
| 		return a.view.DeleteApplicationsByProjectID(event.AggregateID) | ||||
| 	default: | ||||
| 		return a.view.ProcessedApplicationSequence(event) | ||||
| 	} | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return a.view.PutApplication(app, event) | ||||
| } | ||||
|  | ||||
| func (a *Application) OnError(event *models.Event, spoolerError error) error { | ||||
| 	logging.LogWithFields("SPOOL-ls9ew", "id", event.AggregateID).WithError(spoolerError).Warn("something went wrong in project app handler") | ||||
| 	return spooler.HandleError(event, spoolerError, a.view.GetLatestApplicationFailedEvent, a.view.ProcessedApplicationFailedEvent, a.view.ProcessedApplicationSequence, a.errorCountUntilSkip) | ||||
| } | ||||
|  | ||||
| func (a *Application) OnSuccess() error { | ||||
| 	return spooler.HandleSuccess(a.view.UpdateApplicationSpoolerRunTimestamp) | ||||
| } | ||||
|  | ||||
| func (a *Application) getProjectByID(ctx context.Context, projID string) (*proj_model.Project, error) { | ||||
| 	query, err := proj_view.ProjectByIDQuery(projID, 0) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	esProject := &es_model.Project{ | ||||
| 		ObjectRoot: models.ObjectRoot{ | ||||
| 			AggregateID: projID, | ||||
| 		}, | ||||
| 	} | ||||
| 	err = es_sdk.Filter(ctx, a.Eventstore().FilterEvents, esProject.AppendEvents, query) | ||||
| 	if err != nil && !errors.IsNotFound(err) { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if esProject.Sequence == 0 { | ||||
| 		return nil, errors.ThrowNotFound(nil, "EVENT-ADvfs", "Errors.Project.NotFound") | ||||
| 	} | ||||
|  | ||||
| 	return es_model.ProjectToModel(esProject), nil | ||||
| } | ||||
| @@ -35,7 +35,6 @@ func Register(configs Configs, bulkLimit, errorCount uint64, view *view.View, es | ||||
| 	return []query.Handler{ | ||||
| 		newProjectMember(handler{view, bulkLimit, configs.cycleDuration("ProjectMember"), errorCount, es}), | ||||
| 		newProjectGrantMember(handler{view, bulkLimit, configs.cycleDuration("ProjectGrantMember"), errorCount, es}), | ||||
| 		newApplication(handler{view, bulkLimit, configs.cycleDuration("Application"), errorCount, es}), | ||||
| 		newUser(handler{view, bulkLimit, configs.cycleDuration("User"), errorCount, es}, | ||||
| 			defaults.IamID), | ||||
| 		newUserGrant(handler{view, bulkLimit, configs.cycleDuration("UserGrant"), errorCount, es}), | ||||
|   | ||||
| @@ -1,74 +0,0 @@ | ||||
| package view | ||||
|  | ||||
| import ( | ||||
| 	"github.com/caos/zitadel/internal/errors" | ||||
| 	"github.com/caos/zitadel/internal/eventstore/v1/models" | ||||
| 	proj_model "github.com/caos/zitadel/internal/project/model" | ||||
| 	"github.com/caos/zitadel/internal/project/repository/view" | ||||
| 	"github.com/caos/zitadel/internal/project/repository/view/model" | ||||
| 	"github.com/caos/zitadel/internal/view/repository" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	applicationTable = "management.applications" | ||||
| ) | ||||
|  | ||||
| func (v *View) ApplicationByID(projectID, appID string) (*model.ApplicationView, error) { | ||||
| 	return view.ApplicationByID(v.Db, applicationTable, projectID, appID) | ||||
| } | ||||
|  | ||||
| func (v *View) ApplicationsByProjectID(projectID string) ([]*model.ApplicationView, error) { | ||||
| 	return view.ApplicationsByProjectID(v.Db, applicationTable, projectID) | ||||
| } | ||||
|  | ||||
| func (v *View) SearchApplications(request *proj_model.ApplicationSearchRequest) ([]*model.ApplicationView, uint64, error) { | ||||
| 	return view.SearchApplications(v.Db, applicationTable, request) | ||||
| } | ||||
|  | ||||
| func (v *View) PutApplication(app *model.ApplicationView, event *models.Event) error { | ||||
| 	err := view.PutApplication(v.Db, applicationTable, app) | ||||
| 	if err != nil && !errors.IsNotFound(err) { | ||||
| 		return err | ||||
| 	} | ||||
| 	return v.ProcessedApplicationSequence(event) | ||||
| } | ||||
|  | ||||
| func (v *View) PutApplications(apps []*model.ApplicationView, event *models.Event) error { | ||||
| 	err := view.PutApplications(v.Db, applicationTable, apps...) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return v.ProcessedApplicationSequence(event) | ||||
| } | ||||
|  | ||||
| func (v *View) DeleteApplication(appID string, event *models.Event) error { | ||||
| 	err := view.DeleteApplication(v.Db, applicationTable, appID) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return v.ProcessedApplicationSequence(event) | ||||
| } | ||||
|  | ||||
| func (v *View) DeleteApplicationsByProjectID(projectID string) error { | ||||
| 	return view.DeleteApplicationsByProjectID(v.Db, applicationTable, projectID) | ||||
| } | ||||
|  | ||||
| func (v *View) GetLatestApplicationSequence() (*repository.CurrentSequence, error) { | ||||
| 	return v.latestSequence(applicationTable) | ||||
| } | ||||
|  | ||||
| func (v *View) ProcessedApplicationSequence(event *models.Event) error { | ||||
| 	return v.saveCurrentSequence(applicationTable, event) | ||||
| } | ||||
|  | ||||
| func (v *View) UpdateApplicationSpoolerRunTimestamp() error { | ||||
| 	return v.updateSpoolerRunSequence(applicationTable) | ||||
| } | ||||
|  | ||||
| func (v *View) GetLatestApplicationFailedEvent(sequence uint64) (*repository.FailedEvent, error) { | ||||
| 	return v.latestFailedEvent(applicationTable, sequence) | ||||
| } | ||||
|  | ||||
| func (v *View) ProcessedApplicationFailedEvent(failedEvent *repository.FailedEvent) error { | ||||
| 	return v.saveFailedEvent(failedEvent) | ||||
| } | ||||
| @@ -17,8 +17,6 @@ type ProjectRepository interface { | ||||
|  | ||||
| 	ProjectChanges(ctx context.Context, id string, lastSequence uint64, limit uint64, sortAscending bool, retention time.Duration) (*model.ProjectChanges, error) | ||||
|  | ||||
| 	ApplicationByID(ctx context.Context, projectID, appID string) (*model.ApplicationView, error) | ||||
| 	SearchApplications(ctx context.Context, request *model.ApplicationSearchRequest) (*model.ApplicationSearchResponse, error) | ||||
| 	ApplicationChanges(ctx context.Context, projectID string, appID string, lastSequence uint64, limit uint64, sortAscending bool, retention time.Duration) (*model.ApplicationChanges, error) | ||||
| 	SearchClientKeys(ctx context.Context, request *key_model.AuthNKeySearchRequest) (*key_model.AuthNKeySearchResponse, error) | ||||
| 	GetClientKey(ctx context.Context, projectID, applicationID, keyID string) (*key_model.AuthNKeyView, error) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Silvan
					Silvan