diff options
author | 2022-03-19 12:01:40 +0100 | |
---|---|---|
committer | 2022-03-19 12:01:40 +0100 | |
commit | 55ad6dee716112e1a6c95cd53af0680ab3e8679a (patch) | |
tree | 37fe44052801ca3178a9a1c19a0a1ddddbbda96d /internal/processing/admin | |
parent | [feature] Federate local account deletion (#431) (diff) | |
download | gotosocial-55ad6dee716112e1a6c95cd53af0680ab3e8679a.tar.xz |
[feature] Admin account actions (#432)
* add accountAction to the admin API
* model admin account action
* add admin account action to the processor
* add migration for new AdminAccountActions table
* fix accounts admin path
* Update swagger docs
Diffstat (limited to 'internal/processing/admin')
-rw-r--r-- | internal/processing/admin/accountaction.go | 52 | ||||
-rw-r--r-- | internal/processing/admin/admin.go | 1 |
2 files changed, 53 insertions, 0 deletions
diff --git a/internal/processing/admin/accountaction.go b/internal/processing/admin/accountaction.go new file mode 100644 index 000000000..c9b2edf64 --- /dev/null +++ b/internal/processing/admin/accountaction.go @@ -0,0 +1,52 @@ +package admin + +import ( + "context" + "fmt" + + "github.com/superseriousbusiness/gotosocial/internal/ap" + apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model" + "github.com/superseriousbusiness/gotosocial/internal/gtserror" + "github.com/superseriousbusiness/gotosocial/internal/gtsmodel" + "github.com/superseriousbusiness/gotosocial/internal/id" + "github.com/superseriousbusiness/gotosocial/internal/messages" +) + +func (p *processor) AccountAction(ctx context.Context, account *gtsmodel.Account, form *apimodel.AdminAccountActionRequest) gtserror.WithCode { + targetAccount, err := p.db.GetAccountByID(ctx, form.TargetAccountID) + if err != nil { + return gtserror.NewErrorInternalError(err) + } + + adminActionID, err := id.NewULID() + if err != nil { + return gtserror.NewErrorInternalError(err) + } + + adminAction := >smodel.AdminAccountAction{ + ID: adminActionID, + AccountID: account.ID, + TargetAccountID: targetAccount.ID, + Text: form.Text, + } + + switch form.Type { + case string(gtsmodel.AdminActionSuspend): + adminAction.Type = gtsmodel.AdminActionSuspend + // pass the account delete through the client api channel for processing + p.fromClientAPI <- messages.FromClientAPI{ + APObjectType: ap.ActorPerson, + APActivityType: ap.ActivityDelete, + OriginAccount: account, + TargetAccount: targetAccount, + } + default: + return gtserror.NewErrorBadRequest(fmt.Errorf("admin action type %s is not supported for this endpoint", form.Type)) + } + + if err := p.db.Put(ctx, adminAction); err != nil { + return gtserror.NewErrorInternalError(err) + } + + return nil +} diff --git a/internal/processing/admin/admin.go b/internal/processing/admin/admin.go index bdb586588..28d47acf1 100644 --- a/internal/processing/admin/admin.go +++ b/internal/processing/admin/admin.go @@ -38,6 +38,7 @@ type Processor interface { DomainBlocksGet(ctx context.Context, account *gtsmodel.Account, export bool) ([]*apimodel.DomainBlock, gtserror.WithCode) DomainBlockGet(ctx context.Context, account *gtsmodel.Account, id string, export bool) (*apimodel.DomainBlock, gtserror.WithCode) DomainBlockDelete(ctx context.Context, account *gtsmodel.Account, id string) (*apimodel.DomainBlock, gtserror.WithCode) + AccountAction(ctx context.Context, account *gtsmodel.Account, form *apimodel.AdminAccountActionRequest) gtserror.WithCode EmojiCreate(ctx context.Context, account *gtsmodel.Account, user *gtsmodel.User, form *apimodel.EmojiCreateRequest) (*apimodel.Emoji, gtserror.WithCode) } |