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.
144 lines
4.7 KiB
144 lines
4.7 KiB
"use strict";
|
|
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());
|
|
});
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
const grpc = require("grpc");
|
|
const lightning_1 = require("./lightning");
|
|
const path = require("path");
|
|
const ByteBuffer = require("bytebuffer");
|
|
// var protoLoader = require('@grpc/proto-loader')
|
|
const env = process.env.NODE_ENV || 'development';
|
|
const config = require(path.join(__dirname, '../../config/app.json'))[env];
|
|
var signerClient = null;
|
|
exports.loadSigner = () => {
|
|
if (signerClient) {
|
|
return signerClient;
|
|
}
|
|
else {
|
|
try {
|
|
var credentials = lightning_1.loadCredentials();
|
|
var lnrpcDescriptor = grpc.load("signer.proto");
|
|
var signer = lnrpcDescriptor.signrpc;
|
|
signerClient = new signer.Signer(config.node_ip + ':' + config.lnd_port, credentials);
|
|
return signerClient;
|
|
}
|
|
catch (e) {
|
|
throw e;
|
|
}
|
|
}
|
|
};
|
|
exports.signMessage = (msg) => {
|
|
return new Promise((resolve, reject) => __awaiter(void 0, void 0, void 0, function* () {
|
|
let signer = yield exports.loadSigner();
|
|
try {
|
|
const options = {
|
|
msg: ByteBuffer.fromHex(msg),
|
|
key_loc: { key_family: 6, key_index: 0 },
|
|
};
|
|
signer.signMessage(options, function (err, sig) {
|
|
if (err || !sig.signature) {
|
|
reject(err);
|
|
}
|
|
else {
|
|
const buf = ByteBuffer.wrap(sig.signature);
|
|
resolve(buf.toBase64());
|
|
}
|
|
});
|
|
}
|
|
catch (e) {
|
|
reject(e);
|
|
}
|
|
}));
|
|
};
|
|
exports.signBuffer = (msg) => {
|
|
return new Promise((resolve, reject) => __awaiter(void 0, void 0, void 0, function* () {
|
|
let signer = yield exports.loadSigner();
|
|
try {
|
|
const options = { msg };
|
|
signer.signMessage(options, function (err, sig) {
|
|
if (err || !sig.signature) {
|
|
reject(err);
|
|
}
|
|
else {
|
|
const buf = ByteBuffer.wrap(sig.signature);
|
|
resolve(buf.toBase64());
|
|
}
|
|
});
|
|
}
|
|
catch (e) {
|
|
reject(e);
|
|
}
|
|
}));
|
|
};
|
|
function verifyMessage(msg, sig, pubkey) {
|
|
return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
|
|
let signer = yield exports.loadSigner();
|
|
if (msg.length === 0) {
|
|
return reject('invalid msg');
|
|
}
|
|
if (sig.length !== 96) {
|
|
return reject('invalid sig');
|
|
}
|
|
if (pubkey.length !== 66) {
|
|
return reject('invalid pubkey');
|
|
}
|
|
try {
|
|
const options = {
|
|
msg: ByteBuffer.fromHex(msg),
|
|
signature: ByteBuffer.fromBase64(sig),
|
|
pubkey: ByteBuffer.fromHex(pubkey),
|
|
};
|
|
signer.verifyMessage(options, function (err, res) {
|
|
if (err) {
|
|
reject(err);
|
|
}
|
|
else {
|
|
resolve(res);
|
|
}
|
|
});
|
|
}
|
|
catch (e) {
|
|
reject(e);
|
|
}
|
|
}));
|
|
}
|
|
function signAscii(ascii) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
try {
|
|
const sig = yield exports.signMessage(ascii_to_hexa(ascii));
|
|
return sig;
|
|
}
|
|
catch (e) {
|
|
throw e;
|
|
}
|
|
});
|
|
}
|
|
exports.signAscii = signAscii;
|
|
function verifyAscii(ascii, sig, pubkey) {
|
|
return __awaiter(this, void 0, void 0, function* () {
|
|
try {
|
|
const r = yield verifyMessage(ascii_to_hexa(ascii), sig, pubkey);
|
|
return r;
|
|
}
|
|
catch (e) {
|
|
throw e;
|
|
}
|
|
});
|
|
}
|
|
exports.verifyAscii = verifyAscii;
|
|
function ascii_to_hexa(str) {
|
|
var arr1 = [];
|
|
for (var n = 0, l = str.length; n < l; n++) {
|
|
var hex = Number(str.charCodeAt(n)).toString(16);
|
|
arr1.push(hex);
|
|
}
|
|
return arr1.join('');
|
|
}
|
|
//# sourceMappingURL=signer.js.map
|