mirror of
https://github.com/joelwmale/webhook-action.git
synced 2025-01-07 13:26:22 +01:00
46 lines
1.1 KiB
JavaScript
46 lines
1.1 KiB
JavaScript
|
'use strict';
|
||
|
|
||
|
// See http://www.robvanderwoude.com/escapechars.php
|
||
|
const metaCharsRegExp = /([()\][%!^"`<>&|;, *?])/g;
|
||
|
|
||
|
function escapeCommand(arg) {
|
||
|
// Escape meta chars
|
||
|
arg = arg.replace(metaCharsRegExp, '^$1');
|
||
|
|
||
|
return arg;
|
||
|
}
|
||
|
|
||
|
function escapeArgument(arg, doubleEscapeMetaChars) {
|
||
|
// Convert to string
|
||
|
arg = `${arg}`;
|
||
|
|
||
|
// Algorithm below is based on https://qntm.org/cmd
|
||
|
|
||
|
// Sequence of backslashes followed by a double quote:
|
||
|
// double up all the backslashes and escape the double quote
|
||
|
arg = arg.replace(/(\\*)"/g, '$1$1\\"');
|
||
|
|
||
|
// Sequence of backslashes followed by the end of the string
|
||
|
// (which will become a double quote later):
|
||
|
// double up all the backslashes
|
||
|
arg = arg.replace(/(\\*)$/, '$1$1');
|
||
|
|
||
|
// All other backslashes occur literally
|
||
|
|
||
|
// Quote the whole thing:
|
||
|
arg = `"${arg}"`;
|
||
|
|
||
|
// Escape meta chars
|
||
|
arg = arg.replace(metaCharsRegExp, '^$1');
|
||
|
|
||
|
// Double escape meta chars if necessary
|
||
|
if (doubleEscapeMetaChars) {
|
||
|
arg = arg.replace(metaCharsRegExp, '^$1');
|
||
|
}
|
||
|
|
||
|
return arg;
|
||
|
}
|
||
|
|
||
|
module.exports.command = escapeCommand;
|
||
|
module.exports.argument = escapeArgument;
|