/
index.ts
62 lines (56 loc) 路 2.06 KB
/
index.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import { Route } from '@/types';
import got from '@/utils/got';
import { parseDate } from '@/utils/parse-date';
import MarkdownIt from 'markdown-it';
const md = MarkdownIt({
html: true,
linkify: true,
});
import { isValidHost } from '@/utils/valid-host';
import InvalidParameterError from '@/errors/types/invalid-parameter';
export const route: Route = {
path: '/:id',
categories: ['new-media'],
example: '/mirror/tingfei.eth',
parameters: { id: 'user id' },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false,
},
name: 'User',
maintainers: ['fifteen42', 'rde9', 'nczitzk'],
handler,
};
async function handler(ctx) {
const id = ctx.req.param('id');
if (!id.endsWith('.eth') && !isValidHost(id)) {
throw new InvalidParameterError('Invalid id');
}
const rootUrl = 'https://mirror.xyz';
const currentUrl = id.endsWith('.eth') ? `${rootUrl}/${id}` : `https://${id}.mirror.xyz`;
const response = await got(currentUrl);
const data = JSON.parse(response.data.match(/"__NEXT_DATA__" type="application\/json">({"props":.*})<\/script>/)[1]);
const items = Object.keys(data.props.pageProps.__APOLLO_STATE__)
.filter((key) => key.startsWith('entry:'))
.map((key) => {
const item = data.props.pageProps.__APOLLO_STATE__[key];
return {
title: item.title,
description: md.render(item.body),
link: `${currentUrl}/${item._id}`,
pubDate: parseDate(item.publishedAtTimestamp, 'X'),
author: data.props.pageProps.publicationLayoutProject.displayName,
};
});
return {
title: `${data.props.pageProps.publicationLayoutProject.displayName} - Mirror`,
description: data.props.pageProps.publicationLayoutProject.description,
image: data.props.pageProps.publicationLayoutProject.avatarURL,
link: currentUrl,
item: items,
};
}