rsshub
Version:
Make RSS Great Again!
54 lines (48 loc) • 1.74 kB
text/typescript
import { Route } from '@/types';
import { parseDate } from '@/utils/parse-date';
import { getAccountByUsername, getTimelineByAccountId, parseDescription, baseUrl } from './utils';
export const route: Route = {
path: '/user/:username',
categories: ['social-media'],
example: '/fansly/user/AeriGoMoo',
parameters: { username: 'User ID' },
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false,
},
radar: [
{
source: ['fansly.com/:username/posts', 'fansly.com/:username/media'],
},
],
name: 'User Timeline',
maintainers: ['TonyRL'],
handler,
};
async function handler(ctx) {
const username = ctx.req.param('username');
const account = await getAccountByUsername(username);
const timeline = await getTimelineByAccountId(account.id);
const items = timeline.posts.map((post) => ({
title: post.content.split('\n')[0],
description: parseDescription(post, timeline),
pubDate: parseDate(post.createdAt, 'X'),
link: `${baseUrl}/post/${post.id}`,
author: `${account.displayName ?? account.username} (@${account.username})`,
}));
return {
title: `${account.displayName ?? account.username} (@${account.username}) - Fansly`,
link: `${baseUrl}/${account.username}`,
description: account.about.replaceAll('\n', ' '),
image: account.banner.locations[0].location,
icon: account.avatar.locations[0].location,
logo: account.avatar.locations[0].location,
language: 'en',
allowEmpty: true,
item: items,
};
}