2024-09-08 23:46:15 +08:00

105 lines
3.4 KiB
TypeScript

/**
* power by biuuu
*/
import chalk from 'chalk'
import {join} from 'path'
import {ensureDir, emptyDir, copy, outputJSON, remove, stat, readFile} from 'fs-extra'
import {createHmac} from 'crypto'
import {platform} from 'os'
import AdmZip from 'adm-zip'
import packageFile from '../package.json'
import buildConfig from '../build.json'
import config from '../config'
import {okayLog, errorLog, doneLog} from './log'
const platformName = platform().includes('win32') ? 'win' : platform().includes('darwin') ? 'mac' : 'linux'
const buildPath = join('.', 'build', `${platformName === 'mac' ? 'mac' : platformName + '-unpacked'}`)
const hash = (data, type = 'sha256') => {
const hmac = createHmac(type, 'Sky')
hmac.update(data)
return hmac.digest('hex')
}
const createZip = (filePath: string, dest: string) => {
const zip = new AdmZip()
zip.addLocalFolder(filePath, "", undefined)
zip.toBuffer()
zip.writeZip(dest, undefined)
}
const start = async () => {
console.log(chalk.green.bold(`Start packing \n`))
if (buildConfig.asar) {
errorLog(`${chalk.red("Please make sure the build.asar option in the Package.json file is set to false")}\n`)
return;
}
if (config.build.hotPublishConfigName === '') {
errorLog(`${chalk.red("HotPublishConfigName is not set, which will cause the update to fail, please set it in the config/index.js \n") + chalk.red.bold(`\n Packing failed \n`)}`)
process.exit(1)
}
stat(join(buildPath, 'resources', 'app'), async (err, stats) => {
if (err) {
errorLog(`${chalk.red("No resource files were found, please execute this command after the build command")}\n`)
return;
}
try {
console.log(chalk.green.bold(`Check the resource files \n`))
const packResourcesPath = join('.', 'build', 'resources', 'dist');
const packPackagePath = join('.', 'build', 'resources');
const resourcesPath = join('.', 'dist');
const appPath = join('.', 'build', 'resources');
const name = "app.zip";
const outputPath = join('.', 'build', 'update');
const zipPath = join(outputPath, name);
await ensureDir(packResourcesPath);
await emptyDir(packResourcesPath);
await copy(resourcesPath, packResourcesPath);
okayLog(chalk.cyan.bold(`File copy complete \n`))
await outputJSON(join(packPackagePath, "package.json"), {
name: packageFile.name,
productName: buildConfig.productName,
version: packageFile.version,
description: packageFile.description,
main: packageFile.main,
author: packageFile.author,
dependencies: packageFile.dependencies
});
okayLog(chalk.cyan.bold(`Rewrite package file complete \n`))
await ensureDir(outputPath);
await emptyDir(outputPath);
createZip(appPath, zipPath);
const buffer = await readFile(zipPath);
const sha256 = hash(buffer);
const hashName = sha256.slice(7, 12);
await copy(zipPath, join(outputPath, `${hashName}.zip`));
await outputJSON(join(outputPath, `${config.build.hotPublishConfigName}.json`),
{
version: packageFile.version,
name: `${hashName}.zip`,
hash: sha256
}
);
okayLog(chalk.cyan.bold(`Zip file complete, Start cleaning up redundant files \n`))
await remove(zipPath);
await remove(appPath)
okayLog(chalk.cyan.bold(`Cleaning up redundant files completed \n`))
doneLog('The resource file is packaged!\n')
console.log("File location: " + chalk.green(outputPath) + "\n");
} catch (error) {
errorLog(`${chalk.red(error.message || error)}\n`)
process.exit(1)
}
});
}
start()