Hide secrets in your Obsidian.md vault
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

503 lines
60 KiB

(() => {
// src/features/feature-inplace-encrypt/Decryptable.ts
var Decryptable = class {
};
// src/features/feature-inplace-encrypt/FeatureInplaceConstants.ts
var _PREFIX_B = "%%\u{1F510}\u03B2 ";
var _PREFIX_B_VISIBLE = "\u{1F510}\u03B2 ";
var _PREFIX_A = "%%\u{1F510}\u03B1 ";
var _PREFIX_A_VISIBLE = "\u{1F510}\u03B1 ";
var _PREFIX_OBSOLETE = "%%\u{1F510} ";
var _PREFIX_OBSOLETE_VISIBLE = "\u{1F510} ";
var _PREFIX_ENCODE_DEFAULT = _PREFIX_B;
var _PREFIX_ENCODE_DEFAULT_VISIBLE = _PREFIX_B_VISIBLE;
var _PREFIXES = [
_PREFIX_B,
_PREFIX_B_VISIBLE,
_PREFIX_A,
_PREFIX_A_VISIBLE,
_PREFIX_OBSOLETE,
_PREFIX_OBSOLETE_VISIBLE
];
var _SUFFIX_WITH_COMMENT = " \u{1F510}%%";
var _SUFFIX_NO_COMMENT = " \u{1F510}";
var _SUFFIXES = [
_SUFFIX_WITH_COMMENT,
_SUFFIX_NO_COMMENT
];
var _HINT = "\u{1F4A1}";
// src/features/feature-inplace-encrypt/featureInplaceTextAnalysis.ts
var FeatureInplaceTextAnalysis = class {
constructor(text) {
this.process(text);
}
process(text) {
var _a, _b;
this.processedText = text;
this.isEmpty = text.length === 0;
this.prefix = (_a = _PREFIXES.find((prefix) => text.startsWith(prefix))) != null ? _a : "";
this.suffix = (_b = _SUFFIXES.find((suffix) => text.endsWith(suffix))) != null ? _b : "";
this.hasEncryptedPrefix = this.prefix.length > 0;
this.hasEncryptedSuffix = this.suffix.length > 0;
this.hasObsoleteEncryptedPrefix = this.prefix === _PREFIX_OBSOLETE || this.prefix === _PREFIX_OBSOLETE_VISIBLE;
this.containsEncryptedMarkers = [..._PREFIXES, ..._SUFFIXES].some((marker) => text.includes(marker));
this.canDecrypt = this.hasEncryptedPrefix && this.hasEncryptedSuffix;
this.canEncrypt = !this.hasEncryptedPrefix && !this.containsEncryptedMarkers;
if (this.canDecrypt) {
const decryptable = this.parseDecryptableContent(text);
if (decryptable != null) {
this.decryptable = decryptable;
} else {
this.canDecrypt = false;
}
}
}
parseDecryptableContent(text) {
const result = new Decryptable();
if (!this.hasEncryptedPrefix || !this.hasEncryptedSuffix) {
return null;
}
if (this.hasObsoleteEncryptedPrefix) {
result.version = 0;
} else if (this.prefix == _PREFIX_B || this.prefix == _PREFIX_B_VISIBLE) {
result.version = 2;
} else if (this.prefix == _PREFIX_A || this.prefix == _PREFIX_A_VISIBLE) {
result.version = 1;
}
const content = text.substring(this.prefix.length, text.length - this.suffix.length);
if ([..._PREFIXES, ..._SUFFIXES].some((marker) => content.includes(marker))) {
return null;
}
if (content.substring(0, _HINT.length) == _HINT) {
const endHintMarker = content.indexOf(_HINT, _HINT.length);
if (endHintMarker < 0) {
return null;
}
result.hint = content.substring(_HINT.length, endHintMarker);
result.base64CipherText = content.substring(endHintMarker + _HINT.length);
} else {
result.base64CipherText = content;
}
result.showInReadingView = !this.prefix.includes("%%");
return result;
}
};
// src/services/CryptoHelper.ts
var vectorSize = 16;
var utf8Encoder = new TextEncoder();
var utf8Decoder = new TextDecoder();
var iterations = 1e3;
var salt = utf8Encoder.encode("XHWnDAT6ehMVY2zD");
var CryptoHelper = class {
// constructor(){
// console.debug('new CryptoHelper');
// }
async deriveKey(password) {
const buffer = utf8Encoder.encode(password);
const key = await crypto.subtle.importKey("raw", buffer, { name: "PBKDF2" }, false, ["deriveKey"]);
const privateKey = crypto.subtle.deriveKey(
{
name: "PBKDF2",
hash: { name: "SHA-256" },
iterations,
salt
},
key,
{
name: "AES-GCM",
length: 256
},
false,
["encrypt", "decrypt"]
);
return privateKey;
}
async encryptToBytes(text, password) {
const key = await this.deriveKey(password);
const textBytesToEncrypt = utf8Encoder.encode(text);
const vector = crypto.getRandomValues(new Uint8Array(vectorSize));
const encryptedBytes = new Uint8Array(
await crypto.subtle.encrypt(
{ name: "AES-GCM", iv: vector },
key,
textBytesToEncrypt
)
);
const finalBytes = new Uint8Array(vector.byteLength + encryptedBytes.byteLength);
finalBytes.set(vector, 0);
finalBytes.set(encryptedBytes, vector.byteLength);
return finalBytes;
}
convertToString(bytes) {
let result = "";
for (let idx = 0; idx < bytes.length; idx++) {
result += String.fromCharCode(bytes[idx]);
}
return result;
}
async encryptToBase64(text, password) {
const finalBytes = await this.encryptToBytes(text, password);
const base64Text = btoa(this.convertToString(finalBytes));
return base64Text;
}
stringToArray(str) {
const result = [];
for (let i = 0; i < str.length; i++) {
result.push(str.charCodeAt(i));
}
return new Uint8Array(result);
}
async decryptFromBytes(encryptedBytes, password) {
try {
const vector = encryptedBytes.slice(0, vectorSize);
const encryptedTextBytes = encryptedBytes.slice(vectorSize);
const key = await this.deriveKey(password);
const decryptedBytes = await crypto.subtle.decrypt(
{ name: "AES-GCM", iv: vector },
key,
encryptedTextBytes
);
const decryptedText = utf8Decoder.decode(decryptedBytes);
return decryptedText;
} catch (e) {
return null;
}
}
async decryptFromBase64(base64Encoded, password) {
try {
const bytesToDecode = this.stringToArray(atob(base64Encoded));
return await this.decryptFromBytes(bytesToDecode, password);
} catch (e) {
return null;
}
}
};
// src/services/CryptoHelper2304.ts
var CryptoHelper2304 = class {
constructor(vectorSize2, saltSize, iterations2) {
this.vectorSize = vectorSize2;
this.saltSize = saltSize;
this.iterations = iterations2;
}
async deriveKey(password, salt2) {
const utf8Encoder2 = new TextEncoder();
const buffer = utf8Encoder2.encode(password);
const key = await crypto.subtle.importKey(
/*format*/
"raw",
/*keyData*/
buffer,
/*algorithm*/
"PBKDF2",
/*extractable*/
false,
/*keyUsages*/
["deriveKey"]
);
try {
const privateKey = await crypto.subtle.deriveKey(
/*algorithm*/
{
name: "PBKDF2",
hash: "SHA-512",
salt: salt2,
iterations: this.iterations
},
/*baseKey*/
key,
/*derivedKeyAlgorithm*/
{
name: "AES-GCM",
length: 256
},
/*extractable*/
false,
/*keyUsages*/
["encrypt", "decrypt"]
);
return privateKey;
} finally {
}
}
async encryptToBytes(text, password) {
const salt2 = crypto.getRandomValues(new Uint8Array(this.saltSize));
const key = await this.deriveKey(password, salt2);
const utf8Encoder2 = new TextEncoder();
const textBytesToEncrypt = utf8Encoder2.encode(text);
const vector = crypto.getRandomValues(new Uint8Array(this.vectorSize));
const encryptedBytes = new Uint8Array(
await crypto.subtle.encrypt(
/*algorithm*/
{
name: "AES-GCM",
iv: vector
},
/*key*/
key,
/*data*/
textBytesToEncrypt
)
);
const finalBytes = new Uint8Array(vector.byteLength + salt2.byteLength + encryptedBytes.byteLength);
finalBytes.set(vector, 0);
finalBytes.set(salt2, vector.byteLength);
finalBytes.set(encryptedBytes, vector.byteLength + salt2.byteLength);
return finalBytes;
}
convertToString(bytes) {
let result = "";
for (let idx = 0; idx < bytes.length; idx++) {
result += String.fromCharCode(bytes[idx]);
}
return result;
}
async encryptToBase64(text, password) {
const finalBytes = await this.encryptToBytes(text, password);
const base64Text = btoa(this.convertToString(finalBytes));
return base64Text;
}
stringToArray(str) {
const result = [];
for (let i = 0; i < str.length; i++) {
result.push(str.charCodeAt(i));
}
return new Uint8Array(result);
}
async decryptFromBytes(encryptedBytes, password) {
try {
let offset;
let nextOffset;
offset = 0;
nextOffset = offset + this.vectorSize;
const vector = encryptedBytes.slice(offset, nextOffset);
offset = nextOffset;
nextOffset = offset + this.saltSize;
const salt2 = encryptedBytes.slice(offset, nextOffset);
offset = nextOffset;
nextOffset = void 0;
const encryptedTextBytes = encryptedBytes.slice(offset);
const key = await this.deriveKey(password, salt2);
const decryptedBytes = await crypto.subtle.decrypt(
/*algorithm*/
{
name: "AES-GCM",
iv: vector
},
/*key*/
key,
/*data*/
encryptedTextBytes
);
const utf8Decoder2 = new TextDecoder();
const decryptedText = utf8Decoder2.decode(decryptedBytes);
return decryptedText;
} catch (e) {
return null;
}
}
async decryptFromBase64(base64Encoded, password) {
try {
const bytesToDecode = this.stringToArray(atob(base64Encoded));
return await this.decryptFromBytes(bytesToDecode, password);
} catch (e) {
return null;
}
}
};
// src/services/CryptoHelperObsolete.ts
var algorithmObsolete = {
name: "AES-GCM",
iv: new Uint8Array([196, 190, 240, 190, 188, 78, 41, 132, 15, 220, 84, 211]),
tagLength: 128
};
var CryptoHelperObsolete = class {
async buildKey(password) {
const utf8Encode = new TextEncoder();
const passwordBytes = utf8Encode.encode(password);
const passwordDigest = await crypto.subtle.digest({ name: "SHA-256" }, passwordBytes);
const key = await crypto.subtle.importKey(
"raw",
passwordDigest,
algorithmObsolete,
false,
["encrypt", "decrypt"]
);
return key;
}
/**
* @deprecated
*/
async encryptToBase64(text, password) {
const key = await this.buildKey(password);
const utf8Encode = new TextEncoder();
const bytesToEncrypt = utf8Encode.encode(text);
const encryptedBytes = new Uint8Array(await crypto.subtle.encrypt(
algorithmObsolete,
key,
bytesToEncrypt
));
const base64Text = btoa(String.fromCharCode(...encryptedBytes));
return base64Text;
}
stringToArray(str) {
const result = [];
for (let i = 0; i < str.length; i++) {
result.push(str.charCodeAt(i));
}
return new Uint8Array(result);
}
async decryptFromBase64(base64Encoded, password) {
try {
const bytesToDecrypt = this.stringToArray(atob(base64Encoded));
const key = await this.buildKey(password);
const decryptedBytes = await crypto.subtle.decrypt(algorithmObsolete, key, bytesToDecrypt);
const utf8Decode = new TextDecoder();
const decryptedText = utf8Decode.decode(decryptedBytes);
return decryptedText;
} catch (e) {
return null;
}
}
};
// src/services/CryptoHelperFactory.ts
var _CryptoHelperFactory = class _CryptoHelperFactory {
static BuildDefault() {
return this.cryptoHelper2304_v2;
}
static BuildFromFileDataOrThrow(data) {
const result = _CryptoHelperFactory.BuildFromFileDataOrNull(data);
if (result != null) {
return result;
}
throw new Error(`Unable to determine ICryptoHelper for File ver ${data.version}`);
}
static BuildFromFileDataOrNull(data) {
if (data.version == "1.0") {
return new CryptoHelper();
}
if (data.version == "2.0") {
return this.cryptoHelper2304_v2;
}
return null;
}
static BuildFromDecryptableOrThrow(decryptable) {
const result = _CryptoHelperFactory.BuildFromDecryptableOrNull(decryptable);
if (result != null) {
return result;
}
throw new Error(`Unable to determine ICryptoHelper for Decryptable ver ${decryptable.version}`);
}
static BuildFromDecryptableOrNull(decryptable) {
if (decryptable.version == 0) {
return new CryptoHelperObsolete();
}
if (decryptable.version == 1) {
return new CryptoHelper();
}
if (decryptable.version == 2) {
return this.cryptoHelper2304_v2;
}
return null;
}
};
_CryptoHelperFactory.cryptoHelper2304_v2 = new CryptoHelper2304(16, 16, 21e4);
var CryptoHelperFactory = _CryptoHelperFactory;
// src/services/FileDataHelper.ts
var FileData2 = class {
constructor(version, hint, encodedData) {
this.version = "1.0";
this.version = version;
this.hint = hint;
this.encodedData = encodedData;
}
};
var _FileDataHelper = class _FileDataHelper {
static async encrypt(pass, hint, text) {
const crypto2 = CryptoHelperFactory.BuildDefault();
const encryptedData = await crypto2.encryptToBase64(text, pass);
return new FileData2(_FileDataHelper.DEFAULT_VERSION, hint, encryptedData);
}
static async decrypt(data, pass) {
if (data.encodedData == "") {
return "";
}
const crypto2 = CryptoHelperFactory.BuildFromFileDataOrThrow(data);
return await crypto2.decryptFromBase64(data.encodedData, pass);
}
};
_FileDataHelper.DEFAULT_VERSION = "2.0";
var FileDataHelper = _FileDataHelper;
var JsonFileEncoding = class {
static encode(data) {
return JSON.stringify(data, null, 2);
}
static isEncoded(text) {
try {
JSON.parse(text);
return true;
} catch (error) {
return false;
}
}
static decode(encodedText) {
if (encodedText === "") {
return new FileData2(FileDataHelper.DEFAULT_VERSION, "", "");
}
return JSON.parse(encodedText);
}
};
// src/tools/offline-decrypt.ts
var OfflineDecrypt = class {
async decrypt(content, password) {
console.info("Trying the default decryption");
const chDef = CryptoHelperFactory.BuildDefault();
const result = await chDef.decryptFromBase64(content, password);
if (result != null) {
return result;
}
console.info("Trying marked inplace feature decryption");
const ta = new FeatureInplaceTextAnalysis(content);
if (ta.decryptable != null) {
const ch = CryptoHelperFactory.BuildFromDecryptableOrNull(ta.decryptable);
if (ch != null) {
const result2 = await ch.decryptFromBase64(ta.decryptable.base64CipherText, password);
if (result2 != null) {
return result2;
}
}
}
for (let ver = 10; ver >= 0; ver--) {
console.info("Trying non-marked inplace feature decryption", "ver", ver);
const decryptable = { version: ver, base64CipherText: content, hint: "", showInReadingView: false };
const ch = CryptoHelperFactory.BuildFromDecryptableOrNull(decryptable);
const result2 = await (ch == null ? void 0 : ch.decryptFromBase64(decryptable.base64CipherText, password));
if (result2 != null) {
return result2;
}
}
console.info("Trying whole note feature decryption");
try {
const fileData = JsonFileEncoding.decode(content);
console.debug(fileData);
const chFd = CryptoHelperFactory.BuildFromFileDataOrNull(fileData);
const resultFd = await (chFd == null ? void 0 : chFd.decryptFromBase64(fileData.encodedData, password));
if (resultFd != null) {
return resultFd;
}
} catch (e) {
console.info(e);
}
return null;
}
};
window.$ = new OfflineDecrypt();
})();
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/features/feature-inplace-encrypt/Decryptable.ts", "../src/features/feature-inplace-encrypt/FeatureInplaceConstants.ts", "../src/features/feature-inplace-encrypt/featureInplaceTextAnalysis.ts", "../src/services/CryptoHelper.ts", "../src/services/CryptoHelper2304.ts", "../src/services/CryptoHelperObsolete.ts", "../src/services/CryptoHelperFactory.ts", "../src/services/FileDataHelper.ts", "../src/tools/offline-decrypt.ts"],
  "sourcesContent": ["export class Decryptable{\r\n\tversion: number;\r\n\tbase64CipherText:string;\r\n\thint:string;\r\n\tshowInReadingView: boolean;\r\n}", "\r\nexport const _PREFIX_B = '%%\uD83D\uDD10\u03B2 ';\r\nexport const _PREFIX_B_VISIBLE = '\uD83D\uDD10\u03B2 ';\r\n\r\nexport const _PREFIX_A = '%%\uD83D\uDD10\u03B1 ';\r\nexport const _PREFIX_A_VISIBLE = '\uD83D\uDD10\u03B1 ';\r\nexport const _PREFIX_OBSOLETE = '%%\uD83D\uDD10 ';\r\nexport const _PREFIX_OBSOLETE_VISIBLE = '\uD83D\uDD10 ';\r\n\r\nexport const _PREFIX_ENCODE_DEFAULT = _PREFIX_B;\r\nexport const _PREFIX_ENCODE_DEFAULT_VISIBLE = _PREFIX_B_VISIBLE;\r\n\r\n// Should be listed by evaluation priority\r\nexport const _PREFIXES = [\r\n\t_PREFIX_B,\r\n\t_PREFIX_B_VISIBLE,\r\n\t_PREFIX_A,\r\n\t_PREFIX_A_VISIBLE,\r\n\t_PREFIX_OBSOLETE,\r\n\t_PREFIX_OBSOLETE_VISIBLE\r\n];\r\n\r\nexport const _SUFFIX_WITH_COMMENT = ' \uD83D\uDD10%%';\r\nexport const _SUFFIX_NO_COMMENT = ' \uD83D\uDD10';\r\n\r\n// Should be listed by evaluation priority\r\nexport const _SUFFIXES = [\r\n\t_SUFFIX_WITH_COMMENT,\r\n\t_SUFFIX_NO_COMMENT\r\n]\r\n\r\nexport const _HINT = '\uD83D\uDCA1';", "import { Decryptable } from \"./Decryptable.ts\";\r\nimport { _HINT, _PREFIXES, _PREFIX_A, _PREFIX_A_VISIBLE, _PREFIX_B, _PREFIX_B_VISIBLE, _PREFIX_OBSOLETE, _PREFIX_OBSOLETE_VISIBLE, _SUFFIXES } from \"./FeatureInplaceConstants.ts\";\r\n\r\nexport class FeatureInplaceTextAnalysis{\r\n\tprocessedText:string;\r\n\tisEmpty: boolean;\r\n\t\r\n\tprefix: string;\r\n\tsuffix: string;\r\n\r\n\thasObsoleteEncryptedPrefix: boolean;\r\n\thasEncryptedPrefix: boolean;\r\n\thasEncryptedSuffix: boolean;\r\n\tcanDecrypt: boolean;\r\n\tcanEncrypt: boolean;\r\n\tcontainsEncryptedMarkers: boolean;\r\n\tdecryptable? : Decryptable;\r\n\r\n\tconstructor(text: string){\r\n\t\tthis.process(text);\r\n\t}\r\n\r\n\tprivate process( text: string ) : void{\r\n\t\t\r\n\t\tthis.processedText = text;\r\n\r\n\t\tthis.isEmpty = text.length === 0;\r\n\r\n\t\tthis.prefix = _PREFIXES.find( (prefix) => text.startsWith(prefix) ) ?? '';\r\n\t\tthis.suffix = _SUFFIXES.find( (suffix) => text.endsWith(suffix) ) ?? '';\r\n\t\t\r\n\t\tthis.hasEncryptedPrefix = this.prefix.length > 0;\r\n\t\tthis.hasEncryptedSuffix = this.suffix.length > 0;\r\n\r\n\t\tthis.hasObsoleteEncryptedPrefix = this.prefix === _PREFIX_OBSOLETE || this.prefix === _PREFIX_OBSOLETE_VISIBLE;\r\n\r\n\t\tthis.containsEncryptedMarkers = [..._PREFIXES, ..._SUFFIXES].some( (marker) => text.includes(marker ));\r\n\r\n\t\tthis.canDecrypt = this.hasEncryptedPrefix && this.hasEncryptedSuffix;\r\n\t\tthis.canEncrypt = !this.hasEncryptedPrefix && !this.containsEncryptedMarkers;\r\n\t\t\r\n\t\tif (this.canDecrypt){\r\n\t\t\tconst decryptable = this.parseDecryptableContent(text);\r\n\r\n\t\t\tif ( decryptable != null ){\r\n\t\t\t\tthis.decryptable = decryptable;\r\n\t\t\t}else{\r\n\t\t\t\tthis.canDecrypt = false;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprivate parseDecryptableContent(text: string) : Decryptable | null {\r\n\t\tconst result = new Decryptable();\r\n\r\n\t\tif (\r\n\t\t\t!this.hasEncryptedPrefix\r\n\t\t\t|| !this.hasEncryptedSuffix\r\n\t\t){\r\n\t\t\treturn null; // invalid format\r\n\t\t}\r\n\t\t\r\n\t\tif ( this.hasObsoleteEncryptedPrefix ){\r\n\t\t\tresult.version = 0;\r\n\t\t}else if ( this.prefix == _PREFIX_B || this.prefix == _PREFIX_B_VISIBLE ){\r\n\t\t\tresult.version = 2;\r\n\t\t}else if ( this.prefix == _PREFIX_A || this.prefix == _PREFIX_A_VISIBLE ){\r\n\t\t\tresult.version = 1;\r\n\t\t}\r\n\r\n\t\t// remove markers from start and end\t\r\n\t\tconst content = text.substring(this.prefix.length, text.length - this.suffix.length);\r\n\r\n\t\tif ( [..._PREFIXES, ..._SUFFIXES].some( (marker) => content.includes( marker )) ){\r\n\t\t\t// content, itself has markers\r\n\t\t\treturn null;\r\n\t\t}\r\n\r\n\t\t// check if there is a hint\r\n\t\tif (content.substring(0,_HINT.length) == _HINT){\r\n\t\t\tconst endHintMarker = content.indexOf(_HINT,_HINT.length);\r\n\t\t\tif (endHintMarker<0){\r\n\t\t\t\treturn null; // invalid format\r\n\t\t\t}\r\n\t\t\tresult.hint = content.substring(_HINT.length,endHintMarker)\r\n\t\t\tresult.base64CipherText = content.substring(endHintMarker+_HINT.length);\r\n\t\t}else{\r\n\t\t\tresult.base64CipherText = content;\r\n\t\t}\r\n\t\tresult.showInReadingView = !this.prefix.includes(\"%%\");\r\n\t\treturn result;\r\n\r\n\t}\r\n}", "const vectorSize\t= 16;\r\nconst utf8Encoder\t= new TextEncoder();\r\nconst utf8Decoder\t= new TextDecoder();\r\nconst iterations\t= 1000;\r\nconst salt\t\t\t= utf8Encoder.encode('XHWnDAT6ehMVY2zD');\r\n\r\nexport class CryptoHelper {\r\n\r\n\t// constructor(){\r\n\t// \tconsole.debug('new CryptoHelper');\r\n\t// }\r\n\r\n\tprivate async deriveKey(password:string) :Promise<CryptoKey> {\r\n\t\tconst buffer     = utf8Encoder.encode(password);\r\n\t\tconst key        = await crypto.subtle.importKey('raw', buffer, {name: 'PBKDF2'}, false, ['deriveKey']);\r\n\t\tconst privateKey = crypto.subtle.deriveKey(\r\n\t\t\t{\r\n\t\t\t\tname: 'PBKDF2',\r\n\t\t\t\thash: {name: 'SHA-256'},\r\n\t\t\t\titerations,\r\n\t\t\t\tsalt\r\n\t\t\t},\r\n\t\t\tkey,\r\n\t\t\t{\r\n\t\t\t\tname: 'AES-GCM',\r\n\t\t\t\tlength: 256\r\n\t\t\t},\r\n\t\t\tfalse,\r\n\t\t\t['encrypt', 'decrypt']\r\n\t\t);\r\n\t\t\r\n\t\treturn privateKey;\r\n\t}\r\n\r\n\tpublic async encryptToBytes(text: string, password: string): Promise<Uint8Array> {\r\n\r\n\t\tconst key = await this.deriveKey(password);\r\n\t\t\r\n\t\tconst textBytesToEncrypt = utf8Encoder.encode(text);\r\n\t\tconst vector = crypto.getRandomValues(new Uint8Array(vectorSize));\r\n\t\t\r\n\t\t// encrypt into bytes\r\n\t\tconst encryptedBytes = new Uint8Array(\r\n\t\t\tawait crypto.subtle.encrypt(\r\n\t\t\t\t{name: 'AES-GCM', iv: vector},\r\n\t\t\t\tkey,\r\n\t\t\t\ttextBytesToEncrypt\r\n\t\t\t)\r\n\t\t);\r\n\t\t\r\n\t\tconst finalBytes = new Uint8Array( vector.byteLength + encryptedBytes.byteLength );\r\n\t\tfinalBytes.set( vector, 0 );\r\n\t\tfinalBytes.set( encryptedBytes, vector.byteLength );\r\n\r\n\t\treturn finalBytes;\r\n\t}\r\n\r\n\tprivate convertToString( bytes : Uint8Array ): string {\r\n\t\tlet result = '';\r\n\t\tfor (let idx = 0; idx < bytes.length; idx++) {\r\n\t\t\t// append to result\r\n\t\t\tresult += String.fromCharCode(bytes[idx]);\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\r\n\tpublic async encryptToBase64(text: string, password: string): Promise<string> {\r\n\r\n\t\tconst finalBytes = await this.encryptToBytes(text, password);\r\n\r\n\t\t//convert array to base64\r\n\t\tconst base64Text = btoa( this.convertToString(finalBytes) );\r\n\r\n\t\treturn base64Text;\r\n\t}\r\n\r\n\tprivate stringToArray(str: string): Uint8Array {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < str.length; i++) {\r\n\t\t\tresult.push(str.charCodeAt(i));\r\n\t\t}\r\n\t\treturn new Uint8Array(result);\r\n\t}\r\n\r\n\tpublic async decryptFromBytes(encryptedBytes: Uint8Array, password: string): Promise<string|null> {\r\n\t\ttry {\r\n\r\n\t\t\t// extract iv\r\n\t\t\tconst vector = encryptedBytes.slice(0,vectorSize);\r\n\r\n\t\t\t// extract encrypted text\r\n\t\t\tconst encryptedTextBytes = encryptedBytes.slice(vectorSize);\r\n\r\n\t\t\tconst key = await this.deriveKey(password);\r\n\r\n\t\t\t// decrypt into bytes\r\n\t\t\tconst decryptedBytes = await crypto.subtle.decrypt(\r\n\t\t\t\t{name: 'AES-GCM', iv: vector},\r\n\t\t\t\tkey,\r\n\t\t\t\tencryptedTextBytes\r\n\t\t\t);\r\n\r\n\t\t\t// convert bytes to text\r\n\t\t\tconst decryptedText = utf8Decoder.decode(decryptedBytes);\r\n\t\t\treturn decryptedText;\r\n\t\t} catch (e) {\r\n\t\t\t//console.error(e);\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n\tpublic async decryptFromBase64(base64Encoded: string, password: string): Promise<string|null> {\r\n\t\ttry {\r\n\r\n\t\t\tconst bytesToDecode = this.stringToArray(atob(base64Encoded));\r\n\t\t\t\r\n\t\t\treturn await this.decryptFromBytes(bytesToDecode, password);\r\n\r\n\t\t\t// // extract iv\r\n\t\t\t// const vector = bytesToDecode.slice(0,vectorSize);\r\n\r\n\t\t\t// // extract encrypted text\r\n\t\t\t// const encryptedTextBytes = bytesToDecode.slice(vectorSize);\r\n\r\n\t\t\t// const key = await this.deriveKey(password);\r\n\r\n\t\t\t// // decrypt into bytes\r\n\t\t\t// let decryptedBytes = await crypto.subtle.decrypt(\r\n\t\t\t// \t{name: 'AES-GCM', iv: vector},\r\n\t\t\t// \tkey,\r\n\t\t\t// \tencryptedTextBytes\r\n\t\t\t// );\r\n\r\n\t\t\t// // convert bytes to text\r\n\t\t\t// let decryptedText = utf8Decoder.decode(decryptedBytes);\r\n\t\t\t// return decryptedText;\r\n\t\t} catch (e) {\r\n\t\t\t//console.error(e);\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n}\r\n\r\n\r\n\r\n", "import { ICryptoHelper } from \"./ICryptoHelper.ts\";\r\n\r\nexport class CryptoHelper2304 implements ICryptoHelper {\r\n\tpublic vectorSize: number;\r\n\tpublic saltSize: number;\r\n\tpublic iterations: number;\r\n\r\n\tconstructor( vectorSize: number, saltSize: number, iterations: number ){\r\n\t\t//console.debug('new CryptoHelper2304', {vectorSize, saltSize, iterations});\r\n\t\tthis.vectorSize = vectorSize;\r\n\t\tthis.saltSize = saltSize;\r\n\t\tthis.iterations = iterations;\r\n\t}\r\n\r\n\tprivate async deriveKey( password:string, salt:Uint8Array ) :Promise<CryptoKey> {\r\n\t\t// console.trace('CryptoHelper2304.deriveKey');\r\n\t\t//See: https://developer.mozilla.org/en-US/docs/Web/API/SubtleCrypto\r\n\t\tconst utf8Encoder\t= new TextEncoder();\r\n\t\tconst buffer     = utf8Encoder.encode(password);\r\n\t\tconst key        = await crypto.subtle.importKey(\r\n\t\t\t/*format*/ 'raw',\r\n\t\t\t/*keyData*/ buffer,\r\n\t\t\t/*algorithm*/ 'PBKDF2',\r\n\t\t\t/*extractable*/ false,\r\n\t\t\t/*keyUsages*/ ['deriveKey']\r\n\t\t);\r\n\t\t\r\n\t\t//console.time('CryptoHelper2304.deriveKey');\r\n\t\ttry{\r\n\t\t\tconst privateKey = await crypto.subtle.deriveKey(\r\n\t\t\t\t/*algorithm*/ {\r\n\t\t\t\t\tname: 'PBKDF2',\r\n\t\t\t\t\thash: 'SHA-512',\r\n\t\t\t\t\tsalt,\r\n\t\t\t\t\titerations: this.iterations,\r\n\t\t\t\t},\r\n\t\t\t\t/*baseKey*/ key,\r\n\t\t\t\t/*derivedKeyAlgorithm*/ {\r\n\t\t\t\t\tname: 'AES-GCM',\r\n\t\t\t\t\tlength: 256\r\n\t\t\t\t},\r\n\t\t\t\t/*extractable*/ false,\r\n\t\t\t\t/*keyUsages*/ ['encrypt', 'decrypt']\r\n\t\t\t);\r\n\t\t\t\r\n\t\t\treturn privateKey;\r\n\t\t}finally{\r\n\t\t\t//console.timeEnd('CryptoHelper2304.deriveKey');\r\n\t\t}\r\n\t}\r\n\r\n\tprivate async encryptToBytes( text: string, password: string ): Promise<Uint8Array> {\r\n\r\n\t\tconst salt = crypto.getRandomValues( new Uint8Array(this.saltSize) );\r\n\r\n\t\tconst key = await this.deriveKey( password, salt );\r\n\t\t\r\n\t\tconst utf8Encoder\t= new TextEncoder();\r\n\t\tconst textBytesToEncrypt = utf8Encoder.encode(text);\r\n\t\tconst vector = crypto.getRandomValues(new Uint8Array(this.vectorSize));\r\n\t\t\r\n\t\t// encrypt into bytes\r\n\t\tconst encryptedBytes = new Uint8Array(\r\n\t\t\tawait crypto.subtle.encrypt(\r\n\t\t\t\t/*algorithm*/ {\r\n\t\t\t\t\tname: 'AES-GCM',\r\n\t\t\t\t\tiv: vector\r\n\t\t\t\t},\r\n\t\t\t\t/*key*/ key,\r\n\t\t\t\t/*data*/ textBytesToEncrypt\r\n\t\t\t)\r\n\t\t);\r\n\t\t\r\n\t\tconst finalBytes = new Uint8Array( vector.byteLength + salt.byteLength + encryptedBytes.byteLength );\r\n\t\tfinalBytes.set( vector, 0 );\r\n\t\tfinalBytes.set( salt, vector.byteLength );\r\n\t\tfinalBytes.set( encryptedBytes, vector.byteLength + salt.byteLength );\r\n\r\n\t\treturn finalBytes;\r\n\t}\r\n\r\n\tprivate convertToString( bytes : Uint8Array ): string {\r\n\t\tlet result = '';\r\n\t\tfor (let idx = 0; idx < bytes.length; idx++) {\r\n\t\t\t// append to result\r\n\t\t\tresult += String.fromCharCode(bytes[idx]);\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\r\n\tpublic async encryptToBase64(text: string, password: string): Promise<string> {\r\n\r\n\t\tconst finalBytes = await this.encryptToBytes(text, password);\r\n\r\n\t\t//convert array to base64\r\n\t\tconst base64Text = btoa( this.convertToString(finalBytes) );\r\n\r\n\t\treturn base64Text;\r\n\t}\r\n\r\n\tprivate stringToArray(str: string): Uint8Array {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < str.length; i++) {\r\n\t\t\tresult.push(str.charCodeAt(i));\r\n\t\t}\r\n\t\treturn new Uint8Array(result);\r\n\t}\r\n\r\n\tprivate async decryptFromBytes(\r\n\t\tencryptedBytes: Uint8Array,\r\n\t\tpassword: string\r\n\t): Promise<string|null> {\r\n\t\ttry {\r\n\t\t\t\r\n\t\t\tlet offset: number;\r\n\t\t\tlet nextOffset : number|undefined;\r\n\t\t\t\r\n\t\t\t// extract iv\r\n\t\t\toffset = 0;\r\n\t\t\tnextOffset = offset + this.vectorSize;\r\n\t\t\tconst vector = encryptedBytes.slice(offset, nextOffset);\r\n\t\t\t\r\n\t\t\t// extract salt\r\n\t\t\toffset = nextOffset;\r\n\t\t\tnextOffset = offset + this.saltSize;\r\n\t\t\tconst salt = encryptedBytes.slice(offset, nextOffset);\r\n\t\t\t\r\n\t\t\t// extract encrypted text\r\n\t\t\toffset = nextOffset;\r\n\t\t\tnextOffset = undefined;\r\n\t\t\tconst encryptedTextBytes = encryptedBytes.slice(offset);\r\n\t\t\t\r\n\t\t\tconst key = await this.deriveKey(password, salt);\r\n\t\t\t\r\n\t\t\t// decrypt into bytes\r\n\t\t\tconst decryptedBytes = await crypto.subtle.decrypt(\r\n\t\t\t\t/*algorithm*/ {\r\n\t\t\t\t\tname: 'AES-GCM',\r\n\t\t\t\t\tiv: vector\r\n\t\t\t\t},\r\n\t\t\t\t/*key*/ key,\r\n\t\t\t\t/*data*/ encryptedTextBytes\r\n\t\t\t);\r\n\t\t\t\r\n\t\t\t// convert bytes to text\r\n\t\t\tconst utf8Decoder\t= new TextDecoder();\r\n\t\t\tconst decryptedText = utf8Decoder.decode(decryptedBytes);\r\n\t\t\treturn decryptedText;\r\n\t\t\t\r\n\t\t} catch (e) {\r\n\t\t\t//console.error(e);\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n\tpublic async decryptFromBase64( base64Encoded: string, password: string ): Promise<string|null> {\r\n\t\ttry {\r\n\t\t\tconst bytesToDecode = this.stringToArray(atob(base64Encoded));\r\n\t\t\treturn await this.decryptFromBytes( bytesToDecode, password );\r\n\t\t} catch (e) {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n}", "export const algorithmObsolete = {\r\n\tname: 'AES-GCM',\r\n\tiv: new Uint8Array([196, 190, 240, 190, 188, 78, 41, 132, 15, 220, 84, 211]),\r\n\ttagLength: 128\r\n}\r\n\r\nexport class CryptoHelperObsolete {\r\n\r\n\tprivate async buildKey(password: string) {\r\n\t\tconst utf8Encode = new TextEncoder();\r\n\t\tconst passwordBytes = utf8Encode.encode(password);\r\n\r\n\t\tconst passwordDigest = await crypto.subtle.digest({ name: 'SHA-256' }, passwordBytes);\r\n\r\n\t\tconst key = await crypto.subtle.importKey(\r\n\t\t\t'raw',\r\n\t\t\tpasswordDigest,\r\n\t\t\talgorithmObsolete,\r\n\t\t\tfalse,\r\n\t\t\t['encrypt', 'decrypt']\r\n\t\t);\r\n\r\n\t\treturn key;\r\n\t}\r\n\t\r\n\t/**\r\n  \t* @deprecated\r\n \t*/\r\n\tpublic async encryptToBase64(text: string, password: string): Promise<string> {\r\n\t\tconst key = await this.buildKey(password);\r\n\r\n\t\tconst utf8Encode = new TextEncoder();\r\n\t\tconst bytesToEncrypt = utf8Encode.encode(text);\r\n\r\n\t\t// encrypt into bytes\r\n\t\tconst encryptedBytes = new Uint8Array(await crypto.subtle.encrypt(\r\n\t\t\talgorithmObsolete, key, bytesToEncrypt\r\n\t\t));\r\n\r\n\t\t//convert array to base64\r\n\t\tconst base64Text = btoa(String.fromCharCode(...encryptedBytes));\r\n\r\n\t\treturn base64Text;\r\n\t}\r\n\r\n\tprivate stringToArray(str: string): Uint8Array {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < str.length; i++) {\r\n\t\t\tresult.push(str.charCodeAt(i));\r\n\t\t}\r\n\t\treturn new Uint8Array(result);\r\n\t}\r\n\r\n\tpublic async decryptFromBase64(base64Encoded: string, password: string): Promise<string|null> {\r\n\t\ttry {\r\n\t\t\t// convert base 64 to array\r\n\t\t\tconst bytesToDecrypt = this.stringToArray(atob(base64Encoded));\r\n\r\n\t\t\tconst key = await this.buildKey(password);\r\n\r\n\t\t\t// decrypt into bytes\r\n\t\t\tconst decryptedBytes = await crypto.subtle.decrypt(algorithmObsolete, key, bytesToDecrypt);\r\n\r\n\t\t\t// convert bytes to text\r\n\t\t\tconst utf8Decode = new TextDecoder();\r\n\t\t\tconst decryptedText = utf8Decode.decode(decryptedBytes);\r\n\t\t\treturn decryptedText;\r\n\t\t} catch (e) {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\r\n}\r\n", "import { FileData } from \"./FileDataHelper.ts\";\r\nimport { Decryptable } from \"../features/feature-inplace-encrypt/Decryptable.ts\";\r\nimport { CryptoHelper } from \"./CryptoHelper.ts\";\r\nimport { ICryptoHelper } from \"./ICryptoHelper.ts\";\r\nimport { CryptoHelper2304 } from \"./CryptoHelper2304.ts\";\r\nimport { CryptoHelperObsolete } from \"./CryptoHelperObsolete.ts\";\r\n\r\nexport class CryptoHelperFactory{\r\n\r\n\tpublic static cryptoHelper2304_v2 = new CryptoHelper2304( 16, 16, 210000 );\r\n\r\n\tpublic static BuildDefault(): ICryptoHelper{\r\n\t\treturn this.cryptoHelper2304_v2;\r\n\t}\r\n\r\n\tpublic static BuildFromFileDataOrThrow( data: FileData ) : ICryptoHelper {\r\n\t\tconst result = CryptoHelperFactory.BuildFromFileDataOrNull(data);\r\n\t\tif ( result != null ){\r\n\t\t\treturn result;\r\n\t\t}\r\n\t\tthrow new Error( `Unable to determine ICryptoHelper for File ver ${data.version}`);\r\n\t}\r\n\r\n\tpublic static BuildFromFileDataOrNull( data: FileData ) : ICryptoHelper | null {\r\n\t\tif ( data.version == '1.0' ){\r\n\t\t\treturn new CryptoHelper();\r\n\t\t}\r\n\r\n\t\t// note\t\t\t\tv2.0\tCryptoHelper2304\r\n\t\tif ( data.version == '2.0' ){\r\n\t\t\treturn this.cryptoHelper2304_v2;\r\n\t\t}\r\n\r\n\t\treturn null;\r\n\t}\r\n\r\n\tpublic static BuildFromDecryptableOrThrow( decryptable: Decryptable ) : ICryptoHelper {\r\n\t\tconst result = CryptoHelperFactory.BuildFromDecryptableOrNull( decryptable );\r\n\r\n\t\tif (result != null){\r\n\t\t\treturn result;\r\n\t\t}\r\n\t\tthrow new Error( `Unable to determine ICryptoHelper for Decryptable ver ${decryptable.version}`);\r\n\t}\r\n\r\n\tpublic static BuildFromDecryptableOrNull( decryptable: Decryptable ) : ICryptoHelper | null {\r\n\t\t// Versions\r\n\t\t// inplace original\t_PREFIX_OBSOLETE = '%%\uD83D\uDD10 '  CryptoHelperObsolete\r\n\t\t\r\n\t\t// inplace alpha\t_PREFIX_A = '%%\uD83D\uDD10\u03B1 '\t\tCryptoHelper\r\n\t\t// \t\t\t\t\t_PREFIX_A_VISIBLE = '\uD83D\uDD10\u03B1 '\tCryptoHelper\r\n\r\n\t\t// inplace beta \t_PREFIX_B = '%%\uD83D\uDD10\u03B2 '\t\tCryptoHelper2304( 16, 16, 210000 )\r\n\t\t//\t\t\t\t\t_PREFIX_B_VISIBLE = '\uD83D\uDD10\u03B2 '\tCryptoHelper2304( 16, 16, 210000 )\r\n\t\t\r\n\t\tif ( decryptable.version == 0 ){\r\n\t\t\treturn new CryptoHelperObsolete();\r\n\t\t}\r\n\r\n\t\tif ( decryptable.version == 1 ){\r\n\t\t\treturn new CryptoHelper();\r\n\t\t}\r\n\r\n\t\tif ( decryptable.version == 2 ){\r\n\t\t\treturn this.cryptoHelper2304_v2;\r\n\t\t}\r\n\r\n\t\treturn null;\r\n\t}\r\n\r\n}", "import { CryptoHelperFactory } from \"./CryptoHelperFactory.ts\";\r\n\r\nexport class FileData {\r\n\t\r\n\tpublic version = '1.0';\r\n\tpublic hint: string;\r\n\tpublic encodedData:string;\r\n\r\n\tconstructor( version:string, hint:string, encodedData:string ){\r\n\t\tthis.version = version;\r\n\t\tthis.hint = hint;\r\n\t\tthis.encodedData = encodedData;\r\n\t}\r\n}\r\n\r\nexport class FileDataHelper{\r\n\r\n\tpublic static DEFAULT_VERSION = '2.0';\r\n\r\n\tpublic static async encrypt( pass: string, hint:string, text:string ) : Promise<FileData>{\r\n\t\tconst crypto = CryptoHelperFactory.BuildDefault();\r\n\t\tconst encryptedData = await crypto.encryptToBase64(text, pass);\r\n\t\treturn new FileData( FileDataHelper.DEFAULT_VERSION, hint, encryptedData);\r\n\t}\r\n\r\n\tpublic static async decrypt( data: FileData, pass:string ) : Promise<string|null>{\r\n\t\tif ( data.encodedData == '' ){\r\n\t\t\treturn '';\r\n\t\t}\r\n\t\tconst crypto = CryptoHelperFactory.BuildFromFileDataOrThrow( data );\r\n\t\treturn await crypto.decryptFromBase64( data.encodedData, pass );\r\n\t}\r\n}\r\n\r\nexport class JsonFileEncoding {\r\n\r\n\tpublic static encode( data: FileData ) : string{\r\n\t\t//console.debug( 'JsonFileEncoding.encode', {data} );\r\n\t\treturn JSON.stringify(data, null, 2);\r\n\t}\r\n\r\n\tpublic static isEncoded( text: string ) : boolean {\r\n\t\ttry {\r\n\t\t\tJSON.parse( text );\r\n\t\t\treturn true;\r\n\t\t} catch ( error ) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\t}\r\n\r\n\tpublic static decode( encodedText:string ) : FileData {\r\n\t\t//console.debug('JsonFileEncoding.decode',{encodedText});\r\n\t\tif ( encodedText === '' ){\r\n\t\t\treturn new FileData( FileDataHelper.DEFAULT_VERSION, '', '' );\r\n\t\t}\r\n\t\treturn JSON.parse( encodedText ) as FileData;\r\n\t}\r\n}", "import { Decryptable } from \"../features/feature-inplace-encrypt/Decryptable.ts\";\r\nimport { FeatureInplaceTextAnalysis } from \"../features/feature-inplace-encrypt/featureInplaceTextAnalysis.ts\";\r\nimport { CryptoHelperFactory } from \"../services/CryptoHelperFactory.ts\";\r\nimport { JsonFileEncoding } from \"../services/FileDataHelper.ts\";\r\n\r\nexport class OfflineDecrypt {\r\n\r\n\tpublic async decrypt( content:string, password: string ) : Promise<string | null> {\r\n\r\n\t\t// Trying the default decryption\r\n\t\tconsole.info( 'Trying the default decryption' );\r\n\t\tconst chDef = CryptoHelperFactory.BuildDefault();\r\n\t\tconst result = await chDef.decryptFromBase64( content, password );\r\n\t\tif ( result != null ){\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\t// Trying marked inplace feature decryption\r\n\t\tconsole.info( 'Trying marked inplace feature decryption' );\r\n\t\tconst ta = new FeatureInplaceTextAnalysis( content );\r\n\t\tif ( ta.decryptable != null ){\r\n\t\t\tconst ch = CryptoHelperFactory.BuildFromDecryptableOrNull(ta.decryptable);\r\n\t\t\tif (ch != null){\r\n\t\t\t\tconst result = await ch.decryptFromBase64( ta.decryptable.base64CipherText, password );\r\n\t\t\t\tif ( result != null ){\r\n\t\t\t\t\treturn result;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Trying non-marked inplace feature decryption\r\n\t\tfor (let ver = 10; ver >= 0; ver--) {\r\n\t\t\tconsole.info( 'Trying non-marked inplace feature decryption', 'ver', ver );\r\n\t\t\tconst decryptable : Decryptable = { version: ver, base64CipherText: content, hint: '', showInReadingView: false };\r\n\t\t\tconst ch = CryptoHelperFactory.BuildFromDecryptableOrNull(decryptable)\r\n\t\t\tconst result = await ch?.decryptFromBase64( decryptable.base64CipherText, password );\r\n\t\t\tif ( result != null ){\r\n\t\t\t\treturn result;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\r\n\t\t// Trying whole note feature decryption\r\n\t\tconsole.info( 'Trying whole note feature decryption' );\r\n\t\ttry{\r\n\t\t\tconst fileData = JsonFileEncoding.decode( content );\r\n\t\t\tconsole.debug(fileData);\r\n\t\t\tconst chFd = CryptoHelperFactory.BuildFromFileDataOrNull( fileData );\r\n\t\t\tconst resultFd = await chFd?.decryptFromBase64( fileData.encodedData, password );\r\n\t\t\tif ( resultFd != null ){\r\n\t\t\t\treturn resultFd;\r\n\t\t\t}\r\n\t\t} catch (e){\r\n\t\t\tconsole.info(e);\r\n\t\t}\r\n\r\n\t\treturn null;\r\n\t}\r\n}\r\ndeclare global {\r\n    interface Window { $: OfflineDecrypt; }\r\n}\r\n\r\nwindow.$ = new OfflineDecrypt();\r\n"],
  "mappings": ";;AAAO,MAAM,cAAN,MAAiB;AAAA,EAKxB;;;ACJO,MAAM,YAAY;AAClB,MAAM,oBAAoB;AAE1B,MAAM,YAAY;AAClB,MAAM,oBAAoB;AAC1B,MAAM,mBAAmB;AACzB,MAAM,2BAA2B;AAEjC,MAAM,yBAAyB;AAC/B,MAAM,iCAAiC;AAGvC,MAAM,YAAY;AAAA,IACxB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AAEO,MAAM,uBAAuB;AAC7B,MAAM,qBAAqB;AAG3B,MAAM,YAAY;AAAA,IACxB;AAAA,IACA;AAAA,EACD;AAEO,MAAM,QAAQ;;;AC5Bd,MAAM,6BAAN,MAAgC;AAAA,IAetC,YAAY,MAAa;AACxB,WAAK,QAAQ,IAAI;AAAA,IAClB;AAAA,IAEQ,QAAS,MAAqB;AAtBvC;AAwBE,WAAK,gBAAgB;AAErB,WAAK,UAAU,KAAK,WAAW;AAE/B,WAAK,UAAS,eAAU,KAAM,CAAC,WAAW,KAAK,WAAW,MAAM,CAAE,MAApD,YAAyD;AACvE,WAAK,UAAS,eAAU,KAAM,CAAC,WAAW,KAAK,SAAS,MAAM,CAAE,MAAlD,YAAuD;AAErE,WAAK,qBAAqB,KAAK,OAAO,SAAS;AAC/C,WAAK,qBAAqB,KAAK,OAAO,SAAS;AAE/C,WAAK,6BAA6B,KAAK,WAAW,oBAAoB,KAAK,WAAW;AAEtF,WAAK,2BAA2B,CAAC,GAAG,WAAW,GAAG,SAAS,EAAE,KAAM,CAAC,WAAW,KAAK,SAAS,MAAO,CAAC;AAErG,WAAK,aAAa,KAAK,sBAAsB,KAAK;AAClD,WAAK,aAAa,CAAC,KAAK,sBAAsB,CAAC,KAAK;AAEpD,UAAI,KAAK,YAAW;AACnB,cAAM,cAAc,KAAK,wBAAwB,IAAI;AAErD,YAAK,eAAe,MAAM;AACzB,eAAK,cAAc;AAAA,QACpB,OAAK;AACJ,eAAK,aAAa;AAAA,QACnB;AAAA,MACD;AAAA,IACD;AAAA,IAEQ,wBAAwB,MAAmC;AAClE,YAAM,SAAS,IAAI,YAAY;AAE/B,UACC,CAAC,KAAK,sBACH,CAAC,KAAK,oBACT;AACA,eAAO;AAAA,MACR;AAEA,UAAK,KAAK,4BAA4B;AACrC,eAAO,UAAU;AAAA,MAClB,WAAW,KAAK,UAAU,aAAa,KAAK,UAAU,mBAAmB;AACxE,eAAO,UAAU;AAAA,MAClB,WAAW,KAAK,UAAU,aAAa,KAAK,UAAU,mBAAmB;AACxE,eAAO,UAAU;AAAA,MAClB;AAGA,YAAM,UAAU,KAAK,UAAU,KAAK,OAAO,QAAQ,KAAK,SAAS,KAAK,OAAO,MAAM;AAEnF,UAAK,CAAC,GAAG,WAAW,GAAG,SAAS,EAAE,KAAM,CAAC,WAAW,QAAQ,SAAU,MAAO,CAAC,GAAG;AAEhF,eAAO;AAAA,MACR;AAGA,UAAI,QAAQ,UAAU,GAAE,MAAM,MAAM,KAAK,OAAM;AAC9C,cAAM,gBAAgB,QAAQ,QAAQ,OAAM,MAAM,MAAM;AACxD,YAAI,gBAAc,GAAE;AACnB,iBAAO;AAAA,QACR;AACA,eAAO,OAAO,QAAQ,UAAU,MAAM,QAAO,aAAa;AAC1D,eAAO,mBAAmB,QAAQ,UAAU,gBAAc,MAAM,MAAM;AAAA,MACvE,OAAK;AACJ,eAAO,mBAAmB;AAAA,MAC3B;AACA,aAAO,oBAAoB,CAAC,KAAK,OAAO,SAAS,IAAI;AACrD,aAAO;AAAA,IAER;AAAA,EACD;;;AC7FA,MAAM,aAAa;AACnB,MAAM,cAAc,IAAI,YAAY;AACpC,MAAM,cAAc,IAAI,YAAY;AACpC,MAAM,aAAa;AACnB,MAAM,OAAS,YAAY,OAAO,kBAAkB;AAE7C,MAAM,eAAN,MAAmB;AAAA;AAAA;AAAA;AAAA,IAMzB,MAAc,UAAU,UAAqC;AAC5D,YAAM,SAAa,YAAY,OAAO,QAAQ;AAC9C,YAAM,MAAa,MAAM,OAAO,OAAO,UAAU,OAAO,QAAQ,EAAC,MAAM,SAAQ,GAAG,OAAO,CAAC,WAAW,CAAC;AACtG,YAAM,aAAa,OAAO,OAAO;AAAA,QAChC;AAAA,UACC,MAAM;AAAA,UACN,MAAM,EAAC,MAAM,UAAS;AAAA,UACtB;AAAA,UACA;AAAA,QACD;AAAA,QACA;AAAA,QACA;AAAA,UACC,MAAM;AAAA,UACN,QAAQ;AAAA,QACT;AAAA,QACA;AAAA,QACA,CAAC,WAAW,SAAS;AAAA,MACtB;AAEA,aAAO;AAAA,IACR;AAAA,IAEA,MAAa,eAAe,MAAc,UAAuC;AAEhF,YAAM,MAAM,MAAM,KAAK,UAAU,QAAQ;AAEzC,YAAM,qBAAqB,YAAY,OAAO,IAAI;AAClD,YAAM,SAAS,OAAO,gBAAgB,IAAI,WAAW,UAAU,CAAC;AAGhE,YAAM,iBAAiB,IAAI;AAAA,QAC1B,MAAM,OAAO,OAAO;AAAA,UACnB,EAAC,MAAM,WAAW,IAAI,OAAM;AAAA,UAC5B;AAAA,UACA;AAAA,QACD;AAAA,MACD;AAEA,YAAM,aAAa,IAAI,WAAY,OAAO,aAAa,eAAe,UAAW;AACjF,iBAAW,IAAK,QAAQ,CAAE;AAC1B,iBAAW,IAAK,gBAAgB,OAAO,UAAW;AAElD,aAAO;AAAA,IACR;AAAA,IAEQ,gBAAiB,OAA6B;AACrD,UAAI,SAAS;AACb,eAAS,MAAM,GAAG,MAAM,MAAM,QAAQ,OAAO;AAE5C,kBAAU,OAAO,aAAa,MAAM,GAAG,CAAC;AAAA,MACzC;AACA,aAAO;AAAA,IACR;AAAA,IAEA,MAAa,gBAAgB,MAAc,UAAmC;AAE7E,YAAM,aAAa,MAAM,KAAK,eAAe,MAAM,QAAQ;AAG3D,YAAM,aAAa,KAAM,KAAK,gBAAgB,UAAU,CAAE;AAE1D,aAAO;AAAA,IACR;AAAA,IAEQ,cAAc,KAAyB;AAC9C,YAAM,SAAS,CAAC;AAChB,eAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACpC,eAAO,KAAK,IAAI,WAAW,CAAC,CAAC;AAAA,MAC9B;AACA,aAAO,IAAI,WAAW,MAAM;AAAA,IAC7B;AAAA,IAEA,MAAa,iBAAiB,gBAA4B,UAAwC;AACjG,UAAI;AAGH,cAAM,SAAS,eAAe,MAAM,GAAE,UAAU;AAGhD,cAAM,qBAAqB,eAAe,MAAM,UAAU;AAE1D,cAAM,MAAM,MAAM,KAAK,UAAU,QAAQ;AAGzC,cAAM,iBAAiB,MAAM,OAAO,OAAO;AAAA,UAC1C,EAAC,MAAM,WAAW,IAAI,OAAM;AAAA,UAC5B;AAAA,UACA;AAAA,QACD;AAGA,cAAM,gBAAgB,YAAY,OAAO,cAAc;AACvD,eAAO;AAAA,MACR,SAAS,GAAG;AAEX,eAAO;AAAA,MACR;AAAA,IACD;AAAA,IAEA,MAAa,kBAAkB,eAAuB,UAAwC;AAC7F,UAAI;AAEH,cAAM,gBAAgB,KAAK,cAAc,KAAK,aAAa,CAAC;AAE5D,eAAO,MAAM,KAAK,iBAAiB,eAAe,QAAQ;AAAA,MAoB3D,SAAS,GAAG;AAEX,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EAED;;;AC5IO,MAAM,mBAAN,MAAgD;AAAA,IAKtD,YAAaA,aAAoB,UAAkBC,aAAoB;AAEtE,WAAK,aAAaD;AAClB,WAAK,WAAW;AAChB,WAAK,aAAaC;AAAA,IACnB;AAAA,IAEA,MAAc,UAAW,UAAiBC,OAAsC;AAG/E,YAAMC,eAAc,IAAI,YAAY;AACpC,YAAM,SAAaA,aAAY,OAAO,QAAQ;AAC9C,YAAM,MAAa,MAAM,OAAO,OAAO;AAAA;AAAA,QAC3B;AAAA;AAAA,QACC;AAAA;AAAA,QACE;AAAA;AAAA,QACE;AAAA;AAAA,QACF,CAAC,WAAW;AAAA,MAC3B;AAGA,UAAG;AACF,cAAM,aAAa,MAAM,OAAO,OAAO;AAAA;AAAA,UACxB;AAAA,YACb,MAAM;AAAA,YACN,MAAM;AAAA,YACN,MAAAD;AAAA,YACA,YAAY,KAAK;AAAA,UAClB;AAAA;AAAA,UACY;AAAA;AAAA,UACY;AAAA,YACvB,MAAM;AAAA,YACN,QAAQ;AAAA,UACT;AAAA;AAAA,UACgB;AAAA;AAAA,UACF,CAAC,WAAW,SAAS;AAAA,QACpC;AAEA,eAAO;AAAA,MACR,UAAC;AAAA,MAED;AAAA,IACD;AAAA,IAEA,MAAc,eAAgB,MAAc,UAAwC;AAEnF,YAAMA,QAAO,OAAO,gBAAiB,IAAI,WAAW,KAAK,QAAQ,CAAE;AAEnE,YAAM,MAAM,MAAM,KAAK,UAAW,UAAUA,KAAK;AAEjD,YAAMC,eAAc,IAAI,YAAY;AACpC,YAAM,qBAAqBA,aAAY,OAAO,IAAI;AAClD,YAAM,SAAS,OAAO,gBAAgB,IAAI,WAAW,KAAK,UAAU,CAAC;AAGrE,YAAM,iBAAiB,IAAI;AAAA,QAC1B,MAAM,OAAO,OAAO;AAAA;AAAA,UACL;AAAA,YACb,MAAM;AAAA,YACN,IAAI;AAAA,UACL;AAAA;AAAA,UACQ;AAAA;AAAA,UACC;AAAA,QACV;AAAA,MACD;AAEA,YAAM,aAAa,IAAI,WAAY,OAAO,aAAaD,MAAK,aAAa,eAAe,UAAW;AACnG,iBAAW,IAAK,QAAQ,CAAE;AAC1B,iBAAW,IAAKA,OAAM,OAAO,UAAW;AACxC,iBAAW,IAAK,gBAAgB,OAAO,aAAaA,MAAK,UAAW;AAEpE,aAAO;AAAA,IACR;AAAA,IAEQ,gBAAiB,OAA6B;AACrD,UAAI,SAAS;AACb,eAAS,MAAM,GAAG,MAAM,MAAM,QAAQ,OAAO;AAE5C,kBAAU,OAAO,aAAa,MAAM,GAAG,CAAC;AAAA,MACzC;AACA,aAAO;AAAA,IACR;AAAA,IAEA,MAAa,gBAAgB,MAAc,UAAmC;AAE7E,YAAM,aAAa,MAAM,KAAK,eAAe,MAAM,QAAQ;AAG3D,YAAM,aAAa,KAAM,KAAK,gBAAgB,UAAU,CAAE;AAE1D,aAAO;AAAA,IACR;AAAA,IAEQ,cAAc,KAAyB;AAC9C,YAAM,SAAS,CAAC;AAChB,eAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACpC,eAAO,KAAK,IAAI,WAAW,CAAC,CAAC;AAAA,MAC9B;AACA,aAAO,IAAI,WAAW,MAAM;AAAA,IAC7B;AAAA,IAEA,MAAc,iBACb,gBACA,UACuB;AACvB,UAAI;AAEH,YAAI;AACJ,YAAI;AAGJ,iBAAS;AACT,qBAAa,SAAS,KAAK;AAC3B,cAAM,SAAS,eAAe,MAAM,QAAQ,UAAU;AAGtD,iBAAS;AACT,qBAAa,SAAS,KAAK;AAC3B,cAAMA,QAAO,eAAe,MAAM,QAAQ,UAAU;AAGpD,iBAAS;AACT,qBAAa;AACb,cAAM,qBAAqB,eAAe,MAAM,MAAM;AAEtD,cAAM,MAAM,MAAM,KAAK,UAAU,UAAUA,KAAI;AAG/C,cAAM,iBAAiB,MAAM,OAAO,OAAO;AAAA;AAAA,UAC5B;AAAA,YACb,MAAM;AAAA,YACN,IAAI;AAAA,UACL;AAAA;AAAA,UACQ;AAAA;AAAA,UACC;AAAA,QACV;AAGA,cAAME,eAAc,IAAI,YAAY;AACpC,cAAM,gBAAgBA,aAAY,OAAO,cAAc;AACvD,eAAO;AAAA,MAER,SAAS,GAAG;AAEX,eAAO;AAAA,MACR;AAAA,IACD;AAAA,IAEA,MAAa,kBAAmB,eAAuB,UAAyC;AAC/F,UAAI;AACH,cAAM,gBAAgB,KAAK,cAAc,KAAK,aAAa,CAAC;AAC5D,eAAO,MAAM,KAAK,iBAAkB,eAAe,QAAS;AAAA,MAC7D,SAAS,GAAG;AACX,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EAED;;;ACpKO,MAAM,oBAAoB;AAAA,IAChC,MAAM;AAAA,IACN,IAAI,IAAI,WAAW,CAAC,KAAK,KAAK,KAAK,KAAK,KAAK,IAAI,IAAI,KAAK,IAAI,KAAK,IAAI,GAAG,CAAC;AAAA,IAC3E,WAAW;AAAA,EACZ;AAEO,MAAM,uBAAN,MAA2B;AAAA,IAEjC,MAAc,SAAS,UAAkB;AACxC,YAAM,aAAa,IAAI,YAAY;AACnC,YAAM,gBAAgB,WAAW,OAAO,QAAQ;AAEhD,YAAM,iBAAiB,MAAM,OAAO,OAAO,OAAO,EAAE,MAAM,UAAU,GAAG,aAAa;AAEpF,YAAM,MAAM,MAAM,OAAO,OAAO;AAAA,QAC/B;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,CAAC,WAAW,SAAS;AAAA,MACtB;AAEA,aAAO;AAAA,IACR;AAAA;AAAA;AAAA;AAAA,IAKA,MAAa,gBAAgB,MAAc,UAAmC;AAC7E,YAAM,MAAM,MAAM,KAAK,SAAS,QAAQ;AAExC,YAAM,aAAa,IAAI,YAAY;AACnC,YAAM,iBAAiB,WAAW,OAAO,IAAI;AAG7C,YAAM,iBAAiB,IAAI,WAAW,MAAM,OAAO,OAAO;AAAA,QACzD;AAAA,QAAmB;AAAA,QAAK;AAAA,MACzB,CAAC;AAGD,YAAM,aAAa,KAAK,OAAO,aAAa,GAAG,cAAc,CAAC;AAE9D,aAAO;AAAA,IACR;AAAA,IAEQ,cAAc,KAAyB;AAC9C,YAAM,SAAS,CAAC;AAChB,eAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACpC,eAAO,KAAK,IAAI,WAAW,CAAC,CAAC;AAAA,MAC9B;AACA,aAAO,IAAI,WAAW,MAAM;AAAA,IAC7B;AAAA,IAEA,MAAa,kBAAkB,eAAuB,UAAwC;AAC7F,UAAI;AAEH,cAAM,iBAAiB,KAAK,cAAc,KAAK,aAAa,CAAC;AAE7D,cAAM,MAAM,MAAM,KAAK,SAAS,QAAQ;AAGxC,cAAM,iBAAiB,MAAM,OAAO,OAAO,QAAQ,mBAAmB,KAAK,cAAc;AAGzF,cAAM,aAAa,IAAI,YAAY;AACnC,cAAM,gBAAgB,WAAW,OAAO,cAAc;AACtD,eAAO;AAAA,MACR,SAAS,GAAG;AACX,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EAED;;;ACjEO,MAAM,uBAAN,MAAM,qBAAmB;AAAA,IAI/B,OAAc,eAA6B;AAC1C,aAAO,KAAK;AAAA,IACb;AAAA,IAEA,OAAc,yBAA0B,MAAiC;AACxE,YAAM,SAAS,qBAAoB,wBAAwB,IAAI;AAC/D,UAAK,UAAU,MAAM;AACpB,eAAO;AAAA,MACR;AACA,YAAM,IAAI,MAAO,kDAAkD,KAAK,OAAO,EAAE;AAAA,IAClF;AAAA,IAEA,OAAc,wBAAyB,MAAwC;AAC9E,UAAK,KAAK,WAAW,OAAO;AAC3B,eAAO,IAAI,aAAa;AAAA,MACzB;AAGA,UAAK,KAAK,WAAW,OAAO;AAC3B,eAAO,KAAK;AAAA,MACb;AAEA,aAAO;AAAA,IACR;AAAA,IAEA,OAAc,4BAA6B,aAA2C;AACrF,YAAM,SAAS,qBAAoB,2BAA4B,WAAY;AAE3E,UAAI,UAAU,MAAK;AAClB,eAAO;AAAA,MACR;AACA,YAAM,IAAI,MAAO,yDAAyD,YAAY,OAAO,EAAE;AAAA,IAChG;AAAA,IAEA,OAAc,2BAA4B,aAAkD;AAU3F,UAAK,YAAY,WAAW,GAAG;AAC9B,eAAO,IAAI,qBAAqB;AAAA,MACjC;AAEA,UAAK,YAAY,WAAW,GAAG;AAC9B,eAAO,IAAI,aAAa;AAAA,MACzB;AAEA,UAAK,YAAY,WAAW,GAAG;AAC9B,eAAO,KAAK;AAAA,MACb;AAEA,aAAO;AAAA,IACR;AAAA,EAED;AA7DC,EAFY,qBAEE,sBAAsB,IAAI,iBAAkB,IAAI,IAAI,IAAO;AAFnE,MAAM,sBAAN;;;ACLA,MAAMC,YAAN,MAAe;AAAA,IAMrB,YAAa,SAAgB,MAAa,aAAoB;AAJ9D,WAAO,UAAU;AAKhB,WAAK,UAAU;AACf,WAAK,OAAO;AACZ,WAAK,cAAc;AAAA,IACpB;AAAA,EACD;AAEO,MAAM,kBAAN,MAAM,gBAAc;AAAA,IAI1B,aAAoB,QAAS,MAAc,MAAa,MAAiC;AACxF,YAAMC,UAAS,oBAAoB,aAAa;AAChD,YAAM,gBAAgB,MAAMA,QAAO,gBAAgB,MAAM,IAAI;AAC7D,aAAO,IAAID,UAAU,gBAAe,iBAAiB,MAAM,aAAa;AAAA,IACzE;AAAA,IAEA,aAAoB,QAAS,MAAgB,MAAoC;AAChF,UAAK,KAAK,eAAe,IAAI;AAC5B,eAAO;AAAA,MACR;AACA,YAAMC,UAAS,oBAAoB,yBAA0B,IAAK;AAClE,aAAO,MAAMA,QAAO,kBAAmB,KAAK,aAAa,IAAK;AAAA,IAC/D;AAAA,EACD;AAfC,EAFY,gBAEE,kBAAkB;AAF1B,MAAM,iBAAN;AAmBA,MAAM,mBAAN,MAAuB;AAAA,IAE7B,OAAc,OAAQ,MAAyB;AAE9C,aAAO,KAAK,UAAU,MAAM,MAAM,CAAC;AAAA,IACpC;AAAA,IAEA,OAAc,UAAW,MAAyB;AACjD,UAAI;AACH,aAAK,MAAO,IAAK;AACjB,eAAO;AAAA,MACR,SAAU,OAAQ;AACjB,eAAO;AAAA,MACR;AAAA,IACD;AAAA,IAEA,OAAc,OAAQ,aAAgC;AAErD,UAAK,gBAAgB,IAAI;AACxB,eAAO,IAAID,UAAU,eAAe,iBAAiB,IAAI,EAAG;AAAA,MAC7D;AACA,aAAO,KAAK,MAAO,WAAY;AAAA,IAChC;AAAA,EACD;;;ACpDO,MAAM,iBAAN,MAAqB;AAAA,IAE3B,MAAa,QAAS,SAAgB,UAA4C;AAGjF,cAAQ,KAAM,+BAAgC;AAC9C,YAAM,QAAQ,oBAAoB,aAAa;AAC/C,YAAM,SAAS,MAAM,MAAM,kBAAmB,SAAS,QAAS;AAChE,UAAK,UAAU,MAAM;AACpB,eAAO;AAAA,MACR;AAGA,cAAQ,KAAM,0CAA2C;AACzD,YAAM,KAAK,IAAI,2BAA4B,OAAQ;AACnD,UAAK,GAAG,eAAe,MAAM;AAC5B,cAAM,KAAK,oBAAoB,2BAA2B,GAAG,WAAW;AACxE,YAAI,MAAM,MAAK;AACd,gBAAME,UAAS,MAAM,GAAG,kBAAmB,GAAG,YAAY,kBAAkB,QAAS;AACrF,cAAKA,WAAU,MAAM;AACpB,mBAAOA;AAAA,UACR;AAAA,QACD;AAAA,MACD;AAGA,eAAS,MAAM,IAAI,OAAO,GAAG,OAAO;AACnC,gBAAQ,KAAM,gDAAgD,OAAO,GAAI;AACzE,cAAM,cAA4B,EAAE,SAAS,KAAK,kBAAkB,SAAS,MAAM,IAAI,mBAAmB,MAAM;AAChH,cAAM,KAAK,oBAAoB,2BAA2B,WAAW;AACrE,cAAMA,UAAS,OAAM,yBAAI,kBAAmB,YAAY,kBAAkB;AAC1E,YAAKA,WAAU,MAAM;AACpB,iBAAOA;AAAA,QACR;AAAA,MACD;AAIA,cAAQ,KAAM,sCAAuC;AACrD,UAAG;AACF,cAAM,WAAW,iBAAiB,OAAQ,OAAQ;AAClD,gBAAQ,MAAM,QAAQ;AACtB,cAAM,OAAO,oBAAoB,wBAAyB,QAAS;AACnE,cAAM,WAAW,OAAM,6BAAM,kBAAmB,SAAS,aAAa;AACtE,YAAK,YAAY,MAAM;AACtB,iBAAO;AAAA,QACR;AAAA,MACD,SAAS,GAAE;AACV,gBAAQ,KAAK,CAAC;AAAA,MACf;AAEA,aAAO;AAAA,IACR;AAAA,EACD;AAKA,SAAO,IAAI,IAAI,eAAe;",
  "names": ["vectorSize", "iterations", "salt", "utf8Encoder", "utf8Decoder", "FileData", "crypto", "result"]
}
