megalodon
Version:
Fediverse API client for node.js and browser
514 lines (513 loc) • 19.1 kB
JavaScript
import axios from 'axios';
import objectAssignDeep from 'object-assign-deep';
import { RequestCanceledError } from '../cancel.js';
import { NO_REDIRECT, DEFAULT_SCOPE, DEFAULT_UA } from '../default.js';
import NotificationType, { UnknownNotificationTypeError } from '../notification.js';
import PixelfedNotificationType from './notification.js';
import Streaming from './web_socket.js';
var PixelfedAPI;
(function (PixelfedAPI) {
class Client {
static DEFAULT_SCOPE = DEFAULT_SCOPE;
static DEFAULT_URL = 'https://pixelfed.social';
static NO_REDIRECT = NO_REDIRECT;
accessToken;
baseUrl;
abortController;
constructor(baseUrl, accessToken = null, _userAgent = DEFAULT_UA) {
this.accessToken = accessToken;
this.baseUrl = baseUrl;
this.abortController = new AbortController();
axios.defaults.signal = this.abortController.signal;
}
async get(path, params = {}, headers = {}, pathIsFullyQualified = false) {
let options = {
params: params,
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios
.get((pathIsFullyQualified ? '' : this.baseUrl) + path, options)
.catch((err) => {
if (axios.isCancel(err)) {
throw new RequestCanceledError(err.message);
}
else {
throw err;
}
})
.then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async put(path, params = {}, headers = {}) {
let options = {
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios
.put(this.baseUrl + path, params, options)
.catch((err) => {
if (axios.isCancel(err)) {
throw new RequestCanceledError(err.message);
}
else {
throw err;
}
})
.then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async putForm(path, params = {}, headers = {}) {
let options = {
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios
.putForm(this.baseUrl + path, params, options)
.catch((err) => {
if (axios.isCancel(err)) {
throw new RequestCanceledError(err.message);
}
else {
throw err;
}
})
.then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async patch(path, params = {}, headers = {}) {
let options = {
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios
.patch(this.baseUrl + path, params, options)
.catch((err) => {
if (axios.isCancel(err)) {
throw new RequestCanceledError(err.message);
}
else {
throw err;
}
})
.then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async patchForm(path, params = {}, headers = {}) {
let options = {
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios
.patchForm(this.baseUrl + path, params, options)
.catch((err) => {
if (axios.isCancel(err)) {
throw new RequestCanceledError(err.message);
}
else {
throw err;
}
})
.then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async post(path, params = {}, headers = {}) {
let options = {
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios.post(this.baseUrl + path, params, options).then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async postForm(path, params = {}, headers = {}) {
let options = {
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios.postForm(this.baseUrl + path, params, options).then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
async del(path, params = {}, headers = {}) {
let options = {
data: params,
headers: headers,
maxContentLength: Infinity,
maxBodyLength: Infinity
};
if (this.accessToken) {
options = objectAssignDeep({}, options, {
headers: {
Authorization: `Bearer ${this.accessToken}`
}
});
}
return axios
.delete(this.baseUrl + path, options)
.catch((err) => {
if (axios.isCancel(err)) {
throw new RequestCanceledError(err.message);
}
else {
throw err;
}
})
.then((resp) => {
const res = {
data: resp.data,
status: resp.status,
statusText: resp.statusText,
headers: resp.headers
};
return res;
});
}
cancel() {
return this.abortController.abort();
}
socket() {
return new Streaming();
}
}
PixelfedAPI.Client = Client;
let Converter;
(function (Converter) {
Converter.encodeNotificationType = (t) => {
switch (t) {
case NotificationType.Follow:
return PixelfedNotificationType.Follow;
case NotificationType.Favourite:
return PixelfedNotificationType.Favourite;
case NotificationType.Reblog:
return PixelfedNotificationType.Reblog;
case NotificationType.Mention:
return PixelfedNotificationType.Mention;
case NotificationType.FollowRequest:
return PixelfedNotificationType.FollowRequest;
default:
return new UnknownNotificationTypeError();
}
};
Converter.decodeNotificationType = (t) => {
switch (t) {
case PixelfedNotificationType.Follow:
return NotificationType.Follow;
case PixelfedNotificationType.Favourite:
return NotificationType.Favourite;
case PixelfedNotificationType.Mention:
return NotificationType.Mention;
case PixelfedNotificationType.Reblog:
return NotificationType.Reblog;
case PixelfedNotificationType.FollowRequest:
return NotificationType.FollowRequest;
default:
return new UnknownNotificationTypeError();
}
};
Converter.visibility = (v) => {
switch (v) {
case 'public':
return 'public';
case 'unlisted':
return 'unlisted';
case 'private':
return 'private';
case 'direct':
return 'direct';
}
};
Converter.encodeVisibility = (v) => {
switch (v) {
case 'public':
return 'public';
case 'unlisted':
return 'unlisted';
case 'private':
return 'private';
case 'direct':
return 'direct';
case 'local':
return 'public';
}
};
Converter.account = (a) => ({
id: a.id,
username: a.username,
acct: a.acct,
display_name: a.display_name,
locked: a.locked,
discoverable: a.discoverable,
group: null,
noindex: null,
suspended: null,
limited: null,
created_at: a.created_at,
followers_count: a.followers_count,
following_count: a.following_count,
statuses_count: a.statuses_count,
note: a.note,
url: a.url,
avatar: a.avatar,
avatar_static: a.avatar_static,
header: a.header,
header_static: a.header_static,
emojis: a.emojis,
moved: null,
fields: a.fields,
bot: null,
source: a.source
});
Converter.announcement = (a) => a;
Converter.application = (a) => a;
Converter.attachment = (a) => a;
Converter.async_attachment = (a) => {
if (a.url) {
return {
id: a.id,
type: a.type,
url: a.url,
remote_url: a.remote_url,
preview_url: a.preview_url,
text_url: a.text_url,
meta: a.meta,
description: a.description,
blurhash: a.blurhash
};
}
else {
return a;
}
};
Converter.context = (c) => ({
ancestors: Array.isArray(c.ancestors) ? c.ancestors.map(a => Converter.status(a)) : [],
descendants: Array.isArray(c.descendants) ? c.descendants.map(d => Converter.status(d)) : []
});
Converter.conversation = (c) => ({
id: c.id,
accounts: Array.isArray(c.accounts) ? c.accounts.map(a => Converter.account(a)) : [],
last_status: c.last_status ? Converter.status(c.last_status) : null,
unread: c.unread
});
Converter.emoji = (e) => e;
Converter.field = (f) => f;
Converter.filter = (f) => f;
Converter.history = (h) => h;
Converter.instance = (i) => ({
uri: i.uri,
title: i.title,
description: i.description,
email: i.email,
version: i.version,
thumbnail: i.thumbnail,
urls: null,
stats: Converter.stats(i.stats),
languages: i.languages,
registrations: i.registrations,
approval_required: i.approval_required,
configuration: {
statuses: {
max_characters: i.configuration.statuses.max_characters,
max_media_attachments: i.configuration.statuses.max_media_attachments,
characters_reserved_per_url: i.configuration.statuses.characters_reserved_per_url
},
polls: {
max_options: i.configuration.polls.max_options,
max_characters_per_option: i.configuration.polls.max_characters_per_option,
min_expiration: i.configuration.polls.min_expiration,
max_expiration: i.configuration.polls.max_expiration
}
},
contact_account: Converter.account(i.contact_account),
rules: i.rules
});
Converter.marker = (m) => m;
Converter.mention = (m) => m;
Converter.notification = (n) => {
const notificationType = Converter.decodeNotificationType(n.type);
if (notificationType instanceof UnknownNotificationTypeError)
return notificationType;
if (n.status) {
return {
account: Converter.account(n.account),
created_at: n.created_at,
id: n.id,
status: Converter.status(n.status),
type: notificationType
};
}
else {
return {
account: Converter.account(n.account),
created_at: n.created_at,
id: n.id,
type: notificationType
};
}
};
Converter.poll = (p) => p;
Converter.poll_option = (p) => p;
Converter.preferences = (p) => p;
Converter.relationship = (r) => r;
Converter.report = (r) => ({
id: r.id,
action_taken: r.action_taken,
action_taken_at: r.action_taken_at,
status_ids: r.status_ids,
rule_ids: r.rule_ids,
category: r.category,
comment: r.comment,
forwarded: r.forwarded,
target_account: Converter.account(r.target_account)
});
Converter.results = (r) => ({
accounts: Array.isArray(r.accounts) ? r.accounts.map(a => Converter.account(a)) : [],
statuses: Array.isArray(r.statuses) ? r.statuses.map(s => Converter.status(s)) : [],
hashtags: Array.isArray(r.hashtags) ? r.hashtags.map(h => Converter.tag(h)) : []
});
Converter.scheduled_status = (s) => s;
Converter.source = (s) => s;
Converter.stats = (s) => s;
Converter.status = (s) => ({
id: s.id,
uri: s.uri,
url: s.url,
account: Converter.account(s.account),
in_reply_to_id: s.in_reply_to_id,
in_reply_to_account_id: s.in_reply_to_account_id,
reblog: s.reblog ? Converter.status(s.reblog) : null,
content: s.content,
plain_content: null,
created_at: s.created_at,
edited_at: s.edited_at,
emojis: Array.isArray(s.emojis) ? s.emojis.map(e => Converter.emoji(e)) : [],
replies_count: s.replies_count,
reblogs_count: s.reblogs_count,
favourites_count: s.favourites_count,
reblogged: s.reblogged,
favourited: s.favourited,
muted: s.muted,
sensitive: s.sensitive,
spoiler_text: s.spoiler_text,
visibility: Converter.visibility(s.visibility),
media_attachments: Array.isArray(s.media_attachments) ? s.media_attachments.map(m => Converter.attachment(m)) : [],
mentions: Array.isArray(s.mentions) ? s.mentions.map(m => Converter.mention(m)) : [],
tags: s.tags,
card: null,
poll: s.poll ? Converter.poll(s.poll) : null,
application: s.application ? Converter.application(s.application) : null,
language: s.language,
pinned: false,
emoji_reactions: [],
bookmarked: s.bookmarked ? s.bookmarked : false,
quote: false
});
Converter.status_params = (s) => s;
Converter.tag = (t) => t;
Converter.token = (t) => t;
})(Converter = PixelfedAPI.Converter || (PixelfedAPI.Converter = {}));
})(PixelfedAPI || (PixelfedAPI = {}));
export default PixelfedAPI;