diff options
| author | かっこかり <67428053+kakkokari-gtyih@users.noreply.github.com> | 2023-10-28 07:54:06 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-10-28 07:54:06 +0900 |
| commit | e5ff8d8445668eb2bcd1e9fa38a2d0041b6ca678 (patch) | |
| tree | bbc9701bb52038b4d1e470aa95fcb5a57e566036 /packages/backend/src/server | |
| parent | fix(backend): ハッシュタグのランキングの問い合わせ結果が... (diff) | |
| download | sharkey-e5ff8d8445668eb2bcd1e9fa38a2d0041b6ca678.tar.gz sharkey-e5ff8d8445668eb2bcd1e9fa38a2d0041b6ca678.tar.bz2 sharkey-e5ff8d8445668eb2bcd1e9fa38a2d0041b6ca678.zip | |
enhance: プラグイン削除時にアクセストークンも削除する (#12167)
* (enhance) プラグイン削除時にトークンも削除
* update changelog
Diffstat (limited to 'packages/backend/src/server')
| -rw-r--r-- | packages/backend/src/server/api/endpoints/i/revoke-token.ts | 29 |
1 files changed, 22 insertions, 7 deletions
diff --git a/packages/backend/src/server/api/endpoints/i/revoke-token.ts b/packages/backend/src/server/api/endpoints/i/revoke-token.ts index 8e2f271005..e8bb282533 100644 --- a/packages/backend/src/server/api/endpoints/i/revoke-token.ts +++ b/packages/backend/src/server/api/endpoints/i/revoke-token.ts @@ -18,8 +18,12 @@ export const paramDef = { type: 'object', properties: { tokenId: { type: 'string', format: 'misskey:id' }, + token: { type: 'string' }, }, - required: ['tokenId'], + anyOf: [ + { required: ['tokenId'] }, + { required: ['token'] }, + ], } as const; @Injectable() @@ -29,13 +33,24 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- private accessTokensRepository: AccessTokensRepository, ) { super(meta, paramDef, async (ps, me) => { - const tokenExist = await this.accessTokensRepository.exist({ where: { id: ps.tokenId } }); + if (ps.tokenId) { + const tokenExist = await this.accessTokensRepository.exist({ where: { id: ps.tokenId } }); - if (tokenExist) { - await this.accessTokensRepository.delete({ - id: ps.tokenId, - userId: me.id, - }); + if (tokenExist) { + await this.accessTokensRepository.delete({ + id: ps.tokenId, + userId: me.id, + }); + } + } else if (ps.token) { + const tokenExist = await this.accessTokensRepository.exist({ where: { token: ps.token } }); + + if (tokenExist) { + await this.accessTokensRepository.delete({ + token: ps.token, + userId: me.id, + }); + } } }); } |