mirror of
https://github.com/sern-handler/cli
synced 2026-06-28 02:32:20 +00:00
72 lines
2.6 KiB
TypeScript
72 lines
2.6 KiB
TypeScript
import { greenBright } from 'colorette';
|
|
import fs from 'fs';
|
|
import prompt from 'prompts';
|
|
import { fetch } from 'undici';
|
|
import { pluginsQ } from '../prompts/plugin.js';
|
|
import { fromCwd } from '../utilities/fromCwd.js';
|
|
import esbuild from 'esbuild';
|
|
import { getLang } from '../utilities/getLang.js';
|
|
import { resolve } from 'path';
|
|
import { require } from '../utilities/require.js';
|
|
interface PluginData {
|
|
description: string;
|
|
hash: string;
|
|
name: string;
|
|
author: string[];
|
|
link: string;
|
|
example: string;
|
|
version: '1.0.0';
|
|
}
|
|
|
|
/**
|
|
* Installs plugins to project
|
|
*/
|
|
export async function plugins() {
|
|
const e: PluginData[] = (await prompt([await pluginsQ()])).list;
|
|
if (!e) process.exit(1);
|
|
|
|
const lang = await getLang();
|
|
for await (const plgData of e) {
|
|
const pluginText = await download(plgData.link);
|
|
const dir = fromCwd('/src/plugins');
|
|
const linkNoExtension = `${process.cwd()}/src/plugins/${plgData.name}`;
|
|
if (!fs.existsSync(dir)) {
|
|
fs.mkdirSync(dir, { recursive: true });
|
|
}
|
|
if (lang === 'typescript') {
|
|
fs.writeFileSync(linkNoExtension + '.ts', pluginText);
|
|
} else {
|
|
const { type = undefined } = require(resolve('package.json'));
|
|
const format = type === undefined || type === 'cjs' ? 'cjs' : 'esm';
|
|
const transformResult = await esbuild.transform(pluginText, {
|
|
target: 'node18',
|
|
format,
|
|
loader: 'ts',
|
|
banner: `/**\n Partial information: ${plgData.description}\n @author ${plgData.author}\n @example${plgData.example}*/`,
|
|
});
|
|
if (transformResult.warnings.length > 0) {
|
|
console.log(transformResult.warnings.map((msg) => msg.text).join('\n'));
|
|
}
|
|
console.warn('transforming plugins with js strips comments');
|
|
console.warn('We provided some minimal information at top of file, or view the documentation for this plugin here:');
|
|
console.warn(plgData.link);
|
|
fs.writeFileSync(linkNoExtension + '.js', transformResult.code);
|
|
}
|
|
}
|
|
|
|
const pluginNames = e.map((data) => {
|
|
return 'Installed ' + data.name + ' ' + 'from ' + data.author.join(',');
|
|
});
|
|
console.log(`Successfully downloaded plugin(s):\n${greenBright(pluginNames.join('\n'))}`);
|
|
}
|
|
|
|
async function download(url: string) {
|
|
const data = await fetch(url, { method: 'GET' })
|
|
.then((res) => res.text())
|
|
.catch(() => null);
|
|
|
|
if (!data) throw new Error('Download failed! Kindly contact developers');
|
|
|
|
return data;
|
|
}
|