切换到 sign({...}) 和 verify({...}) 调用参数

This commit is contained in:
陆柯 2021-05-08 22:32:24 +08:00
parent fbf91171c3
commit aff70d43f7

143
tic.js
View File

@ -1,135 +1,156 @@
'use strict' "use strict";
const axios = require('axios') const axios = require("axios");
const ticCrypto = require('tic.crypto') const ticCrypto = require("tic.crypto");
const ticActionTransfer = require('tic.action').ActionTransfer const ticActionTransfer = require("tic.action").ActionTransfer;
const TIC_TXFEE = 10; const TIC_TXFEE = 10;
const TIC_NODE = require('./netConfig').TIC_NODE const TIC_NODE = require("./netConfig").TIC_NODE;
class TIC { class TIC {
constructor(seckey, option = {}) { constructor(seckey, option = {}) {
if(!seckey||!ticCrypto.isSeckey(seckey)) throw "ERROR:Invalid Seckey" if (!seckey || !ticCrypto.isSeckey(seckey)) throw "ERROR:Invalid Seckey";
Object.defineProperties(this, { Object.defineProperties(this, {
'seckey' : { seckey: {
value: seckey, value: seckey,
enumerable: true, enumerable: true,
writable: false, writable: false,
}, },
'pubkey' : { pubkey: {
value: ticCrypto.seckey2pubkey(seckey), value: ticCrypto.seckey2pubkey(seckey),
enumerable: true, enumerable: true,
writable: false, writable: false,
}, },
'address' : { address: {
value: ticCrypto.pubkey2address(ticCrypto.seckey2pubkey(seckey)), value: ticCrypto.pubkey2address(ticCrypto.seckey2pubkey(seckey)),
enumerable: true, enumerable: true,
writable : false writable: false,
} },
}) });
Object.assign(this, { Object.assign(this, {
_url: option._url || TIC_NODE, _url: option._url || TIC_NODE,
_defaultFee : option.fee||TIC_TXFEE //fee cannot be zero _defaultFee: option.fee || TIC_TXFEE, //fee cannot be zero
}) });
}
get url() {
return this._url;
}
set url(newURL) {
this._url = newURL;
}
get txfee() {
return this._defaultFee;
}
set txfee(fee) {
this._defaultFee = fee;
} }
get url(){return this._url}
set url(newURL){this._url = newURL}
get txfee(){return this._defaultFee}
set txfee(fee){this._defaultFee = fee}
static generateNewAccount() { static generateNewAccount() {
var secword = ticCrypto.randomSecword() var secword = ticCrypto.randomSecword();
return Object.assign(new TIC(ticCrypto.secword2keypair(secword).seckey),{secword:secword}) return Object.assign(new TIC(ticCrypto.secword2keypair(secword).seckey), {
secword: secword,
});
} }
static fromMnemonic(secword) { static fromMnemonic(secword) {
if(!secword||!ticCrypto.isSecword(secword)) throw "ERROR:Invalid Secword" if (!secword || !ticCrypto.isSecword(secword))
return new TIC(ticCrypto.secword2keypair(secword).seckey) throw "ERROR:Invalid Secword";
return new TIC(ticCrypto.secword2keypair(secword).seckey);
} }
static async getBalance(address) { static async getBalance(address) {
if(!address){ throw new Error('Address is required'); } if (!address) {
return (await axios.post(TIC_NODE+'/Account/getBalance',{ throw new Error("Address is required");
"Account" : {
"address":address
} }
})).data return (
await axios.post(TIC_NODE + "/Account/getBalance", {
Account: {
address: address,
},
})
).data;
} }
static async getActions(address) { static async getActions(address) {
if(!address){ throw new Error('Address is required'); } if (!address) {
return (await axios.post(TIC_NODE+'/Action/getActionList',{ throw new Error("Address is required");
"Action" : {
"actorAddress" : address,
"toAddress" : address
},
"config":{
"logic":"OR"
} }
})).data return (
await axios.post(TIC_NODE + "/Action/getActionList", {
Action: {
actorAddress: address,
toAddress: address,
},
config: {
logic: "OR",
},
})
).data;
} }
static encrypt(data, key) { static encrypt(data, key) {
if(!data || !key) throw new Error('Required Params Missing') if (!data || !key) throw new Error("Required Params Missing");
return ticCrypto.encrypt(data,key) return ticCrypto.encrypt(data, key);
} }
static decrypt(data, key) { static decrypt(data, key) {
return ticCrypto.decrypt(data, key, {format:"json"}) //return null for wrong key return ticCrypto.decrypt(data, key, { format: "json" }); //return null for wrong key
} }
static isValidAddress(address) { static isValidAddress(address) {
return ticCrypto.isAddress(address) return ticCrypto.isAddress(address);
} }
async sendTransaction(toAddress, amount, option = { gasFee: TIC_TXFEE }) { async sendTransaction(toAddress, amount, option = { gasFee: TIC_TXFEE }) {
if(!toAddress||!amount){throw new Error("ERROR:RequiredParamsMissing")} //amount cannot be zero if (!toAddress || !amount) {
throw new Error("ERROR:RequiredParamsMissing");
} //amount cannot be zero
let action = new ticActionTransfer({ let action = new ticActionTransfer({
amount: parseInt(amount), amount: parseInt(amount),
toAddress: toAddress, toAddress: toAddress,
fee: option.gasFee, fee: option.gasFee,
}) });
//对交易数据签名,packMe 内的参数是交易发起人的keypair //对交易数据签名,packMe 内的参数是交易发起人的keypair
action.packMe({ action.packMe({
seckey: this.seckey, seckey: this.seckey,
pubkey: this.pubkey, pubkey: this.pubkey,
}) });
let data = { let data = {
Action:action Action: action,
} };
try { try {
let res = (await axios.post(this._url + "/Action/prepare", data)).data;
let res = (await axios.post(this._url + '/Action/prepare',data)).data return res;
return res
} catch (err) { } catch (err) {
return null return null;
} }
} }
async getBalance() { async getBalance() {
return TIC.getBalance(this.address) return TIC.getBalance(this.address);
} }
async getActions() { async getActions() {
return TIC.getActions(this.address) return TIC.getActions(this.address);
} }
getSerializedTx(option) { getSerializedTx(option) {
if(!option.toAddress||!option.amount){throw new Error("ERROR:RequiredParamsMissing")} if (!option.toAddress || !option.amount) {
throw new Error("ERROR:RequiredParamsMissing");
}
let action = new ticActionTransfer({ let action = new ticActionTransfer({
amount: parseInt(option.amount), amount: parseInt(option.amount),
toAddress: option.toAddress, toAddress: option.toAddress,
fee: option.fee || this._defaultFee, fee: option.fee || this._defaultFee,
}) });
//sign for txBody use function packMe, which needs actor's keypair as parameter //sign for txBody use function packMe, which needs actor's keypair as parameter
action.packMe({ action.packMe({
seckey: this.seckey, seckey: this.seckey,
pubkey: this.pubkey, pubkey: this.pubkey,
}) });
return action return action;
} }
//default key for sign&encrypt is account's seckey,other keys are optional. //default key for sign&encrypt is account's seckey,other keys are optional.
sign(message, key = this.seckey) { sign(message, key = this.seckey) {
return ticCrypto.sign(message,key) return ticCrypto.sign({ data: message, seckey: key });
} }
verify(message, signature) { verify(message, signature) {
return ticCrypto.sign(message,signature,this.seckey) return ticCrypto.sign({ data: message, signature, seckey: this.seckey });
} }
encrypt(key) { encrypt(key) {
return TIC.encrypt(this, key) return TIC.encrypt(this, key);
}
} }
} module.exports = { TIC };
module.exports = {TIC}