Skip to content

Commit b99511b

Browse files
authored
Merge pull request #184 from Armadillidiid/feat/delete-script-after-exec
Feature: Delete Script After Execution
2 parents 01a39e3 + b82eced commit b99511b

File tree

2 files changed

+28
-2
lines changed

2 files changed

+28
-2
lines changed

src/helpers.js

+25-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
const { existsSync, mkdirSync, writeFileSync } = require('fs');
1+
const { existsSync, mkdirSync, writeFileSync, unlink } = require('fs');
22
const { join } = require('path');
33

44
const validateDir = (dir) => {
@@ -45,6 +45,29 @@ const writeToFile = ({ dir, filename, content, isRequired, mode = '0644' }) => {
4545
}
4646
};
4747

48+
const deleteFile = ({ dir, filename, isRequired }) => {
49+
validateDir(dir);
50+
const filePath = join(dir, filename);
51+
52+
if (existsSync(filePath)) {
53+
const message = `⚠️ [FILE] ${filePath} Required file exist.`;
54+
handleError(message, isRequired);
55+
return;
56+
}
57+
58+
try {
59+
console.log(`[FILE] Deleting ${filePath} file ...`);
60+
unlink(filePath, (error) => {
61+
if (error) {
62+
throw new Error(error);
63+
}
64+
});
65+
} catch (error) {
66+
const message = `⚠️[FILE] Deleting file error. filePath: ${filePath}, message: ${error.message}`;
67+
handleError(message, isRequired);
68+
}
69+
};
70+
4871
const validateRequiredInputs = (inputs) => {
4972
const inputKeys = Object.keys(inputs);
5073
const validInputs = inputKeys.filter((inputKey) => {
@@ -66,6 +89,7 @@ const snakeToCamel = (str) => str.replace(/[^a-zA-Z0-9]+(.)/g, (m, chr) => chr.t
6689

6790
module.exports = {
6891
writeToFile,
92+
deleteFile,
6993
validateRequiredInputs,
7094
snakeToCamel
7195
};

src/remoteCmd.js

+3-1
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
const { exec } = require('child_process');
22
const crypto = require('crypto');
33
const { sshServer, githubWorkspace, remotePort } = require('./inputs');
4-
const { writeToFile } = require('./helpers');
4+
const { writeToFile, deleteFile } = require('./helpers');
55

66
const handleError = (message, isRequired, callback) => {
77
if (isRequired) {
@@ -30,6 +30,8 @@ const remoteCmd = async (content, privateKeyPath, isRequired, label) => new Prom
3030
} else {
3131
const limited = data.substring(0, dataLimit);
3232
console.log('✅ [CMD] Remote script executed. \n', limited, stderr);
33+
deleteFile({ dir: githubWorkspace, filename });
34+
console.log('✅ [FILE] Script file deleted.');
3335
resolve(limited);
3436
}
3537
}

0 commit comments

Comments
 (0)