feat: discord webhook support + custom id func

pull/250/head
William Harrison 1 year ago
parent 3f685ef067
commit 58fd55cfa6

@ -3,6 +3,7 @@ import { UserConfiguration, UserConfigTypeChecker, PostgresConfiguration } from
import fs from 'fs-extra'; import fs from 'fs-extra';
import { path } from '@tycrek/joint'; import { path } from '@tycrek/joint';
import { log } from './log.js'; import { log } from './log.js';
import fetch from "node-fetch";
const FILEPATH = path.join('.ass-data/userconfig.json'); const FILEPATH = path.join('.ass-data/userconfig.json');
@ -40,6 +41,10 @@ const Checkers: UserConfigTypeChecker = {
idSize: numChecker, idSize: numChecker,
gfySize: numChecker, gfySize: numChecker,
maximumFileSize: numChecker, maximumFileSize: numChecker,
discordWebhook: (val) => {
const regex = /^https:\/\/discord\.com\/api\/webhooks\/\d+\/\S+$/;
return regex.test(val);
},
s3: { s3: {
endpoint: basicStringChecker, endpoint: basicStringChecker,
@ -96,6 +101,7 @@ export class UserConfig {
if (!Checkers.idSize(config.idSize)) throw new Error('Invalid ID size'); if (!Checkers.idSize(config.idSize)) throw new Error('Invalid ID size');
if (!Checkers.gfySize(config.gfySize)) throw new Error('Invalid Gfy size'); if (!Checkers.gfySize(config.gfySize)) throw new Error('Invalid Gfy size');
if (!Checkers.maximumFileSize(config.maximumFileSize)) throw new Error('Invalid maximum file size'); if (!Checkers.maximumFileSize(config.maximumFileSize)) throw new Error('Invalid maximum file size');
if (!Checkers.discordWebhook(config.discordWebhook)) throw new Error('Invalid Discord webhook');
// * Optional S3 config // * Optional S3 config
if (config.s3 != null) { if (config.s3 != null) {

@ -3,6 +3,7 @@ import { BusBoyFile, AssFile } from 'ass';
import fs from 'fs-extra'; import fs from 'fs-extra';
import bb from 'express-busboy'; import bb from 'express-busboy';
import crypto from 'crypto'; import crypto from 'crypto';
import fetch from 'node-fetch';
import { Router } from 'express'; import { Router } from 'express';
import { Readable } from 'stream'; import { Readable } from 'stream';
@ -88,7 +89,21 @@ router.post('/', rateLimiterMiddleware("upload", UserConfig.config?.rateLimit?.u
data.put('files', assFile.fakeid, assFile); data.put('files', assFile.fakeid, assFile);
log.debug('File saved to', !s3 ? assFile.save.local! : 'S3'); log.debug('File saved to', !s3 ? assFile.save.local! : 'S3');
return res.type('json').send({ resource: `${req.ass.host}/${assFile.fakeid}` }); await res.type('json').send({ resource: `${req.ass.host}/${assFile.fakeid}` });
// Send to Discord webhook
try {
await fetch(UserConfig.config.discordWebhook, {
method: "POST",
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({ content: `New upload: ${req.ass.host}/${assFile.fakeid}` })
})
} catch (err) {
log.warn("Failed to send request to Discord webhook");
console.error(err);
}
} catch (err) { } catch (err) {
log.error('Failed to upload file', bbFile.filename); log.error('Failed to upload file', bbFile.filename);
console.error(err); console.error(err);

@ -1,4 +1,7 @@
import { DateTime } from 'luxon'; import { DateTime } from 'luxon';
import { id } from 'william.js';
export const customId = (length: number, alphabet: string = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789") => id(length, 1, alphabet);
export const randomHexColour = () => { // From: https://www.geeksforgeeks.org/javascript-generate-random-hex-codes-color/ export const randomHexColour = () => { // From: https://www.geeksforgeeks.org/javascript-generate-random-hex-codes-color/
const letters = '0123456789ABCDEF'; const letters = '0123456789ABCDEF';

2
common/types.d.ts vendored

@ -25,6 +25,7 @@ declare module 'ass' {
idSize: number; idSize: number;
gfySize: number; gfySize: number;
maximumFileSize: number; maximumFileSize: number;
discordWebhook: string;
s3?: S3Configuration; s3?: S3Configuration;
database?: DatabaseConfiguration; database?: DatabaseConfiguration;
@ -154,6 +155,7 @@ declare module 'ass' {
idSize: (val: any) => boolean; idSize: (val: any) => boolean;
gfySize: (val: any) => boolean; gfySize: (val: any) => boolean;
maximumFileSize: (val: any) => boolean; maximumFileSize: (val: any) => boolean;
discordWebhook: (val: any) => boolean;
s3: { s3: {
endpoint: (val: any) => boolean; endpoint: (val: any) => boolean;
bucket: (val: any) => boolean; bucket: (val: any) => boolean;

@ -54,6 +54,7 @@
"luxon": "^3.4.4", "luxon": "^3.4.4",
"memorystore": "^1.6.7", "memorystore": "^1.6.7",
"mysql2": "^3.6.5", "mysql2": "^3.6.5",
"node-fetch": "^3.3.2",
"node-vibrant": "^3.1.6", "node-vibrant": "^3.1.6",
"pg": "^8.11.3", "pg": "^8.11.3",
"pug": "^3.0.2", "pug": "^3.0.2",
@ -61,7 +62,8 @@
"shoelace-fontawesome-pug": "^6.4.3", "shoelace-fontawesome-pug": "^6.4.3",
"shoelace-pug-loader": "^2.11.0", "shoelace-pug-loader": "^2.11.0",
"tailwindcss": "^3.3.6", "tailwindcss": "^3.3.6",
"typescript": "^5.3.2" "typescript": "^5.3.2",
"william.js": "^1.2.2"
}, },
"devDependencies": { "devDependencies": {
"@types/bcrypt": "^5.0.2", "@types/bcrypt": "^5.0.2",

Loading…
Cancel
Save