* upd: attempt to turn MFM to html on mastodon * revert: recent change until better implementation later * chore: remove unused packages * Update docker.yml * upd: add MFM to HTML for timelines and status view * chore: lint * upd: megalodon resolve urls * upd: add spliting * test: local user mention * test: change local user url in mention * upd: change check * test: megalodon changes * upd: edit resolving of local users This is starting to drive me nuts * upd: remove the @ symbol in query * fix: make renderPerson return host instead of null for local * upd: change url for local user * upd: change limit * upd: add url to output * upd: add mastodon boolean * test: test different format * fix: test of different format * test: change up resolving * fix: forgot to provide url * upd: change lookup function a bit * test: substring * test: regex * upd: remove substr * test: new regexs * dirty test * test: one last attempt for today * upd: fix build error * upd: take input from iceshrimp dev * upd: parse remote statuses * upd: fix pleroma users misformatted urls * upd: add uri to normal user * fix: forgot to push updated types * fix: resolving broke * fix: html not converting correctly * fix: return default img if no banner * upd: swap out img used for no header, set fallback avatar * fix: html escaped & and ' symbols * upd: fix ' converting into 39; and get profile fields * upd: resolve fields on lookup --------- Co-authored-by: Amelia Yukii <123300075+Insert5StarName@users.noreply.github.com>
274 lines
7.5 KiB
TypeScript
274 lines
7.5 KiB
TypeScript
import { convertId, IdConvertType as IdType, convertAccount, convertRelationship, convertStatus } from '../converters.js';
|
|
import { argsToBools, convertTimelinesArgsId, limitToInt } from './timeline.js';
|
|
import type { MegalodonInterface } from 'megalodon';
|
|
import type { FastifyRequest } from 'fastify';
|
|
|
|
const relationshipModel = {
|
|
id: '',
|
|
following: false,
|
|
followed_by: false,
|
|
delivery_following: false,
|
|
blocking: false,
|
|
blocked_by: false,
|
|
muting: false,
|
|
muting_notifications: false,
|
|
requested: false,
|
|
domain_blocking: false,
|
|
showing_reblogs: false,
|
|
endorsed: false,
|
|
notifying: false,
|
|
note: '',
|
|
};
|
|
|
|
export class ApiAccountMastodon {
|
|
private request: FastifyRequest;
|
|
private client: MegalodonInterface;
|
|
private BASE_URL: string;
|
|
|
|
constructor(request: FastifyRequest, client: MegalodonInterface, BASE_URL: string) {
|
|
this.request = request;
|
|
this.client = client;
|
|
this.BASE_URL = BASE_URL;
|
|
}
|
|
|
|
public async verifyCredentials() {
|
|
try {
|
|
const data = await this.client.verifyAccountCredentials();
|
|
const acct = data.data;
|
|
acct.id = convertId(acct.id, IdType.MastodonId);
|
|
acct.display_name = acct.display_name || acct.username;
|
|
acct.url = `${this.BASE_URL}/@${acct.url}`;
|
|
acct.note = acct.note || '';
|
|
acct.avatar_static = acct.avatar;
|
|
acct.header = acct.header || '/static-assets/transparent.png';
|
|
acct.header_static = acct.header || '/static-assets/transparent.png';
|
|
acct.source = {
|
|
note: acct.note,
|
|
fields: acct.fields,
|
|
privacy: '',
|
|
sensitive: false,
|
|
language: '',
|
|
};
|
|
console.log(acct);
|
|
return acct;
|
|
} catch (e: any) {
|
|
/* console.error(e);
|
|
console.error(e.response.data); */
|
|
return e.response;
|
|
}
|
|
}
|
|
|
|
public async lookup() {
|
|
try {
|
|
const data = await this.client.search((this.request.query as any).acct, { type: 'accounts' });
|
|
return convertAccount(data.data.accounts[0]);
|
|
} catch (e: any) {
|
|
/* console.error(e)
|
|
console.error(e.response.data); */
|
|
return e.response;
|
|
}
|
|
}
|
|
|
|
public async getRelationships(users: [string]) {
|
|
try {
|
|
relationshipModel.id = users.toString() || '1';
|
|
|
|
if (!(users.length > 0)) {
|
|
return [relationshipModel];
|
|
}
|
|
|
|
const reqIds = [];
|
|
for (let i = 0; i < users.length; i++) {
|
|
reqIds.push(convertId(users[i], IdType.SharkeyId));
|
|
}
|
|
|
|
const data = await this.client.getRelationships(reqIds);
|
|
return data.data.map((relationship) => convertRelationship(relationship));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getStatuses() {
|
|
try {
|
|
const data = await this.client.getAccountStatuses(
|
|
convertId((this.request.params as any).id, IdType.SharkeyId),
|
|
convertTimelinesArgsId(argsToBools(limitToInt(this.request.query as any)))
|
|
);
|
|
return data.data.map((status) => convertStatus(status));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getFollowers() {
|
|
try {
|
|
const data = await this.client.getAccountFollowers(
|
|
convertId((this.request.params as any).id, IdType.SharkeyId),
|
|
convertTimelinesArgsId(limitToInt(this.request.query as any)),
|
|
);
|
|
return data.data.map((account) => convertAccount(account));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getFollowing() {
|
|
try {
|
|
const data = await this.client.getAccountFollowing(
|
|
convertId((this.request.params as any).id, IdType.SharkeyId),
|
|
convertTimelinesArgsId(limitToInt(this.request.query as any)),
|
|
);
|
|
return data.data.map((account) => convertAccount(account));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async addFollow() {
|
|
try {
|
|
const data = await this.client.followAccount( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
const acct = convertRelationship(data.data);
|
|
acct.following = true;
|
|
return acct;
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async rmFollow() {
|
|
try {
|
|
const data = await this.client.unfollowAccount( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
const acct = convertRelationship(data.data);
|
|
acct.following = false;
|
|
return acct;
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async addBlock() {
|
|
try {
|
|
const data = await this.client.blockAccount( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
return convertRelationship(data.data);
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async rmBlock() {
|
|
try {
|
|
const data = await this.client.unblockAccount( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
return convertRelationship(data.data);
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async addMute() {
|
|
try {
|
|
const data = await this.client.muteAccount(
|
|
convertId((this.request.params as any).id, IdType.SharkeyId),
|
|
this.request.body as any,
|
|
);
|
|
return convertRelationship(data.data);
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async rmMute() {
|
|
try {
|
|
const data = await this.client.unmuteAccount( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
return convertRelationship(data.data);
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getBookmarks() {
|
|
try {
|
|
const data = await this.client.getBookmarks( convertTimelinesArgsId(limitToInt(this.request.query as any)) );
|
|
return data.data.map((status) => convertStatus(status));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getFavourites() {
|
|
try {
|
|
const data = await this.client.getFavourites( convertTimelinesArgsId(limitToInt(this.request.query as any)) );
|
|
return data.data.map((status) => convertStatus(status));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getMutes() {
|
|
try {
|
|
const data = await this.client.getMutes( convertTimelinesArgsId(limitToInt(this.request.query as any)) );
|
|
return data.data.map((account) => convertAccount(account));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async getBlocks() {
|
|
try {
|
|
const data = await this.client.getBlocks( convertTimelinesArgsId(limitToInt(this.request.query as any)) );
|
|
return data.data.map((account) => convertAccount(account));
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async acceptFollow() {
|
|
try {
|
|
const data = await this.client.acceptFollowRequest( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
return convertRelationship(data.data);
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
|
|
public async rejectFollow() {
|
|
try {
|
|
const data = await this.client.rejectFollowRequest( convertId((this.request.params as any).id, IdType.SharkeyId) );
|
|
return convertRelationship(data.data);
|
|
} catch (e: any) {
|
|
console.error(e);
|
|
console.error(e.response.data);
|
|
return e.response.data;
|
|
}
|
|
}
|
|
}
|