mirror of
https://git.joinfirefish.org/firefish/firefish.git
synced 2024-05-18 21:21:10 +02:00
717aa899b1
This commit adds (maybe unstable) support for Mastodons v1 api also some v2 endpoints, maybe I miss stuff, I dont know. We will need to test this but it should be kinda stable and work like (old) butter. Co-authored-by: Natty <natty.sh.git@gmail.com> Co-authored-by: cutls <web-pro@cutls.com>
90 lines
2.9 KiB
TypeScript
90 lines
2.9 KiB
TypeScript
import megalodon, { MegalodonInterface } from '@cutls/megalodon';
|
|
import Router from "@koa/router";
|
|
import { koaBody } from 'koa-body';
|
|
import { getClient } from '../ApiMastodonCompatibleService.js';
|
|
import { toTextWithReaction } from './timeline.js';
|
|
function toLimitToInt(q: any) {
|
|
if (q.limit) if (typeof q.limit === 'string') q.limit = parseInt(q.limit, 10)
|
|
return q
|
|
}
|
|
|
|
export function apiNotificationMastodon(router: Router): void {
|
|
|
|
router.get('/v1/notifications', koaBody(), async (ctx) => {
|
|
const BASE_URL = `${ctx.request.protocol}://${ctx.request.hostname}`;
|
|
const accessTokens = ctx.request.headers.authorization;
|
|
const client = getClient(BASE_URL, accessTokens);
|
|
const body: any = ctx.request.body;
|
|
try {
|
|
const data = await client.getNotifications(toLimitToInt(ctx.query));
|
|
const notfs = data.data;
|
|
const ret = notfs.map((n) => {
|
|
if(n.type !== 'follow' && n.type !== 'follow_request') {
|
|
if (n.type === 'reaction') n.type = 'favourite'
|
|
n.status = toTextWithReaction(n.status ? [n.status] : [], ctx.hostname)[0]
|
|
return n
|
|
} else {
|
|
return n
|
|
}
|
|
})
|
|
ctx.body = ret;
|
|
} catch (e: any) {
|
|
console.error(e)
|
|
ctx.status = 401;
|
|
ctx.body = e.response.data;
|
|
}
|
|
});
|
|
|
|
router.get('/v1/notification/:id', koaBody(), async (ctx) => {
|
|
const BASE_URL = `${ctx.request.protocol}://${ctx.request.hostname}`;
|
|
const accessTokens = ctx.request.headers.authorization;
|
|
const client = getClient(BASE_URL, accessTokens);
|
|
const body: any = ctx.request.body;
|
|
try {
|
|
const dataRaw = await client.getNotification(ctx.params.id);
|
|
const data = dataRaw.data;
|
|
if(data.type !== 'follow' && data.type !== 'follow_request') {
|
|
if (data.type === 'reaction') data.type = 'favourite'
|
|
ctx.body = toTextWithReaction([data as any], ctx.request.hostname)[0]
|
|
} else {
|
|
ctx.body = data
|
|
}
|
|
} catch (e: any) {
|
|
console.error(e)
|
|
ctx.status = 401;
|
|
ctx.body = e.response.data;
|
|
}
|
|
});
|
|
|
|
router.post('/v1/notifications/clear', koaBody(), async (ctx) => {
|
|
const BASE_URL = `${ctx.request.protocol}://${ctx.request.hostname}`;
|
|
const accessTokens = ctx.request.headers.authorization;
|
|
const client = getClient(BASE_URL, accessTokens);
|
|
const body: any = ctx.request.body;
|
|
try {
|
|
const data = await client.dismissNotifications();
|
|
ctx.body = data.data;
|
|
} catch (e: any) {
|
|
console.error(e)
|
|
ctx.status = 401;
|
|
ctx.body = e.response.data;
|
|
}
|
|
});
|
|
|
|
router.post('/v1/notification/:id/dismiss', koaBody(), async (ctx) => {
|
|
const BASE_URL = `${ctx.request.protocol}://${ctx.request.hostname}`;
|
|
const accessTokens = ctx.request.headers.authorization;
|
|
const client = getClient(BASE_URL, accessTokens);
|
|
const body: any = ctx.request.body;
|
|
try {
|
|
const data = await client.dismissNotification(ctx.params.id);
|
|
ctx.body = data.data;
|
|
} catch (e: any) {
|
|
console.error(e)
|
|
ctx.status = 401;
|
|
ctx.body = e.response.data;
|
|
}
|
|
});
|
|
|
|
}
|