2021-11-11 09:10:24 -06:00
|
|
|
package serviceaccounts
|
|
|
|
|
2021-12-14 07:39:25 -06:00
|
|
|
import (
|
|
|
|
"context"
|
2023-01-31 02:51:55 -06:00
|
|
|
|
|
|
|
"github.com/grafana/grafana/pkg/services/apikey"
|
2021-12-14 07:39:25 -06:00
|
|
|
)
|
2021-11-11 09:10:24 -06:00
|
|
|
|
2022-11-04 07:39:54 -05:00
|
|
|
/*
|
|
|
|
ServiceAccountService is the service that manages service accounts.
|
|
|
|
|
|
|
|
Service accounts are used to authenticate API requests. They are not users and
|
|
|
|
do not have a password.
|
|
|
|
*/
|
2023-10-27 06:46:25 -05:00
|
|
|
|
|
|
|
//go:generate mockery --name Service --structname MockServiceAccountService --output tests --outpkg tests --filename mocks.go
|
2021-11-11 09:10:24 -06:00
|
|
|
type Service interface {
|
2022-07-07 11:32:56 -05:00
|
|
|
CreateServiceAccount(ctx context.Context, orgID int64, saForm *CreateServiceAccountForm) (*ServiceAccountDTO, error)
|
2021-11-11 09:10:24 -06:00
|
|
|
DeleteServiceAccount(ctx context.Context, orgID, serviceAccountID int64) error
|
2022-12-13 07:56:10 -06:00
|
|
|
RetrieveServiceAccount(ctx context.Context, orgID, serviceAccountID int64) (*ServiceAccountProfileDTO, error)
|
2022-04-12 12:34:04 -05:00
|
|
|
RetrieveServiceAccountIdByName(ctx context.Context, orgID int64, name string) (int64, error)
|
2023-10-24 08:54:14 -05:00
|
|
|
SearchOrgServiceAccounts(ctx context.Context, query *SearchOrgServiceAccountsQuery) (*SearchOrgServiceAccountsResult, error)
|
2023-10-27 06:46:25 -05:00
|
|
|
EnableServiceAccount(ctx context.Context, orgID, serviceAccountID int64, enable bool) error
|
2023-10-25 05:40:30 -05:00
|
|
|
UpdateServiceAccount(ctx context.Context, orgID, serviceAccountID int64,
|
|
|
|
saForm *UpdateServiceAccountForm) (*ServiceAccountProfileDTO, error)
|
|
|
|
|
|
|
|
// Tokens
|
|
|
|
AddServiceAccountToken(ctx context.Context, serviceAccountID int64,
|
|
|
|
cmd *AddServiceAccountTokenCommand) (*apikey.APIKey, error)
|
|
|
|
DeleteServiceAccountToken(ctx context.Context, orgID, serviceAccountID, tokenID int64) error
|
|
|
|
ListTokens(ctx context.Context, query *GetSATokensQuery) ([]apikey.APIKey, error)
|
|
|
|
|
|
|
|
// API specific functions
|
|
|
|
MigrateApiKey(ctx context.Context, orgID int64, keyId int64) error
|
|
|
|
MigrateApiKeysToServiceAccounts(ctx context.Context, orgID int64) (*MigrationResult, error)
|
2021-11-11 09:10:24 -06:00
|
|
|
}
|
2023-10-24 04:01:04 -05:00
|
|
|
|
|
|
|
//go:generate mockery --name ExtSvcAccountsService --structname MockExtSvcAccountsService --output tests --outpkg tests --filename extsvcaccmock.go
|
|
|
|
type ExtSvcAccountsService interface {
|
2023-10-27 06:46:25 -05:00
|
|
|
// EnableExtSvcAccount enables or disables the service account associated to an external service
|
|
|
|
EnableExtSvcAccount(ctx context.Context, cmd *EnableExtSvcAccountCmd) error
|
2023-10-24 04:01:04 -05:00
|
|
|
// ManageExtSvcAccount creates, updates or deletes the service account associated with an external service
|
|
|
|
ManageExtSvcAccount(ctx context.Context, cmd *ManageExtSvcAccountCmd) (int64, error)
|
2023-11-13 06:18:13 -06:00
|
|
|
// RemoveExtSvcAccount removes the external service account associated with an external service
|
|
|
|
RemoveExtSvcAccount(ctx context.Context, orgID int64, extSvcSlug string) error
|
2023-10-24 04:01:04 -05:00
|
|
|
// RetrieveExtSvcAccount fetches an external service account by ID
|
|
|
|
RetrieveExtSvcAccount(ctx context.Context, orgID, saID int64) (*ExtSvcAccount, error)
|
|
|
|
}
|