diff --git a/docs/api/swagger.yaml b/docs/api/swagger.yaml index 8e3c942c2b..8bd6e3725b 100644 --- a/docs/api/swagger.yaml +++ b/docs/api/swagger.yaml @@ -3316,7 +3316,6 @@ paths: post: consumes: - multipart/form-data - description: NOT IMPLEMENTED YET! operationId: accountMove parameters: - description: Password of the account user, for confirmation. diff --git a/internal/api/client/accounts/accountmove.go b/internal/api/client/accounts/accountmove.go index 4f311e1066..3698c06a3d 100644 --- a/internal/api/client/accounts/accountmove.go +++ b/internal/api/client/accounts/accountmove.go @@ -31,8 +31,6 @@ import ( // // Move your account to another account. // -// NOT IMPLEMENTED YET! -// // --- // tags: // - accounts diff --git a/internal/api/client/accounts/accounts.go b/internal/api/client/accounts/accounts.go index 000c27d786..c94fbfbaac 100644 --- a/internal/api/client/accounts/accounts.go +++ b/internal/api/client/accounts/accounts.go @@ -113,5 +113,5 @@ func (m *Module) Route(attachHandler func(method string, path string, f ...gin.H // migration handlers attachHandler(http.MethodPost, AliasPath, m.AccountAliasPOSTHandler) - // attachHandler(http.MethodPost, MovePath, m.AccountMovePOSTHandler) // todo: enable this only when Move is completed + attachHandler(http.MethodPost, MovePath, m.AccountMovePOSTHandler) } diff --git a/internal/processing/account/move.go b/internal/processing/account/move.go index ca8dd4deac..a68c8f750f 100644 --- a/internal/processing/account/move.go +++ b/internal/processing/account/move.go @@ -154,6 +154,17 @@ func (p *Processor) MoveSelf( } } + // If originAcct has already moved, ensure + // this move reattempt is to the same account. + if originAcct.IsMoving() && + originAcct.MovedToURI != targetAcct.URI { + err := fmt.Errorf( + "your account is already Moving or has Moved to %s; you cannot also Move to %s", + originAcct.MovedToURI, targetAcct.URI, + ) + return gtserror.NewErrorUnprocessableEntity(err, err.Error()) + } + // Target account MUST be aliased to this // account for this to be a valid Move. if !slices.Contains(targetAcct.AlsoKnownAsURIs, originAcct.URI) { diff --git a/web/source/settings/user/migration.tsx b/web/source/settings/user/migration.tsx index d0c5e3393a..9dfa3a75bd 100644 --- a/web/source/settings/user/migration.tsx +++ b/web/source/settings/user/migration.tsx @@ -40,49 +40,23 @@ export default function UserMigration() { } function UserMigrationForm({ data: profile }) { - let urlStr = store.getState().oauth.instanceUrl ?? ""; - let url = new URL(urlStr); - return ( <>
- The following settings allow you to alias your account to another account - elsewhere, and to move your followers and following lists to another account. + The following settings allow you to alias your account to + another account elsewhere, or to move to another account.
Account aliasing is harmless and reversible; you can set and unset up to five account aliases as many times as you wish.
- The account move action, on the other hand, has serious and irreversible consequences. -
-- To move, you must set an alias from your account to the target account, using this settings panel. + The account move action, on the other + hand, has serious and irreversible consequences.
- You must also set an alias from the target account back to your account, using - the settings panel of the instance on which the target account resides. -
-- Provide the following details to the other instance: -
-- For more information on account migration, please see the documentation. + For more information on account migration, please see the documentation.