summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/i
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2022-04-02 15:28:49 +0900
committerGitHub <noreply@github.com>2022-04-02 15:28:49 +0900
commit8e5f2690f29b7e6bee95e54a8bb647ff1ff4b94a (patch)
tree78740472dc48e4fec6986056f548e4ee7743cc29 /packages/backend/src/server/api/endpoints/i
parentUpdate CHANGELOG.md (diff)
downloadsharkey-8e5f2690f29b7e6bee95e54a8bb647ff1ff4b94a.tar.gz
sharkey-8e5f2690f29b7e6bee95e54a8bb647ff1ff4b94a.tar.bz2
sharkey-8e5f2690f29b7e6bee95e54a8bb647ff1ff4b94a.zip
feat: Webhook (#8457)
* feat: introduce webhook * wip * wip * wip * Update CHANGELOG.md
Diffstat (limited to 'packages/backend/src/server/api/endpoints/i')
-rw-r--r--packages/backend/src/server/api/endpoints/i/webhooks/create.ts43
-rw-r--r--packages/backend/src/server/api/endpoints/i/webhooks/delete.ts44
-rw-r--r--packages/backend/src/server/api/endpoints/i/webhooks/list.ts25
-rw-r--r--packages/backend/src/server/api/endpoints/i/webhooks/show.ts41
-rw-r--r--packages/backend/src/server/api/endpoints/i/webhooks/update.ts59
5 files changed, 212 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/i/webhooks/create.ts b/packages/backend/src/server/api/endpoints/i/webhooks/create.ts
new file mode 100644
index 0000000000..2e2fd00b8c
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/i/webhooks/create.ts
@@ -0,0 +1,43 @@
+import define from '../../../define.js';
+import { genId } from '@/misc/gen-id.js';
+import { Webhooks } from '@/models/index.js';
+import { publishInternalEvent } from '@/services/stream.js';
+import { webhookEventTypes } from '@/models/entities/webhook.js';
+
+export const meta = {
+ tags: ['webhooks'],
+
+ requireCredential: true,
+
+ kind: 'write:account',
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ name: { type: 'string', minLength: 1, maxLength: 100 },
+ url: { type: 'string', minLength: 1, maxLength: 1024 },
+ secret: { type: 'string', minLength: 1, maxLength: 1024 },
+ on: { type: 'array', items: {
+ type: 'string', enum: webhookEventTypes,
+ } },
+ },
+ required: ['name', 'url', 'secret', 'on'],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+export default define(meta, paramDef, async (ps, user) => {
+ const webhook = await Webhooks.insert({
+ id: genId(),
+ createdAt: new Date(),
+ userId: user.id,
+ name: ps.name,
+ url: ps.url,
+ secret: ps.secret,
+ on: ps.on,
+ }).then(x => Webhooks.findOneByOrFail(x.identifiers[0]));
+
+ publishInternalEvent('webhookCreated', webhook);
+
+ return webhook;
+});
diff --git a/packages/backend/src/server/api/endpoints/i/webhooks/delete.ts b/packages/backend/src/server/api/endpoints/i/webhooks/delete.ts
new file mode 100644
index 0000000000..2821eaa5f1
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/i/webhooks/delete.ts
@@ -0,0 +1,44 @@
+import define from '../../../define.js';
+import { ApiError } from '../../../error.js';
+import { Webhooks } from '@/models/index.js';
+import { publishInternalEvent } from '@/services/stream.js';
+
+export const meta = {
+ tags: ['webhooks'],
+
+ requireCredential: true,
+
+ kind: 'write:account',
+
+ errors: {
+ noSuchWebhook: {
+ message: 'No such webhook.',
+ code: 'NO_SUCH_WEBHOOK',
+ id: 'bae73e5a-5522-4965-ae19-3a8688e71d82',
+ },
+ },
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ webhookId: { type: 'string', format: 'misskey:id' },
+ },
+ required: ['webhookId'],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+export default define(meta, paramDef, async (ps, user) => {
+ const webhook = await Webhooks.findOneBy({
+ id: ps.webhookId,
+ userId: user.id,
+ });
+
+ if (webhook == null) {
+ throw new ApiError(meta.errors.noSuchWebhook);
+ }
+
+ await Webhooks.delete(webhook.id);
+
+ publishInternalEvent('webhookDeleted', webhook);
+});
diff --git a/packages/backend/src/server/api/endpoints/i/webhooks/list.ts b/packages/backend/src/server/api/endpoints/i/webhooks/list.ts
new file mode 100644
index 0000000000..54e4563732
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/i/webhooks/list.ts
@@ -0,0 +1,25 @@
+import define from '../../../define.js';
+import { Webhooks } from '@/models/index.js';
+
+export const meta = {
+ tags: ['webhooks', 'account'],
+
+ requireCredential: true,
+
+ kind: 'read:account',
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {},
+ required: [],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+export default define(meta, paramDef, async (ps, me) => {
+ const webhooks = await Webhooks.findBy({
+ userId: me.id,
+ });
+
+ return webhooks;
+});
diff --git a/packages/backend/src/server/api/endpoints/i/webhooks/show.ts b/packages/backend/src/server/api/endpoints/i/webhooks/show.ts
new file mode 100644
index 0000000000..02fa1edb5e
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/i/webhooks/show.ts
@@ -0,0 +1,41 @@
+import define from '../../../define.js';
+import { ApiError } from '../../../error.js';
+import { Webhooks } from '@/models/index.js';
+
+export const meta = {
+ tags: ['webhooks'],
+
+ requireCredential: true,
+
+ kind: 'read:account',
+
+ errors: {
+ noSuchWebhook: {
+ message: 'No such webhook.',
+ code: 'NO_SUCH_WEBHOOK',
+ id: '50f614d9-3047-4f7e-90d8-ad6b2d5fb098',
+ },
+ },
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ webhookId: { type: 'string', format: 'misskey:id' },
+ },
+ required: ['webhookId'],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+export default define(meta, paramDef, async (ps, user) => {
+ const webhook = await Webhooks.findOneBy({
+ id: ps.webhookId,
+ userId: user.id,
+ });
+
+ if (webhook == null) {
+ throw new ApiError(meta.errors.noSuchWebhook);
+ }
+
+ return webhook;
+});
diff --git a/packages/backend/src/server/api/endpoints/i/webhooks/update.ts b/packages/backend/src/server/api/endpoints/i/webhooks/update.ts
new file mode 100644
index 0000000000..f87b9753fb
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/i/webhooks/update.ts
@@ -0,0 +1,59 @@
+import define from '../../../define.js';
+import { ApiError } from '../../../error.js';
+import { Webhooks } from '@/models/index.js';
+import { publishInternalEvent } from '@/services/stream.js';
+import { webhookEventTypes } from '@/models/entities/webhook.js';
+
+export const meta = {
+ tags: ['webhooks'],
+
+ requireCredential: true,
+
+ kind: 'write:account',
+
+ errors: {
+ noSuchWebhook: {
+ message: 'No such webhook.',
+ code: 'NO_SUCH_WEBHOOK',
+ id: 'fb0fea69-da18-45b1-828d-bd4fd1612518',
+ },
+ },
+
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ webhookId: { type: 'string', format: 'misskey:id' },
+ name: { type: 'string', minLength: 1, maxLength: 100 },
+ url: { type: 'string', minLength: 1, maxLength: 1024 },
+ secret: { type: 'string', minLength: 1, maxLength: 1024 },
+ on: { type: 'array', items: {
+ type: 'string', enum: webhookEventTypes,
+ } },
+ active: { type: 'boolean' },
+ },
+ required: ['webhookId', 'name', 'url', 'secret', 'on', 'active'],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+export default define(meta, paramDef, async (ps, user) => {
+ const webhook = await Webhooks.findOneBy({
+ id: ps.webhookId,
+ userId: user.id,
+ });
+
+ if (webhook == null) {
+ throw new ApiError(meta.errors.noSuchWebhook);
+ }
+
+ await Webhooks.update(webhook.id, {
+ name: ps.name,
+ url: ps.url,
+ secret: ps.secret,
+ on: ps.on,
+ active: ps.active,
+ });
+
+ publishInternalEvent('webhookUpdated', webhook);
+});