mirror of
https://github.com/gchq/CyberChef.git
synced 2025-04-26 17:56:15 -04:00
consistency with ../Base64.mjs
removeNonAlphChars and strictMode params
This commit is contained in:
parent
7acd9a3bd2
commit
d9fb3e28dd
1 changed files with 5 additions and 2 deletions
|
@ -100,10 +100,13 @@ export function toHexFast(data) {
|
|||
* // returns [10,20,30]
|
||||
* fromHex("0a:14:1e", "Colon");
|
||||
*/
|
||||
export function fromHex(data, delim="Auto", byteLen=2, strict=False) {
|
||||
export function fromHex(data, delim="Auto", byteLen=2, removeNonAlphChars=false, strictMode=false) {
|
||||
if (byteLen < 1 || Math.round(byteLen) !== byteLen)
|
||||
throw new OperationError("Byte length must be a positive integer");
|
||||
|
||||
if (removeNonAlphChars)
|
||||
data = data.replace(/[^\da-fA-F]/g, '');
|
||||
|
||||
if (delim !== "None") {
|
||||
const delimRegex = delim === "Auto" ? /\s+|0x/gi : Utils.regexRep(delim);
|
||||
data = data.split(delimRegex);
|
||||
|
@ -113,7 +116,7 @@ export function fromHex(data, delim="Auto", byteLen=2, strict=False) {
|
|||
|
||||
const output = [];
|
||||
for (let i = 0; i < data.length; i++) {
|
||||
if (/[^a-f\d\s]/.test(data[i]) && strict)
|
||||
if (/[^a-f\d\s]/.test(data[i]) && strictMode)
|
||||
throw new OperationError("Hex input must only contain hex digits");
|
||||
for (let j = 0; j < data[i].length; j += byteLen) {
|
||||
output.push(parseInt(data[i].substr(j, byteLen), 16));
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue