2021-10-30 17:26:41 +00:00
|
|
|
import * as fs from 'fs/promises';
|
2021-11-02 04:29:24 +00:00
|
|
|
import * as path from 'path';
|
2021-10-30 17:26:41 +00:00
|
|
|
import * as crypto from 'crypto';
|
|
|
|
|
|
|
|
import * as FileType from 'file-type';
|
|
|
|
|
|
|
|
import { ExitCodes, ExitCode } from '../../exit-codes/exit-codes';
|
|
|
|
import Logger from '../../logger/logger';
|
|
|
|
|
|
|
|
import DB from '../db';
|
|
|
|
|
2021-11-02 04:29:24 +00:00
|
|
|
const LOG = Logger.create(__filename);
|
2021-10-30 17:26:41 +00:00
|
|
|
|
|
|
|
let serverName = process.argv[2] || 'no chicoms';
|
|
|
|
let expiresAfter = process.argv[3] || '7 days';
|
2021-11-02 04:29:24 +00:00
|
|
|
let outputPath = process.argv[4] || path.join(__dirname, '../invites/no-chicoms.cordis');
|
2021-10-30 17:26:41 +00:00
|
|
|
|
|
|
|
process.on('unhandledRejection', async (reason, promise) => {
|
|
|
|
LOG.error('unhandled promise rejection:', reason);
|
|
|
|
ExitCodes.exit(ExitCode.GENERAL_ERROR);
|
|
|
|
});
|
|
|
|
|
|
|
|
// From ElementsUtil
|
|
|
|
async function getImageBufferSrc(buffer) {
|
|
|
|
let result = await FileType.fromBuffer(buffer);
|
|
|
|
switch (result && result.mime) {
|
|
|
|
case 'image/png':
|
|
|
|
case 'image/jpeg':
|
|
|
|
case 'image/gif':
|
|
|
|
return 'data:' + result?.mime + ';base64,' + buffer.toString('base64');
|
|
|
|
default:
|
|
|
|
// TODO: some images are not getting setup here... (webp, etc)
|
|
|
|
LOG.warn('bad result for buffer:', { buffer, result });
|
|
|
|
throw new Error('invalid image buffer');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
(async () => {
|
|
|
|
await DB.connect();
|
|
|
|
|
2021-11-02 04:29:24 +00:00
|
|
|
let certFile = path.join(__dirname, '../ssl/cert.pem');
|
2021-10-30 17:26:41 +00:00
|
|
|
let cert = (await fs.readFile(certFile)).toString();
|
|
|
|
|
2021-11-18 01:26:32 +00:00
|
|
|
let servers = await DB.getAllGuilds();
|
2021-10-30 17:26:41 +00:00
|
|
|
let found = false;
|
|
|
|
for (let server of servers) {
|
|
|
|
if (server.name == serverName) {
|
|
|
|
found = true;
|
|
|
|
let iconBuff = (await DB.getResource(server.id, server.icon_resource_id)).data;
|
|
|
|
let iconSrc = await getImageBufferSrc(iconBuff);
|
|
|
|
let tokenInfo = await DB.createToken(server.id, expiresAfter);
|
|
|
|
let fileData = {
|
|
|
|
name: server.name,
|
|
|
|
url: 'https://localhost:3030',
|
|
|
|
cert: cert,
|
|
|
|
token: tokenInfo.token,
|
|
|
|
expires: new Date(tokenInfo.expires).getTime(),
|
|
|
|
iconSrc: iconSrc
|
|
|
|
};
|
|
|
|
LOG.info('writing file data:', fileData);
|
2021-11-02 04:29:24 +00:00
|
|
|
await fs.writeFile(outputPath, JSON.stringify(fileData));
|
2021-10-30 17:26:41 +00:00
|
|
|
LOG.info('wrote to ' + outputPath);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!found) {
|
|
|
|
LOG.warn('unable to find server named "' + serverName + '"');
|
|
|
|
}
|
|
|
|
await DB.end();
|
|
|
|
})();
|