tailoring to my taste
This commit is contained in:
@@ -1,34 +0,0 @@
|
||||
import { Logger } from './utils/logger.js';
|
||||
import { getArg } from './utils/funcs.js';
|
||||
import { resolve } from 'path';
|
||||
import { cwd } from 'process';
|
||||
import { deploy } from './tasks/deploy.js';
|
||||
|
||||
const logger = new Logger('deploy', 'info', 'brightMagenta');
|
||||
|
||||
const src = './src';
|
||||
const dist = './dist';
|
||||
const serviceName = getArg('--service', 'gitea');
|
||||
const srcPath = resolve(cwd(), src);
|
||||
const distPath = resolve(cwd(), dist);
|
||||
const serverPath = resolve(
|
||||
cwd(),
|
||||
getArg('--server', 'd:/users/lucas/Desktop/dev/server/gitea')
|
||||
);
|
||||
|
||||
logger.info('Deploy started!');
|
||||
logger.info(`Service name: '${serviceName}'`);
|
||||
logger.info(`Src path: ${srcPath}`);
|
||||
logger.info(`Dist path: ${distPath}`);
|
||||
logger.info(`Server path: ${serverPath}`);
|
||||
|
||||
function exit(err) {
|
||||
err && logger.error(err);
|
||||
process.exit(err ? 1 : 0);
|
||||
}
|
||||
|
||||
async function executeDeployTask() {
|
||||
await deploy(srcPath, distPath, serverPath, serviceName);
|
||||
}
|
||||
|
||||
executeDeployTask().then(exit).catch(exit);
|
||||
@@ -1,19 +0,0 @@
|
||||
import { getArg } from './utils/funcs.js';
|
||||
import { restartService } from './tasks/restart-service.js';
|
||||
import { Logger } from './utils/logger.js';
|
||||
|
||||
const logger = new Logger('restart', 'info', 'brightMagenta');
|
||||
const serviceName = getArg('--service', 'gitea');
|
||||
|
||||
function exit(err) {
|
||||
if (err) {
|
||||
console.error(err);
|
||||
} else {
|
||||
console.log('');
|
||||
logger.info('Build completed successfully');
|
||||
}
|
||||
|
||||
process.exit(err ? 1 : 0);
|
||||
}
|
||||
|
||||
restartService(serviceName).then(exit).catch(exit);
|
||||
@@ -1,41 +0,0 @@
|
||||
import { watch } from 'chokidar';
|
||||
import { TaskDebouncer } from './utils/task-debouncer.js';
|
||||
import { Logger } from './utils/logger.js';
|
||||
import { getArg } from './utils/funcs.js';
|
||||
import { resolve } from 'path';
|
||||
import { cwd } from 'process';
|
||||
import { deploy } from './tasks/deploy.js';
|
||||
|
||||
const src = './src';
|
||||
const dist = './dist';
|
||||
const serviceName = getArg('--service', 'gitea');
|
||||
const srcPath = resolve(cwd(), src);
|
||||
const distPath = resolve(cwd(), dist);
|
||||
const serverPath = resolve(
|
||||
cwd(),
|
||||
getArg('--server', 'd:/users/lucas/Desktop/dev/server/gitea')
|
||||
);
|
||||
const debouncer = new TaskDebouncer(300);
|
||||
const logger = new Logger('serve', 'info', 'brightMagenta');
|
||||
|
||||
logger.info('Serve task started!');
|
||||
logger.info('Watching for changes...');
|
||||
logger.info(`Service name: '${serviceName}'`);
|
||||
logger.info(`Src path: ${srcPath}`);
|
||||
logger.info(`Dist path: ${distPath}`);
|
||||
logger.info(`Server path: ${serverPath}`);
|
||||
|
||||
const watcher = watch([`${src}/**/*`], {
|
||||
persistent: true,
|
||||
ignoreInitial: true,
|
||||
});
|
||||
|
||||
watcher.on('change', (file) => debouncer.add(
|
||||
deploy,
|
||||
srcPath,
|
||||
distPath,
|
||||
serverPath,
|
||||
serviceName,
|
||||
file,
|
||||
true
|
||||
));
|
||||
@@ -1,48 +0,0 @@
|
||||
import { Logger } from '../utils/logger.js';
|
||||
import { buildScss } from './scss.js';
|
||||
import { buildFonts } from './fonts.js';
|
||||
import { buildTemplates } from './templates.js';
|
||||
import { copyTo } from './copy-to.js';
|
||||
import { restartService } from './restart-service.js';
|
||||
import { extname } from 'path';
|
||||
import browsersync from 'browser-sync';
|
||||
import { optimizeCss } from './optimize-css.js';
|
||||
|
||||
const logger = new Logger('deploy', 'info', 'brightMagenta');
|
||||
|
||||
const sync = browsersync.create('lugit')
|
||||
|
||||
export async function deploy(srcPath, distPath, serverPath, serviceName, file = null, live = false) {
|
||||
logger.info('Deploying...');
|
||||
|
||||
if(live && !sync.active) {
|
||||
sync.init({
|
||||
proxy: 'http://lugit.local',
|
||||
port: 8080,
|
||||
})
|
||||
}
|
||||
|
||||
let shouldRestart = true;
|
||||
|
||||
// check if it's an scss
|
||||
if (file !== null && file !== undefined && extname(file) === '.scss') {
|
||||
shouldRestart = false;
|
||||
}
|
||||
|
||||
try {
|
||||
await buildScss(srcPath, distPath).then(() => optimizeCss(distPath));
|
||||
await buildFonts(srcPath, distPath);
|
||||
// await buildImg(srcPath, distPath);
|
||||
await buildTemplates(srcPath, distPath);
|
||||
await copyTo(distPath, serverPath);
|
||||
shouldRestart && await restartService(serviceName);
|
||||
|
||||
if(!shouldRestart && live) {
|
||||
sync.reload();
|
||||
}
|
||||
|
||||
logger.info('Deployment successful!');
|
||||
} catch (error) {
|
||||
logger.error(`Deployment failed: ${error}`);
|
||||
}
|
||||
}
|
||||
@@ -1,31 +0,0 @@
|
||||
import { exec } from 'child_process';
|
||||
|
||||
import { Logger } from '../utils/logger.js';
|
||||
const logger = new Logger(restartService.name, 'info', 'brightRed');
|
||||
|
||||
export async function restartService(serviceName) {
|
||||
return new Promise((resolve, reject) => {
|
||||
logger.info(`Restarting '${serviceName}' service...`);
|
||||
|
||||
let command;
|
||||
let args;
|
||||
|
||||
if (process.platform === 'win32') {
|
||||
command = 'cmd.exe';
|
||||
args = ['/c', 'net', 'stop', serviceName, '&&', 'net', 'start', serviceName];
|
||||
} else {
|
||||
command = 'sudo';
|
||||
args = ['systemctl', 'restart', serviceName];
|
||||
}
|
||||
|
||||
exec(`${command} ${args.join(' ')}`, (error, stdout) => {
|
||||
if (error) {
|
||||
logger.error(`Failed to restart '${serviceName}' service: ${error}`);
|
||||
reject(error);
|
||||
} else {
|
||||
logger.info(`'${serviceName}' service restarted!`);
|
||||
resolve(stdout);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
Reference in New Issue
Block a user