@gandlaf21/cashu-crypto
Version:
Basic cashu crypto functions
51 lines • 1.84 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.getSignedProof = exports.getSignedProofs = exports.signP2PKsecret = exports.createP2PKsecret = void 0;
const utils_1 = require("@noble/curves/abstract/utils");
const sha256_1 = require("@noble/hashes/sha256");
const secp256k1_1 = require("@noble/curves/secp256k1");
const utils_2 = require("@noble/hashes/utils");
const NUT11_js_1 = require("../common/NUT11.js");
const createP2PKsecret = (pubkey) => {
const newSecret = [
'P2PK',
{
nonce: (0, utils_1.bytesToHex)((0, utils_2.randomBytes)(32)),
data: pubkey
}
];
const parsed = JSON.stringify(newSecret);
return new TextEncoder().encode(parsed);
};
exports.createP2PKsecret = createP2PKsecret;
const signP2PKsecret = (secret, privateKey) => {
const msghash = (0, sha256_1.sha256)(new TextDecoder().decode(secret));
const sig = secp256k1_1.schnorr.sign(msghash, privateKey);
return sig;
};
exports.signP2PKsecret = signP2PKsecret;
const getSignedProofs = (proofs, privateKey) => {
return proofs.map((p) => {
try {
const parsed = (0, NUT11_js_1.parseSecret)(p.secret);
if (parsed[0] !== 'P2PK') {
throw new Error('unknown secret type');
}
return (0, exports.getSignedProof)(p, (0, utils_1.hexToBytes)(privateKey));
}
catch (error) {
return p;
}
});
};
exports.getSignedProofs = getSignedProofs;
const getSignedProof = (proof, privateKey) => {
if (!proof.witness) {
proof.witness = {
signatures: [(0, utils_1.bytesToHex)((0, exports.signP2PKsecret)(proof.secret, privateKey))]
};
}
return proof;
};
exports.getSignedProof = getSignedProof;
//# sourceMappingURL=NUT11.js.map