coralpay-node-sdk
Version:
Coral Pay NodeJS SDK
154 lines • 17.8 kB
JavaScript
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
if (kind === "m") throw new TypeError("Private method is not writable");
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
};
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
};
var _PGPEncryption_decryptionKey, _PGPEncryption_encryptionKey, _PGPEncryption_init, _PGPEncryption_useLegacyOpenPGP;
Object.defineProperty(exports, "__esModule", { value: true });
exports.PGPEncryption = void 0;
const keymanager = __importStar(require("../keymanager"));
const openpgp = __importStar(require("openpgp"));
const openpgpLegacy = __importStar(require("openpgp-legacy"));
openpgpLegacy.config.ignore_mdc_error = true;
openpgpLegacy.config.use_native = true;
const loadInsecureTwoByteHashPrivateKey = (text, passphrase) => __awaiter(void 0, void 0, void 0, function* () {
const key = (yield openpgpLegacy.key.readArmored(text)).keys[0];
if (!key.isDecrypted()) {
yield key.decrypt(passphrase !== null && passphrase !== void 0 ? passphrase : "");
}
return key;
});
class PGPEncryption {
constructor(config) {
this.config = config;
_PGPEncryption_decryptionKey.set(this, void 0);
_PGPEncryption_encryptionKey.set(this, void 0);
_PGPEncryption_init.set(this, false);
_PGPEncryption_useLegacyOpenPGP.set(this, false);
}
readPrivateKey() {
return __awaiter(this, void 0, void 0, function* () {
if (this.config.isInsecureTwoByteHashPrivateKey === true) {
__classPrivateFieldSet(this, _PGPEncryption_useLegacyOpenPGP, true, "f");
return loadInsecureTwoByteHashPrivateKey(this.config.privatekey, this.config.passphrase);
}
return openpgp
.readPrivateKey({
armoredKey: this.config.privatekey,
})
.then((key) => {
if (key.isDecrypted()) {
return key;
}
return openpgp.decryptKey({
privateKey: key,
passphrase: this.config.passphrase,
});
})
.catch((error) => {
if (error.message.includes("Encrypted private key is authenticated using an insecure two-byte hash")) {
console.warn("WARNING: Private key was created using an insecure two-byte hash! Suggest to upgrade to a newer format");
__classPrivateFieldSet(this, _PGPEncryption_useLegacyOpenPGP, true, "f");
return loadInsecureTwoByteHashPrivateKey(this.config.privatekey, this.config.passphrase);
}
throw error;
});
});
}
init() {
return __awaiter(this, void 0, void 0, function* () {
const [encryptionKey, decryptionKey] = yield Promise.all([
keymanager.importKeys(this.config.publickey, { debug: true, showVersion: false }),
this.readPrivateKey(),
]);
__classPrivateFieldSet(this, _PGPEncryption_encryptionKey, encryptionKey, "f");
__classPrivateFieldSet(this, _PGPEncryption_decryptionKey, decryptionKey, "f");
__classPrivateFieldSet(this, _PGPEncryption_init, true, "f");
});
}
encrypt(data) {
return __awaiter(this, void 0, void 0, function* () {
if (!__classPrivateFieldGet(this, _PGPEncryption_init, "f")) {
yield this.init();
}
this.config.logger("Encrypting Data ===>", data);
const result = yield keymanager.encryptRequest(data, __classPrivateFieldGet(this, _PGPEncryption_encryptionKey, "f"), { format: "hex", debug: false, showVersion: false });
this.config.logger("Encryption Result ===>", result);
return result;
});
}
decrypt(text, json = false) {
return __awaiter(this, void 0, void 0, function* () {
if (!__classPrivateFieldGet(this, _PGPEncryption_init, "f")) {
yield this.init();
}
this.config.logger("Decrypting Text ===>", text, "Possibly JSON ===>", json);
const buffer = Buffer.from(text, "hex");
const result = yield Promise.resolve(__classPrivateFieldGet(this, _PGPEncryption_useLegacyOpenPGP, "f")).then((legacy) => __awaiter(this, void 0, void 0, function* () {
if (legacy) {
return openpgpLegacy
.decrypt({
message: yield openpgpLegacy.message.read(buffer),
privateKeys: __classPrivateFieldGet(this, _PGPEncryption_decryptionKey, "f"),
})
.then((result) => result.data);
}
return openpgp
.decrypt({
message: yield openpgp.readMessage({
binaryMessage: buffer,
}),
decryptionKeys: __classPrivateFieldGet(this, _PGPEncryption_decryptionKey, "f"),
})
.then((result) => result.data);
}));
this.config.logger("Decryption Result ===>", result);
if (json) {
return JSON.parse(result);
}
return result;
});
}
}
exports.PGPEncryption = PGPEncryption;
_PGPEncryption_decryptionKey = new WeakMap(), _PGPEncryption_encryptionKey = new WeakMap(), _PGPEncryption_init = new WeakMap(), _PGPEncryption_useLegacyOpenPGP = new WeakMap();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"encryption.js","sourceRoot":"","sources":["../src/encryption.ts"],"names":[],"mappings":"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","sourcesContent":["import * as keymanager from \"../keymanager\";\nimport * as openpgp from \"openpgp\";\nimport * as openpgpLegacy from \"openpgp-legacy\";\n\nopenpgpLegacy.config.ignore_mdc_error = true;\nopenpgpLegacy.config.use_native = true;\n\ninterface PGPEncryptionConfig {\n\tpublickey: string;\n\tprivatekey: string;\n\tpassphrase?: string;\n\tisInsecureTwoByteHashPrivateKey?: boolean;\n\tlogger: (...args: any[]) => void;\n}\n\nconst loadInsecureTwoByteHashPrivateKey = async (text: string, passphrase?: string) => {\n\tconst key = (await openpgpLegacy.key.readArmored(text)).keys[0];\n\tif (!key.isDecrypted()) {\n\t\tawait key.decrypt(passphrase ?? \"\");\n\t}\n\treturn key;\n};\n\nexport class PGPEncryption {\n\t#decryptionKey!: openpgp.PrivateKey | openpgpLegacy.key.Key;\n\t#encryptionKey!: string;\n\t#init = false;\n\t#useLegacyOpenPGP = false;\n\tconstructor(private config: PGPEncryptionConfig) {}\n\n\tasync readPrivateKey() {\n\t\tif (this.config.isInsecureTwoByteHashPrivateKey === true) {\n\t\t\tthis.#useLegacyOpenPGP = true;\n\t\t\treturn loadInsecureTwoByteHashPrivateKey(this.config.privatekey, this.config.passphrase);\n\t\t}\n\t\treturn openpgp\n\t\t\t.readPrivateKey({\n\t\t\t\tarmoredKey: this.config.privatekey,\n\t\t\t})\n\t\t\t.then((key) => {\n\t\t\t\tif (key.isDecrypted()) {\n\t\t\t\t\treturn key;\n\t\t\t\t}\n\t\t\t\treturn openpgp.decryptKey({\n\t\t\t\t\tprivateKey: key,\n\t\t\t\t\tpassphrase: this.config.passphrase,\n\t\t\t\t});\n\t\t\t})\n\t\t\t.catch((error: Error) => {\n\t\t\t\tif (error.message.includes(\"Encrypted private key is authenticated using an insecure two-byte hash\")) {\n\t\t\t\t\tconsole.warn(\"WARNING: Private key was created using an insecure two-byte hash! Suggest to upgrade to a newer format\");\n\t\t\t\t\tthis.#useLegacyOpenPGP = true;\n\t\t\t\t\treturn loadInsecureTwoByteHashPrivateKey(this.config.privatekey, this.config.passphrase);\n\t\t\t\t}\n\t\t\t\tthrow error;\n\t\t\t});\n\t}\n\n\tasync init() {\n\t\tconst [encryptionKey, decryptionKey] = await Promise.all([\n\t\t\tkeymanager.importKeys(this.config.publickey, { debug: true, showVersion: false }),\n\t\t\tthis.readPrivateKey(),\n\t\t]);\n\t\tthis.#encryptionKey = encryptionKey;\n\t\tthis.#decryptionKey = decryptionKey;\n\t\tthis.#init = true;\n\t}\n\n\tasync encrypt(data: string) {\n\t\tif (!this.#init) {\n\t\t\tawait this.init();\n\t\t}\n\t\tthis.config.logger(\"Encrypting Data ===>\", data);\n\t\tconst result = await keymanager.encryptRequest(data, this.#encryptionKey, { format: \"hex\", debug: false, showVersion: false });\n\t\tthis.config.logger(\"Encryption Result ===>\", result);\n\t\treturn result;\n\t}\n\n\tasync decrypt<T = Record<string, any>>(text: string, json: true): Promise<T>;\n\tasync decrypt(text: string, json?: false): Promise<string>;\n\tasync decrypt(text: string, json = false) {\n\t\tif (!this.#init) {\n\t\t\tawait this.init();\n\t\t}\n\t\tthis.config.logger(\"Decrypting Text ===>\", text, \"Possibly JSON ===>\", json);\n\t\tconst buffer = Buffer.from(text, \"hex\");\n\t\tconst result = await Promise.resolve(this.#useLegacyOpenPGP).then(async (legacy) => {\n\t\t\tif (legacy) {\n\t\t\t\treturn openpgpLegacy\n\t\t\t\t\t.decrypt({\n\t\t\t\t\t\tmessage: await openpgpLegacy.message.read(buffer),\n\t\t\t\t\t\tprivateKeys: this.#decryptionKey as openpgpLegacy.key.Key,\n\t\t\t\t\t})\n\t\t\t\t\t.then((result) => result.data);\n\t\t\t}\n\n\t\t\treturn openpgp\n\t\t\t\t.decrypt({\n\t\t\t\t\tmessage: await openpgp.readMessage({\n\t\t\t\t\t\tbinaryMessage: buffer,\n\t\t\t\t\t}),\n\t\t\t\t\tdecryptionKeys: this.#decryptionKey as openpgp.PrivateKey,\n\t\t\t\t})\n\t\t\t\t.then((result) => result.data);\n\t\t});\n\t\tthis.config.logger(\"Decryption Result ===>\", result);\n\t\tif (json) {\n\t\t\treturn JSON.parse(result);\n\t\t}\n\t\treturn result;\n\t}\n}\n"]}