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.

120 lines
2.8 KiB

5 years ago
import * as grpc from 'grpc'
import {loadCredentials} from './lightning'
import * as path from 'path'
import * as ByteBuffer from '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 = <any> null;
export const loadSigner = () => {
if (signerClient) {
return signerClient
} else {
try{
var credentials = loadCredentials()
var lnrpcDescriptor = grpc.load("signer.proto");
var signer: any = lnrpcDescriptor.signrpc
signerClient = new signer.Signer(config.node_ip + ':' + config.lnd_port, credentials);
return signerClient
} catch(e) {
throw e
}
}
}
export const signMessage = (msg) => {
return new Promise(async(resolve, reject)=> {
let signer = await loadSigner()
5 years ago
console.log("SIGNER",signer)
5 years ago
try {
5 years ago
const options = {
msg:ByteBuffer.fromHex(msg),
key_loc:{key_family:6, key_index:0},
}
5 years ago
console.log('signer.signMessage',signer.signMessage)
5 years ago
signer.signMessage(options, function(err,sig){
if(err || !sig.signature) {
reject(err)
} else {
resolve(sig.signature)
}
})
} catch(e) {
reject(e)
}
})
}
export const signBuffer = (msg) => {
return new Promise(async (resolve, reject)=> {
let signer = await loadSigner()
try {
const options = {msg}
signer.signMessage(options, function(err,sig){
if(err || !sig.signature) {
reject(err)
} else {
resolve(sig.signature)
}
})
} catch(e) {
reject(e)
}
})
}
5 years ago
function verifyMessage(msg,sig,pubkey): Promise<{[k:string]:any}> {
5 years ago
return new Promise(async(resolve, reject)=> {
let signer = await loadSigner()
5 years ago
console.log('verifyMessage signer,',signer)
5 years ago
try {
const options = {
msg:ByteBuffer.fromHex(msg),
signature:sig,
5 years ago
pubkey:ByteBuffer.fromHex(pubkey),
5 years ago
}
5 years ago
console.log("OPSP",options,signer.verifyMessage)
5 years ago
signer.verifyMessage(options, function(err,res){
5 years ago
if(err) {
5 years ago
reject(err)
} else {
resolve(res)
}
})
} catch(e) {
reject(e)
}
})
}
export async function signAscii(ascii) {
try {
const sig = await signMessage(ascii_to_hexa(ascii))
return sig
} catch(e) {
throw e
}
}
5 years ago
export async function verifyAscii(ascii:string,sig:Buffer,pubkey:string): Promise<{[k:string]:any}>{
5 years ago
try {
5 years ago
const r = await verifyMessage(ascii_to_hexa(ascii),sig,pubkey)
5 years ago
return r
} catch(e) {
throw e
}
}
function ascii_to_hexa(str){
var arr1 = <string[]> [];
for (var n = 0, l = str.length; n < l; n ++) {
var hex = Number(str.charCodeAt(n)).toString(16);
arr1.push(hex);
}
return arr1.join('');
}