ontology-ts-sdk
Version:
Comprehensive TypeScript library for the Ontology blockchain.
88 lines (79 loc) • 6.12 kB
text/typescript
import { Transaction } from 'ontology-ts-sdk';
import { PublicKey } from './../src/crypto/PublicKey';
/*
* Copyright (C) 2018 The ontology Authors
* This file is part of The ontology library.
*
* The ontology is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* The ontology is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with The ontology. If not, see <http://www.gnu.org/licenses/>.
*/
import { Address, PrivateKey, Signature, SignatureScheme } from '../src/crypto';
import { makeTransferTx } from '../src/smartcontract/nativevm/ontAssetTxBuilder';
import { hexstr2str, str2hexstr } from '../src/utils';
import { signTransaction } from './../src/transaction/transactionBuilder';
// tslint:disable:no-console
// tslint:disable:max-line-length
// tslint:disable:quotemark
describe('test transfer sign', () => {
test('test canonical sign', async () => {
const mnemonics = 'immune annual decorate major humble surprise dismiss trend edit suit alert uncover release transfer suit torch small timber lock mind tomorrow north lend diet';
const privateKey = PrivateKey.generateFromMnemonic(mnemonics, "m/44'/888'/0'/0/0");
const publicKey = privateKey.getPublicKey();
const address = Address.fromPubKey(publicKey);
const from = new Address('AGn8JFPGM5S4jkWhTC89Xtz1Y76sPz29Rc');
const to = new Address('AcyLq3tokVpkMBMLALVMWRdVJ83TTgBUwU');
const tx = makeTransferTx('ONG', from, to, 12000000, '500', '30000');
tx.nonce = 'eb1c7f7f';
signTransaction(tx, privateKey);
console.log(tx);
console.log('hash', tx.getHash());
console.log('key ', privateKey.key);
console.log('pub ', publicKey.key);
console.log('sig ', tx.sigs[0].sigData[0]);
// if canonical mode is not set, the result will be
// 017da1b8268e1272d7471eef58fa0884108073c09d5efdae0143da5d281019682ea5ea9d0d289b7b15fc861c01418fda56642be628560fe4d7ccdede930e620b5d
expect(tx.sigs[0].sigData[0]).toBe('017da1b8268e1272d7471eef58fa0884108073c09d5efdae0143da5d281019682e5a1562f1d76484eb0379e3febe7025a958bb14855107b9ad26daec2fee0119f4');
}, 10000);
test('verify', async () => {
const pk = new PublicKey('022f71daef10803ece19f96b2cdb348d22bf7871c178b41f35a4f3772a8359b7d2');
const data0 = '{"action":"signMessage","params":{"invokeConfig":{"contractHash":"0000000000000000000000000000000000000000","functions":[{"operation":"signMessage","args":[{"name":"message","value":"String: register"}]}],"payer":"","gasLimit":20000,"gasPrice":500}}}';
console.log('data3:' + str2hexstr(data0));
const data = "7b22616374696f6e223a227369676e4d657373616765222c22706172616d73223a7b22696e766f6b65436f6e666967223a7b22636f6e747261637448617368223a2230303030303030303030303030303030303030303030303030303030303030303030303030303030222c2266756e6374696f6e73223a5b7b226f7065726174696f6e223a227369676e4d657373616765222c2261726773223a5b7b226e616d65223a226d657373616765222c2276616c7565223a22537472696e673a7265676973746572227d5d7d5d2c227061796572223a22222c226761734c696d6974223a32303030302c226761735072696365223a3530307d7d7d";
const data1 = hexstr2str(data);
console.log(data1);
console.log('data equal: ' + (data0 === data1));
const sig = Signature.deserializeHex('016f1d5074b4bdb2a19958c0daa08f504ecd475ddf643f5859d051e27c636bba046838bdd226d6b32bdf1743da281b2f7d89ee667913cf48ab7a7b079b5b6b4f3c');
const res = pk.verify(data1, sig);
console.log('res: ' + res);
// const sig = Signature.deserializeHex("016f1d5074b4bdb2a19958c0daa08f504ecd475ddf643f5859d051e27c636bba046838bdd226d6b32bdf1743da281b2f7d89ee667913cf48ab7a7b079b5b6b4f3c");
// const pri = PrivateKey.deserializeWIF('L1PJ9ScWP3EzhtG9tRJPpZL7mwtmCWfKM8RtsszHXU34zahxXTJ5');
// const sig2 = pri.sign(data);
// // console.log('sig equal: ' + (sig.serializeHex() === sig2));
// const pk = pri.getPublicKey();
// const res = pk.verify(data, sig2);
// console.log('res: ' + res);
});
test('verifySig', async () => {
const rightTx = '00d11ac5b076f401000000000000204e00000000000000000000000000000000000000000000000000003a0b7369676e4d6573736167651400000000000000000000000000000000000000000068164f6e746f6c6f67792e4e61746976652e496e766f6b650001424101bf874cc55a1d2585d400f3b5ede05fa28e7e47ce5f481a30c78fdaf36a7e564fac5e6b113f5a8d5affb5c9d2199c37dae8620c3c6ca70a2ec84c5a73958052c5232103471ce02a48066b398c4314c4425b6cb5dbdce275618eff0ef4d9694ddb4c9356ac","signer":"did:ont:AerVaGFiufSuv83KKYs6L1zbz7FSqxCrbC';
const tx = Transaction.deserialize('00d156b79f04f401000000000000204e00000000000000000000000000000000000000000000000000002c08726567697374657251c10b7369676e4d65737361676567000000000000000000000000000000000000000000014140fbd3965e697fb4e06c4e545a490151d74b8b6439f8ffaba7d83451c400753e502ed35cf99faa0338d466ca7a76e96066e0d11ca182b3aa5839842167f9579ce7232103cb792433b98712120850bcc061e509bef50515d719096a31f407ca8edeaeb9b6ac');
const sigData = tx.sigs[0].sigData[0];
console.log(JSON.stringify(sigData));
// const sig = Signature.deserializeHex(sigData);
const txRight = Transaction.deserialize(rightTx);
const sigData2 = txRight.sigs[0].sigData[0];
console.log(JSON.stringify(sigData2));
const sig2 = Signature.deserializeHex(sigData2);
});
});
fbd3965e697fb4e06c4e545a490151d74b8b6439f8ffaba7d83451c400753e502ed35cf99faa0338d466ca7a76e96066e0d11ca182b3aa5839842167f9579ce7
01bf874cc55a1d2585d400f3b5ede05fa28e7e47ce5f481a30c78fdaf36a7e564fac5e6b113f5a8d5affb5c9d2199c37dae8620c3c6ca70a2ec84c5a73958052c5