mirror of
https://github.com/unraid/api.git
synced 2026-01-05 16:09:49 -06:00
- **New Features** - Created a dynamic plugin system for the API to enable community augmentation of GraphQL, CLI, and Cron functionalities capabilities. - Included an example plugin under `packages/unraid-api-plugin-health` that adds a new graphql query for API health checks. - Added `rc.unraid-api` commands for backing up, restoring, and installing production dependencies, streamlining maintenance and deployment. - Improved dependency vendoring by bundling a versioned pnpm store (instead of `node_modules`). Versioning will allow users to add plugins to a specific api release without requiring an internet connection on subsequent reboots. - **Chores** - Upgraded build workflows and versioning processes to ensure more reliable artifact handling and production packaging.
70 lines
2.3 KiB
TypeScript
Executable File
70 lines
2.3 KiB
TypeScript
Executable File
#!/usr/bin/env zx
|
|
import { mkdir, readFile, rm, writeFile } from 'fs/promises';
|
|
import { exit } from 'process';
|
|
|
|
import { $, cd } from 'zx';
|
|
|
|
import { getDeploymentVersion } from './get-deployment-version.js';
|
|
|
|
try {
|
|
// Create release and pack directories
|
|
await mkdir('./deploy/release', { recursive: true });
|
|
await mkdir('./deploy/pack', { recursive: true });
|
|
|
|
// Build Generated Types
|
|
await $`pnpm run codegen`;
|
|
|
|
await $`pnpm run build`;
|
|
// Copy app files to plugin directory
|
|
|
|
// Get package details
|
|
const packageJson = await readFile('./package.json', 'utf-8');
|
|
const parsedPackageJson = JSON.parse(packageJson);
|
|
|
|
const deploymentVersion = await getDeploymentVersion(process.env, parsedPackageJson.version);
|
|
|
|
// Update the package.json version to the deployment version
|
|
parsedPackageJson.version = deploymentVersion;
|
|
// omit dev dependencies from release build
|
|
parsedPackageJson.devDependencies = {};
|
|
|
|
// Create a temporary directory for packaging
|
|
await mkdir('./deploy/pack/', { recursive: true });
|
|
|
|
await writeFile('./deploy/pack/package.json', JSON.stringify(parsedPackageJson, null, 4));
|
|
// Copy necessary files to the pack directory
|
|
await $`cp -r dist README.md .env.* ecosystem.config.json ./deploy/pack/`;
|
|
|
|
// Change to the pack directory and install dependencies
|
|
cd('./deploy/pack');
|
|
|
|
console.log('Building production pnpm store...');
|
|
$.verbose = true;
|
|
await $`pnpm install --prod --ignore-workspace --store-dir=../.pnpm-store`;
|
|
|
|
await $`rm -rf node_modules`; // Don't include node_modules in final package
|
|
|
|
const sudoCheck = await $`command -v sudo`.nothrow();
|
|
const SUDO = sudoCheck.exitCode === 0 ? 'sudo' : '';
|
|
await $`${SUDO} chown -R 0:0 ../.pnpm-store`;
|
|
|
|
await $`XZ_OPT=-5 tar -cJf ../packed-pnpm-store.txz ../.pnpm-store`;
|
|
await $`${SUDO} rm -rf ../.pnpm-store`;
|
|
|
|
// chmod the cli
|
|
await $`chmod +x ./dist/cli.js`;
|
|
await $`chmod +x ./dist/main.js`;
|
|
} catch (error) {
|
|
// Error with a command
|
|
if (Object.keys(error).includes('stderr')) {
|
|
console.log(`Failed building package. Exit code: ${error.exitCode}`);
|
|
console.log(`Error: ${error.stderr}`);
|
|
} else {
|
|
// Normal js error
|
|
console.log('Failed building package.');
|
|
console.log(`Error: ${error.message}`);
|
|
}
|
|
|
|
exit(error.exitCode);
|
|
}
|