Comparing version 1.2.1 to 1.3.0
{ | ||
"name": "slopes", | ||
"version": "1.2.1", | ||
"version": "1.3.0", | ||
"description": "AVA Platform JS Library", | ||
@@ -5,0 +5,0 @@ "main": "typings/src/index.js", |
@@ -6,7 +6,7 @@ /** | ||
import { Buffer } from "buffer/"; | ||
import { JRPCAPI, RequestResponseData } from "../../utils/types"; | ||
import { JRPCAPI, RequestResponseData, Defaults } from "../../utils/types"; | ||
import { UTXOSet } from './utxos'; | ||
import { MergeRule, UnixNow } from './types'; | ||
import { MergeRule, UnixNow, AVMConstants, InitialStates } from './types'; | ||
import { AVMKeyChain } from './keychain'; | ||
import { TxUnsigned, Tx } from './tx'; | ||
import { TxUnsigned, Tx, TxCreateAsset } from './tx'; | ||
import BN from "bn.js"; | ||
@@ -85,9 +85,24 @@ import BinTools from '../../utils/bintools'; | ||
*/ | ||
protected keychain:AVMKeyChain = new AVMKeyChain(); | ||
protected keychain:AVMKeyChain = new AVMKeyChain(""); | ||
protected blockchainID:string = ""; | ||
protected AVAAssetID:Buffer = undefined; | ||
/** | ||
* Gets the alias for the blockchainID if it exists, otherwise returns `undefined`. | ||
* | ||
* @returns The alias for the blockchainID | ||
*/ | ||
getBlockchainAlias = ():string => { | ||
let netid:number = this.core.getNetworkID(); | ||
if(netid in Defaults.network && this.blockchainID in Defaults.network[netid]){ | ||
return Defaults.network[netid][this.blockchainID].alias; | ||
} | ||
/* istanbul ignore next */ | ||
return undefined; | ||
} | ||
/** | ||
* Gets the blockchainID and returns it. | ||
* | ||
* @returns The the provided string representing the blockchainID | ||
* @returns The blockchainID | ||
*/ | ||
@@ -99,2 +114,31 @@ getBlockchainID = ():string => { | ||
/** | ||
* Takes an address string and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid. | ||
*/ | ||
parseAddress = (addr:string):Buffer => { | ||
let alias:string = this.getBlockchainAlias(); | ||
let blockchainID:string = this.getBlockchainID(); | ||
return bintools.parseAddress(addr, blockchainID, alias, AVMConstants.ADDRESSLENGTH); | ||
} | ||
addressFromBuffer = (address:Buffer):string => { | ||
let chainid:string = this.getBlockchainAlias() ? this.getBlockchainAlias() : this.getBlockchainID(); | ||
return bintools.addressToString(chainid, address); | ||
} | ||
/** | ||
* Fetches the AVA AssetID and returns it in a Promise. | ||
* | ||
* @returns The the provided string representing the blockchainID | ||
*/ | ||
getAVAAssetID = async ():Promise<Buffer> => { | ||
if(typeof this.AVAAssetID === 'undefined'){ | ||
let asset:object = await this.getAssetDescription("AVA"); | ||
this.AVAAssetID = asset["assetID"]; | ||
} | ||
return this.AVAAssetID; | ||
} | ||
/** | ||
* Gets a reference to the keychain for this class. | ||
@@ -113,3 +157,8 @@ * | ||
//warning, overwrites the old keychain | ||
this.keychain = new AVMKeyChain(); | ||
let alias = this.getBlockchainAlias(); | ||
if(alias){ | ||
this.keychain = new AVMKeyChain(alias); | ||
} else { | ||
this.keychain = new AVMKeyChain(this.blockchainID); | ||
} | ||
return this.keychain; | ||
@@ -119,15 +168,76 @@ } | ||
/** | ||
* Creates an asset of a given amount and assigns it to the address provided. | ||
* Gets the balance of a particular asset on a subnet. | ||
* | ||
* @param amount The amount of the asset to be created. If Amount is 10, for example, there will be exist 10 units of the new asset | ||
* @param address The base 58 string representation of the address that holds all units of the new asset upon creation of the asset | ||
* @param address The address to pull the asset balance from | ||
* @param assetID The assetID to pull the balance from | ||
* | ||
* @returns Promise with the balance of the assetID on the provided address for the subnet. | ||
*/ | ||
getBalance = async (address:string, assetID:string):Promise<number> => { | ||
if(typeof this.parseAddress(address) === "undefined"){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.getBalance: Invalid address format " + address); | ||
} | ||
let params = { | ||
"address": address, | ||
"assetID": assetID | ||
}; | ||
return this.callMethod("avm.getBalance", params).then((response:RequestResponseData) => { | ||
return parseInt(response.data["result"]["balance"]); | ||
}); | ||
} | ||
/** | ||
* Creates an address (and associated private keys) on a user under a subnet. | ||
* | ||
* @param username Name of the user to create the address under | ||
* @param password Password to unlock the user and encrypt the private key | ||
* | ||
* @returns Promise for a string representing the address created by the subnet. | ||
*/ | ||
createAddress = async (username:string, password:string):Promise<string> => { | ||
let params = { | ||
"username": username, | ||
"password": password | ||
}; | ||
return this.callMethod("avm.createAddress", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["address"]; | ||
}); | ||
} | ||
/** | ||
* Create a new fixed-cap, fungible asset. A quantity of it is created at initialization and there no more is ever created. | ||
* | ||
* @param username The user paying the transaction fee (in $AVA) for asset creation | ||
* @param password The password for the user paying the transaction fee (in $AVA) for asset creation | ||
* @param name The human-readable name for the asset | ||
* @param symbol Optional. The shorthand symbol for the asset. Between 0 and 4 characters | ||
* @param initialHolders An array of objects containing the field "address" and "amount" to establish the genesis values for the new asset | ||
* | ||
* ```js | ||
* Example initialHolders: | ||
* [ | ||
* { | ||
* "address": "X-7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh", | ||
* "amount": 10000 | ||
* }, | ||
* { | ||
* "address": "X-7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh", | ||
* "amount": 50000 | ||
* } | ||
* ] | ||
* ``` | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the ID of the newly created asset. | ||
*/ | ||
createAsset = async (amount:number, address:string):Promise<string> => { | ||
createFixedCapAsset = async (username:string, password:string, name:string, symbol:string, initialHolders:Array<object>):Promise<string> => { | ||
let params = { | ||
"amount": amount, | ||
"address": address | ||
"name": name, | ||
"symbol": symbol, | ||
"username": username, | ||
"password": password, | ||
"initialHolders": initialHolders | ||
}; | ||
return this.callMethod("avm.createAsset", params).then((response:RequestResponseData) => { | ||
return this.callMethod("avm.createFixedCapAsset", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["assetID"]; | ||
@@ -138,9 +248,195 @@ }); | ||
/** | ||
* Create a new variable-cap, fungible asset. No units of the asset exist at initialization. Minters can mint units of this asset using createMintTx, signMintTx and sendMintTx. | ||
* | ||
* @param username The user paying the transaction fee (in $AVA) for asset creation | ||
* @param password The password for the user paying the transaction fee (in $AVA) for asset creation | ||
* @param name The human-readable name for the asset | ||
* @param symbol Optional. The shorthand symbol for the asset -- between 0 and 4 characters | ||
* @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction | ||
* | ||
* ```js | ||
* Example minterSets: | ||
* [ | ||
* { | ||
* "minters":[ | ||
* "X-4peJsFvhdn7XjhNF4HWAQy6YaJts27s9q" | ||
* ], | ||
* "threshold": 1 | ||
* }, | ||
* { | ||
* "minters": [ | ||
* "X-dcJ6z9duLfyQTgbjq2wBCowkvcPZHVDF", | ||
* "X-2fE6iibqfERz5wenXE6qyvinsxDvFhHZk", | ||
* "X-7ieAJbfrGQbpNZRAQEpZCC1Gs1z5gz4HU" | ||
* ], | ||
* "threshold": 2 | ||
* } | ||
* ] | ||
* ``` | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the ID of the newly created asset. | ||
*/ | ||
createVariableCapAsset = async (username:string, password:string, name:string, symbol:string, minterSets:Array<object>):Promise<string> => { | ||
let params = { | ||
"name": name, | ||
"symbol": symbol, | ||
"username": username, | ||
"password": password, | ||
"minterSets": minterSets | ||
}; | ||
return this.callMethod("avm.createVariableCapAsset", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["assetID"]; | ||
}); | ||
} | ||
/** | ||
* Create an unsigned transaction to mint more of an asset. | ||
* | ||
* @param amount The units of the asset to mint | ||
* @param assetID The ID of the asset to mint | ||
* @param to The address to assign the units of the minted asset | ||
* @param minters Addresses of the minters responsible for signing the transaction | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the unsigned transaction. | ||
*/ | ||
createMintTx = async (amount:number | BN, assetID:Buffer | string, to:string, minters:Array<string>):Promise<string> => { | ||
let asset:string; | ||
let amnt:BN; | ||
if(typeof assetID !== "string"){ | ||
asset = bintools.avaSerialize(assetID); | ||
} else { | ||
asset = assetID; | ||
} | ||
if(typeof amount === 'number'){ | ||
amnt = new BN(amount); | ||
} else { | ||
amnt = amount; | ||
} | ||
let params = { | ||
"amount": amnt.toString(10), | ||
"assetID": asset, | ||
"to": to, | ||
"minters": minters | ||
}; | ||
return this.callMethod("avm.createMintTx", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["tx"]; | ||
}); | ||
} | ||
/** | ||
* Sign an unsigned or partially signed mint transaction. | ||
* | ||
* @param username The user signing | ||
* @param password The password for the user signing | ||
* @param tx The output of createMintTx or signMintTx | ||
* @param minter The minter signing this transaction | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the unsigned transaction. | ||
*/ | ||
signMintTx = async (username:string, password:string, tx:string | Buffer, minter:string):Promise<string> => { | ||
if(typeof this.parseAddress(minter) === "undefined"){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.signMintTx: Invalid address format " + minter); | ||
} | ||
let params = { | ||
"username": username, | ||
"password": password, | ||
"tx": tx, | ||
"minter": minter | ||
}; | ||
return this.callMethod("avm.signMintTx", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["tx"]; | ||
}); | ||
} | ||
/** | ||
* Exports the private key for an address. | ||
* | ||
* @param username The name of the user with the private key | ||
* @param password The password used to decrypt the private key | ||
* @param address The address whose private key should be exported | ||
* | ||
* @returns Promise with the decrypted private key as store in the database | ||
*/ | ||
exportKey = async (username:string, password:string, address:string):Promise<string> => { | ||
if(typeof this.parseAddress(address) === "undefined"){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.exportKey: Invalid address format " + address); | ||
} | ||
let params = { | ||
"username": username, | ||
"password": password, | ||
"address": address | ||
}; | ||
return this.callMethod("avm.exportKey", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["privateKey"]; | ||
}); | ||
} | ||
/** | ||
* Imports a private key into the node's database under an user and for a subnet. | ||
* | ||
* @param username The name of the user to store the private key | ||
* @param password The password that unlocks the user | ||
* @param privateKey A string representing the private key in the subnet's format | ||
* | ||
* @returns The address for the imported private key. | ||
*/ | ||
importKey = async (username:string, password:string, privateKey:string):Promise<string> => { | ||
let params = { | ||
"username": username, | ||
"password": password, | ||
"privateKey": privateKey | ||
}; | ||
return this.callMethod("avm.importKey", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["address"]; | ||
}); | ||
} | ||
/** | ||
* Lists all the addresses under a user. | ||
* | ||
* @param username The user to list addresses | ||
* @param password The password of the user to list the addresses | ||
* | ||
* @returns Promise of an array of address strings in the format specified by the subnet. | ||
*/ | ||
listAddresses = async (username:string, password:string): Promise<Array<string>> => { | ||
let params = { | ||
"username": username, | ||
"password": password | ||
}; | ||
return this.callMethod("avm.listAddresses", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["addresses"]; | ||
}); | ||
} | ||
/** | ||
* Lists all assets for an address. | ||
* | ||
* @param address The address to get a list of assets | ||
* | ||
* @returns Promise of an array of assetIDs for the address on the subnet. | ||
*/ | ||
listAssets = async (address:string):Promise<Array<string>> => { | ||
if(typeof this.parseAddress(address) === "undefined"){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.listAssets: Invalid address format " + address); | ||
} | ||
let params = { | ||
"address": address | ||
}; | ||
return this.callMethod("avm.listAssets", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["assets"]; | ||
}); | ||
} | ||
/** | ||
* Retrieves an assets name and symbol. | ||
* | ||
* @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an AVA serialized string for the AssetID. | ||
* @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an AVA serialized string for the AssetID or its alias. | ||
* | ||
* @returns Returns a Promise<object> with keys "name" and "symbol". | ||
*/ | ||
getAssetDescription = async(assetID:Buffer | string):Promise<{name:string;symbol:string}> => { | ||
getAssetDescription = async(assetID:Buffer | string):Promise<{name:string;symbol:string;assetID:Buffer;denomination:number}> => { | ||
let asset:string; | ||
@@ -156,3 +452,8 @@ if(typeof assetID !== "string"){ | ||
return this.callMethod("avm.getAssetDescription", params).then((response:RequestResponseData) => { | ||
return {name: response.data["result"]["name"], symbol: response.data["result"]["symbol"]}; | ||
return { | ||
name: response.data["result"]["name"], | ||
symbol: response.data["result"]["symbol"], | ||
assetID: bintools.avaDeserialize(response.data["result"]["assetID"]), | ||
denomination: parseInt(response.data["result"]["denomination"]) | ||
}; | ||
}); | ||
@@ -180,3 +481,3 @@ } | ||
* | ||
* @param addresses An array of addresses as strings | ||
* @param addresses An array of addresses as strings or addresses as {@link https://github.com/feross/buffer|Buffer}s | ||
* @param persistOpts Options available to persist these UTXOs in local storage | ||
@@ -188,5 +489,7 @@ * | ||
*/ | ||
getUTXOs = async (addresses:Array<string>, persistOpts:PersistanceOptions = undefined ):Promise<UTXOSet> => { | ||
getUTXOs = async (addresses:Array<string> | Array<Buffer>, persistOpts:PersistanceOptions = undefined ):Promise<UTXOSet> => { | ||
let addrs:Array<string> = this._cleanAddressArray(addresses, "getUTXOs"); | ||
let params = { | ||
"addresses": addresses | ||
"addresses": addrs | ||
}; | ||
@@ -233,13 +536,18 @@ return this.callMethod("avm.getUTXOs", params).then((response:RequestResponseData) => { | ||
*/ | ||
makeUnsignedTx = ( | ||
makeUnsignedTx = async ( | ||
utxoset:UTXOSet, amount:BN, toAddresses:Array<string>, fromAddresses:Array<string>, | ||
changeAddresses:Array<string>, assetID:Buffer | string = undefined, asOf:BN = UnixNow(), | ||
locktime:BN = new BN(0), threshold:number = 1 | ||
):TxUnsigned => { | ||
):Promise<TxUnsigned> => { | ||
let to:Array<Buffer> = this._cleanAddressArray(toAddresses, "makeUnsignedTx").map(a => bintools.stringToAddress(a));; | ||
let from:Array<Buffer> = this._cleanAddressArray(fromAddresses, "makeUnsignedTx").map(a => bintools.stringToAddress(a));; | ||
let change:Array<Buffer> = this._cleanAddressArray(changeAddresses, "makeUnsignedTx").map(a => bintools.stringToAddress(a));; | ||
if(typeof assetID === "string"){ | ||
assetID = bintools.avaDeserialize(assetID); | ||
} | ||
return utxoset.makeUnsignedTx( | ||
this.core.getNetworkID(), bintools.avaDeserialize(this.blockchainID), | ||
amount, toAddresses, fromAddresses, changeAddresses, | ||
amount, to, from, change, | ||
assetID, asOf, locktime, threshold | ||
@@ -249,3 +557,42 @@ ); | ||
/** | ||
* Creates an unsigned transaction. For more granular control, you may create your own | ||
* [[TxCreateAsset]] manually (with their corresponding [[Input]]s, [[Output]]s). | ||
* | ||
* @param utxoset A set of UTXOs that the transaction is built on | ||
* @param fee The amount of AVA to be paid for fees, in NanoAVA | ||
* @param creatorAddresses The addresses to send the fees | ||
* @param initialState The [[InitialStates]] that represent the intial state of a created asset | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* | ||
* @returns An unsigned transaction created from the passed in parameters. | ||
* | ||
*/ | ||
makeCreateAssetTx = async ( | ||
utxoset:UTXOSet, fee:BN, creatorAddresses:Array<string> | Array<Buffer>, | ||
initialState:InitialStates, name:string, | ||
symbol:string, denomination:number | ||
):Promise<TxCreateAsset> => { | ||
let creators:Array<Buffer> = this._cleanAddressArray(creatorAddresses, "makeCreateAssetTx").map(a => bintools.stringToAddress(a)); | ||
/* istanbul ignore next */ | ||
if(symbol.length > AVMConstants.SYMBOLMAXLEN){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.makeCreateAssetTx: Symbols may not exceed length of " + AVMConstants.SYMBOLMAXLEN); | ||
} | ||
/* istanbul ignore next */ | ||
if(name.length > AVMConstants.ASSETNAMELEN) { | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.makeCreateAssetTx: Names may not exceed length of " + AVMConstants.ASSETNAMELEN); | ||
} | ||
let avaAssetID:Buffer = await this.getAVAAssetID(); | ||
return utxoset.makeCreateAssetTx( | ||
this.core.getNetworkID(), bintools.avaDeserialize(this.blockchainID), avaAssetID, | ||
fee, creators, initialState, name, symbol, denomination | ||
); | ||
} | ||
/** | ||
* Helper function which takes an unsigned transaction and signs it, returning the resulting [[Tx]]. | ||
@@ -287,3 +634,70 @@ * | ||
} | ||
/** | ||
* Sends an amount of assetID to the specified address from a list of owned of addresses. | ||
* | ||
* @param username The user that owns the private keys associated with the `from` addresses | ||
* @param password The password unlocking the user | ||
* @param assetID The assetID of the asset to send | ||
* @param amount The amount of the asset to be sent | ||
* @param to The address of the recipient | ||
* @param from An array of addresses managed by the node for this subnet which will fund this transaction | ||
* | ||
* @returns Promise for the string representing the transaction's ID. | ||
*/ | ||
send = async (username:string, password:string, assetID:string | Buffer, amount:number | BN, to:string, from:Array<string> | Array<Buffer>):Promise<string> => { | ||
let asset:string; | ||
let amnt:BN; | ||
if(typeof this.parseAddress(to) === "undefined"){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI.listAssets: Invalid address format " + to); | ||
} | ||
from = this._cleanAddressArray(from, "send") | ||
if(typeof assetID !== "string"){ | ||
asset = bintools.avaSerialize(assetID); | ||
} else { | ||
asset = assetID; | ||
} | ||
if(typeof amount === 'number'){ | ||
amnt = new BN(amount); | ||
} else { | ||
amnt = amount; | ||
} | ||
let params = { | ||
"username": username, | ||
"password": password, | ||
"assetID": asset, | ||
"amount": amnt.toString(10), | ||
"to": to, | ||
"from": from | ||
}; | ||
return this.callMethod("avm.send", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["txID"]; | ||
}); | ||
} | ||
protected _cleanAddressArray(addresses:Array<string> | Array<Buffer>, caller:string):Array<string> { | ||
let addrs:Array<string> = []; | ||
let chainid:string = this.getBlockchainAlias() ? this.getBlockchainAlias() : this.getBlockchainID(); | ||
if(addresses && addresses.length > 0){ | ||
for(let i = 0; i < addresses.length; i++){ | ||
if(typeof addresses[i] === "string"){ | ||
if(typeof this.parseAddress(addresses[i] as string) === "undefined"){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - AVMAPI." + caller + ": Invalid address format " + addresses[i]); | ||
} | ||
addrs.push(addresses[i] as string); | ||
} else { | ||
addrs.push(bintools.addressToString(chainid, addresses[i] as Buffer)) | ||
} | ||
} | ||
} | ||
return addrs; | ||
} | ||
/** | ||
* This class should not be instantiated directly. Instead use the [[Slopes.addAPI]] method. | ||
@@ -296,3 +710,9 @@ * | ||
super(core, baseurl); | ||
this.keychain = new AVMKeyChain(); | ||
let netid:number = core.getNetworkID(); | ||
if(netid in Defaults.network && this.blockchainID in Defaults.network[netid]){ | ||
let alias = Defaults.network[netid][this.blockchainID].alias; | ||
this.keychain = new AVMKeyChain(alias); | ||
} else { | ||
this.keychain = new AVMKeyChain(blockchainID); | ||
} | ||
this.blockchainID = blockchainID | ||
@@ -299,0 +719,0 @@ } |
@@ -7,3 +7,3 @@ /** | ||
import BN from "bn.js"; | ||
import { SigIdx, Constants } from './types'; | ||
import { SigIdx, AVMConstants } from './types'; | ||
@@ -38,3 +38,3 @@ /** | ||
let inputid:number = inbuffer.readUInt32BE(68); | ||
if(inputid == Constants.SECPINPUTID){ | ||
if(inputid == AVMConstants.SECPINPUTID){ | ||
let secpin:SecpInput = new SecpInput(); | ||
@@ -86,20 +86,9 @@ secpin.fromBuffer(inbuffer); | ||
/** | ||
* @ignore | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
protected _basicInBuffer = (): Buffer => { | ||
try { | ||
let bsize:number = this.txid.length + this.txidx.length + this.assetid.length + this.inputid.length ; | ||
let barr:Array<Buffer> = [this.txid, this.txidx, this.assetid, this.inputid]; | ||
let buff: Buffer = Buffer.concat(barr,bsize); | ||
return buff; | ||
} catch(e) { | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - Input._basicInBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
protected _basicInParser = (bytes:Buffer):number => { | ||
let offset:number = 0; | ||
fromBuffer(bytes:Buffer, offset:number = 0):number { | ||
this.txid = bintools.copyFrom(bytes, offset, offset + 32); | ||
@@ -117,19 +106,16 @@ offset += 32; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
fromBuffer = (bytes:Buffer):number => { | ||
/* istanbul ignore next */ | ||
return this._basicInParser(bytes); | ||
} | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
toBuffer = ():Buffer => { | ||
/* istanbul ignore next */ | ||
return this._basicInBuffer(); | ||
toBuffer():Buffer { | ||
try { | ||
let bsize:number = this.txid.length + this.txidx.length + this.assetid.length + this.inputid.length ; | ||
let barr:Array<Buffer> = [this.txid, this.txidx, this.assetid, this.inputid]; | ||
let buff: Buffer = Buffer.concat(barr,bsize); | ||
return buff; | ||
} catch(e) { | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - Input.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
@@ -140,3 +126,3 @@ | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
/* istanbul ignore next */ | ||
@@ -180,26 +166,10 @@ return bintools.bufferToB58(this.toBuffer()); | ||
/** | ||
* @ignore | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
protected _SecpInBuffer = (): Buffer => { | ||
try { | ||
this.numAddr.writeUInt32BE(this.sigIdxs.length, 0); | ||
let bsize:number = this.amount.length + this.numAddr.length; | ||
let barr:Array<Buffer> = [this.amount, this.numAddr]; | ||
for(let i = 0; i < this.sigIdxs.length; i++) { | ||
let b:Buffer = this.sigIdxs[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
let buff: Buffer = Buffer.concat(barr,bsize); | ||
return buff; | ||
} catch(e) { | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - SecpInput._SecpInBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
protected _SecpInParser = (bytes:Buffer):number => { | ||
let offset:number = this._basicInParser(bytes); | ||
fromBuffer(bytes:Buffer, offset:number = 0):number { | ||
offset = super.fromBuffer(bytes, offset); | ||
this.amount = bintools.copyFrom(bytes, offset, offset + 8); | ||
@@ -223,19 +193,22 @@ offset += 8; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
fromBuffer = (bytes:Buffer):number => { | ||
return this._SecpInParser(bytes); | ||
} | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
toBuffer = ():Buffer => { | ||
let basicin:Buffer = this._basicInBuffer(); | ||
let secp:Buffer = this._SecpInBuffer(); | ||
return Buffer.concat([basicin, secp]); | ||
toBuffer():Buffer { | ||
try { | ||
let basicin:Buffer = super.toBuffer(); | ||
this.numAddr.writeUInt32BE(this.sigIdxs.length, 0); | ||
let bsize:number = basicin.length + this.amount.length + this.numAddr.length; | ||
let barr:Array<Buffer> = [basicin, this.amount, this.numAddr]; | ||
for(let i = 0; i < this.sigIdxs.length; i++) { | ||
let b:Buffer = this.sigIdxs[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
return Buffer.concat(barr,bsize); | ||
} catch(e) { | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - SecpInput.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
@@ -246,3 +219,3 @@ | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
@@ -257,3 +230,3 @@ } | ||
*/ | ||
addSignatureIdx = (addressIdx:number, address:string) => { | ||
addSignatureIdx = (addressIdx:number, address:Buffer) => { | ||
let sigidx:SigIdx = new SigIdx(); | ||
@@ -277,5 +250,5 @@ let b:Buffer = Buffer.alloc(4); | ||
constructor(txid?:Buffer, txidx?:Buffer, amount?:BN, assetID?:Buffer) { | ||
super(txid, txidx, assetID, Constants.SECPINPUTID); | ||
super(txid, txidx, assetID, AVMConstants.SECPINPUTID); | ||
if(txid && txidx && amount && assetID){ | ||
this.inputid.writeUInt32BE(Constants.SECPINPUTID,0); | ||
this.inputid.writeUInt32BE(AVMConstants.SECPINPUTID,0); | ||
this.txid = txid; | ||
@@ -282,0 +255,0 @@ this.txidx = txidx; |
@@ -89,7 +89,7 @@ /** | ||
/** | ||
* Returns the address. | ||
* Returns the address as a {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A string representation of the address | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representation of the address | ||
*/ | ||
getAddress = ():string => { | ||
getAddress = ():Buffer => { | ||
return this.addressFromPublicKey(this.pubk); | ||
@@ -99,2 +99,12 @@ } | ||
/** | ||
* Returns the address's string representation. | ||
* | ||
* @returns A string representation of the address | ||
*/ | ||
getAddressString = ():string => { | ||
let addr:Buffer = this.addressFromPublicKey(this.pubk); | ||
return bintools.addressToString(this.chainid, addr); | ||
} | ||
/** | ||
* Returns an address given a public key. | ||
@@ -104,5 +114,5 @@ * | ||
* | ||
* @returns A string for the address of the public key. | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address of the public key. | ||
*/ | ||
addressFromPublicKey = (pubk:Buffer): string => { | ||
addressFromPublicKey = (pubk:Buffer): Buffer => { | ||
let address:string = ""; | ||
@@ -116,4 +126,5 @@ if(pubk.length == 65) { | ||
let ripesha:Buffer = Buffer.from(createHash('rmd160').update(sha256).digest()); | ||
address = bintools.avaSerialize(ripesha); | ||
return address; | ||
return ripesha; | ||
//address = bintools.avaSerialize(ripesha); | ||
//return address; | ||
} | ||
@@ -189,4 +200,4 @@ /* istanbul ignore next */ | ||
*/ | ||
constructor(entropy:Buffer = undefined) { | ||
super(); | ||
constructor(chainid:string, entropy:Buffer = undefined) { | ||
super(chainid); | ||
this.generateKey(); | ||
@@ -211,4 +222,4 @@ } | ||
*/ | ||
makeKey = (entropy:Buffer = undefined):string => { | ||
let keypair:AVMKeyPair = new AVMKeyPair(entropy); | ||
makeKey = (entropy:Buffer = undefined):Buffer => { | ||
let keypair:AVMKeyPair = new AVMKeyPair(this.chainid, entropy); | ||
this.addKey(keypair); | ||
@@ -225,4 +236,4 @@ return keypair.getAddress(); | ||
*/ | ||
importKey = (privk:Buffer | string):string => { | ||
let keypair:AVMKeyPair = new AVMKeyPair(); | ||
importKey = (privk:Buffer | string):Buffer => { | ||
let keypair:AVMKeyPair = new AVMKeyPair(this.chainid); | ||
let pk:Buffer; | ||
@@ -235,3 +246,3 @@ if(typeof privk === 'string'){ | ||
keypair.importKey(pk); | ||
if(!(keypair.getAddress() in this.keys)){ | ||
if(!(keypair.getAddress().toString("hex") in this.keys)){ | ||
this.addKey(keypair); | ||
@@ -272,5 +283,5 @@ } | ||
*/ | ||
constructor(){ | ||
super(); | ||
constructor(chainid:string){ | ||
super(chainid); | ||
} | ||
} |
@@ -7,8 +7,6 @@ /** | ||
import BN from "bn.js"; | ||
import { Address, UnixNow, Constants } from './types'; | ||
import { Address, UnixNow, AVMConstants } from './types'; | ||
const bintools = BinTools.getInstance(); | ||
const SECPFXID = 4; | ||
/** | ||
@@ -22,5 +20,5 @@ * Takes a buffer representing the output and returns the proper Output instance. | ||
export const SelectOutputClass = (outbuffer:Buffer, args:Array<any> = []):Output => { | ||
let assetid:Buffer = bintools.copyFrom(outbuffer, 0, 32); | ||
let outputid:number = outbuffer.readUInt32BE(32); | ||
if(outputid == Constants.SECPOUTPUTID){ | ||
let assetid:Buffer = bintools.copyFrom(outbuffer, 0, AVMConstants.ASSETIDLEN); | ||
let outputid:number = outbuffer.readUInt32BE(AVMConstants.ASSETIDLEN); | ||
if(outputid == AVMConstants.SECPOUTPUTID){ | ||
let secpout:SecpOutput = new SecpOutput(assetid, ...args); | ||
@@ -34,16 +32,26 @@ secpout.fromBuffer(outbuffer); | ||
/** | ||
* An abstract representing a transaction output. All output types must extend on this class. | ||
* A class representing a transaction output. All output types must extend on this class. | ||
*/ | ||
export abstract class Output { | ||
export class Output { | ||
protected outputid:Buffer = Buffer.alloc(4); | ||
protected outputidnum:number; | ||
protected assetid:Buffer = Buffer.alloc(32); | ||
abstract getOutputID:() => number; | ||
abstract getAssetID:() => Buffer; | ||
getOutputID = ():number => { | ||
return this.outputidnum; | ||
}; | ||
abstract fromBuffer:(utxobuff:Buffer) => number; | ||
abstract toBuffer:() => Buffer; | ||
abstract toString:() => string; | ||
fromBuffer(outbuff:Buffer, offset:number = 0):number { | ||
this.outputid = bintools.copyFrom(outbuff, offset, offset + 4); | ||
this.outputidnum = this.outputid.readUInt32BE(0); | ||
return offset + 4; | ||
}; | ||
toBuffer():Buffer { | ||
return this.outputid; | ||
}; | ||
toString():string { | ||
return bintools.bufferToB58(this.outputid); | ||
}; | ||
static comparator = ():(a:Output, b:Output) => (1|-1|0) => { | ||
@@ -55,8 +63,5 @@ return function(a:Output, b:Output):(1|-1|0) { | ||
constructor(outputidnum:number, assetID?:Buffer) { | ||
constructor(outputidnum:number) { | ||
this.outputid.writeUInt32BE(outputidnum, 0); | ||
this.outputidnum = outputidnum; | ||
if(assetID){ | ||
this.assetid = assetID; | ||
} | ||
} | ||
@@ -66,5 +71,5 @@ } | ||
/** | ||
* An [[Output]] class which issues a payment on an assetID. | ||
* An [[Output]] class which specifies a secp256k1 . | ||
*/ | ||
export class SecpOutput extends Output { | ||
export class SecpOutBase extends Output { | ||
protected locktime:Buffer = Buffer.alloc(8); | ||
@@ -78,20 +83,2 @@ protected threshold:Buffer = Buffer.alloc(4); | ||
/** | ||
* @ignore | ||
*/ | ||
protected _OPGetAddresses = ():{[address:string]: BN} => { | ||
let result:{[address:string]: BN} = {}; | ||
for(let i = 0; i < this.addresses.length; i++) { | ||
result[this.addresses[i].toString()] = bintools.fromBufferToBN(this.locktime); | ||
} | ||
return result; | ||
} | ||
/** | ||
* Returns the number for the output type of the output class. | ||
*/ | ||
getOutputID = ():number => { | ||
return this.outputidnum; | ||
}; | ||
/** | ||
* Returns the amount as a {@link https://github.com/indutny/bn.js/|BN}. | ||
@@ -118,25 +105,22 @@ */ | ||
/** | ||
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}. | ||
* Returns an array of {@link https://github.com/feross/buffer|Buffer}s for the addresses. | ||
*/ | ||
getAssetID = ():Buffer => { | ||
return this.assetid; | ||
getAddresses = ():Array<Buffer> => { | ||
let result:Array<Buffer> = []; | ||
for(let i = 0; i < this.addresses.length; i++) { | ||
result.push(this.addresses[i].toBuffer()) | ||
} | ||
return result; | ||
} | ||
/** | ||
* Returns a map from all addresses as string keys to their locktime represented in {@link https://github.com/indutny/bn.js/|BN}. | ||
*/ | ||
getAddresses = ():{[address:string]: BN} => { | ||
return this._OPGetAddresses(); | ||
} | ||
/** | ||
* Returns an array of length 2 with the first index being the index of the provided address and the second being false (as fallback addresses are not available in this output type). | ||
* Returns the index of the address. | ||
* | ||
* @param address Address to look up to return its index. | ||
* @param address A {@link https://github.com/feross/buffer|Buffer} of the address to look up to return its index. | ||
* | ||
* @returns An array of length 2, first index is the index the address resides in, second index is false. | ||
* @returns The index of the address. | ||
*/ | ||
getAddressIdx = (address:string):number => { | ||
getAddressIdx = (address:Buffer):number => { | ||
for(let i = 0; i < this.addresses.length; i++){ | ||
if(this.addresses[i].toString() == address){ | ||
if(this.addresses[i].toBuffer().toString("hex") == address.toString("hex")){ | ||
return i | ||
@@ -156,18 +140,14 @@ } | ||
*/ | ||
getAddress = (idx:number):string => { | ||
getAddress = (idx:number):Buffer => { | ||
if(idx < this.addresses.length){ | ||
return this.addresses[idx].toString(); | ||
return this.addresses[idx].toBuffer(); | ||
} | ||
throw new Error("Error - OutPayment.getAddress: idx out of range"); | ||
throw new Error("Error - SecpOutBase.getAddress: idx out of range"); | ||
} | ||
/** | ||
* @ignore | ||
* Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[SecpOutBase]] and returns the size of the output. | ||
*/ | ||
protected _OPParseBuffer = (utxobuff:Buffer, offset:number):number => { | ||
this.assetid = bintools.copyFrom(utxobuff, offset, offset + 32); | ||
offset += 32; | ||
this.outputid = bintools.copyFrom(utxobuff, offset, offset + 4); //copied | ||
this.outputidnum = this.outputid.readUInt32BE(0); | ||
offset += 4; | ||
fromBuffer(utxobuff:Buffer, offset:number = 0):number { | ||
offset = super.fromBuffer(utxobuff, offset); | ||
this.amount = bintools.copyFrom(utxobuff, offset, offset + 8); | ||
@@ -197,17 +177,11 @@ this.amountValue = bintools.fromBufferToBN(this.amount); | ||
/** | ||
* Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[OutCreateAsset]] and returns the size of the output. | ||
* Returns the buffer representing the [[SecpOutBase]] instance. | ||
*/ | ||
fromBuffer = (utxobuff:Buffer):number => { | ||
return this._OPParseBuffer(utxobuff, 0); | ||
} | ||
/** | ||
* @ignore | ||
*/ | ||
protected _OPBuffer = (): Buffer => { | ||
toBuffer():Buffer { | ||
try { | ||
this.addresses.sort(Address.comparitor()); | ||
let bsize:number = this.assetid.length + this.outputid.length + this.amount.length + this.locktime.length + this.threshold.length + this.numaddrs.length; | ||
let superbuff:Buffer = super.toBuffer(); | ||
let bsize:number = superbuff.length + this.amount.length + this.locktime.length + this.threshold.length + this.numaddrs.length; | ||
this.numaddrs.writeUInt32BE(this.addresses.length, 0); | ||
let barr:Array<Buffer> = [this.assetid, this.outputid, this.amount, this.locktime, this.threshold, this.numaddrs]; | ||
let barr:Array<Buffer> = [superbuff, this.amount, this.locktime, this.threshold, this.numaddrs]; | ||
for(let i = 0; i < this.addresses.length; i++) { | ||
@@ -218,7 +192,6 @@ let b: Buffer = this.addresses[i].toBuffer(); | ||
} | ||
let buff: Buffer = Buffer.concat(barr,bsize); | ||
return buff; | ||
return Buffer.concat(barr,bsize);; | ||
} catch(e) { | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - TxOut._OPTxBuffer: " + e; | ||
let emsg:string = "Error - SecpOutBase.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
@@ -230,12 +203,5 @@ throw new Error(emsg); | ||
/** | ||
* Returns the buffer representing the [[OutCreateAsset]] instance. | ||
* Returns a base-58 string representing the [[SecpOutBase]]. | ||
*/ | ||
toBuffer = ():Buffer => { | ||
return this._OPBuffer(); | ||
} | ||
/** | ||
* Returns a base-58 string representing the [[OutCreateAsset]]. | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
@@ -245,6 +211,6 @@ } | ||
/** | ||
* @ignore | ||
* Given an array of addresses and an optional timestamp, select an array of address {@link https://github.com/feross/buffer|Buffer}s of qualified spenders for the output. | ||
*/ | ||
protected _OPQualified = (addresses:Array<string>, asOf:BN = undefined):Array<string> => { | ||
let qualified:Array<string> = []; | ||
getSpenders = (addresses:Array<Buffer>, asOf:BN = undefined):Array<Buffer> => { | ||
let qualified:Array<Buffer> = []; | ||
let now:BN; | ||
@@ -265,3 +231,3 @@ if(typeof asOf === 'undefined'){ | ||
for(let j = 0; j < addresses.length && qualified.length < threshold; j++){ | ||
if(addresses[j] == this.addresses[i].toString()){ | ||
if(addresses[j].toString("hex") == this.addresses[i].toBuffer().toString("hex")){ | ||
qualified.push(addresses[j]); | ||
@@ -276,12 +242,5 @@ } | ||
/** | ||
* Given an array of addresses and an optional timestamp, select an array of address strings of qualified spenders for the output. | ||
* Given an array of address {@link https://github.com/feross/buffer|Buffer}s and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
getSpenders = (addresses:Array<string>, asOf:BN = undefined):Array<string> => { | ||
return this._OPQualified(addresses, asOf); | ||
} | ||
/** | ||
* Given an array of addresses and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
meetsThreshold = (addresses:Array<string>, asOf:BN = undefined):boolean => { | ||
meetsThreshold = (addresses:Array<Buffer>, asOf:BN = undefined):boolean => { | ||
let now:BN; | ||
@@ -293,8 +252,4 @@ if(typeof asOf === 'undefined'){ | ||
} | ||
let locktime:BN = bintools.fromBufferToBN(this.locktime); | ||
let qualified:Array<string> = this._OPQualified(addresses, now); | ||
let qualified:Array<Buffer> = this.getSpenders(addresses, now); | ||
let threshold:number = this.threshold.readUInt32BE(0); | ||
if(now.lte(locktime)){ | ||
return false; | ||
} | ||
if(qualified.length >= threshold){ | ||
@@ -312,8 +267,8 @@ return true; | ||
* @param amount A {@link https://github.com/indutny/bn.js/|BN} representing the amount in the output | ||
* @param addresses An array of strings representing addresses | ||
* @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses | ||
* @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime | ||
* @param threshold A number representing the the threshold number of signers required to sign the transaction | ||
*/ | ||
constructor(assetid:Buffer, amount?:BN, addresses?:Array<string>, locktime?:BN, threshold?:number){ | ||
super(SECPFXID, assetid); | ||
constructor(amount?:BN, addresses?:Array<Buffer>, locktime?:BN, threshold?:number){ | ||
super(AVMConstants.SECPOUTPUTID); | ||
if(amount && addresses){ | ||
@@ -325,3 +280,3 @@ this.amountValue = amount.clone(); | ||
addrs[i] = new Address(); | ||
addrs[i].fromString(addresses[i]); | ||
addrs[i].fromBuffer(addresses[i]); | ||
} | ||
@@ -341,2 +296,30 @@ this.addresses = addrs; | ||
export class SecpOutput extends SecpOutBase { | ||
protected assetid:Buffer = Buffer.alloc(32); | ||
fromBuffer(outbuff:Buffer, offset:number = 0):number { | ||
this.assetid = bintools.copyFrom(outbuff, offset, offset + 32); | ||
offset += 32; | ||
offset = super.fromBuffer(outbuff, offset); | ||
return offset; | ||
} | ||
toBuffer():Buffer { | ||
let superbuff:Buffer = super.toBuffer(); | ||
return Buffer.concat([this.assetid, superbuff]); | ||
} | ||
/** | ||
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
getAssetID = ():Buffer => { | ||
return this.assetid; | ||
} | ||
constructor(assetid?:Buffer, amount?:BN, addresses?:Array<Buffer>, locktime?:BN, threshold?:number){ | ||
super(amount, addresses, locktime, threshold); | ||
if(typeof assetid !== 'undefined' && assetid.length == AVMConstants.ASSETIDLEN) { | ||
this.assetid = assetid; | ||
} | ||
} | ||
} |
@@ -5,5 +5,5 @@ /** | ||
import {Buffer} from "buffer/"; | ||
import { Signature, Constants } from './types'; | ||
import { Output, SelectOutputClass } from './outputs'; | ||
import { Input, SecpInput, SelectInputClass } from './inputs'; | ||
import { Signature, AVMConstants, InitialStates } from './types'; | ||
import { Output, SecpOutBase, SelectOutputClass } from './outputs'; | ||
import { Input, SelectInputClass } from './inputs'; | ||
import BinTools from '../../utils/bintools'; | ||
@@ -91,6 +91,5 @@ | ||
* | ||
* @remarks assume not-checksummed and deserialized | ||
* @remarks assume not-checksummed | ||
*/ | ||
fromBuffer = (bytes:Buffer):number => { | ||
let offset:number = 0; | ||
fromBuffer(bytes:Buffer, offset:number = 0):number { | ||
this.txtype = bintools.copyFrom(bytes, offset, offset + 4); | ||
@@ -126,5 +125,5 @@ offset += 4; | ||
/** | ||
* @ignore | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]]. | ||
*/ | ||
protected _basicTxBuffer = ():Buffer => { | ||
toBuffer():Buffer { | ||
try { | ||
@@ -153,3 +152,3 @@ this.outs.sort(Output.comparator()); | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - TxUnsigned._basicTxBuffer: " + e; | ||
let emsg:string = "Error - TxUnsigned.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
@@ -161,12 +160,5 @@ throw new Error(emsg); | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]]. | ||
*/ | ||
toBuffer = ():Buffer => { | ||
return this._basicTxBuffer(); | ||
} | ||
/** | ||
* Returns a base-58 representation of the [[TxUnsigned]]. | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
@@ -197,2 +189,119 @@ } | ||
export class TxCreateAsset extends TxUnsigned { | ||
protected name:string = ""; | ||
protected namebuff:Buffer = Buffer.alloc(2); | ||
protected symbol:string = ""; | ||
protected symbolbuff:Buffer = Buffer.alloc(2); | ||
protected denomination:Buffer = Buffer.alloc(1); | ||
protected initialstate:InitialStates = new InitialStates(); | ||
/** | ||
* Returns the array of array of [[Output]]s for the initial state | ||
*/ | ||
getInitialStates = ():InitialStates => { | ||
return this.initialstate; | ||
} | ||
/** | ||
* Returns the string representation of the name | ||
*/ | ||
getName = ():string => { | ||
return this.name; | ||
} | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the name | ||
*/ | ||
getNameBuffer = ():Buffer => { | ||
return this.namebuff; | ||
} | ||
/** | ||
* Returns the string representation of the symbol | ||
*/ | ||
getSymbol = ():string => { | ||
return this.symbol; | ||
} | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the symbol | ||
*/ | ||
getSymbolBuffer = ():Buffer => { | ||
return this.symbolbuff; | ||
} | ||
/** | ||
* Returns the numeric representation of the denomination | ||
*/ | ||
getDenomination = ():number => { | ||
return this.denomination.readUInt8(0); | ||
} | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the denomination | ||
*/ | ||
getDenominationBuffer = ():Buffer => { | ||
return this.denomination; | ||
} | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxCreateAsset]], parses it, populates the class, and returns the length of the TxUnsigned in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxCreateAsset]] | ||
* | ||
* @returns The length of the raw [[TxCreateAsset]] | ||
* | ||
* @remarks assume not-checksummed | ||
*/ | ||
fromBuffer(bytes:Buffer, offset:number = 0):number { | ||
offset = super.fromBuffer(bytes, offset); | ||
let namesize:number = bintools.copyFrom(bytes, offset, offset + 2).readUInt16BE(0); | ||
this.namebuff = bintools.copyFrom(bytes, offset, offset + 2 + namesize); | ||
offset += 2; | ||
offset += namesize; | ||
let symsize:number = bintools.copyFrom(bytes, offset, offset + 2).readUInt16BE(0); | ||
this.symbolbuff = bintools.copyFrom(bytes, offset, offset + 2 + symsize); | ||
offset += 2; | ||
offset += symsize; | ||
this.denomination = bintools.copyFrom(bytes, offset, offset + 1); | ||
offset += 1; | ||
let inits:InitialStates = new InitialStates(); | ||
offset = inits.fromBuffer(bytes, offset); | ||
this.initialstate = inits; | ||
return offset; | ||
} | ||
toBuffer():Buffer { | ||
let barr:Array<Buffer> = [super.toBuffer(), this.namebuff, this.symbolbuff, this.denomination, this.initialstate.toBuffer()]; | ||
return Buffer.concat(barr); | ||
} | ||
/** | ||
* Class representing an unsigned Create Asset transaction. | ||
* | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* @param initialstate Optional [[InitialStates]] that represent the intial state of a created asset | ||
* @param ins Optional array of the [[Input]]s | ||
* @param outs Optional array of the [[Output]]s | ||
* @param networkid Optional networkid, default 2 | ||
* @param blockchainid Optional blockchainid, default Buffer.alloc(32, 16) | ||
* @param txtype Optional txtype, default 1 | ||
*/ | ||
constructor(name:string = undefined, symbol:string = undefined, denomination:number = undefined, initialstate:InitialStates = undefined, ins:Array<Input> = undefined, outs:Array<Output> = undefined, networkid:number = 2, blockchainid:Buffer = Buffer.alloc(32, 16), txtype:number = AVMConstants.CREATEASSETTX) { | ||
super(ins, outs, networkid, blockchainid, txtype); | ||
if(typeof name === 'string' && typeof symbol === 'string' && typeof denomination === 'number' && denomination >= 0 && denomination <= 32 && initialstate) { | ||
this.initialstate = initialstate; | ||
this.namebuff = bintools.stringToBuffer(name); | ||
this.name = name; | ||
this.symbolbuff = bintools.stringToBuffer(symbol); | ||
this.symbol = symbol; | ||
this.denomination.writeUInt8(denomination, 0); | ||
} | ||
} | ||
} | ||
/** | ||
@@ -212,3 +321,3 @@ * Class representing a signed transaction. | ||
*/ | ||
fromBuffer = (bytes:Buffer):number => { | ||
fromBuffer(bytes:Buffer):number { | ||
this.tx = new TxUnsigned(); | ||
@@ -223,3 +332,3 @@ let offset:number = this.tx.fromBuffer(bytes); | ||
offset += 4; | ||
if(credential != Constants.SECPCREDENTIAL){ | ||
if(credential != AVMConstants.SECPCREDENTIAL){ | ||
/* istanbul ignore next */ | ||
@@ -250,3 +359,3 @@ throw new Error("Error - Tx.fromBuffer: Invalid credentialID " + credential); | ||
*/ | ||
fromString = (serialized:string):number => { | ||
fromString(serialized:string):number { | ||
return this.fromBuffer(bintools.avaDeserialize(serialized)); | ||
@@ -258,3 +367,3 @@ } | ||
*/ | ||
toBuffer = ():Buffer => { | ||
toBuffer():Buffer { | ||
try { | ||
@@ -271,3 +380,3 @@ let txbuff: Buffer = this.tx.toBuffer(); | ||
let credentialID = Buffer.alloc(4); | ||
credentialID.writeUInt32BE(Constants.SECPCREDENTIAL, 0); | ||
credentialID.writeUInt32BE(AVMConstants.SECPCREDENTIAL, 0); | ||
barr.push(credentialID); | ||
@@ -299,3 +408,3 @@ bsize += credentialID.length; | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
@@ -302,0 +411,0 @@ } |
@@ -8,2 +8,3 @@ /** | ||
import BinTools from '../../utils/bintools'; | ||
import { Output, SelectOutputClass, SecpOutBase } from './outputs'; | ||
@@ -19,3 +20,3 @@ /** | ||
export class SigIdx extends NBytes { | ||
source:string; | ||
source:Buffer; | ||
@@ -25,3 +26,3 @@ /** | ||
*/ | ||
setSource = (address:string) => { | ||
setSource = (address:Buffer) => { | ||
this.source = address; | ||
@@ -33,3 +34,3 @@ } | ||
*/ | ||
getSource = ():string => { | ||
getSource = ():Buffer => { | ||
return this.source; | ||
@@ -79,3 +80,3 @@ } | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
@@ -90,3 +91,3 @@ } | ||
*/ | ||
fromString = (addr:string):number => { | ||
fromString(addr:string):number { | ||
let addrbuff:Buffer = bintools.b58ToBuffer(addr); | ||
@@ -119,7 +120,74 @@ if(addrbuff.length == 24 && bintools.validateChecksum(addrbuff)) { | ||
export class Constants { | ||
export class InitialStates { | ||
protected fxs:{[fxid:number]:Array<Output>} = {}; | ||
addOutput(out:Output, fxid:number):void { | ||
if(!(fxid in this.fxs)){ | ||
this.fxs[fxid] = []; | ||
} | ||
this.fxs[fxid].push(out); | ||
} | ||
fromBuffer(bytes:Buffer, offset:number):number { | ||
let result:{[fxid:number]:Array<Output>} = {}; | ||
let klen:Buffer = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let klennum:number = klen.readUInt32BE(0); | ||
for(let i = 0; i < klennum; i++){ | ||
let fxidbuff:Buffer = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let fxid:number = fxidbuff.readUInt32BE(0); | ||
result[fxid] = []; | ||
let statelenbuff:Buffer = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let statelen:number = statelenbuff.readUInt32BE(0); | ||
for(let j = 0; j < statelen; j++){ | ||
let abuff:Buffer = bintools.copyFrom(bytes, offset); | ||
let out:Output = new SecpOutBase(); | ||
out.fromBuffer(abuff) | ||
let outbuff:Buffer = out.toBuffer(); | ||
offset += outbuff.length; | ||
result[fxid].push(out); | ||
} | ||
} | ||
this.fxs = result; | ||
return offset | ||
} | ||
toBuffer():Buffer { | ||
let buff:Array<Buffer> = []; | ||
let keys:Array<number> = Object.keys(this.fxs).map(k => parseInt(k)).sort(); | ||
let klen:Buffer = Buffer.alloc(4); | ||
klen.writeUInt32BE(keys.length, 0); | ||
buff.push(klen); | ||
for(let i = 0; i < keys.length; i++){ | ||
let fxid:number = keys[i]; | ||
let fxidbuff:Buffer = Buffer.alloc(4); | ||
fxidbuff.writeUInt32BE(fxid, 0); | ||
buff.push(fxidbuff); | ||
let initialState = this.fxs[fxid].sort(Output.comparator()); | ||
let statelen:Buffer = Buffer.alloc(4); | ||
statelen.writeUInt32BE(initialState.length, 0); | ||
buff.push(statelen); | ||
for(let j = 0; j < initialState.length; j++){ | ||
buff.push(initialState[j].toBuffer()); | ||
} | ||
} | ||
return Buffer.concat(buff); | ||
} | ||
constructor(){} | ||
} | ||
export class AVMConstants { | ||
static SECPOUTPUTID:number = 4; | ||
static SECPINPUTID:number = 6; | ||
static CREATEASSETTX:number = 1; | ||
static BASETX:number = 0; | ||
static SECPCREDENTIAL:number =7; | ||
static SECPCREDENTIAL:number = 7; | ||
static ASSETIDLEN:number = 32; | ||
static BLOCKCHAINIDLEN:number = 32; | ||
static SYMBOLMAXLEN:number = 4; | ||
static ASSETNAMELEN:number = 128; | ||
static ADDRESSLENGTH:number = 20; | ||
static SECPFXID:number = 0; | ||
} | ||
@@ -126,0 +194,0 @@ |
@@ -8,5 +8,5 @@ /** | ||
import { Output, SecpOutput, SelectOutputClass } from './outputs'; | ||
import { MergeRule, UnixNow, Constants } from './types'; | ||
import { TxUnsigned } from './tx'; | ||
import { SecpInput } from './inputs'; | ||
import { MergeRule, UnixNow, AVMConstants, InitialStates } from './types'; | ||
import { TxUnsigned, TxCreateAsset } from './tx'; | ||
import { SecpInput, Input } from './inputs'; | ||
@@ -32,3 +32,3 @@ /** | ||
let outputid:number = output.getOutputID(); | ||
if(outputid == Constants.SECPOUTPUTID){ | ||
if(outputid == AVMConstants.SECPOUTPUTID){ | ||
let secpout:SecpOutput = output as SecpOutput; | ||
@@ -45,7 +45,9 @@ let utxo:SecpUTXO = new SecpUTXO(txid, txidx, secpout); | ||
*/ | ||
export abstract class UTXO { | ||
export class UTXO { | ||
protected txid:Buffer = Buffer.alloc(32); | ||
protected txidx:Buffer = Buffer.alloc(4); | ||
abstract getOuputID:() => number; | ||
getOuputID():number { | ||
return undefined; | ||
}; | ||
@@ -76,7 +78,2 @@ /** | ||
_basicUTXOBuffer = (utxobuff) => { | ||
this.txid = bintools.copyFrom(utxobuff, 0, 32); | ||
this.txidx = bintools.copyFrom(utxobuff, 32, 36); | ||
} | ||
/** | ||
@@ -87,5 +84,8 @@ * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[UTXO]], parses it, populates the class, and returns the length of the UTXO in bytes. | ||
*/ | ||
fromBuffer = (utxobuff:Buffer) => { | ||
/* istanbul ignore next */ | ||
this._basicUTXOBuffer(utxobuff); | ||
fromBuffer(utxobuff:Buffer, offset:number = 0):number { | ||
this.txid = bintools.copyFrom(utxobuff, offset, offset + 32); | ||
offset += 32; | ||
this.txidx = bintools.copyFrom(utxobuff, offset, offset + 4); | ||
offset += 4; | ||
return offset; | ||
} | ||
@@ -103,3 +103,3 @@ | ||
*/ | ||
fromString = (serialized:string) => { | ||
fromString(serialized:string) { | ||
/* istanbul ignore next */ | ||
@@ -112,3 +112,3 @@ return this.fromBuffer( bintools.avaDeserialize(serialized) ); | ||
*/ | ||
toBuffer = ():Buffer => { | ||
toBuffer():Buffer { | ||
/* istanbul ignore next */ | ||
@@ -132,3 +132,3 @@ try { | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
/* istanbul ignore next */ | ||
@@ -141,6 +141,7 @@ return bintools.avaSerialize(this.toBuffer()); | ||
* | ||
* @param serialized Optional parameter of the serialized string representing a UTXO | ||
* @param txid Optional {@link https://github.com/feross/buffer|Buffer} of transaction ID for the UTXO | ||
* @param txidx Optional number for the index of the transaction's [[Output]] | ||
*/ | ||
constructor(txid?:Buffer, txidx:number = undefined) { | ||
if(txid && typeof txidx === "number") { | ||
constructor(txid:Buffer = undefined, txidx:number = undefined) { | ||
if(typeof txid !== "undefined" && typeof txidx === "number") { | ||
this.txid = txid; | ||
@@ -173,3 +174,3 @@ this.txidx.writeUInt32BE(txidx, 0); | ||
*/ | ||
getAddresses = ():{[address:string]: BN} => { | ||
getAddresses = ():Array<Buffer> => { | ||
return this.output.getAddresses(); | ||
@@ -183,3 +184,3 @@ }; | ||
*/ | ||
getAddressIdx = (address:string):number => { | ||
getAddressIdx = (address:Buffer):number => { | ||
return this.output.getAddressIdx(address); | ||
@@ -193,5 +194,5 @@ } | ||
* | ||
* @returns A string representing the address. | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representing the address. | ||
*/ | ||
getAddress = (idx:number):string => { | ||
getAddress = (idx:number):Buffer => { | ||
return this.output.getAddress(idx); | ||
@@ -227,2 +228,9 @@ } | ||
/** | ||
* Returns a {@link https://github.com/indutny/bn.js/|BN} of the locktime. | ||
*/ | ||
getLocktime = ():BN => { | ||
return this.output.getLocktime(); | ||
} | ||
/** | ||
* Returns the UTXOID as a base-58 string (UTXOID is a string ) | ||
@@ -239,7 +247,8 @@ */ | ||
*/ | ||
fromBuffer = (utxobuff:Buffer) => { | ||
this._basicUTXOBuffer(utxobuff); | ||
let utxoOut = bintools.copyFrom(utxobuff, 36, utxobuff.length); | ||
fromBuffer(utxobuff:Buffer, offset:number = 0):number { | ||
offset = super.fromBuffer(utxobuff, offset); | ||
let utxoOut = bintools.copyFrom(utxobuff, offset, utxobuff.length); | ||
this.output = SelectOutputClass(utxoOut) as SecpOutput; | ||
this.output.fromBuffer(utxoOut); | ||
offset += this.output.toBuffer().length; | ||
return offset; | ||
} | ||
@@ -257,3 +266,3 @@ | ||
*/ | ||
fromString = (serialized:string) => { | ||
fromString(serialized:string):number { | ||
return this.fromBuffer( bintools.avaDeserialize(serialized) ); | ||
@@ -265,10 +274,11 @@ } | ||
*/ | ||
toBuffer = ():Buffer => { | ||
toBuffer():Buffer { | ||
try { | ||
let superbuff = super.toBuffer(); | ||
let obuff = this.output.toBuffer(); | ||
let barr:Array<Buffer> = [this.txid, this.txidx, obuff]; | ||
return Buffer.concat(barr, this.txid.length + this.txidx.length + obuff.length) | ||
let barr:Array<Buffer> = [superbuff, obuff]; | ||
return Buffer.concat(barr, superbuff.length + obuff.length) | ||
} catch(e) { | ||
/* istanbul ignore next */ | ||
let emsg:string = "Error - UTXO.toBuffer: " + e; | ||
let emsg:string = "Error - SecpUTXO.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
@@ -285,3 +295,3 @@ throw new Error(emsg); | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
@@ -293,3 +303,3 @@ } | ||
*/ | ||
getSpenders = (addresses:Array<string>, asOf:BN = undefined):Array<string> => { | ||
getSpenders = (addresses:Array<Buffer>, asOf:BN = undefined):Array<Buffer> => { | ||
return this.output.getSpenders(addresses, asOf); | ||
@@ -301,3 +311,3 @@ } | ||
*/ | ||
meetsThreshold = (addresses:Array<string>, asOf:BN = undefined) => { | ||
meetsThreshold = (addresses:Array<Buffer>, asOf:BN = undefined) => { | ||
return this.output.meetsThreshold(addresses, asOf); | ||
@@ -360,3 +370,3 @@ } | ||
} | ||
let secputxo; | ||
let secputxo:SecpUTXO; | ||
try { | ||
@@ -372,4 +382,6 @@ secputxo = utxoX as SecpUTXO; | ||
let addresses:{[address:string]: BN} = secputxo.getAddresses(); //gets addresses and their locktime | ||
for(let [address, locktime] of Object.entries(addresses)){ | ||
let addresses:Array<Buffer> = secputxo.getAddresses(); | ||
let locktime:BN = secputxo.getLocktime(); | ||
for(let i = 0; i < addresses.length; i++){ | ||
let address:string = addresses[i].toString("hex"); | ||
if(!(address in this.addressUTXOs)){ | ||
@@ -521,3 +533,3 @@ this.addressUTXOs[address] = {}; | ||
* | ||
* @param address An address or array of addresses | ||
* @param address An array of address {@link https://github.com/feross/buffer|Buffer}s | ||
* @param spendable If true, only retrieves UTXOIDs whose locktime has passed | ||
@@ -527,12 +539,9 @@ * | ||
*/ | ||
getUTXOIDs = (address:string | Array<string> = undefined, spendable:boolean = true):Array<string> => { | ||
if(typeof address !== "undefined") { | ||
let results:Array<string> = []; | ||
if(typeof address === 'string'){ | ||
address = [address]; | ||
} | ||
getUTXOIDs = (addresses:Array<Buffer> = undefined, spendable:boolean = true):Array<string> => { | ||
if(typeof addresses !== "undefined") { | ||
let results:Array<string> = []; | ||
let now:BN = UnixNow(); | ||
for(let i = 0; i < address.length; i++){ | ||
if(address[i] in this.addressUTXOs){ | ||
let entries = Object.entries(this.addressUTXOs[address[i]]); | ||
for(let i = 0; i < addresses.length; i++){ | ||
if(addresses[i].toString("hex") in this.addressUTXOs){ | ||
let entries = Object.entries(this.addressUTXOs[addresses[i].toString("hex")]); | ||
for(let [utxoid, locktime] of entries){ | ||
@@ -551,6 +560,6 @@ if(results.indexOf(utxoid) == -1 && (spendable && locktime.lte(now)) || !spendable) { | ||
/** | ||
* Gets the addresses in the [[UTXOSet]]. | ||
* Gets the addresses in the [[UTXOSet]] and returns an array of {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
getAddresses = ():Array<string> => { | ||
return Object.keys(this.addressUTXOs); | ||
getAddresses = ():Array<Buffer> => { | ||
return Object.keys(this.addressUTXOs).map(k => Buffer.from(k, "hex")); | ||
} | ||
@@ -567,3 +576,3 @@ | ||
*/ | ||
getBalance = (addresses:Array<string>, assetID:Buffer|string, asOf:BN = undefined):BN => { | ||
getBalance = (addresses:Array<Buffer>, assetID:Buffer|string, asOf:BN = undefined):BN => { | ||
let utxoids:Array<string> = this.getUTXOIDs(addresses); | ||
@@ -593,3 +602,3 @@ let utxos:Array<SecpUTXO> = this.getAllUTXOs(utxoids); | ||
*/ | ||
getAssetIDs = (addresses:string | Array<string> = undefined ):Array<Buffer> => { | ||
getAssetIDs = (addresses:Array<Buffer> = undefined ):Array<Buffer> => { | ||
let results:Set<Buffer> = new Set(); | ||
@@ -615,3 +624,3 @@ let utxoids:Array<string> = []; | ||
* Creates an unsigned transaction. For more granular control, you may create your own | ||
* [[TxUnsigned]] manually (with their corresponding [[Input]]s and [[Output]]s. | ||
* [[TxUnsigned]] manually (with their corresponding [[Input]]s and [[Output]]s). | ||
* | ||
@@ -622,5 +631,3 @@ * @param networkid The number representing NetworkID of the node | ||
* @param toAddresses The addresses to send the funds | ||
* @param fromAddresses The addresses being used to send the funds from the UTXOs provided | ||
* @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs, locktime of BN(0) and a threshold of 1 | ||
* @param assetID The assetID of the value being sent as a {@link https://github.com/indutny/bn.js/|BN} | ||
* @param fromAddresses The addresses being used to send the funds from the UTXOs {@link https://github.com/feross/buffer|Buffer} | ||
* @param asOf The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN} | ||
@@ -633,3 +640,3 @@ * @param locktime The locktime field created in the resulting outputs | ||
*/ | ||
makeUnsignedTx = (networkid:number, blockchainid:Buffer, amount:BN, toAddresses:Array<string>, fromAddresses:Array<string>, changeAddresses:Array<string>, assetID:Buffer, asOf:BN = UnixNow(), locktime:BN = new BN(0), threshold:number = 1):TxUnsigned => { | ||
makeUnsignedTx = (networkid:number, blockchainid:Buffer, amount:BN, toAddresses:Array<Buffer>, fromAddresses:Array<Buffer>, changeAddresses:Array<Buffer>, assetID:Buffer, asOf:BN = UnixNow(), locktime:BN = new BN(0), threshold:number = 1):TxUnsigned => { | ||
const zero:BN = new BN(0); | ||
@@ -643,46 +650,48 @@ let spendamount:BN = zero.clone(); | ||
outs.push(new SecpOutput(assetID, amount, toAddresses, locktime, threshold)); | ||
if(amount.toNumber() !== 0){ | ||
outs.push(new SecpOutput(assetID, amount, toAddresses, locktime, threshold)); | ||
for(let i = 0; i < utxos.length && spendamount.lt(amount); i++){ | ||
if((assetID === undefined || (utxos[i].getAssetID().compare(assetID) == 0) && utxos[i].meetsThreshold(fromAddresses, asOf))){ | ||
let amt:BN = utxos[i].getAmount().clone(); | ||
spendamount = spendamount.add(amt); | ||
change = spendamount.sub(amount); | ||
change = change.gt(zero) ? change : zero.clone(); | ||
for(let i = 0; i < utxos.length && spendamount.lt(amount); i++){ | ||
if((assetID === undefined || (utxos[i].getAssetID().compare(assetID) == 0) && utxos[i].meetsThreshold(fromAddresses, asOf))){ | ||
let amt:BN = utxos[i].getAmount().clone(); | ||
spendamount = spendamount.add(amt); | ||
change = spendamount.sub(amount); | ||
change = change.gt(zero) ? change : zero.clone(); | ||
let txid:Buffer = utxos[i].getTxID(); | ||
let txidx:Buffer = utxos[i].getTxIdx(); | ||
let input:SecpInput = new SecpInput(txid, txidx, amt, assetID); | ||
let spenders:Array<string> = utxos[i].getSpenders(fromAddresses, asOf); | ||
for(let j = 0; j < spenders.length; j++){ | ||
let idx:number; | ||
idx = utxos[i].getAddressIdx(spenders[j]); | ||
if(idx == -1){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - UTXOSet.makeUnsignedTx: no such address in output: " + spenders[j]); | ||
let txid:Buffer = utxos[i].getTxID(); | ||
let txidx:Buffer = utxos[i].getTxIdx(); | ||
let input:SecpInput = new SecpInput(txid, txidx, amt, assetID); | ||
let spenders:Array<Buffer> = utxos[i].getSpenders(fromAddresses, asOf); | ||
for(let j = 0; j < spenders.length; j++){ | ||
let idx:number; | ||
idx = utxos[i].getAddressIdx(spenders[j]); | ||
if(idx == -1){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - UTXOSet.makeUnsignedTx: no such address in output: " + spenders[j]); | ||
} | ||
input.addSignatureIdx(idx, spenders[j]); | ||
} | ||
input.addSignatureIdx(idx, spenders[j]); | ||
ins.push(input); | ||
if(change.gt(zero)){ | ||
if(assetID) { | ||
outs.push(new SecpOutput(assetID, change, changeAddresses, zero.clone(), 1)); | ||
} | ||
break; | ||
} | ||
/* istanbul ignore next */ | ||
if(spendamount.gte(amount)){ | ||
break; | ||
} | ||
} else { | ||
continue; | ||
} | ||
ins.push(input); | ||
} | ||
if(change.gt(zero)){ | ||
if(assetID) { | ||
outs.push(new SecpOutput(assetID, change, changeAddresses, zero.clone(), 1)); | ||
} | ||
break; | ||
} | ||
if(spendamount.lt(amount)){ | ||
/* istanbul ignore next */ | ||
if(spendamount.gte(amount)){ | ||
break; | ||
} | ||
} else { | ||
continue; | ||
throw new Error("Error - UTXOSet.makeUnsignedTx: insufficient funds to create the transaction"); | ||
} | ||
} | ||
if(spendamount.lt(amount)){ | ||
/* istanbul ignore next */ | ||
throw new Error("Error - UTXOSet.makeUnsignedTx: insufficient funds to create the transaction"); | ||
} | ||
return new TxUnsigned(ins, outs, networkid, blockchainid); | ||
@@ -692,2 +701,32 @@ } | ||
/** | ||
* Creates an unsigned transaction. For more granular control, you may create your own | ||
* [[TxCreateAsset]] manually (with their corresponding [[Input]]s, [[Output]]s). | ||
* | ||
* @param networkid The number representing NetworkID of the node | ||
* @param blockchainid The {@link https://github.com/feross/buffer|Buffer} representing the BlockchainID for the transaction | ||
* @param fee The amount of AVA to be paid for fees, in NanoAVA | ||
* @param creatorAddresses The addresses to send the fees | ||
* @param initialState The [[InitialStates]]that represent the intial state of a created asset | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* | ||
* @returns An unsigned transaction created from the passed in parameters. | ||
* | ||
*/ | ||
makeCreateAssetTx = ( | ||
networkid:number, blockchainid:Buffer, avaAssetID:Buffer, | ||
fee:BN, creatorAddresses:Array<Buffer>, | ||
initialState:InitialStates, name:string, | ||
symbol:string, denomination:number | ||
):TxCreateAsset => { | ||
// Cheating and using makeUnsignedTx to get Ins and Outs for fees. | ||
// Fees are burned, so no toAddresses, only fromAddresses and changeAddresses, both are the creatorAddresses | ||
let utx:TxUnsigned = this.makeUnsignedTx(networkid, blockchainid, fee, [], creatorAddresses, creatorAddresses, avaAssetID); | ||
let ins:Array<Input> = utx.getIns(); | ||
let outs:Array<Output> = utx.getOuts(); | ||
return new TxCreateAsset(name, symbol, denomination, initialState, ins, outs, networkid, blockchainid, AVMConstants.CREATEASSETTX); | ||
} | ||
/** | ||
* Returns a new set with copy of UTXOs in this and set parameter. | ||
@@ -694,0 +733,0 @@ * |
@@ -19,15 +19,15 @@ /** | ||
/** | ||
* Creates a account in the node's database. | ||
* Creates a user in the node's database. | ||
* | ||
* @param accountName Name of the account to create | ||
* @param password Password for the account | ||
* @param username Name of the user to create | ||
* @param password Password for the user | ||
* | ||
* @returns Promise for a boolean with true on success | ||
*/ | ||
createAccount = async (accountName:string, password:string):Promise<boolean> => { | ||
createUser = async (username:string, password:string):Promise<boolean> => { | ||
let params = { | ||
"accountName": accountName, | ||
"username": username, | ||
"password": password | ||
}; | ||
return this.callMethod("keystore.createAccount", params).then((response:RequestResponseData) => { | ||
return this.callMethod("keystore.createUser", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["success"]; | ||
@@ -38,36 +38,16 @@ }); | ||
/** | ||
* Creates an address (and associated private keys) on an account under a subnet. | ||
* Exports a user. The user can be imported to another node with keystore.importUser . | ||
* | ||
* @param accountName Name of the account to create the address under | ||
* @param password Password to unlock the account and encrypt the private key | ||
* @param subnetAlias The subnetID or subnetAlias which the address is created under | ||
* @param username The name of the user to export | ||
* @param password The password of the user to export | ||
* | ||
* @returns Promise for a string representing the address created by the subnet. | ||
* @returns Promise with a string importable using importUser | ||
*/ | ||
createAddress = async (accountName:string, password:string, subnetAlias:string):Promise<string> => { | ||
exportUser = async (username:string, password:string):Promise<string> => { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias | ||
}; | ||
return this.callMethod("keystore.createAddress", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["address"]; | ||
}); | ||
} | ||
/** | ||
* Exports and account, returning a string with the AVA Keystore File (AKF). | ||
* | ||
* @param accountName The name of the account to export | ||
* @param password Not just anyone can export an account... you must have the password | ||
* | ||
* @returns Promise with a string representing the AVA Keystore File (AKF) | ||
*/ | ||
exportAccount = async (accountName:string, password:string):Promise<string> => { | ||
let params = { | ||
"accountName": accountName, | ||
"username": username, | ||
"password": password | ||
}; | ||
return this.callMethod("keystore.exportAccount", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["accountData"]; | ||
return this.callMethod("keystore.exportUser", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["user"]; | ||
}); | ||
@@ -77,90 +57,17 @@ } | ||
/** | ||
* Exports the private key for an address. | ||
* Imports a user file into the node's user database and assigns it to a username. | ||
* | ||
* @param accountName The name of the account with the private key | ||
* @param password The password used to decrypt the private key | ||
* @param subnetAlias The subnetID or subnetAlias that the key exists under | ||
* @param address The address whose private key should be exported | ||
* @param username The name the user file should be imported into | ||
* @param user AVA serialized string represetning a user's data | ||
* @param password The user's password | ||
* | ||
* @returns Promise with the decrypted private key as store in the database | ||
*/ | ||
exportKey = async (accountName:string, password:string, subnetAlias:string, address:string):Promise<string> => { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.exportKey", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["privateKey"]; | ||
}); | ||
} | ||
/** | ||
* Gets the balances for all assets on the provided address on the provided subnet. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias that the address exists under | ||
* @param address The address to pull the asset balances from | ||
* | ||
* @returns Promise with the key-value pair of assetID to balance. | ||
*/ | ||
getAllBalances = async (subnetAlias:string, address:string):Promise<object> => { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.getAllBalances", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["balances"]; | ||
}); | ||
} | ||
/** | ||
* Gets the balance of a particular asset on a subnet. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias that the address exists under | ||
* @param address The address to pull the asset balance from | ||
* @param assetID The assetID to pull the balance from | ||
* | ||
* @returns Promise with the balance of the assetID on the provided address for the subnet. | ||
*/ | ||
getBalance = async (subnetAlias:string, address:string, assetID:string):Promise<number> => { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address, | ||
"assetID": assetID | ||
}; | ||
return this.callMethod("keystore.getBalance", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["balance"]; | ||
}); | ||
} | ||
/** | ||
* @ignore | ||
*/ | ||
getTxHistory = async (subnetAlias:string, address:string):Promise<object> => { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.getTxHistory", params).then((response:RequestResponseData) => { | ||
return response.data["result"]; | ||
}); | ||
} | ||
/** | ||
* Imports an account file into the node's account database and assigns it to an account name. | ||
* | ||
* @param accountName The name the account file should be imported into | ||
* @param accountData The JSON in the AVA Keystore File (AKF) format | ||
* @param password The password that's used to encode the private keys in the AKF | ||
* | ||
* @returns A promise with a true-value on success. | ||
*/ | ||
importAccount = async (accountName:string, accountData:string, password:string):Promise<boolean> => { | ||
importUser = async (username:string, user:string, password:string):Promise<boolean> => { | ||
let params = { | ||
"accountName": accountName, | ||
"accountData": accountData, | ||
"usermame": username, | ||
"user": user, | ||
"password": password | ||
}; | ||
return this.callMethod("keystore.importAccount", params).then((response:RequestResponseData) => { | ||
return this.callMethod("keystore.importUser", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["success"]; | ||
@@ -171,20 +78,9 @@ }); | ||
/** | ||
* Imports a private key into the node's database under an account and for a subnet. | ||
* Lists the names of all users on the node. | ||
* | ||
* @param accountName The name of the account to store the private key | ||
* @param password The password that unlocks the account | ||
* @param subnetAlias The subnetID or subnetAlias to insert the private key | ||
* @param privateKey A string representing the private key in the subnet's format | ||
* | ||
* @returns The address for the imported private key. | ||
* @returns Promise of an array with all user names. | ||
*/ | ||
importKey = async (accountName:string, password:string, subnetAlias:string, privateKey:string):Promise<string> => { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias, | ||
"privateKey": privateKey | ||
}; | ||
return this.callMethod("keystore.importKey", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["address"]; | ||
listUsers = async ():Promise<Array<string>> => { | ||
return this.callMethod("keystore.listUsers").then((response:RequestResponseData) => { | ||
return response.data["result"]["users"]; | ||
}); | ||
@@ -194,88 +90,2 @@ } | ||
/** | ||
* Lists the names of all accounts on the node. | ||
* | ||
* @returns Promise of an array with all account names. | ||
*/ | ||
listAccounts = async ():Promise<Array<string>> => { | ||
return this.callMethod("keystore.listAccounts").then((response:RequestResponseData) => { | ||
return response.data["result"]["accounts"]; | ||
}); | ||
} | ||
/** | ||
* Lists all the addresses under a subnet on an account. | ||
* | ||
* @param accountName The account to list addresses for | ||
* @param subnetAlias The subnet to list the addreses for | ||
* | ||
* @returns Promise of an array of address strings in the format specified by the subnet. | ||
*/ | ||
listAddresses = async (accountName:string, subnetAlias:string): Promise<Array<string>> => { | ||
let params = { | ||
"accountName": accountName, | ||
"subnetAlias": subnetAlias | ||
}; | ||
return this.callMethod("keystore.listAddresses", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["addresses"]; | ||
}); | ||
} | ||
/** | ||
* Lists all assets for a subnet on an address. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias the address is on | ||
* @param address The address to get a list of assets for | ||
* | ||
* @returns Promise of an array of assetIDs for the address on the subnet. | ||
*/ | ||
listAssets = async (subnetAlias:string, address:string):Promise<Array<string>> => { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.listAssets", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["assets"]; | ||
}); | ||
} | ||
/** | ||
* A list of all subnets supported by the wallet. | ||
* | ||
* @returns An array of subnetIDs which the wallet supports. | ||
*/ | ||
listSubnets = async ():Promise<Array<string>> => { | ||
return this.callMethod("keystore.listSubnets").then((response:RequestResponseData) => { | ||
return response.data["result"]["subnetIDs"]; | ||
}); | ||
} | ||
/** | ||
* Sends an amount of assetID to the specified address from a list of owned of addresses. | ||
* | ||
* @param accountName The account that owns the private keys associated with the `from` addresses | ||
* @param password The password unlocking the account | ||
* @param subnetAlias The subnetID or subnetAlias the asset resides on | ||
* @param assetID The assetID of the asset to send | ||
* @param amount The amount of the asset to be sent | ||
* @param to The address of the recipient | ||
* @param from An array of addresses managed by the node for this subnet which will fund this transaction | ||
* | ||
* @returns Promise for the string representing the transaction's ID. | ||
*/ | ||
send = async (accountName:string, password:string, subnetAlias:string, assetID:string, amount:number, to:string, from:Array<string>):Promise<string> => { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias, | ||
"assetID": assetID, | ||
"amount": amount, | ||
"to": to, | ||
"from": from | ||
}; | ||
return this.callMethod("keystore.send", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["txID"]; | ||
}); | ||
} | ||
/** | ||
* This class should not be instantiated directly. Instead use the [[Slopes.addAPI]] method. | ||
@@ -282,0 +92,0 @@ * |
@@ -33,14 +33,20 @@ /** | ||
/** | ||
* Creates a new subnet. | ||
* Creates a new blockchain. | ||
* | ||
* @param tx The string representation of a createSubnetTx | ||
* @param vmID The VMID used to build the blockchain | ||
* @param name A human-readable name for the new blockchain | ||
* @param method The VMID's hook method for ingesting genesis data | ||
* @param genesis The object used to build the initial state of the blockchain | ||
* | ||
* @returns Promise for a boolean value, true on success. | ||
* @returns Promise for a string for the blockchainID. | ||
*/ | ||
createSubnet = async (tx:string):Promise<boolean> => { | ||
createBlockchain = async (vmID:string, name:string, method:string, genesis:object):Promise<string> => { | ||
let params = { | ||
"tx": tx | ||
"vmID": vmID, | ||
"name": name, | ||
"method": method, | ||
"genesis": genesis | ||
}; | ||
return this.callMethod("platform.createSubnet", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["success"]; | ||
return this.callMethod("platform.createBlockchain", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["blockchainID"]; | ||
}); | ||
@@ -50,2 +56,18 @@ } | ||
/** | ||
* Creates a new blockchain. | ||
* | ||
* @param blockchainID The blockchainID requesting a status update | ||
* | ||
* @returns Promise for a string of one of: "Validating", "Created", "Preferred", "Unknown". | ||
*/ | ||
getBlockchainStatus = async (blockchainID: string):Promise<string> => { | ||
let params = { | ||
"blockchainID": blockchainID | ||
}; | ||
return this.callMethod("platform.getBlockchainStatus", params).then((response:RequestResponseData) => { | ||
return response.data["result"]["status"]; | ||
}); | ||
} | ||
/** | ||
* Lists the current set of validators. | ||
@@ -70,3 +92,3 @@ * | ||
let params = { | ||
"size": sampleSize | ||
"size": sampleSize.toString() | ||
}; | ||
@@ -73,0 +95,0 @@ return this.callMethod("platform.sampleValidators", params).then((response:RequestResponseData) => { |
@@ -94,7 +94,7 @@ /** | ||
export {Tx, TxUnsigned} from './apis/avm/tx'; | ||
export {UTXO, SecpUTXO, UTXOSet} from './apis/avm/utxos'; | ||
export {SigIdx, Signature, UnixNow, Address} from './apis/avm/types'; | ||
export {SecpOutput, Output, SelectOutputClass} from './apis/avm/outputs'; | ||
export {SecpInput, Input} from './apis/avm/inputs'; | ||
export {Tx, TxUnsigned, TxCreateAsset} from './apis/avm/tx'; | ||
export {UTXO, SecpUTXO, UTXOSet, SelectUTXOClass} from './apis/avm/utxos'; | ||
export {SigIdx, Signature, UnixNow, Address, AVMConstants, InitialStates} from './apis/avm/types'; | ||
export {SecpOutput, SecpOutBase, Output, SelectOutputClass} from './apis/avm/outputs'; | ||
export {SecpInput, Input, SelectInputClass} from './apis/avm/inputs'; | ||
export {AVMKeyPair, AVMKeyChain} from './apis/avm/keychain'; | ||
@@ -101,0 +101,0 @@ |
@@ -40,2 +40,23 @@ /** | ||
/** | ||
* Produces a string from a {@link https://github.com/feross/buffer|Buffer} representing a string. | ||
* | ||
* @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a string | ||
*/ | ||
bufferToString = (buff:Buffer):string => { | ||
return this.copyFrom(buff, 2).toString("utf8"); | ||
} | ||
/** | ||
* Produces a {@link https://github.com/feross/buffer|Buffer} from a string. | ||
* | ||
* @param str The string to convert to a {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
stringToBuffer = (str:string):Buffer => { | ||
let buff:Buffer = Buffer.alloc(2 + str.length); | ||
buff.writeUInt16BE(str.length, 0); | ||
buff.write(str, 2, str.length, "utf8"); | ||
return buff; | ||
} | ||
/** | ||
* Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer} over provided indecies. | ||
@@ -174,2 +195,29 @@ * | ||
addressToString = (chainid:string, bytes:Buffer):string => { | ||
return chainid + "-" + this.avaSerialize(bytes); | ||
} | ||
stringToAddress = (address:string):Buffer => { | ||
let parts:Array<string> = address.split("-"); | ||
return this.avaDeserialize(parts[1]); | ||
} | ||
/** | ||
* Takes an address and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid. | ||
*/ | ||
parseAddress = (addr:string, blockchainID:string, alias:string = undefined, addrlen:number = 20):Buffer => { | ||
let abc:Array<string> = addr.split("-"); | ||
if(abc.length == 2){ | ||
if((alias && abc[0] == alias) || (blockchainID && abc[0] == blockchainID)) { | ||
let addrbuff = this.avaDeserialize(abc[1]); | ||
if((addrlen && addrbuff.length == addrlen) || !(addrlen)){ | ||
return addrbuff; | ||
} | ||
} | ||
} | ||
return undefined; | ||
} | ||
} | ||
@@ -176,0 +224,0 @@ |
@@ -148,2 +148,3 @@ /** | ||
protected privk:Buffer; | ||
protected chainid:string = ""; | ||
@@ -230,7 +231,34 @@ /** | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representation of the address | ||
*/ | ||
getAddress:() => Buffer; | ||
/** | ||
* Returns the address's string representation. | ||
* | ||
* @returns A string representation of the address | ||
*/ | ||
getAddress:() => string; | ||
getAddressString:() => string; | ||
constructor() {} | ||
/** | ||
* Returns the chainID associated with this key. | ||
* | ||
* @returns The [[KeyPair]]'s chainID | ||
*/ | ||
getChainID = ():string => { | ||
return this.chainid | ||
} | ||
/** | ||
* Sets the the chainID associated with this key. | ||
* | ||
* @param chainid String for the chainID | ||
*/ | ||
setChainID = (chainid:string):void => { | ||
this.chainid = chainid; | ||
} | ||
constructor(chainid:string) { | ||
this.chainid = chainid | ||
} | ||
} | ||
@@ -242,56 +270,67 @@ | ||
* | ||
* @typeparam KPClass Class extending [[KeyPair]] which is used as the key in [[KeyChain]] | ||
* @typeparam KPClass extending [[KeyPair]] which is used as the key in [[KeyChain]] | ||
*/ | ||
export class KeyChain<KPClass extends KeyPair> { | ||
protected keys:{[address: string]: KPClass} = {}; | ||
protected chainid:string = ""; | ||
/** | ||
* Makes a new key pair, returns the address. | ||
* Makes a new [[KeyPair]], returns the address. | ||
* | ||
* @param entropy Optional parameter that may be necessary to produce secure keys | ||
* | ||
* @returns Address of the new key pair | ||
* @returns Address of the new [[KeyPair]] | ||
*/ | ||
makeKey:(entropy?:Buffer) => string; | ||
makeKey:(entropy?:Buffer) => Buffer; | ||
/** | ||
* Given a private key, makes a new key pair, returns the address. | ||
* Given a private key, makes a new [[KeyPair]], returns the address. | ||
* | ||
* @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key | ||
* | ||
* @returns Address of the new key pair | ||
* @returns Address of the new [[KeyPair]] | ||
*/ | ||
importKey:(privk:Buffer) => string; | ||
importKey:(privk:Buffer) => Buffer; | ||
/** | ||
* Gets an array of addresses stored in the key chain. | ||
* Gets an array of addresses stored in the [[KeyChain]]. | ||
* | ||
* @returns An array of {@link https://github.com/feross/buffer|Buffer} representations of the addresses | ||
*/ | ||
getAddresses = ():Array<Buffer> => { | ||
return Object.values(this.keys).map(kp => kp.getAddress()); | ||
} | ||
/** | ||
* Gets an array of addresses stored in the [[KeyChain]]. | ||
* | ||
* @returns An array of string representations of the addresses | ||
*/ | ||
getAddresses = ():Array<string> => { | ||
return Object.keys(this.keys); | ||
getAddressStrings = ():Array<string> => { | ||
return Object.values(this.keys).map(kp => kp.getAddressString()); | ||
} | ||
/** | ||
* Adds the key pair to the list of the keys managed in the keychain. | ||
* Adds the key pair to the list of the keys managed in the [[KeyChain]]. | ||
* | ||
* @param newKey A key pair of the appropriate class to be added to the keychain | ||
* @param newKey A key pair of the appropriate class to be added to the [[KeyChain]] | ||
*/ | ||
addKey = (newKey:KPClass) => { | ||
this.keys[newKey.getAddress()] = newKey; | ||
newKey.setChainID(this.chainid); | ||
this.keys[newKey.getAddress().toString("hex")] = newKey; | ||
} | ||
/** | ||
* Removes the key pair from the list of they keys managed in the keychain. | ||
* Removes the key pair from the list of they keys managed in the [[KeyChain]]. | ||
* | ||
* @param key A string for the address or KPClass to remove | ||
* @param key A {@link https://github.com/feross/buffer|Buffer} for the address or KPClass to remove | ||
* | ||
* @returns The boolean true if a key was removed. | ||
*/ | ||
removeKey = (key:KPClass | string) => { | ||
removeKey = (key:KPClass | Buffer) => { | ||
let kaddr:string; | ||
if(typeof key !== "string"){ | ||
kaddr = key.getAddress(); | ||
if(key instanceof Buffer){ | ||
kaddr = key.toString("hex"); | ||
} else { | ||
kaddr = key; | ||
kaddr = key.getAddress().toString("hex"); | ||
} | ||
@@ -313,20 +352,44 @@ if(kaddr in this.keys){ | ||
*/ | ||
hasKey = (address:string):boolean => { | ||
return (address in this.keys); | ||
hasKey = (address:Buffer):boolean => { | ||
return (address.toString("hex") in this.keys); | ||
} | ||
/** | ||
* Returns the key pair listed under the provided address | ||
* Returns the [[KeyPair]] listed under the provided address | ||
* | ||
* @param address The address to retrieve from the keys database | ||
* @param address The {@link https://github.com/feross/buffer|Buffer} of the address to retrieve from the keys database | ||
* | ||
* @returns A reference to the key pair in the keys database | ||
* @returns A reference to the [[KeyPair]] in the keys database | ||
*/ | ||
getKey = (address:string): KPClass => { | ||
return this.keys[address]; | ||
getKey = (address:Buffer): KPClass => { | ||
return this.keys[address.toString("hex")]; | ||
} | ||
/** | ||
* Returns instance of KeyChain. | ||
* Returns the chainID associated with this [[KeyChain]]. | ||
* | ||
* @returns The [[KeyChain]]'s chainID | ||
*/ | ||
constructor() {} | ||
getChainID = ():string => { | ||
return this.chainid | ||
} | ||
/** | ||
* Sets the the chainID associated with this [[KeyChain]] and all associated keypairs. | ||
* | ||
* @param chainid String for the chainID | ||
*/ | ||
setChainID = (chainid:string):void => { | ||
this.chainid = chainid; | ||
for(let address in this.keys){ | ||
this.keys[address].setChainID(chainid); | ||
} | ||
} | ||
/** | ||
* Returns instance of [[KeyChain]]. | ||
*/ | ||
constructor(chainid:string) { | ||
this.chainid = chainid; | ||
} | ||
} | ||
@@ -357,3 +420,3 @@ | ||
*/ | ||
fromString = (b58str:string):number => { | ||
fromString(b58str:string):number { | ||
try { | ||
@@ -375,3 +438,3 @@ this.fromBuffer(bintools.b58ToBuffer(b58str)); | ||
*/ | ||
fromBuffer = (buff:Buffer):number => { | ||
fromBuffer(buff:Buffer):number { | ||
try { | ||
@@ -397,3 +460,3 @@ if(buff.length != this.bsize){ | ||
*/ | ||
toBuffer = ():Buffer => { | ||
toBuffer():Buffer { | ||
return this.bytes; | ||
@@ -407,3 +470,3 @@ } | ||
*/ | ||
toString = ():string => { | ||
toString():string { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
@@ -416,1 +479,58 @@ } | ||
} | ||
let n2_avm:object = { | ||
blockchainID: "HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7", | ||
alias: "X", | ||
vm: "avm" | ||
}; | ||
let n2_platform:object = { | ||
blockchainID: "", | ||
alias: "P", | ||
vm: "platform" | ||
}; | ||
let n2_contracts:object = { | ||
blockchainID: "", | ||
alias: "C", | ||
vm: "contracts" | ||
} | ||
export class Defaults { | ||
static network = { | ||
1: {}, //update before mainnet | ||
2: { | ||
"avm": n2_avm, | ||
"X": n2_avm, | ||
"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7": n2_avm, | ||
"platform": n2_platform, | ||
"P": n2_platform, | ||
"BCID1": n2_platform, | ||
"contracts": n2_contracts, | ||
"C": n2_contracts, | ||
"BCID2": n2_contracts | ||
}, | ||
49: { | ||
"avm": n2_avm, | ||
"X": n2_avm, | ||
"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7": n2_avm, | ||
"platform": n2_platform, | ||
"P": n2_platform, | ||
"BCID1": n2_platform, | ||
"contracts": n2_contracts, | ||
"C": n2_contracts, | ||
"BCID2": n2_contracts | ||
}, | ||
12345: { | ||
"avm": n2_avm, | ||
"X": n2_avm, | ||
"GJABrZ9A6UQFpwjPU8MDxDd8vuyRoDVeDAXc694wJ5t3zEkhU": n2_avm, | ||
"platform": n2_platform, | ||
"P": n2_platform, | ||
"BCID1": n2_platform, | ||
"contracts": n2_contracts, | ||
"C": n2_contracts, | ||
"BCID2": n2_contracts | ||
} | ||
}; | ||
} |
@@ -9,7 +9,8 @@ import mockAxios from 'jest-mock-axios'; | ||
import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos'; | ||
import { Output, SecpOutput } from 'src/apis/avm/outputs'; | ||
import { Output, SecpOutput, SecpOutBase } from 'src/apis/avm/outputs'; | ||
import { Input, SecpInput } from 'src/apis/avm/inputs'; | ||
import createHash from "create-hash"; | ||
import { TxUnsigned, Tx } from 'src/apis/avm/tx'; | ||
import { UnixNow } from 'src/apis/avm/types'; | ||
import { TxUnsigned, TxCreateAsset, Tx } from 'src/apis/avm/tx'; | ||
import { UnixNow, AVMConstants } from 'src/apis/avm/types'; | ||
import { InitialStates } from '../../../src/apis/avm/types'; | ||
@@ -23,3 +24,3 @@ /** | ||
const networkid:number = 49; | ||
const blockchainid:string = "6h2s5de1VC65meajE1L2PjvZ1MXvHc3F6eqPCGKuDt4MxiweF"; | ||
const blockchainid:string = "HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7"; | ||
const ip:string = '127.0.0.1'; | ||
@@ -34,5 +35,11 @@ const port:number = 9650; | ||
let api:AVMAPI; | ||
let alias:string; | ||
const addrA:string = "X-B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW"; | ||
const addrB:string = "X-P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF"; | ||
const addrC:string = "X-6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV"; | ||
beforeAll(() => { | ||
api = new AVMAPI(slopes, "/ext/subnet/avm", blockchainid); | ||
api = new AVMAPI(slopes, "/ext/bc/avm", blockchainid); | ||
alias = api.getBlockchainAlias(); | ||
}); | ||
@@ -44,11 +51,181 @@ | ||
test('createAsset', async ()=>{ | ||
let kp:AVMKeyPair = new AVMKeyPair(); | ||
test('can Send 1', async ()=>{ | ||
let txId = 'asdfhvl234'; | ||
let result:Promise<string> = api.send(username, password, 'assetId', 10, addrA, [addrB]); | ||
let payload:object = { | ||
"result": { | ||
'txID': txId | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(txId); | ||
}); | ||
test('can Send 2', async ()=>{ | ||
let txId = 'asdfhvl234'; | ||
let result:Promise<string> = api.send(username, password, bintools.b58ToBuffer("6h2s5de1VC65meajE1L2PjvZ1MXvHc3F6eqPCGKuDt4MxiweF"), new BN(10), addrA, [addrB]); | ||
let payload:object = { | ||
"result": { | ||
'txID': txId | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(txId); | ||
}); | ||
test('listAssets', async ()=>{ | ||
let assets = ['ATH','ETH']; | ||
let result:Promise<Array<string>> = api.listAssets(addrA); | ||
let payload:object = { | ||
"result": { | ||
'assets': assets | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:Array<string> = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(assets); | ||
}); | ||
test('listAddresses', async ()=>{ | ||
let addresses = [addrA,addrB]; | ||
let result:Promise<Array<string>> = api.listAddresses(username, password); | ||
let payload:object = { | ||
"result": { | ||
'addresses': addresses | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:Array<string> = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(addresses); | ||
}); | ||
test('importKey', async ()=>{ | ||
let address = addrC; | ||
let result:Promise<string> = api.importKey(username, password, 'key'); | ||
let payload:object = { | ||
"result": { | ||
'address': address | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(address); | ||
}); | ||
test('getBalance', async ()=>{ | ||
let balance = 100; | ||
let result:Promise<number> = api.getBalance(addrA, 'ATH'); | ||
let payload:object = { | ||
"result": { | ||
"balance": balance | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:number = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(balance); | ||
}); | ||
test('exportKey', async ()=>{ | ||
let key = 'sdfglvlj2h3v45'; | ||
let result:Promise<string> = api.exportKey(username, password, addrA); | ||
let payload:object = { | ||
"result": { | ||
"privateKey": key | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(key); | ||
}); | ||
test('createAddress', async ()=>{ | ||
let alias = 'randomalias'; | ||
let result:Promise<string> = api.createAddress(username, password); | ||
let payload:object = { | ||
"result": { | ||
"address": alias | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(alias); | ||
}); | ||
test('createFixedCapAsset', async ()=>{ | ||
let kp:AVMKeyPair = new AVMKeyPair(alias); | ||
kp.importKey(Buffer.from("ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676", "hex")); | ||
let amount:number = 10000; | ||
let address:string = kp.getAddress(); | ||
let address:Buffer = kp.getAddress(); | ||
let assetid:string = "8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533"; | ||
let initialHolders:Array<object> = [ | ||
{ | ||
"address": "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh", | ||
"amount": "10000" | ||
}, | ||
{ | ||
"address": "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh", | ||
"amount": "50000" | ||
} | ||
] | ||
let result:Promise<string> = api.createAsset(amount,address); | ||
let result:Promise<string> = api.createFixedCapAsset(username, password, "Some Coin", "SCC", initialHolders); | ||
let payload:object = { | ||
@@ -70,2 +247,43 @@ "result": { | ||
test('createVariableCapAsset', async ()=>{ | ||
let kp:AVMKeyPair = new AVMKeyPair(alias); | ||
kp.importKey(Buffer.from("ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676", "hex")); | ||
let amount:number = 10000; | ||
let address:Buffer = kp.getAddress(); | ||
let assetid:string = "8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533"; | ||
let minterSets:Array<object> = [ | ||
{ | ||
"minters":[ | ||
"4peJsFvhdn7XjhNF4HWAQy6YaJts27s9q" | ||
], | ||
"threshold": 1 | ||
}, | ||
{ | ||
"minters": [ | ||
"dcJ6z9duLfyQTgbjq2wBCowkvcPZHVDF", | ||
"2fE6iibqfERz5wenXE6qyvinsxDvFhHZk", | ||
"7ieAJbfrGQbpNZRAQEpZCC1Gs1z5gz4HU" | ||
], | ||
"threshold": 2 | ||
} | ||
] | ||
let result:Promise<string> = api.createVariableCapAsset(username, password, "Some Coin", "SCC", minterSets); | ||
let payload:object = { | ||
"result": { | ||
'assetID': assetid | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(assetid); | ||
}); | ||
test('getTxStatus', async ()=>{ | ||
@@ -93,9 +311,12 @@ let txid:string = "f966750f438867c3c9828ddcdbe660e21ccdbb36a9276958f011ba472f75d4e7"; | ||
test('getAssetDescription as string', async ()=>{ | ||
let assetid:string = "8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533"; | ||
let assetid:Buffer = Buffer.from("8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533", 'hex'); | ||
let assetidstr:string = bintools.avaSerialize(assetid); | ||
let result:Promise<object> = api.getAssetDescription(assetid); | ||
let result:Promise<object> = api.getAssetDescription(assetidstr); | ||
let payload:object = { | ||
"result": { | ||
'name': "Collin Coin", | ||
'symbol': 'CKC' | ||
'symbol': 'CKC', | ||
'assetID': assetidstr, | ||
'denomination': '10' | ||
} | ||
@@ -113,6 +334,9 @@ }; | ||
expect(response["symbol"]).toBe("CKC"); | ||
expect(response["assetID"].toString("hex")).toBe(assetid.toString("hex")); | ||
expect(response["denomination"]).toBe(10); | ||
}); | ||
test('getAssetDescription as Buffer', async ()=>{ | ||
let assetid:Buffer = Buffer.from("8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533"); | ||
let assetid:Buffer = Buffer.from("8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533", 'hex'); | ||
let assetidstr:string = bintools.avaSerialize(Buffer.from('8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533', 'hex')); | ||
@@ -123,3 +347,5 @@ let result:Promise<object> = api.getAssetDescription(assetid); | ||
'name': "Collin Coin", | ||
'symbol': 'CKC' | ||
'symbol': 'CKC', | ||
'assetID': assetidstr, | ||
'denomination': '11' | ||
} | ||
@@ -137,2 +363,4 @@ }; | ||
expect(response["symbol"]).toBe("CKC"); | ||
expect(response["assetID"].toString("hex")).toBe(assetid.toString("hex")); | ||
expect(response["denomination"]).toBe(11); | ||
}); | ||
@@ -152,4 +380,4 @@ | ||
expect(persistOpts.getMergeRule()).toBe("union"); | ||
let result:Promise<UTXOSet> = api.getUTXOs(set.getAddresses(), persistOpts); | ||
let addresses:Array<string> = set.getAddresses().map(a => api.addressFromBuffer(a)); | ||
let result:Promise<UTXOSet> = api.getUTXOs(addresses, persistOpts); | ||
let payload:object = { | ||
@@ -170,3 +398,4 @@ "result": { | ||
result = api.getUTXOs(set.getAddresses(), persistOpts); | ||
addresses = set.getAddresses().map(a => api.addressFromBuffer(a)); | ||
result = api.getUTXOs(addresses, persistOpts); | ||
@@ -193,2 +422,7 @@ | ||
let assetID:Buffer = Buffer.from(createHash("sha256").update("mary had a little lamb").digest()); | ||
let secpbase1:SecpOutBase; | ||
let secpbase2:SecpOutBase; | ||
let secpbase3:SecpOutBase; | ||
let initialState:InitialStates; | ||
@@ -198,4 +432,4 @@ beforeEach(() => { | ||
api.newKeyChain() | ||
keymgr2 = new AVMKeyChain(); | ||
keymgr3 = new AVMKeyChain(); | ||
keymgr2 = new AVMKeyChain(alias); | ||
keymgr3 = new AVMKeyChain(alias); | ||
addrs1 = []; | ||
@@ -208,12 +442,11 @@ addrs2 = []; | ||
for(let i:number = 0; i < 3; i++){ | ||
addrs1.push(api.keyChain().makeKey()); | ||
addrs2.push(keymgr2.makeKey()); | ||
addrs3.push(keymgr3.makeKey()); | ||
addrs1.push(api.addressFromBuffer(api.keyChain().makeKey())); | ||
addrs2.push(api.addressFromBuffer(keymgr2.makeKey())); | ||
addrs3.push(api.addressFromBuffer(keymgr3.makeKey())); | ||
} | ||
let amount:BN = new BN(amnt); | ||
let addresses:Array<string> = api.keyChain().getAddresses(); | ||
let fallAddresses:Array<string> = keymgr2.getAddresses() | ||
let addressbuffs:Array<Buffer> = api.keyChain().getAddresses(); | ||
let addresses:Array<string> = addressbuffs.map(a => api.addressFromBuffer(a)); | ||
let fallAddresses:Array<string> = keymgr2.getAddresses().map(a => api.addressFromBuffer(a)); | ||
let locktime:BN = new BN(54321); | ||
@@ -228,3 +461,3 @@ let fallLocktime:BN = locktime.add(new BN(50)); | ||
let out:SecpOutput; | ||
out = new SecpOutput(assetID, amount, addresses, locktime, threshold); | ||
out = new SecpOutput(assetID, amount, addressbuffs, locktime, threshold); | ||
outputs.push(out); | ||
@@ -244,11 +477,21 @@ | ||
set.addArray(utxos); | ||
secpbase1 = new SecpOutBase(new BN(777), addrs3.map(a => api.parseAddress(a))); | ||
secpbase2 = new SecpOutBase(new BN(888), addrs2.map(a => api.parseAddress(a))); | ||
secpbase3 = new SecpOutBase(new BN(999), addrs2.map(a => api.parseAddress(a))); | ||
initialState = new InitialStates(); | ||
initialState.addOutput(secpbase1, AVMConstants.SECPFXID); | ||
initialState.addOutput(secpbase2, AVMConstants.SECPFXID); | ||
initialState.addOutput(secpbase3, AVMConstants.SECPFXID); | ||
}); | ||
test('makeUnsignedTx1', () => { | ||
test('makeUnsignedTx1', async () => { | ||
let txu1:TxUnsigned = api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let txu1:TxUnsigned = await api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let txu2:TxUnsigned = set.makeUnsignedTx( | ||
networkid, bintools.avaDeserialize(blockchainid), new BN(amnt), | ||
addrs3, addrs1, addrs1, assetID, | ||
UnixNow(), new BN(0), 1 | ||
addrs3.map(a => api.parseAddress(a)), | ||
addrs1.map(a => api.parseAddress(a)), | ||
addrs1.map(a => api.parseAddress(a)), | ||
assetID, UnixNow(), new BN(0), 1 | ||
); | ||
@@ -261,8 +504,10 @@ | ||
test('makeUnsignedTx2', () => { | ||
let txu1:TxUnsigned = api.makeUnsignedTx(set, new BN(amnt).sub(new BN(100)), addrs3, addrs1, addrs2, bintools.avaSerialize(assetID)); | ||
test('makeUnsignedTx2', async () => { | ||
let txu1:TxUnsigned = await api.makeUnsignedTx(set, new BN(amnt).sub(new BN(100)), addrs3, addrs1, addrs2, bintools.avaSerialize(assetID)); | ||
let txu2:TxUnsigned = set.makeUnsignedTx( | ||
networkid, bintools.avaDeserialize(blockchainid), new BN(amnt).sub(new BN(100)), | ||
addrs3, addrs1, addrs2, assetID, | ||
UnixNow(), new BN(0), 1 | ||
addrs3.map(a => api.parseAddress(a)), | ||
addrs1.map(a => api.parseAddress(a)), | ||
addrs2.map(a => api.parseAddress(a)), | ||
assetID, UnixNow(), new BN(0), 1 | ||
); | ||
@@ -276,4 +521,4 @@ | ||
expect(outies.length).toBe(2); | ||
let outaddr0 = Object.keys(outies[0].getAddresses()); | ||
let outaddr1 = Object.keys(outies[1].getAddresses()); | ||
let outaddr0 = outies[0].getAddresses().map(a => api.addressFromBuffer(a)); | ||
let outaddr1 = outies[1].getAddresses().map(a => api.addressFromBuffer(a)); | ||
@@ -291,8 +536,10 @@ let testaddr2 = JSON.stringify(addrs2.sort()); | ||
test('signTx', () => { | ||
let txu1:TxUnsigned = api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
test('signTx', async () => { | ||
let txu1:TxUnsigned = await api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let txu2:TxUnsigned = set.makeUnsignedTx( | ||
networkid, bintools.avaDeserialize(blockchainid), new BN(amnt), | ||
addrs3, addrs1, addrs1, assetID, UnixNow(), | ||
new BN(0), 1 | ||
addrs3.map(a => api.parseAddress(a)), | ||
addrs1.map(a => api.parseAddress(a)), | ||
addrs1.map(a => api.parseAddress(a)), | ||
assetID, UnixNow(), new BN(0), 1 | ||
); | ||
@@ -309,3 +556,3 @@ | ||
test('issueTx Serialized', async ()=>{ | ||
let txu:TxUnsigned = api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let txu:TxUnsigned = await api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let tx = api.signTx(txu); | ||
@@ -333,3 +580,3 @@ | ||
test('issueTx Buffer', async ()=>{ | ||
let txu:TxUnsigned = api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let txu:TxUnsigned = await api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let tx = api.signTx(txu); | ||
@@ -357,3 +604,3 @@ | ||
test('issueTx Class Tx', async ()=>{ | ||
let txu:TxUnsigned = api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let txu:TxUnsigned = await api.makeUnsignedTx(set, new BN(amnt), addrs3, addrs1, addrs1, bintools.avaSerialize(assetID)); | ||
let tx = api.signTx(txu); | ||
@@ -380,2 +627,34 @@ | ||
test('makeCreateAssetTx', async () => { | ||
let fee:number = 10; | ||
let name:string = "Mortycoin is the dumb as a sack of hammers."; | ||
let symbol:string = "morT"; | ||
let denomination:number = 8; | ||
let result:Promise<TxCreateAsset> = api.makeCreateAssetTx(set, new BN(fee), addrs1, initialState, name, symbol, denomination); | ||
let payload:object = { | ||
"result": { | ||
'name': name, | ||
'symbol': symbol, | ||
'assetID': bintools.avaSerialize(assetID), | ||
'denomination': "" + denomination | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let txu1:TxCreateAsset = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
let txu2:TxCreateAsset = set.makeCreateAssetTx(slopes.getNetworkID(), bintools.avaDeserialize(api.getBlockchainID()), assetID, new BN(fee), addrs1.map(a => api.parseAddress(a)), initialState, name, symbol, denomination); | ||
expect(txu2.toBuffer().toString("hex")).toBe(txu1.toBuffer().toString("hex")); | ||
expect(txu2.toString()).toBe(txu1.toString()); | ||
}); | ||
}); | ||
@@ -382,0 +661,0 @@ |
@@ -9,3 +9,3 @@ import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos'; | ||
import { Output, SecpOutput } from 'src/apis/avm/outputs'; | ||
import { Constants } from 'src/apis/avm/types'; | ||
import { AVMConstants } from 'src/apis/avm/types'; | ||
@@ -21,4 +21,4 @@ | ||
let keymgr2:AVMKeyChain; | ||
let addrs1:Array<string>; | ||
let addrs2:Array<string>; | ||
let addrs1:Array<Buffer>; | ||
let addrs2:Array<Buffer>; | ||
let utxos:Array<SecpUTXO>; | ||
@@ -28,4 +28,4 @@ const amnt:number = 10000; | ||
set = new UTXOSet(); | ||
keymgr1 = new AVMKeyChain(); | ||
keymgr2 = new AVMKeyChain(); | ||
keymgr1 = new AVMKeyChain("X"); | ||
keymgr2 = new AVMKeyChain("X"); | ||
addrs1 = []; | ||
@@ -39,4 +39,4 @@ addrs2 = []; | ||
let amount:BN = new BN(amnt); | ||
let addresses:Array<string> = keymgr1.getAddresses(); | ||
let fallAddresses:Array<string> = keymgr2.getAddresses() | ||
let addresses:Array<Buffer> = keymgr1.getAddresses(); | ||
let fallAddresses:Array<Buffer> = keymgr2.getAddresses() | ||
let locktime:BN = new BN(54321); | ||
@@ -73,3 +73,3 @@ let fallLocktime:BN = locktime.add(new BN(50)); | ||
expect(input.getUTXOID()).toBe(u.getUTXOID()); | ||
expect(input.getInputID()).toBe(Constants.SECPINPUTID); | ||
expect(input.getInputID()).toBe(AVMConstants.SECPINPUTID); | ||
@@ -76,0 +76,0 @@ input.addSignatureIdx(0, addrs2[0]); |
@@ -7,6 +7,6 @@ import { AVMKeyChain, AVMKeyPair } from 'src/apis/avm/keychain'; | ||
const bintools = BinTools.getInstance(); | ||
const alias = "X"; | ||
describe('AVMKeyPair', () => { | ||
test('repeatable 1', () => { | ||
let kp:AVMKeyPair = new AVMKeyPair(); | ||
let kp:AVMKeyPair = new AVMKeyPair(alias); | ||
kp.importKey(Buffer.from("ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676", "hex")); | ||
@@ -25,3 +25,3 @@ expect(kp.getPublicKey().toString("hex")).toBe("033fad3644deb20d7a210d12757092312451c112d04773cee2699fbb59dc8bb2ef"); | ||
test('repeatable 2', () => { | ||
let kp:AVMKeyPair = new AVMKeyPair(); | ||
let kp:AVMKeyPair = new AVMKeyPair(alias); | ||
kp.importKey(Buffer.from("17c692d4a99d12f629d9f0ff92ec0dba15c9a83e85487b085c1a3018286995c6", "hex")); | ||
@@ -40,3 +40,3 @@ expect(kp.getPublicKey().toString("hex")).toBe("02486553b276cfe7abf0efbcd8d173e55db9c03da020c33d0b219df24124da18ee"); | ||
test('repeatable 3', () => { | ||
let kp:AVMKeyPair = new AVMKeyPair(); | ||
let kp:AVMKeyPair = new AVMKeyPair(alias); | ||
kp.importKey(Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex")); | ||
@@ -55,3 +55,3 @@ expect(kp.getPublicKey().toString("hex")).toBe("031475b91d4fcf52979f1cf107f058088cc2bea6edd51915790f27185a7586e2f2"); | ||
test('Creation Empty', () => { | ||
let kp:AVMKeyPair = new AVMKeyPair(); | ||
let kp:AVMKeyPair = new AVMKeyPair(alias); | ||
expect(kp.getPrivateKey()).not.toBeUndefined(); | ||
@@ -75,9 +75,9 @@ expect(kp.getAddress()).not.toBeUndefined(); | ||
let keybuff:Buffer = Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc:AVMKeyChain = new AVMKeyChain(); | ||
let kp2:AVMKeyPair = new AVMKeyPair(); | ||
let addr1:string = kc.importKey(keybuff); | ||
let kc:AVMKeyChain = new AVMKeyChain(alias); | ||
let kp2:AVMKeyPair = new AVMKeyPair(alias); | ||
let addr1:Buffer = kc.importKey(keybuff); | ||
let kp1:AVMKeyPair = kc.getKey(addr1); | ||
kp2.importKey(keybuff); | ||
let addr2 = kp1.getAddress(); | ||
expect(addr1).toBe(addr2); | ||
expect(addr1.toString("hex")).toBe(addr2.toString("hex")); | ||
expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString()); | ||
@@ -90,9 +90,9 @@ expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString()); | ||
let keybuff:Buffer = Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc:AVMKeyChain = new AVMKeyChain(); | ||
let kp2:AVMKeyPair = new AVMKeyPair(); | ||
let addr1:string = kc.importKey(bintools.avaSerialize(keybuff)); | ||
let kc:AVMKeyChain = new AVMKeyChain(alias); | ||
let kp2:AVMKeyPair = new AVMKeyPair(alias); | ||
let addr1:Buffer = kc.importKey(bintools.avaSerialize(keybuff)); | ||
let kp1:AVMKeyPair = kc.getKey(addr1); | ||
kp2.importKey(keybuff); | ||
let addr2 = kp1.getAddress(); | ||
expect(addr1).toBe(addr2); | ||
expect(addr1.toString("hex")).toBe(addr2.toString("hex")); | ||
expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString()); | ||
@@ -105,5 +105,5 @@ expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString()); | ||
let keybuff:Buffer = Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc:AVMKeyChain = new AVMKeyChain(); | ||
let kp1:AVMKeyPair = new AVMKeyPair(); | ||
let addr1:string = kc.importKey(keybuff); | ||
let kc:AVMKeyChain = new AVMKeyChain(alias); | ||
let kp1:AVMKeyPair = new AVMKeyPair(alias); | ||
let addr1:Buffer = kc.importKey(keybuff); | ||
kp1.importKey(keybuff); | ||
@@ -117,4 +117,4 @@ expect(kc.hasKey(addr1)).toBe(true); | ||
let keybuff:Buffer = Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc:AVMKeyChain = new AVMKeyChain(); | ||
let addr1:string = kc.importKey(keybuff); | ||
let kc:AVMKeyChain = new AVMKeyChain(alias); | ||
let addr1:Buffer = kc.importKey(keybuff); | ||
expect(kc.hasKey(addr1)).toBe(true); | ||
@@ -127,7 +127,7 @@ kc.removeKey(addr1); | ||
let keybuff:Buffer = Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc:AVMKeyChain = new AVMKeyChain(); | ||
let addr1:string = kc.importKey(keybuff); | ||
let kc:AVMKeyChain = new AVMKeyChain(alias); | ||
let addr1:Buffer = kc.importKey(keybuff); | ||
expect(kc.hasKey(addr1)).toBe(true); | ||
expect(kc.removeKey("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV")).toBe(false); | ||
expect(kc.removeKey(bintools.avaDeserialize("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV"))).toBe(false); | ||
}); | ||
}); |
@@ -5,3 +5,2 @@ import BN from "bn.js"; | ||
import { Output, SecpOutput, SelectOutputClass } from 'src/apis/avm/outputs'; | ||
import { Constants } from '../../../src/apis/avm/types'; | ||
@@ -13,6 +12,6 @@ const bintools = BinTools.getInstance(); | ||
let assetIDBuff:Buffer = Buffer.from(assetID, "hex"); | ||
let addrs:Array<string> = [ | ||
"B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW", | ||
"P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF", | ||
"6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV" | ||
let addrs:Array<Buffer> = [ | ||
bintools.avaDeserialize("B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW"), | ||
bintools.avaDeserialize("P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF"), | ||
bintools.avaDeserialize("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV") | ||
].sort(); | ||
@@ -50,6 +49,3 @@ | ||
expect(out.getOutputID()).toBe(4); | ||
expect(JSON.stringify(Object.keys(out.getAddresses()).sort())).toBe(JSON.stringify(addrs.sort())); | ||
expect(out.getAddresses()[addrs[0]].toNumber()).toBe(locktime.toNumber()); | ||
expect(out.getAddresses()[addrs[1]].toNumber()).toBe(locktime.toNumber()); | ||
expect(out.getAddresses()[addrs[2]].toNumber()).toBe(locktime.toNumber()); | ||
expect(JSON.stringify(out.getAddresses().sort())).toStrictEqual(JSON.stringify(addrs.sort())); | ||
@@ -62,3 +58,3 @@ expect(out.getThreshold()).toBe(3); | ||
let r = out.getAddressIdx(addrs[2]); | ||
expect(out.getAddress(r)).toBe(addrs[2]); | ||
expect(out.getAddress(r)).toStrictEqual(addrs[2]); | ||
expect(() => { | ||
@@ -73,3 +69,3 @@ out.getAddress(400) | ||
let s:Array<string> = out.getSpenders(addrs); | ||
let s:Array<Buffer> = out.getSpenders(addrs); | ||
expect(JSON.stringify(s.sort())).toBe(JSON.stringify(addrs.sort())); | ||
@@ -76,0 +72,0 @@ |
import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos'; | ||
import { TxUnsigned, Tx } from 'src/apis/avm/tx'; | ||
import { TxUnsigned, TxCreateAsset, Tx } from 'src/apis/avm/tx'; | ||
import { AVMKeyChain } from 'src/apis/avm/keychain'; | ||
@@ -9,5 +9,5 @@ import { Input, SecpInput } from 'src/apis/avm/inputs'; | ||
import {Buffer} from "buffer/"; | ||
import { Output, SecpOutput } from 'src/apis/avm/outputs'; | ||
import { UnixNow } from 'src/apis/avm/types'; | ||
import { Output, SecpOutput, SecpOutBase } from 'src/apis/avm/outputs'; | ||
import { UnixNow, AVMConstants} from 'src/apis/avm/types'; | ||
import { InitialStates } from '../../../src/apis/avm/types'; | ||
/** | ||
@@ -22,5 +22,5 @@ * @ignore | ||
let keymgr3:AVMKeyChain; | ||
let addrs1:Array<string>; | ||
let addrs2:Array<string>; | ||
let addrs3:Array<string>; | ||
let addrs1:Array<Buffer>; | ||
let addrs2:Array<Buffer>; | ||
let addrs3:Array<Buffer>; | ||
let utxos:Array<SecpUTXO>; | ||
@@ -32,8 +32,9 @@ let inputs:Array<SecpInput>; | ||
let blockchainID:Buffer = Buffer.from(createHash("sha256").update("I am the very model of a modern major general").digest()); | ||
let alias:string = "X"; | ||
let assetID:Buffer = Buffer.from(createHash("sha256").update("mary had a little lamb").digest()); | ||
beforeEach(() => { | ||
set = new UTXOSet(); | ||
keymgr1 = new AVMKeyChain(); | ||
keymgr2 = new AVMKeyChain(); | ||
keymgr3 = new AVMKeyChain(); | ||
keymgr1 = new AVMKeyChain(alias); | ||
keymgr2 = new AVMKeyChain(alias); | ||
keymgr3 = new AVMKeyChain(alias); | ||
addrs1 = []; | ||
@@ -52,4 +53,4 @@ addrs2 = []; | ||
let amount:BN = new BN(amnt); | ||
let addresses:Array<string> = keymgr1.getAddresses(); | ||
let fallAddresses:Array<string> = keymgr2.getAddresses() | ||
let addresses:Array<Buffer> = keymgr1.getAddresses(); | ||
let fallAddresses:Array<Buffer> = keymgr2.getAddresses(); | ||
let locktime:BN = new BN(54321); | ||
@@ -59,3 +60,2 @@ let fallLocktime:BN = locktime.add(new BN(50)); | ||
let fallThreshold:number = 1; | ||
for(let i:number = 0; i < 5; i++){ | ||
@@ -152,3 +152,55 @@ let txid:Buffer = Buffer.from(createHash("sha256").update(bintools.fromBNToBuffer(new BN(i), 32)).digest()); | ||
}); | ||
test('Asset Creation Tx', () => { | ||
let secpbase1:SecpOutBase = new SecpOutBase(new BN(777), addrs3); | ||
let secpbase2:SecpOutBase = new SecpOutBase(new BN(888), addrs2); | ||
let secpbase3:SecpOutBase = new SecpOutBase(new BN(999), addrs2); | ||
let initialState:InitialStates = new InitialStates(); | ||
initialState.addOutput(secpbase1, AVMConstants.SECPFXID); | ||
initialState.addOutput(secpbase2, AVMConstants.SECPFXID); | ||
initialState.addOutput(secpbase3, AVMConstants.SECPFXID); | ||
let name:string = "Rickcoin is the most intelligent coin"; | ||
let symbol:string = "RICK"; | ||
let denomination:number = 9; | ||
let txu:TxCreateAsset = new TxCreateAsset(name, symbol, denomination, initialState, inputs, outputs, netid, blockchainID, AVMConstants.CREATEASSETTX); | ||
let txins:Array<Input> = txu.getIns(); | ||
let txouts:Array<Output> = txu.getOuts(); | ||
let initState:InitialStates = txu.getInitialStates(); | ||
expect(txins.length).toBe(inputs.length); | ||
expect(txouts.length).toBe(outputs.length); | ||
expect(initState.toBuffer().toString("hex")).toBe(initialState.toBuffer().toString("hex")); | ||
expect(txu.getTxType()).toBe(AVMConstants.CREATEASSETTX); | ||
expect(txu.getNetworkID()).toBe(49); | ||
expect(txu.getBlockchainID().toString("hex")).toBe(blockchainID.toString("hex")); | ||
expect(txu.getName()).toBe(name); | ||
expect(txu.getNameBuffer().toString("hex")).toBe(bintools.stringToBuffer(name).toString("hex")); | ||
expect(txu.getSymbol()).toBe(symbol); | ||
expect(txu.getSymbolBuffer().toString("hex")).toBe(bintools.stringToBuffer(symbol).toString("hex")); | ||
expect(txu.getDenomination()).toBe(denomination); | ||
expect(txu.getDenominationBuffer().readUInt8(0)).toBe(denomination); | ||
let a:Array<string> = []; | ||
let b:Array<string> = []; | ||
for(let i:number = 0; i < txins.length; i++){ | ||
a.push(txins[i].toString()); | ||
b.push(inputs[i].toString()); | ||
} | ||
expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort())); | ||
a = []; | ||
b = []; | ||
for(let i:number = 0; i < txouts.length; i++){ | ||
a.push(txouts[i].toString()); | ||
b.push(outputs[i].toString()); | ||
} | ||
expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort())); | ||
let txunew:TxCreateAsset = new TxCreateAsset(); | ||
txunew.fromBuffer(txu.toBuffer()); | ||
expect(txunew.toBuffer().toString("hex")).toBe(txu.toBuffer().toString("hex")); | ||
expect(txunew.toString()).toBe(txu.toString()); | ||
}); | ||
}); | ||
@@ -38,4 +38,4 @@ import { SigIdx, Signature, Address, UnixNow } from 'src/apis/avm/types'; | ||
expect(sigidx.getSize()).toBe(sigidx.toBuffer().length); | ||
sigidx.setSource("abcd"); | ||
expect(sigidx.getSource()).toBe("abcd"); | ||
sigidx.setSource(Buffer.from("abcd", "hex")); | ||
expect(sigidx.getSource().toString("hex")).toBe("abcd"); | ||
}); | ||
@@ -42,0 +42,0 @@ |
@@ -77,13 +77,9 @@ import BN from "bn.js"; | ||
test('getAddresses', () => { | ||
let addresses:{ [address: string]: BN } = u1.getAddresses(); | ||
let expected:{ [address: string]: BN; } = {}; | ||
expected[opaddr] = new BN(oplocktime, "hex"); | ||
const addrs = Object.keys(addresses); | ||
for( let x of addrs ){ | ||
expect(expected[x]).not.toBeUndefined(); | ||
expect(expected[x].toNumber()).toBe(addresses[x].toNumber()); | ||
let addresses:Array<Buffer> = u1.getAddresses(); | ||
for( let i = 0; i < addresses.length; i++ ){ | ||
expect(addresses[i]).not.toBeUndefined(); | ||
} | ||
}); | ||
test('getAddressIdx', () => { | ||
let addropinfo:number = u1.getAddressIdx(opaddr); | ||
let addropinfo:number = u1.getAddressIdx(bintools.avaDeserialize(opaddr)); | ||
expect(addropinfo).toBe(0); | ||
@@ -94,7 +90,7 @@ }); | ||
let recaddr1 = u1.getAddress(0); | ||
expect(recaddr1).toBe(opaddr); | ||
expect(recaddr1.toString("hex")).toBe(bintools.avaDeserialize(opaddr).toString("hex")); | ||
}); | ||
test('getSpenders', () => { | ||
let addrs = [opaddr]; | ||
let addrs = [bintools.avaDeserialize(opaddr)]; | ||
@@ -110,3 +106,3 @@ let thepast = u1.getSpenders(addrs, new BN(0)); | ||
test('meetsThreshold', () => { | ||
let addrs = [opaddr]; | ||
let addrs = [bintools.avaDeserialize(opaddr)]; | ||
let thepast = u1.meetsThreshold(addrs, new BN(1)); | ||
@@ -144,5 +140,5 @@ expect(thepast).toBe(true); | ||
]; | ||
let addrs:Array<string> = [ | ||
"FuB6Lw2D62NuM8zpGLA4Avepq7eGsZRiG", | ||
"MaTvKGccbYzCxzBkJpb2zHW7E1WReZqB8" | ||
let addrs:Array<Buffer> = [ | ||
bintools.avaDeserialize("FuB6Lw2D62NuM8zpGLA4Avepq7eGsZRiG"), | ||
bintools.avaDeserialize("MaTvKGccbYzCxzBkJpb2zHW7E1WReZqB8") | ||
]; | ||
@@ -262,3 +258,3 @@ test('Creation', () => { | ||
let utxoids:Array<string>; | ||
utxoids = set.getUTXOIDs(addrs[0]); | ||
utxoids = set.getUTXOIDs([addrs[0]]); | ||
expect(utxoids.length).toBe(1); | ||
@@ -315,3 +311,3 @@ utxoids = set.getUTXOIDs(addrs); | ||
} | ||
let addresses:Array<string> = set.getAddresses(); | ||
let addresses:Array<Buffer> = set.getAddresses(); | ||
expect(set.getAssetIDs(addresses)).toEqual(set.getAssetIDs()) | ||
@@ -318,0 +314,0 @@ }); |
@@ -26,5 +26,5 @@ import mockAxios from 'jest-mock-axios'; | ||
test("createAccount", async ()=>{ | ||
test("createUser", async ()=>{ | ||
let result:Promise<boolean> = keystore.createAccount(username, password); | ||
let result:Promise<boolean> = keystore.createUser(username, password); | ||
let payload:object = { | ||
@@ -46,30 +46,9 @@ "result": { | ||
test('can CreateAddress', async ()=>{ | ||
let alias = 'randomalias'; | ||
let result:Promise<string> = keystore.createAddress(username, password, alias); | ||
let payload:object = { | ||
"result": { | ||
"address": alias | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(alias); | ||
}); | ||
test('exportAccount', async ()=>{ | ||
test('exportUser', async ()=>{ | ||
let data = 'data'; | ||
let result:Promise<string> = keystore.exportAccount(username, password); | ||
let result:Promise<string> = keystore.exportUser(username, password); | ||
let payload:object = { | ||
"result": { | ||
"accountData": data | ||
"user": data | ||
} | ||
@@ -88,90 +67,7 @@ }; | ||
test('exportKey', async ()=>{ | ||
let key = 'sdfglvlj2h3v45'; | ||
test('importUser', async ()=>{ | ||
let result:Promise<string> = keystore.exportKey(username, password, 'alias', 'address'); | ||
let result:Promise<boolean> = keystore.importUser(username, 'data', password); | ||
let payload:object = { | ||
"result": { | ||
"privateKey": key | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(key); | ||
}); | ||
test('getAllBalances', async ()=>{ | ||
let balances = { | ||
'ATH': 23, | ||
'BTC': 59 | ||
}; | ||
let result:Promise<object> = keystore.getAllBalances('alias', 'address'); | ||
let payload:object = { | ||
"result": { | ||
"balances": balances | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:object = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(balances); | ||
}); | ||
test('getBalance', async ()=>{ | ||
let balance = 100; | ||
let result:Promise<number> = keystore.getBalance('alias', 'address', 'ATH'); | ||
let payload:object = { | ||
"result": { | ||
"balance": balance | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:number = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(balance); | ||
}); | ||
test('getTxHistory', async ()=>{ | ||
let history = {}; | ||
let result:Promise<object> = keystore.getTxHistory('alias', 'address'); | ||
let payload:object = { | ||
"result": history | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:object = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(history); | ||
}); | ||
test('importAccount', async ()=>{ | ||
let result:Promise<boolean> = keystore.importAccount(username, 'data', password); | ||
let payload:object = { | ||
"result": { | ||
'success': true | ||
@@ -191,30 +87,9 @@ } | ||
test('importKey', async ()=>{ | ||
let address = 'asdflashdvfalsdf'; | ||
let result:Promise<string> = keystore.importKey(username,password, 'alias', 'key'); | ||
let payload:object = { | ||
"result": { | ||
'address': address | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(address); | ||
}); | ||
test('listAccounts', async ()=>{ | ||
test('listUsers', async ()=>{ | ||
let accounts = ['acc1','acc2']; | ||
let result:Promise<Array<string>> = keystore.listAccounts(); | ||
let result:Promise<Array<string>> = keystore.listUsers(); | ||
let payload:object = { | ||
"result": { | ||
'accounts': accounts | ||
'users': accounts | ||
} | ||
@@ -233,87 +108,2 @@ }; | ||
test('listAddresses', async ()=>{ | ||
let addresses = ['acc1','acc2']; | ||
let result:Promise<Array<string>> = keystore.listAddresses(username, 'alias'); | ||
let payload:object = { | ||
"result": { | ||
'addresses': addresses | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:Array<string> = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(addresses); | ||
}); | ||
test('listAssets', async ()=>{ | ||
let assets = ['ATH','ETH']; | ||
let result:Promise<Array<string>> = keystore.listAssets(username, 'address'); | ||
let payload:object = { | ||
"result": { | ||
'assets': assets | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:Array<string> = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(assets); | ||
}); | ||
test('can ListSubnets', async ()=>{ | ||
let subnets = ['net1','net2']; | ||
let result:Promise<Array<string>> = keystore.listSubnets(); | ||
let payload:object = { | ||
"result": { | ||
'subnetIDs': subnets | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:Array<string> = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(subnets); | ||
}); | ||
test('can Send', async ()=>{ | ||
let txId = 'asdfhvl234'; | ||
let result:Promise<string> = keystore.send(username,password,'alias', 'assetId', 10, 'toAddress', ['fromAddress']); | ||
let payload:object = { | ||
"result": { | ||
'txID': txId | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(txId); | ||
}); | ||
}); |
@@ -45,9 +45,32 @@ import mockAxios from 'jest-mock-axios'; | ||
test("createBlockchain", async ()=>{ | ||
let blockchainID:string = "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh"; | ||
let vmID:string = "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh"; | ||
let name:string = "Some Blockchain"; | ||
let method:string = 'avm.Booyashakalah'; | ||
let genesis:object = {ruh:"roh"}; | ||
let result:Promise<string> = platform.createBlockchain(vmID, name, method, genesis); | ||
let payload:object = { | ||
"result": { | ||
"blockchainID": blockchainID | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
test("createSubnet", async ()=>{ | ||
mockAxios.mockResponse(responseObj); | ||
let response:string = await result; | ||
let result:Promise<boolean> = platform.createSubnet('txId'); | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(blockchainID); | ||
}); | ||
test("getBlockchainStatus", async ()=>{ | ||
let blockchainID:string = "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh"; | ||
let result:Promise<string> = platform.getBlockchainStatus(blockchainID); | ||
let payload:object = { | ||
"result": { | ||
"success": true | ||
"status": "Accepted" | ||
} | ||
@@ -60,6 +83,6 @@ }; | ||
mockAxios.mockResponse(responseObj); | ||
let response:boolean = await result; | ||
let response:string = await result; | ||
expect(mockAxios.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(true); | ||
expect(response).toBe("Accepted"); | ||
}); | ||
@@ -66,0 +89,0 @@ |
@@ -11,2 +11,5 @@ import BinTools from "src/utils/bintools"; | ||
let hexstr3:string = "0001020304050607080909080706050403020101" | ||
let hexbuffstr1:string = "000461736466"; // = asdf | ||
let hexbuffstr2:string = "000761626364656667"; // = abcdefg | ||
let hexbuffstr3:string = "00076f6b0066696e65"; // = ok<null>fineokfine | ||
let b58str:string = "1UoWww8DGaVGLtea7zU7p"; | ||
@@ -37,2 +40,24 @@ let b58str2:string = "1Bhh3pU9gLXZiJv73kmqZwHJ4F" | ||
test('bufferToString', () => { | ||
let bres:string = bintools.bufferToString(Buffer.from(hexbuffstr1, "hex")); | ||
expect(bres).toBe(Buffer.from(hexbuffstr1.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres2:string = bintools.bufferToString(Buffer.from(hexbuffstr2, "hex")); | ||
expect(bres2).toBe(Buffer.from(hexbuffstr2.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres3:string = bintools.bufferToString(Buffer.from(hexbuffstr3, "hex")); | ||
expect(bres3).toBe(Buffer.from(hexbuffstr3.slice(4), "hex").toString("utf8")); | ||
}); | ||
test('stringToBuffer', () => { | ||
let bres:Buffer = bintools.stringToBuffer("asdf"); | ||
expect(bres.slice(2).toString()).toBe(Buffer.from(hexbuffstr1.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres2:Buffer = bintools.stringToBuffer("abcdefg"); | ||
expect(bres2.slice(2).toString()).toBe(Buffer.from(hexbuffstr2.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres3:Buffer = bintools.stringToBuffer(Buffer.from(hexbuffstr3.slice(4), "hex").toString("utf8")); | ||
expect(bres3.slice(2).toString()).toBe(Buffer.from(hexbuffstr3.slice(4), "hex").toString("utf8")); | ||
}); | ||
test('bufferToB58', () => { | ||
@@ -39,0 +64,0 @@ let b58res:string = bintools.bufferToB58(buff); |
@@ -8,5 +8,5 @@ /** | ||
import { UTXOSet } from './utxos'; | ||
import { MergeRule } from './types'; | ||
import { MergeRule, InitialStates } from './types'; | ||
import { AVMKeyChain } from './keychain'; | ||
import { TxUnsigned, Tx } from './tx'; | ||
import { TxUnsigned, Tx, TxCreateAsset } from './tx'; | ||
import BN from "bn.js"; | ||
@@ -64,9 +64,29 @@ /** | ||
protected blockchainID: string; | ||
protected AVAAssetID: Buffer; | ||
/** | ||
* Gets the alias for the blockchainID if it exists, otherwise returns `undefined`. | ||
* | ||
* @returns The alias for the blockchainID | ||
*/ | ||
getBlockchainAlias: () => string; | ||
/** | ||
* Gets the blockchainID and returns it. | ||
* | ||
* @returns The the provided string representing the blockchainID | ||
* @returns The blockchainID | ||
*/ | ||
getBlockchainID: () => string; | ||
/** | ||
* Takes an address string and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid. | ||
*/ | ||
parseAddress: (addr: string) => Buffer; | ||
addressFromBuffer: (address: Buffer) => string; | ||
/** | ||
* Fetches the AVA AssetID and returns it in a Promise. | ||
* | ||
* @returns The the provided string representing the blockchainID | ||
*/ | ||
getAVAAssetID: () => Promise<Buffer>; | ||
/** | ||
* Gets a reference to the keychain for this class. | ||
@@ -82,14 +102,140 @@ * | ||
/** | ||
* Creates an asset of a given amount and assigns it to the address provided. | ||
* Gets the balance of a particular asset on a subnet. | ||
* | ||
* @param amount The amount of the asset to be created. If Amount is 10, for example, there will be exist 10 units of the new asset | ||
* @param address The base 58 string representation of the address that holds all units of the new asset upon creation of the asset | ||
* @param address The address to pull the asset balance from | ||
* @param assetID The assetID to pull the balance from | ||
* | ||
* @returns Promise with the balance of the assetID on the provided address for the subnet. | ||
*/ | ||
getBalance: (address: string, assetID: string) => Promise<number>; | ||
/** | ||
* Creates an address (and associated private keys) on a user under a subnet. | ||
* | ||
* @param username Name of the user to create the address under | ||
* @param password Password to unlock the user and encrypt the private key | ||
* | ||
* @returns Promise for a string representing the address created by the subnet. | ||
*/ | ||
createAddress: (username: string, password: string) => Promise<string>; | ||
/** | ||
* Create a new fixed-cap, fungible asset. A quantity of it is created at initialization and there no more is ever created. | ||
* | ||
* @param username The user paying the transaction fee (in $AVA) for asset creation | ||
* @param password The password for the user paying the transaction fee (in $AVA) for asset creation | ||
* @param name The human-readable name for the asset | ||
* @param symbol Optional. The shorthand symbol for the asset. Between 0 and 4 characters | ||
* @param initialHolders An array of objects containing the field "address" and "amount" to establish the genesis values for the new asset | ||
* | ||
* ```js | ||
* Example initialHolders: | ||
* [ | ||
* { | ||
* "address": "X-7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh", | ||
* "amount": 10000 | ||
* }, | ||
* { | ||
* "address": "X-7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh", | ||
* "amount": 50000 | ||
* } | ||
* ] | ||
* ``` | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the ID of the newly created asset. | ||
*/ | ||
createAsset: (amount: number, address: string) => Promise<string>; | ||
createFixedCapAsset: (username: string, password: string, name: string, symbol: string, initialHolders: object[]) => Promise<string>; | ||
/** | ||
* Create a new variable-cap, fungible asset. No units of the asset exist at initialization. Minters can mint units of this asset using createMintTx, signMintTx and sendMintTx. | ||
* | ||
* @param username The user paying the transaction fee (in $AVA) for asset creation | ||
* @param password The password for the user paying the transaction fee (in $AVA) for asset creation | ||
* @param name The human-readable name for the asset | ||
* @param symbol Optional. The shorthand symbol for the asset -- between 0 and 4 characters | ||
* @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction | ||
* | ||
* ```js | ||
* Example minterSets: | ||
* [ | ||
* { | ||
* "minters":[ | ||
* "X-4peJsFvhdn7XjhNF4HWAQy6YaJts27s9q" | ||
* ], | ||
* "threshold": 1 | ||
* }, | ||
* { | ||
* "minters": [ | ||
* "X-dcJ6z9duLfyQTgbjq2wBCowkvcPZHVDF", | ||
* "X-2fE6iibqfERz5wenXE6qyvinsxDvFhHZk", | ||
* "X-7ieAJbfrGQbpNZRAQEpZCC1Gs1z5gz4HU" | ||
* ], | ||
* "threshold": 2 | ||
* } | ||
* ] | ||
* ``` | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the ID of the newly created asset. | ||
*/ | ||
createVariableCapAsset: (username: string, password: string, name: string, symbol: string, minterSets: object[]) => Promise<string>; | ||
/** | ||
* Create an unsigned transaction to mint more of an asset. | ||
* | ||
* @param amount The units of the asset to mint | ||
* @param assetID The ID of the asset to mint | ||
* @param to The address to assign the units of the minted asset | ||
* @param minters Addresses of the minters responsible for signing the transaction | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the unsigned transaction. | ||
*/ | ||
createMintTx: (amount: number | BN, assetID: string | Buffer, to: string, minters: string[]) => Promise<string>; | ||
/** | ||
* Sign an unsigned or partially signed mint transaction. | ||
* | ||
* @param username The user signing | ||
* @param password The password for the user signing | ||
* @param tx The output of createMintTx or signMintTx | ||
* @param minter The minter signing this transaction | ||
* | ||
* @returns Returns a Promise<string> containing the base 58 string representation of the unsigned transaction. | ||
*/ | ||
signMintTx: (username: string, password: string, tx: string | Buffer, minter: string) => Promise<string>; | ||
/** | ||
* Exports the private key for an address. | ||
* | ||
* @param username The name of the user with the private key | ||
* @param password The password used to decrypt the private key | ||
* @param address The address whose private key should be exported | ||
* | ||
* @returns Promise with the decrypted private key as store in the database | ||
*/ | ||
exportKey: (username: string, password: string, address: string) => Promise<string>; | ||
/** | ||
* Imports a private key into the node's database under an user and for a subnet. | ||
* | ||
* @param username The name of the user to store the private key | ||
* @param password The password that unlocks the user | ||
* @param privateKey A string representing the private key in the subnet's format | ||
* | ||
* @returns The address for the imported private key. | ||
*/ | ||
importKey: (username: string, password: string, privateKey: string) => Promise<string>; | ||
/** | ||
* Lists all the addresses under a user. | ||
* | ||
* @param username The user to list addresses | ||
* @param password The password of the user to list the addresses | ||
* | ||
* @returns Promise of an array of address strings in the format specified by the subnet. | ||
*/ | ||
listAddresses: (username: string, password: string) => Promise<string[]>; | ||
/** | ||
* Lists all assets for an address. | ||
* | ||
* @param address The address to get a list of assets | ||
* | ||
* @returns Promise of an array of assetIDs for the address on the subnet. | ||
*/ | ||
listAssets: (address: string) => Promise<string[]>; | ||
/** | ||
* Retrieves an assets name and symbol. | ||
* | ||
* @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an AVA serialized string for the AssetID. | ||
* @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an AVA serialized string for the AssetID or its alias. | ||
* | ||
@@ -101,2 +247,4 @@ * @returns Returns a Promise<object> with keys "name" and "symbol". | ||
symbol: string; | ||
assetID: Buffer; | ||
denomination: number; | ||
}>; | ||
@@ -114,3 +262,3 @@ /** | ||
* | ||
* @param addresses An array of addresses as strings | ||
* @param addresses An array of addresses as strings or addresses as {@link https://github.com/feross/buffer|Buffer}s | ||
* @param persistOpts Options available to persist these UTXOs in local storage | ||
@@ -122,3 +270,3 @@ * | ||
*/ | ||
getUTXOs: (addresses: string[], persistOpts?: PersistanceOptions) => Promise<UTXOSet>; | ||
getUTXOs: (addresses: Buffer[] | string[], persistOpts?: PersistanceOptions) => Promise<UTXOSet>; | ||
/** | ||
@@ -143,4 +291,20 @@ * Helper function which creates an unsigned transaction. For more granular control, you may create your own | ||
*/ | ||
makeUnsignedTx: (utxoset: UTXOSet, amount: BN, toAddresses: string[], fromAddresses: string[], changeAddresses: string[], assetID?: string | Buffer, asOf?: BN, locktime?: BN, threshold?: number) => TxUnsigned; | ||
makeUnsignedTx: (utxoset: UTXOSet, amount: BN, toAddresses: string[], fromAddresses: string[], changeAddresses: string[], assetID?: string | Buffer, asOf?: BN, locktime?: BN, threshold?: number) => Promise<TxUnsigned>; | ||
/** | ||
* Creates an unsigned transaction. For more granular control, you may create your own | ||
* [[TxCreateAsset]] manually (with their corresponding [[Input]]s, [[Output]]s). | ||
* | ||
* @param utxoset A set of UTXOs that the transaction is built on | ||
* @param fee The amount of AVA to be paid for fees, in NanoAVA | ||
* @param creatorAddresses The addresses to send the fees | ||
* @param initialState The [[InitialStates]] that represent the intial state of a created asset | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* | ||
* @returns An unsigned transaction created from the passed in parameters. | ||
* | ||
*/ | ||
makeCreateAssetTx: (utxoset: UTXOSet, fee: BN, creatorAddresses: Buffer[] | string[], initialState: InitialStates, name: string, symbol: string, denomination: number) => Promise<TxCreateAsset>; | ||
/** | ||
* Helper function which takes an unsigned transaction and signs it, returning the resulting [[Tx]]. | ||
@@ -162,2 +326,16 @@ * | ||
/** | ||
* Sends an amount of assetID to the specified address from a list of owned of addresses. | ||
* | ||
* @param username The user that owns the private keys associated with the `from` addresses | ||
* @param password The password unlocking the user | ||
* @param assetID The assetID of the asset to send | ||
* @param amount The amount of the asset to be sent | ||
* @param to The address of the recipient | ||
* @param from An array of addresses managed by the node for this subnet which will fund this transaction | ||
* | ||
* @returns Promise for the string representing the transaction's ID. | ||
*/ | ||
send: (username: string, password: string, assetID: string | Buffer, amount: number | BN, to: string, from: Buffer[] | string[]) => Promise<string>; | ||
protected _cleanAddressArray(addresses: Array<string> | Array<Buffer>, caller: string): Array<string>; | ||
/** | ||
* This class should not be instantiated directly. Instead use the [[Slopes.addAPI]] method. | ||
@@ -164,0 +342,0 @@ * |
@@ -50,7 +50,2 @@ /** | ||
/** | ||
* @ignore | ||
*/ | ||
protected _basicInBuffer: () => Buffer; | ||
protected _basicInParser: (bytes: Buffer) => number; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes. | ||
@@ -62,11 +57,11 @@ * | ||
*/ | ||
fromBuffer: (bytes: Buffer) => number; | ||
fromBuffer(bytes: Buffer, offset?: number): number; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
* Returns a base-58 representation of the [[Input]]. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
@@ -92,7 +87,2 @@ * Class representing an Input for a transaction. | ||
/** | ||
* @ignore | ||
*/ | ||
protected _SecpInBuffer: () => Buffer; | ||
protected _SecpInParser: (bytes: Buffer) => number; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes. | ||
@@ -104,11 +94,11 @@ * | ||
*/ | ||
fromBuffer: (bytes: Buffer) => number; | ||
fromBuffer(bytes: Buffer, offset?: number): number; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
* Returns a base-58 representation of the [[Input]]. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
@@ -120,3 +110,3 @@ * Creates and adds a [[SigIdx]] to the [[Input]]. | ||
*/ | ||
addSignatureIdx: (addressIdx: number, address: string) => void; | ||
addSignatureIdx: (addressIdx: number, address: Buffer) => void; | ||
/** | ||
@@ -123,0 +113,0 @@ * Class representing an Input for a transaction. |
@@ -39,3 +39,3 @@ "use strict"; | ||
let inputid = inbuffer.readUInt32BE(68); | ||
if (inputid == types_1.Constants.SECPINPUTID) { | ||
if (inputid == types_1.AVMConstants.SECPINPUTID) { | ||
let secpin = new SecpInput(); | ||
@@ -81,56 +81,2 @@ secpin.fromBuffer(inbuffer); | ||
}; | ||
/** | ||
* @ignore | ||
*/ | ||
this._basicInBuffer = () => { | ||
try { | ||
let bsize = this.txid.length + this.txidx.length + this.assetid.length + this.inputid.length; | ||
let barr = [this.txid, this.txidx, this.assetid, this.inputid]; | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - Input._basicInBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
}; | ||
this._basicInParser = (bytes) => { | ||
let offset = 0; | ||
this.txid = bintools.copyFrom(bytes, offset, offset + 32); | ||
offset += 32; | ||
this.txidx = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
this.assetid = bintools.copyFrom(bytes, offset, offset + 32); | ||
offset += 32; | ||
this.inputid = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
return offset; | ||
}; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
this.fromBuffer = (bytes) => { | ||
/* istanbul ignore next */ | ||
return this._basicInParser(bytes); | ||
}; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
this.toBuffer = () => { | ||
/* istanbul ignore next */ | ||
return this._basicInBuffer(); | ||
}; | ||
/** | ||
* Returns a base-58 representation of the [[Input]]. | ||
*/ | ||
this.toString = () => { | ||
/* istanbul ignore next */ | ||
return bintools.bufferToB58(this.toBuffer()); | ||
}; | ||
if (txid && txidx && assetID && inputid) { | ||
@@ -143,2 +89,44 @@ this.inputid.writeUInt32BE(inputid, 0); | ||
} | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
fromBuffer(bytes, offset = 0) { | ||
this.txid = bintools.copyFrom(bytes, offset, offset + 32); | ||
offset += 32; | ||
this.txidx = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
this.assetid = bintools.copyFrom(bytes, offset, offset + 32); | ||
offset += 32; | ||
this.inputid = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
return offset; | ||
} | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
toBuffer() { | ||
try { | ||
let bsize = this.txid.length + this.txidx.length + this.assetid.length + this.inputid.length; | ||
let barr = [this.txid, this.txidx, this.assetid, this.inputid]; | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - Input.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
/** | ||
* Returns a base-58 representation of the [[Input]]. | ||
*/ | ||
toString() { | ||
/* istanbul ignore next */ | ||
return bintools.bufferToB58(this.toBuffer()); | ||
} | ||
} | ||
@@ -164,3 +152,3 @@ exports.Input = Input; | ||
constructor(txid, txidx, amount, assetID) { | ||
super(txid, txidx, assetID, types_1.Constants.SECPINPUTID); | ||
super(txid, txidx, assetID, types_1.AVMConstants.SECPINPUTID); | ||
this.amount = buffer_1.Buffer.alloc(8); | ||
@@ -177,67 +165,2 @@ this.amountValue = new bn_js_1.default(0); | ||
/** | ||
* @ignore | ||
*/ | ||
this._SecpInBuffer = () => { | ||
try { | ||
this.numAddr.writeUInt32BE(this.sigIdxs.length, 0); | ||
let bsize = this.amount.length + this.numAddr.length; | ||
let barr = [this.amount, this.numAddr]; | ||
for (let i = 0; i < this.sigIdxs.length; i++) { | ||
let b = this.sigIdxs[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - SecpInput._SecpInBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
}; | ||
this._SecpInParser = (bytes) => { | ||
let offset = this._basicInParser(bytes); | ||
this.amount = bintools.copyFrom(bytes, offset, offset + 8); | ||
offset += 8; | ||
this.amountValue = bintools.fromBufferToBN(this.amount); | ||
this.numAddr = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let numaddr = this.numAddr.readUInt32BE(0); | ||
this.sigIdxs = []; | ||
for (let i = 0; i < numaddr; i++) { | ||
let sigidx = new types_1.SigIdx(); | ||
let sigbuff = bintools.copyFrom(bytes, offset, offset + 4); | ||
sigidx.fromBuffer(sigbuff); | ||
offset += 4; | ||
this.sigIdxs.push(sigidx); | ||
} | ||
return offset; | ||
}; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
this.fromBuffer = (bytes) => { | ||
return this._SecpInParser(bytes); | ||
}; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
this.toBuffer = () => { | ||
let basicin = this._basicInBuffer(); | ||
let secp = this._SecpInBuffer(); | ||
return buffer_1.Buffer.concat([basicin, secp]); | ||
}; | ||
/** | ||
* Returns a base-58 representation of the [[Input]]. | ||
*/ | ||
this.toString = () => { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
}; | ||
/** | ||
* Creates and adds a [[SigIdx]] to the [[Input]]. | ||
@@ -258,3 +181,3 @@ * | ||
if (txid && txidx && amount && assetID) { | ||
this.inputid.writeUInt32BE(types_1.Constants.SECPINPUTID, 0); | ||
this.inputid.writeUInt32BE(types_1.AVMConstants.SECPINPUTID, 0); | ||
this.txid = txid; | ||
@@ -268,4 +191,58 @@ this.txidx = txidx; | ||
} | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]] | ||
* | ||
* @returns The length of the raw [[Input]] | ||
*/ | ||
fromBuffer(bytes, offset = 0) { | ||
offset = super.fromBuffer(bytes, offset); | ||
this.amount = bintools.copyFrom(bytes, offset, offset + 8); | ||
offset += 8; | ||
this.amountValue = bintools.fromBufferToBN(this.amount); | ||
this.numAddr = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let numaddr = this.numAddr.readUInt32BE(0); | ||
this.sigIdxs = []; | ||
for (let i = 0; i < numaddr; i++) { | ||
let sigidx = new types_1.SigIdx(); | ||
let sigbuff = bintools.copyFrom(bytes, offset, offset + 4); | ||
sigidx.fromBuffer(sigbuff); | ||
offset += 4; | ||
this.sigIdxs.push(sigidx); | ||
} | ||
return offset; | ||
} | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]]. | ||
*/ | ||
toBuffer() { | ||
try { | ||
let basicin = super.toBuffer(); | ||
this.numAddr.writeUInt32BE(this.sigIdxs.length, 0); | ||
let bsize = basicin.length + this.amount.length + this.numAddr.length; | ||
let barr = [basicin, this.amount, this.numAddr]; | ||
for (let i = 0; i < this.sigIdxs.length; i++) { | ||
let b = this.sigIdxs[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
return buffer_1.Buffer.concat(barr, bsize); | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - SecpInput.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
/** | ||
* Returns a base-58 representation of the [[Input]]. | ||
*/ | ||
toString() { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
} | ||
} | ||
exports.SecpInput = SecpInput; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs.js","sourceRoot":"","sources":["../../../../src/apis/avm/inputs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport BinTools from '../../utils/bintools';\nimport BN from \"bn.js\";\nimport { SigIdx, Constants } from './types';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n/**\n * Class representing an Input for a transaction.\n * \n * @remarks \n * Input:\n * ObjectID | 04 bytes\n * TxID     | 32 bytes\n * TxIndex  | 04 bytes\n * Amount   | 08 bytes\n * NumSigs  | 04 bytes\n * Repeated (NumSigs):\n *     SigIdx  | 04 bytes\n */\n\n/**\n * Takes a buffer representing the output and returns the proper [[Input]] instance.\n * \n * @param inbuffer A {@link https://github.com/feross/buffer|Buffer} containing the [[Input]] raw data.\n * \n * @returns An instance of an [[Input]]-extended class: [[SecpInput]].\n */\nexport const SelectInputClass = (inbuffer:Buffer, args:Array<any> = []):Input => {\n    let inputid:number = inbuffer.readUInt32BE(68);\n    if(inputid == Constants.SECPINPUTID){\n        let secpin:SecpInput = new SecpInput();\n        secpin.fromBuffer(inbuffer);\n        return secpin;\n    }\n    /* istanbul ignore next */\n    throw new Error(\"Error - SelectInputClass: unknown inputid \" + inputid);\n}\n\nexport class Input {\n    protected txid:Buffer = Buffer.alloc(32);\n    protected txidx:Buffer = Buffer.alloc(4);\n    protected assetid:Buffer = Buffer.alloc(32);\n    protected inputid:Buffer = Buffer.alloc(4);\n\n    /**\n     * Returns a function used to sort an array of [[Input]]s\n     */\n    static comparator = ():(a:Input, b:Input) => (1|-1|0) => {\n        return function(a:Input, b:Input):(1|-1|0) { \n            return Buffer.compare(a.toBuffer(), b.toBuffer()) as (1|-1|0);\n        }\n    }\n\n    /**\n     * Returns a base-58 string representation of the UTXOID this [[Input]] references.\n     */\n    getUTXOID = ():string => {\n        return bintools.bufferToB58(Buffer.concat([this.txid, this.txidx]));\n    }\n\n    /**\n     * Returns the number for the input type of the output class.\n     */\n    getInputID = ():number => {\n        return this.inputid.readUInt32BE(0);\n    };\n\n    /**\n     * Returns the assetID of the input.\n     */\n    getAssetID = ():Buffer => {\n        /* istanbul ignore next */\n        return this.assetid;\n    }\n\n    /**\n     * @ignore\n     */\n    protected _basicInBuffer = (): Buffer => {\n        try {\n            let bsize:number = this.txid.length + this.txidx.length + this.assetid.length + this.inputid.length ;\n            let barr:Array<Buffer> = [this.txid, this.txidx, this.assetid, this.inputid];\n            let buff: Buffer = Buffer.concat(barr,bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - Input._basicInBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    protected _basicInParser = (bytes:Buffer):number => {\n        let offset:number = 0;\n        this.txid = bintools.copyFrom(bytes, offset, offset + 32);\n        offset += 32;\n        this.txidx = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        this.assetid = bintools.copyFrom(bytes, offset, offset + 32);\n        offset += 32;\n        this.inputid = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        return offset;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]]\n     * \n     * @returns The length of the raw [[Input]]\n     */\n    fromBuffer = (bytes:Buffer):number => {\n        /* istanbul ignore next */\n        return this._basicInParser(bytes);\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]].\n     */\n    toBuffer = ():Buffer => {\n        /* istanbul ignore next */\n        return this._basicInBuffer();\n    }\n\n    /**\n     * Returns a base-58 representation of the [[Input]].\n     */\n    toString = ():string => {\n        /* istanbul ignore next */\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Class representing an Input for a transaction.\n     * \n     * @param txid A {@link https://github.com/feross/buffer|Buffer} containing the transaction ID of the referenced UTXO\n     * @param txidx A {@link https://github.com/feross/buffer|Buffer} containing the index of the output in the transaction consumed in the [[Input]]\n     * @param assetID A {@link https://github.com/feross/buffer|Buffer} representing the assetID of the [[Input]]\n     * @param inputid A number representing the InputID of the [[Input]]\n     */\n    constructor(txid?:Buffer, txidx?:Buffer, assetID?:Buffer, inputid?:number) {\n        if(txid && txidx && assetID && inputid){\n            this.inputid.writeUInt32BE(inputid,0);\n            this.txid = txid;\n            this.txidx = txidx;\n            this.assetid = assetID;\n        }\n    }\n}\n\n\nexport class SecpInput extends Input {\n    protected amount:Buffer = Buffer.alloc(8);\n    protected amountValue:BN = new BN(0);\n    protected numAddr:Buffer = Buffer.alloc(4);\n    protected sigIdxs:Array<SigIdx> = []; // idxs of signers from utxo\n\n\n    /**\n     * Returns the array of [[SigIdx]] for this [[Input]] \n     */\n    getSigIdxs = ():Array<SigIdx> => {\n        return this.sigIdxs;\n    }\n\n    /**\n     * @ignore\n     */\n    protected _SecpInBuffer = (): Buffer => {\n        try {\n            this.numAddr.writeUInt32BE(this.sigIdxs.length, 0);\n            let bsize:number = this.amount.length + this.numAddr.length;\n            let barr:Array<Buffer> = [this.amount, this.numAddr];\n            for(let i = 0; i < this.sigIdxs.length; i++) {\n                let b:Buffer = this.sigIdxs[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            let buff: Buffer = Buffer.concat(barr,bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - SecpInput._SecpInBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    protected _SecpInParser = (bytes:Buffer):number => {\n        let offset:number = this._basicInParser(bytes);\n        this.amount = bintools.copyFrom(bytes, offset, offset + 8);\n        offset += 8;\n        this.amountValue = bintools.fromBufferToBN(this.amount);\n        this.numAddr = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let numaddr:number = this.numAddr.readUInt32BE(0);\n        this.sigIdxs = [];\n        for(let i = 0; i < numaddr; i++){\n            let sigidx = new SigIdx();\n            let sigbuff:Buffer = bintools.copyFrom(bytes, offset, offset + 4);\n            sigidx.fromBuffer(sigbuff);\n            offset += 4;\n            this.sigIdxs.push(sigidx);\n        }\n        return offset;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]]\n     * \n     * @returns The length of the raw [[Input]]\n     */\n    fromBuffer = (bytes:Buffer):number => {\n        return this._SecpInParser(bytes);\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]].\n     */\n    toBuffer = ():Buffer => {\n        let basicin:Buffer = this._basicInBuffer();\n        let secp:Buffer = this._SecpInBuffer();\n        return Buffer.concat([basicin, secp]);\n    }\n\n    /**\n     * Returns a base-58 representation of the [[Input]].\n     */\n    toString = ():string => {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Creates and adds a [[SigIdx]] to the [[Input]].\n     * \n     * @param addressIdx The index of the address to reference in the signatures\n     * @param address The address of the source of the signature\n     */\n    addSignatureIdx = (addressIdx:number, address:string) => {\n        let sigidx:SigIdx = new SigIdx();\n        let b:Buffer = Buffer.alloc(4);\n        b.writeUInt32BE(addressIdx, 0);\n        sigidx.fromBuffer(b);\n        sigidx.setSource(address);\n        this.sigIdxs.push(sigidx);\n        this.numAddr.writeUInt32BE(this.sigIdxs.length,0);\n    }\n\n    /**\n     * Class representing an Input for a transaction.\n     * \n     * @param txid A {@link https://github.com/feross/buffer|Buffer} containing the transaction ID of the referenced UTXO\n     * @param txidx A {@link https://github.com/feross/buffer|Buffer} containing the index of the output in the transaction consumed in the [[Input]]\n     * @param assetID A {@link https://github.com/feross/buffer|Buffer} representing the assetID of the [[Input]]\n     * @param amount A {@link https://github.com/indutny/bn.js/|BN} containing the amount of the output to be consumed\n     */\n    constructor(txid?:Buffer, txidx?:Buffer, amount?:BN, assetID?:Buffer) {\n        super(txid, txidx, assetID, Constants.SECPINPUTID);\n        if(txid && txidx && amount && assetID){\n            this.inputid.writeUInt32BE(Constants.SECPINPUTID,0);\n            this.txid = txid;\n            this.txidx = txidx;\n            this.assetid = assetID;\n            this.amountValue = amount;\n            this.amount = bintools.fromBNToBuffer(amount, 8);\n            this.sigIdxs = [];\n        }\n        \n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs.js","sourceRoot":"","sources":["../../../../src/apis/avm/inputs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport BinTools from '../../utils/bintools';\nimport BN from \"bn.js\";\nimport { SigIdx, AVMConstants } from './types';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n/**\n * Class representing an Input for a transaction.\n * \n * @remarks \n * Input:\n * ObjectID | 04 bytes\n * TxID     | 32 bytes\n * TxIndex  | 04 bytes\n * Amount   | 08 bytes\n * NumSigs  | 04 bytes\n * Repeated (NumSigs):\n *     SigIdx  | 04 bytes\n */\n\n/**\n * Takes a buffer representing the output and returns the proper [[Input]] instance.\n * \n * @param inbuffer A {@link https://github.com/feross/buffer|Buffer} containing the [[Input]] raw data.\n * \n * @returns An instance of an [[Input]]-extended class: [[SecpInput]].\n */\nexport const SelectInputClass = (inbuffer:Buffer, args:Array<any> = []):Input => {\n    let inputid:number = inbuffer.readUInt32BE(68);\n    if(inputid == AVMConstants.SECPINPUTID){\n        let secpin:SecpInput = new SecpInput();\n        secpin.fromBuffer(inbuffer);\n        return secpin;\n    }\n    /* istanbul ignore next */\n    throw new Error(\"Error - SelectInputClass: unknown inputid \" + inputid);\n}\n\nexport class Input {\n    protected txid:Buffer = Buffer.alloc(32);\n    protected txidx:Buffer = Buffer.alloc(4);\n    protected assetid:Buffer = Buffer.alloc(32);\n    protected inputid:Buffer = Buffer.alloc(4);\n\n    /**\n     * Returns a function used to sort an array of [[Input]]s\n     */\n    static comparator = ():(a:Input, b:Input) => (1|-1|0) => {\n        return function(a:Input, b:Input):(1|-1|0) { \n            return Buffer.compare(a.toBuffer(), b.toBuffer()) as (1|-1|0);\n        }\n    }\n\n    /**\n     * Returns a base-58 string representation of the UTXOID this [[Input]] references.\n     */\n    getUTXOID = ():string => {\n        return bintools.bufferToB58(Buffer.concat([this.txid, this.txidx]));\n    }\n\n    /**\n     * Returns the number for the input type of the output class.\n     */\n    getInputID = ():number => {\n        return this.inputid.readUInt32BE(0);\n    };\n\n    /**\n     * Returns the assetID of the input.\n     */\n    getAssetID = ():Buffer => {\n        /* istanbul ignore next */\n        return this.assetid;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the Input in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]]\n     * \n     * @returns The length of the raw [[Input]]\n     */\n    fromBuffer(bytes:Buffer, offset:number = 0):number {\n        this.txid = bintools.copyFrom(bytes, offset, offset + 32);\n        offset += 32;\n        this.txidx = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        this.assetid = bintools.copyFrom(bytes, offset, offset + 32);\n        offset += 32;\n        this.inputid = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        return offset;\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]].\n     */\n    toBuffer():Buffer {\n        try {\n            let bsize:number = this.txid.length + this.txidx.length + this.assetid.length + this.inputid.length ;\n            let barr:Array<Buffer> = [this.txid, this.txidx, this.assetid, this.inputid];\n            let buff: Buffer = Buffer.concat(barr,bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - Input.toBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a base-58 representation of the [[Input]].\n     */\n    toString():string {\n        /* istanbul ignore next */\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Class representing an Input for a transaction.\n     * \n     * @param txid A {@link https://github.com/feross/buffer|Buffer} containing the transaction ID of the referenced UTXO\n     * @param txidx A {@link https://github.com/feross/buffer|Buffer} containing the index of the output in the transaction consumed in the [[Input]]\n     * @param assetID A {@link https://github.com/feross/buffer|Buffer} representing the assetID of the [[Input]]\n     * @param inputid A number representing the InputID of the [[Input]]\n     */\n    constructor(txid?:Buffer, txidx?:Buffer, assetID?:Buffer, inputid?:number) {\n        if(txid && txidx && assetID && inputid){\n            this.inputid.writeUInt32BE(inputid,0);\n            this.txid = txid;\n            this.txidx = txidx;\n            this.assetid = assetID;\n        }\n    }\n}\n\n\nexport class SecpInput extends Input {\n    protected amount:Buffer = Buffer.alloc(8);\n    protected amountValue:BN = new BN(0);\n    protected numAddr:Buffer = Buffer.alloc(4);\n    protected sigIdxs:Array<SigIdx> = []; // idxs of signers from utxo\n\n\n    /**\n     * Returns the array of [[SigIdx]] for this [[Input]] \n     */\n    getSigIdxs = ():Array<SigIdx> => {\n        return this.sigIdxs;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Input]], parses it, populates the class, and returns the length of the [[Input]] in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Input]]\n     * \n     * @returns The length of the raw [[Input]]\n     */\n    fromBuffer(bytes:Buffer, offset:number = 0):number {\n        offset = super.fromBuffer(bytes, offset);\n        this.amount = bintools.copyFrom(bytes, offset, offset + 8);\n        offset += 8;\n        this.amountValue = bintools.fromBufferToBN(this.amount);\n        this.numAddr = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let numaddr:number = this.numAddr.readUInt32BE(0);\n        this.sigIdxs = [];\n        for(let i = 0; i < numaddr; i++){\n            let sigidx = new SigIdx();\n            let sigbuff:Buffer = bintools.copyFrom(bytes, offset, offset + 4);\n            sigidx.fromBuffer(sigbuff);\n            offset += 4;\n            this.sigIdxs.push(sigidx);\n        }\n        return offset;\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Input]].\n     */\n    toBuffer():Buffer {\n        try {\n            let basicin:Buffer = super.toBuffer();\n            this.numAddr.writeUInt32BE(this.sigIdxs.length, 0);\n            let bsize:number = basicin.length + this.amount.length + this.numAddr.length;\n            let barr:Array<Buffer> = [basicin, this.amount, this.numAddr];\n            for(let i = 0; i < this.sigIdxs.length; i++) {\n                let b:Buffer = this.sigIdxs[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            return Buffer.concat(barr,bsize);\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - SecpInput.toBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a base-58 representation of the [[Input]].\n     */\n    toString():string {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Creates and adds a [[SigIdx]] to the [[Input]].\n     * \n     * @param addressIdx The index of the address to reference in the signatures\n     * @param address The address of the source of the signature\n     */\n    addSignatureIdx = (addressIdx:number, address:Buffer) => {\n        let sigidx:SigIdx = new SigIdx();\n        let b:Buffer = Buffer.alloc(4);\n        b.writeUInt32BE(addressIdx, 0);\n        sigidx.fromBuffer(b);\n        sigidx.setSource(address);\n        this.sigIdxs.push(sigidx);\n        this.numAddr.writeUInt32BE(this.sigIdxs.length,0);\n    }\n\n    /**\n     * Class representing an Input for a transaction.\n     * \n     * @param txid A {@link https://github.com/feross/buffer|Buffer} containing the transaction ID of the referenced UTXO\n     * @param txidx A {@link https://github.com/feross/buffer|Buffer} containing the index of the output in the transaction consumed in the [[Input]]\n     * @param assetID A {@link https://github.com/feross/buffer|Buffer} representing the assetID of the [[Input]]\n     * @param amount A {@link https://github.com/indutny/bn.js/|BN} containing the amount of the output to be consumed\n     */\n    constructor(txid?:Buffer, txidx?:Buffer, amount?:BN, assetID?:Buffer) {\n        super(txid, txidx, assetID, AVMConstants.SECPINPUTID);\n        if(txid && txidx && amount && assetID){\n            this.inputid.writeUInt32BE(AVMConstants.SECPINPUTID,0);\n            this.txid = txid;\n            this.txidx = txidx;\n            this.assetid = assetID;\n            this.amountValue = amount;\n            this.amount = bintools.fromBNToBuffer(amount, 8);\n            this.sigIdxs = [];\n        }\n        \n    }\n}"]} |
@@ -32,7 +32,13 @@ /** | ||
/** | ||
* Returns the address. | ||
* Returns the address as a {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representation of the address | ||
*/ | ||
getAddress: () => Buffer; | ||
/** | ||
* Returns the address's string representation. | ||
* | ||
* @returns A string representation of the address | ||
*/ | ||
getAddress: () => string; | ||
getAddressString: () => string; | ||
/** | ||
@@ -43,5 +49,5 @@ * Returns an address given a public key. | ||
* | ||
* @returns A string for the address of the public key. | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address of the public key. | ||
*/ | ||
addressFromPublicKey: (pubk: Buffer) => string; | ||
addressFromPublicKey: (pubk: Buffer) => Buffer; | ||
/** | ||
@@ -88,3 +94,3 @@ * Returns a string representation of the private key. | ||
*/ | ||
constructor(entropy?: Buffer); | ||
constructor(chainid: string, entropy?: Buffer); | ||
} | ||
@@ -104,3 +110,3 @@ /** | ||
*/ | ||
makeKey: (entropy?: Buffer) => string; | ||
makeKey: (entropy?: Buffer) => Buffer; | ||
/** | ||
@@ -113,3 +119,3 @@ * Given a private key, makes a new key pair, returns the address. | ||
*/ | ||
importKey: (privk: string | Buffer) => string; | ||
importKey: (privk: string | Buffer) => Buffer; | ||
/** | ||
@@ -126,4 +132,4 @@ * Signs a [[TxUnsigned]] and returns signed [[Tx]] | ||
*/ | ||
constructor(); | ||
constructor(chainid: string); | ||
} | ||
//# sourceMappingURL=keychain.d.ts.map |
@@ -50,4 +50,4 @@ "use strict"; | ||
*/ | ||
constructor(entropy = undefined) { | ||
super(); | ||
constructor(chainid, entropy = undefined) { | ||
super(chainid); | ||
/** | ||
@@ -93,5 +93,5 @@ * @ignore | ||
/** | ||
* Returns the address. | ||
* Returns the address as a {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A string representation of the address | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representation of the address | ||
*/ | ||
@@ -102,2 +102,11 @@ this.getAddress = () => { | ||
/** | ||
* Returns the address's string representation. | ||
* | ||
* @returns A string representation of the address | ||
*/ | ||
this.getAddressString = () => { | ||
let addr = this.addressFromPublicKey(this.pubk); | ||
return bintools.addressToString(this.chainid, addr); | ||
}; | ||
/** | ||
* Returns an address given a public key. | ||
@@ -107,3 +116,3 @@ * | ||
* | ||
* @returns A string for the address of the public key. | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address of the public key. | ||
*/ | ||
@@ -119,4 +128,5 @@ this.addressFromPublicKey = (pubk) => { | ||
let ripesha = buffer_1.Buffer.from(create_hash_1.default('rmd160').update(sha256).digest()); | ||
address = bintools.avaSerialize(ripesha); | ||
return address; | ||
return ripesha; | ||
//address = bintools.avaSerialize(ripesha); | ||
//return address; | ||
} | ||
@@ -196,4 +206,4 @@ /* istanbul ignore next */ | ||
*/ | ||
constructor() { | ||
super(); | ||
constructor(chainid) { | ||
super(chainid); | ||
/** | ||
@@ -207,3 +217,3 @@ * Makes a new key pair, returns the address. | ||
this.makeKey = (entropy = undefined) => { | ||
let keypair = new AVMKeyPair(entropy); | ||
let keypair = new AVMKeyPair(this.chainid, entropy); | ||
this.addKey(keypair); | ||
@@ -220,3 +230,3 @@ return keypair.getAddress(); | ||
this.importKey = (privk) => { | ||
let keypair = new AVMKeyPair(); | ||
let keypair = new AVMKeyPair(this.chainid); | ||
let pk; | ||
@@ -230,3 +240,3 @@ if (typeof privk === 'string') { | ||
keypair.importKey(pk); | ||
if (!(keypair.getAddress() in this.keys)) { | ||
if (!(keypair.getAddress().toString("hex") in this.keys)) { | ||
this.addKey(keypair); | ||
@@ -265,2 +275,2 @@ } | ||
exports.AVMKeyChain = AVMKeyChain; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keychain.js","sourceRoot":"","sources":["../../../../src/apis/avm/keychain.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport * as elliptic from \"elliptic\";\nimport BinTools from '../../utils/bintools';\nimport { TxUnsigned, Tx } from './tx';\nimport { Signature, SigIdx } from './types';\nimport { SecpInput, Input } from './inputs';\nimport createHash from \"create-hash\";\nimport { KeyPair, KeyChain } from '../../utils/types';\n\n/**\n * @ignore\n */\nconst EC = elliptic.ec;\n\n/**\n * @ignore\n */\nconst ec = new EC('secp256k1');\n\n/**\n * @ignore\n */\nconst ecparams = ec.curve;\n\n/**\n * @ignore\n */\nconst BN = ecparams.n.constructor;\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n\n/**\n * Class for representing a private and public keypair in AVAJS. \n */\nexport class AVMKeyPair extends KeyPair {\n    protected keypair:elliptic.ec.KeyPair\n\n    /**\n     * @ignore\n     */\n    protected _sigFromSigBuffer = (sig:Buffer):elliptic.ec.SignatureOptions => {\n        let r = new BN(bintools.copyFrom(sig, 0, 32));\n        let s = new BN(bintools.copyFrom(sig, 32, 64));\n        let recoveryParam:number = bintools.copyFrom(sig, 64, 65).readUIntBE(0, 1);\n        let sigOpt = {\n            r:r,\n            s:s,\n            recoveryParam:recoveryParam\n        };\n        return sigOpt;\n    }\n\n    /**\n     * Generates a new keypair.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     */\n    generateKey = (entropy?:Buffer) => {\n        this.keypair = ec.genKeyPair();\n\n        // doing hex translation to get Buffer class\n        this.privk = Buffer.from(this.keypair.getPrivate(\"hex\"), \"hex\");\n        this.pubk = Buffer.from(this.keypair.getPublic(true, \"hex\"), \"hex\");\n    }\n\n    /**\n     * Imports a private key and generates the appropriate public key.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key \n     * \n     * @returns true on success, false on failure\n     */\n    importKey = (privk:Buffer):boolean => {\n        this.keypair = ec.keyFromPrivate(privk.toString(\"hex\"),\"hex\");\n        // doing hex translation to get Buffer class\n        this.privk = Buffer.from(this.keypair.getPrivate(\"hex\"), \"hex\");\n        this.pubk = Buffer.from(this.keypair.getPublic(true, \"hex\"), \"hex\");\n        return true; //silly I know, but the interface requires so it returns true on success, so if Buffer fails validation...\n    }\n\n    /**\n     * Returns the address.\n     * \n     * @returns A string representation of the address\n     */\n    getAddress = ():string => {\n        return this.addressFromPublicKey(this.pubk);\n    }\n\n    /**\n     * Returns an address given a public key.\n     * \n     * @param pubk A {@link https://github.com/feross/buffer|Buffer} representing the public key\n     * \n     * @returns A string for the address of the public key.\n     */\n    addressFromPublicKey = (pubk:Buffer): string => {\n        let address:string = \"\";\n        if(pubk.length == 65) {\n            /* istanbul ignore next */\n            pubk = Buffer.from(ec.keyFromPublic(pubk).getPublic(true, \"hex\"), \"hex\"); //make compact, stick back into buffer\n        } \n        if(pubk.length == 33){\n            let sha256:Buffer = Buffer.from(createHash('sha256').update(pubk).digest());\n            let ripesha:Buffer = Buffer.from(createHash('rmd160').update(sha256).digest());\n            address = bintools.avaSerialize(ripesha);\n            return address;\n        }\n        /* istanbul ignore next */\n        throw new Error(\"Unable to make address.\");\n    }\n\n    /**\n     * Returns a string representation of the private key.\n     * \n     * @returns An AVA serialized string representation of the public key\n     */\n    getPrivateKeyString = ():string => {\n        return bintools.avaSerialize(this.privk);\n    }\n\n    /**\n     * Returns the public key.\n     * \n     * @returns An AVA serialized string representation of the public key\n     */\n    getPublicKeyString = ():string => {\n        return bintools.avaSerialize(this.pubk);\n    }\n\n    /**\n     * Takes a message, signs it, and returns the signature.\n     * \n     * @param msg The message to sign, be sure to hash first if expected\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the signature\n     */\n    sign = (msg:Buffer):Buffer => {\n        let sigObj = this.keypair.sign(msg, undefined, { canonical: true });\n        let recovery:Buffer = Buffer.alloc(1);\n        recovery.writeUInt8(sigObj.recoveryParam, 0);\n        let r:Buffer = Buffer.from(sigObj.r.toArray(\"be\", 32)); //we have to skip native Buffer class, so this is the way\n        let s:Buffer = Buffer.from(sigObj.s.toArray(\"be\", 32)); //we have to skip native Buffer class, so this is the way\n        let result:Buffer = Buffer.concat([r,s, recovery], 65);\n        return result;\n    }\n    \n    /**\n     * Verifies that the private key associated with the provided public key produces the signature associated with the given message.\n     * \n     * @param msg The message associated with the signature\n     * @param sig The signature of the signed message\n     * \n     * @returns True on success, false on failure\n     */\n    verify = (msg:Buffer, sig:Buffer):boolean => { \n        let sigObj:elliptic.ec.SignatureOptions = this._sigFromSigBuffer(sig);\n        return ec.verify(msg, sigObj, this.keypair);\n    }\n\n    /**\n     * Recovers the public key of a message signer from a message and its associated signature.\n     * \n     * @param msg The message that's signed\n     * @param sig The signature that's signed on the message\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the public key of the signer\n     */\n    recover = (msg:Buffer, sig:Buffer):Buffer => {\n        let sigObj:elliptic.ec.SignatureOptions = this._sigFromSigBuffer(sig);\n        let pubk = ec.recoverPubKey(msg, sigObj, sigObj.recoveryParam);\n        return Buffer.from(pubk.encodeCompressed());\n    }\n\n    /**\n     * Class for representing a private and public keypair in AVAJS. \n     */\n    constructor(entropy:Buffer = undefined) {\n        super();\n        this.generateKey();\n    }\n    \n}\n\n/**\n * Class for representing a key chain in AVAJS. \n * \n * @typeparam AVMKeyPair Class extending [[KeyPair]] which is used as the key in [[AVMKeyChain]]\n */\nexport class AVMKeyChain extends KeyChain<AVMKeyPair> {\n\n    /**\n     * Makes a new key pair, returns the address.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     * \n     * @returns Address of the new key pair\n     */\n    makeKey = (entropy:Buffer = undefined):string => {\n        let keypair:AVMKeyPair = new AVMKeyPair(entropy);\n        this.addKey(keypair);\n        return keypair.getAddress();\n    }\n\n    /**\n     * Given a private key, makes a new key pair, returns the address.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} or AVA serialized string representing the private key \n     * \n     * @returns Address of the new key pair\n     */\n    importKey = (privk:Buffer | string):string => {\n        let keypair:AVMKeyPair = new AVMKeyPair();\n        let pk:Buffer;\n        if(typeof privk === 'string'){\n            pk = bintools.avaDeserialize(privk);\n        } else {\n            pk = bintools.copyFrom(privk);\n        }\n        keypair.importKey(pk);\n        if(!(keypair.getAddress() in this.keys)){\n            this.addKey(keypair);\n        }\n        return keypair.getAddress();\n    }\n\n    /**\n     * Signs a [[TxUnsigned]] and returns signed [[Tx]]\n     * \n     * @param utx A [[TxUnsigned]] that needs to be signed\n     * \n     * @returns A signed [[Tx]]\n     */\n    signTx = (utx:TxUnsigned):Tx => {\n        let txbuff = utx.toBuffer();\n        let msg:Buffer = Buffer.from(createHash('sha256').update(txbuff).digest()); \n        let sigs:Array<Array<Signature>> = [];\n        let ins:Array<Input> = utx.getIns();\n        for(let i = 0; i < ins.length; i++){\n            let arrsigs:Array<Signature> = [];\n            let sigidxs:Array<SigIdx> = (ins[i] as SecpInput).getSigIdxs();\n            for(let j = 0; j < sigidxs.length; j++){\n                let keypair:AVMKeyPair = this.getKey(sigidxs[j].getSource());\n                let signval:Buffer = keypair.sign(msg)\n                let sig:Signature = new Signature();\n                sig.fromBuffer(signval);\n                arrsigs.push(sig);\n            }\n            sigs.push(arrsigs);\n        }\n        return new Tx(utx, sigs);\n    }\n\n    /**\n     * Returns instance of AVMKeyChain.\n     */\n    constructor(){\n        super();\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keychain.js","sourceRoot":"","sources":["../../../../src/apis/avm/keychain.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport * as elliptic from \"elliptic\";\nimport BinTools from '../../utils/bintools';\nimport { TxUnsigned, Tx } from './tx';\nimport { Signature, SigIdx } from './types';\nimport { SecpInput, Input } from './inputs';\nimport createHash from \"create-hash\";\nimport { KeyPair, KeyChain } from '../../utils/types';\n\n/**\n * @ignore\n */\nconst EC = elliptic.ec;\n\n/**\n * @ignore\n */\nconst ec = new EC('secp256k1');\n\n/**\n * @ignore\n */\nconst ecparams = ec.curve;\n\n/**\n * @ignore\n */\nconst BN = ecparams.n.constructor;\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n\n/**\n * Class for representing a private and public keypair in AVAJS. \n */\nexport class AVMKeyPair extends KeyPair {\n    protected keypair:elliptic.ec.KeyPair\n\n    /**\n     * @ignore\n     */\n    protected _sigFromSigBuffer = (sig:Buffer):elliptic.ec.SignatureOptions => {\n        let r = new BN(bintools.copyFrom(sig, 0, 32));\n        let s = new BN(bintools.copyFrom(sig, 32, 64));\n        let recoveryParam:number = bintools.copyFrom(sig, 64, 65).readUIntBE(0, 1);\n        let sigOpt = {\n            r:r,\n            s:s,\n            recoveryParam:recoveryParam\n        };\n        return sigOpt;\n    }\n\n    /**\n     * Generates a new keypair.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     */\n    generateKey = (entropy?:Buffer) => {\n        this.keypair = ec.genKeyPair();\n\n        // doing hex translation to get Buffer class\n        this.privk = Buffer.from(this.keypair.getPrivate(\"hex\"), \"hex\");\n        this.pubk = Buffer.from(this.keypair.getPublic(true, \"hex\"), \"hex\");\n    }\n\n    /**\n     * Imports a private key and generates the appropriate public key.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key \n     * \n     * @returns true on success, false on failure\n     */\n    importKey = (privk:Buffer):boolean => {\n        this.keypair = ec.keyFromPrivate(privk.toString(\"hex\"),\"hex\");\n        // doing hex translation to get Buffer class\n        this.privk = Buffer.from(this.keypair.getPrivate(\"hex\"), \"hex\");\n        this.pubk = Buffer.from(this.keypair.getPublic(true, \"hex\"), \"hex\");\n        return true; //silly I know, but the interface requires so it returns true on success, so if Buffer fails validation...\n    }\n\n    /**\n     * Returns the address as a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} representation of the address\n     */\n    getAddress = ():Buffer => {\n        return this.addressFromPublicKey(this.pubk);\n    }\n\n    /**\n     * Returns the address's string representation.\n     * \n     * @returns A string representation of the address\n     */\n    getAddressString = ():string => {\n        let addr:Buffer = this.addressFromPublicKey(this.pubk);\n        return bintools.addressToString(this.chainid, addr);\n    }\n\n    /**\n     * Returns an address given a public key.\n     * \n     * @param pubk A {@link https://github.com/feross/buffer|Buffer} representing the public key\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} for the address of the public key.\n     */\n    addressFromPublicKey = (pubk:Buffer): Buffer => {\n        let address:string = \"\";\n        if(pubk.length == 65) {\n            /* istanbul ignore next */\n            pubk = Buffer.from(ec.keyFromPublic(pubk).getPublic(true, \"hex\"), \"hex\"); //make compact, stick back into buffer\n        } \n        if(pubk.length == 33){\n            let sha256:Buffer = Buffer.from(createHash('sha256').update(pubk).digest());\n            let ripesha:Buffer = Buffer.from(createHash('rmd160').update(sha256).digest());\n            return ripesha;\n            //address = bintools.avaSerialize(ripesha);\n            //return address;\n        }\n        /* istanbul ignore next */\n        throw new Error(\"Unable to make address.\");\n    }\n\n    /**\n     * Returns a string representation of the private key.\n     * \n     * @returns An AVA serialized string representation of the public key\n     */\n    getPrivateKeyString = ():string => {\n        return bintools.avaSerialize(this.privk);\n    }\n\n    /**\n     * Returns the public key.\n     * \n     * @returns An AVA serialized string representation of the public key\n     */\n    getPublicKeyString = ():string => {\n        return bintools.avaSerialize(this.pubk);\n    }\n\n    /**\n     * Takes a message, signs it, and returns the signature.\n     * \n     * @param msg The message to sign, be sure to hash first if expected\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the signature\n     */\n    sign = (msg:Buffer):Buffer => {\n        let sigObj = this.keypair.sign(msg, undefined, { canonical: true });\n        let recovery:Buffer = Buffer.alloc(1);\n        recovery.writeUInt8(sigObj.recoveryParam, 0);\n        let r:Buffer = Buffer.from(sigObj.r.toArray(\"be\", 32)); //we have to skip native Buffer class, so this is the way\n        let s:Buffer = Buffer.from(sigObj.s.toArray(\"be\", 32)); //we have to skip native Buffer class, so this is the way\n        let result:Buffer = Buffer.concat([r,s, recovery], 65);\n        return result;\n    }\n    \n    /**\n     * Verifies that the private key associated with the provided public key produces the signature associated with the given message.\n     * \n     * @param msg The message associated with the signature\n     * @param sig The signature of the signed message\n     * \n     * @returns True on success, false on failure\n     */\n    verify = (msg:Buffer, sig:Buffer):boolean => { \n        let sigObj:elliptic.ec.SignatureOptions = this._sigFromSigBuffer(sig);\n        return ec.verify(msg, sigObj, this.keypair);\n    }\n\n    /**\n     * Recovers the public key of a message signer from a message and its associated signature.\n     * \n     * @param msg The message that's signed\n     * @param sig The signature that's signed on the message\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the public key of the signer\n     */\n    recover = (msg:Buffer, sig:Buffer):Buffer => {\n        let sigObj:elliptic.ec.SignatureOptions = this._sigFromSigBuffer(sig);\n        let pubk = ec.recoverPubKey(msg, sigObj, sigObj.recoveryParam);\n        return Buffer.from(pubk.encodeCompressed());\n    }\n\n    /**\n     * Class for representing a private and public keypair in AVAJS. \n     */\n    constructor(chainid:string, entropy:Buffer = undefined) {\n        super(chainid);\n        this.generateKey();\n    }\n    \n}\n\n/**\n * Class for representing a key chain in AVAJS. \n * \n * @typeparam AVMKeyPair Class extending [[KeyPair]] which is used as the key in [[AVMKeyChain]]\n */\nexport class AVMKeyChain extends KeyChain<AVMKeyPair> {\n\n    /**\n     * Makes a new key pair, returns the address.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     * \n     * @returns Address of the new key pair\n     */\n    makeKey = (entropy:Buffer = undefined):Buffer => {\n        let keypair:AVMKeyPair = new AVMKeyPair(this.chainid, entropy);\n        this.addKey(keypair);\n        return keypair.getAddress();\n    }\n\n    /**\n     * Given a private key, makes a new key pair, returns the address.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} or AVA serialized string representing the private key \n     * \n     * @returns Address of the new key pair\n     */\n    importKey = (privk:Buffer | string):Buffer => {\n        let keypair:AVMKeyPair = new AVMKeyPair(this.chainid);\n        let pk:Buffer;\n        if(typeof privk === 'string'){\n            pk = bintools.avaDeserialize(privk);\n        } else {\n            pk = bintools.copyFrom(privk);\n        }\n        keypair.importKey(pk);\n        if(!(keypair.getAddress().toString(\"hex\") in this.keys)){\n            this.addKey(keypair);\n        }\n        return keypair.getAddress();\n    }\n\n    /**\n     * Signs a [[TxUnsigned]] and returns signed [[Tx]]\n     * \n     * @param utx A [[TxUnsigned]] that needs to be signed\n     * \n     * @returns A signed [[Tx]]\n     */\n    signTx = (utx:TxUnsigned):Tx => {\n        let txbuff = utx.toBuffer();\n        let msg:Buffer = Buffer.from(createHash('sha256').update(txbuff).digest()); \n        let sigs:Array<Array<Signature>> = [];\n        let ins:Array<Input> = utx.getIns();\n        for(let i = 0; i < ins.length; i++){\n            let arrsigs:Array<Signature> = [];\n            let sigidxs:Array<SigIdx> = (ins[i] as SecpInput).getSigIdxs();\n            for(let j = 0; j < sigidxs.length; j++){\n                let keypair:AVMKeyPair = this.getKey(sigidxs[j].getSource());\n                let signval:Buffer = keypair.sign(msg)\n                let sig:Signature = new Signature();\n                sig.fromBuffer(signval);\n                arrsigs.push(sig);\n            }\n            sigs.push(arrsigs);\n        }\n        return new Tx(utx, sigs);\n    }\n\n    /**\n     * Returns instance of AVMKeyChain.\n     */\n    constructor(chainid:string){\n        super(chainid);\n    }\n}"]} |
@@ -16,20 +16,18 @@ /** | ||
/** | ||
* An abstract representing a transaction output. All output types must extend on this class. | ||
* A class representing a transaction output. All output types must extend on this class. | ||
*/ | ||
export declare abstract class Output { | ||
export declare class Output { | ||
protected outputid: Buffer; | ||
protected outputidnum: number; | ||
protected assetid: Buffer; | ||
abstract getOutputID: () => number; | ||
abstract getAssetID: () => Buffer; | ||
abstract fromBuffer: (utxobuff: Buffer) => number; | ||
abstract toBuffer: () => Buffer; | ||
abstract toString: () => string; | ||
getOutputID: () => number; | ||
fromBuffer(outbuff: Buffer, offset?: number): number; | ||
toBuffer(): Buffer; | ||
toString(): string; | ||
static comparator: () => (a: Output, b: Output) => 0 | 1 | -1; | ||
constructor(outputidnum: number, assetID?: Buffer); | ||
constructor(outputidnum: number); | ||
} | ||
/** | ||
* An [[Output]] class which issues a payment on an assetID. | ||
* An [[Output]] class which specifies a secp256k1 . | ||
*/ | ||
export declare class SecpOutput extends Output { | ||
export declare class SecpOutBase extends Output { | ||
protected locktime: Buffer; | ||
@@ -42,12 +40,2 @@ protected threshold: Buffer; | ||
/** | ||
* @ignore | ||
*/ | ||
protected _OPGetAddresses: () => { | ||
[address: string]: BN; | ||
}; | ||
/** | ||
* Returns the number for the output type of the output class. | ||
*/ | ||
getOutputID: () => number; | ||
/** | ||
* Returns the amount as a {@link https://github.com/indutny/bn.js/|BN}. | ||
@@ -65,19 +53,13 @@ */ | ||
/** | ||
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}. | ||
* Returns an array of {@link https://github.com/feross/buffer|Buffer}s for the addresses. | ||
*/ | ||
getAssetID: () => Buffer; | ||
getAddresses: () => Buffer[]; | ||
/** | ||
* Returns a map from all addresses as string keys to their locktime represented in {@link https://github.com/indutny/bn.js/|BN}. | ||
*/ | ||
getAddresses: () => { | ||
[address: string]: BN; | ||
}; | ||
/** | ||
* Returns an array of length 2 with the first index being the index of the provided address and the second being false (as fallback addresses are not available in this output type). | ||
* Returns the index of the address. | ||
* | ||
* @param address Address to look up to return its index. | ||
* @param address A {@link https://github.com/feross/buffer|Buffer} of the address to look up to return its index. | ||
* | ||
* @returns An array of length 2, first index is the index the address resides in, second index is false. | ||
* @returns The index of the address. | ||
*/ | ||
getAddressIdx: (address: string) => number; | ||
getAddressIdx: (address: Buffer) => number; | ||
/** | ||
@@ -90,36 +72,24 @@ * Returns the address from the index provided. | ||
*/ | ||
getAddress: (idx: number) => string; | ||
getAddress: (idx: number) => Buffer; | ||
/** | ||
* @ignore | ||
* Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[SecpOutBase]] and returns the size of the output. | ||
*/ | ||
protected _OPParseBuffer: (utxobuff: Buffer, offset: number) => number; | ||
fromBuffer(utxobuff: Buffer, offset?: number): number; | ||
/** | ||
* Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[OutCreateAsset]] and returns the size of the output. | ||
* Returns the buffer representing the [[SecpOutBase]] instance. | ||
*/ | ||
fromBuffer: (utxobuff: Buffer) => number; | ||
toBuffer(): Buffer; | ||
/** | ||
* @ignore | ||
* Returns a base-58 string representing the [[SecpOutBase]]. | ||
*/ | ||
protected _OPBuffer: () => Buffer; | ||
toString(): string; | ||
/** | ||
* Returns the buffer representing the [[OutCreateAsset]] instance. | ||
* Given an array of addresses and an optional timestamp, select an array of address {@link https://github.com/feross/buffer|Buffer}s of qualified spenders for the output. | ||
*/ | ||
toBuffer: () => Buffer; | ||
getSpenders: (addresses: Buffer[], asOf?: BN) => Buffer[]; | ||
/** | ||
* Returns a base-58 string representing the [[OutCreateAsset]]. | ||
* Given an array of address {@link https://github.com/feross/buffer|Buffer}s and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
toString: () => string; | ||
meetsThreshold: (addresses: Buffer[], asOf?: BN) => boolean; | ||
/** | ||
* @ignore | ||
*/ | ||
protected _OPQualified: (addresses: string[], asOf?: BN) => string[]; | ||
/** | ||
* Given an array of addresses and an optional timestamp, select an array of address strings of qualified spenders for the output. | ||
*/ | ||
getSpenders: (addresses: string[], asOf?: BN) => string[]; | ||
/** | ||
* Given an array of addresses and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
meetsThreshold: (addresses: string[], asOf?: BN) => boolean; | ||
/** | ||
* An [[Output]] class which issues a payment on an assetID. | ||
@@ -129,8 +99,18 @@ * | ||
* @param amount A {@link https://github.com/indutny/bn.js/|BN} representing the amount in the output | ||
* @param addresses An array of strings representing addresses | ||
* @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses | ||
* @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime | ||
* @param threshold A number representing the the threshold number of signers required to sign the transaction | ||
*/ | ||
constructor(assetid: Buffer, amount?: BN, addresses?: Array<string>, locktime?: BN, threshold?: number); | ||
constructor(amount?: BN, addresses?: Array<Buffer>, locktime?: BN, threshold?: number); | ||
} | ||
export declare class SecpOutput extends SecpOutBase { | ||
protected assetid: Buffer; | ||
fromBuffer(outbuff: Buffer, offset?: number): number; | ||
toBuffer(): Buffer; | ||
/** | ||
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
getAssetID: () => Buffer; | ||
constructor(assetid?: Buffer, amount?: BN, addresses?: Array<Buffer>, locktime?: BN, threshold?: number); | ||
} | ||
//# sourceMappingURL=outputs.d.ts.map |
@@ -14,3 +14,2 @@ "use strict"; | ||
const bintools = bintools_1.default.getInstance(); | ||
const SECPFXID = 4; | ||
/** | ||
@@ -24,5 +23,5 @@ * Takes a buffer representing the output and returns the proper Output instance. | ||
exports.SelectOutputClass = (outbuffer, args = []) => { | ||
let assetid = bintools.copyFrom(outbuffer, 0, 32); | ||
let outputid = outbuffer.readUInt32BE(32); | ||
if (outputid == types_1.Constants.SECPOUTPUTID) { | ||
let assetid = bintools.copyFrom(outbuffer, 0, types_1.AVMConstants.ASSETIDLEN); | ||
let outputid = outbuffer.readUInt32BE(types_1.AVMConstants.ASSETIDLEN); | ||
if (outputid == types_1.AVMConstants.SECPOUTPUTID) { | ||
let secpout = new SecpOutput(assetid, ...args); | ||
@@ -35,14 +34,27 @@ secpout.fromBuffer(outbuffer); | ||
/** | ||
* An abstract representing a transaction output. All output types must extend on this class. | ||
* A class representing a transaction output. All output types must extend on this class. | ||
*/ | ||
class Output { | ||
constructor(outputidnum, assetID) { | ||
constructor(outputidnum) { | ||
this.outputid = buffer_1.Buffer.alloc(4); | ||
this.assetid = buffer_1.Buffer.alloc(32); | ||
this.getOutputID = () => { | ||
return this.outputidnum; | ||
}; | ||
this.outputid.writeUInt32BE(outputidnum, 0); | ||
this.outputidnum = outputidnum; | ||
if (assetID) { | ||
this.assetid = assetID; | ||
} | ||
} | ||
fromBuffer(outbuff, offset = 0) { | ||
this.outputid = bintools.copyFrom(outbuff, offset, offset + 4); | ||
this.outputidnum = this.outputid.readUInt32BE(0); | ||
return offset + 4; | ||
} | ||
; | ||
toBuffer() { | ||
return this.outputid; | ||
} | ||
; | ||
toString() { | ||
return bintools.bufferToB58(this.outputid); | ||
} | ||
; | ||
} | ||
@@ -56,5 +68,5 @@ exports.Output = Output; | ||
/** | ||
* An [[Output]] class which issues a payment on an assetID. | ||
* An [[Output]] class which specifies a secp256k1 . | ||
*/ | ||
class SecpOutput extends Output { | ||
class SecpOutBase extends Output { | ||
/** | ||
@@ -65,8 +77,8 @@ * An [[Output]] class which issues a payment on an assetID. | ||
* @param amount A {@link https://github.com/indutny/bn.js/|BN} representing the amount in the output | ||
* @param addresses An array of strings representing addresses | ||
* @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses | ||
* @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime | ||
* @param threshold A number representing the the threshold number of signers required to sign the transaction | ||
*/ | ||
constructor(assetid, amount, addresses, locktime, threshold) { | ||
super(SECPFXID, assetid); | ||
constructor(amount, addresses, locktime, threshold) { | ||
super(types_1.AVMConstants.SECPOUTPUTID); | ||
this.locktime = buffer_1.Buffer.alloc(8); | ||
@@ -79,18 +91,2 @@ this.threshold = buffer_1.Buffer.alloc(4); | ||
/** | ||
* @ignore | ||
*/ | ||
this._OPGetAddresses = () => { | ||
let result = {}; | ||
for (let i = 0; i < this.addresses.length; i++) { | ||
result[this.addresses[i].toString()] = bintools.fromBufferToBN(this.locktime); | ||
} | ||
return result; | ||
}; | ||
/** | ||
* Returns the number for the output type of the output class. | ||
*/ | ||
this.getOutputID = () => { | ||
return this.outputidnum; | ||
}; | ||
/** | ||
* Returns the amount as a {@link https://github.com/indutny/bn.js/|BN}. | ||
@@ -114,23 +110,21 @@ */ | ||
/** | ||
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}. | ||
* Returns an array of {@link https://github.com/feross/buffer|Buffer}s for the addresses. | ||
*/ | ||
this.getAssetID = () => { | ||
return this.assetid; | ||
}; | ||
/** | ||
* Returns a map from all addresses as string keys to their locktime represented in {@link https://github.com/indutny/bn.js/|BN}. | ||
*/ | ||
this.getAddresses = () => { | ||
return this._OPGetAddresses(); | ||
let result = []; | ||
for (let i = 0; i < this.addresses.length; i++) { | ||
result.push(this.addresses[i].toBuffer()); | ||
} | ||
return result; | ||
}; | ||
/** | ||
* Returns an array of length 2 with the first index being the index of the provided address and the second being false (as fallback addresses are not available in this output type). | ||
* Returns the index of the address. | ||
* | ||
* @param address Address to look up to return its index. | ||
* @param address A {@link https://github.com/feross/buffer|Buffer} of the address to look up to return its index. | ||
* | ||
* @returns An array of length 2, first index is the index the address resides in, second index is false. | ||
* @returns The index of the address. | ||
*/ | ||
this.getAddressIdx = (address) => { | ||
for (let i = 0; i < this.addresses.length; i++) { | ||
if (this.addresses[i].toString() == address) { | ||
if (this.addresses[i].toBuffer().toString("hex") == address.toString("hex")) { | ||
return i; | ||
@@ -151,83 +145,10 @@ } | ||
if (idx < this.addresses.length) { | ||
return this.addresses[idx].toString(); | ||
return this.addresses[idx].toBuffer(); | ||
} | ||
throw new Error("Error - OutPayment.getAddress: idx out of range"); | ||
throw new Error("Error - SecpOutBase.getAddress: idx out of range"); | ||
}; | ||
/** | ||
* @ignore | ||
* Given an array of addresses and an optional timestamp, select an array of address {@link https://github.com/feross/buffer|Buffer}s of qualified spenders for the output. | ||
*/ | ||
this._OPParseBuffer = (utxobuff, offset) => { | ||
this.assetid = bintools.copyFrom(utxobuff, offset, offset + 32); | ||
offset += 32; | ||
this.outputid = bintools.copyFrom(utxobuff, offset, offset + 4); //copied | ||
this.outputidnum = this.outputid.readUInt32BE(0); | ||
offset += 4; | ||
this.amount = bintools.copyFrom(utxobuff, offset, offset + 8); | ||
this.amountValue = bintools.fromBufferToBN(this.amount); | ||
offset += 8; | ||
this.locktime = bintools.copyFrom(utxobuff, offset, offset + 8); | ||
offset += 8; | ||
this.threshold = bintools.copyFrom(utxobuff, offset, offset + 4); | ||
offset += 4; | ||
this.numaddrs = bintools.copyFrom(utxobuff, offset, offset + 4); | ||
offset += 4; | ||
let numaddrs = this.numaddrs.readUInt32BE(0); | ||
this.addresses = []; | ||
for (let i = 0; i < numaddrs; i++) { | ||
let addr = new types_1.Address(); | ||
let offsetEnd = offset + addr.getSize(); | ||
let copied = bintools.copyFrom(utxobuff, offset, offsetEnd); | ||
addr.fromBuffer(copied); | ||
this.addresses.push(addr); | ||
offset = offsetEnd; | ||
} | ||
this.addresses.sort(types_1.Address.comparitor()); | ||
return offset; | ||
}; | ||
/** | ||
* Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[OutCreateAsset]] and returns the size of the output. | ||
*/ | ||
this.fromBuffer = (utxobuff) => { | ||
return this._OPParseBuffer(utxobuff, 0); | ||
}; | ||
/** | ||
* @ignore | ||
*/ | ||
this._OPBuffer = () => { | ||
try { | ||
this.addresses.sort(types_1.Address.comparitor()); | ||
let bsize = this.assetid.length + this.outputid.length + this.amount.length + this.locktime.length + this.threshold.length + this.numaddrs.length; | ||
this.numaddrs.writeUInt32BE(this.addresses.length, 0); | ||
let barr = [this.assetid, this.outputid, this.amount, this.locktime, this.threshold, this.numaddrs]; | ||
for (let i = 0; i < this.addresses.length; i++) { | ||
let b = this.addresses[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - TxOut._OPTxBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
}; | ||
/** | ||
* Returns the buffer representing the [[OutCreateAsset]] instance. | ||
*/ | ||
this.toBuffer = () => { | ||
return this._OPBuffer(); | ||
}; | ||
/** | ||
* Returns a base-58 string representing the [[OutCreateAsset]]. | ||
*/ | ||
this.toString = () => { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
}; | ||
/** | ||
* @ignore | ||
*/ | ||
this._OPQualified = (addresses, asOf = undefined) => { | ||
this.getSpenders = (addresses, asOf = undefined) => { | ||
let qualified = []; | ||
@@ -248,3 +169,3 @@ let now; | ||
for (let j = 0; j < addresses.length && qualified.length < threshold; j++) { | ||
if (addresses[j] == this.addresses[i].toString()) { | ||
if (addresses[j].toString("hex") == this.addresses[i].toBuffer().toString("hex")) { | ||
qualified.push(addresses[j]); | ||
@@ -257,10 +178,4 @@ } | ||
/** | ||
* Given an array of addresses and an optional timestamp, select an array of address strings of qualified spenders for the output. | ||
* Given an array of address {@link https://github.com/feross/buffer|Buffer}s and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
this.getSpenders = (addresses, asOf = undefined) => { | ||
return this._OPQualified(addresses, asOf); | ||
}; | ||
/** | ||
* Given an array of addresses and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
this.meetsThreshold = (addresses, asOf = undefined) => { | ||
@@ -274,8 +189,4 @@ let now; | ||
} | ||
let locktime = bintools.fromBufferToBN(this.locktime); | ||
let qualified = this._OPQualified(addresses, now); | ||
let qualified = this.getSpenders(addresses, now); | ||
let threshold = this.threshold.readUInt32BE(0); | ||
if (now.lte(locktime)) { | ||
return false; | ||
} | ||
if (qualified.length >= threshold) { | ||
@@ -292,3 +203,3 @@ return true; | ||
addrs[i] = new types_1.Address(); | ||
addrs[i].fromString(addresses[i]); | ||
addrs[i].fromBuffer(addresses[i]); | ||
} | ||
@@ -306,4 +217,88 @@ this.addresses = addrs; | ||
} | ||
/** | ||
* Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[SecpOutBase]] and returns the size of the output. | ||
*/ | ||
fromBuffer(utxobuff, offset = 0) { | ||
offset = super.fromBuffer(utxobuff, offset); | ||
this.amount = bintools.copyFrom(utxobuff, offset, offset + 8); | ||
this.amountValue = bintools.fromBufferToBN(this.amount); | ||
offset += 8; | ||
this.locktime = bintools.copyFrom(utxobuff, offset, offset + 8); | ||
offset += 8; | ||
this.threshold = bintools.copyFrom(utxobuff, offset, offset + 4); | ||
offset += 4; | ||
this.numaddrs = bintools.copyFrom(utxobuff, offset, offset + 4); | ||
offset += 4; | ||
let numaddrs = this.numaddrs.readUInt32BE(0); | ||
this.addresses = []; | ||
for (let i = 0; i < numaddrs; i++) { | ||
let addr = new types_1.Address(); | ||
let offsetEnd = offset + addr.getSize(); | ||
let copied = bintools.copyFrom(utxobuff, offset, offsetEnd); | ||
addr.fromBuffer(copied); | ||
this.addresses.push(addr); | ||
offset = offsetEnd; | ||
} | ||
this.addresses.sort(types_1.Address.comparitor()); | ||
return offset; | ||
} | ||
/** | ||
* Returns the buffer representing the [[SecpOutBase]] instance. | ||
*/ | ||
toBuffer() { | ||
try { | ||
this.addresses.sort(types_1.Address.comparitor()); | ||
let superbuff = super.toBuffer(); | ||
let bsize = superbuff.length + this.amount.length + this.locktime.length + this.threshold.length + this.numaddrs.length; | ||
this.numaddrs.writeUInt32BE(this.addresses.length, 0); | ||
let barr = [superbuff, this.amount, this.locktime, this.threshold, this.numaddrs]; | ||
for (let i = 0; i < this.addresses.length; i++) { | ||
let b = this.addresses[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
return buffer_1.Buffer.concat(barr, bsize); | ||
; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - SecpOutBase.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
/** | ||
* Returns a base-58 string representing the [[SecpOutBase]]. | ||
*/ | ||
toString() { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
} | ||
} | ||
exports.SecpOutBase = SecpOutBase; | ||
class SecpOutput extends SecpOutBase { | ||
constructor(assetid, amount, addresses, locktime, threshold) { | ||
super(amount, addresses, locktime, threshold); | ||
this.assetid = buffer_1.Buffer.alloc(32); | ||
/** | ||
* Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
this.getAssetID = () => { | ||
return this.assetid; | ||
}; | ||
if (typeof assetid !== 'undefined' && assetid.length == types_1.AVMConstants.ASSETIDLEN) { | ||
this.assetid = assetid; | ||
} | ||
} | ||
fromBuffer(outbuff, offset = 0) { | ||
this.assetid = bintools.copyFrom(outbuff, offset, offset + 32); | ||
offset += 32; | ||
offset = super.fromBuffer(outbuff, offset); | ||
return offset; | ||
} | ||
toBuffer() { | ||
let superbuff = super.toBuffer(); | ||
return buffer_1.Buffer.concat([this.assetid, superbuff]); | ||
} | ||
} | ||
exports.SecpOutput = SecpOutput; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../../../src/apis/avm/outputs.ts"],"names":[],"mappings":";;;;;AAAA;;GAEG;AACH,oCAA+B;AAC/B,oEAA4C;AAC5C,kDAAuB;AACvB,mCAAsD;AAEtD,MAAM,QAAQ,GAAG,kBAAQ,CAAC,WAAW,EAAE,CAAC;AAExC,MAAM,QAAQ,GAAG,CAAC,CAAC;AAEnB;;;;;;GAMG;AACU,QAAA,iBAAiB,GAAG,CAAC,SAAgB,EAAE,OAAkB,EAAE,EAAS,EAAE;IAC/E,IAAI,OAAO,GAAU,QAAQ,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACzD,IAAI,QAAQ,GAAU,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;IACjD,IAAG,QAAQ,IAAI,iBAAS,CAAC,YAAY,EAAC;QAClC,IAAI,OAAO,GAAc,IAAI,UAAU,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1D,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QAC9B,OAAO,OAAO,CAAC;KAClB;IACD,MAAM,IAAI,KAAK,CAAC,8CAA8C,GAAG,QAAQ,CAAC,CAAC;AAC/E,CAAC,CAAA;AAED;;GAEG;AACH,MAAsB,MAAM;IAkBxB,YAAY,WAAkB,EAAE,OAAe;QAjBrC,aAAQ,GAAU,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAElC,YAAO,GAAU,eAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAgBxC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAG,OAAO,EAAC;YACP,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;SAC1B;IACL,CAAC;;AAxBL,wBAyBC;AAbU,iBAAU,GAAG,GAAoC,EAAE;IACtD,OAAO,UAAS,CAAQ,EAAE,CAAQ;QAC9B,OAAO,eAAM,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAa,CAAC;IAClE,CAAC,CAAA;AACL,CAAC,CAAA;AAWL;;GAEG;AACH,MAAa,UAAW,SAAQ,MAAM;IAoOlC;;;;;;;;OAQG;IACH,YAAY,OAAc,EAAE,MAAU,EAAE,SAAwB,EAAE,QAAY,EAAE,SAAiB;QAC7F,KAAK,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QA7OnB,aAAQ,GAAU,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAClC,cAAS,GAAU,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,aAAQ,GAAU,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAClC,cAAS,GAAkB,EAAE,CAAC;QAC9B,WAAM,GAAU,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAChC,gBAAW,GAAM,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC;QAErC;;WAEG;QACO,oBAAe,GAAG,GAA0B,EAAE;YACpD,IAAI,MAAM,GAA0B,EAAE,CAAC;YACvC,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC3C,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACjF;YACD,OAAO,MAAM,CAAC;QAClB,CAAC,CAAA;QAED;;WAEG;QACH,gBAAW,GAAG,GAAU,EAAE;YACtB,OAAO,IAAI,CAAC,WAAW,CAAC;QAC5B,CAAC,CAAC;QAEF;;WAEG;QACH,cAAS,GAAG,GAAM,EAAE;YAChB,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACpC,CAAC,CAAA;QAED;;WAEG;QACH,iBAAY,GAAG,GAAU,EAAE;YACvB,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAA;QAED;;WAEG;QACH,gBAAW,GAAG,GAAM,EAAE;YAClB,OAAO,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClD,CAAC,CAAA;QAED;;WAEG;QACH,eAAU,GAAG,GAAU,EAAE;YACrB,OAAO,IAAI,CAAC,OAAO,CAAC;QACxB,CAAC,CAAA;QAED;;WAEG;QACH,iBAAY,GAAG,GAA0B,EAAE;YACvC,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;QAClC,CAAC,CAAA;QAED;;;;;;WAMG;QACH,kBAAa,GAAG,CAAC,OAAc,EAAS,EAAE;YACtC,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;gBAC1C,IAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,OAAO,EAAC;oBACvC,OAAO,CAAC,CAAA;iBACX;aACJ;YACD,0BAA0B;YAC1B,OAAO,CAAC,CAAC,CAAC;QACd,CAAC,CAAA;QAED;;;;;;WAMG;QACH,eAAU,GAAG,CAAC,GAAU,EAAS,EAAE;YAC/B,IAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAC;gBAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aACzC;YACD,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;QACvE,CAAC,CAAA;QAED;;WAEG;QACO,mBAAc,GAAG,CAAC,QAAe,EAAE,MAAa,EAAS,EAAE;YACjE,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAC;YAChE,MAAM,IAAI,EAAE,CAAC;YACb,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ;YACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACjD,MAAM,IAAI,CAAC,CAAC;YACZ,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;YAC9D,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACxD,MAAM,IAAI,CAAC,CAAC;YACZ,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;YAChE,MAAM,IAAI,CAAC,CAAC;YACZ,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;YACjE,MAAM,IAAI,CAAC,CAAC;YACZ,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;YAChE,MAAM,IAAI,CAAC,CAAC;YACZ,IAAI,QAAQ,GAAU,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACpD,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YACpB,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAC;gBAC7B,IAAI,IAAI,GAAW,IAAI,eAAO,EAAE,CAAC;gBACjC,IAAI,SAAS,GAAU,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;gBAC/C,IAAI,MAAM,GAAU,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;gBACnE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;gBACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC1B,MAAM,GAAG,SAAS,CAAC;aACtB;YACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,CAAC;YAC1C,OAAO,MAAM,CAAC;QAClB,CAAC,CAAA;QAED;;WAEG;QACH,eAAU,GAAG,CAAC,QAAe,EAAS,EAAE;YACpC,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;QAC5C,CAAC,CAAA;QAED;;WAEG;QACO,cAAS,GAAG,GAAW,EAAE;YAC/B,IAAI;gBACA,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,CAAC;gBAC1C,IAAI,KAAK,GAAW,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAC1J,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;gBACtD,IAAI,IAAI,GAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAClH,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAC3C,IAAI,CAAC,GAAW,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;oBAC7C,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBACb,KAAK,IAAI,CAAC,CAAC,MAAM,CAAC;iBACrB;gBACD,IAAI,IAAI,GAAW,eAAM,CAAC,MAAM,CAAC,IAAI,EAAC,KAAK,CAAC,CAAC;gBAC7C,OAAO,IAAI,CAAC;aACf;YAAC,OAAM,CAAC,EAAE;gBACP,0BAA0B;gBAC1B,IAAI,IAAI,GAAU,6BAA6B,GAAG,CAAC,CAAC;gBACpD,0BAA0B;gBAC1B,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC;aACzB;QACL,CAAC,CAAA;QAED;;WAEG;QACH,aAAQ,GAAG,GAAU,EAAE;YACnB,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC;QAC5B,CAAC,CAAA;QAED;;WAEG;QACH,aAAQ,GAAG,GAAU,EAAE;YACnB,OAAO,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACjD,CAAC,CAAA;QAED;;WAEG;QACO,iBAAY,GAAG,CAAC,SAAuB,EAAE,OAAU,SAAS,EAAgB,EAAE;YACpF,IAAI,SAAS,GAAiB,EAAE,CAAC;YACjC,IAAI,GAAM,CAAC;YACX,IAAG,OAAO,IAAI,KAAK,WAAW,EAAC;gBAC3B,GAAG,GAAG,eAAO,EAAE,CAAC;aACnB;iBAAM;gBACH,GAAG,GAAG,IAAI,CAAC;aACd;YACD,IAAI,QAAQ,GAAM,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzD,IAAG,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAC,EAAE,6BAA6B;gBAChD,OAAO,SAAS,CAAC;aACpB;YAED,IAAI,SAAS,GAAU,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAEtD,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,SAAS,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;gBAC3E,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,IAAI,SAAS,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC,EAAE,EAAC;oBACrE,IAAG,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAC;wBAC5C,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;qBAChC;iBACJ;aACJ;YAED,OAAO,SAAS,CAAC;QACrB,CAAC,CAAA;QAED;;WAEG;QACH,gBAAW,GAAG,CAAC,SAAuB,EAAE,OAAU,SAAS,EAAgB,EAAE;YACzE,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC9C,CAAC,CAAA;QAED;;WAEG;QACH,mBAAc,GAAG,CAAC,SAAuB,EAAE,OAAU,SAAS,EAAU,EAAE;YACtE,IAAI,GAAM,CAAC;YACX,IAAG,OAAO,IAAI,KAAK,WAAW,EAAC;gBAC3B,GAAG,GAAG,eAAO,EAAE,CAAC;aACnB;iBAAM;gBACH,GAAG,GAAG,IAAI,CAAC;aACd;YACD,IAAI,QAAQ,GAAM,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzD,IAAI,SAAS,GAAiB,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;YAChE,IAAI,SAAS,GAAU,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACtD,IAAG,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAC;gBACjB,OAAO,KAAK,CAAC;aAChB;YACD,IAAG,SAAS,CAAC,MAAM,IAAI,SAAS,EAAC;gBAC7B,OAAO,IAAI,CAAC;aACf;YAED,OAAO,KAAK,CAAC;QACjB,CAAC,CAAA;QAaG,IAAG,MAAM,IAAI,SAAS,EAAC;YACnB,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;YAClC,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACjD,IAAI,KAAK,GAAkB,EAAE,CAAC;YAC9B,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;gBACrC,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,eAAO,EAAE,CAAC;gBACzB,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;aACrC;YACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,CAAC;YAC1C,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACtD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC7D,IAAG,CAAC,CAAC,QAAQ,CAAC,EAAC;gBACX,0BAA0B;gBAC1B,QAAQ,GAAG,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC;aACxB;YACD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;SACxD;IACL,CAAC;CACJ;AAlQD,gCAkQC","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport BinTools from '../../utils/bintools';\nimport BN from \"bn.js\";\nimport { Address, UnixNow, Constants } from './types';\n\nconst bintools = BinTools.getInstance();\n\nconst SECPFXID = 4;\n\n/**\n * Takes a buffer representing the output and returns the proper Output instance.\n * \n * @param outbuffer A {@link https://github.com/feross/buffer|Buffer} containing the Output raw data.\n * \n * @returns An instance of an [[Output]]-extended class: [[OutputPayment]], [[OutTakeOrLeave]], [[OutCreateAsset]].\n */\nexport const SelectOutputClass = (outbuffer:Buffer, args:Array<any> = []):Output => {\n    let assetid:Buffer = bintools.copyFrom(outbuffer, 0, 32);\n    let outputid:number = outbuffer.readUInt32BE(32);\n    if(outputid == Constants.SECPOUTPUTID){\n        let secpout:SecpOutput = new SecpOutput(assetid, ...args);\n        secpout.fromBuffer(outbuffer);\n        return secpout;\n    }\n    throw new Error(\"Error - SelectOutputClass: unknown outputid \" + outputid);\n}\n\n/**\n * An abstract representing a transaction output. All output types must extend on this class.\n */\nexport abstract class Output {\n    protected outputid:Buffer = Buffer.alloc(4);\n    protected outputidnum:number;\n    protected assetid:Buffer = Buffer.alloc(32);\n\n    abstract getOutputID:() => number;\n    abstract getAssetID:() => Buffer;\n\n    abstract fromBuffer:(utxobuff:Buffer) => number;\n    abstract toBuffer:() => Buffer;\n    abstract toString:() => string;\n\n    static comparator = ():(a:Output, b:Output) => (1|-1|0) => {\n        return function(a:Output, b:Output):(1|-1|0) { \n            return Buffer.compare(a.toBuffer(), b.toBuffer()) as (1|-1|0);\n        }\n    }\n\n    constructor(outputidnum:number, assetID?:Buffer) {\n        this.outputid.writeUInt32BE(outputidnum, 0);\n        this.outputidnum = outputidnum;\n        if(assetID){\n            this.assetid = assetID;\n        }\n    }\n}\n\n/**\n * An [[Output]] class which issues a payment on an assetID.\n */\nexport class SecpOutput extends Output {\n    protected locktime:Buffer = Buffer.alloc(8);\n    protected threshold:Buffer = Buffer.alloc(4);\n    protected numaddrs:Buffer = Buffer.alloc(4);\n    protected addresses:Array<Address> = [];\n    protected amount:Buffer = Buffer.alloc(8);\n    protected amountValue:BN = new BN(0);\n\n    /**\n     * @ignore\n     */\n    protected _OPGetAddresses = ():{[address:string]: BN} => {\n        let result:{[address:string]: BN} = {};\n        for(let i = 0; i < this.addresses.length; i++) {\n            result[this.addresses[i].toString()] = bintools.fromBufferToBN(this.locktime);\n        }\n        return result;\n    }\n\n    /**\n     * Returns the number for the output type of the output class.\n     */\n    getOutputID = ():number => {\n        return this.outputidnum;\n    };\n\n    /**\n     * Returns the amount as a {@link https://github.com/indutny/bn.js/|BN}.\n     */\n    getAmount = ():BN => {\n        return this.amountValue.clone();\n    }\n\n    /**\n     * Returns the threshold of signers required to spend this output.\n     */\n    getThreshold = ():number => {\n        return this.threshold.readUInt32BE(0);\n    }\n\n    /**\n     * Returns the a {@link https://github.com/indutny/bn.js/|BN} repersenting the UNIX Timestamp when the lock is made available.\n     */\n    getLocktime = ():BN => {\n        return bintools.fromBufferToBN(this.locktime);\n    }\n\n    /**\n     * Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}.\n     */\n    getAssetID = ():Buffer => {\n        return this.assetid;\n    }\n\n    /**\n     * Returns a map from all addresses as string keys to their locktime represented in {@link https://github.com/indutny/bn.js/|BN}.\n     */\n    getAddresses = ():{[address:string]: BN} => {\n        return this._OPGetAddresses();\n    }\n\n    /**\n     * Returns an array of length 2 with the first index being the index of the provided address and the second being false (as fallback addresses are not available in this output type).\n     * \n     * @param address Address to look up to return its index.\n     * \n     * @returns An array of length 2, first index is the index the address resides in, second index is false.\n     */\n    getAddressIdx = (address:string):number => {\n        for(let i = 0; i < this.addresses.length; i++){\n            if(this.addresses[i].toString() == address){\n                return i\n            }\n        }\n        /* istanbul ignore next */\n        return -1;\n    }\n\n    /**\n     * Returns the address from the index provided.\n     * \n     * @param idx The index of the address.\n     * \n     * @returns Returns the string representing the address.\n     */\n    getAddress = (idx:number):string => {\n        if(idx < this.addresses.length){\n            return this.addresses[idx].toString();\n        }\n        throw new Error(\"Error - OutPayment.getAddress: idx out of range\");\n    }\n\n    /**\n     * @ignore\n     */\n    protected _OPParseBuffer = (utxobuff:Buffer, offset:number):number => {\n        this.assetid = bintools.copyFrom(utxobuff, offset, offset + 32);\n        offset += 32;\n        this.outputid = bintools.copyFrom(utxobuff, offset, offset + 4); //copied\n        this.outputidnum = this.outputid.readUInt32BE(0);\n        offset += 4;\n        this.amount = bintools.copyFrom(utxobuff, offset, offset + 8);\n        this.amountValue = bintools.fromBufferToBN(this.amount);\n        offset += 8;\n        this.locktime = bintools.copyFrom(utxobuff, offset, offset + 8);\n        offset += 8;\n        this.threshold = bintools.copyFrom(utxobuff, offset, offset + 4);\n        offset += 4;\n        this.numaddrs = bintools.copyFrom(utxobuff, offset, offset + 4);\n        offset += 4;\n        let numaddrs:number = this.numaddrs.readUInt32BE(0);\n        this.addresses = [];\n        for(let i = 0; i < numaddrs; i++){\n            let addr:Address = new Address();\n            let offsetEnd:number = offset + addr.getSize();\n            let copied:Buffer = bintools.copyFrom(utxobuff, offset, offsetEnd);\n            addr.fromBuffer(copied);\n            this.addresses.push(addr);\n            offset = offsetEnd;\n        }\n        this.addresses.sort(Address.comparitor());\n        return offset;\n    }\n\n    /**\n     * Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[OutCreateAsset]] and returns the size of the output.\n     */\n    fromBuffer = (utxobuff:Buffer):number => {\n        return this._OPParseBuffer(utxobuff, 0);\n    }\n\n    /**\n     * @ignore\n     */\n    protected _OPBuffer = (): Buffer => {\n        try {\n            this.addresses.sort(Address.comparitor());\n            let bsize:number =  this.assetid.length + this.outputid.length + this.amount.length + this.locktime.length + this.threshold.length + this.numaddrs.length;\n            this.numaddrs.writeUInt32BE(this.addresses.length, 0);\n            let barr:Array<Buffer> = [this.assetid, this.outputid, this.amount, this.locktime, this.threshold, this.numaddrs];\n            for(let i = 0; i < this.addresses.length; i++) {\n                let b: Buffer = this.addresses[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            let buff: Buffer = Buffer.concat(barr,bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - TxOut._OPTxBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns the buffer representing the [[OutCreateAsset]] instance.\n     */\n    toBuffer = ():Buffer => {\n        return this._OPBuffer();\n    }\n\n    /**\n     * Returns a base-58 string representing the [[OutCreateAsset]].\n     */\n    toString = ():string => {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * @ignore\n     */\n    protected _OPQualified = (addresses:Array<string>, asOf:BN = undefined):Array<string> => {\n        let qualified:Array<string> = [];\n        let now:BN;\n        if(typeof asOf === 'undefined'){\n            now = UnixNow();\n        } else {\n            now = asOf;\n        }\n        let locktime:BN = bintools.fromBufferToBN(this.locktime);\n        if(now.lte(locktime)){ //not unlocked, not spendable\n            return qualified;\n        }\n\n        let threshold:number = this.threshold.readUInt32BE(0);\n\n        for(let i = 0; i < this.addresses.length && qualified.length < threshold; i++) {\n            for(let j = 0; j < addresses.length && qualified.length < threshold; j++){\n                if(addresses[j] == this.addresses[i].toString()){\n                    qualified.push(addresses[j]);\n                }\n            }\n        }\n\n        return qualified;\n    }\n\n    /**\n     * Given an array of addresses and an optional timestamp, select an array of address strings of qualified spenders for the output.\n     */\n    getSpenders = (addresses:Array<string>, asOf:BN = undefined):Array<string> => {\n        return this._OPQualified(addresses, asOf);\n    }\n\n    /**\n     * Given an array of addresses and an optional timestamp, returns true if the addresses meet the threshold required to spend the output.\n     */\n    meetsThreshold = (addresses:Array<string>, asOf:BN = undefined):boolean => {\n        let now:BN;\n        if(typeof asOf === 'undefined'){\n            now = UnixNow();\n        } else {\n            now = asOf;\n        }\n        let locktime:BN = bintools.fromBufferToBN(this.locktime);\n        let qualified:Array<string> = this._OPQualified(addresses, now);\n        let threshold:number = this.threshold.readUInt32BE(0);\n        if(now.lte(locktime)){\n            return false;\n        }\n        if(qualified.length >= threshold){\n            return true;\n        }\n\n        return false;\n    }\n\n    /**\n     * An [[Output]] class which issues a payment on an assetID.\n     * \n     * @param assetid A {@link https://github.com/feross/buffer|Buffer} representing the AssetID\n     * @param amount A {@link https://github.com/indutny/bn.js/|BN} representing the amount in the output\n     * @param addresses An array of strings representing addresses\n     * @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime\n     * @param threshold A number representing the the threshold number of signers required to sign the transaction\n     */\n    constructor(assetid:Buffer, amount?:BN, addresses?:Array<string>, locktime?:BN, threshold?:number){\n        super(SECPFXID, assetid);\n        if(amount && addresses){\n            this.amountValue = amount.clone();\n            this.amount = bintools.fromBNToBuffer(amount, 8);\n            let addrs:Array<Address> = [];\n            for(let i = 0; i < addresses.length; i++){\n                addrs[i] = new Address();\n                addrs[i].fromString(addresses[i]);\n            }\n            this.addresses = addrs;\n            this.addresses.sort(Address.comparitor());\n            this.numaddrs.writeUInt32BE(this.addresses.length, 0);\n            this.threshold.writeUInt32BE((threshold ? threshold : 1), 0);\n            if(!(locktime)){\n                /* istanbul ignore next */\n                locktime = new BN(0);\n            }\n            this.locktime = bintools.fromBNToBuffer(locktime, 8);\n        }\n    }\n}\n\n\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../../../src/apis/avm/outputs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport BinTools from '../../utils/bintools';\nimport BN from \"bn.js\";\nimport { Address, UnixNow, AVMConstants } from './types';\n\nconst bintools = BinTools.getInstance();\n\n/**\n * Takes a buffer representing the output and returns the proper Output instance.\n * \n * @param outbuffer A {@link https://github.com/feross/buffer|Buffer} containing the Output raw data.\n * \n * @returns An instance of an [[Output]]-extended class: [[OutputPayment]], [[OutTakeOrLeave]], [[OutCreateAsset]].\n */\nexport const SelectOutputClass = (outbuffer:Buffer, args:Array<any> = []):Output => {\n    let assetid:Buffer = bintools.copyFrom(outbuffer, 0, AVMConstants.ASSETIDLEN);\n    let outputid:number = outbuffer.readUInt32BE(AVMConstants.ASSETIDLEN);\n    if(outputid == AVMConstants.SECPOUTPUTID){\n        let secpout:SecpOutput = new SecpOutput(assetid, ...args);\n        secpout.fromBuffer(outbuffer);\n        return secpout;\n    }\n    throw new Error(\"Error - SelectOutputClass: unknown outputid \" + outputid);\n}\n\n/**\n * A class representing a transaction output. All output types must extend on this class.\n */\nexport class Output {\n    protected outputid:Buffer = Buffer.alloc(4);\n    protected outputidnum:number;\n\n    getOutputID = ():number => {\n        return this.outputidnum;\n    };\n\n    fromBuffer(outbuff:Buffer, offset:number = 0):number {\n        this.outputid = bintools.copyFrom(outbuff, offset, offset + 4);\n        this.outputidnum = this.outputid.readUInt32BE(0);\n        return offset + 4;\n    };\n\n    toBuffer():Buffer {\n        return this.outputid;\n    };\n\n    toString():string {\n        return bintools.bufferToB58(this.outputid);\n    };\n\n    static comparator = ():(a:Output, b:Output) => (1|-1|0) => {\n        return function(a:Output, b:Output):(1|-1|0) { \n            return Buffer.compare(a.toBuffer(), b.toBuffer()) as (1|-1|0);\n        }\n    }\n\n    constructor(outputidnum:number) {\n        this.outputid.writeUInt32BE(outputidnum, 0);\n        this.outputidnum = outputidnum;\n    }\n}\n\n/**\n * An [[Output]] class which specifies a secp256k1 .\n */\nexport class SecpOutBase extends Output {\n    protected locktime:Buffer = Buffer.alloc(8);\n    protected threshold:Buffer = Buffer.alloc(4);\n    protected numaddrs:Buffer = Buffer.alloc(4);\n    protected addresses:Array<Address> = [];\n    protected amount:Buffer = Buffer.alloc(8);\n    protected amountValue:BN = new BN(0);\n\n    /**\n     * Returns the amount as a {@link https://github.com/indutny/bn.js/|BN}.\n     */\n    getAmount = ():BN => {\n        return this.amountValue.clone();\n    }\n\n    /**\n     * Returns the threshold of signers required to spend this output.\n     */\n    getThreshold = ():number => {\n        return this.threshold.readUInt32BE(0);\n    }\n\n    /**\n     * Returns the a {@link https://github.com/indutny/bn.js/|BN} repersenting the UNIX Timestamp when the lock is made available.\n     */\n    getLocktime = ():BN => {\n        return bintools.fromBufferToBN(this.locktime);\n    }\n\n    /**\n     * Returns an array of {@link https://github.com/feross/buffer|Buffer}s for the addresses.\n     */\n    getAddresses = ():Array<Buffer> => {\n        let result:Array<Buffer> = [];\n        for(let i = 0; i < this.addresses.length; i++) {\n            result.push(this.addresses[i].toBuffer())\n        }\n        return result;\n    }\n\n    /**\n     * Returns the index of the address.\n     * \n     * @param address A {@link https://github.com/feross/buffer|Buffer} of the address to look up to return its index.\n     * \n     * @returns The index of the address.\n     */\n    getAddressIdx = (address:Buffer):number => {\n        for(let i = 0; i < this.addresses.length; i++){\n            if(this.addresses[i].toBuffer().toString(\"hex\") == address.toString(\"hex\")){\n                return i\n            }\n        }\n        /* istanbul ignore next */\n        return -1;\n    }\n\n    /**\n     * Returns the address from the index provided.\n     * \n     * @param idx The index of the address.\n     * \n     * @returns Returns the string representing the address.\n     */\n    getAddress = (idx:number):Buffer => {\n        if(idx < this.addresses.length){\n            return this.addresses[idx].toBuffer();\n        }\n        throw new Error(\"Error - SecpOutBase.getAddress: idx out of range\");\n    }\n\n    /**\n     * Popuates the instance from a {@link https://github.com/feross/buffer|Buffer} representing the [[SecpOutBase]] and returns the size of the output.\n     */\n    fromBuffer(utxobuff:Buffer, offset:number = 0):number {\n        offset = super.fromBuffer(utxobuff, offset);\n        this.amount = bintools.copyFrom(utxobuff, offset, offset + 8);\n        this.amountValue = bintools.fromBufferToBN(this.amount);\n        offset += 8;\n        this.locktime = bintools.copyFrom(utxobuff, offset, offset + 8);\n        offset += 8;\n        this.threshold = bintools.copyFrom(utxobuff, offset, offset + 4);\n        offset += 4;\n        this.numaddrs = bintools.copyFrom(utxobuff, offset, offset + 4);\n        offset += 4;\n        let numaddrs:number = this.numaddrs.readUInt32BE(0);\n        this.addresses = [];\n        for(let i = 0; i < numaddrs; i++){\n            let addr:Address = new Address();\n            let offsetEnd:number = offset + addr.getSize();\n            let copied:Buffer = bintools.copyFrom(utxobuff, offset, offsetEnd);\n            addr.fromBuffer(copied);\n            this.addresses.push(addr);\n            offset = offsetEnd;\n        }\n        this.addresses.sort(Address.comparitor());\n        return offset;\n    }\n\n    /**\n     * Returns the buffer representing the [[SecpOutBase]] instance.\n     */\n    toBuffer():Buffer {\n        try {\n            this.addresses.sort(Address.comparitor());\n            let superbuff:Buffer = super.toBuffer();\n            let bsize:number = superbuff.length + this.amount.length + this.locktime.length + this.threshold.length + this.numaddrs.length;\n            this.numaddrs.writeUInt32BE(this.addresses.length, 0);\n            let barr:Array<Buffer> = [superbuff, this.amount, this.locktime, this.threshold, this.numaddrs];\n            for(let i = 0; i < this.addresses.length; i++) {\n                let b: Buffer = this.addresses[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            return Buffer.concat(barr,bsize);;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - SecpOutBase.toBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a base-58 string representing the [[SecpOutBase]].\n     */\n    toString():string {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Given an array of addresses and an optional timestamp, select an array of address {@link https://github.com/feross/buffer|Buffer}s of qualified spenders for the output.\n     */\n    getSpenders = (addresses:Array<Buffer>, asOf:BN = undefined):Array<Buffer> => {\n        let qualified:Array<Buffer> = [];\n        let now:BN;\n        if(typeof asOf === 'undefined'){\n            now = UnixNow();\n        } else {\n            now = asOf;\n        }\n        let locktime:BN = bintools.fromBufferToBN(this.locktime);\n        if(now.lte(locktime)){ //not unlocked, not spendable\n            return qualified;\n        }\n\n        let threshold:number = this.threshold.readUInt32BE(0);\n\n        for(let i = 0; i < this.addresses.length && qualified.length < threshold; i++) {\n            for(let j = 0; j < addresses.length && qualified.length < threshold; j++){\n                if(addresses[j].toString(\"hex\") == this.addresses[i].toBuffer().toString(\"hex\")){\n                    qualified.push(addresses[j]);\n                }\n            }\n        }\n\n        return qualified;\n    }\n\n    /**\n     * Given an array of address {@link https://github.com/feross/buffer|Buffer}s and an optional timestamp, returns true if the addresses meet the threshold required to spend the output.\n     */\n    meetsThreshold = (addresses:Array<Buffer>, asOf:BN = undefined):boolean => {\n        let now:BN;\n        if(typeof asOf === 'undefined'){\n            now = UnixNow();\n        } else {\n            now = asOf;\n        }\n        let qualified:Array<Buffer> = this.getSpenders(addresses, now);\n        let threshold:number = this.threshold.readUInt32BE(0);\n        if(qualified.length >= threshold){\n            return true;\n        }\n\n        return false;\n    }\n\n    /**\n     * An [[Output]] class which issues a payment on an assetID.\n     * \n     * @param assetid A {@link https://github.com/feross/buffer|Buffer} representing the AssetID\n     * @param amount A {@link https://github.com/indutny/bn.js/|BN} representing the amount in the output\n     * @param addresses An array of {@link https://github.com/feross/buffer|Buffer}s representing addresses\n     * @param locktime A {@link https://github.com/indutny/bn.js/|BN} representing the locktime\n     * @param threshold A number representing the the threshold number of signers required to sign the transaction\n     */\n    constructor(amount?:BN, addresses?:Array<Buffer>, locktime?:BN, threshold?:number){\n        super(AVMConstants.SECPOUTPUTID);\n        if(amount && addresses){\n            this.amountValue = amount.clone();\n            this.amount = bintools.fromBNToBuffer(amount, 8);\n            let addrs:Array<Address> = [];\n            for(let i = 0; i < addresses.length; i++){\n                addrs[i] = new Address();\n                addrs[i].fromBuffer(addresses[i]);\n            }\n            this.addresses = addrs;\n            this.addresses.sort(Address.comparitor());\n            this.numaddrs.writeUInt32BE(this.addresses.length, 0);\n            this.threshold.writeUInt32BE((threshold ? threshold : 1), 0);\n            if(!(locktime)){\n                /* istanbul ignore next */\n                locktime = new BN(0);\n            }\n            this.locktime = bintools.fromBNToBuffer(locktime, 8);\n        }\n    }\n}\n\nexport class SecpOutput extends SecpOutBase {\n    protected assetid:Buffer = Buffer.alloc(32);\n\n    fromBuffer(outbuff:Buffer, offset:number = 0):number {\n        this.assetid = bintools.copyFrom(outbuff, offset, offset + 32);\n        offset += 32;\n        offset = super.fromBuffer(outbuff, offset);\n        return offset;\n    }\n\n    toBuffer():Buffer {\n        let superbuff:Buffer = super.toBuffer();\n        return Buffer.concat([this.assetid, superbuff]);\n    }\n\n    /**\n     * Returns the assetID as a {@link https://github.com/feross/buffer|Buffer}.\n     */\n    getAssetID = ():Buffer => {\n        return this.assetid;\n    }\n\n    constructor(assetid?:Buffer, amount?:BN, addresses?:Array<Buffer>, locktime?:BN, threshold?:number){\n        super(amount, addresses, locktime, threshold);\n        if(typeof assetid !== 'undefined' && assetid.length == AVMConstants.ASSETIDLEN) {\n            this.assetid = assetid;\n        }\n    }\n}"]} |
@@ -5,3 +5,3 @@ /** | ||
import { Buffer } from "buffer/"; | ||
import { Signature } from './types'; | ||
import { Signature, InitialStates } from './types'; | ||
import { Output } from './outputs'; | ||
@@ -59,17 +59,13 @@ import { Input } from './inputs'; | ||
* | ||
* @remarks assume not-checksummed and deserialized | ||
* @remarks assume not-checksummed | ||
*/ | ||
fromBuffer: (bytes: Buffer) => number; | ||
fromBuffer(bytes: Buffer, offset?: number): number; | ||
/** | ||
* @ignore | ||
*/ | ||
protected _basicTxBuffer: () => Buffer; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]]. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
* Returns a base-58 representation of the [[TxUnsigned]]. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
@@ -86,2 +82,63 @@ * Class representing an unsigned transaction. | ||
} | ||
export declare class TxCreateAsset extends TxUnsigned { | ||
protected name: string; | ||
protected namebuff: Buffer; | ||
protected symbol: string; | ||
protected symbolbuff: Buffer; | ||
protected denomination: Buffer; | ||
protected initialstate: InitialStates; | ||
/** | ||
* Returns the array of array of [[Output]]s for the initial state | ||
*/ | ||
getInitialStates: () => InitialStates; | ||
/** | ||
* Returns the string representation of the name | ||
*/ | ||
getName: () => string; | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the name | ||
*/ | ||
getNameBuffer: () => Buffer; | ||
/** | ||
* Returns the string representation of the symbol | ||
*/ | ||
getSymbol: () => string; | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the symbol | ||
*/ | ||
getSymbolBuffer: () => Buffer; | ||
/** | ||
* Returns the numeric representation of the denomination | ||
*/ | ||
getDenomination: () => number; | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the denomination | ||
*/ | ||
getDenominationBuffer: () => Buffer; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxCreateAsset]], parses it, populates the class, and returns the length of the TxUnsigned in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxCreateAsset]] | ||
* | ||
* @returns The length of the raw [[TxCreateAsset]] | ||
* | ||
* @remarks assume not-checksummed | ||
*/ | ||
fromBuffer(bytes: Buffer, offset?: number): number; | ||
toBuffer(): Buffer; | ||
/** | ||
* Class representing an unsigned Create Asset transaction. | ||
* | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* @param initialstate Optional [[InitialStates]] that represent the intial state of a created asset | ||
* @param ins Optional array of the [[Input]]s | ||
* @param outs Optional array of the [[Output]]s | ||
* @param networkid Optional networkid, default 2 | ||
* @param blockchainid Optional blockchainid, default Buffer.alloc(32, 16) | ||
* @param txtype Optional txtype, default 1 | ||
*/ | ||
constructor(name?: string, symbol?: string, denomination?: number, initialstate?: InitialStates, ins?: Array<Input>, outs?: Array<Output>, networkid?: number, blockchainid?: Buffer, txtype?: number); | ||
} | ||
/** | ||
@@ -100,3 +157,3 @@ * Class representing a signed transaction. | ||
*/ | ||
fromBuffer: (bytes: Buffer) => number; | ||
fromBuffer(bytes: Buffer): number; | ||
/** | ||
@@ -112,7 +169,7 @@ * Takes a base-58 string containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes. | ||
*/ | ||
fromString: (serialized: string) => number; | ||
fromString(serialized: string): number; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Tx]]. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
@@ -124,3 +181,3 @@ * Returns a base-58 AVA-serialized representation of the [[Tx]]. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
@@ -127,0 +184,0 @@ * Class representing a signed transaction. |
@@ -88,98 +88,196 @@ "use strict"; | ||
}; | ||
this.txtype.writeUInt32BE(txtype, 0); | ||
this.networkid.writeUInt32BE(networkid, 0); | ||
this.blockchainid = blockchainid; | ||
if (ins && outs) { | ||
this.numouts.writeUInt32BE(outs.length, 0); | ||
this.outs = outs.sort(outputs_1.Output.comparator()); | ||
this.numins.writeUInt32BE(ins.length, 0); | ||
this.ins = ins.sort(inputs_1.Input.comparator()); | ||
} | ||
} | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxUnsigned]], parses it, populates the class, and returns the length of the TxUnsigned in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxUnsigned]] | ||
* | ||
* @returns The length of the raw [[TxUnsigned]] | ||
* | ||
* @remarks assume not-checksummed | ||
*/ | ||
fromBuffer(bytes, offset = 0) { | ||
this.txtype = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
this.networkid = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
this.blockchainid = bintools.copyFrom(bytes, offset, offset + 32); | ||
offset += 32; | ||
this.numouts = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let outcount = this.numouts.readUInt32BE(0); | ||
this.outs = []; | ||
for (let i = 0; i < outcount; i++) { | ||
let outbuff = bintools.copyFrom(bytes, offset, bytes.length); | ||
let out = outputs_1.SelectOutputClass(outbuff); | ||
offset += out.fromBuffer(outbuff); | ||
this.outs.push(out); | ||
} | ||
this.numins = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let incount = this.numins.readUInt32BE(0); | ||
this.ins = []; | ||
for (let i = 0; i < incount; i++) { | ||
let inbuff = bintools.copyFrom(bytes, offset, bytes.length); | ||
let input = inputs_1.SelectInputClass(inbuff); | ||
offset += input.fromBuffer(inbuff); | ||
this.ins.push(input); | ||
} | ||
return offset; | ||
} | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]]. | ||
*/ | ||
toBuffer() { | ||
try { | ||
this.outs.sort(outputs_1.Output.comparator()); | ||
this.ins.sort(inputs_1.Input.comparator()); | ||
this.numouts.writeUInt32BE(this.outs.length, 0); | ||
this.numins.writeUInt32BE(this.ins.length, 0); | ||
let bsize = this.txtype.length + this.networkid.length + this.blockchainid.length + this.numouts.length; | ||
let barr = [this.txtype, this.networkid, this.blockchainid, this.numouts]; | ||
for (let i = 0; i < this.outs.length; i++) { | ||
let b = this.outs[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
barr.push(this.numins); | ||
bsize += this.numins.length; | ||
for (let i = 0; i < this.ins.length; i++) { | ||
let b = this.ins[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - TxUnsigned.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
/** | ||
* Returns a base-58 representation of the [[TxUnsigned]]. | ||
*/ | ||
toString() { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
} | ||
} | ||
exports.TxUnsigned = TxUnsigned; | ||
class TxCreateAsset extends TxUnsigned { | ||
/** | ||
* Class representing an unsigned Create Asset transaction. | ||
* | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* @param initialstate Optional [[InitialStates]] that represent the intial state of a created asset | ||
* @param ins Optional array of the [[Input]]s | ||
* @param outs Optional array of the [[Output]]s | ||
* @param networkid Optional networkid, default 2 | ||
* @param blockchainid Optional blockchainid, default Buffer.alloc(32, 16) | ||
* @param txtype Optional txtype, default 1 | ||
*/ | ||
constructor(name = undefined, symbol = undefined, denomination = undefined, initialstate = undefined, ins = undefined, outs = undefined, networkid = 2, blockchainid = buffer_1.Buffer.alloc(32, 16), txtype = types_1.AVMConstants.CREATEASSETTX) { | ||
super(ins, outs, networkid, blockchainid, txtype); | ||
this.name = ""; | ||
this.namebuff = buffer_1.Buffer.alloc(2); | ||
this.symbol = ""; | ||
this.symbolbuff = buffer_1.Buffer.alloc(2); | ||
this.denomination = buffer_1.Buffer.alloc(1); | ||
this.initialstate = new types_1.InitialStates(); | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxUnsigned]], parses it, populates the class, and returns the length of the TxUnsigned in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxUnsigned]] | ||
* | ||
* @returns The length of the raw [[TxUnsigned]] | ||
* | ||
* @remarks assume not-checksummed and deserialized | ||
* Returns the array of array of [[Output]]s for the initial state | ||
*/ | ||
this.fromBuffer = (bytes) => { | ||
let offset = 0; | ||
this.txtype = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
this.networkid = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
this.blockchainid = bintools.copyFrom(bytes, offset, offset + 32); | ||
offset += 32; | ||
this.numouts = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let outcount = this.numouts.readUInt32BE(0); | ||
this.outs = []; | ||
for (let i = 0; i < outcount; i++) { | ||
let outbuff = bintools.copyFrom(bytes, offset, bytes.length); | ||
let out = outputs_1.SelectOutputClass(outbuff); | ||
offset += out.fromBuffer(outbuff); | ||
this.outs.push(out); | ||
} | ||
this.numins = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let incount = this.numins.readUInt32BE(0); | ||
this.ins = []; | ||
for (let i = 0; i < incount; i++) { | ||
let inbuff = bintools.copyFrom(bytes, offset, bytes.length); | ||
let input = inputs_1.SelectInputClass(inbuff); | ||
offset += input.fromBuffer(inbuff); | ||
this.ins.push(input); | ||
} | ||
return offset; | ||
this.getInitialStates = () => { | ||
return this.initialstate; | ||
}; | ||
/** | ||
* @ignore | ||
* Returns the string representation of the name | ||
*/ | ||
this._basicTxBuffer = () => { | ||
try { | ||
this.outs.sort(outputs_1.Output.comparator()); | ||
this.ins.sort(inputs_1.Input.comparator()); | ||
this.numouts.writeUInt32BE(this.outs.length, 0); | ||
this.numins.writeUInt32BE(this.ins.length, 0); | ||
let bsize = this.txtype.length + this.networkid.length + this.blockchainid.length + this.numouts.length; | ||
let barr = [this.txtype, this.networkid, this.blockchainid, this.numouts]; | ||
for (let i = 0; i < this.outs.length; i++) { | ||
let b = this.outs[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
barr.push(this.numins); | ||
bsize += this.numins.length; | ||
for (let i = 0; i < this.ins.length; i++) { | ||
let b = this.ins[i].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - TxUnsigned._basicTxBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
this.getName = () => { | ||
return this.name; | ||
}; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]]. | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the name | ||
*/ | ||
this.toBuffer = () => { | ||
return this._basicTxBuffer(); | ||
this.getNameBuffer = () => { | ||
return this.namebuff; | ||
}; | ||
/** | ||
* Returns a base-58 representation of the [[TxUnsigned]]. | ||
* Returns the string representation of the symbol | ||
*/ | ||
this.toString = () => { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
this.getSymbol = () => { | ||
return this.symbol; | ||
}; | ||
this.txtype.writeUInt32BE(txtype, 0); | ||
this.networkid.writeUInt32BE(networkid, 0); | ||
this.blockchainid = blockchainid; | ||
if (ins && outs) { | ||
this.numouts.writeUInt32BE(outs.length, 0); | ||
this.outs = outs.sort(outputs_1.Output.comparator()); | ||
this.numins.writeUInt32BE(ins.length, 0); | ||
this.ins = ins.sort(inputs_1.Input.comparator()); | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the symbol | ||
*/ | ||
this.getSymbolBuffer = () => { | ||
return this.symbolbuff; | ||
}; | ||
/** | ||
* Returns the numeric representation of the denomination | ||
*/ | ||
this.getDenomination = () => { | ||
return this.denomination.readUInt8(0); | ||
}; | ||
/** | ||
* Returns the {@link https://github.com/feross/buffer|Buffer} representation of the denomination | ||
*/ | ||
this.getDenominationBuffer = () => { | ||
return this.denomination; | ||
}; | ||
if (typeof name === 'string' && typeof symbol === 'string' && typeof denomination === 'number' && denomination >= 0 && denomination <= 32 && initialstate) { | ||
this.initialstate = initialstate; | ||
this.namebuff = bintools.stringToBuffer(name); | ||
this.name = name; | ||
this.symbolbuff = bintools.stringToBuffer(symbol); | ||
this.symbol = symbol; | ||
this.denomination.writeUInt8(denomination, 0); | ||
} | ||
} | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxCreateAsset]], parses it, populates the class, and returns the length of the TxUnsigned in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxCreateAsset]] | ||
* | ||
* @returns The length of the raw [[TxCreateAsset]] | ||
* | ||
* @remarks assume not-checksummed | ||
*/ | ||
fromBuffer(bytes, offset = 0) { | ||
offset = super.fromBuffer(bytes, offset); | ||
let namesize = bintools.copyFrom(bytes, offset, offset + 2).readUInt16BE(0); | ||
this.namebuff = bintools.copyFrom(bytes, offset, offset + 2 + namesize); | ||
offset += 2; | ||
offset += namesize; | ||
let symsize = bintools.copyFrom(bytes, offset, offset + 2).readUInt16BE(0); | ||
this.symbolbuff = bintools.copyFrom(bytes, offset, offset + 2 + symsize); | ||
offset += 2; | ||
offset += symsize; | ||
this.denomination = bintools.copyFrom(bytes, offset, offset + 1); | ||
offset += 1; | ||
let inits = new types_1.InitialStates(); | ||
offset = inits.fromBuffer(bytes, offset); | ||
this.initialstate = inits; | ||
return offset; | ||
} | ||
toBuffer() { | ||
let barr = [super.toBuffer(), this.namebuff, this.symbolbuff, this.denomination, this.initialstate.toBuffer()]; | ||
return buffer_1.Buffer.concat(barr); | ||
} | ||
} | ||
exports.TxUnsigned = TxUnsigned; | ||
exports.TxCreateAsset = TxCreateAsset; | ||
/** | ||
@@ -198,93 +296,2 @@ * Class representing a signed transaction. | ||
this.signatures = []; | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Tx]] | ||
* | ||
* @returns The length of the raw [[Tx]] | ||
*/ | ||
this.fromBuffer = (bytes) => { | ||
this.tx = new TxUnsigned(); | ||
let offset = this.tx.fromBuffer(bytes); | ||
let numcreds = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0); | ||
offset += 4; | ||
this.signatures = []; | ||
for (let i = 0; i < numcreds; i++) { | ||
let sigarray = []; | ||
let credential = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0); | ||
offset += 4; | ||
if (credential != types_1.Constants.SECPCREDENTIAL) { | ||
/* istanbul ignore next */ | ||
throw new Error("Error - Tx.fromBuffer: Invalid credentialID " + credential); | ||
} | ||
let numsigs = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0); | ||
offset += 4; | ||
for (let j = 0; j < numsigs; j++) { | ||
let sig = new types_1.Signature(); | ||
sig.fromBuffer(bintools.copyFrom(bytes, offset, offset + 65)); | ||
sigarray.push(sig); | ||
offset += 65; | ||
} | ||
this.signatures.push(sigarray); | ||
} | ||
return offset; | ||
}; | ||
/** | ||
* Takes a base-58 string containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes. | ||
* | ||
* @param serialized A base-58 string containing a raw [[Tx]] | ||
* | ||
* @returns The length of the raw [[Tx]] | ||
* | ||
* @remarks | ||
* unlike most fromStrings, it expects the string to be serialized in AVA format | ||
*/ | ||
this.fromString = (serialized) => { | ||
return this.fromBuffer(bintools.avaDeserialize(serialized)); | ||
}; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Tx]]. | ||
*/ | ||
this.toBuffer = () => { | ||
try { | ||
let txbuff = this.tx.toBuffer(); | ||
let bsize = txbuff.length; | ||
let sigarrlen = buffer_1.Buffer.alloc(4); | ||
sigarrlen.writeUInt32BE(this.signatures.length, 0); | ||
let barr = [txbuff, sigarrlen]; | ||
bsize += sigarrlen.length; | ||
for (let i = 0; i < this.signatures.length; i++) { | ||
let siglen = buffer_1.Buffer.alloc(4); | ||
siglen.writeUInt32BE(this.signatures[i].length, 0); | ||
let credentialID = buffer_1.Buffer.alloc(4); | ||
credentialID.writeUInt32BE(types_1.Constants.SECPCREDENTIAL, 0); | ||
barr.push(credentialID); | ||
bsize += credentialID.length; | ||
barr.push(siglen); | ||
bsize += siglen.length; | ||
for (let j = 0; j < this.signatures[i].length; j++) { | ||
let b = this.signatures[i][j].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
} | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - TxSigned.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
}; | ||
/** | ||
* Returns a base-58 AVA-serialized representation of the [[Tx]]. | ||
* | ||
* @remarks | ||
* unlike most toStrings, this returns in AVA serialization format | ||
*/ | ||
this.toString = () => { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
}; | ||
if (tx) { | ||
@@ -297,4 +304,95 @@ this.tx = tx; | ||
} | ||
/** | ||
* Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes. | ||
* | ||
* @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Tx]] | ||
* | ||
* @returns The length of the raw [[Tx]] | ||
*/ | ||
fromBuffer(bytes) { | ||
this.tx = new TxUnsigned(); | ||
let offset = this.tx.fromBuffer(bytes); | ||
let numcreds = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0); | ||
offset += 4; | ||
this.signatures = []; | ||
for (let i = 0; i < numcreds; i++) { | ||
let sigarray = []; | ||
let credential = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0); | ||
offset += 4; | ||
if (credential != types_1.AVMConstants.SECPCREDENTIAL) { | ||
/* istanbul ignore next */ | ||
throw new Error("Error - Tx.fromBuffer: Invalid credentialID " + credential); | ||
} | ||
let numsigs = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0); | ||
offset += 4; | ||
for (let j = 0; j < numsigs; j++) { | ||
let sig = new types_1.Signature(); | ||
sig.fromBuffer(bintools.copyFrom(bytes, offset, offset + 65)); | ||
sigarray.push(sig); | ||
offset += 65; | ||
} | ||
this.signatures.push(sigarray); | ||
} | ||
return offset; | ||
} | ||
/** | ||
* Takes a base-58 string containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes. | ||
* | ||
* @param serialized A base-58 string containing a raw [[Tx]] | ||
* | ||
* @returns The length of the raw [[Tx]] | ||
* | ||
* @remarks | ||
* unlike most fromStrings, it expects the string to be serialized in AVA format | ||
*/ | ||
fromString(serialized) { | ||
return this.fromBuffer(bintools.avaDeserialize(serialized)); | ||
} | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Tx]]. | ||
*/ | ||
toBuffer() { | ||
try { | ||
let txbuff = this.tx.toBuffer(); | ||
let bsize = txbuff.length; | ||
let sigarrlen = buffer_1.Buffer.alloc(4); | ||
sigarrlen.writeUInt32BE(this.signatures.length, 0); | ||
let barr = [txbuff, sigarrlen]; | ||
bsize += sigarrlen.length; | ||
for (let i = 0; i < this.signatures.length; i++) { | ||
let siglen = buffer_1.Buffer.alloc(4); | ||
siglen.writeUInt32BE(this.signatures[i].length, 0); | ||
let credentialID = buffer_1.Buffer.alloc(4); | ||
credentialID.writeUInt32BE(types_1.AVMConstants.SECPCREDENTIAL, 0); | ||
barr.push(credentialID); | ||
bsize += credentialID.length; | ||
barr.push(siglen); | ||
bsize += siglen.length; | ||
for (let j = 0; j < this.signatures[i].length; j++) { | ||
let b = this.signatures[i][j].toBuffer(); | ||
barr.push(b); | ||
bsize += b.length; | ||
} | ||
} | ||
let buff = buffer_1.Buffer.concat(barr, bsize); | ||
return buff; | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - TxSigned.toBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
} | ||
/** | ||
* Returns a base-58 AVA-serialized representation of the [[Tx]]. | ||
* | ||
* @remarks | ||
* unlike most toStrings, this returns in AVA serialization format | ||
*/ | ||
toString() { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
} | ||
} | ||
exports.Tx = Tx; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tx.js","sourceRoot":"","sources":["../../../../src/apis/avm/tx.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport { Signature, Constants } from './types';\nimport { Output, SelectOutputClass } from './outputs';\nimport { Input, SecpInput, SelectInputClass } from './inputs';\nimport BinTools from '../../utils/bintools';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n/** \n * Class representing an unsigned transaction.\n * \n * @remarks\n * Unsigned Tx:\n * TxID      | 4 bytes\n * NetworkID  | 4 bytes\n * BlockchainID   | 32 bytes\n * NumOuts    | 4 bytes\n * Repeated (NumOuts):\n *     Out    | ? bytes\n * NumIns     | 4 bytes\n * Repeated (NumIns):\n *     In     | ? bytes\n */\n/* Tx:\n * Unsigned Tx | ? bytes\n * Repeated (NumIns):\n *     Sig     | ? bytes\n */\n/* Sig:\n * Repeated (NumSigs):\n *     Sig    | 65 bytes\n */\nexport class TxUnsigned {\n    protected txtype:Buffer = Buffer.alloc(4);\n    protected networkid:Buffer = Buffer.alloc(4);\n    protected blockchainid:Buffer = Buffer.alloc(32);\n    protected numouts:Buffer = Buffer.alloc(4);\n    protected outs:Array<Output>;\n    protected numins:Buffer = Buffer.alloc(4);\n    protected ins:Array<Input>;\n\n    /**\n     * Returns the number representation of the txtype\n     */\n    getTxType = ():number => {\n        return this.txtype.readUInt32BE(0);\n    }\n\n    /**\n     * Returns the number representation of the NetworkID\n     */\n    getNetworkID = ():number => {\n        return this.networkid.readUInt32BE(0);\n    }\n\n    /**\n     * Returns the Buffer representation of the BlockchainID\n     */\n    getBlockchainID = ():Buffer => {\n        return this.blockchainid;\n    }\n    \n    /**\n     * Returns the array of [[Input]]s\n     */\n    getIns = ():Array<Input> => {\n        return this.ins;\n    }\n\n    /**\n     * Returns the array of [[Output]]s\n     */\n    getOuts = ():Array<Output> => {\n        return this.outs;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxUnsigned]], parses it, populates the class, and returns the length of the TxUnsigned in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxUnsigned]]\n     * \n     * @returns The length of the raw [[TxUnsigned]]\n     * \n     * @remarks assume not-checksummed and deserialized\n     */\n    fromBuffer = (bytes:Buffer):number => {\n        let offset:number = 0;\n        this.txtype = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        this.networkid = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        this.blockchainid = bintools.copyFrom(bytes, offset, offset + 32);\n        offset += 32;\n        this.numouts = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let outcount:number = this.numouts.readUInt32BE(0);\n        this.outs = [];\n        for(let i = 0; i < outcount; i++){\n            let outbuff:Buffer = bintools.copyFrom(bytes, offset, bytes.length);\n            let out:Output = SelectOutputClass(outbuff);\n            offset += out.fromBuffer(outbuff);\n            this.outs.push(out);\n        }\n        this.numins = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let incount:number = this.numins.readUInt32BE(0);\n        this.ins = [];\n        for(let i = 0; i < incount; i++){\n            let inbuff:Buffer = bintools.copyFrom(bytes, offset, bytes.length);\n            let input:Input = SelectInputClass(inbuff);\n            offset += input.fromBuffer(inbuff);\n            this.ins.push(input);\n        }\n        return offset;\n    }\n\n    /**\n     * @ignore\n     */\n    protected _basicTxBuffer = ():Buffer => {\n        try {\n            this.outs.sort(Output.comparator());\n            this.ins.sort(Input.comparator());\n            this.numouts.writeUInt32BE(this.outs.length, 0);\n            this.numins.writeUInt32BE(this.ins.length, 0);\n            let bsize:number = this.txtype.length + this.networkid.length + this.blockchainid.length + this.numouts.length;\n            let barr:Array<Buffer> = [this.txtype, this.networkid, this.blockchainid, this.numouts];\n            for(let i = 0; i < this.outs.length; i++) {\n                let b:Buffer = this.outs[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            barr.push(this.numins);\n            bsize += this.numins.length;\n            for(let i = 0; i < this.ins.length; i++) {\n                let b:Buffer = this.ins[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            let buff:Buffer = Buffer.concat(barr, bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - TxUnsigned._basicTxBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]].\n     */\n    toBuffer = ():Buffer => {\n        return this._basicTxBuffer();\n    }\n\n    /**\n     * Returns a base-58 representation of the [[TxUnsigned]].\n     */\n    toString = ():string => {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Class representing an unsigned transaction.\n     * \n     * @param ins Optional array of the [[Input]]s\n     * @param outs Optional array of the [[Output]]s\n     * @param networkid Optional networkid, default 2\n     * @param blockchainid Optional blockchainid, default Buffer.alloc(32, 16)\n     * @param txtype Optional txtype, default 2\n     */\n    constructor(ins?:Array<Input>, outs?:Array<Output>, networkid:number = 2, blockchainid:Buffer = Buffer.alloc(32, 16), txtype:number = 0) {\n        this.txtype.writeUInt32BE(txtype, 0);\n        this.networkid.writeUInt32BE(networkid, 0);\n        this.blockchainid = blockchainid;\n        if(ins && outs){\n            this.numouts.writeUInt32BE(outs.length, 0);\n            this.outs = outs.sort(Output.comparator());\n            this.numins.writeUInt32BE(ins.length, 0);\n            this.ins = ins.sort(Input.comparator());\n        }\n    }\n}\n\n/**\n * Class representing a signed transaction.\n */\nexport class Tx {\n    protected tx:TxUnsigned = new TxUnsigned();\n    protected signatures:Array<Array<Signature>> = [];\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Tx]]\n     * \n     * @returns The length of the raw [[Tx]]\n     */\n    fromBuffer = (bytes:Buffer):number => {\n        this.tx = new TxUnsigned();\n        let offset:number = this.tx.fromBuffer(bytes);\n        let numcreds:number = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0);\n        offset += 4;\n        this.signatures = [];\n        for(let i = 0; i < numcreds; i++){\n            let sigarray:Array<Signature> = [];\n            let credential:number = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0);\n            offset += 4;\n            if(credential != Constants.SECPCREDENTIAL){\n                /* istanbul ignore next */\n                throw new Error(\"Error - Tx.fromBuffer: Invalid credentialID \" + credential);\n            }\n            let numsigs:number =   bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0);\n            offset += 4;\n            for(let j = 0; j  < numsigs; j++) {\n                let sig:Signature = new Signature();\n                sig.fromBuffer(bintools.copyFrom(bytes, offset, offset + 65));\n                sigarray.push(sig);\n                offset += 65;\n            }\n            this.signatures.push(sigarray);\n        }\n        return offset;\n    }\n    /**\n     * Takes a base-58 string containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes.\n     * \n     * @param serialized A base-58 string containing a raw [[Tx]]\n     * \n     * @returns The length of the raw [[Tx]]\n     * \n     * @remarks \n     * unlike most fromStrings, it expects the string to be serialized in AVA format\n     */\n    fromString = (serialized:string):number => {\n        return this.fromBuffer(bintools.avaDeserialize(serialized));\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Tx]].\n     */\n    toBuffer = ():Buffer => {\n        try {\n            let txbuff: Buffer = this.tx.toBuffer();\n            let bsize:number = txbuff.length;\n            let sigarrlen:Buffer = Buffer.alloc(4);\n            sigarrlen.writeUInt32BE(this.signatures.length, 0);\n            let barr:Array<Buffer> = [txbuff, sigarrlen];\n            bsize += sigarrlen.length;\n            for(let i = 0; i < this.signatures.length; i++){\n                let siglen:Buffer = Buffer.alloc(4);\n                siglen.writeUInt32BE(this.signatures[i].length, 0);\n                let credentialID = Buffer.alloc(4);\n                credentialID.writeUInt32BE(Constants.SECPCREDENTIAL, 0);\n                barr.push(credentialID);\n                bsize += credentialID.length;\n                barr.push(siglen);\n                bsize += siglen.length;\n                for(let j = 0; j < this.signatures[i].length; j++){\n                    let b:Buffer = this.signatures[i][j].toBuffer();\n                    barr.push(b);\n                    bsize += b.length;\n                }\n            }\n            let buff:Buffer = Buffer.concat(barr, bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - TxSigned.toBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a base-58 AVA-serialized representation of the [[Tx]].\n     * \n     * @remarks \n     * unlike most toStrings, this returns in AVA serialization format\n     */\n    toString = ():string => {\n        return bintools.avaSerialize(this.toBuffer());\n    }\n\n    /**\n     * Class representing a signed transaction.\n     * \n     * @param tx Optional [[Tx]]\n     * @param signatures Optional array of [[Signature]]s\n     */\n    constructor(tx?:TxUnsigned, signatures?:Array<Array<Signature>>) {\n        if(tx){\n            this.tx = tx;\n            if(signatures){\n                this.signatures = signatures\n            }\n        }\n    }\n}\n\n\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tx.js","sourceRoot":"","sources":["../../../../src/apis/avm/tx.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport { Signature, AVMConstants, InitialStates } from './types';\nimport { Output, SecpOutBase, SelectOutputClass } from './outputs';\nimport { Input, SelectInputClass } from './inputs';\nimport BinTools from '../../utils/bintools';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n/** \n * Class representing an unsigned transaction.\n * \n * @remarks\n * Unsigned Tx:\n * TxID      | 4 bytes\n * NetworkID  | 4 bytes\n * BlockchainID   | 32 bytes\n * NumOuts    | 4 bytes\n * Repeated (NumOuts):\n *     Out    | ? bytes\n * NumIns     | 4 bytes\n * Repeated (NumIns):\n *     In     | ? bytes\n */\n/* Tx:\n * Unsigned Tx | ? bytes\n * Repeated (NumIns):\n *     Sig     | ? bytes\n */\n/* Sig:\n * Repeated (NumSigs):\n *     Sig    | 65 bytes\n */\nexport class TxUnsigned {\n    protected txtype:Buffer = Buffer.alloc(4);\n    protected networkid:Buffer = Buffer.alloc(4);\n    protected blockchainid:Buffer = Buffer.alloc(32);\n    protected numouts:Buffer = Buffer.alloc(4);\n    protected outs:Array<Output>;\n    protected numins:Buffer = Buffer.alloc(4);\n    protected ins:Array<Input>;\n\n    /**\n     * Returns the number representation of the txtype\n     */\n    getTxType = ():number => {\n        return this.txtype.readUInt32BE(0);\n    }\n\n    /**\n     * Returns the number representation of the NetworkID\n     */\n    getNetworkID = ():number => {\n        return this.networkid.readUInt32BE(0);\n    }\n\n    /**\n     * Returns the Buffer representation of the BlockchainID\n     */\n    getBlockchainID = ():Buffer => {\n        return this.blockchainid;\n    }\n    \n    /**\n     * Returns the array of [[Input]]s\n     */\n    getIns = ():Array<Input> => {\n        return this.ins;\n    }\n\n    /**\n     * Returns the array of [[Output]]s\n     */\n    getOuts = ():Array<Output> => {\n        return this.outs;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxUnsigned]], parses it, populates the class, and returns the length of the TxUnsigned in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxUnsigned]]\n     * \n     * @returns The length of the raw [[TxUnsigned]]\n     * \n     * @remarks assume not-checksummed\n     */\n    fromBuffer(bytes:Buffer, offset:number = 0):number {\n        this.txtype = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        this.networkid = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        this.blockchainid = bintools.copyFrom(bytes, offset, offset + 32);\n        offset += 32;\n        this.numouts = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let outcount:number = this.numouts.readUInt32BE(0);\n        this.outs = [];\n        for(let i = 0; i < outcount; i++){\n            let outbuff:Buffer = bintools.copyFrom(bytes, offset, bytes.length);\n            let out:Output = SelectOutputClass(outbuff);\n            offset += out.fromBuffer(outbuff);\n            this.outs.push(out);\n        }\n        this.numins = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let incount:number = this.numins.readUInt32BE(0);\n        this.ins = [];\n        for(let i = 0; i < incount; i++){\n            let inbuff:Buffer = bintools.copyFrom(bytes, offset, bytes.length);\n            let input:Input = SelectInputClass(inbuff);\n            offset += input.fromBuffer(inbuff);\n            this.ins.push(input);\n        }\n        return offset;\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[TxUnsigned]].\n     */\n    toBuffer():Buffer {\n        try {\n            this.outs.sort(Output.comparator());\n            this.ins.sort(Input.comparator());\n            this.numouts.writeUInt32BE(this.outs.length, 0);\n            this.numins.writeUInt32BE(this.ins.length, 0);\n            let bsize:number = this.txtype.length + this.networkid.length + this.blockchainid.length + this.numouts.length;\n            let barr:Array<Buffer> = [this.txtype, this.networkid, this.blockchainid, this.numouts];\n            for(let i = 0; i < this.outs.length; i++) {\n                let b:Buffer = this.outs[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            barr.push(this.numins);\n            bsize += this.numins.length;\n            for(let i = 0; i < this.ins.length; i++) {\n                let b:Buffer = this.ins[i].toBuffer();\n                barr.push(b);\n                bsize += b.length;\n            }\n            let buff:Buffer = Buffer.concat(barr, bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - TxUnsigned.toBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a base-58 representation of the [[TxUnsigned]].\n     */\n    toString():string {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n\n    /**\n     * Class representing an unsigned transaction.\n     * \n     * @param ins Optional array of the [[Input]]s\n     * @param outs Optional array of the [[Output]]s\n     * @param networkid Optional networkid, default 2\n     * @param blockchainid Optional blockchainid, default Buffer.alloc(32, 16)\n     * @param txtype Optional txtype, default 2\n     */\n    constructor(ins?:Array<Input>, outs?:Array<Output>, networkid:number = 2, blockchainid:Buffer = Buffer.alloc(32, 16), txtype:number = 0) {\n        this.txtype.writeUInt32BE(txtype, 0);\n        this.networkid.writeUInt32BE(networkid, 0);\n        this.blockchainid = blockchainid;\n        if(ins && outs){\n            this.numouts.writeUInt32BE(outs.length, 0);\n            this.outs = outs.sort(Output.comparator());\n            this.numins.writeUInt32BE(ins.length, 0);\n            this.ins = ins.sort(Input.comparator());\n        }\n    }\n}\n\nexport class TxCreateAsset extends TxUnsigned {\n    protected name:string = \"\";\n    protected namebuff:Buffer = Buffer.alloc(2);\n    protected symbol:string = \"\";\n    protected symbolbuff:Buffer = Buffer.alloc(2);\n    protected denomination:Buffer = Buffer.alloc(1);\n    protected initialstate:InitialStates = new InitialStates();\n\n    /**\n     * Returns the array of array of [[Output]]s for the initial state\n     */\n    getInitialStates = ():InitialStates => {\n        return this.initialstate;\n    }\n\n    /**\n     * Returns the string representation of the name\n     */\n    getName = ():string => {\n        return this.name;\n    }\n\n    /**\n     * Returns the {@link https://github.com/feross/buffer|Buffer} representation of the name\n     */\n    getNameBuffer = ():Buffer => {\n        return this.namebuff;\n    }\n\n    /**\n     * Returns the string representation of the symbol\n     */\n    getSymbol = ():string => {\n        return this.symbol;\n    }\n\n    /**\n     * Returns the {@link https://github.com/feross/buffer|Buffer} representation of the symbol\n     */\n    getSymbolBuffer = ():Buffer => {\n        return this.symbolbuff;\n    }\n\n    /**\n     * Returns the numeric representation of the denomination\n     */\n    getDenomination = ():number => {\n        return this.denomination.readUInt8(0);\n    }\n\n\n    /**\n     * Returns the {@link https://github.com/feross/buffer|Buffer} representation of the denomination\n     */\n    getDenominationBuffer = ():Buffer => {\n        return this.denomination;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[TxCreateAsset]], parses it, populates the class, and returns the length of the TxUnsigned in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[TxCreateAsset]]\n     * \n     * @returns The length of the raw [[TxCreateAsset]]\n     * \n     * @remarks assume not-checksummed\n     */\n    fromBuffer(bytes:Buffer, offset:number = 0):number {\n        offset = super.fromBuffer(bytes, offset);\n        let namesize:number = bintools.copyFrom(bytes, offset, offset + 2).readUInt16BE(0);\n        this.namebuff = bintools.copyFrom(bytes, offset, offset + 2 + namesize);\n        offset += 2;\n        offset += namesize;\n        let symsize:number = bintools.copyFrom(bytes, offset, offset + 2).readUInt16BE(0);\n        this.symbolbuff = bintools.copyFrom(bytes, offset, offset + 2 + symsize);\n        offset += 2;\n        offset += symsize;\n        this.denomination = bintools.copyFrom(bytes, offset, offset + 1);\n        offset += 1;\n        let inits:InitialStates = new InitialStates();\n        offset = inits.fromBuffer(bytes, offset);\n        this.initialstate = inits;\n\n        return offset;\n    }\n\n    toBuffer():Buffer {\n        let barr:Array<Buffer> = [super.toBuffer(), this.namebuff, this.symbolbuff, this.denomination, this.initialstate.toBuffer()];\n        return Buffer.concat(barr);\n    }\n    \n    /**\n     * Class representing an unsigned Create Asset transaction.\n     * \n     * @param name String for the descriptive name of the asset\n     * @param symbol String for the ticker symbol of the asset\n     * @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA\n     * @param initialstate Optional [[InitialStates]] that represent the intial state of a created asset\n     * @param ins Optional array of the [[Input]]s\n     * @param outs Optional array of the [[Output]]s\n     * @param networkid Optional networkid, default 2\n     * @param blockchainid Optional blockchainid, default Buffer.alloc(32, 16)\n     * @param txtype Optional txtype, default 1\n     */\n    constructor(name:string = undefined, symbol:string = undefined, denomination:number = undefined, initialstate:InitialStates = undefined, ins:Array<Input> = undefined, outs:Array<Output> = undefined, networkid:number = 2, blockchainid:Buffer = Buffer.alloc(32, 16), txtype:number = AVMConstants.CREATEASSETTX) {\n        super(ins, outs, networkid, blockchainid, txtype);\n        if(typeof name === 'string' && typeof symbol === 'string' && typeof denomination === 'number' && denomination >= 0 && denomination <= 32 && initialstate) {\n            this.initialstate = initialstate;\n            this.namebuff = bintools.stringToBuffer(name);\n            this.name = name;\n            this.symbolbuff = bintools.stringToBuffer(symbol);\n            this.symbol = symbol;\n            this.denomination.writeUInt8(denomination, 0);\n        }\n    }\n}\n\n/**\n * Class representing a signed transaction.\n */\nexport class Tx {\n    protected tx:TxUnsigned = new TxUnsigned();\n    protected signatures:Array<Array<Signature>> = [];\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} containing a raw [[Tx]]\n     * \n     * @returns The length of the raw [[Tx]]\n     */\n    fromBuffer(bytes:Buffer):number {\n        this.tx = new TxUnsigned();\n        let offset:number = this.tx.fromBuffer(bytes);\n        let numcreds:number = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0);\n        offset += 4;\n        this.signatures = [];\n        for(let i = 0; i < numcreds; i++){\n            let sigarray:Array<Signature> = [];\n            let credential:number = bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0);\n            offset += 4;\n            if(credential != AVMConstants.SECPCREDENTIAL){\n                /* istanbul ignore next */\n                throw new Error(\"Error - Tx.fromBuffer: Invalid credentialID \" + credential);\n            }\n            let numsigs:number =   bintools.copyFrom(bytes, offset, offset + 4).readUInt32BE(0);\n            offset += 4;\n            for(let j = 0; j  < numsigs; j++) {\n                let sig:Signature = new Signature();\n                sig.fromBuffer(bintools.copyFrom(bytes, offset, offset + 65));\n                sigarray.push(sig);\n                offset += 65;\n            }\n            this.signatures.push(sigarray);\n        }\n        return offset;\n    }\n    /**\n     * Takes a base-58 string containing an [[Tx]], parses it, populates the class, and returns the length of the Tx in bytes.\n     * \n     * @param serialized A base-58 string containing a raw [[Tx]]\n     * \n     * @returns The length of the raw [[Tx]]\n     * \n     * @remarks \n     * unlike most fromStrings, it expects the string to be serialized in AVA format\n     */\n    fromString(serialized:string):number {\n        return this.fromBuffer(bintools.avaDeserialize(serialized));\n    }\n\n    /**\n     * Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[Tx]].\n     */\n    toBuffer():Buffer {\n        try {\n            let txbuff: Buffer = this.tx.toBuffer();\n            let bsize:number = txbuff.length;\n            let sigarrlen:Buffer = Buffer.alloc(4);\n            sigarrlen.writeUInt32BE(this.signatures.length, 0);\n            let barr:Array<Buffer> = [txbuff, sigarrlen];\n            bsize += sigarrlen.length;\n            for(let i = 0; i < this.signatures.length; i++){\n                let siglen:Buffer = Buffer.alloc(4);\n                siglen.writeUInt32BE(this.signatures[i].length, 0);\n                let credentialID = Buffer.alloc(4);\n                credentialID.writeUInt32BE(AVMConstants.SECPCREDENTIAL, 0);\n                barr.push(credentialID);\n                bsize += credentialID.length;\n                barr.push(siglen);\n                bsize += siglen.length;\n                for(let j = 0; j < this.signatures[i].length; j++){\n                    let b:Buffer = this.signatures[i][j].toBuffer();\n                    barr.push(b);\n                    bsize += b.length;\n                }\n            }\n            let buff:Buffer = Buffer.concat(barr, bsize);\n            return buff;\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - TxSigned.toBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n    }\n\n    /**\n     * Returns a base-58 AVA-serialized representation of the [[Tx]].\n     * \n     * @remarks \n     * unlike most toStrings, this returns in AVA serialization format\n     */\n    toString():string {\n        return bintools.avaSerialize(this.toBuffer());\n    }\n\n    /**\n     * Class representing a signed transaction.\n     * \n     * @param tx Optional [[Tx]]\n     * @param signatures Optional array of [[Signature]]s\n     */\n    constructor(tx?:TxUnsigned, signatures?:Array<Array<Signature>>) {\n        if(tx){\n            this.tx = tx;\n            if(signatures){\n                this.signatures = signatures\n            }\n        }\n    }\n}\n\n\n"]} |
@@ -0,3 +1,8 @@ | ||
/** | ||
* @module AVMAPI | ||
*/ | ||
import { Buffer } from "buffer/"; | ||
import { NBytes } from '../../utils/types'; | ||
import BN from "bn.js"; | ||
import { Output } from './outputs'; | ||
/** | ||
@@ -7,11 +12,11 @@ * Type representing a [[Signature]] index used in [[Input]] | ||
export declare class SigIdx extends NBytes { | ||
source: string; | ||
source: Buffer; | ||
/** | ||
* Sets the source address for the signature | ||
*/ | ||
setSource: (address: string) => void; | ||
setSource: (address: Buffer) => void; | ||
/** | ||
* Retrieves the source address for the signature | ||
*/ | ||
getSource: () => string; | ||
getSource: () => Buffer; | ||
/** | ||
@@ -42,3 +47,3 @@ * Type representing a [[Signature]] index used in [[Input]] | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
@@ -51,3 +56,3 @@ * Takes a base-58 string containing an [[Address]], parses it, populates the class, and returns the length of the Address in bytes. | ||
*/ | ||
fromString: (addr: string) => number; | ||
fromString(addr: string): number; | ||
/** | ||
@@ -58,7 +63,23 @@ * Class for representing an address used in [[Output]] types | ||
} | ||
export declare class Constants { | ||
export declare class InitialStates { | ||
protected fxs: { | ||
[fxid: number]: Array<Output>; | ||
}; | ||
addOutput(out: Output, fxid: number): void; | ||
fromBuffer(bytes: Buffer, offset: number): number; | ||
toBuffer(): Buffer; | ||
constructor(); | ||
} | ||
export declare class AVMConstants { | ||
static SECPOUTPUTID: number; | ||
static SECPINPUTID: number; | ||
static CREATEASSETTX: number; | ||
static BASETX: number; | ||
static SECPCREDENTIAL: number; | ||
static ASSETIDLEN: number; | ||
static BLOCKCHAINIDLEN: number; | ||
static SYMBOLMAXLEN: number; | ||
static ASSETNAMELEN: number; | ||
static ADDRESSLENGTH: number; | ||
static SECPFXID: number; | ||
} | ||
@@ -65,0 +86,0 @@ /** |
@@ -13,2 +13,3 @@ "use strict"; | ||
const bintools_1 = __importDefault(require("../../utils/bintools")); | ||
const outputs_1 = require("./outputs"); | ||
/** | ||
@@ -67,38 +68,38 @@ * @ignore | ||
super(); | ||
/** | ||
* Returns a base-58 representation of the [[Address]]. | ||
*/ | ||
this.toString = () => { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
}; | ||
/** | ||
* Takes a base-58 string containing an [[Address]], parses it, populates the class, and returns the length of the Address in bytes. | ||
* | ||
* @param bytes A base-58 string containing a raw [[Address]] | ||
* | ||
* @returns The length of the raw [[Address]] | ||
*/ | ||
this.fromString = (addr) => { | ||
let addrbuff = bintools.b58ToBuffer(addr); | ||
if (addrbuff.length == 24 && bintools.validateChecksum(addrbuff)) { | ||
let newbuff = bintools.copyFrom(addrbuff, 0, addrbuff.length - 4); | ||
if (newbuff.length == 20) { | ||
this.bytes = newbuff; | ||
} | ||
} | ||
else if (addrbuff.length == 24) { | ||
throw new Error("Error - Address.fromString: invalid checksum on address"); | ||
} | ||
else if (addrbuff.length == 20) { | ||
this.bytes = addrbuff; | ||
} | ||
else { | ||
/* istanbul ignore next */ | ||
throw new Error("Error - Address.fromString: invalid address"); | ||
} | ||
return this.getSize(); | ||
}; | ||
this.bytes = buffer_1.Buffer.alloc(20); | ||
this.bsize = 20; | ||
} | ||
/** | ||
* Returns a base-58 representation of the [[Address]]. | ||
*/ | ||
toString() { | ||
return bintools.avaSerialize(this.toBuffer()); | ||
} | ||
/** | ||
* Takes a base-58 string containing an [[Address]], parses it, populates the class, and returns the length of the Address in bytes. | ||
* | ||
* @param bytes A base-58 string containing a raw [[Address]] | ||
* | ||
* @returns The length of the raw [[Address]] | ||
*/ | ||
fromString(addr) { | ||
let addrbuff = bintools.b58ToBuffer(addr); | ||
if (addrbuff.length == 24 && bintools.validateChecksum(addrbuff)) { | ||
let newbuff = bintools.copyFrom(addrbuff, 0, addrbuff.length - 4); | ||
if (newbuff.length == 20) { | ||
this.bytes = newbuff; | ||
} | ||
} | ||
else if (addrbuff.length == 24) { | ||
throw new Error("Error - Address.fromString: invalid checksum on address"); | ||
} | ||
else if (addrbuff.length == 20) { | ||
this.bytes = addrbuff; | ||
} | ||
else { | ||
/* istanbul ignore next */ | ||
throw new Error("Error - Address.fromString: invalid address"); | ||
} | ||
return this.getSize(); | ||
} | ||
} | ||
@@ -114,9 +115,74 @@ exports.Address = Address; | ||
}; | ||
class Constants { | ||
class InitialStates { | ||
constructor() { | ||
this.fxs = {}; | ||
} | ||
addOutput(out, fxid) { | ||
if (!(fxid in this.fxs)) { | ||
this.fxs[fxid] = []; | ||
} | ||
this.fxs[fxid].push(out); | ||
} | ||
fromBuffer(bytes, offset) { | ||
let result = {}; | ||
let klen = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let klennum = klen.readUInt32BE(0); | ||
for (let i = 0; i < klennum; i++) { | ||
let fxidbuff = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let fxid = fxidbuff.readUInt32BE(0); | ||
result[fxid] = []; | ||
let statelenbuff = bintools.copyFrom(bytes, offset, offset + 4); | ||
offset += 4; | ||
let statelen = statelenbuff.readUInt32BE(0); | ||
for (let j = 0; j < statelen; j++) { | ||
let abuff = bintools.copyFrom(bytes, offset); | ||
let out = new outputs_1.SecpOutBase(); | ||
out.fromBuffer(abuff); | ||
let outbuff = out.toBuffer(); | ||
offset += outbuff.length; | ||
result[fxid].push(out); | ||
} | ||
} | ||
this.fxs = result; | ||
return offset; | ||
} | ||
toBuffer() { | ||
let buff = []; | ||
let keys = Object.keys(this.fxs).map(k => parseInt(k)).sort(); | ||
let klen = buffer_1.Buffer.alloc(4); | ||
klen.writeUInt32BE(keys.length, 0); | ||
buff.push(klen); | ||
for (let i = 0; i < keys.length; i++) { | ||
let fxid = keys[i]; | ||
let fxidbuff = buffer_1.Buffer.alloc(4); | ||
fxidbuff.writeUInt32BE(fxid, 0); | ||
buff.push(fxidbuff); | ||
let initialState = this.fxs[fxid].sort(outputs_1.Output.comparator()); | ||
let statelen = buffer_1.Buffer.alloc(4); | ||
statelen.writeUInt32BE(initialState.length, 0); | ||
buff.push(statelen); | ||
for (let j = 0; j < initialState.length; j++) { | ||
buff.push(initialState[j].toBuffer()); | ||
} | ||
} | ||
return buffer_1.Buffer.concat(buff); | ||
} | ||
} | ||
exports.Constants = Constants; | ||
Constants.SECPOUTPUTID = 4; | ||
Constants.SECPINPUTID = 6; | ||
Constants.BASETX = 0; | ||
Constants.SECPCREDENTIAL = 7; | ||
exports.InitialStates = InitialStates; | ||
class AVMConstants { | ||
} | ||
exports.AVMConstants = AVMConstants; | ||
AVMConstants.SECPOUTPUTID = 4; | ||
AVMConstants.SECPINPUTID = 6; | ||
AVMConstants.CREATEASSETTX = 1; | ||
AVMConstants.BASETX = 0; | ||
AVMConstants.SECPCREDENTIAL = 7; | ||
AVMConstants.ASSETIDLEN = 32; | ||
AVMConstants.BLOCKCHAINIDLEN = 32; | ||
AVMConstants.SYMBOLMAXLEN = 4; | ||
AVMConstants.ASSETNAMELEN = 128; | ||
AVMConstants.ADDRESSLENGTH = 20; | ||
AVMConstants.SECPFXID = 0; | ||
/** | ||
@@ -130,2 +196,2 @@ * Function providing the current UNIX time using a {@link https://github.com/indutny/bn.js/|BN} | ||
; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/apis/avm/types.ts"],"names":[],"mappings":";;;;;AAAA;;GAEG;AACH,oCAA+B;AAC/B,6CAA2C;AAC3C,kDAAuB;AACvB,oEAA4C;AAE5C;;GAEG;AACH,IAAI,QAAQ,GAAY,kBAAQ,CAAC,WAAW,EAAE,CAAC;AAE/C;;GAEG;AACH,MAAa,MAAO,SAAQ,cAAM;IAiB9B;;OAEG;IACH;QACI,KAAK,EAAE,CAAC;QAlBZ;;WAEG;QACH,cAAS,GAAG,CAAC,OAAc,EAAE,EAAE;YAC3B,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC;QAC1B,CAAC,CAAA;QAED;;WAEG;QACH,cAAS,GAAG,GAAU,EAAE;YACpB,OAAO,IAAI,CAAC,MAAM,CAAC;QACvB,CAAC,CAAA;QAOG,IAAI,CAAC,KAAK,GAAG,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC7B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACnB,CAAC;CACJ;AAzBD,wBAyBC;AAED;;GAEG;AACH,MAAa,SAAU,SAAQ,cAAM;IAEjC;;OAEG;IACH;QACI,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,eAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;IACpB,CAAC;CACJ;AAVD,8BAUC;AAED;;GAEG;AACH,MAAa,OAAQ,SAAQ,cAAM;IAyC/B;;OAEG;IACH;QACI,KAAK,EAAE,CAAC;QAnCZ;;WAEG;QACH,aAAQ,GAAG,GAAU,EAAE;YACnB,OAAO,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAClD,CAAC,CAAA;QACD;;;;;;WAMG;QACH,eAAU,GAAG,CAAC,IAAW,EAAS,EAAE;YAChC,IAAI,QAAQ,GAAU,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YACjD,IAAG,QAAQ,CAAC,MAAM,IAAI,EAAE,IAAI,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE;gBAC7D,IAAI,OAAO,GAAU,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,EAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBACxE,IAAG,OAAO,CAAC,MAAM,IAAI,EAAE,EAAC;oBACpB,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC;iBACxB;aACJ;iBAAM,IAAG,QAAQ,CAAC,MAAM,IAAI,EAAE,EAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;aAC9E;iBAAM,IAAG,QAAQ,CAAC,MAAM,IAAI,EAAE,EAAC;gBAC5B,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;aACzB;iBAAM;gBACH,0BAA0B;gBAC1B,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;aAClE;YACD,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;QAC1B,CAAC,CAAA;QAOG,IAAI,CAAC,KAAK,GAAG,eAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;IACpB,CAAC;;AAhDL,0BAiDC;AA/CG;;GAEG;AACI,kBAAU,GAAG,GAAsC,EAAE;IACxD,OAAO,UAAS,CAAS,EAAE,CAAS;QAChC,OAAO,eAAM,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAa,CAAC;IAClE,CAAC,CAAA;AACL,CAAC,CAAA;AA0CL,MAAa,SAAS;;AAAtB,8BAKC;AAJU,sBAAY,GAAU,CAAC,CAAC;AACxB,qBAAW,GAAU,CAAC,CAAC;AACvB,gBAAM,GAAU,CAAC,CAAC;AAClB,wBAAc,GAAS,CAAC,CAAC;AAepC;;GAEG;AACH,SAAgB,OAAO;IACnB,OAAO,IAAI,eAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;AAC7D,CAAC;AAFD,0BAEC;AAAA,CAAC","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport { NBytes } from '../../utils/types';\nimport BN from \"bn.js\";\nimport BinTools from '../../utils/bintools';\n\n/**\n * @ignore\n */\nlet bintools:BinTools = BinTools.getInstance();\n\n/**\n * Type representing a [[Signature]] index used in [[Input]]\n */\nexport class SigIdx extends NBytes {\n    source:string;\n\n    /**\n     * Sets the source address for the signature\n     */\n    setSource = (address:string) => {\n        this.source = address;\n    }\n\n    /**\n     * Retrieves the source address for the signature\n     */\n    getSource = ():string => {\n        return this.source;\n    }\n\n    /**\n     * Type representing a [[Signature]] index used in [[Input]]\n     */\n    constructor(){\n        super();\n        this.bytes = Buffer.alloc(4);\n        this.bsize = 4;\n    }\n}\n\n/**\n * Signature for a [[Tx]]\n */\nexport class Signature extends NBytes {\n\n    /**\n     * Signature for a [[Tx]]\n     */\n    constructor(){\n        super();\n        this.bytes = Buffer.alloc(65);\n        this.bsize = 65;\n    }\n}\n\n/**\n * Class for representing an address used in [[Output]] types\n */\nexport class Address extends NBytes {\n\n    /**\n     * Returns a function used to sort an array of [[Address]]es\n     */\n    static comparitor = ():(a:Address, b:Address) => (1|-1|0) => {\n        return function(a:Address, b:Address):(1|-1|0) { \n            return Buffer.compare(a.toBuffer(), b.toBuffer()) as (1|-1|0);\n        }\n    }\n    /**\n     * Returns a base-58 representation of the [[Address]].\n     */\n    toString = ():string => {\n        return bintools.avaSerialize(this.toBuffer());\n    }\n    /**\n     * Takes a base-58 string containing an [[Address]], parses it, populates the class, and returns the length of the Address in bytes.\n     * \n     * @param bytes A base-58 string containing a raw [[Address]]\n     * \n     * @returns The length of the raw [[Address]]\n     */\n    fromString = (addr:string):number => {\n        let addrbuff:Buffer = bintools.b58ToBuffer(addr);\n        if(addrbuff.length == 24 && bintools.validateChecksum(addrbuff)) {\n            let newbuff:Buffer = bintools.copyFrom(addrbuff, 0,addrbuff.length - 4);\n            if(newbuff.length == 20){\n                this.bytes = newbuff;\n            }\n        } else if(addrbuff.length == 24){\n            throw new Error(\"Error - Address.fromString: invalid checksum on address\");\n        } else if(addrbuff.length == 20){\n            this.bytes = addrbuff;\n        } else {\n            /* istanbul ignore next */\n            throw new Error(\"Error - Address.fromString: invalid address\");\n        }\n        return this.getSize();\n    }\n\n    /**\n     * Class for representing an address used in [[Output]] types\n     */\n    constructor(){\n        super();\n        this.bytes = Buffer.alloc(20);\n        this.bsize = 20;\n    }\n}\n\nexport class Constants {\n    static SECPOUTPUTID:number = 4;\n    static SECPINPUTID:number = 6;\n    static BASETX:number = 0;\n    static SECPCREDENTIAL:number =7;\n}\n\n/**\n * Rules used when merging sets\n */\nexport type MergeRule = \"intersection\" //Self INTERSECT New \n                        | \"differenceSelf\" //Self MINUS New\n                        | \"differenceNew\" //New MINUS Self\n                        | \"symDifference\" //differenceSelf UNION differenceNew\n                        | \"union\" //Self UNION New\n                        | \"unionMinusNew\" //union MINUS differenceNew\n                        | \"unionMinusSelf\" //union MINUS differenceSelf\n                        | \"ERROR\"; //generate error for testing\n\n/**\n * Function providing the current UNIX time using a {@link https://github.com/indutny/bn.js/|BN}\n */\nexport function UnixNow():BN {\n    return new BN(Math.round((new Date()).getTime() / 1000));\n};"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/apis/avm/types.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module AVMAPI\n */\nimport {Buffer} from \"buffer/\";\nimport { NBytes } from '../../utils/types';\nimport BN from \"bn.js\";\nimport BinTools from '../../utils/bintools';\nimport { Output, SelectOutputClass, SecpOutBase } from './outputs';\n\n/**\n * @ignore\n */\nlet bintools:BinTools = BinTools.getInstance();\n\n/**\n * Type representing a [[Signature]] index used in [[Input]]\n */\nexport class SigIdx extends NBytes {\n    source:Buffer;\n\n    /**\n     * Sets the source address for the signature\n     */\n    setSource = (address:Buffer) => {\n        this.source = address;\n    }\n\n    /**\n     * Retrieves the source address for the signature\n     */\n    getSource = ():Buffer => {\n        return this.source;\n    }\n\n    /**\n     * Type representing a [[Signature]] index used in [[Input]]\n     */\n    constructor(){\n        super();\n        this.bytes = Buffer.alloc(4);\n        this.bsize = 4;\n    }\n}\n\n/**\n * Signature for a [[Tx]]\n */\nexport class Signature extends NBytes {\n\n    /**\n     * Signature for a [[Tx]]\n     */\n    constructor(){\n        super();\n        this.bytes = Buffer.alloc(65);\n        this.bsize = 65;\n    }\n}\n\n/**\n * Class for representing an address used in [[Output]] types\n */\nexport class Address extends NBytes {\n\n    /**\n     * Returns a function used to sort an array of [[Address]]es\n     */\n    static comparitor = ():(a:Address, b:Address) => (1|-1|0) => {\n        return function(a:Address, b:Address):(1|-1|0) { \n            return Buffer.compare(a.toBuffer(), b.toBuffer()) as (1|-1|0);\n        }\n    }\n    /**\n     * Returns a base-58 representation of the [[Address]].\n     */\n    toString():string {\n        return bintools.avaSerialize(this.toBuffer());\n    }\n    /**\n     * Takes a base-58 string containing an [[Address]], parses it, populates the class, and returns the length of the Address in bytes.\n     * \n     * @param bytes A base-58 string containing a raw [[Address]]\n     * \n     * @returns The length of the raw [[Address]]\n     */\n    fromString(addr:string):number {\n        let addrbuff:Buffer = bintools.b58ToBuffer(addr);\n        if(addrbuff.length == 24 && bintools.validateChecksum(addrbuff)) {\n            let newbuff:Buffer = bintools.copyFrom(addrbuff, 0,addrbuff.length - 4);\n            if(newbuff.length == 20){\n                this.bytes = newbuff;\n            }\n        } else if(addrbuff.length == 24){\n            throw new Error(\"Error - Address.fromString: invalid checksum on address\");\n        } else if(addrbuff.length == 20){\n            this.bytes = addrbuff;\n        } else {\n            /* istanbul ignore next */\n            throw new Error(\"Error - Address.fromString: invalid address\");\n        }\n        return this.getSize();\n    }\n\n    /**\n     * Class for representing an address used in [[Output]] types\n     */\n    constructor(){\n        super();\n        this.bytes = Buffer.alloc(20);\n        this.bsize = 20;\n    }\n}\n\nexport class InitialStates {\n    protected fxs:{[fxid:number]:Array<Output>} = {};\n\n    addOutput(out:Output, fxid:number):void {\n        if(!(fxid in this.fxs)){\n            this.fxs[fxid] = [];\n        }\n        this.fxs[fxid].push(out);\n    }\n\n    fromBuffer(bytes:Buffer, offset:number):number {\n        let result:{[fxid:number]:Array<Output>} = {};\n        let klen:Buffer = bintools.copyFrom(bytes, offset, offset + 4);\n        offset += 4;\n        let klennum:number = klen.readUInt32BE(0);\n        for(let i = 0; i < klennum; i++){\n            let fxidbuff:Buffer = bintools.copyFrom(bytes, offset, offset + 4);\n            offset += 4;\n            let fxid:number = fxidbuff.readUInt32BE(0);\n            result[fxid] = [];\n            let statelenbuff:Buffer = bintools.copyFrom(bytes, offset, offset + 4);\n            offset += 4;\n            let statelen:number = statelenbuff.readUInt32BE(0);\n            for(let j = 0; j < statelen; j++){\n                let abuff:Buffer = bintools.copyFrom(bytes, offset);\n                let out:Output = new SecpOutBase();\n                out.fromBuffer(abuff)\n                let outbuff:Buffer = out.toBuffer();\n                offset += outbuff.length;\n                result[fxid].push(out);\n            }\n        }\n        this.fxs = result;\n        return offset\n    }\n\n    toBuffer():Buffer {\n        let buff:Array<Buffer> = [];\n        let keys:Array<number> = Object.keys(this.fxs).map(k => parseInt(k)).sort();\n        let klen:Buffer = Buffer.alloc(4);\n        klen.writeUInt32BE(keys.length, 0);\n        buff.push(klen);\n        for(let i = 0; i < keys.length; i++){\n            let fxid:number = keys[i];\n            let fxidbuff:Buffer = Buffer.alloc(4);\n            fxidbuff.writeUInt32BE(fxid, 0);\n            buff.push(fxidbuff);\n            let initialState = this.fxs[fxid].sort(Output.comparator());\n            let statelen:Buffer = Buffer.alloc(4);\n            statelen.writeUInt32BE(initialState.length, 0);\n            buff.push(statelen);\n            for(let j = 0; j < initialState.length; j++){\n                buff.push(initialState[j].toBuffer());\n            }\n        }\n        return Buffer.concat(buff);\n    }\n    constructor(){}\n}\n\nexport class AVMConstants {\n    static SECPOUTPUTID:number = 4;\n    static SECPINPUTID:number = 6;\n    static CREATEASSETTX:number = 1;\n    static BASETX:number = 0;\n    static SECPCREDENTIAL:number = 7;\n    static ASSETIDLEN:number = 32;\n    static BLOCKCHAINIDLEN:number = 32;\n    static SYMBOLMAXLEN:number = 4;\n    static ASSETNAMELEN:number = 128;\n    static ADDRESSLENGTH:number = 20;\n    static SECPFXID:number = 0;\n}\n\n/**\n * Rules used when merging sets\n */\nexport type MergeRule = \"intersection\" //Self INTERSECT New \n                        | \"differenceSelf\" //Self MINUS New\n                        | \"differenceNew\" //New MINUS Self\n                        | \"symDifference\" //differenceSelf UNION differenceNew\n                        | \"union\" //Self UNION New\n                        | \"unionMinusNew\" //union MINUS differenceNew\n                        | \"unionMinusSelf\" //union MINUS differenceSelf\n                        | \"ERROR\"; //generate error for testing\n\n/**\n * Function providing the current UNIX time using a {@link https://github.com/indutny/bn.js/|BN}\n */\nexport function UnixNow():BN {\n    return new BN(Math.round((new Date()).getTime() / 1000));\n};"]} |
@@ -7,4 +7,4 @@ /** | ||
import { SecpOutput } from './outputs'; | ||
import { MergeRule } from './types'; | ||
import { TxUnsigned } from './tx'; | ||
import { MergeRule, InitialStates } from './types'; | ||
import { TxUnsigned, TxCreateAsset } from './tx'; | ||
/** | ||
@@ -21,6 +21,6 @@ * Takes a buffer representing the output and returns the proper UTXO instance. | ||
*/ | ||
export declare abstract class UTXO { | ||
export declare class UTXO { | ||
protected txid: Buffer; | ||
protected txidx: Buffer; | ||
abstract getOuputID: () => number; | ||
getOuputID(): number; | ||
/** | ||
@@ -38,3 +38,2 @@ * Returns a {@link https://github.com/feross/buffer|Buffer} of the TxID. | ||
getUTXOID: () => string; | ||
_basicUTXOBuffer: (utxobuff: any) => void; | ||
/** | ||
@@ -45,3 +44,3 @@ * Takes a {@link https://github.com/feross/buffer|Buffer} containing an [[UTXO]], parses it, populates the class, and returns the length of the UTXO in bytes. | ||
*/ | ||
fromBuffer: (utxobuff: Buffer) => void; | ||
fromBuffer(utxobuff: Buffer, offset?: number): number; | ||
/** | ||
@@ -57,7 +56,7 @@ * Takes a base-58 string containing an [[UTXO]], parses it, populates the class, and returns the length of the UTXO in bytes. | ||
*/ | ||
fromString: (serialized: string) => void; | ||
fromString(serialized: string): number; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[UTXO]]. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
@@ -69,7 +68,8 @@ * Returns a base-58 representation of the [[UTXO]]. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
* Class for representing a single UTXO. | ||
* | ||
* @param serialized Optional parameter of the serialized string representing a UTXO | ||
* @param txid Optional {@link https://github.com/feross/buffer|Buffer} of transaction ID for the UTXO | ||
* @param txidx Optional number for the index of the transaction's [[Output]] | ||
*/ | ||
@@ -91,5 +91,3 @@ constructor(txid?: Buffer, txidx?: number); | ||
*/ | ||
getAddresses: () => { | ||
[address: string]: BN; | ||
}; | ||
getAddresses: () => Buffer[]; | ||
/** | ||
@@ -100,3 +98,3 @@ * Gets the index of the address in the output. | ||
*/ | ||
getAddressIdx: (address: string) => number; | ||
getAddressIdx: (address: Buffer) => number; | ||
/** | ||
@@ -107,5 +105,5 @@ * Gets the address at the index. | ||
* | ||
* @returns A string representing the address. | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representing the address. | ||
*/ | ||
getAddress: (idx: number) => string; | ||
getAddress: (idx: number) => Buffer; | ||
/** | ||
@@ -124,2 +122,6 @@ * Returns a {@link https://github.com/feross/buffer|Buffer} of the assetID. | ||
/** | ||
* Returns a {@link https://github.com/indutny/bn.js/|BN} of the locktime. | ||
*/ | ||
getLocktime: () => BN; | ||
/** | ||
* Returns the UTXOID as a base-58 string (UTXOID is a string ) | ||
@@ -133,3 +135,3 @@ */ | ||
*/ | ||
fromBuffer: (utxobuff: Buffer) => void; | ||
fromBuffer(utxobuff: Buffer, offset?: number): number; | ||
/** | ||
@@ -145,7 +147,7 @@ * Takes a base-58 string containing an [[UTXO]], parses it, populates the class, and returns the length of the UTXO in bytes. | ||
*/ | ||
fromString: (serialized: string) => void; | ||
fromString(serialized: string): number; | ||
/** | ||
* Returns a {@link https://github.com/feross/buffer|Buffer} representation of the [[UTXO]]. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
@@ -157,11 +159,11 @@ * Returns a base-58 representation of the [[UTXO]]. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
* Given an array of addresses and an optional timestamp, returns an array of address strings of qualified spenders for the output. | ||
*/ | ||
getSpenders: (addresses: string[], asOf?: BN) => string[]; | ||
getSpenders: (addresses: Buffer[], asOf?: BN) => Buffer[]; | ||
/** | ||
* Given an array of addresses and an optional timestamp, returns true if the addresses meet the threshold required to spend the output. | ||
*/ | ||
meetsThreshold: (addresses: string[], asOf?: BN) => boolean; | ||
meetsThreshold: (addresses: Buffer[], asOf?: BN) => boolean; | ||
/** | ||
@@ -255,3 +257,3 @@ * Class for representing a single UTXO. | ||
* | ||
* @param address An address or array of addresses | ||
* @param address An array of address {@link https://github.com/feross/buffer|Buffer}s | ||
* @param spendable If true, only retrieves UTXOIDs whose locktime has passed | ||
@@ -261,7 +263,7 @@ * | ||
*/ | ||
getUTXOIDs: (address?: string | string[], spendable?: boolean) => string[]; | ||
getUTXOIDs: (addresses?: Buffer[], spendable?: boolean) => string[]; | ||
/** | ||
* Gets the addresses in the [[UTXOSet]]. | ||
* Gets the addresses in the [[UTXOSet]] and returns an array of {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
getAddresses: () => string[]; | ||
getAddresses: () => Buffer[]; | ||
/** | ||
@@ -276,3 +278,3 @@ * Returns the balance of a set of addresses in the UTXOSet. | ||
*/ | ||
getBalance: (addresses: string[], assetID: string | Buffer, asOf?: BN) => BN; | ||
getBalance: (addresses: Buffer[], assetID: string | Buffer, asOf?: BN) => BN; | ||
/** | ||
@@ -285,6 +287,6 @@ * Gets all the Asset IDs, optionally that match with Asset IDs in an array | ||
*/ | ||
getAssetIDs: (addresses?: string | string[]) => Buffer[]; | ||
getAssetIDs: (addresses?: Buffer[]) => Buffer[]; | ||
/** | ||
* Creates an unsigned transaction. For more granular control, you may create your own | ||
* [[TxUnsigned]] manually (with their corresponding [[Input]]s and [[Output]]s. | ||
* [[TxUnsigned]] manually (with their corresponding [[Input]]s and [[Output]]s). | ||
* | ||
@@ -295,5 +297,3 @@ * @param networkid The number representing NetworkID of the node | ||
* @param toAddresses The addresses to send the funds | ||
* @param fromAddresses The addresses being used to send the funds from the UTXOs provided | ||
* @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs, locktime of BN(0) and a threshold of 1 | ||
* @param assetID The assetID of the value being sent as a {@link https://github.com/indutny/bn.js/|BN} | ||
* @param fromAddresses The addresses being used to send the funds from the UTXOs {@link https://github.com/feross/buffer|Buffer} | ||
* @param asOf The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN} | ||
@@ -306,4 +306,21 @@ * @param locktime The locktime field created in the resulting outputs | ||
*/ | ||
makeUnsignedTx: (networkid: number, blockchainid: Buffer, amount: BN, toAddresses: string[], fromAddresses: string[], changeAddresses: string[], assetID: Buffer, asOf?: BN, locktime?: BN, threshold?: number) => TxUnsigned; | ||
makeUnsignedTx: (networkid: number, blockchainid: Buffer, amount: BN, toAddresses: Buffer[], fromAddresses: Buffer[], changeAddresses: Buffer[], assetID: Buffer, asOf?: BN, locktime?: BN, threshold?: number) => TxUnsigned; | ||
/** | ||
* Creates an unsigned transaction. For more granular control, you may create your own | ||
* [[TxCreateAsset]] manually (with their corresponding [[Input]]s, [[Output]]s). | ||
* | ||
* @param networkid The number representing NetworkID of the node | ||
* @param blockchainid The {@link https://github.com/feross/buffer|Buffer} representing the BlockchainID for the transaction | ||
* @param fee The amount of AVA to be paid for fees, in NanoAVA | ||
* @param creatorAddresses The addresses to send the fees | ||
* @param initialState The [[InitialStates]]that represent the intial state of a created asset | ||
* @param name String for the descriptive name of the asset | ||
* @param symbol String for the ticker symbol of the asset | ||
* @param denomination Optional number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVA = 10^9 $nAVA | ||
* | ||
* @returns An unsigned transaction created from the passed in parameters. | ||
* | ||
*/ | ||
makeCreateAssetTx: (networkid: number, blockchainid: Buffer, avaAssetID: Buffer, fee: BN, creatorAddresses: Buffer[], initialState: InitialStates, name: string, symbol: string, denomination: number) => TxCreateAsset; | ||
/** | ||
* Returns a new set with copy of UTXOs in this and set parameter. | ||
@@ -310,0 +327,0 @@ * |
@@ -17,129 +17,36 @@ /** | ||
/** | ||
* Creates a account in the node's database. | ||
* Creates a user in the node's database. | ||
* | ||
* @param accountName Name of the account to create | ||
* @param password Password for the account | ||
* @param username Name of the user to create | ||
* @param password Password for the user | ||
* | ||
* @returns Promise for a boolean with true on success | ||
*/ | ||
createAccount: (accountName: string, password: string) => Promise<boolean>; | ||
createUser: (username: string, password: string) => Promise<boolean>; | ||
/** | ||
* Creates an address (and associated private keys) on an account under a subnet. | ||
* Exports a user. The user can be imported to another node with keystore.importUser . | ||
* | ||
* @param accountName Name of the account to create the address under | ||
* @param password Password to unlock the account and encrypt the private key | ||
* @param subnetAlias The subnetID or subnetAlias which the address is created under | ||
* @param username The name of the user to export | ||
* @param password The password of the user to export | ||
* | ||
* @returns Promise for a string representing the address created by the subnet. | ||
* @returns Promise with a string importable using importUser | ||
*/ | ||
createAddress: (accountName: string, password: string, subnetAlias: string) => Promise<string>; | ||
exportUser: (username: string, password: string) => Promise<string>; | ||
/** | ||
* Exports and account, returning a string with the AVA Keystore File (AKF). | ||
* Imports a user file into the node's user database and assigns it to a username. | ||
* | ||
* @param accountName The name of the account to export | ||
* @param password Not just anyone can export an account... you must have the password | ||
* @param username The name the user file should be imported into | ||
* @param user AVA serialized string represetning a user's data | ||
* @param password The user's password | ||
* | ||
* @returns Promise with a string representing the AVA Keystore File (AKF) | ||
*/ | ||
exportAccount: (accountName: string, password: string) => Promise<string>; | ||
/** | ||
* Exports the private key for an address. | ||
* | ||
* @param accountName The name of the account with the private key | ||
* @param password The password used to decrypt the private key | ||
* @param subnetAlias The subnetID or subnetAlias that the key exists under | ||
* @param address The address whose private key should be exported | ||
* | ||
* @returns Promise with the decrypted private key as store in the database | ||
*/ | ||
exportKey: (accountName: string, password: string, subnetAlias: string, address: string) => Promise<string>; | ||
/** | ||
* Gets the balances for all assets on the provided address on the provided subnet. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias that the address exists under | ||
* @param address The address to pull the asset balances from | ||
* | ||
* @returns Promise with the key-value pair of assetID to balance. | ||
*/ | ||
getAllBalances: (subnetAlias: string, address: string) => Promise<object>; | ||
/** | ||
* Gets the balance of a particular asset on a subnet. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias that the address exists under | ||
* @param address The address to pull the asset balance from | ||
* @param assetID The assetID to pull the balance from | ||
* | ||
* @returns Promise with the balance of the assetID on the provided address for the subnet. | ||
*/ | ||
getBalance: (subnetAlias: string, address: string, assetID: string) => Promise<number>; | ||
/** | ||
* @ignore | ||
*/ | ||
getTxHistory: (subnetAlias: string, address: string) => Promise<object>; | ||
/** | ||
* Imports an account file into the node's account database and assigns it to an account name. | ||
* | ||
* @param accountName The name the account file should be imported into | ||
* @param accountData The JSON in the AVA Keystore File (AKF) format | ||
* @param password The password that's used to encode the private keys in the AKF | ||
* | ||
* @returns A promise with a true-value on success. | ||
*/ | ||
importAccount: (accountName: string, accountData: string, password: string) => Promise<boolean>; | ||
importUser: (username: string, user: string, password: string) => Promise<boolean>; | ||
/** | ||
* Imports a private key into the node's database under an account and for a subnet. | ||
* Lists the names of all users on the node. | ||
* | ||
* @param accountName The name of the account to store the private key | ||
* @param password The password that unlocks the account | ||
* @param subnetAlias The subnetID or subnetAlias to insert the private key | ||
* @param privateKey A string representing the private key in the subnet's format | ||
* | ||
* @returns The address for the imported private key. | ||
* @returns Promise of an array with all user names. | ||
*/ | ||
importKey: (accountName: string, password: string, subnetAlias: string, privateKey: string) => Promise<string>; | ||
listUsers: () => Promise<string[]>; | ||
/** | ||
* Lists the names of all accounts on the node. | ||
* | ||
* @returns Promise of an array with all account names. | ||
*/ | ||
listAccounts: () => Promise<string[]>; | ||
/** | ||
* Lists all the addresses under a subnet on an account. | ||
* | ||
* @param accountName The account to list addresses for | ||
* @param subnetAlias The subnet to list the addreses for | ||
* | ||
* @returns Promise of an array of address strings in the format specified by the subnet. | ||
*/ | ||
listAddresses: (accountName: string, subnetAlias: string) => Promise<string[]>; | ||
/** | ||
* Lists all assets for a subnet on an address. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias the address is on | ||
* @param address The address to get a list of assets for | ||
* | ||
* @returns Promise of an array of assetIDs for the address on the subnet. | ||
*/ | ||
listAssets: (subnetAlias: string, address: string) => Promise<string[]>; | ||
/** | ||
* A list of all subnets supported by the wallet. | ||
* | ||
* @returns An array of subnetIDs which the wallet supports. | ||
*/ | ||
listSubnets: () => Promise<string[]>; | ||
/** | ||
* Sends an amount of assetID to the specified address from a list of owned of addresses. | ||
* | ||
* @param accountName The account that owns the private keys associated with the `from` addresses | ||
* @param password The password unlocking the account | ||
* @param subnetAlias The subnetID or subnetAlias the asset resides on | ||
* @param assetID The assetID of the asset to send | ||
* @param amount The amount of the asset to be sent | ||
* @param to The address of the recipient | ||
* @param from An array of addresses managed by the node for this subnet which will fund this transaction | ||
* | ||
* @returns Promise for the string representing the transaction's ID. | ||
*/ | ||
send: (accountName: string, password: string, subnetAlias: string, assetID: string, amount: number, to: string, from: string[]) => Promise<string>; | ||
/** | ||
* This class should not be instantiated directly. Instead use the [[Slopes.addAPI]] method. | ||
@@ -146,0 +53,0 @@ * |
@@ -32,15 +32,15 @@ "use strict"; | ||
/** | ||
* Creates a account in the node's database. | ||
* Creates a user in the node's database. | ||
* | ||
* @param accountName Name of the account to create | ||
* @param password Password for the account | ||
* @param username Name of the user to create | ||
* @param password Password for the user | ||
* | ||
* @returns Promise for a boolean with true on success | ||
*/ | ||
this.createAccount = (accountName, password) => __awaiter(this, void 0, void 0, function* () { | ||
this.createUser = (username, password) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"username": username, | ||
"password": password | ||
}; | ||
return this.callMethod("keystore.createAccount", params).then((response) => { | ||
return this.callMethod("keystore.createUser", params).then((response) => { | ||
return response.data["result"]["success"]; | ||
@@ -50,122 +50,34 @@ }); | ||
/** | ||
* Creates an address (and associated private keys) on an account under a subnet. | ||
* Exports a user. The user can be imported to another node with keystore.importUser . | ||
* | ||
* @param accountName Name of the account to create the address under | ||
* @param password Password to unlock the account and encrypt the private key | ||
* @param subnetAlias The subnetID or subnetAlias which the address is created under | ||
* @param username The name of the user to export | ||
* @param password The password of the user to export | ||
* | ||
* @returns Promise for a string representing the address created by the subnet. | ||
* @returns Promise with a string importable using importUser | ||
*/ | ||
this.createAddress = (accountName, password, subnetAlias) => __awaiter(this, void 0, void 0, function* () { | ||
this.exportUser = (username, password) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias | ||
}; | ||
return this.callMethod("keystore.createAddress", params).then((response) => { | ||
return response.data["result"]["address"]; | ||
}); | ||
}); | ||
/** | ||
* Exports and account, returning a string with the AVA Keystore File (AKF). | ||
* | ||
* @param accountName The name of the account to export | ||
* @param password Not just anyone can export an account... you must have the password | ||
* | ||
* @returns Promise with a string representing the AVA Keystore File (AKF) | ||
*/ | ||
this.exportAccount = (accountName, password) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"username": username, | ||
"password": password | ||
}; | ||
return this.callMethod("keystore.exportAccount", params).then((response) => { | ||
return response.data["result"]["accountData"]; | ||
return this.callMethod("keystore.exportUser", params).then((response) => { | ||
return response.data["result"]["user"]; | ||
}); | ||
}); | ||
/** | ||
* Exports the private key for an address. | ||
* Imports a user file into the node's user database and assigns it to a username. | ||
* | ||
* @param accountName The name of the account with the private key | ||
* @param password The password used to decrypt the private key | ||
* @param subnetAlias The subnetID or subnetAlias that the key exists under | ||
* @param address The address whose private key should be exported | ||
* @param username The name the user file should be imported into | ||
* @param user AVA serialized string represetning a user's data | ||
* @param password The user's password | ||
* | ||
* @returns Promise with the decrypted private key as store in the database | ||
*/ | ||
this.exportKey = (accountName, password, subnetAlias, address) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.exportKey", params).then((response) => { | ||
return response.data["result"]["privateKey"]; | ||
}); | ||
}); | ||
/** | ||
* Gets the balances for all assets on the provided address on the provided subnet. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias that the address exists under | ||
* @param address The address to pull the asset balances from | ||
* | ||
* @returns Promise with the key-value pair of assetID to balance. | ||
*/ | ||
this.getAllBalances = (subnetAlias, address) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.getAllBalances", params).then((response) => { | ||
return response.data["result"]["balances"]; | ||
}); | ||
}); | ||
/** | ||
* Gets the balance of a particular asset on a subnet. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias that the address exists under | ||
* @param address The address to pull the asset balance from | ||
* @param assetID The assetID to pull the balance from | ||
* | ||
* @returns Promise with the balance of the assetID on the provided address for the subnet. | ||
*/ | ||
this.getBalance = (subnetAlias, address, assetID) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address, | ||
"assetID": assetID | ||
}; | ||
return this.callMethod("keystore.getBalance", params).then((response) => { | ||
return response.data["result"]["balance"]; | ||
}); | ||
}); | ||
/** | ||
* @ignore | ||
*/ | ||
this.getTxHistory = (subnetAlias, address) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.getTxHistory", params).then((response) => { | ||
return response.data["result"]; | ||
}); | ||
}); | ||
/** | ||
* Imports an account file into the node's account database and assigns it to an account name. | ||
* | ||
* @param accountName The name the account file should be imported into | ||
* @param accountData The JSON in the AVA Keystore File (AKF) format | ||
* @param password The password that's used to encode the private keys in the AKF | ||
* | ||
* @returns A promise with a true-value on success. | ||
*/ | ||
this.importAccount = (accountName, accountData, password) => __awaiter(this, void 0, void 0, function* () { | ||
this.importUser = (username, user, password) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"accountData": accountData, | ||
"usermame": username, | ||
"user": user, | ||
"password": password | ||
}; | ||
return this.callMethod("keystore.importAccount", params).then((response) => { | ||
return this.callMethod("keystore.importUser", params).then((response) => { | ||
return response.data["result"]["success"]; | ||
@@ -175,106 +87,14 @@ }); | ||
/** | ||
* Imports a private key into the node's database under an account and for a subnet. | ||
* Lists the names of all users on the node. | ||
* | ||
* @param accountName The name of the account to store the private key | ||
* @param password The password that unlocks the account | ||
* @param subnetAlias The subnetID or subnetAlias to insert the private key | ||
* @param privateKey A string representing the private key in the subnet's format | ||
* | ||
* @returns The address for the imported private key. | ||
* @returns Promise of an array with all user names. | ||
*/ | ||
this.importKey = (accountName, password, subnetAlias, privateKey) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias, | ||
"privateKey": privateKey | ||
}; | ||
return this.callMethod("keystore.importKey", params).then((response) => { | ||
return response.data["result"]["address"]; | ||
this.listUsers = () => __awaiter(this, void 0, void 0, function* () { | ||
return this.callMethod("keystore.listUsers").then((response) => { | ||
return response.data["result"]["users"]; | ||
}); | ||
}); | ||
/** | ||
* Lists the names of all accounts on the node. | ||
* | ||
* @returns Promise of an array with all account names. | ||
*/ | ||
this.listAccounts = () => __awaiter(this, void 0, void 0, function* () { | ||
return this.callMethod("keystore.listAccounts").then((response) => { | ||
return response.data["result"]["accounts"]; | ||
}); | ||
}); | ||
/** | ||
* Lists all the addresses under a subnet on an account. | ||
* | ||
* @param accountName The account to list addresses for | ||
* @param subnetAlias The subnet to list the addreses for | ||
* | ||
* @returns Promise of an array of address strings in the format specified by the subnet. | ||
*/ | ||
this.listAddresses = (accountName, subnetAlias) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"subnetAlias": subnetAlias | ||
}; | ||
return this.callMethod("keystore.listAddresses", params).then((response) => { | ||
return response.data["result"]["addresses"]; | ||
}); | ||
}); | ||
/** | ||
* Lists all assets for a subnet on an address. | ||
* | ||
* @param subnetAlias The subnetID or subnetAlias the address is on | ||
* @param address The address to get a list of assets for | ||
* | ||
* @returns Promise of an array of assetIDs for the address on the subnet. | ||
*/ | ||
this.listAssets = (subnetAlias, address) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"subnetAlias": subnetAlias, | ||
"address": address | ||
}; | ||
return this.callMethod("keystore.listAssets", params).then((response) => { | ||
return response.data["result"]["assets"]; | ||
}); | ||
}); | ||
/** | ||
* A list of all subnets supported by the wallet. | ||
* | ||
* @returns An array of subnetIDs which the wallet supports. | ||
*/ | ||
this.listSubnets = () => __awaiter(this, void 0, void 0, function* () { | ||
return this.callMethod("keystore.listSubnets").then((response) => { | ||
return response.data["result"]["subnetIDs"]; | ||
}); | ||
}); | ||
/** | ||
* Sends an amount of assetID to the specified address from a list of owned of addresses. | ||
* | ||
* @param accountName The account that owns the private keys associated with the `from` addresses | ||
* @param password The password unlocking the account | ||
* @param subnetAlias The subnetID or subnetAlias the asset resides on | ||
* @param assetID The assetID of the asset to send | ||
* @param amount The amount of the asset to be sent | ||
* @param to The address of the recipient | ||
* @param from An array of addresses managed by the node for this subnet which will fund this transaction | ||
* | ||
* @returns Promise for the string representing the transaction's ID. | ||
*/ | ||
this.send = (accountName, password, subnetAlias, assetID, amount, to, from) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"accountName": accountName, | ||
"password": password, | ||
"subnetAlias": subnetAlias, | ||
"assetID": assetID, | ||
"amount": amount, | ||
"to": to, | ||
"from": from | ||
}; | ||
return this.callMethod("keystore.send", params).then((response) => { | ||
return response.data["result"]["txID"]; | ||
}); | ||
}); | ||
} | ||
} | ||
exports.default = KeystoreAPI; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/apis/keystore/api.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module KeystoreAPI\n */\nimport SlopesCore from '../../slopes';\nimport {JRPCAPI, RequestResponseData} from \"../../utils/types\"\n\n/**\n * Class for interacting with a node API that is using the node's KeystoreAPI.\n * \n * **WARNING**: The KeystoreAPI is to be used by the node-owner as the data is stored locally on the node. Do not trust the root user. If you are not the node-owner, do not use this as your wallet. \n * \n * @category RPCAPIs\n * \n * @remarks This extends the [[JRPCAPI]] class. This class should not be directly called. Instead, use the [[Slopes.addAPI]] function to register this interface with Slopes.\n */ \nclass KeystoreAPI extends JRPCAPI{\n\n    /**\n     * Creates a account in the node's database.\n     * \n     * @param accountName Name of the account to create\n     * @param password Password for the account\n     * \n     * @returns Promise for a boolean with true on success\n     */\n    createAccount = async (accountName:string, password:string):Promise<boolean> => {\n        let params = {\n            \"accountName\": accountName,\n            \"password\": password\n        };\n        return this.callMethod(\"keystore.createAccount\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"success\"];\n        });\n    }\n\n    /**\n     * Creates an address (and associated private keys) on an account under a subnet.\n     * \n     * @param accountName Name of the account to create the address under\n     * @param password Password to unlock the account and encrypt the private key\n     * @param subnetAlias The subnetID or subnetAlias which the address is created under\n     * \n     * @returns Promise for a string representing the address created by the subnet.\n     */\n    createAddress = async (accountName:string, password:string, subnetAlias:string):Promise<string> => {\n        let params = {\n            \"accountName\": accountName,\n            \"password\": password,\n            \"subnetAlias\": subnetAlias\n        };\n        return this.callMethod(\"keystore.createAddress\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"address\"];\n        });\n    }\n\n    /**\n     * Exports and account, returning a string with the AVA Keystore File (AKF).\n     * \n     * @param accountName The name of the account to export\n     * @param password Not just anyone can export an account... you must have the password\n     * \n     * @returns Promise with a string representing the AVA Keystore File (AKF)\n     */\n    exportAccount = async (accountName:string, password:string):Promise<string> => {\n        let params = {\n            \"accountName\": accountName,\n            \"password\": password\n        };\n        return this.callMethod(\"keystore.exportAccount\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"accountData\"];\n        });\n    }\n\n    /**\n     * Exports the private key for an address.\n     * \n     * @param accountName The name of the account with the private key\n     * @param password The password used to decrypt the private key\n     * @param subnetAlias The subnetID or subnetAlias that the key exists under\n     * @param address The address whose private key should be exported\n     * \n     * @returns Promise with the decrypted private key as store in the database\n     */\n    exportKey = async (accountName:string, password:string, subnetAlias:string, address:string):Promise<string> => {\n        let params = {\n            \"accountName\": accountName,\n            \"password\": password,\n            \"subnetAlias\": subnetAlias,\n            \"address\": address\n        };\n        return this.callMethod(\"keystore.exportKey\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"privateKey\"];\n        });\n    }\n\n    /**\n     * Gets the balances for all assets on the provided address on the provided subnet.\n     * \n     * @param subnetAlias The subnetID or subnetAlias that the address exists under\n     * @param address The address to pull the asset balances from\n     * \n     * @returns Promise with the key-value pair of assetID to balance.\n     */\n    getAllBalances = async (subnetAlias:string, address:string):Promise<object> => {\n        let params = {\n            \"subnetAlias\": subnetAlias,\n            \"address\": address\n        };\n        return this.callMethod(\"keystore.getAllBalances\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"balances\"];\n        });\n    }\n\n    /**\n     * Gets the balance of a particular asset on a subnet.\n     * \n     * @param subnetAlias The subnetID or subnetAlias that the address exists under\n     * @param address The address to pull the asset balance from\n     * @param assetID The assetID to pull the balance from\n     * \n     * @returns Promise with the balance of the assetID on the provided address for the subnet.\n     */\n    getBalance = async (subnetAlias:string, address:string, assetID:string):Promise<number> => {\n        let params = {\n            \"subnetAlias\": subnetAlias,\n            \"address\": address, \n            \"assetID\": assetID\n        };\n        return this.callMethod(\"keystore.getBalance\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"balance\"];\n        });\n    }\n\n    /**\n     * @ignore\n     */\n    getTxHistory =  async (subnetAlias:string, address:string):Promise<object> => {\n        let params = {\n            \"subnetAlias\": subnetAlias,\n            \"address\": address\n        };\n        return this.callMethod(\"keystore.getTxHistory\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"];\n        });\n    }\n\n    /**\n     * Imports an account file into the node's account database and assigns it to an account name.\n     * \n     * @param accountName The name the account file should be imported into\n     * @param accountData The JSON in the AVA Keystore File (AKF) format\n     * @param password The password that's used to encode the private keys in the AKF\n     * \n     * @returns A promise with a true-value on success.\n     */\n    importAccount = async (accountName:string, accountData:string, password:string):Promise<boolean> => {\n        let params = {\n            \"accountName\": accountName,\n            \"accountData\": accountData,\n            \"password\": password\n        };\n        return this.callMethod(\"keystore.importAccount\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"success\"];\n        });\n    }\n\n    /**\n     * Imports a private key into the node's database under an account and for a subnet.\n     * \n     * @param accountName The name of the account to store the private key\n     * @param password The password that unlocks the account\n     * @param subnetAlias The subnetID or subnetAlias to insert the private key\n     * @param privateKey A string representing the private key in the subnet's format\n     * \n     * @returns The address for the imported private key.\n     */\n    importKey = async (accountName:string, password:string, subnetAlias:string, privateKey:string):Promise<string> => {\n        let params = {\n            \"accountName\": accountName,\n            \"password\": password,\n            \"subnetAlias\": subnetAlias,\n            \"privateKey\": privateKey\n        };\n        return this.callMethod(\"keystore.importKey\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"address\"];\n        });\n    }\n\n    /**\n     * Lists the names of all accounts on the node.\n     * \n     * @returns Promise of an array with all account names.\n     */\n    listAccounts = async ():Promise<Array<string>> => {\n        return this.callMethod(\"keystore.listAccounts\").then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"accounts\"];\n        });\n    }\n\n    /**\n     * Lists all the addresses under a subnet on an account.\n     * \n     * @param accountName The account to list addresses for\n     * @param subnetAlias The subnet to list the addreses for\n     * \n     * @returns Promise of an array of address strings in the format specified by the subnet.\n     */\n    listAddresses = async (accountName:string, subnetAlias:string): Promise<Array<string>> => {\n        let params = {\n            \"accountName\": accountName,\n            \"subnetAlias\": subnetAlias\n        };\n        return this.callMethod(\"keystore.listAddresses\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"addresses\"];\n        });\n    }\n\n    /**\n     * Lists all assets for a subnet on an address.\n     * \n     * @param subnetAlias The subnetID or subnetAlias the address is on\n     * @param address The address to get a list of assets for\n     * \n     * @returns Promise of an array of assetIDs for the address on the subnet.\n     */\n    listAssets = async (subnetAlias:string, address:string):Promise<Array<string>> => {\n        let params = {\n            \"subnetAlias\": subnetAlias,\n            \"address\": address\n        };\n        return this.callMethod(\"keystore.listAssets\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"assets\"];\n        });\n    }\n\n    /**\n     * A list of all subnets supported by the wallet.\n     * \n     * @returns An array of subnetIDs which the wallet supports.\n     */\n    listSubnets = async ():Promise<Array<string>> => {\n        return this.callMethod(\"keystore.listSubnets\").then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"subnetIDs\"];\n        });\n    }\n\n    /**\n     * Sends an amount of assetID to the specified address from a list of owned of addresses.\n     * \n     * @param accountName The account that owns the private keys associated with the `from` addresses\n     * @param password The password unlocking the account\n     * @param subnetAlias The subnetID or subnetAlias the asset resides on\n     * @param assetID The assetID of the asset to send\n     * @param amount The amount of the asset to be sent\n     * @param to The address of the recipient\n     * @param from An array of addresses managed by the node for this subnet which will fund this transaction\n     * \n     * @returns Promise for the string representing the transaction's ID.\n     */\n    send = async (accountName:string, password:string, subnetAlias:string, assetID:string, amount:number, to:string, from:Array<string>):Promise<string> => {\n        let params = {\n            \"accountName\": accountName,\n            \"password\": password,\n            \"subnetAlias\": subnetAlias,\n            \"assetID\": assetID,\n            \"amount\": amount,\n            \"to\": to, \n            \"from\": from\n        };\n        return this.callMethod(\"keystore.send\", params).then((response:RequestResponseData) => {\n            return response.data[\"result\"][\"txID\"];\n        });\n    }\n\n    /**\n     * This class should not be instantiated directly. Instead use the [[Slopes.addAPI]] method.\n     * \n     * @param core A reference to the Slopes class\n     * @param baseurl Defaults to the string \"/ext/keystore\" as the path to subnets baseurl\n     */\n    constructor(core:SlopesCore, baseurl:string = \"/ext/keystore\"){ super(core, baseurl); }\n}\n\nexport default KeystoreAPI;"]} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaXMva2V5c3RvcmUvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBSUEsNkNBQThEO0FBRTlEOzs7Ozs7OztHQVFHO0FBQ0gsTUFBTSxXQUFZLFNBQVEsZUFBTztJQXFFN0I7Ozs7O09BS0c7SUFDSCxZQUFZLElBQWUsRUFBRSxVQUFpQixlQUFlO1FBQUcsS0FBSyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztRQXpFckY7Ozs7Ozs7V0FPRztRQUNILGVBQVUsR0FBRyxDQUFPLFFBQWUsRUFBRSxRQUFlLEVBQW1CLEVBQUU7WUFDckUsSUFBSSxNQUFNLEdBQUc7Z0JBQ1QsVUFBVSxFQUFFLFFBQVE7Z0JBQ3BCLFVBQVUsRUFBRSxRQUFRO2FBQ3ZCLENBQUM7WUFDRixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMscUJBQXFCLEVBQUUsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBNEIsRUFBRSxFQUFFO2dCQUN4RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDOUMsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUEsQ0FBQTtRQUVEOzs7Ozs7O1dBT0c7UUFDSCxlQUFVLEdBQUcsQ0FBTyxRQUFlLEVBQUUsUUFBZSxFQUFrQixFQUFFO1lBQ3BFLElBQUksTUFBTSxHQUFHO2dCQUNULFVBQVUsRUFBRSxRQUFRO2dCQUNwQixVQUFVLEVBQUUsUUFBUTthQUN2QixDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLHFCQUFxQixFQUFFLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQTRCLEVBQUUsRUFBRTtnQkFDeEYsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzNDLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFBLENBQUE7UUFFRDs7Ozs7Ozs7V0FRRztRQUNILGVBQVUsR0FBRyxDQUFPLFFBQWUsRUFBRSxJQUFXLEVBQUUsUUFBZSxFQUFtQixFQUFFO1lBQ2xGLElBQUksTUFBTSxHQUFHO2dCQUNULFVBQVUsRUFBRSxRQUFRO2dCQUNwQixNQUFNLEVBQUUsSUFBSTtnQkFDWixVQUFVLEVBQUUsUUFBUTthQUN2QixDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLHFCQUFxQixFQUFFLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQTRCLEVBQUUsRUFBRTtnQkFDeEYsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQzlDLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFBLENBQUE7UUFFRDs7OztXQUlHO1FBQ0gsY0FBUyxHQUFHLEdBQWdDLEVBQUU7WUFDMUMsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLG9CQUFvQixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBNEIsRUFBRSxFQUFFO2dCQUMvRSxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDNUMsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUEsQ0FBQTtJQVFxRixDQUFDO0NBQzFGO0FBRUQsa0JBQWUsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIEtleXN0b3JlQVBJXG4gKi9cbmltcG9ydCBTbG9wZXNDb3JlIGZyb20gJy4uLy4uL3Nsb3Blcyc7XG5pbXBvcnQge0pSUENBUEksIFJlcXVlc3RSZXNwb25zZURhdGF9IGZyb20gXCIuLi8uLi91dGlscy90eXBlc1wiXG5cbi8qKlxuICogQ2xhc3MgZm9yIGludGVyYWN0aW5nIHdpdGggYSBub2RlIEFQSSB0aGF0IGlzIHVzaW5nIHRoZSBub2RlJ3MgS2V5c3RvcmVBUEkuXG4gKiBcbiAqICoqV0FSTklORyoqOiBUaGUgS2V5c3RvcmVBUEkgaXMgdG8gYmUgdXNlZCBieSB0aGUgbm9kZS1vd25lciBhcyB0aGUgZGF0YSBpcyBzdG9yZWQgbG9jYWxseSBvbiB0aGUgbm9kZS4gRG8gbm90IHRydXN0IHRoZSByb290IHVzZXIuIElmIHlvdSBhcmUgbm90IHRoZSBub2RlLW93bmVyLCBkbyBub3QgdXNlIHRoaXMgYXMgeW91ciB3YWxsZXQuIFxuICogXG4gKiBAY2F0ZWdvcnkgUlBDQVBJc1xuICogXG4gKiBAcmVtYXJrcyBUaGlzIGV4dGVuZHMgdGhlIFtbSlJQQ0FQSV1dIGNsYXNzLiBUaGlzIGNsYXNzIHNob3VsZCBub3QgYmUgZGlyZWN0bHkgY2FsbGVkLiBJbnN0ZWFkLCB1c2UgdGhlIFtbU2xvcGVzLmFkZEFQSV1dIGZ1bmN0aW9uIHRvIHJlZ2lzdGVyIHRoaXMgaW50ZXJmYWNlIHdpdGggU2xvcGVzLlxuICovIFxuY2xhc3MgS2V5c3RvcmVBUEkgZXh0ZW5kcyBKUlBDQVBJe1xuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIHVzZXIgaW4gdGhlIG5vZGUncyBkYXRhYmFzZS5cbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gdXNlcm5hbWUgTmFtZSBvZiB0aGUgdXNlciB0byBjcmVhdGVcbiAgICAgKiBAcGFyYW0gcGFzc3dvcmQgUGFzc3dvcmQgZm9yIHRoZSB1c2VyXG4gICAgICogXG4gICAgICogQHJldHVybnMgUHJvbWlzZSBmb3IgYSBib29sZWFuIHdpdGggdHJ1ZSBvbiBzdWNjZXNzXG4gICAgICovXG4gICAgY3JlYXRlVXNlciA9IGFzeW5jICh1c2VybmFtZTpzdHJpbmcsIHBhc3N3b3JkOnN0cmluZyk6UHJvbWlzZTxib29sZWFuPiA9PiB7XG4gICAgICAgIGxldCBwYXJhbXMgPSB7XG4gICAgICAgICAgICBcInVzZXJuYW1lXCI6IHVzZXJuYW1lLFxuICAgICAgICAgICAgXCJwYXNzd29yZFwiOiBwYXNzd29yZFxuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdGhpcy5jYWxsTWV0aG9kKFwia2V5c3RvcmUuY3JlYXRlVXNlclwiLCBwYXJhbXMpLnRoZW4oKHJlc3BvbnNlOlJlcXVlc3RSZXNwb25zZURhdGEpID0+IHtcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhW1wicmVzdWx0XCJdW1wic3VjY2Vzc1wiXTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogRXhwb3J0cyBhIHVzZXIuIFRoZSB1c2VyIGNhbiBiZSBpbXBvcnRlZCB0byBhbm90aGVyIG5vZGUgd2l0aCBrZXlzdG9yZS5pbXBvcnRVc2VyIC5cbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gdXNlcm5hbWUgVGhlIG5hbWUgb2YgdGhlIHVzZXIgdG8gZXhwb3J0XG4gICAgICogQHBhcmFtIHBhc3N3b3JkIFRoZSBwYXNzd29yZCBvZiB0aGUgdXNlciB0byBleHBvcnRcbiAgICAgKiBcbiAgICAgKiBAcmV0dXJucyBQcm9taXNlIHdpdGggYSBzdHJpbmcgaW1wb3J0YWJsZSB1c2luZyBpbXBvcnRVc2VyXG4gICAgICovXG4gICAgZXhwb3J0VXNlciA9IGFzeW5jICh1c2VybmFtZTpzdHJpbmcsIHBhc3N3b3JkOnN0cmluZyk6UHJvbWlzZTxzdHJpbmc+ID0+IHtcbiAgICAgICAgbGV0IHBhcmFtcyA9IHtcbiAgICAgICAgICAgIFwidXNlcm5hbWVcIjogdXNlcm5hbWUsXG4gICAgICAgICAgICBcInBhc3N3b3JkXCI6IHBhc3N3b3JkXG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxNZXRob2QoXCJrZXlzdG9yZS5leHBvcnRVc2VyXCIsIHBhcmFtcykudGhlbigocmVzcG9uc2U6UmVxdWVzdFJlc3BvbnNlRGF0YSkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFbXCJyZXN1bHRcIl1bXCJ1c2VyXCJdO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBJbXBvcnRzIGEgdXNlciBmaWxlIGludG8gdGhlIG5vZGUncyB1c2VyIGRhdGFiYXNlIGFuZCBhc3NpZ25zIGl0IHRvIGEgdXNlcm5hbWUuXG4gICAgICogXG4gICAgICogQHBhcmFtIHVzZXJuYW1lIFRoZSBuYW1lIHRoZSB1c2VyIGZpbGUgc2hvdWxkIGJlIGltcG9ydGVkIGludG9cbiAgICAgKiBAcGFyYW0gdXNlciBBVkEgc2VyaWFsaXplZCBzdHJpbmcgcmVwcmVzZXRuaW5nIGEgdXNlcidzIGRhdGFcbiAgICAgKiBAcGFyYW0gcGFzc3dvcmQgVGhlIHVzZXIncyBwYXNzd29yZFxuICAgICAqIFxuICAgICAqIEByZXR1cm5zIEEgcHJvbWlzZSB3aXRoIGEgdHJ1ZS12YWx1ZSBvbiBzdWNjZXNzLlxuICAgICAqL1xuICAgIGltcG9ydFVzZXIgPSBhc3luYyAodXNlcm5hbWU6c3RyaW5nLCB1c2VyOnN0cmluZywgcGFzc3dvcmQ6c3RyaW5nKTpQcm9taXNlPGJvb2xlYW4+ID0+IHtcbiAgICAgICAgbGV0IHBhcmFtcyA9IHtcbiAgICAgICAgICAgIFwidXNlcm1hbWVcIjogdXNlcm5hbWUsXG4gICAgICAgICAgICBcInVzZXJcIjogdXNlcixcbiAgICAgICAgICAgIFwicGFzc3dvcmRcIjogcGFzc3dvcmRcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbE1ldGhvZChcImtleXN0b3JlLmltcG9ydFVzZXJcIiwgcGFyYW1zKS50aGVuKChyZXNwb25zZTpSZXF1ZXN0UmVzcG9uc2VEYXRhKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YVtcInJlc3VsdFwiXVtcInN1Y2Nlc3NcIl07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIExpc3RzIHRoZSBuYW1lcyBvZiBhbGwgdXNlcnMgb24gdGhlIG5vZGUuXG4gICAgICogXG4gICAgICogQHJldHVybnMgUHJvbWlzZSBvZiBhbiBhcnJheSB3aXRoIGFsbCB1c2VyIG5hbWVzLlxuICAgICAqL1xuICAgIGxpc3RVc2VycyA9IGFzeW5jICgpOlByb21pc2U8QXJyYXk8c3RyaW5nPj4gPT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5jYWxsTWV0aG9kKFwia2V5c3RvcmUubGlzdFVzZXJzXCIpLnRoZW4oKHJlc3BvbnNlOlJlcXVlc3RSZXNwb25zZURhdGEpID0+IHtcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhW1wicmVzdWx0XCJdW1widXNlcnNcIl07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFRoaXMgY2xhc3Mgc2hvdWxkIG5vdCBiZSBpbnN0YW50aWF0ZWQgZGlyZWN0bHkuIEluc3RlYWQgdXNlIHRoZSBbW1Nsb3Blcy5hZGRBUEldXSBtZXRob2QuXG4gICAgICogXG4gICAgICogQHBhcmFtIGNvcmUgQSByZWZlcmVuY2UgdG8gdGhlIFNsb3BlcyBjbGFzc1xuICAgICAqIEBwYXJhbSBiYXNldXJsIERlZmF1bHRzIHRvIHRoZSBzdHJpbmcgXCIvZXh0L2tleXN0b3JlXCIgYXMgdGhlIHBhdGggdG8gc3VibmV0cyBiYXNldXJsXG4gICAgICovXG4gICAgY29uc3RydWN0b3IoY29yZTpTbG9wZXNDb3JlLCBiYXNldXJsOnN0cmluZyA9IFwiL2V4dC9rZXlzdG9yZVwiKXsgc3VwZXIoY29yZSwgYmFzZXVybCk7IH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgS2V5c3RvcmVBUEk7Il19 |
@@ -23,10 +23,21 @@ /** | ||
/** | ||
* Creates a new subnet. | ||
* Creates a new blockchain. | ||
* | ||
* @param tx The string representation of a createSubnetTx | ||
* @param vmID The VMID used to build the blockchain | ||
* @param name A human-readable name for the new blockchain | ||
* @param method The VMID's hook method for ingesting genesis data | ||
* @param genesis The object used to build the initial state of the blockchain | ||
* | ||
* @returns Promise for a boolean value, true on success. | ||
* @returns Promise for a string for the blockchainID. | ||
*/ | ||
createSubnet: (tx: string) => Promise<boolean>; | ||
createBlockchain: (vmID: string, name: string, method: string, genesis: object) => Promise<string>; | ||
/** | ||
* Creates a new blockchain. | ||
* | ||
* @param blockchainID The blockchainID requesting a status update | ||
* | ||
* @returns Promise for a string of one of: "Validating", "Created", "Preferred", "Unknown". | ||
*/ | ||
getBlockchainStatus: (blockchainID: string) => Promise<string>; | ||
/** | ||
* Lists the current set of validators. | ||
@@ -33,0 +44,0 @@ * |
@@ -45,17 +45,38 @@ "use strict"; | ||
/** | ||
* Creates a new subnet. | ||
* Creates a new blockchain. | ||
* | ||
* @param tx The string representation of a createSubnetTx | ||
* @param vmID The VMID used to build the blockchain | ||
* @param name A human-readable name for the new blockchain | ||
* @param method The VMID's hook method for ingesting genesis data | ||
* @param genesis The object used to build the initial state of the blockchain | ||
* | ||
* @returns Promise for a boolean value, true on success. | ||
* @returns Promise for a string for the blockchainID. | ||
*/ | ||
this.createSubnet = (tx) => __awaiter(this, void 0, void 0, function* () { | ||
this.createBlockchain = (vmID, name, method, genesis) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"tx": tx | ||
"vmID": vmID, | ||
"name": name, | ||
"method": method, | ||
"genesis": genesis | ||
}; | ||
return this.callMethod("platform.createSubnet", params).then((response) => { | ||
return response.data["result"]["success"]; | ||
return this.callMethod("platform.createBlockchain", params).then((response) => { | ||
return response.data["result"]["blockchainID"]; | ||
}); | ||
}); | ||
/** | ||
* Creates a new blockchain. | ||
* | ||
* @param blockchainID The blockchainID requesting a status update | ||
* | ||
* @returns Promise for a string of one of: "Validating", "Created", "Preferred", "Unknown". | ||
*/ | ||
this.getBlockchainStatus = (blockchainID) => __awaiter(this, void 0, void 0, function* () { | ||
let params = { | ||
"blockchainID": blockchainID | ||
}; | ||
return this.callMethod("platform.getBlockchainStatus", params).then((response) => { | ||
return response.data["result"]["status"]; | ||
}); | ||
}); | ||
/** | ||
* Lists the current set of validators. | ||
@@ -79,3 +100,3 @@ * | ||
let params = { | ||
"size": sampleSize | ||
"size": sampleSize.toString() | ||
}; | ||
@@ -89,2 +110,2 @@ return this.callMethod("platform.sampleValidators", params).then((response) => { | ||
exports.default = PlatformAPI; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaXMvcGxhdGZvcm0vYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBSUEsNkNBQWlFO0FBRWpFOzs7Ozs7R0FNRztBQUNILE1BQU0sV0FBWSxTQUFRLGVBQU87SUE2RDdCOzs7OztPQUtHO0lBQ0gsWUFBWSxJQUFlLEVBQUUsVUFBaUIsZUFBZTtRQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFqRXJGOzs7Ozs7V0FNRztRQUNILGNBQVMsR0FBRyxDQUFPLEVBQVMsRUFBbUIsRUFBRTtZQUM3QyxJQUFJLE1BQU0sR0FBRztnQkFDVCxJQUFJLEVBQUUsRUFBRTthQUNYLENBQUM7WUFDRixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsb0JBQW9CLEVBQUUsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBNEIsRUFBRSxFQUFFO2dCQUN2RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDOUMsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUEsQ0FBQTtRQUVEOzs7Ozs7V0FNRztRQUNILGlCQUFZLEdBQUcsQ0FBTyxFQUFTLEVBQW1CLEVBQUU7WUFDaEQsSUFBSSxNQUFNLEdBQUc7Z0JBQ1QsSUFBSSxFQUFFLEVBQUU7YUFDWCxDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLHVCQUF1QixFQUFFLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQTRCLEVBQUUsRUFBRTtnQkFDMUYsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQzlDLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFBLENBQUE7UUFFRDs7OztXQUlHO1FBQ0gsbUJBQWMsR0FBRyxHQUFnQyxFQUFFO1lBQy9DLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQTRCLEVBQUUsRUFBRTtnQkFDcEYsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQ2pELENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFBLENBQUE7UUFFRDs7Ozs7O1dBTUc7UUFDSCxxQkFBZ0IsR0FBRyxDQUFPLFVBQWlCLEVBQXlCLEVBQUU7WUFDbEUsSUFBSSxNQUFNLEdBQUc7Z0JBQ1QsTUFBTSxFQUFFLFVBQVU7YUFDckIsQ0FBQztZQUNGLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQywyQkFBMkIsRUFBRSxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUE0QixFQUFFLEVBQUU7Z0JBQzlGLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUNqRCxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQSxDQUFBO0lBUXFGLENBQUM7Q0FDMUY7QUFFRCxrQkFBZSxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgUGxhdGZvcm1BUElcbiAqL1xuaW1wb3J0IFNsb3Blc0NvcmUgZnJvbSAnLi4vLi4vc2xvcGVzJztcbmltcG9ydCB7IEpSUENBUEksIFJlcXVlc3RSZXNwb25zZURhdGEgfSBmcm9tICcuLi8uLi91dGlscy90eXBlcyc7XG5cbi8qKlxuICogQ2xhc3MgZm9yIGludGVyYWN0aW5nIHdpdGggYSBub2RlJ3MgUGxhdGZvcm1BUElcbiAqIFxuICogQGNhdGVnb3J5IFJQQ0FQSXNcbiAqIFxuICogQHJlbWFya3MgVGhpcyBleHRlbmRzIHRoZSBbW0pSUENBUEldXSBjbGFzcy4gVGhpcyBjbGFzcyBzaG91bGQgbm90IGJlIGRpcmVjdGx5IGNhbGxlZC4gSW5zdGVhZCwgdXNlIHRoZSBbW1Nsb3Blcy5hZGRBUEldXSBmdW5jdGlvbiB0byByZWdpc3RlciB0aGlzIGludGVyZmFjZSB3aXRoIFNsb3Blcy5cbiAqLyBcbmNsYXNzIFBsYXRmb3JtQVBJIGV4dGVuZHMgSlJQQ0FQSXtcblxuICAgIC8qKlxuICAgICAqIEFkZCBhIHN0YWtlZCB2YWxpZGF0b3IgdG8gdGhlIHZhbGlkYXRvciBzZXQuXG4gICAgICogXG4gICAgICogQHBhcmFtIHR4IFRoZSBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgYW4gQWRkU3Rha2VyVHhcbiAgICAgKiBcbiAgICAgKiBAcmV0dXJucyBQcm9taXNlIGZvciBhIGJvb2xlYW4gdmFsdWUsIHRydWUgb24gc3VjY2Vzcy5cbiAgICAgKi9cbiAgICBhZGRTdGFrZXIgPSBhc3luYyAodHg6c3RyaW5nKTpQcm9taXNlPGJvb2xlYW4+ID0+IHtcbiAgICAgICAgbGV0IHBhcmFtcyA9IHtcbiAgICAgICAgICAgIFwidHhcIjogdHhcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbE1ldGhvZChcInBsYXRmb3JtLmFkZFN0YWtlclwiLCBwYXJhbXMpLnRoZW4oKHJlc3BvbnNlOlJlcXVlc3RSZXNwb25zZURhdGEpID0+IHtcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhW1wicmVzdWx0XCJdW1wic3VjY2Vzc1wiXTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIG5ldyBzdWJuZXQuXG4gICAgICogXG4gICAgICogQHBhcmFtIHR4IFRoZSBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgYSBjcmVhdGVTdWJuZXRUeFxuICAgICAqIFxuICAgICAqIEByZXR1cm5zIFByb21pc2UgZm9yIGEgYm9vbGVhbiB2YWx1ZSwgdHJ1ZSBvbiBzdWNjZXNzLlxuICAgICAqL1xuICAgIGNyZWF0ZVN1Ym5ldCA9IGFzeW5jICh0eDpzdHJpbmcpOlByb21pc2U8Ym9vbGVhbj4gPT4ge1xuICAgICAgICBsZXQgcGFyYW1zID0ge1xuICAgICAgICAgICAgXCJ0eFwiOiB0eFxuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdGhpcy5jYWxsTWV0aG9kKFwicGxhdGZvcm0uY3JlYXRlU3VibmV0XCIsIHBhcmFtcykudGhlbigocmVzcG9uc2U6UmVxdWVzdFJlc3BvbnNlRGF0YSkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFbXCJyZXN1bHRcIl1bXCJzdWNjZXNzXCJdO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBMaXN0cyB0aGUgY3VycmVudCBzZXQgb2YgdmFsaWRhdG9ycy5cbiAgICAgKiBcbiAgICAgKiBAcmV0dXJucyBQcm9taXNlIGZvciBhbiBhcnJheSBvZiB2YWxpZGF0b3IncyBzdGFraW5nSURzLlxuICAgICAqL1xuICAgIGxpc3RWYWxpZGF0b3JzID0gYXN5bmMgKCk6UHJvbWlzZTxBcnJheTxzdHJpbmc+PiA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxNZXRob2QoXCJwbGF0Zm9ybS5saXN0VmFsaWRhdG9yc1wiKS50aGVuKChyZXNwb25zZTpSZXF1ZXN0UmVzcG9uc2VEYXRhKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YVtcInJlc3VsdFwiXVtcInZhbGlkYXRvcnNcIl07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFNhbXBsZXMgYFNpemVgIHZhbGlkYXRvcnMgZnJvbSB0aGUgY3VycmVudCB2YWxpZGF0b3Igc2V0LlxuICAgICAqIFxuICAgICAqIEBwYXJhbSBzYW1wbGVTaXplIE9mIHRoZSB0b3RhbCB1bml2ZXJzZSBvZiB2YWxpZGF0b3JzLCBzZWxlY3QgdGhpcyBtYW55IGF0IHJhbmRvbVxuICAgICAqIFxuICAgICAqIEByZXR1cm5zIFByb21pc2UgZm9yIGFuIGFycmF5IG9mIHZhbGlkYXRvcidzIHN0YWtpbmdJRHMuXG4gICAgICovXG4gICAgc2FtcGxlVmFsaWRhdG9ycyA9IGFzeW5jIChzYW1wbGVTaXplOm51bWJlcik6UHJvbWlzZTxBcnJheTxzdHJpbmc+PiA9PiB7XG4gICAgICAgIGxldCBwYXJhbXMgPSB7XG4gICAgICAgICAgICBcInNpemVcIjogc2FtcGxlU2l6ZVxuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdGhpcy5jYWxsTWV0aG9kKFwicGxhdGZvcm0uc2FtcGxlVmFsaWRhdG9yc1wiLCBwYXJhbXMpLnRoZW4oKHJlc3BvbnNlOlJlcXVlc3RSZXNwb25zZURhdGEpID0+IHtcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhW1wicmVzdWx0XCJdW1widmFsaWRhdG9yc1wiXTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogVGhpcyBjbGFzcyBzaG91bGQgbm90IGJlIGluc3RhbnRpYXRlZCBkaXJlY3RseS4gSW5zdGVhZCB1c2UgdGhlIFtbU2xvcGVzLmFkZEFQSV1dIG1ldGhvZC5cbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gY29yZSBBIHJlZmVyZW5jZSB0byB0aGUgU2xvcGVzIGNsYXNzXG4gICAgICogQHBhcmFtIGJhc2V1cmwgRGVmYXVsdHMgdG8gdGhlIHN0cmluZyBcIi9leHQvcGxhdGZvcm1cIiBhcyB0aGUgcGF0aCB0byBzdWJuZXRzIGJhc2V1cmxcbiAgICAgKi9cbiAgICBjb25zdHJ1Y3Rvcihjb3JlOlNsb3Blc0NvcmUsIGJhc2V1cmw6c3RyaW5nID0gXCIvZXh0L3BsYXRmb3JtXCIpeyBzdXBlcihjb3JlLCBiYXNldXJsKTsgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQbGF0Zm9ybUFQSTsiXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaXMvcGxhdGZvcm0vYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBSUEsNkNBQWlFO0FBRWpFOzs7Ozs7R0FNRztBQUNILE1BQU0sV0FBWSxTQUFRLGVBQU87SUFtRjdCOzs7OztPQUtHO0lBQ0gsWUFBWSxJQUFlLEVBQUUsVUFBaUIsZUFBZTtRQUFHLEtBQUssQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUF2RnJGOzs7Ozs7V0FNRztRQUNILGNBQVMsR0FBRyxDQUFPLEVBQVMsRUFBbUIsRUFBRTtZQUM3QyxJQUFJLE1BQU0sR0FBRztnQkFDVCxJQUFJLEVBQUUsRUFBRTthQUNYLENBQUM7WUFDRixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsb0JBQW9CLEVBQUUsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBNEIsRUFBRSxFQUFFO2dCQUN2RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDOUMsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUEsQ0FBQTtRQUVEOzs7Ozs7Ozs7V0FTRztRQUNILHFCQUFnQixHQUFHLENBQU8sSUFBVyxFQUFFLElBQVcsRUFBRSxNQUFhLEVBQUUsT0FBYyxFQUFrQixFQUFFO1lBQ2pHLElBQUksTUFBTSxHQUFHO2dCQUNULE1BQU0sRUFBRSxJQUFJO2dCQUNaLE1BQU0sRUFBRSxJQUFJO2dCQUNaLFFBQVEsRUFBRSxNQUFNO2dCQUNoQixTQUFTLEVBQUUsT0FBTzthQUNyQixDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLDJCQUEyQixFQUFFLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQTRCLEVBQUUsRUFBRTtnQkFDOUYsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1lBQ25ELENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFBLENBQUE7UUFFRDs7Ozs7O1dBTUc7UUFDSCx3QkFBbUIsR0FBRyxDQUFPLFlBQW9CLEVBQWtCLEVBQUU7WUFDakUsSUFBSSxNQUFNLEdBQUc7Z0JBQ1QsY0FBYyxFQUFFLFlBQVk7YUFDL0IsQ0FBQztZQUNGLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyw4QkFBOEIsRUFBRSxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUE0QixFQUFFLEVBQUU7Z0JBQ2pHLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM3QyxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQSxDQUFBO1FBRUQ7Ozs7V0FJRztRQUNILG1CQUFjLEdBQUcsR0FBZ0MsRUFBRTtZQUMvQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMseUJBQXlCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUE0QixFQUFFLEVBQUU7Z0JBQ3BGLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUNqRCxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQSxDQUFBO1FBRUQ7Ozs7OztXQU1HO1FBQ0gscUJBQWdCLEdBQUcsQ0FBTyxVQUFpQixFQUF5QixFQUFFO1lBQ2xFLElBQUksTUFBTSxHQUFHO2dCQUNULE1BQU0sRUFBRSxVQUFVLENBQUMsUUFBUSxFQUFFO2FBQ2hDLENBQUM7WUFDRixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsMkJBQTJCLEVBQUUsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBNEIsRUFBRSxFQUFFO2dCQUM5RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDakQsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUEsQ0FBQTtJQVFxRixDQUFDO0NBQzFGO0FBRUQsa0JBQWUsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIFBsYXRmb3JtQVBJXG4gKi9cbmltcG9ydCBTbG9wZXNDb3JlIGZyb20gJy4uLy4uL3Nsb3Blcyc7XG5pbXBvcnQgeyBKUlBDQVBJLCBSZXF1ZXN0UmVzcG9uc2VEYXRhIH0gZnJvbSAnLi4vLi4vdXRpbHMvdHlwZXMnO1xuXG4vKipcbiAqIENsYXNzIGZvciBpbnRlcmFjdGluZyB3aXRoIGEgbm9kZSdzIFBsYXRmb3JtQVBJXG4gKiBcbiAqIEBjYXRlZ29yeSBSUENBUElzXG4gKiBcbiAqIEByZW1hcmtzIFRoaXMgZXh0ZW5kcyB0aGUgW1tKUlBDQVBJXV0gY2xhc3MuIFRoaXMgY2xhc3Mgc2hvdWxkIG5vdCBiZSBkaXJlY3RseSBjYWxsZWQuIEluc3RlYWQsIHVzZSB0aGUgW1tTbG9wZXMuYWRkQVBJXV0gZnVuY3Rpb24gdG8gcmVnaXN0ZXIgdGhpcyBpbnRlcmZhY2Ugd2l0aCBTbG9wZXMuXG4gKi8gXG5jbGFzcyBQbGF0Zm9ybUFQSSBleHRlbmRzIEpSUENBUEl7XG5cbiAgICAvKipcbiAgICAgKiBBZGQgYSBzdGFrZWQgdmFsaWRhdG9yIHRvIHRoZSB2YWxpZGF0b3Igc2V0LlxuICAgICAqIFxuICAgICAqIEBwYXJhbSB0eCBUaGUgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIGFuIEFkZFN0YWtlclR4XG4gICAgICogXG4gICAgICogQHJldHVybnMgUHJvbWlzZSBmb3IgYSBib29sZWFuIHZhbHVlLCB0cnVlIG9uIHN1Y2Nlc3MuXG4gICAgICovXG4gICAgYWRkU3Rha2VyID0gYXN5bmMgKHR4OnN0cmluZyk6UHJvbWlzZTxib29sZWFuPiA9PiB7XG4gICAgICAgIGxldCBwYXJhbXMgPSB7XG4gICAgICAgICAgICBcInR4XCI6IHR4XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxNZXRob2QoXCJwbGF0Zm9ybS5hZGRTdGFrZXJcIiwgcGFyYW1zKS50aGVuKChyZXNwb25zZTpSZXF1ZXN0UmVzcG9uc2VEYXRhKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YVtcInJlc3VsdFwiXVtcInN1Y2Nlc3NcIl07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIENyZWF0ZXMgYSBuZXcgYmxvY2tjaGFpbi5cbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gdm1JRCBUaGUgVk1JRCB1c2VkIHRvIGJ1aWxkIHRoZSBibG9ja2NoYWluXG4gICAgICogQHBhcmFtIG5hbWUgQSBodW1hbi1yZWFkYWJsZSBuYW1lIGZvciB0aGUgbmV3IGJsb2NrY2hhaW5cbiAgICAgKiBAcGFyYW0gbWV0aG9kIFRoZSBWTUlEJ3MgaG9vayBtZXRob2QgZm9yIGluZ2VzdGluZyBnZW5lc2lzIGRhdGFcbiAgICAgKiBAcGFyYW0gZ2VuZXNpcyBUaGUgb2JqZWN0IHVzZWQgdG8gYnVpbGQgdGhlIGluaXRpYWwgc3RhdGUgb2YgdGhlIGJsb2NrY2hhaW5cbiAgICAgKiBcbiAgICAgKiBAcmV0dXJucyBQcm9taXNlIGZvciBhIHN0cmluZyBmb3IgdGhlIGJsb2NrY2hhaW5JRC5cbiAgICAgKi9cbiAgICBjcmVhdGVCbG9ja2NoYWluID0gYXN5bmMgKHZtSUQ6c3RyaW5nLCBuYW1lOnN0cmluZywgbWV0aG9kOnN0cmluZywgZ2VuZXNpczpvYmplY3QpOlByb21pc2U8c3RyaW5nPiA9PiB7XG4gICAgICAgIGxldCBwYXJhbXMgPSB7XG4gICAgICAgICAgICBcInZtSURcIjogdm1JRCxcbiAgICAgICAgICAgIFwibmFtZVwiOiBuYW1lLFxuICAgICAgICAgICAgXCJtZXRob2RcIjogbWV0aG9kLFxuICAgICAgICAgICAgXCJnZW5lc2lzXCI6IGdlbmVzaXNcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbE1ldGhvZChcInBsYXRmb3JtLmNyZWF0ZUJsb2NrY2hhaW5cIiwgcGFyYW1zKS50aGVuKChyZXNwb25zZTpSZXF1ZXN0UmVzcG9uc2VEYXRhKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YVtcInJlc3VsdFwiXVtcImJsb2NrY2hhaW5JRFwiXTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIG5ldyBibG9ja2NoYWluLlxuICAgICAqIFxuICAgICAqIEBwYXJhbSBibG9ja2NoYWluSUQgVGhlIGJsb2NrY2hhaW5JRCByZXF1ZXN0aW5nIGEgc3RhdHVzIHVwZGF0ZVxuICAgICAqIFxuICAgICAqIEByZXR1cm5zIFByb21pc2UgZm9yIGEgc3RyaW5nIG9mIG9uZSBvZjogXCJWYWxpZGF0aW5nXCIsIFwiQ3JlYXRlZFwiLCBcIlByZWZlcnJlZFwiLCBcIlVua25vd25cIi5cbiAgICAgKi9cbiAgICBnZXRCbG9ja2NoYWluU3RhdHVzID0gYXN5bmMgKGJsb2NrY2hhaW5JRDogc3RyaW5nKTpQcm9taXNlPHN0cmluZz4gPT4ge1xuICAgICAgICBsZXQgcGFyYW1zID0ge1xuICAgICAgICAgICAgXCJibG9ja2NoYWluSURcIjogYmxvY2tjaGFpbklEXG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxNZXRob2QoXCJwbGF0Zm9ybS5nZXRCbG9ja2NoYWluU3RhdHVzXCIsIHBhcmFtcykudGhlbigocmVzcG9uc2U6UmVxdWVzdFJlc3BvbnNlRGF0YSkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFbXCJyZXN1bHRcIl1bXCJzdGF0dXNcIl07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIExpc3RzIHRoZSBjdXJyZW50IHNldCBvZiB2YWxpZGF0b3JzLlxuICAgICAqIFxuICAgICAqIEByZXR1cm5zIFByb21pc2UgZm9yIGFuIGFycmF5IG9mIHZhbGlkYXRvcidzIHN0YWtpbmdJRHMuXG4gICAgICovXG4gICAgbGlzdFZhbGlkYXRvcnMgPSBhc3luYyAoKTpQcm9taXNlPEFycmF5PHN0cmluZz4+ID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbE1ldGhvZChcInBsYXRmb3JtLmxpc3RWYWxpZGF0b3JzXCIpLnRoZW4oKHJlc3BvbnNlOlJlcXVlc3RSZXNwb25zZURhdGEpID0+IHtcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhW1wicmVzdWx0XCJdW1widmFsaWRhdG9yc1wiXTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogU2FtcGxlcyBgU2l6ZWAgdmFsaWRhdG9ycyBmcm9tIHRoZSBjdXJyZW50IHZhbGlkYXRvciBzZXQuXG4gICAgICogXG4gICAgICogQHBhcmFtIHNhbXBsZVNpemUgT2YgdGhlIHRvdGFsIHVuaXZlcnNlIG9mIHZhbGlkYXRvcnMsIHNlbGVjdCB0aGlzIG1hbnkgYXQgcmFuZG9tXG4gICAgICogXG4gICAgICogQHJldHVybnMgUHJvbWlzZSBmb3IgYW4gYXJyYXkgb2YgdmFsaWRhdG9yJ3Mgc3Rha2luZ0lEcy5cbiAgICAgKi9cbiAgICBzYW1wbGVWYWxpZGF0b3JzID0gYXN5bmMgKHNhbXBsZVNpemU6bnVtYmVyKTpQcm9taXNlPEFycmF5PHN0cmluZz4+ID0+IHtcbiAgICAgICAgbGV0IHBhcmFtcyA9IHtcbiAgICAgICAgICAgIFwic2l6ZVwiOiBzYW1wbGVTaXplLnRvU3RyaW5nKClcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbE1ldGhvZChcInBsYXRmb3JtLnNhbXBsZVZhbGlkYXRvcnNcIiwgcGFyYW1zKS50aGVuKChyZXNwb25zZTpSZXF1ZXN0UmVzcG9uc2VEYXRhKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YVtcInJlc3VsdFwiXVtcInZhbGlkYXRvcnNcIl07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFRoaXMgY2xhc3Mgc2hvdWxkIG5vdCBiZSBpbnN0YW50aWF0ZWQgZGlyZWN0bHkuIEluc3RlYWQgdXNlIHRoZSBbW1Nsb3Blcy5hZGRBUEldXSBtZXRob2QuXG4gICAgICogXG4gICAgICogQHBhcmFtIGNvcmUgQSByZWZlcmVuY2UgdG8gdGhlIFNsb3BlcyBjbGFzc1xuICAgICAqIEBwYXJhbSBiYXNldXJsIERlZmF1bHRzIHRvIHRoZSBzdHJpbmcgXCIvZXh0L3BsYXRmb3JtXCIgYXMgdGhlIHBhdGggdG8gc3VibmV0cyBiYXNldXJsXG4gICAgICovXG4gICAgY29uc3RydWN0b3IoY29yZTpTbG9wZXNDb3JlLCBiYXNldXJsOnN0cmluZyA9IFwiL2V4dC9wbGF0Zm9ybVwiKXsgc3VwZXIoY29yZSwgYmFzZXVybCk7IH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgUGxhdGZvcm1BUEk7Il19 |
@@ -62,7 +62,7 @@ /** | ||
export * from './utils/db'; | ||
export { Tx, TxUnsigned } from './apis/avm/tx'; | ||
export { UTXO, SecpUTXO, UTXOSet } from './apis/avm/utxos'; | ||
export { SigIdx, Signature, UnixNow, Address } from './apis/avm/types'; | ||
export { SecpOutput, Output, SelectOutputClass } from './apis/avm/outputs'; | ||
export { SecpInput, Input } from './apis/avm/inputs'; | ||
export { Tx, TxUnsigned, TxCreateAsset } from './apis/avm/tx'; | ||
export { UTXO, SecpUTXO, UTXOSet, SelectUTXOClass } from './apis/avm/utxos'; | ||
export { SigIdx, Signature, UnixNow, Address, AVMConstants, InitialStates } from './apis/avm/types'; | ||
export { SecpOutput, SecpOutBase, Output, SelectOutputClass } from './apis/avm/outputs'; | ||
export { SecpInput, Input, SelectInputClass } from './apis/avm/inputs'; | ||
export { AVMKeyPair, AVMKeyChain } from './apis/avm/keychain'; | ||
@@ -69,0 +69,0 @@ export { AVMAPI as AVM }; |
@@ -108,2 +108,3 @@ "use strict"; | ||
exports.TxUnsigned = tx_1.TxUnsigned; | ||
exports.TxCreateAsset = tx_1.TxCreateAsset; | ||
var utxos_1 = require("./apis/avm/utxos"); | ||
@@ -113,2 +114,3 @@ exports.UTXO = utxos_1.UTXO; | ||
exports.UTXOSet = utxos_1.UTXOSet; | ||
exports.SelectUTXOClass = utxos_1.SelectUTXOClass; | ||
var types_1 = require("./apis/avm/types"); | ||
@@ -119,4 +121,7 @@ exports.SigIdx = types_1.SigIdx; | ||
exports.Address = types_1.Address; | ||
exports.AVMConstants = types_1.AVMConstants; | ||
exports.InitialStates = types_1.InitialStates; | ||
var outputs_1 = require("./apis/avm/outputs"); | ||
exports.SecpOutput = outputs_1.SecpOutput; | ||
exports.SecpOutBase = outputs_1.SecpOutBase; | ||
exports.Output = outputs_1.Output; | ||
@@ -127,5 +132,6 @@ exports.SelectOutputClass = outputs_1.SelectOutputClass; | ||
exports.Input = inputs_1.Input; | ||
exports.SelectInputClass = inputs_1.SelectInputClass; | ||
var keychain_1 = require("./apis/avm/keychain"); | ||
exports.AVMKeyPair = keychain_1.AVMKeyPair; | ||
exports.AVMKeyChain = keychain_1.AVMKeyChain; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0dBRUc7QUFDSCxzREFBa0M7QUErRTFCLHFCQS9FRCxnQkFBVSxDQStFQztBQTlFbEIsOERBQThDO0FBaUd2QixtQkFqR2hCLGFBQVcsQ0FpR2E7QUFoRy9CLDhEQUE4QztBQWlHdkIsbUJBakdoQixhQUFXLENBaUdhO0FBaEcvQix5REFBb0M7QUE4RmxCLGNBOUZYLGFBQU0sQ0E4RlE7QUE3RnJCLDJEQUF3QztBQWdHcEIsZ0JBaEdiLGFBQVEsQ0FnR1U7QUEvRnpCLHlEQUEyQztBQXlFbkMsOEJBQVM7QUF4RWpCLGdFQUF3QztBQXNFaEMsbUJBdEVELGtCQUFRLENBc0VDO0FBckVoQixvREFBNEI7QUFzRXBCLGFBdEVELFlBQUUsQ0FzRUM7QUFwRVY7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFhLE1BQU8sU0FBUSxnQkFBVTtJQThCbEM7Ozs7Ozs7OztPQVNHO0lBQ0gsWUFBWSxFQUFTLEVBQUUsSUFBVyxFQUFFLFdBQWtCLE1BQU0sRUFBRSxZQUFtQixDQUFDLEVBQUUsYUFBb0IsU0FBUyxFQUFFLFdBQW1CLEtBQUs7UUFDdkksS0FBSyxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7UUF2QzlCOztXQUVHO1FBQ0gsVUFBSyxHQUFHLEdBQUcsRUFBRTtZQUNULE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQWEsQ0FBQztRQUMxQyxDQUFDLENBQUE7UUFFRDs7V0FFRztRQUNILFFBQUcsR0FBRyxHQUFHLEVBQUU7WUFDUCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFXLENBQUM7UUFDdEMsQ0FBQyxDQUFBO1FBRUQ7O1dBRUc7UUFDSCxhQUFRLEdBQUcsR0FBRyxFQUFFO1lBQ1osT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBZ0IsQ0FBQztRQUNoRCxDQUFDLENBQUE7UUFFRDs7V0FFRztRQUNILGFBQVEsR0FBRyxHQUFHLEVBQUU7WUFDWixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFnQixDQUFDO1FBQ2hELENBQUMsQ0FBQTtRQWNHLElBQUksT0FBTyxHQUFHLFVBQVUsQ0FBQztRQUN6QixJQUFHLE9BQU8sVUFBVSxLQUFLLFdBQVcsSUFBSSxDQUFDLFVBQVUsRUFBQztZQUNoRCxPQUFPLEdBQUcsbURBQW1ELENBQUM7U0FDakU7UUFDRCxJQUFHLE9BQU8sU0FBUyxLQUFLLFFBQVEsSUFBSSxTQUFTLElBQUksQ0FBQyxFQUFDO1lBQy9DLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1NBQzlCO1FBQ0QsSUFBRyxDQUFDLFFBQVEsRUFBQztZQUNULElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLGFBQVEsQ0FBQyxDQUFDO1lBQy9CLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLGFBQU0sRUFBRSxhQUFhLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsYUFBVyxDQUFDLENBQUM7WUFDckMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsYUFBVyxDQUFDLENBQUM7U0FDeEM7SUFDTCxDQUFDO0NBQ0o7QUF4REQsd0JBd0RDO0FBT0QsOEJBQXlCO0FBQ3pCLHlDQUFvQztBQUNwQyx5Q0FBb0M7QUFDcEMsb0NBQStCO0FBQy9CLHNDQUFpQztBQUNqQyxtQ0FBOEI7QUFDOUIsc0NBQWlDO0FBQ2pDLGdDQUEyQjtBQUUzQixvQ0FBNkM7QUFBckMsa0JBQUEsRUFBRSxDQUFBO0FBQUUsMEJBQUEsVUFBVSxDQUFBO0FBQ3RCLDBDQUF5RDtBQUFqRCx1QkFBQSxJQUFJLENBQUE7QUFBRSwyQkFBQSxRQUFRLENBQUE7QUFBRSwwQkFBQSxPQUFPLENBQUE7QUFDL0IsMENBQXFFO0FBQTdELHlCQUFBLE1BQU0sQ0FBQTtBQUFFLDRCQUFBLFNBQVMsQ0FBQTtBQUFFLDBCQUFBLE9BQU8sQ0FBQTtBQUFFLDBCQUFBLE9BQU8sQ0FBQTtBQUMzQyw4Q0FBeUU7QUFBakUsK0JBQUEsVUFBVSxDQUFBO0FBQUUsMkJBQUEsTUFBTSxDQUFBO0FBQUUsc0NBQUEsaUJBQWlCLENBQUE7QUFDN0MsNENBQW1EO0FBQTNDLDZCQUFBLFNBQVMsQ0FBQTtBQUFFLHlCQUFBLEtBQUssQ0FBQTtBQUN4QixnREFBNEQ7QUFBcEQsZ0NBQUEsVUFBVSxDQUFBO0FBQUUsaUNBQUEsV0FBVyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIFNsb3Blc1xuICovXG5pbXBvcnQgU2xvcGVzQ29yZSBmcm9tICcuL3Nsb3Blcyc7XG5pbXBvcnQgS2V5c3RvcmVBUEkgZnJvbSAnLi9hcGlzL2tleXN0b3JlL2FwaSc7XG5pbXBvcnQgUGxhdGZvcm1BUEkgZnJvbSAnLi9hcGlzL3BsYXRmb3JtL2FwaSc7XG5pbXBvcnQgQVZNQVBJIGZyb20gJy4vYXBpcy9hdm0vYXBpJztcbmltcG9ydCBBZG1pbkFQSSBmcm9tICcuL2FwaXMvYWRtaW4vYXBpJztcbmltcG9ydCAqIGFzIENvcmVUeXBlcyBmcm9tICcuL3V0aWxzL3R5cGVzJztcbmltcG9ydCBCaW5Ub29scyBmcm9tICcuL3V0aWxzL2JpbnRvb2xzJztcbmltcG9ydCBEQiBmcm9tICcuL3V0aWxzL2RiJztcblxuLyoqXG4gKiBTbG9wZXMgaXMgbWlkZGxld2FyZSBmb3IgaW50ZXJhY3Rpbmcgd2l0aCBBVkEgbm9kZSBSUEMgQVBJcy4gXG4gKiBcbiAqIEV4YW1wbGUgdXNhZ2U6XG4gKiBgYGBqc1xuICogbGV0IHNsb3BlcyA9IG5ldyBTbG9wZXMoXCIxMjcuMC4wLjFcIiwgOTY1MCwgXCJodHRwc1wiKTtcbiAqIGBgYFxuICogXG4gKi9cbmV4cG9ydCBjbGFzcyBTbG9wZXMgZXh0ZW5kcyBTbG9wZXNDb3JlIHtcblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgYSByZWZlcmVuY2UgdG8gdGhlIEFkbWluIFJQQy5cbiAgICAgKi9cbiAgICBBZG1pbiA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYXBpc1tcImFkbWluXCJdIGFzIEFkbWluQVBJO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgYSByZWZlcmVuY2UgdG8gdGhlIEFWTSBSUEMuXG4gICAgICovXG4gICAgQVZNID0gKCkgPT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5hcGlzW1wiYXZtXCJdIGFzIEFWTUFQSTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBSZXR1cm5zIGEgcmVmZXJlbmNlIHRvIHRoZSBQbGF0Zm9ybSBSUEMuXG4gICAgICovXG4gICAgUGxhdGZvcm0gPSAoKSA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFwaXNbXCJwbGF0Zm9ybVwiXSBhcyBQbGF0Zm9ybUFQSTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBSZXR1cm5zIGEgcmVmZXJlbmNlIHRvIHRoZSBLZXlzdG9yZSBSUEMgZm9yIGEgbm9kZS4gV2UgbGFiZWwgaXQgXCJOb2RlS2V5c1wiIHRvIHJlZHVjZSBjb25mdXNpb24gYWJvdXQgd2hhdCBpdCdzIGFjY2Vzc2luZy5cbiAgICAgKi9cbiAgICBOb2RlS2V5cyA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYXBpc1tcImtleXN0b3JlXCJdIGFzIEtleXN0b3JlQVBJO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIENyZWF0ZXMgYSBuZXcgQVZBIGluc3RhbmNlLiBTZXRzIHRoZSBhZGRyZXNzIGFuZCBwb3J0IG9mIHRoZSBtYWluIEFWQSBDbGllbnQuXG4gICAgICogXG4gICAgICogQHBhcmFtIGlwIFRoZSBob3N0bmFtZSB0byByZXNvbHZlIHRvIHJlYWNoIHRoZSBBVkEgQ2xpZW50IFJQQyBBUElzXG4gICAgICogQHBhcmFtIHBvcnQgVGhlIHBvcnQgdG8gcmVvbHZlIHRvIHJlYWNoIHRoZSBBVkEgQ2xpZW50IFJQQyBBUElzXG4gICAgICogQHBhcmFtIHByb3RvY29sIFRoZSBwcm90b2NvbCBzdHJpbmcgdG8gdXNlIGJlZm9yZSBhIFwiOi8vXCIgaW4gYSByZXF1ZXN0LCBleDogXCJodHRwXCIsIFwiaHR0cHNcIiwgXCJnaXRcIiwgXCJ3c1wiLCBldGMgLi4uXG4gICAgICogQHBhcmFtIG5ldHdvcmtpZCBTZXRzIHRoZSBOZXR3b3JrSUQgb2YgdGhlIGNsYXNzLiBEZWZhdWx0IDJcbiAgICAgKiBAcGFyYW0gYXZtQ2hhaW5JRCBTZXRzIHRoZSBibG9ja2NoYWluSUQgZm9yIHRoZSBBVk0uIERlZmF1bHQgXCJIRDhIRXdOS1RYUkJjVlVxdlFXMkxSdTlpenFlajkxeHpHbVhBVEY0S01NVjZMTG03XCJcbiAgICAgKiBAcGFyYW0gc2tpcGluaXQgU2tpcHMgY3JlYXRpbmcgdGhlIEFQSXNcbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvcihpcDpzdHJpbmcsIHBvcnQ6bnVtYmVyLCBwcm90b2NvbDpzdHJpbmcgPSBcImh0dHBcIiwgbmV0d29ya0lEOm51bWJlciA9IDIsIGF2bUNoYWluSUQ6c3RyaW5nID0gdW5kZWZpbmVkLCBza2lwaW5pdDpib29sZWFuID0gZmFsc2UpIHtcbiAgICAgICAgc3VwZXIoaXAsIHBvcnQsIHByb3RvY29sKTtcbiAgICAgICAgbGV0IGNoYWluaWQgPSBhdm1DaGFpbklEO1xuICAgICAgICBpZih0eXBlb2YgYXZtQ2hhaW5JRCA9PT0gJ3VuZGVmaW5lZCcgfHwgIWF2bUNoYWluSUQpe1xuICAgICAgICAgICAgY2hhaW5pZCA9IFwiSEQ4SEV3TktUWFJCY1ZVcXZRVzJMUnU5aXpxZWo5MXh6R21YQVRGNEtNTVY2TExtN1wiO1xuICAgICAgICB9XG4gICAgICAgIGlmKHR5cGVvZiBuZXR3b3JrSUQgPT09ICdudW1iZXInICYmIG5ldHdvcmtJRCA+PSAwKXtcbiAgICAgICAgICAgIHRoaXMubmV0d29ya0lEID0gbmV0d29ya0lEO1xuICAgICAgICB9XG4gICAgICAgIGlmKCFza2lwaW5pdCl7XG4gICAgICAgICAgICB0aGlzLmFkZEFQSShcImFkbWluXCIsIEFkbWluQVBJKTtcbiAgICAgICAgICAgIHRoaXMuYWRkQVBJKFwiYXZtXCIsIEFWTUFQSSwgXCIvZXh0L2JjL2F2bVwiLCBjaGFpbmlkKTtcbiAgICAgICAgICAgIHRoaXMuYWRkQVBJKFwicGxhdGZvcm1cIiwgUGxhdGZvcm1BUEkpO1xuICAgICAgICAgICAgdGhpcy5hZGRBUEkoXCJrZXlzdG9yZVwiLCBLZXlzdG9yZUFQSSk7XG4gICAgICAgIH1cbiAgICB9XG59XG5cbmV4cG9ydCB7QmluVG9vbHN9O1xuZXhwb3J0IHtEQn07XG5leHBvcnQge0NvcmVUeXBlc307XG5leHBvcnQge1Nsb3Blc0NvcmV9O1xuXG5leHBvcnQgKiBmcm9tICcuL3Nsb3Blcyc7XG5leHBvcnQgKiBmcm9tICcuL2FwaXMva2V5c3RvcmUvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vYXBpcy9wbGF0Zm9ybS9hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9hcGlzL2F2bS9hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9hcGlzL2FkbWluL2FwaSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvYmludG9vbHMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9kYic7XG5cbmV4cG9ydCB7VHgsIFR4VW5zaWduZWR9IGZyb20gJy4vYXBpcy9hdm0vdHgnO1xuZXhwb3J0IHtVVFhPLCBTZWNwVVRYTywgVVRYT1NldH0gZnJvbSAnLi9hcGlzL2F2bS91dHhvcyc7XHRcbmV4cG9ydCB7U2lnSWR4LCBTaWduYXR1cmUsIFVuaXhOb3csIEFkZHJlc3N9IGZyb20gJy4vYXBpcy9hdm0vdHlwZXMnO1x0XG5leHBvcnQge1NlY3BPdXRwdXQsIE91dHB1dCwgU2VsZWN0T3V0cHV0Q2xhc3N9IGZyb20gJy4vYXBpcy9hdm0vb3V0cHV0cyc7XHRcbmV4cG9ydCB7U2VjcElucHV0LCBJbnB1dH0gZnJvbSAnLi9hcGlzL2F2bS9pbnB1dHMnO1x0XG5leHBvcnQge0FWTUtleVBhaXIsIEFWTUtleUNoYWlufSBmcm9tICcuL2FwaXMvYXZtL2tleWNoYWluJztcblxuZXhwb3J0IHtBVk1BUEkgYXMgQVZNfTtcbmV4cG9ydCB7S2V5c3RvcmVBUEkgYXMgS2V5c3RvcmV9O1xuZXhwb3J0IHtQbGF0Zm9ybUFQSSBhcyBQbGF0Zm9ybX07XG5leHBvcnQge0FkbWluQVBJIGFzIEFkbWlufTtcblxuXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0dBRUc7QUFDSCxzREFBa0M7QUErRTFCLHFCQS9FRCxnQkFBVSxDQStFQztBQTlFbEIsOERBQThDO0FBaUd2QixtQkFqR2hCLGFBQVcsQ0FpR2E7QUFoRy9CLDhEQUE4QztBQWlHdkIsbUJBakdoQixhQUFXLENBaUdhO0FBaEcvQix5REFBb0M7QUE4RmxCLGNBOUZYLGFBQU0sQ0E4RlE7QUE3RnJCLDJEQUF3QztBQWdHcEIsZ0JBaEdiLGFBQVEsQ0FnR1U7QUEvRnpCLHlEQUEyQztBQXlFbkMsOEJBQVM7QUF4RWpCLGdFQUF3QztBQXNFaEMsbUJBdEVELGtCQUFRLENBc0VDO0FBckVoQixvREFBNEI7QUFzRXBCLGFBdEVELFlBQUUsQ0FzRUM7QUFwRVY7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFhLE1BQU8sU0FBUSxnQkFBVTtJQThCbEM7Ozs7Ozs7OztPQVNHO0lBQ0gsWUFBWSxFQUFTLEVBQUUsSUFBVyxFQUFFLFdBQWtCLE1BQU0sRUFBRSxZQUFtQixDQUFDLEVBQUUsYUFBb0IsU0FBUyxFQUFFLFdBQW1CLEtBQUs7UUFDdkksS0FBSyxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7UUF2QzlCOztXQUVHO1FBQ0gsVUFBSyxHQUFHLEdBQUcsRUFBRTtZQUNULE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQWEsQ0FBQztRQUMxQyxDQUFDLENBQUE7UUFFRDs7V0FFRztRQUNILFFBQUcsR0FBRyxHQUFHLEVBQUU7WUFDUCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFXLENBQUM7UUFDdEMsQ0FBQyxDQUFBO1FBRUQ7O1dBRUc7UUFDSCxhQUFRLEdBQUcsR0FBRyxFQUFFO1lBQ1osT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBZ0IsQ0FBQztRQUNoRCxDQUFDLENBQUE7UUFFRDs7V0FFRztRQUNILGFBQVEsR0FBRyxHQUFHLEVBQUU7WUFDWixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFnQixDQUFDO1FBQ2hELENBQUMsQ0FBQTtRQWNHLElBQUksT0FBTyxHQUFHLFVBQVUsQ0FBQztRQUN6QixJQUFHLE9BQU8sVUFBVSxLQUFLLFdBQVcsSUFBSSxDQUFDLFVBQVUsRUFBQztZQUNoRCxPQUFPLEdBQUcsbURBQW1ELENBQUM7U0FDakU7UUFDRCxJQUFHLE9BQU8sU0FBUyxLQUFLLFFBQVEsSUFBSSxTQUFTLElBQUksQ0FBQyxFQUFDO1lBQy9DLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1NBQzlCO1FBQ0QsSUFBRyxDQUFDLFFBQVEsRUFBQztZQUNULElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLGFBQVEsQ0FBQyxDQUFDO1lBQy9CLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLGFBQU0sRUFBRSxhQUFhLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsYUFBVyxDQUFDLENBQUM7WUFDckMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsYUFBVyxDQUFDLENBQUM7U0FDeEM7SUFDTCxDQUFDO0NBQ0o7QUF4REQsd0JBd0RDO0FBT0QsOEJBQXlCO0FBQ3pCLHlDQUFvQztBQUNwQyx5Q0FBb0M7QUFDcEMsb0NBQStCO0FBQy9CLHNDQUFpQztBQUNqQyxtQ0FBOEI7QUFDOUIsc0NBQWlDO0FBQ2pDLGdDQUEyQjtBQUUzQixvQ0FBNEQ7QUFBcEQsa0JBQUEsRUFBRSxDQUFBO0FBQUUsMEJBQUEsVUFBVSxDQUFBO0FBQUUsNkJBQUEsYUFBYSxDQUFBO0FBQ3JDLDBDQUEwRTtBQUFsRSx1QkFBQSxJQUFJLENBQUE7QUFBRSwyQkFBQSxRQUFRLENBQUE7QUFBRSwwQkFBQSxPQUFPLENBQUE7QUFBRSxrQ0FBQSxlQUFlLENBQUE7QUFDaEQsMENBQWtHO0FBQTFGLHlCQUFBLE1BQU0sQ0FBQTtBQUFFLDRCQUFBLFNBQVMsQ0FBQTtBQUFFLDBCQUFBLE9BQU8sQ0FBQTtBQUFFLDBCQUFBLE9BQU8sQ0FBQTtBQUFFLCtCQUFBLFlBQVksQ0FBQTtBQUFFLGdDQUFBLGFBQWEsQ0FBQTtBQUN4RSw4Q0FBc0Y7QUFBOUUsK0JBQUEsVUFBVSxDQUFBO0FBQUUsZ0NBQUEsV0FBVyxDQUFBO0FBQUUsMkJBQUEsTUFBTSxDQUFBO0FBQUUsc0NBQUEsaUJBQWlCLENBQUE7QUFDMUQsNENBQXFFO0FBQTdELDZCQUFBLFNBQVMsQ0FBQTtBQUFFLHlCQUFBLEtBQUssQ0FBQTtBQUFFLG9DQUFBLGdCQUFnQixDQUFBO0FBQzFDLGdEQUE0RDtBQUFwRCxnQ0FBQSxVQUFVLENBQUE7QUFBRSxpQ0FBQSxXQUFXLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgU2xvcGVzXG4gKi9cbmltcG9ydCBTbG9wZXNDb3JlIGZyb20gJy4vc2xvcGVzJztcbmltcG9ydCBLZXlzdG9yZUFQSSBmcm9tICcuL2FwaXMva2V5c3RvcmUvYXBpJztcbmltcG9ydCBQbGF0Zm9ybUFQSSBmcm9tICcuL2FwaXMvcGxhdGZvcm0vYXBpJztcbmltcG9ydCBBVk1BUEkgZnJvbSAnLi9hcGlzL2F2bS9hcGknO1xuaW1wb3J0IEFkbWluQVBJIGZyb20gJy4vYXBpcy9hZG1pbi9hcGknO1xuaW1wb3J0ICogYXMgQ29yZVR5cGVzIGZyb20gJy4vdXRpbHMvdHlwZXMnO1xuaW1wb3J0IEJpblRvb2xzIGZyb20gJy4vdXRpbHMvYmludG9vbHMnO1xuaW1wb3J0IERCIGZyb20gJy4vdXRpbHMvZGInO1xuXG4vKipcbiAqIFNsb3BlcyBpcyBtaWRkbGV3YXJlIGZvciBpbnRlcmFjdGluZyB3aXRoIEFWQSBub2RlIFJQQyBBUElzLiBcbiAqIFxuICogRXhhbXBsZSB1c2FnZTpcbiAqIGBgYGpzXG4gKiBsZXQgc2xvcGVzID0gbmV3IFNsb3BlcyhcIjEyNy4wLjAuMVwiLCA5NjUwLCBcImh0dHBzXCIpO1xuICogYGBgXG4gKiBcbiAqL1xuZXhwb3J0IGNsYXNzIFNsb3BlcyBleHRlbmRzIFNsb3Blc0NvcmUge1xuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyBhIHJlZmVyZW5jZSB0byB0aGUgQWRtaW4gUlBDLlxuICAgICAqL1xuICAgIEFkbWluID0gKCkgPT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5hcGlzW1wiYWRtaW5cIl0gYXMgQWRtaW5BUEk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyBhIHJlZmVyZW5jZSB0byB0aGUgQVZNIFJQQy5cbiAgICAgKi9cbiAgICBBVk0gPSAoKSA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFwaXNbXCJhdm1cIl0gYXMgQVZNQVBJO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgYSByZWZlcmVuY2UgdG8gdGhlIFBsYXRmb3JtIFJQQy5cbiAgICAgKi9cbiAgICBQbGF0Zm9ybSA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYXBpc1tcInBsYXRmb3JtXCJdIGFzIFBsYXRmb3JtQVBJO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgYSByZWZlcmVuY2UgdG8gdGhlIEtleXN0b3JlIFJQQyBmb3IgYSBub2RlLiBXZSBsYWJlbCBpdCBcIk5vZGVLZXlzXCIgdG8gcmVkdWNlIGNvbmZ1c2lvbiBhYm91dCB3aGF0IGl0J3MgYWNjZXNzaW5nLlxuICAgICAqL1xuICAgIE5vZGVLZXlzID0gKCkgPT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5hcGlzW1wia2V5c3RvcmVcIl0gYXMgS2V5c3RvcmVBUEk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhIG5ldyBBVkEgaW5zdGFuY2UuIFNldHMgdGhlIGFkZHJlc3MgYW5kIHBvcnQgb2YgdGhlIG1haW4gQVZBIENsaWVudC5cbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gaXAgVGhlIGhvc3RuYW1lIHRvIHJlc29sdmUgdG8gcmVhY2ggdGhlIEFWQSBDbGllbnQgUlBDIEFQSXNcbiAgICAgKiBAcGFyYW0gcG9ydCBUaGUgcG9ydCB0byByZW9sdmUgdG8gcmVhY2ggdGhlIEFWQSBDbGllbnQgUlBDIEFQSXNcbiAgICAgKiBAcGFyYW0gcHJvdG9jb2wgVGhlIHByb3RvY29sIHN0cmluZyB0byB1c2UgYmVmb3JlIGEgXCI6Ly9cIiBpbiBhIHJlcXVlc3QsIGV4OiBcImh0dHBcIiwgXCJodHRwc1wiLCBcImdpdFwiLCBcIndzXCIsIGV0YyAuLi5cbiAgICAgKiBAcGFyYW0gbmV0d29ya2lkIFNldHMgdGhlIE5ldHdvcmtJRCBvZiB0aGUgY2xhc3MuIERlZmF1bHQgMlxuICAgICAqIEBwYXJhbSBhdm1DaGFpbklEIFNldHMgdGhlIGJsb2NrY2hhaW5JRCBmb3IgdGhlIEFWTS4gRGVmYXVsdCBcIkhEOEhFd05LVFhSQmNWVXF2UVcyTFJ1OWl6cWVqOTF4ekdtWEFURjRLTU1WNkxMbTdcIlxuICAgICAqIEBwYXJhbSBza2lwaW5pdCBTa2lwcyBjcmVhdGluZyB0aGUgQVBJc1xuICAgICAqL1xuICAgIGNvbnN0cnVjdG9yKGlwOnN0cmluZywgcG9ydDpudW1iZXIsIHByb3RvY29sOnN0cmluZyA9IFwiaHR0cFwiLCBuZXR3b3JrSUQ6bnVtYmVyID0gMiwgYXZtQ2hhaW5JRDpzdHJpbmcgPSB1bmRlZmluZWQsIHNraXBpbml0OmJvb2xlYW4gPSBmYWxzZSkge1xuICAgICAgICBzdXBlcihpcCwgcG9ydCwgcHJvdG9jb2wpO1xuICAgICAgICBsZXQgY2hhaW5pZCA9IGF2bUNoYWluSUQ7XG4gICAgICAgIGlmKHR5cGVvZiBhdm1DaGFpbklEID09PSAndW5kZWZpbmVkJyB8fCAhYXZtQ2hhaW5JRCl7XG4gICAgICAgICAgICBjaGFpbmlkID0gXCJIRDhIRXdOS1RYUkJjVlVxdlFXMkxSdTlpenFlajkxeHpHbVhBVEY0S01NVjZMTG03XCI7XG4gICAgICAgIH1cbiAgICAgICAgaWYodHlwZW9mIG5ldHdvcmtJRCA9PT0gJ251bWJlcicgJiYgbmV0d29ya0lEID49IDApe1xuICAgICAgICAgICAgdGhpcy5uZXR3b3JrSUQgPSBuZXR3b3JrSUQ7XG4gICAgICAgIH1cbiAgICAgICAgaWYoIXNraXBpbml0KXtcbiAgICAgICAgICAgIHRoaXMuYWRkQVBJKFwiYWRtaW5cIiwgQWRtaW5BUEkpO1xuICAgICAgICAgICAgdGhpcy5hZGRBUEkoXCJhdm1cIiwgQVZNQVBJLCBcIi9leHQvYmMvYXZtXCIsIGNoYWluaWQpO1xuICAgICAgICAgICAgdGhpcy5hZGRBUEkoXCJwbGF0Zm9ybVwiLCBQbGF0Zm9ybUFQSSk7XG4gICAgICAgICAgICB0aGlzLmFkZEFQSShcImtleXN0b3JlXCIsIEtleXN0b3JlQVBJKTtcbiAgICAgICAgfVxuICAgIH1cbn1cblxuZXhwb3J0IHtCaW5Ub29sc307XG5leHBvcnQge0RCfTtcbmV4cG9ydCB7Q29yZVR5cGVzfTtcbmV4cG9ydCB7U2xvcGVzQ29yZX07XG5cbmV4cG9ydCAqIGZyb20gJy4vc2xvcGVzJztcbmV4cG9ydCAqIGZyb20gJy4vYXBpcy9rZXlzdG9yZS9hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9hcGlzL3BsYXRmb3JtL2FwaSc7XG5leHBvcnQgKiBmcm9tICcuL2FwaXMvYXZtL2FwaSc7XG5leHBvcnQgKiBmcm9tICcuL2FwaXMvYWRtaW4vYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9iaW50b29scyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2RiJztcblxuZXhwb3J0IHtUeCwgVHhVbnNpZ25lZCwgVHhDcmVhdGVBc3NldH0gZnJvbSAnLi9hcGlzL2F2bS90eCc7XG5leHBvcnQge1VUWE8sIFNlY3BVVFhPLCBVVFhPU2V0LCBTZWxlY3RVVFhPQ2xhc3N9IGZyb20gJy4vYXBpcy9hdm0vdXR4b3MnO1x0XG5leHBvcnQge1NpZ0lkeCwgU2lnbmF0dXJlLCBVbml4Tm93LCBBZGRyZXNzLCBBVk1Db25zdGFudHMsIEluaXRpYWxTdGF0ZXN9IGZyb20gJy4vYXBpcy9hdm0vdHlwZXMnO1x0XG5leHBvcnQge1NlY3BPdXRwdXQsIFNlY3BPdXRCYXNlLCBPdXRwdXQsIFNlbGVjdE91dHB1dENsYXNzfSBmcm9tICcuL2FwaXMvYXZtL291dHB1dHMnO1x0XG5leHBvcnQge1NlY3BJbnB1dCwgSW5wdXQsIFNlbGVjdElucHV0Q2xhc3N9IGZyb20gJy4vYXBpcy9hdm0vaW5wdXRzJztcdFxuZXhwb3J0IHtBVk1LZXlQYWlyLCBBVk1LZXlDaGFpbn0gZnJvbSAnLi9hcGlzL2F2bS9rZXljaGFpbic7XG5cbmV4cG9ydCB7QVZNQVBJIGFzIEFWTX07XG5leHBvcnQge0tleXN0b3JlQVBJIGFzIEtleXN0b3JlfTtcbmV4cG9ydCB7UGxhdGZvcm1BUEkgYXMgUGxhdGZvcm19O1xuZXhwb3J0IHtBZG1pbkFQSSBhcyBBZG1pbn07XG5cblxuIl19 |
@@ -28,2 +28,14 @@ /** | ||
/** | ||
* Produces a string from a {@link https://github.com/feross/buffer|Buffer} representing a string. | ||
* | ||
* @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a string | ||
*/ | ||
bufferToString: (buff: Buffer) => string; | ||
/** | ||
* Produces a {@link https://github.com/feross/buffer|Buffer} from a string. | ||
* | ||
* @param str The string to convert to a {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
stringToBuffer: (str: string) => Buffer; | ||
/** | ||
* Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer} over provided indecies. | ||
@@ -99,2 +111,10 @@ * | ||
avaDeserialize: (bytes: string | Buffer) => Buffer; | ||
addressToString: (chainid: string, bytes: Buffer) => string; | ||
stringToAddress: (address: string) => Buffer; | ||
/** | ||
* Takes an address and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid. | ||
*/ | ||
parseAddress: (addr: string, blockchainID: string, alias?: string, addrlen?: number) => Buffer; | ||
} | ||
@@ -101,0 +121,0 @@ /** |
@@ -28,2 +28,21 @@ "use strict"; | ||
/** | ||
* Produces a string from a {@link https://github.com/feross/buffer|Buffer} representing a string. | ||
* | ||
* @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a string | ||
*/ | ||
this.bufferToString = (buff) => { | ||
return this.copyFrom(buff, 2).toString("utf8"); | ||
}; | ||
/** | ||
* Produces a {@link https://github.com/feross/buffer|Buffer} from a string. | ||
* | ||
* @param str The string to convert to a {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
this.stringToBuffer = (str) => { | ||
let buff = buffer_1.Buffer.alloc(2 + str.length); | ||
buff.writeUInt16BE(str.length, 0); | ||
buff.write(str, 2, str.length, "utf8"); | ||
return buff; | ||
}; | ||
/** | ||
* Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer} over provided indecies. | ||
@@ -151,2 +170,26 @@ * | ||
}; | ||
this.addressToString = (chainid, bytes) => { | ||
return chainid + "-" + this.avaSerialize(bytes); | ||
}; | ||
this.stringToAddress = (address) => { | ||
let parts = address.split("-"); | ||
return this.avaDeserialize(parts[1]); | ||
}; | ||
/** | ||
* Takes an address and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid. | ||
*/ | ||
this.parseAddress = (addr, blockchainID, alias = undefined, addrlen = 20) => { | ||
let abc = addr.split("-"); | ||
if (abc.length == 2) { | ||
if ((alias && abc[0] == alias) || (blockchainID && abc[0] == blockchainID)) { | ||
let addrbuff = this.avaDeserialize(abc[1]); | ||
if ((addrlen && addrbuff.length == addrlen) || !(addrlen)) { | ||
return addrbuff; | ||
} | ||
} | ||
} | ||
return undefined; | ||
}; | ||
this.b58 = new Base58(); | ||
@@ -274,2 +317,2 @@ } | ||
exports.Base58 = Base58; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bintools.js","sourceRoot":"","sources":["../../../src/utils/bintools.ts"],"names":[],"mappings":"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AG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;SACzC,CAAA;QACS,eAAU,GAAM,IAAI,eA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","sourcesContent":["/**\n * @module Utils\n */\nimport BN  from \"bn.js\";\nimport {Buffer} from \"buffer/\";\nimport createHash from \"create-hash\";\n\n/**\n * A class containing tools useful in interacting with binary data cross-platform using nodejs & javascript.\n * \n * This class should never be instantiated directly. Instead, invoke the \"BinTools.getInstance()\" static\n * function to grab the singleton instance of the tools.\n * \n * Everything in this library uses the {@link https://github.com/feross/buffer|feross's Buffer class}.\n * \n * ```js\n * const bintools = BinTools.getInstance();\n * let b58str = bintools.bufferToB58(Buffer.from(\"Wubalubadubdub!\"));\n * ```\n */\nexport default class BinTools {\n    private static  instance:BinTools;\n    private constructor() {\n        this.b58 = new Base58();\n    }\n    private b58:Base58;\n    \n  \n    /**\n     * Retrieves the BinTools singleton. \n     */\n    static getInstance(): BinTools {\n        if (!BinTools.instance) {\n            BinTools.instance = new BinTools();\n        }\n        return BinTools.instance;\n    }\n\n    /**\n     * Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer} over provided indecies. \n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to copy\n     * @param start The index to start the copy\n     * @param end The index to end the copy\n     */\n    copyFrom = (buff:Buffer, start:number = 0, end:number = undefined):Buffer => {\n        let theEnd = end;\n        if(end === undefined){\n            theEnd = buff.length;\n        }\n        return Buffer.from(Uint8Array.prototype.slice.call(buff.slice(start,theEnd)))\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string of the {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to base-58\n     */\n    bufferToB58 = (buff:Buffer):string => {\n        return this.b58.encode(buff);\n    }\n\n    /**\n     * Takes a base-58 string and returns a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param b58str The base-58 string to convert to a {@link https://github.com/feross/buffer|Buffer}\n     */\n    b58ToBuffer = (b58str:string):Buffer => {\n        return this.b58.decode(b58str);\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and returns an ArrayBuffer.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to an ArrayBuffer\n     */\n    fromBufferToArrayBuffer = (buff:Buffer):ArrayBuffer => {\n        let ab = new ArrayBuffer(buff.length);\n        let view = new Uint8Array(ab);\n        for (let i = 0; i < buff.length; ++i) {\n            view[i] = buff[i];\n        }\n        return view;\n    }\n\n    /**\n     * Takes an ArrayBuffer and converts it to a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param ab The ArrayBuffer to convert to a {@link https://github.com/feross/buffer|Buffer} \n     */\n    fromArrayBufferToBuffer = (ab:ArrayBuffer):Buffer => {\n        let buf = Buffer.alloc(ab.byteLength);\n        for (let i = 0; i < ab.byteLength; ++i) {\n            buf[i] = ab[i];\n        }\n        return buf;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and converts it to a {@link https://github.com/indutny/bn.js/|BN}.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a {@link https://github.com/indutny/bn.js/|BN}\n     */\n    fromBufferToBN = (buff:Buffer):BN => {\n        return new BN(buff.toString(\"hex\"), 16, \"be\");\n    }\n\n    /**\n     * Takes a {@link https://github.com/indutny/bn.js/|BN} and converts it to a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param bn The {@link https://github.com/indutny/bn.js/|BN} to convert to a {@link https://github.com/feross/buffer|Buffer}\n     * @param length The zero-padded length of the {@link https://github.com/feross/buffer|Buffer}\n     */\n    fromBNToBuffer = (bn:BN, length?:number):Buffer => {\n        let newarr = bn.toArray(\"be\");\n        if(length){ //bn toArray with the length parameter doesn't work correctly, need this.\n            let x = length - newarr.length;\n            for(let i:number = 0; i < x; i++){  \n                newarr.unshift(0);\n            }\n        }\n        return Buffer.from(newarr);\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and adds a checksum, returning a {@link https://github.com/feross/buffer|Buffer} with the 4-byte checksum appended.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to append a checksum\n     */\n    addChecksum = (buff:Buffer):Buffer => {\n        let hashslice:Buffer = Buffer.from(createHash('sha256').update(buff).digest().slice(28));\n        return Buffer.concat([buff, hashslice]);\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} with an appended 4-byte checksum and returns true if the checksum is valid, otherwise false.\n     * \n     * @param b The {@link https://github.com/feross/buffer|Buffer} to validate the checksum\n     */\n    validateChecksum = (buff:Buffer):boolean => {\n        let checkslice:Buffer = buff.slice(buff.length - 4);\n        let hashslice:Buffer = Buffer.from(createHash('sha256').update(buff.slice(0, buff.length - 4)).digest().slice(28));\n        return checkslice.toString(\"hex\") == hashslice.toString(\"hex\");\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string with checksum as per the AVA standard.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} to serialize\n     * \n     * @returns A serialized base-58 strig of the Buffer.\n     */\n    avaSerialize = (bytes:Buffer):string => {\n        bytes = this.addChecksum(bytes);\n        return this.bufferToB58(bytes);\n    }\n\n    /**\n     * Takes an AVA serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string and returns a {@link https://github.com/feross/buffer|Buffer} of the original data. Throws on error.\n     * \n     * @param bytes An AVA serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string\n     */\n    avaDeserialize = (bytes:Buffer | string):Buffer => {\n        if(typeof bytes === 'string'){\n            bytes = this.b58ToBuffer(bytes);\n        }\n        if(this.validateChecksum(bytes)){\n            return this.copyFrom(bytes, 0,bytes.length - 4);\n        }\n        throw new Error(\"Error - BinTools.avaDeserialize: invalid checksum\");\n    }\n\n}\n\n/**\n * A Base58 class that uses the cross-platform Buffer module. Built so that Typescript will accept the code.\n * \n * ```js\n * let b58:Base58 = new Base58();\n * let str:string = b58.encode(somebuffer);\n * let buff:Buffer = b58.decode(somestring);\n * ```\n */\nexport class Base58 {\n    protected b58alphabet:string = \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\";\n    protected alphabetIdx0 = '1'\n    protected b58 = [\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 0, 1, 2, 3, 4, 5, 6,\n        7, 8, 255, 255, 255, 255, 255, 255,\n        255, 9, 10, 11, 12, 13, 14, 15,\n        16, 255, 17, 18, 19, 20, 21, 255,\n        22, 23, 24, 25, 26, 27, 28, 29,\n        30, 31, 32, 255, 255, 255, 255, 255,\n        255, 33, 34, 35, 36, 37, 38, 39,\n        40, 41, 42, 43, 255, 44, 45, 46,\n        47, 48, 49, 50, 51, 52, 53, 54,\n        55, 56, 57, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255\n    ]\n    protected big58Radix:BN = new BN(58);\n    protected bigZero:BN = new BN(0);\n\n    /**\n     * Encodes a {@link https://github.com/feross/buffer|Buffer} as a base-58 string\n     * \n     * @param buff A {@link https://github.com/feross/buffer|Buffer} to encode\n     * \n     * @returns A base-58 string.\n     */\n    encode = (buff:Buffer):string => {\n        let x:BN = new BN(buff.toString(\"hex\"), \"hex\", \"be\");\n        let answer:string = \"\";// = Buffer.alloc(buff.length*136/100, 0);\n        while(x.cmp(this.bigZero) > 0){\n            let mod:BN = x.mod(this.big58Radix);\n            x = x.div(this.big58Radix);\n            answer += this.b58alphabet[mod.toNumber()];\n        }\n\n        for(let i:number = 0; i < buff.length; i++){\n            if(buff.readUInt8(i) != 0){\n                break;\n            }\n            answer += this.alphabetIdx0;\n        }\n        return answer.split(\"\").reverse().join(\"\");\n    }\n\n    /**\n     * Dencodes a base-58 into a {@link https://github.com/feross/buffer|Buffer}\n     * \n     * @param b A base-58 string to decode\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} from the decoded string.\n     */\n    decode = (b:string):Buffer => {\n        let answer:BN = new BN(0);\n        let j:BN = new BN(1);\n\n        for(let i:number = b.length - 1; i >= 0; i--){\n            let tmp:number = this.b58[b.charCodeAt(i)];\n            if(tmp == 255) {\n                throw new Error(`Error - Base58.decode: not a valid base58 string`);\n            }\n            let scratch:BN = new BN(tmp);\n            scratch.imul(j);\n            answer.iadd(scratch);\n            j.imul(this.big58Radix);\n        }\n\n        let anshex = answer.toString(\"hex\");\n        anshex = anshex.length % 2 ? \"0\" + anshex : anshex; \n\n        let tmpval:Buffer = Buffer.from(anshex, \"hex\");\n        let numZeros:number;\n        for(numZeros = 0; numZeros < b.length; numZeros++){\n            if(b[numZeros] != this.alphabetIdx0){\n                break;\n            }\n        }\n        let xlen:number = numZeros + tmpval.length;\n        let result:Buffer = Buffer.alloc(xlen, 0);\n        tmpval.copy(result, numZeros);\n\n        return result;\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bintools.js","sourceRoot":"","sources":["../../../src/utils/bintools.ts"],"names":[],"mappings":"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GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;YACtC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;SACzC,CAAA;QACS,eAAU,GAAM,IAAI,eAAE,CAAC,EAAE,CAAC,CAAC;QAC3B,YAAO,GAAM,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC;QAEjC;;;;;;WAMG;QACH,WAAM,GAAG,CAAC,IAAW,EAAS,EAAE;YAC5B,IAAI,CAAC,GAAM,IAAI,eAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;YACrD,IAAI,MAAM,GAAU,EAAE,CAAC,CAAA,0CAA0C;YACjE,OAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAC;gBAC1B,IAAI,GAAG,GAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACpC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC3B,MAAM,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;aAC9C;YAED,KAAI,IAAI,CAAC,GAAU,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;gBACvC,IAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,EAAC;oBACtB,MAAM;iBACT;gBACD,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC;aAC/B;YACD,OAAO,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC/C,CAAC,CAAA;QAED;;;;;;WAMG;QACH,WAAM,GAAG,CAAC,CAAQ,EAAS,EAAE;YACzB,IAAI,MAAM,GAAM,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC;YAC1B,IAAI,CAAC,GAAM,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC;YAErB,KAAI,IAAI,CAAC,GAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAC;gBACzC,IAAI,GAAG,GAAU,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC3C,IAAG,GAAG,IAAI,GAAG,EAAE;oBACX,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;iBACvE;gBACD,IAAI,OAAO,GAAM,IAAI,eAAE,CAAC,GAAG,CAAC,CAAC;gBAC7B,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAChB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACrB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAC3B;YAED,IAAI,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACpC,MAAM,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;YAEnD,IAAI,MAAM,GAAU,eAAM,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;YAC/C,IAAI,QAAe,CAAC;YACpB,KAAI,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,CAAC,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAC;gBAC9C,IAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,YAAY,EAAC;oBAChC,MAAM;iBACT;aACJ;YACD,IAAI,IAAI,GAAU,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC;YAC3C,IAAI,MAAM,GAAU,eAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAC1C,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YAE9B,OAAO,MAAM,CAAC;QAClB,CAAC,CAAA;IACL,CAAC;CAAA;AAvGD,wBAuGC","sourcesContent":["/**\n * @module Utils\n */\nimport BN  from \"bn.js\";\nimport {Buffer} from \"buffer/\";\nimport createHash from \"create-hash\";\n\n/**\n * A class containing tools useful in interacting with binary data cross-platform using nodejs & javascript.\n * \n * This class should never be instantiated directly. Instead, invoke the \"BinTools.getInstance()\" static\n * function to grab the singleton instance of the tools.\n * \n * Everything in this library uses the {@link https://github.com/feross/buffer|feross's Buffer class}.\n * \n * ```js\n * const bintools = BinTools.getInstance();\n * let b58str = bintools.bufferToB58(Buffer.from(\"Wubalubadubdub!\"));\n * ```\n */\nexport default class BinTools {\n    private static  instance:BinTools;\n    private constructor() {\n        this.b58 = new Base58();\n    }\n    private b58:Base58;\n    \n  \n    /**\n     * Retrieves the BinTools singleton. \n     */\n    static getInstance(): BinTools {\n        if (!BinTools.instance) {\n            BinTools.instance = new BinTools();\n        }\n        return BinTools.instance;\n    }\n\n    /**\n     * Produces a string from a {@link https://github.com/feross/buffer|Buffer} representing a string. \n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a string\n     */\n    bufferToString = (buff:Buffer):string => {\n        return this.copyFrom(buff, 2).toString(\"utf8\");\n    }\n\n    /**\n     * Produces a {@link https://github.com/feross/buffer|Buffer} from a string. \n     * \n     * @param str The string to convert to a {@link https://github.com/feross/buffer|Buffer} \n     */\n    stringToBuffer = (str:string):Buffer => {\n        let buff:Buffer = Buffer.alloc(2 + str.length);\n        buff.writeUInt16BE(str.length, 0);\n        buff.write(str, 2, str.length, \"utf8\");\n        return buff;\n    }\n\n    /**\n     * Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer} over provided indecies. \n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to copy\n     * @param start The index to start the copy\n     * @param end The index to end the copy\n     */\n    copyFrom = (buff:Buffer, start:number = 0, end:number = undefined):Buffer => {\n        let theEnd = end;\n        if(end === undefined){\n            theEnd = buff.length;\n        }\n        return Buffer.from(Uint8Array.prototype.slice.call(buff.slice(start,theEnd)))\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string of the {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to base-58\n     */\n    bufferToB58 = (buff:Buffer):string => {\n        return this.b58.encode(buff);\n    }\n\n    /**\n     * Takes a base-58 string and returns a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param b58str The base-58 string to convert to a {@link https://github.com/feross/buffer|Buffer}\n     */\n    b58ToBuffer = (b58str:string):Buffer => {\n        return this.b58.decode(b58str);\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and returns an ArrayBuffer.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to an ArrayBuffer\n     */\n    fromBufferToArrayBuffer = (buff:Buffer):ArrayBuffer => {\n        let ab = new ArrayBuffer(buff.length);\n        let view = new Uint8Array(ab);\n        for (let i = 0; i < buff.length; ++i) {\n            view[i] = buff[i];\n        }\n        return view;\n    }\n\n    /**\n     * Takes an ArrayBuffer and converts it to a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param ab The ArrayBuffer to convert to a {@link https://github.com/feross/buffer|Buffer} \n     */\n    fromArrayBufferToBuffer = (ab:ArrayBuffer):Buffer => {\n        let buf = Buffer.alloc(ab.byteLength);\n        for (let i = 0; i < ab.byteLength; ++i) {\n            buf[i] = ab[i];\n        }\n        return buf;\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and converts it to a {@link https://github.com/indutny/bn.js/|BN}.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a {@link https://github.com/indutny/bn.js/|BN}\n     */\n    fromBufferToBN = (buff:Buffer):BN => {\n        return new BN(buff.toString(\"hex\"), 16, \"be\");\n    }\n\n    /**\n     * Takes a {@link https://github.com/indutny/bn.js/|BN} and converts it to a {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @param bn The {@link https://github.com/indutny/bn.js/|BN} to convert to a {@link https://github.com/feross/buffer|Buffer}\n     * @param length The zero-padded length of the {@link https://github.com/feross/buffer|Buffer}\n     */\n    fromBNToBuffer = (bn:BN, length?:number):Buffer => {\n        let newarr = bn.toArray(\"be\");\n        if(length){ //bn toArray with the length parameter doesn't work correctly, need this.\n            let x = length - newarr.length;\n            for(let i:number = 0; i < x; i++){  \n                newarr.unshift(0);\n            }\n        }\n        return Buffer.from(newarr);\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and adds a checksum, returning a {@link https://github.com/feross/buffer|Buffer} with the 4-byte checksum appended.\n     * \n     * @param buff The {@link https://github.com/feross/buffer|Buffer} to append a checksum\n     */\n    addChecksum = (buff:Buffer):Buffer => {\n        let hashslice:Buffer = Buffer.from(createHash('sha256').update(buff).digest().slice(28));\n        return Buffer.concat([buff, hashslice]);\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} with an appended 4-byte checksum and returns true if the checksum is valid, otherwise false.\n     * \n     * @param b The {@link https://github.com/feross/buffer|Buffer} to validate the checksum\n     */\n    validateChecksum = (buff:Buffer):boolean => {\n        let checkslice:Buffer = buff.slice(buff.length - 4);\n        let hashslice:Buffer = Buffer.from(createHash('sha256').update(buff.slice(0, buff.length - 4)).digest().slice(28));\n        return checkslice.toString(\"hex\") == hashslice.toString(\"hex\");\n    }\n\n    /**\n     * Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string with checksum as per the AVA standard.\n     * \n     * @param bytes A {@link https://github.com/feross/buffer|Buffer} to serialize\n     * \n     * @returns A serialized base-58 strig of the Buffer.\n     */\n    avaSerialize = (bytes:Buffer):string => {\n        bytes = this.addChecksum(bytes);\n        return this.bufferToB58(bytes);\n    }\n\n    /**\n     * Takes an AVA serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string and returns a {@link https://github.com/feross/buffer|Buffer} of the original data. Throws on error.\n     * \n     * @param bytes An AVA serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string\n     */\n    avaDeserialize = (bytes:Buffer | string):Buffer => {\n        if(typeof bytes === 'string'){\n            bytes = this.b58ToBuffer(bytes);\n        }\n        if(this.validateChecksum(bytes)){\n            return this.copyFrom(bytes, 0,bytes.length - 4);\n        }\n        throw new Error(\"Error - BinTools.avaDeserialize: invalid checksum\");\n    }\n\n    addressToString = (chainid:string, bytes:Buffer):string => {\n        return chainid + \"-\" + this.avaSerialize(bytes);\n    }\n\n    stringToAddress = (address:string):Buffer => {\n        let parts:Array<string> = address.split(\"-\");\n        return this.avaDeserialize(parts[1]);\n    }\n\n    /**\n     * Takes an address and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid. \n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid.\n     */\n    parseAddress = (addr:string, blockchainID:string, alias:string = undefined, addrlen:number = 20):Buffer => {\n        let abc:Array<string> = addr.split(\"-\");\n        if(abc.length == 2){\n            if((alias && abc[0] == alias) || (blockchainID && abc[0] == blockchainID)) {\n                let addrbuff = this.avaDeserialize(abc[1]);\n                if((addrlen && addrbuff.length == addrlen) || !(addrlen)){\n                    return addrbuff;\n                }\n            }\n        }\n        return undefined;\n    }\n\n}\n\n/**\n * A Base58 class that uses the cross-platform Buffer module. Built so that Typescript will accept the code.\n * \n * ```js\n * let b58:Base58 = new Base58();\n * let str:string = b58.encode(somebuffer);\n * let buff:Buffer = b58.decode(somestring);\n * ```\n */\nexport class Base58 {\n    protected b58alphabet:string = \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\";\n    protected alphabetIdx0 = '1'\n    protected b58 = [\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 0, 1, 2, 3, 4, 5, 6,\n        7, 8, 255, 255, 255, 255, 255, 255,\n        255, 9, 10, 11, 12, 13, 14, 15,\n        16, 255, 17, 18, 19, 20, 21, 255,\n        22, 23, 24, 25, 26, 27, 28, 29,\n        30, 31, 32, 255, 255, 255, 255, 255,\n        255, 33, 34, 35, 36, 37, 38, 39,\n        40, 41, 42, 43, 255, 44, 45, 46,\n        47, 48, 49, 50, 51, 52, 53, 54,\n        55, 56, 57, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255,\n        255, 255, 255, 255, 255, 255, 255, 255\n    ]\n    protected big58Radix:BN = new BN(58);\n    protected bigZero:BN = new BN(0);\n\n    /**\n     * Encodes a {@link https://github.com/feross/buffer|Buffer} as a base-58 string\n     * \n     * @param buff A {@link https://github.com/feross/buffer|Buffer} to encode\n     * \n     * @returns A base-58 string.\n     */\n    encode = (buff:Buffer):string => {\n        let x:BN = new BN(buff.toString(\"hex\"), \"hex\", \"be\");\n        let answer:string = \"\";// = Buffer.alloc(buff.length*136/100, 0);\n        while(x.cmp(this.bigZero) > 0){\n            let mod:BN = x.mod(this.big58Radix);\n            x = x.div(this.big58Radix);\n            answer += this.b58alphabet[mod.toNumber()];\n        }\n\n        for(let i:number = 0; i < buff.length; i++){\n            if(buff.readUInt8(i) != 0){\n                break;\n            }\n            answer += this.alphabetIdx0;\n        }\n        return answer.split(\"\").reverse().join(\"\");\n    }\n\n    /**\n     * Dencodes a base-58 into a {@link https://github.com/feross/buffer|Buffer}\n     * \n     * @param b A base-58 string to decode\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} from the decoded string.\n     */\n    decode = (b:string):Buffer => {\n        let answer:BN = new BN(0);\n        let j:BN = new BN(1);\n\n        for(let i:number = b.length - 1; i >= 0; i--){\n            let tmp:number = this.b58[b.charCodeAt(i)];\n            if(tmp == 255) {\n                throw new Error(`Error - Base58.decode: not a valid base58 string`);\n            }\n            let scratch:BN = new BN(tmp);\n            scratch.imul(j);\n            answer.iadd(scratch);\n            j.imul(this.big58Radix);\n        }\n\n        let anshex = answer.toString(\"hex\");\n        anshex = anshex.length % 2 ? \"0\" + anshex : anshex; \n\n        let tmpval:Buffer = Buffer.from(anshex, \"hex\");\n        let numZeros:number;\n        for(numZeros = 0; numZeros < b.length; numZeros++){\n            if(b[numZeros] != this.alphabetIdx0){\n                break;\n            }\n        }\n        let xlen:number = numZeros + tmpval.length;\n        let result:Buffer = Buffer.alloc(xlen, 0);\n        tmpval.copy(result, numZeros);\n\n        return result;\n    }\n}"]} |
@@ -70,2 +70,3 @@ /// <reference types="node" /> | ||
protected privk: Buffer; | ||
protected chainid: string; | ||
/** | ||
@@ -139,6 +140,24 @@ * Generates a new keypair. | ||
* | ||
* @returns A {@link https://github.com/feross/buffer|Buffer} representation of the address | ||
*/ | ||
getAddress: () => Buffer; | ||
/** | ||
* Returns the address's string representation. | ||
* | ||
* @returns A string representation of the address | ||
*/ | ||
getAddress: () => string; | ||
constructor(); | ||
getAddressString: () => string; | ||
/** | ||
* Returns the chainID associated with this key. | ||
* | ||
* @returns The [[KeyPair]]'s chainID | ||
*/ | ||
getChainID: () => string; | ||
/** | ||
* Sets the the chainID associated with this key. | ||
* | ||
* @param chainid String for the chainID | ||
*/ | ||
setChainID: (chainid: string) => void; | ||
constructor(chainid: string); | ||
} | ||
@@ -149,3 +168,3 @@ /** | ||
* | ||
* @typeparam KPClass Class extending [[KeyPair]] which is used as the key in [[KeyChain]] | ||
* @typeparam KPClass extending [[KeyPair]] which is used as the key in [[KeyChain]] | ||
*/ | ||
@@ -156,38 +175,45 @@ export declare class KeyChain<KPClass extends KeyPair> { | ||
}; | ||
protected chainid: string; | ||
/** | ||
* Makes a new key pair, returns the address. | ||
* Makes a new [[KeyPair]], returns the address. | ||
* | ||
* @param entropy Optional parameter that may be necessary to produce secure keys | ||
* | ||
* @returns Address of the new key pair | ||
* @returns Address of the new [[KeyPair]] | ||
*/ | ||
makeKey: (entropy?: Buffer) => string; | ||
makeKey: (entropy?: Buffer) => Buffer; | ||
/** | ||
* Given a private key, makes a new key pair, returns the address. | ||
* Given a private key, makes a new [[KeyPair]], returns the address. | ||
* | ||
* @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key | ||
* | ||
* @returns Address of the new key pair | ||
* @returns Address of the new [[KeyPair]] | ||
*/ | ||
importKey: (privk: Buffer) => string; | ||
importKey: (privk: Buffer) => Buffer; | ||
/** | ||
* Gets an array of addresses stored in the key chain. | ||
* Gets an array of addresses stored in the [[KeyChain]]. | ||
* | ||
* @returns An array of {@link https://github.com/feross/buffer|Buffer} representations of the addresses | ||
*/ | ||
getAddresses: () => Buffer[]; | ||
/** | ||
* Gets an array of addresses stored in the [[KeyChain]]. | ||
* | ||
* @returns An array of string representations of the addresses | ||
*/ | ||
getAddresses: () => string[]; | ||
getAddressStrings: () => string[]; | ||
/** | ||
* Adds the key pair to the list of the keys managed in the keychain. | ||
* Adds the key pair to the list of the keys managed in the [[KeyChain]]. | ||
* | ||
* @param newKey A key pair of the appropriate class to be added to the keychain | ||
* @param newKey A key pair of the appropriate class to be added to the [[KeyChain]] | ||
*/ | ||
addKey: (newKey: KPClass) => void; | ||
/** | ||
* Removes the key pair from the list of they keys managed in the keychain. | ||
* Removes the key pair from the list of they keys managed in the [[KeyChain]]. | ||
* | ||
* @param key A string for the address or KPClass to remove | ||
* @param key A {@link https://github.com/feross/buffer|Buffer} for the address or KPClass to remove | ||
* | ||
* @returns The boolean true if a key was removed. | ||
*/ | ||
removeKey: (key: string | KPClass) => boolean; | ||
removeKey: (key: Buffer | KPClass) => boolean; | ||
/** | ||
@@ -200,15 +226,27 @@ * Checks if there is a key associated with the provided address. | ||
*/ | ||
hasKey: (address: string) => boolean; | ||
hasKey: (address: Buffer) => boolean; | ||
/** | ||
* Returns the key pair listed under the provided address | ||
* Returns the [[KeyPair]] listed under the provided address | ||
* | ||
* @param address The address to retrieve from the keys database | ||
* @param address The {@link https://github.com/feross/buffer|Buffer} of the address to retrieve from the keys database | ||
* | ||
* @returns A reference to the key pair in the keys database | ||
* @returns A reference to the [[KeyPair]] in the keys database | ||
*/ | ||
getKey: (address: string) => KPClass; | ||
getKey: (address: Buffer) => KPClass; | ||
/** | ||
* Returns instance of KeyChain. | ||
* Returns the chainID associated with this [[KeyChain]]. | ||
* | ||
* @returns The [[KeyChain]]'s chainID | ||
*/ | ||
constructor(); | ||
getChainID: () => string; | ||
/** | ||
* Sets the the chainID associated with this [[KeyChain]] and all associated keypairs. | ||
* | ||
* @param chainid String for the chainID | ||
*/ | ||
setChainID: (chainid: string) => void; | ||
/** | ||
* Returns instance of [[KeyChain]]. | ||
*/ | ||
constructor(chainid: string); | ||
} | ||
@@ -234,3 +272,3 @@ /** | ||
*/ | ||
fromString: (b58str: string) => number; | ||
fromString(b58str: string): number; | ||
/** | ||
@@ -241,3 +279,3 @@ * Takes a [[Buffer]], verifies its length, and stores it. | ||
*/ | ||
fromBuffer: (buff: Buffer) => number; | ||
fromBuffer(buff: Buffer): number; | ||
/** | ||
@@ -248,3 +286,3 @@ * Returns the stored {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
toBuffer: () => Buffer; | ||
toBuffer(): Buffer; | ||
/** | ||
@@ -255,3 +293,3 @@ * Returns a base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}. | ||
*/ | ||
toString: () => string; | ||
toString(): string; | ||
/** | ||
@@ -262,2 +300,40 @@ * Returns instance of [[NBytes]]. | ||
} | ||
export declare class Defaults { | ||
static network: { | ||
1: {}; | ||
2: { | ||
"avm": object; | ||
"X": object; | ||
"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7": object; | ||
"platform": object; | ||
"P": object; | ||
"BCID1": object; | ||
"contracts": object; | ||
"C": object; | ||
"BCID2": object; | ||
}; | ||
49: { | ||
"avm": object; | ||
"X": object; | ||
"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7": object; | ||
"platform": object; | ||
"P": object; | ||
"BCID1": object; | ||
"contracts": object; | ||
"C": object; | ||
"BCID2": object; | ||
}; | ||
12345: { | ||
"avm": object; | ||
"X": object; | ||
"GJABrZ9A6UQFpwjPU8MDxDd8vuyRoDVeDAXc694wJ5t3zEkhU": object; | ||
"platform": object; | ||
"P": object; | ||
"BCID1": object; | ||
"contracts": object; | ||
"C": object; | ||
"BCID2": object; | ||
}; | ||
}; | ||
} | ||
//# sourceMappingURL=types.d.ts.map |
@@ -133,3 +133,4 @@ "use strict"; | ||
class KeyPair { | ||
constructor() { | ||
constructor(chainid) { | ||
this.chainid = ""; | ||
/** | ||
@@ -151,2 +152,19 @@ * Returns a reference to the private key. | ||
}; | ||
/** | ||
* Returns the chainID associated with this key. | ||
* | ||
* @returns The [[KeyPair]]'s chainID | ||
*/ | ||
this.getChainID = () => { | ||
return this.chainid; | ||
}; | ||
/** | ||
* Sets the the chainID associated with this key. | ||
* | ||
* @param chainid String for the chainID | ||
*/ | ||
this.setChainID = (chainid) => { | ||
this.chainid = chainid; | ||
}; | ||
this.chainid = chainid; | ||
} | ||
@@ -159,30 +177,40 @@ } | ||
* | ||
* @typeparam KPClass Class extending [[KeyPair]] which is used as the key in [[KeyChain]] | ||
* @typeparam KPClass extending [[KeyPair]] which is used as the key in [[KeyChain]] | ||
*/ | ||
class KeyChain { | ||
/** | ||
* Returns instance of KeyChain. | ||
* Returns instance of [[KeyChain]]. | ||
*/ | ||
constructor() { | ||
constructor(chainid) { | ||
this.keys = {}; | ||
this.chainid = ""; | ||
/** | ||
* Gets an array of addresses stored in the key chain. | ||
* Gets an array of addresses stored in the [[KeyChain]]. | ||
* | ||
* @returns An array of string representations of the addresses | ||
* @returns An array of {@link https://github.com/feross/buffer|Buffer} representations of the addresses | ||
*/ | ||
this.getAddresses = () => { | ||
return Object.keys(this.keys); | ||
return Object.values(this.keys).map(kp => kp.getAddress()); | ||
}; | ||
/** | ||
* Adds the key pair to the list of the keys managed in the keychain. | ||
* Gets an array of addresses stored in the [[KeyChain]]. | ||
* | ||
* @param newKey A key pair of the appropriate class to be added to the keychain | ||
* @returns An array of string representations of the addresses | ||
*/ | ||
this.getAddressStrings = () => { | ||
return Object.values(this.keys).map(kp => kp.getAddressString()); | ||
}; | ||
/** | ||
* Adds the key pair to the list of the keys managed in the [[KeyChain]]. | ||
* | ||
* @param newKey A key pair of the appropriate class to be added to the [[KeyChain]] | ||
*/ | ||
this.addKey = (newKey) => { | ||
this.keys[newKey.getAddress()] = newKey; | ||
newKey.setChainID(this.chainid); | ||
this.keys[newKey.getAddress().toString("hex")] = newKey; | ||
}; | ||
/** | ||
* Removes the key pair from the list of they keys managed in the keychain. | ||
* Removes the key pair from the list of they keys managed in the [[KeyChain]]. | ||
* | ||
* @param key A string for the address or KPClass to remove | ||
* @param key A {@link https://github.com/feross/buffer|Buffer} for the address or KPClass to remove | ||
* | ||
@@ -193,7 +221,7 @@ * @returns The boolean true if a key was removed. | ||
let kaddr; | ||
if (typeof key !== "string") { | ||
kaddr = key.getAddress(); | ||
if (key instanceof buffer_1.Buffer) { | ||
kaddr = key.toString("hex"); | ||
} | ||
else { | ||
kaddr = key; | ||
kaddr = key.getAddress().toString("hex"); | ||
} | ||
@@ -216,14 +244,34 @@ if (kaddr in this.keys) { | ||
this.hasKey = (address) => { | ||
return (address in this.keys); | ||
return (address.toString("hex") in this.keys); | ||
}; | ||
/** | ||
* Returns the key pair listed under the provided address | ||
* Returns the [[KeyPair]] listed under the provided address | ||
* | ||
* @param address The address to retrieve from the keys database | ||
* @param address The {@link https://github.com/feross/buffer|Buffer} of the address to retrieve from the keys database | ||
* | ||
* @returns A reference to the key pair in the keys database | ||
* @returns A reference to the [[KeyPair]] in the keys database | ||
*/ | ||
this.getKey = (address) => { | ||
return this.keys[address]; | ||
return this.keys[address.toString("hex")]; | ||
}; | ||
/** | ||
* Returns the chainID associated with this [[KeyChain]]. | ||
* | ||
* @returns The [[KeyChain]]'s chainID | ||
*/ | ||
this.getChainID = () => { | ||
return this.chainid; | ||
}; | ||
/** | ||
* Sets the the chainID associated with this [[KeyChain]] and all associated keypairs. | ||
* | ||
* @param chainid String for the chainID | ||
*/ | ||
this.setChainID = (chainid) => { | ||
this.chainid = chainid; | ||
for (let address in this.keys) { | ||
this.keys[address].setChainID(chainid); | ||
} | ||
}; | ||
this.chainid = chainid; | ||
} | ||
@@ -250,59 +298,113 @@ } | ||
}; | ||
/** | ||
* Takes a base-58 encoded string, verifies its length, and stores it. | ||
* | ||
* @returns The size of the {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
this.fromString = (b58str) => { | ||
try { | ||
this.fromBuffer(bintools.b58ToBuffer(b58str)); | ||
} | ||
catch (e) { | ||
} | ||
/** | ||
* Takes a base-58 encoded string, verifies its length, and stores it. | ||
* | ||
* @returns The size of the {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
fromString(b58str) { | ||
try { | ||
this.fromBuffer(bintools.b58ToBuffer(b58str)); | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - NBytes.fromString: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
return this.bsize; | ||
} | ||
/** | ||
* Takes a [[Buffer]], verifies its length, and stores it. | ||
* | ||
* @returns The size of the {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
fromBuffer(buff) { | ||
try { | ||
if (buff.length != this.bsize) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - NBytes.fromString: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
throw new Error("Buffer length must be exactly " + this.bsize + " bytes."); | ||
} | ||
return this.bsize; | ||
}; | ||
/** | ||
* Takes a [[Buffer]], verifies its length, and stores it. | ||
* | ||
* @returns The size of the {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
this.fromBuffer = (buff) => { | ||
try { | ||
if (buff.length != this.bsize) { | ||
/* istanbul ignore next */ | ||
throw new Error("Buffer length must be exactly " + this.bsize + " bytes."); | ||
} | ||
this.bytes = buffer_1.Buffer.from(buff); | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - NBytes.fromBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
return this.bsize; | ||
}; | ||
/** | ||
* Returns the stored {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A reference to the stored {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
this.toBuffer = () => { | ||
return this.bytes; | ||
}; | ||
/** | ||
* Returns a base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A base-58 string of the stored {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
this.toString = () => { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
}; | ||
this.bytes = buffer_1.Buffer.from(buff); | ||
} | ||
catch (e) { | ||
/* istanbul ignore next */ | ||
let emsg = "Error - NBytes.fromBuffer: " + e; | ||
/* istanbul ignore next */ | ||
throw new Error(emsg); | ||
} | ||
return this.bsize; | ||
} | ||
/** | ||
* Returns the stored {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A reference to the stored {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
toBuffer() { | ||
return this.bytes; | ||
} | ||
/** | ||
* Returns a base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}. | ||
* | ||
* @returns A base-58 string of the stored {@link https://github.com/feross/buffer|Buffer} | ||
*/ | ||
toString() { | ||
return bintools.bufferToB58(this.toBuffer()); | ||
} | ||
} | ||
exports.NBytes = NBytes; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/utils/types.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module Utils\n */\nimport SlopesCore from '../slopes';\nimport { Buffer } from \"buffer/\";\nimport DB from \"./db\";\nimport { StoreAPI } from 'store2';\nimport BinTools  from './bintools';\nimport { ClientRequest } from \"http\";\nimport { AxiosRequestConfig } from 'axios';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n/**\n * Response data for HTTP requests.\n */\nexport class RequestResponseData {\n    data: string | object | Array<object>;\n    headers:object;\n    status: number;\n    statusText: string;\n    request:ClientRequest | XMLHttpRequest;\n}\n\n/**\n * Abstract class defining a generic endpoint that all endpoints must implement (extend).\n */\nexport abstract class APIBase {\n    protected core:SlopesCore;\n    protected baseurl:string;\n    protected db:StoreAPI;\n\n    /**\n     * Sets the path of the APIs baseurl.\n     * \n     * @param baseurl Path of the APIs baseurl - ex: \"/ext/ava\"\n     */\n    setBaseURL = (baseurl:string) => {\n        if(this.db && this.baseurl !== baseurl){\n            let backup = this.db.getAll();\n            this.db.clearAll();\n            this.baseurl = baseurl;\n            this.db = DB.getNamespace(baseurl);\n            this.db.setAll(backup, true);\n        } else {\n            this.baseurl = baseurl;\n            this.db = DB.getNamespace(baseurl);\n        }\n    } \n\n    /**\n     * Returns the baseurl's path. \n     */\n    getBaseURL = () : string => {\n        return this.baseurl;\n    }\n\n    /**\n     * Returns the baseurl's database.\n     */\n    getDB = ():StoreAPI => {\n        return this.db;\n    }\n\n    /**\n     * \n     * @param core Reference to the Slopes instance using this baseurl\n     * @param baseurl Path to the baseurl - ex: \"/ext/subnet/avm\"\n     */\n    constructor(core:SlopesCore, baseurl:string) {\n        this.core = core;\n        this.setBaseURL(baseurl);\n    }\n}\n\nexport class JRPCAPI extends APIBase {\n    protected jrpcVersion:string = \"2.0\";\n    protected rpcid = 1;\n    callMethod = async (method:string, params?:Array<object> | object, baseurl?:string):Promise<RequestResponseData> => {\n        let ep = baseurl ? baseurl : this.baseurl;\n        let rpc:object = {};\n        rpc[\"id\"] = this.rpcid;\n        rpc[\"method\"] = method;\n\n        // Set parameters if exists\n        if(params){\n            rpc['params'] = params;\n        } else if(this.jrpcVersion == \"1.0\"){\n            rpc[\"params\"] = [];\n        }\n\n        if(this.jrpcVersion != \"1.0\") {\n            rpc[\"jsonrpc\"] = this.jrpcVersion;\n        }\n\n        let headers:object = {\"Content-Type\": \"application/json;charset=UTF-8\"};\n\n        let axConf:AxiosRequestConfig = {\n            baseURL:this.core.getProtocol()+\"://\"+this.core.getIP()+\":\"+this.core.getPort(),\n            responseType: 'json'\n        };\n\n        return this.core.post(ep, {}, JSON.stringify(rpc), headers, axConf).then( (resp:RequestResponseData) => {\n            if(resp.status >= 200 && resp.status < 300){\n                this.rpcid += 1;\n                if(typeof resp.data === \"string\"){\n                    resp.data = JSON.parse(resp.data);\n                    \n                }\n                if(typeof resp.data === 'object' && 'error' in resp.data) {\n                    throw new Error(\"Error returned: \" + JSON.stringify(resp.data));\n                }\n                return resp;\n            }\n        });\n    }   \n\n    /**\n     * Returns the rpcid, a strictly-increasing number, starting from 1, indicating the next request ID that will be sent.\n     */\n    getRPCID = ():number => {\n        return this.rpcid;\n    }\n\n    /**\n     * \n     * @param core Reference to the Slopes instance using this endpoint\n     * @param baseurl Path of the APIs baseurl - ex: \"/ext/subnet/avm\"\n     * @param jrpcVersion The jrpc version to use, default \"2.0\".\n     */\n    constructor(core:SlopesCore, baseurl:string, jrpcVersion:string = \"2.0\") {\n        super(core, baseurl);\n        this.jrpcVersion = jrpcVersion;\n        this.rpcid = 1;\n    }\n}\n\n/**\n * Class for representing a private and public keypair in Slopes. \n * All APIs that need key pairs should extend on this class.\n */\nexport class KeyPair {\n    protected pubk:Buffer;\n    protected privk:Buffer;\n\n    /**\n     * Generates a new keypair.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     */\n    generateKey:(entropy?:Buffer) => void;\n    /**\n     * Imports a private key and generates the appropriate public key.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key \n     * \n     * @returns true on success, false on failure\n     */\n    importKey:(privk:Buffer) => boolean;\n\n    /**\n     * Takes a message, signs it, and returns the signature.\n     * \n     * @param msg The message to sign\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the signature\n     */\n    sign:(msg:Buffer) => Buffer;\n\n    /**\n     * Recovers the public key of a message signer from a message and its associated signature.\n     * \n     * @param msg The message that's signed\n     * @param sig The signature that's signed on the message\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the public key of the signer\n     */\n    recover:(msg:Buffer, sig:Buffer) => Buffer;\n\n    /**\n     * Verifies that the private key associated with the provided public key produces the signature associated with the given message.\n     * \n     * @param msg The message associated with the signature\n     * @param sig The signature of the signed message\n     * @param pubk The public key associated with the message signature\n     * \n     * @returns True on success, false on failure\n     */\n    verify:(msg:Buffer, sig:Buffer, pubk:Buffer) => boolean;\n\n    /**\n     * Returns a reference to the private key.\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the private key\n     */\n    getPrivateKey = ():Buffer => {\n        return this.privk;\n    }\n\n    /**\n     * Returns a reference to the public key.\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the public key\n     */\n    getPublicKey = ():Buffer => {\n        return this.pubk;\n    }\n\n    /**\n     * Returns a string representation of the private key.\n     * \n     * @returns A string representation of the public key\n     */\n    getPrivateKeyString:() => string;\n\n    /**\n     * Returns the public key.\n     * \n     * @returns A string representation of the public key\n     */\n    getPublicKeyString:() => string;\n\n    /**\n     * Returns the address.\n     * \n     * @returns A string representation of the address\n     */\n    getAddress:() => string;\n\n    constructor() {}\n}\n\n/**\n * Class for representing a key chain in Slopes. \n * All endpoints that need key chains should extend on this class.\n * \n * @typeparam KPClass Class extending [[KeyPair]] which is used as the key in [[KeyChain]]\n */\nexport class KeyChain<KPClass extends KeyPair> {\n    protected keys:{[address: string]: KPClass} = {};\n\n    /**\n     * Makes a new key pair, returns the address.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     * \n     * @returns Address of the new key pair\n     */\n    makeKey:(entropy?:Buffer) => string;\n\n    /**\n     * Given a private key, makes a new key pair, returns the address.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key \n     * \n     * @returns Address of the new key pair\n     */\n    importKey:(privk:Buffer) => string;\n\n    /**\n     * Gets an array of addresses stored in the key chain.\n     * \n     * @returns An array of string representations of the addresses\n     */\n    getAddresses = ():Array<string> => {\n        return Object.keys(this.keys);\n    }\n\n    /**\n     * Adds the key pair to the list of the keys managed in the keychain.\n     * \n     * @param newKey A key pair of the appropriate class to be added to the keychain\n     */\n    addKey = (newKey:KPClass) => {\n        this.keys[newKey.getAddress()] = newKey;\n    }\n\n    /**\n     * Removes the key pair from the list of they keys managed in the keychain.\n     * \n     * @param key A string for the address or KPClass to remove\n     * \n     * @returns The boolean true if a key was removed.\n     */\n    removeKey = (key:KPClass | string) => {\n        let kaddr:string;\n        if(typeof key !== \"string\"){\n            kaddr = key.getAddress();\n        } else {\n            kaddr = key;\n        }\n        if(kaddr in this.keys){\n            delete this.keys[kaddr];\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    /**\n     * Checks if there is a key associated with the provided address.\n     * \n     * @param address The address to check for existence in the keys database\n     * \n     * @returns True on success, false if not found\n     */\n    hasKey = (address:string):boolean => {\n        return (address in this.keys);\n    }\n\n    /**\n     * Returns the key pair listed under the provided address\n     * \n     * @param address The address to retrieve from the keys database\n     * \n     * @returns A reference to the key pair in the keys database\n     */\n    getKey = (address:string): KPClass => {\n        return this.keys[address];\n    }\n    /**\n     * Returns instance of KeyChain.\n     */\n    constructor() {}\n}\n\n/**\n * Abstract class that implements basic functionality for managing a {@link https://github.com/feross/buffer|Buffer} of an exact length.\n * \n * Create a class that extends this one and override bsize to make it validate for exactly the correct length.\n */\nexport abstract class NBytes {\n    protected bytes:Buffer;\n    protected bsize:number;\n\n    /**\n     * Returns the length of the {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns The exact length requirement of this class\n     */\n    getSize = () => {\n        return this.bsize;\n    }\n\n    /**\n     * Takes a base-58 encoded string, verifies its length, and stores it.\n     * \n     * @returns The size of the {@link https://github.com/feross/buffer|Buffer}\n     */\n    fromString = (b58str:string):number => {\n        try {\n            this.fromBuffer(bintools.b58ToBuffer(b58str));\n        } catch(e){\n            /* istanbul ignore next */\n            let emsg:string = \"Error - NBytes.fromString: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n        return this.bsize;\n    }\n\n    /**\n     * Takes a [[Buffer]], verifies its length, and stores it. \n     * \n     * @returns The size of the {@link https://github.com/feross/buffer|Buffer}\n     */\n    fromBuffer = (buff:Buffer):number => {\n        try {\n            if(buff.length != this.bsize){\n                /* istanbul ignore next */\n                throw new Error(\"Buffer length must be exactly \" + this.bsize + \" bytes.\");\n            }\n            this.bytes = Buffer.from(buff);\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - NBytes.fromBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n        return this.bsize;\n    }\n\n    /**\n     * Returns the stored {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns A reference to the stored {@link https://github.com/feross/buffer|Buffer}\n     */\n    toBuffer = ():Buffer => {\n        return this.bytes;\n    }\n\n    /**\n     * Returns a base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns A base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}\n     */\n    toString = ():string => {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n    /**\n     * Returns instance of [[NBytes]].\n     */\n    constructor() {}\n}\n"]} | ||
let n2_avm = { | ||
blockchainID: "HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7", | ||
alias: "X", | ||
vm: "avm" | ||
}; | ||
let n2_platform = { | ||
blockchainID: "", | ||
alias: "P", | ||
vm: "platform" | ||
}; | ||
let n2_contracts = { | ||
blockchainID: "", | ||
alias: "C", | ||
vm: "contracts" | ||
}; | ||
class Defaults { | ||
} | ||
exports.Defaults = Defaults; | ||
Defaults.network = { | ||
1: {}, | ||
2: { | ||
"avm": n2_avm, | ||
"X": n2_avm, | ||
"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7": n2_avm, | ||
"platform": n2_platform, | ||
"P": n2_platform, | ||
"BCID1": n2_platform, | ||
"contracts": n2_contracts, | ||
"C": n2_contracts, | ||
"BCID2": n2_contracts | ||
}, | ||
49: { | ||
"avm": n2_avm, | ||
"X": n2_avm, | ||
"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7": n2_avm, | ||
"platform": n2_platform, | ||
"P": n2_platform, | ||
"BCID1": n2_platform, | ||
"contracts": n2_contracts, | ||
"C": n2_contracts, | ||
"BCID2": n2_contracts | ||
}, | ||
12345: { | ||
"avm": n2_avm, | ||
"X": n2_avm, | ||
"GJABrZ9A6UQFpwjPU8MDxDd8vuyRoDVeDAXc694wJ5t3zEkhU": n2_avm, | ||
"platform": n2_platform, | ||
"P": n2_platform, | ||
"BCID1": n2_platform, | ||
"contracts": n2_contracts, | ||
"C": n2_contracts, | ||
"BCID2": n2_contracts | ||
} | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/utils/types.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @module Utils\n */\nimport SlopesCore from '../slopes';\nimport { Buffer } from \"buffer/\";\nimport DB from \"./db\";\nimport { StoreAPI } from 'store2';\nimport BinTools  from './bintools';\nimport { ClientRequest } from \"http\";\nimport { AxiosRequestConfig } from 'axios';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\n\n/**\n * Response data for HTTP requests.\n */\nexport class RequestResponseData {\n    data: string | object | Array<object>;\n    headers:object;\n    status: number;\n    statusText: string;\n    request:ClientRequest | XMLHttpRequest;\n}\n\n/**\n * Abstract class defining a generic endpoint that all endpoints must implement (extend).\n */\nexport abstract class APIBase {\n    protected core:SlopesCore;\n    protected baseurl:string;\n    protected db:StoreAPI;\n\n    /**\n     * Sets the path of the APIs baseurl.\n     * \n     * @param baseurl Path of the APIs baseurl - ex: \"/ext/ava\"\n     */\n    setBaseURL = (baseurl:string) => {\n        if(this.db && this.baseurl !== baseurl){\n            let backup = this.db.getAll();\n            this.db.clearAll();\n            this.baseurl = baseurl;\n            this.db = DB.getNamespace(baseurl);\n            this.db.setAll(backup, true);\n        } else {\n            this.baseurl = baseurl;\n            this.db = DB.getNamespace(baseurl);\n        }\n    } \n\n    /**\n     * Returns the baseurl's path. \n     */\n    getBaseURL = () : string => {\n        return this.baseurl;\n    }\n\n    /**\n     * Returns the baseurl's database.\n     */\n    getDB = ():StoreAPI => {\n        return this.db;\n    }\n\n    /**\n     * \n     * @param core Reference to the Slopes instance using this baseurl\n     * @param baseurl Path to the baseurl - ex: \"/ext/subnet/avm\"\n     */\n    constructor(core:SlopesCore, baseurl:string) {\n        this.core = core;\n        this.setBaseURL(baseurl);\n    }\n}\n\nexport class JRPCAPI extends APIBase {\n    protected jrpcVersion:string = \"2.0\";\n    protected rpcid = 1;\n    callMethod = async (method:string, params?:Array<object> | object, baseurl?:string):Promise<RequestResponseData> => {\n        let ep = baseurl ? baseurl : this.baseurl;\n        let rpc:object = {};\n        rpc[\"id\"] = this.rpcid;\n        rpc[\"method\"] = method;\n\n        // Set parameters if exists\n        if(params){\n            rpc['params'] = params;\n        } else if(this.jrpcVersion == \"1.0\"){\n            rpc[\"params\"] = [];\n        }\n\n        if(this.jrpcVersion != \"1.0\") {\n            rpc[\"jsonrpc\"] = this.jrpcVersion;\n        }\n\n        let headers:object = {\"Content-Type\": \"application/json;charset=UTF-8\"};\n\n        let axConf:AxiosRequestConfig = {\n            baseURL:this.core.getProtocol()+\"://\"+this.core.getIP()+\":\"+this.core.getPort(),\n            responseType: 'json'\n        };\n\n        return this.core.post(ep, {}, JSON.stringify(rpc), headers, axConf).then( (resp:RequestResponseData) => {\n            if(resp.status >= 200 && resp.status < 300){\n                this.rpcid += 1;\n                if(typeof resp.data === \"string\"){\n                    resp.data = JSON.parse(resp.data);\n                    \n                }\n                if(typeof resp.data === 'object' && 'error' in resp.data) {\n                    throw new Error(\"Error returned: \" + JSON.stringify(resp.data));\n                }\n                return resp;\n            }\n        });\n    }   \n\n    /**\n     * Returns the rpcid, a strictly-increasing number, starting from 1, indicating the next request ID that will be sent.\n     */\n    getRPCID = ():number => {\n        return this.rpcid;\n    }\n\n    /**\n     * \n     * @param core Reference to the Slopes instance using this endpoint\n     * @param baseurl Path of the APIs baseurl - ex: \"/ext/subnet/avm\"\n     * @param jrpcVersion The jrpc version to use, default \"2.0\".\n     */\n    constructor(core:SlopesCore, baseurl:string, jrpcVersion:string = \"2.0\") {\n        super(core, baseurl);\n        this.jrpcVersion = jrpcVersion;\n        this.rpcid = 1;\n    }\n}\n\n/**\n * Class for representing a private and public keypair in Slopes. \n * All APIs that need key pairs should extend on this class.\n */\nexport class KeyPair {\n    protected pubk:Buffer;\n    protected privk:Buffer;\n    protected chainid:string = \"\";\n\n    /**\n     * Generates a new keypair.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     */\n    generateKey:(entropy?:Buffer) => void;\n    /**\n     * Imports a private key and generates the appropriate public key.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key \n     * \n     * @returns true on success, false on failure\n     */\n    importKey:(privk:Buffer) => boolean;\n\n    /**\n     * Takes a message, signs it, and returns the signature.\n     * \n     * @param msg The message to sign\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the signature\n     */\n    sign:(msg:Buffer) => Buffer;\n\n    /**\n     * Recovers the public key of a message signer from a message and its associated signature.\n     * \n     * @param msg The message that's signed\n     * @param sig The signature that's signed on the message\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the public key of the signer\n     */\n    recover:(msg:Buffer, sig:Buffer) => Buffer;\n\n    /**\n     * Verifies that the private key associated with the provided public key produces the signature associated with the given message.\n     * \n     * @param msg The message associated with the signature\n     * @param sig The signature of the signed message\n     * @param pubk The public key associated with the message signature\n     * \n     * @returns True on success, false on failure\n     */\n    verify:(msg:Buffer, sig:Buffer, pubk:Buffer) => boolean;\n\n    /**\n     * Returns a reference to the private key.\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the private key\n     */\n    getPrivateKey = ():Buffer => {\n        return this.privk;\n    }\n\n    /**\n     * Returns a reference to the public key.\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer} containing the public key\n     */\n    getPublicKey = ():Buffer => {\n        return this.pubk;\n    }\n\n    /**\n     * Returns a string representation of the private key.\n     * \n     * @returns A string representation of the public key\n     */\n    getPrivateKeyString:() => string;\n\n    /**\n     * Returns the public key.\n     * \n     * @returns A string representation of the public key\n     */\n    getPublicKeyString:() => string;\n\n    /**\n     * Returns the address.\n     * \n     * @returns A {@link https://github.com/feross/buffer|Buffer}  representation of the address\n     */\n    getAddress:() => Buffer;\n\n    /**\n     * Returns the address's string representation.\n     * \n     * @returns A string representation of the address\n     */\n    getAddressString:() => string;\n\n    /**\n     * Returns the chainID associated with this key.\n     * \n     * @returns The [[KeyPair]]'s chainID\n     */\n    getChainID = ():string => {\n        return this.chainid\n    }\n\n    /**\n     * Sets the the chainID associated with this key.\n     * \n     * @param chainid String for the chainID\n     */\n    setChainID = (chainid:string):void => {\n        this.chainid = chainid;\n    }\n\n    constructor(chainid:string) {\n        this.chainid = chainid\n    }\n}\n\n/**\n * Class for representing a key chain in Slopes. \n * All endpoints that need key chains should extend on this class.\n * \n * @typeparam KPClass extending [[KeyPair]] which is used as the key in [[KeyChain]]\n */\nexport class KeyChain<KPClass extends KeyPair> {\n    protected keys:{[address: string]: KPClass} = {};\n    protected chainid:string = \"\";\n\n    /**\n     * Makes a new [[KeyPair]], returns the address.\n     * \n     * @param entropy Optional parameter that may be necessary to produce secure keys\n     * \n     * @returns Address of the new [[KeyPair]]\n     */\n    makeKey:(entropy?:Buffer) => Buffer;\n\n    /**\n     * Given a private key, makes a new [[KeyPair]], returns the address.\n     * \n     * @param privk A {@link https://github.com/feross/buffer|Buffer} representing the private key \n     * \n     * @returns Address of the new [[KeyPair]]\n     */\n    importKey:(privk:Buffer) => Buffer;\n\n    /**\n     * Gets an array of addresses stored in the [[KeyChain]].\n     * \n     * @returns An array of {@link https://github.com/feross/buffer|Buffer}  representations of the addresses\n     */\n    getAddresses = ():Array<Buffer> => {\n        return Object.values(this.keys).map(kp => kp.getAddress());\n    }\n\n    /**\n     * Gets an array of addresses stored in the [[KeyChain]].\n     * \n     * @returns An array of string representations of the addresses\n     */\n    getAddressStrings = ():Array<string> => {\n        return Object.values(this.keys).map(kp => kp.getAddressString());\n    }\n\n    /**\n     * Adds the key pair to the list of the keys managed in the [[KeyChain]].\n     * \n     * @param newKey A key pair of the appropriate class to be added to the [[KeyChain]]\n     */\n    addKey = (newKey:KPClass) => {\n        newKey.setChainID(this.chainid);\n        this.keys[newKey.getAddress().toString(\"hex\")] = newKey;\n    }\n\n    /**\n     * Removes the key pair from the list of they keys managed in the [[KeyChain]].\n     * \n     * @param key A {@link https://github.com/feross/buffer|Buffer} for the address or KPClass to remove\n     * \n     * @returns The boolean true if a key was removed.\n     */\n    removeKey = (key:KPClass | Buffer) => {\n        let kaddr:string;\n        if(key instanceof Buffer){\n            kaddr = key.toString(\"hex\");\n        } else {\n            kaddr = key.getAddress().toString(\"hex\");\n        }\n        if(kaddr in this.keys){\n            delete this.keys[kaddr];\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    /**\n     * Checks if there is a key associated with the provided address.\n     * \n     * @param address The address to check for existence in the keys database\n     * \n     * @returns True on success, false if not found\n     */\n    hasKey = (address:Buffer):boolean => {\n        return (address.toString(\"hex\") in this.keys);\n    }\n\n    /**\n     * Returns the [[KeyPair]] listed under the provided address\n     * \n     * @param address The {@link https://github.com/feross/buffer|Buffer} of the address to retrieve from the keys database\n     * \n     * @returns A reference to the [[KeyPair]] in the keys database\n     */\n    getKey = (address:Buffer): KPClass => {\n        return this.keys[address.toString(\"hex\")];\n    }\n\n    /**\n     * Returns the chainID associated with this [[KeyChain]].\n     * \n     * @returns The [[KeyChain]]'s chainID\n     */\n    getChainID = ():string => {\n        return this.chainid\n    }\n\n    /**\n     * Sets the the chainID associated with this [[KeyChain]] and all associated keypairs.\n     * \n     * @param chainid String for the chainID\n     */\n    setChainID = (chainid:string):void => {\n        this.chainid = chainid;\n        for(let address in this.keys){\n            this.keys[address].setChainID(chainid);\n        }\n    }\n\n    /**\n     * Returns instance of [[KeyChain]].\n     */\n    constructor(chainid:string) {\n        this.chainid = chainid;\n    }\n}\n\n/**\n * Abstract class that implements basic functionality for managing a {@link https://github.com/feross/buffer|Buffer} of an exact length.\n * \n * Create a class that extends this one and override bsize to make it validate for exactly the correct length.\n */\nexport abstract class NBytes {\n    protected bytes:Buffer;\n    protected bsize:number;\n\n    /**\n     * Returns the length of the {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns The exact length requirement of this class\n     */\n    getSize = () => {\n        return this.bsize;\n    }\n\n    /**\n     * Takes a base-58 encoded string, verifies its length, and stores it.\n     * \n     * @returns The size of the {@link https://github.com/feross/buffer|Buffer}\n     */\n    fromString(b58str:string):number {\n        try {\n            this.fromBuffer(bintools.b58ToBuffer(b58str));\n        } catch(e){\n            /* istanbul ignore next */\n            let emsg:string = \"Error - NBytes.fromString: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n        return this.bsize;\n    }\n\n    /**\n     * Takes a [[Buffer]], verifies its length, and stores it. \n     * \n     * @returns The size of the {@link https://github.com/feross/buffer|Buffer}\n     */\n    fromBuffer(buff:Buffer):number {\n        try {\n            if(buff.length != this.bsize){\n                /* istanbul ignore next */\n                throw new Error(\"Buffer length must be exactly \" + this.bsize + \" bytes.\");\n            }\n            this.bytes = Buffer.from(buff);\n        } catch(e) {\n            /* istanbul ignore next */\n            let emsg:string = \"Error - NBytes.fromBuffer: \" + e;\n            /* istanbul ignore next */\n            throw new Error(emsg);\n        }\n        return this.bsize;\n    }\n\n    /**\n     * Returns the stored {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns A reference to the stored {@link https://github.com/feross/buffer|Buffer}\n     */\n    toBuffer():Buffer {\n        return this.bytes;\n    }\n\n    /**\n     * Returns a base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}.\n     * \n     * @returns A base-58 string of the stored {@link https://github.com/feross/buffer|Buffer}\n     */\n    toString():string {\n        return bintools.bufferToB58(this.toBuffer());\n    }\n    /**\n     * Returns instance of [[NBytes]].\n     */\n    constructor() {}\n}\n\nlet n2_avm:object = {\n    blockchainID: \"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7\",\n    alias: \"X\",\n    vm: \"avm\"\n};\n\nlet n2_platform:object =  {\n    blockchainID: \"\",\n    alias: \"P\",\n    vm: \"platform\"\n};\n\nlet n2_contracts:object = {\n    blockchainID: \"\",\n    alias: \"C\",\n    vm: \"contracts\"\n}\n\nexport class Defaults {\n    static network = {\n        1: {}, //update before mainnet\n        2: {\n            \"avm\": n2_avm,\n            \"X\": n2_avm,\n            \"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7\": n2_avm,\n            \"platform\": n2_platform,\n            \"P\": n2_platform,\n            \"BCID1\": n2_platform,\n            \"contracts\": n2_contracts,\n            \"C\": n2_contracts,\n            \"BCID2\": n2_contracts\n        },\n        49: {\n            \"avm\": n2_avm,\n            \"X\": n2_avm,\n            \"HD8HEwNKTXRBcVUqvQW2LRu9izqej91xzGmXATF4KMMV6LLm7\": n2_avm,\n            \"platform\": n2_platform,\n            \"P\": n2_platform,\n            \"BCID1\": n2_platform,\n            \"contracts\": n2_contracts,\n            \"C\": n2_contracts,\n            \"BCID2\": n2_contracts\n        },\n        12345: {\n            \"avm\": n2_avm,\n            \"X\": n2_avm,\n            \"GJABrZ9A6UQFpwjPU8MDxDd8vuyRoDVeDAXc694wJ5t3zEkhU\": n2_avm,\n            \"platform\": n2_platform,\n            \"P\": n2_platform,\n            \"BCID1\": n2_platform,\n            \"contracts\": n2_contracts,\n            \"C\": n2_contracts,\n            \"BCID2\": n2_contracts\n        }\n    };\n}"]} |
@@ -29,4 +29,4 @@ "use strict"; | ||
set = new utxos_1.UTXOSet(); | ||
keymgr1 = new keychain_1.AVMKeyChain(); | ||
keymgr2 = new keychain_1.AVMKeyChain(); | ||
keymgr1 = new keychain_1.AVMKeyChain("X"); | ||
keymgr2 = new keychain_1.AVMKeyChain("X"); | ||
addrs1 = []; | ||
@@ -70,3 +70,3 @@ addrs2 = []; | ||
expect(input.getUTXOID()).toBe(u.getUTXOID()); | ||
expect(input.getInputID()).toBe(types_1.Constants.SECPINPUTID); | ||
expect(input.getInputID()).toBe(types_1.AVMConstants.SECPINPUTID); | ||
input.addSignatureIdx(0, addrs2[0]); | ||
@@ -91,2 +91,2 @@ input.addSignatureIdx(1, addrs2[1]); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/inputs.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos';\nimport { AVMKeyChain } from 'src/apis/avm/keychain';\nimport { Input, SecpInput } from 'src/apis/avm/inputs';\nimport createHash from 'create-hash';\nimport BinTools from 'src/utils/bintools';\nimport BN from 'bn.js';\nimport {Buffer} from \"buffer/\";\nimport { Output, SecpOutput } from 'src/apis/avm/outputs';\nimport { Constants } from 'src/apis/avm/types';\n\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\ndescribe('Inputs', () => {\n    let set:UTXOSet;\n    let keymgr1:AVMKeyChain;\n    let keymgr2:AVMKeyChain;\n    let addrs1:Array<string>;\n    let addrs2:Array<string>;\n    let utxos:Array<SecpUTXO>;\n    const amnt:number = 10000;\n    beforeEach(() => {\n        set = new UTXOSet();\n        keymgr1 = new AVMKeyChain();\n        keymgr2 = new AVMKeyChain();\n        addrs1 = [];\n        addrs2 = [];\n        utxos = [];\n        for(let i:number = 0; i < 3; i++){\n            addrs1.push(keymgr1.makeKey());\n            addrs2.push(keymgr2.makeKey());\n        }\n        let amount:BN = new BN(amnt);\n        let addresses:Array<string> = keymgr1.getAddresses();\n        let fallAddresses:Array<string> = keymgr2.getAddresses()\n        let locktime:BN = new BN(54321);\n        let fallLocktime:BN = locktime.add(new BN(50));\n        let threshold:number = 3;\n        let fallThreshold:number = 1;\n        \n        for(let i:number = 0; i < 3; i++){\n            let txid:Buffer = Buffer.from(createHash(\"sha256\").update(bintools.fromBNToBuffer(new BN(i), 32)).digest());\n            let txidx:Buffer = Buffer.from(bintools.fromBNToBuffer(new BN(i), 4));\n            let assetID:Buffer = Buffer.from(createHash(\"sha256\").update(txid).digest());\n            let out:Output;\n            out = new SecpOutput(assetID, amount, addresses, locktime, threshold);\n            let u:SecpUTXO = new SecpUTXO();\n            u.fromBuffer(Buffer.concat([txid, txidx, out.toBuffer()]));\n            utxos.push(u);\n        }\n        set.addArray(utxos);\n    });\n    test('SecpInput', () => {\n        let u:SecpUTXO;\n        let txid:Buffer;\n        let txidx:Buffer;\n        let amount:BN = new BN(amnt);\n        let input:SecpInput;\n\n        u = utxos[0];\n        txid = u.getTxID();\n        txidx = u.getTxIdx();\n        let asset = u.getAssetID();\n\n        input = new SecpInput(txid, txidx, amount, asset);\n        expect(input.getUTXOID()).toBe(u.getUTXOID());\n        expect(input.getInputID()).toBe(Constants.SECPINPUTID);\n\n        input.addSignatureIdx(0, addrs2[0]);\n        input.addSignatureIdx(1, addrs2[1]);\n\n        let newin:SecpInput = new SecpInput();\n        newin.fromBuffer(bintools.b58ToBuffer(input.toString()));\n        expect(newin.toBuffer().toString(\"hex\")).toBe(input.toBuffer().toString(\"hex\"));\n        expect(newin.getSigIdxs().toString()).toBe(input.getSigIdxs().toString());\n    });\n    test('comparitor', () => {\n        let in1:SecpInput = new SecpInput(utxos[0].getTxID(), utxos[0].getTxIdx(), utxos[0].getAmount(), utxos[0].getAssetID());\n        let in2:SecpInput = new SecpInput(utxos[1].getTxID(), utxos[1].getTxIdx(), utxos[1].getAmount(), utxos[1].getAssetID());\n        let in3:SecpInput = new SecpInput(utxos[2].getTxID(), utxos[2].getTxIdx(), utxos[2].getAmount(), utxos[2].getAssetID());\n\n        let cmp = SecpInput.comparator();\n        expect(cmp(in1, in2)).toBe(-1);\n        expect(cmp(in1, in3)).toBe(-1);\n        expect(cmp(in1, in1)).toBe(0);\n        expect(cmp(in2, in2)).toBe(0);\n        expect(cmp(in3, in3)).toBe(0);\n    });\n\n});"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/inputs.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos';\nimport { AVMKeyChain } from 'src/apis/avm/keychain';\nimport { Input, SecpInput } from 'src/apis/avm/inputs';\nimport createHash from 'create-hash';\nimport BinTools from 'src/utils/bintools';\nimport BN from 'bn.js';\nimport {Buffer} from \"buffer/\";\nimport { Output, SecpOutput } from 'src/apis/avm/outputs';\nimport { AVMConstants } from 'src/apis/avm/types';\n\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\ndescribe('Inputs', () => {\n    let set:UTXOSet;\n    let keymgr1:AVMKeyChain;\n    let keymgr2:AVMKeyChain;\n    let addrs1:Array<Buffer>;\n    let addrs2:Array<Buffer>;\n    let utxos:Array<SecpUTXO>;\n    const amnt:number = 10000;\n    beforeEach(() => {\n        set = new UTXOSet();\n        keymgr1 = new AVMKeyChain(\"X\");\n        keymgr2 = new AVMKeyChain(\"X\");\n        addrs1 = [];\n        addrs2 = [];\n        utxos = [];\n        for(let i:number = 0; i < 3; i++){\n            addrs1.push(keymgr1.makeKey());\n            addrs2.push(keymgr2.makeKey());\n        }\n        let amount:BN = new BN(amnt);\n        let addresses:Array<Buffer> = keymgr1.getAddresses();\n        let fallAddresses:Array<Buffer> = keymgr2.getAddresses()\n        let locktime:BN = new BN(54321);\n        let fallLocktime:BN = locktime.add(new BN(50));\n        let threshold:number = 3;\n        let fallThreshold:number = 1;\n        \n        for(let i:number = 0; i < 3; i++){\n            let txid:Buffer = Buffer.from(createHash(\"sha256\").update(bintools.fromBNToBuffer(new BN(i), 32)).digest());\n            let txidx:Buffer = Buffer.from(bintools.fromBNToBuffer(new BN(i), 4));\n            let assetID:Buffer = Buffer.from(createHash(\"sha256\").update(txid).digest());\n            let out:Output;\n            out = new SecpOutput(assetID, amount, addresses, locktime, threshold);\n            let u:SecpUTXO = new SecpUTXO();\n            u.fromBuffer(Buffer.concat([txid, txidx, out.toBuffer()]));\n            utxos.push(u);\n        }\n        set.addArray(utxos);\n    });\n    test('SecpInput', () => {\n        let u:SecpUTXO;\n        let txid:Buffer;\n        let txidx:Buffer;\n        let amount:BN = new BN(amnt);\n        let input:SecpInput;\n\n        u = utxos[0];\n        txid = u.getTxID();\n        txidx = u.getTxIdx();\n        let asset = u.getAssetID();\n\n        input = new SecpInput(txid, txidx, amount, asset);\n        expect(input.getUTXOID()).toBe(u.getUTXOID());\n        expect(input.getInputID()).toBe(AVMConstants.SECPINPUTID);\n\n        input.addSignatureIdx(0, addrs2[0]);\n        input.addSignatureIdx(1, addrs2[1]);\n\n        let newin:SecpInput = new SecpInput();\n        newin.fromBuffer(bintools.b58ToBuffer(input.toString()));\n        expect(newin.toBuffer().toString(\"hex\")).toBe(input.toBuffer().toString(\"hex\"));\n        expect(newin.getSigIdxs().toString()).toBe(input.getSigIdxs().toString());\n    });\n    test('comparitor', () => {\n        let in1:SecpInput = new SecpInput(utxos[0].getTxID(), utxos[0].getTxIdx(), utxos[0].getAmount(), utxos[0].getAssetID());\n        let in2:SecpInput = new SecpInput(utxos[1].getTxID(), utxos[1].getTxIdx(), utxos[1].getAmount(), utxos[1].getAssetID());\n        let in3:SecpInput = new SecpInput(utxos[2].getTxID(), utxos[2].getTxIdx(), utxos[2].getAmount(), utxos[2].getAssetID());\n\n        let cmp = SecpInput.comparator();\n        expect(cmp(in1, in2)).toBe(-1);\n        expect(cmp(in1, in3)).toBe(-1);\n        expect(cmp(in1, in1)).toBe(0);\n        expect(cmp(in2, in2)).toBe(0);\n        expect(cmp(in3, in3)).toBe(0);\n    });\n\n});"]} |
@@ -11,5 +11,6 @@ "use strict"; | ||
const bintools = bintools_1.default.getInstance(); | ||
const alias = "X"; | ||
describe('AVMKeyPair', () => { | ||
test('repeatable 1', () => { | ||
let kp = new keychain_1.AVMKeyPair(); | ||
let kp = new keychain_1.AVMKeyPair(alias); | ||
kp.importKey(buffer_1.Buffer.from("ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676", "hex")); | ||
@@ -24,3 +25,3 @@ expect(kp.getPublicKey().toString("hex")).toBe("033fad3644deb20d7a210d12757092312451c112d04773cee2699fbb59dc8bb2ef"); | ||
test('repeatable 2', () => { | ||
let kp = new keychain_1.AVMKeyPair(); | ||
let kp = new keychain_1.AVMKeyPair(alias); | ||
kp.importKey(buffer_1.Buffer.from("17c692d4a99d12f629d9f0ff92ec0dba15c9a83e85487b085c1a3018286995c6", "hex")); | ||
@@ -35,3 +36,3 @@ expect(kp.getPublicKey().toString("hex")).toBe("02486553b276cfe7abf0efbcd8d173e55db9c03da020c33d0b219df24124da18ee"); | ||
test('repeatable 3', () => { | ||
let kp = new keychain_1.AVMKeyPair(); | ||
let kp = new keychain_1.AVMKeyPair(alias); | ||
kp.importKey(buffer_1.Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex")); | ||
@@ -46,3 +47,3 @@ expect(kp.getPublicKey().toString("hex")).toBe("031475b91d4fcf52979f1cf107f058088cc2bea6edd51915790f27185a7586e2f2"); | ||
test('Creation Empty', () => { | ||
let kp = new keychain_1.AVMKeyPair(); | ||
let kp = new keychain_1.AVMKeyPair(alias); | ||
expect(kp.getPrivateKey()).not.toBeUndefined(); | ||
@@ -63,4 +64,4 @@ expect(kp.getAddress()).not.toBeUndefined(); | ||
let keybuff = buffer_1.Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc = new keychain_1.AVMKeyChain(); | ||
let kp2 = new keychain_1.AVMKeyPair(); | ||
let kc = new keychain_1.AVMKeyChain(alias); | ||
let kp2 = new keychain_1.AVMKeyPair(alias); | ||
let addr1 = kc.importKey(keybuff); | ||
@@ -70,3 +71,3 @@ let kp1 = kc.getKey(addr1); | ||
let addr2 = kp1.getAddress(); | ||
expect(addr1).toBe(addr2); | ||
expect(addr1.toString("hex")).toBe(addr2.toString("hex")); | ||
expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString()); | ||
@@ -78,4 +79,4 @@ expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString()); | ||
let keybuff = buffer_1.Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc = new keychain_1.AVMKeyChain(); | ||
let kp2 = new keychain_1.AVMKeyPair(); | ||
let kc = new keychain_1.AVMKeyChain(alias); | ||
let kp2 = new keychain_1.AVMKeyPair(alias); | ||
let addr1 = kc.importKey(bintools.avaSerialize(keybuff)); | ||
@@ -85,3 +86,3 @@ let kp1 = kc.getKey(addr1); | ||
let addr2 = kp1.getAddress(); | ||
expect(addr1).toBe(addr2); | ||
expect(addr1.toString("hex")).toBe(addr2.toString("hex")); | ||
expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString()); | ||
@@ -93,4 +94,4 @@ expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString()); | ||
let keybuff = buffer_1.Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc = new keychain_1.AVMKeyChain(); | ||
let kp1 = new keychain_1.AVMKeyPair(); | ||
let kc = new keychain_1.AVMKeyChain(alias); | ||
let kp1 = new keychain_1.AVMKeyPair(alias); | ||
let addr1 = kc.importKey(keybuff); | ||
@@ -104,3 +105,3 @@ kp1.importKey(keybuff); | ||
let keybuff = buffer_1.Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc = new keychain_1.AVMKeyChain(); | ||
let kc = new keychain_1.AVMKeyChain(alias); | ||
let addr1 = kc.importKey(keybuff); | ||
@@ -113,8 +114,8 @@ expect(kc.hasKey(addr1)).toBe(true); | ||
let keybuff = buffer_1.Buffer.from("d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475", "hex"); | ||
let kc = new keychain_1.AVMKeyChain(); | ||
let kc = new keychain_1.AVMKeyChain(alias); | ||
let addr1 = kc.importKey(keybuff); | ||
expect(kc.hasKey(addr1)).toBe(true); | ||
expect(kc.removeKey("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV")).toBe(false); | ||
expect(kc.removeKey(bintools.avaDeserialize("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV"))).toBe(false); | ||
}); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keychain.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/keychain.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { AVMKeyChain, AVMKeyPair } from 'src/apis/avm/keychain';\nimport { Buffer } from 'buffer/';\nimport createHash from \"create-hash\";\nimport BinTools from 'src/utils/bintools';\n\nconst bintools = BinTools.getInstance();\n\ndescribe('AVMKeyPair', () => {\n    test('repeatable 1', () => {\n        let kp:AVMKeyPair = new AVMKeyPair();\n        kp.importKey(Buffer.from(\"ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676\", \"hex\"));\n        expect(kp.getPublicKey().toString(\"hex\")).toBe(\"033fad3644deb20d7a210d12757092312451c112d04773cee2699fbb59dc8bb2ef\");\n\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n\n    });\n\n    test('repeatable 2', () => {\n        let kp:AVMKeyPair = new AVMKeyPair();\n        kp.importKey(Buffer.from(\"17c692d4a99d12f629d9f0ff92ec0dba15c9a83e85487b085c1a3018286995c6\", \"hex\"));\n        expect(kp.getPublicKey().toString(\"hex\")).toBe(\"02486553b276cfe7abf0efbcd8d173e55db9c03da020c33d0b219df24124da18ee\");\n\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n\n    });\n\n    test('repeatable 3', () => {\n        let kp:AVMKeyPair = new AVMKeyPair();\n        kp.importKey(Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\"));\n        expect(kp.getPublicKey().toString(\"hex\")).toBe(\"031475b91d4fcf52979f1cf107f058088cc2bea6edd51915790f27185a7586e2f2\");\n\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n\n    });\n\n    test('Creation Empty', () => {\n        let kp:AVMKeyPair = new AVMKeyPair();\n        expect(kp.getPrivateKey()).not.toBeUndefined();\n        expect(kp.getAddress()).not.toBeUndefined();\n        expect(kp.getPrivateKeyString()).not.toBeUndefined();\n        expect(kp.getPublicKey()).not.toBeUndefined();\n        expect(kp.getPublicKeyString()).not.toBeUndefined();\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n    });\n    \n});\n\ndescribe('AVMKeyChain', () => {\n    test('importKey from Buffer', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain();\n        let kp2:AVMKeyPair = new AVMKeyPair();\n        let addr1:string = kc.importKey(keybuff);\n        let kp1:AVMKeyPair = kc.getKey(addr1);\n        kp2.importKey(keybuff);\n        let addr2 = kp1.getAddress();\n        expect(addr1).toBe(addr2);\n        expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString());\n        expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString());\n        expect(kc.hasKey(addr1)).toBe(true);\n    });\n\n    test('importKey from serialized string', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain();\n        let kp2:AVMKeyPair = new AVMKeyPair();\n        let addr1:string = kc.importKey(bintools.avaSerialize(keybuff));\n        let kp1:AVMKeyPair = kc.getKey(addr1);\n        kp2.importKey(keybuff);\n        let addr2 = kp1.getAddress();\n        expect(addr1).toBe(addr2);\n        expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString());\n        expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString());\n        expect(kc.hasKey(addr1)).toBe(true);\n    });\n\n    test('removeKey via keypair', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain();\n        let kp1:AVMKeyPair = new AVMKeyPair();\n        let addr1:string = kc.importKey(keybuff);\n        kp1.importKey(keybuff);\n        expect(kc.hasKey(addr1)).toBe(true);\n        kc.removeKey(kp1);\n        expect(kc.hasKey(addr1)).toBe(false);\n    });\n\n    test('removeKey via string', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain();\n        let addr1:string = kc.importKey(keybuff);\n        expect(kc.hasKey(addr1)).toBe(true);\n        kc.removeKey(addr1);\n        expect(kc.hasKey(addr1)).toBe(false);\n    });\n\n    test('removeKey bad keys', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain();\n        let addr1:string = kc.importKey(keybuff);\n        expect(kc.hasKey(addr1)).toBe(true);\n        expect(kc.removeKey(\"6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV\")).toBe(false);\n    });\n});"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keychain.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/keychain.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { AVMKeyChain, AVMKeyPair } from 'src/apis/avm/keychain';\nimport { Buffer } from 'buffer/';\nimport createHash from \"create-hash\";\nimport BinTools from 'src/utils/bintools';\n\nconst bintools = BinTools.getInstance();\nconst alias = \"X\";\ndescribe('AVMKeyPair', () => {\n    test('repeatable 1', () => {\n        let kp:AVMKeyPair = new AVMKeyPair(alias);\n        kp.importKey(Buffer.from(\"ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676\", \"hex\"));\n        expect(kp.getPublicKey().toString(\"hex\")).toBe(\"033fad3644deb20d7a210d12757092312451c112d04773cee2699fbb59dc8bb2ef\");\n\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n\n    });\n\n    test('repeatable 2', () => {\n        let kp:AVMKeyPair = new AVMKeyPair(alias);\n        kp.importKey(Buffer.from(\"17c692d4a99d12f629d9f0ff92ec0dba15c9a83e85487b085c1a3018286995c6\", \"hex\"));\n        expect(kp.getPublicKey().toString(\"hex\")).toBe(\"02486553b276cfe7abf0efbcd8d173e55db9c03da020c33d0b219df24124da18ee\");\n\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n\n    });\n\n    test('repeatable 3', () => {\n        let kp:AVMKeyPair = new AVMKeyPair(alias);\n        kp.importKey(Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\"));\n        expect(kp.getPublicKey().toString(\"hex\")).toBe(\"031475b91d4fcf52979f1cf107f058088cc2bea6edd51915790f27185a7586e2f2\");\n\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n\n    });\n\n    test('Creation Empty', () => {\n        let kp:AVMKeyPair = new AVMKeyPair(alias);\n        expect(kp.getPrivateKey()).not.toBeUndefined();\n        expect(kp.getAddress()).not.toBeUndefined();\n        expect(kp.getPrivateKeyString()).not.toBeUndefined();\n        expect(kp.getPublicKey()).not.toBeUndefined();\n        expect(kp.getPublicKeyString()).not.toBeUndefined();\n        let msg:Buffer = Buffer.from(createHash(\"sha256\").update(Buffer.from(\"09090909\", \"hex\")).digest(\"hex\"), \"hex\");\n        let sig:Buffer = kp.sign(msg);\n\n        expect(sig.length).toBe(65);\n        expect(kp.verify(msg, sig)).toBe(true);\n        expect(kp.recover(msg, sig).toString(\"hex\")).toBe(kp.getPublicKey().toString(\"hex\"));\n    });\n    \n});\n\ndescribe('AVMKeyChain', () => {\n    test('importKey from Buffer', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain(alias);\n        let kp2:AVMKeyPair = new AVMKeyPair(alias);\n        let addr1:Buffer = kc.importKey(keybuff);\n        let kp1:AVMKeyPair = kc.getKey(addr1);\n        kp2.importKey(keybuff);\n        let addr2 = kp1.getAddress();\n        expect(addr1.toString(\"hex\")).toBe(addr2.toString(\"hex\"));\n        expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString());\n        expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString());\n        expect(kc.hasKey(addr1)).toBe(true);\n    });\n\n    test('importKey from serialized string', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain(alias);\n        let kp2:AVMKeyPair = new AVMKeyPair(alias);\n        let addr1:Buffer = kc.importKey(bintools.avaSerialize(keybuff));\n        let kp1:AVMKeyPair = kc.getKey(addr1);\n        kp2.importKey(keybuff);\n        let addr2 = kp1.getAddress();\n        expect(addr1.toString(\"hex\")).toBe(addr2.toString(\"hex\"));\n        expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString());\n        expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString());\n        expect(kc.hasKey(addr1)).toBe(true);\n    });\n\n    test('removeKey via keypair', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain(alias);\n        let kp1:AVMKeyPair = new AVMKeyPair(alias);\n        let addr1:Buffer = kc.importKey(keybuff);\n        kp1.importKey(keybuff);\n        expect(kc.hasKey(addr1)).toBe(true);\n        kc.removeKey(kp1);\n        expect(kc.hasKey(addr1)).toBe(false);\n    });\n\n    test('removeKey via string', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain(alias);\n        let addr1:Buffer = kc.importKey(keybuff);\n        expect(kc.hasKey(addr1)).toBe(true);\n        kc.removeKey(addr1);\n        expect(kc.hasKey(addr1)).toBe(false);\n    });\n\n    test('removeKey bad keys', () => {\n        let keybuff:Buffer = Buffer.from(\"d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475\", \"hex\");\n        let kc:AVMKeyChain = new AVMKeyChain(alias);\n        let addr1:Buffer = kc.importKey(keybuff);\n        expect(kc.hasKey(addr1)).toBe(true);\n        expect(kc.removeKey(bintools.avaDeserialize(\"6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV\"))).toBe(false);\n    });\n});"]} |
@@ -15,5 +15,5 @@ "use strict"; | ||
let addrs = [ | ||
"B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW", | ||
"P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF", | ||
"6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV" | ||
bintools.avaDeserialize("B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW"), | ||
bintools.avaDeserialize("P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF"), | ||
bintools.avaDeserialize("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV") | ||
].sort(); | ||
@@ -48,6 +48,3 @@ let locktime = new bn_js_1.default(54321); | ||
expect(out.getOutputID()).toBe(4); | ||
expect(JSON.stringify(Object.keys(out.getAddresses()).sort())).toBe(JSON.stringify(addrs.sort())); | ||
expect(out.getAddresses()[addrs[0]].toNumber()).toBe(locktime.toNumber()); | ||
expect(out.getAddresses()[addrs[1]].toNumber()).toBe(locktime.toNumber()); | ||
expect(out.getAddresses()[addrs[2]].toNumber()).toBe(locktime.toNumber()); | ||
expect(JSON.stringify(out.getAddresses().sort())).toStrictEqual(JSON.stringify(addrs.sort())); | ||
expect(out.getThreshold()).toBe(3); | ||
@@ -57,3 +54,3 @@ expect(out.getLocktime().toNumber()).toBe(locktime.toNumber()); | ||
let r = out.getAddressIdx(addrs[2]); | ||
expect(out.getAddress(r)).toBe(addrs[2]); | ||
expect(out.getAddress(r)).toStrictEqual(addrs[2]); | ||
expect(() => { | ||
@@ -77,2 +74,2 @@ out.getAddress(400); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputs.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/outputs.test.ts"],"names":[],"mappings":"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","sourcesContent":["import BN from \"bn.js\";\nimport {Buffer} from \"buffer/\";\nimport BinTools from 'src/utils/bintools';\nimport { Output, SecpOutput, SelectOutputClass } from 'src/apis/avm/outputs';\nimport { Constants } from '../../../src/apis/avm/types';\n\nconst bintools = BinTools.getInstance();\n\ndescribe('Outputs', () => {\n    let assetID:string = \"8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533\";\n    let assetIDBuff:Buffer = Buffer.from(assetID, \"hex\");\n    let addrs:Array<string> = [\n        \"B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW\",\n        \"P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF\",\n        \"6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV\"\n    ].sort();\n\n    let locktime:BN = new BN(54321);\n    let addrpay = [addrs[0], addrs[1]];\n    let addrfall = [addrs[1], addrs[2]];\n    let fallLocktime:BN = locktime.add(new BN(50));\n\n    test('SelectOutputClass', () => {\n        let goodout:SecpOutput = new SecpOutput(assetIDBuff, new BN(2600), addrpay, locktime, 1);\n        let badoutbuff:Buffer = bintools.copyFrom(goodout.toBuffer());\n        badoutbuff.write(\"00000099\", 32, 4, \"hex\");\n        let outpayment:Output = SelectOutputClass(goodout.toBuffer());\n        expect(outpayment).toBeInstanceOf(SecpOutput);\n        expect(() => {\n            SelectOutputClass(badoutbuff);\n        }).toThrow(\"Error - SelectOutputClass: unknown outputid\");\n    });\n\n    test('comparator', () => {\n        let outpayment1:Output = new SecpOutput(assetIDBuff, new BN(10000), addrs, locktime, 3);\n        let outpayment2:Output = new SecpOutput(assetIDBuff, new BN(10001), addrs, locktime, 3);\n        let outpayment3:Output = new SecpOutput(assetIDBuff, new BN(9999), addrs, locktime, 3);\n        let cmp = Output.comparator();\n        expect(cmp(outpayment1, outpayment1)).toBe(0);\n        expect(cmp(outpayment2, outpayment2)).toBe(0);\n        expect(cmp(outpayment3, outpayment3)).toBe(0);\n        expect(cmp(outpayment1, outpayment2)).toBe(-1);\n        expect(cmp(outpayment1, outpayment3)).toBe(1);\n    });\n    test('OutPayment', () => {\n        let out:SecpOutput = new SecpOutput(assetIDBuff, new BN(10000), addrs, locktime, 3);\n        expect(out.getOutputID()).toBe(4);\n        expect(JSON.stringify(Object.keys(out.getAddresses()).sort())).toBe(JSON.stringify(addrs.sort()));\n        expect(out.getAddresses()[addrs[0]].toNumber()).toBe(locktime.toNumber());\n        expect(out.getAddresses()[addrs[1]].toNumber()).toBe(locktime.toNumber());\n        expect(out.getAddresses()[addrs[2]].toNumber()).toBe(locktime.toNumber());\n\n        expect(out.getThreshold()).toBe(3);\n        expect(out.getLocktime().toNumber()).toBe(locktime.toNumber());\n\n        expect(out.getAssetID().toString(\"hex\")).toBe(assetID);\n\n        let r = out.getAddressIdx(addrs[2]);\n        expect(out.getAddress(r)).toBe(addrs[2]);\n        expect(() => {\n            out.getAddress(400)\n        }).toThrow();\n\n        expect(out.getAmount().toNumber()).toBe(10000);\n\n        let b:Buffer = out.toBuffer();\n        expect(out.toString()).toBe(bintools.bufferToB58(b));\n\n        let s:Array<string> = out.getSpenders(addrs);\n        expect(JSON.stringify(s.sort())).toBe(JSON.stringify(addrs.sort()));\n\n        let m1:boolean = out.meetsThreshold([addrs[0]]);\n        expect(m1).toBe(false);\n        let m2:boolean = out.meetsThreshold(addrs, new BN(100));\n        expect(m2).toBe(false);\n        let m3:boolean = out.meetsThreshold(addrs);\n        expect(m3).toBe(true);\n        let m4:boolean = out.meetsThreshold(addrs, locktime.add(new BN(100)));\n        expect(m4).toBe(true);\n    });\n});"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputs.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/outputs.test.ts"],"names":[],"mappings":"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","sourcesContent":["import BN from \"bn.js\";\nimport {Buffer} from \"buffer/\";\nimport BinTools from 'src/utils/bintools';\nimport { Output, SecpOutput, SelectOutputClass } from 'src/apis/avm/outputs';\n\nconst bintools = BinTools.getInstance();\n\ndescribe('Outputs', () => {\n    let assetID:string = \"8a5d2d32e68bc50036e4d086044617fe4a0a0296b274999ba568ea92da46d533\";\n    let assetIDBuff:Buffer = Buffer.from(assetID, \"hex\");\n    let addrs:Array<Buffer> = [\n        bintools.avaDeserialize(\"B6D4v1VtPYLbiUvYXtW4Px8oE9imC2vGW\"),\n        bintools.avaDeserialize(\"P5wdRuZeaDt28eHMP5S3w9ZdoBfo7wuzF\"),\n        bintools.avaDeserialize(\"6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV\")\n    ].sort();\n\n    let locktime:BN = new BN(54321);\n    let addrpay = [addrs[0], addrs[1]];\n    let addrfall = [addrs[1], addrs[2]];\n    let fallLocktime:BN = locktime.add(new BN(50));\n\n    test('SelectOutputClass', () => {\n        let goodout:SecpOutput = new SecpOutput(assetIDBuff, new BN(2600), addrpay, locktime, 1);\n        let badoutbuff:Buffer = bintools.copyFrom(goodout.toBuffer());\n        badoutbuff.write(\"00000099\", 32, 4, \"hex\");\n        let outpayment:Output = SelectOutputClass(goodout.toBuffer());\n        expect(outpayment).toBeInstanceOf(SecpOutput);\n        expect(() => {\n            SelectOutputClass(badoutbuff);\n        }).toThrow(\"Error - SelectOutputClass: unknown outputid\");\n    });\n\n    test('comparator', () => {\n        let outpayment1:Output = new SecpOutput(assetIDBuff, new BN(10000), addrs, locktime, 3);\n        let outpayment2:Output = new SecpOutput(assetIDBuff, new BN(10001), addrs, locktime, 3);\n        let outpayment3:Output = new SecpOutput(assetIDBuff, new BN(9999), addrs, locktime, 3);\n        let cmp = Output.comparator();\n        expect(cmp(outpayment1, outpayment1)).toBe(0);\n        expect(cmp(outpayment2, outpayment2)).toBe(0);\n        expect(cmp(outpayment3, outpayment3)).toBe(0);\n        expect(cmp(outpayment1, outpayment2)).toBe(-1);\n        expect(cmp(outpayment1, outpayment3)).toBe(1);\n    });\n    test('OutPayment', () => {\n        let out:SecpOutput = new SecpOutput(assetIDBuff, new BN(10000), addrs, locktime, 3);\n        expect(out.getOutputID()).toBe(4);\n        expect(JSON.stringify(out.getAddresses().sort())).toStrictEqual(JSON.stringify(addrs.sort()));\n\n        expect(out.getThreshold()).toBe(3);\n        expect(out.getLocktime().toNumber()).toBe(locktime.toNumber());\n\n        expect(out.getAssetID().toString(\"hex\")).toBe(assetID);\n\n        let r = out.getAddressIdx(addrs[2]);\n        expect(out.getAddress(r)).toStrictEqual(addrs[2]);\n        expect(() => {\n            out.getAddress(400)\n        }).toThrow();\n\n        expect(out.getAmount().toNumber()).toBe(10000);\n\n        let b:Buffer = out.toBuffer();\n        expect(out.toString()).toBe(bintools.bufferToB58(b));\n\n        let s:Array<Buffer> = out.getSpenders(addrs);\n        expect(JSON.stringify(s.sort())).toBe(JSON.stringify(addrs.sort()));\n\n        let m1:boolean = out.meetsThreshold([addrs[0]]);\n        expect(m1).toBe(false);\n        let m2:boolean = out.meetsThreshold(addrs, new BN(100));\n        expect(m2).toBe(false);\n        let m3:boolean = out.meetsThreshold(addrs);\n        expect(m3).toBe(true);\n        let m4:boolean = out.meetsThreshold(addrs, locktime.add(new BN(100)));\n        expect(m4).toBe(true);\n    });\n});"]} |
@@ -16,2 +16,3 @@ "use strict"; | ||
const types_1 = require("src/apis/avm/types"); | ||
const types_2 = require("../../../src/apis/avm/types"); | ||
/** | ||
@@ -35,8 +36,9 @@ * @ignore | ||
let blockchainID = buffer_1.Buffer.from(create_hash_1.default("sha256").update("I am the very model of a modern major general").digest()); | ||
let alias = "X"; | ||
let assetID = buffer_1.Buffer.from(create_hash_1.default("sha256").update("mary had a little lamb").digest()); | ||
beforeEach(() => { | ||
set = new utxos_1.UTXOSet(); | ||
keymgr1 = new keychain_1.AVMKeyChain(); | ||
keymgr2 = new keychain_1.AVMKeyChain(); | ||
keymgr3 = new keychain_1.AVMKeyChain(); | ||
keymgr1 = new keychain_1.AVMKeyChain(alias); | ||
keymgr2 = new keychain_1.AVMKeyChain(alias); | ||
keymgr3 = new keychain_1.AVMKeyChain(alias); | ||
addrs1 = []; | ||
@@ -126,3 +128,49 @@ addrs2 = []; | ||
}); | ||
test('Asset Creation Tx', () => { | ||
let secpbase1 = new outputs_1.SecpOutBase(new bn_js_1.default(777), addrs3); | ||
let secpbase2 = new outputs_1.SecpOutBase(new bn_js_1.default(888), addrs2); | ||
let secpbase3 = new outputs_1.SecpOutBase(new bn_js_1.default(999), addrs2); | ||
let initialState = new types_2.InitialStates(); | ||
initialState.addOutput(secpbase1, types_1.AVMConstants.SECPFXID); | ||
initialState.addOutput(secpbase2, types_1.AVMConstants.SECPFXID); | ||
initialState.addOutput(secpbase3, types_1.AVMConstants.SECPFXID); | ||
let name = "Rickcoin is the most intelligent coin"; | ||
let symbol = "RICK"; | ||
let denomination = 9; | ||
let txu = new tx_1.TxCreateAsset(name, symbol, denomination, initialState, inputs, outputs, netid, blockchainID, types_1.AVMConstants.CREATEASSETTX); | ||
let txins = txu.getIns(); | ||
let txouts = txu.getOuts(); | ||
let initState = txu.getInitialStates(); | ||
expect(txins.length).toBe(inputs.length); | ||
expect(txouts.length).toBe(outputs.length); | ||
expect(initState.toBuffer().toString("hex")).toBe(initialState.toBuffer().toString("hex")); | ||
expect(txu.getTxType()).toBe(types_1.AVMConstants.CREATEASSETTX); | ||
expect(txu.getNetworkID()).toBe(49); | ||
expect(txu.getBlockchainID().toString("hex")).toBe(blockchainID.toString("hex")); | ||
expect(txu.getName()).toBe(name); | ||
expect(txu.getNameBuffer().toString("hex")).toBe(bintools.stringToBuffer(name).toString("hex")); | ||
expect(txu.getSymbol()).toBe(symbol); | ||
expect(txu.getSymbolBuffer().toString("hex")).toBe(bintools.stringToBuffer(symbol).toString("hex")); | ||
expect(txu.getDenomination()).toBe(denomination); | ||
expect(txu.getDenominationBuffer().readUInt8(0)).toBe(denomination); | ||
let a = []; | ||
let b = []; | ||
for (let i = 0; i < txins.length; i++) { | ||
a.push(txins[i].toString()); | ||
b.push(inputs[i].toString()); | ||
} | ||
expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort())); | ||
a = []; | ||
b = []; | ||
for (let i = 0; i < txouts.length; i++) { | ||
a.push(txouts[i].toString()); | ||
b.push(outputs[i].toString()); | ||
} | ||
expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort())); | ||
let txunew = new tx_1.TxCreateAsset(); | ||
txunew.fromBuffer(txu.toBuffer()); | ||
expect(txunew.toBuffer().toString("hex")).toBe(txu.toBuffer().toString("hex")); | ||
expect(txunew.toString()).toBe(txu.toString()); | ||
}); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tx.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/tx.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos';\nimport { TxUnsigned, Tx } from 'src/apis/avm/tx';\nimport { AVMKeyChain } from 'src/apis/avm/keychain';\nimport { Input, SecpInput } from 'src/apis/avm/inputs';\nimport createHash from 'create-hash';\nimport BinTools from 'src/utils/bintools';\nimport BN from 'bn.js';\nimport {Buffer} from \"buffer/\";\nimport { Output, SecpOutput } from 'src/apis/avm/outputs';\nimport { UnixNow } from 'src/apis/avm/types';\n\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\ndescribe('Transactions', () => {\n    let set:UTXOSet;\n    let keymgr1:AVMKeyChain;\n    let keymgr2:AVMKeyChain;\n    let keymgr3:AVMKeyChain;\n    let addrs1:Array<string>;\n    let addrs2:Array<string>;\n    let addrs3:Array<string>;\n    let utxos:Array<SecpUTXO>;\n    let inputs:Array<SecpInput>;\n    let outputs:Array<Output>;\n    const amnt:number = 10000;\n    let netid:number = 49;\n    let blockchainID:Buffer = Buffer.from(createHash(\"sha256\").update(\"I am the very model of a modern major general\").digest());\n    let assetID:Buffer = Buffer.from(createHash(\"sha256\").update(\"mary had a little lamb\").digest());\n    beforeEach(() => {\n        set = new UTXOSet();\n        keymgr1 = new AVMKeyChain();\n        keymgr2 = new AVMKeyChain();\n        keymgr3 = new AVMKeyChain();\n        addrs1 = [];\n        addrs2 = [];\n        addrs3 = [];\n        utxos = [];\n        inputs = [];\n        outputs = [];\n\n        for(let i:number = 0; i < 3; i++){\n            addrs1.push(keymgr1.makeKey());\n            addrs2.push(keymgr2.makeKey());\n            addrs3.push(keymgr3.makeKey());\n        }\n        let amount:BN = new BN(amnt);\n        let addresses:Array<string> = keymgr1.getAddresses();\n        let fallAddresses:Array<string> = keymgr2.getAddresses()\n        let locktime:BN = new BN(54321);\n        let fallLocktime:BN = locktime.add(new BN(50));\n        let threshold:number = 3;\n        let fallThreshold:number = 1;\n        \n        for(let i:number = 0; i < 5; i++){\n            let txid:Buffer = Buffer.from(createHash(\"sha256\").update(bintools.fromBNToBuffer(new BN(i), 32)).digest());\n            let txidx:Buffer = Buffer.from(bintools.fromBNToBuffer(new BN(i), 4));\n            let out:SecpOutput;\n            out = new SecpOutput(assetID, amount, addresses, locktime, threshold);\n            outputs.push(out);\n\n            let u:SecpUTXO = new SecpUTXO();\n            u.fromBuffer(Buffer.concat([txid, txidx, out.toBuffer()]));\n            utxos.push(u);\n\n            txid = u.getTxID();\n            txidx = u.getTxIdx();\n            let asset = u.getAssetID();\n\n            let input:SecpInput = new SecpInput(txid, txidx, amount, asset);\n            inputs.push(input);\n        }\n        set.addArray(utxos);\n    });\n\n    test('Creation TxUnsigned', () => {\n        let txu:TxUnsigned = new TxUnsigned(inputs, outputs, netid, blockchainID, 99);\n        let txins:Array<Input>  = txu.getIns();\n        let txouts:Array<Output> = txu.getOuts();\n        expect(txins.length).toBe(inputs.length);\n        expect(txouts.length).toBe(outputs.length);\n        \n        expect(txu.getTxType()).toBe(99);\n        expect(txu.getNetworkID()).toBe(49);\n        expect(txu.getBlockchainID().toString(\"hex\")).toBe(blockchainID.toString(\"hex\"));\n        \n        let a:Array<string> = [];\n        let b:Array<string> = [];\n        for(let i:number = 0; i < txins.length; i++){\n            a.push(txins[i].toString());\n            b.push(inputs[i].toString());\n        }\n        expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort()));\n        \n        a = [];\n        b = [];\n\n        for(let i:number = 0; i < txouts.length; i++){\n            a.push(txouts[i].toString());\n            b.push(outputs[i].toString());\n        }\n        expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort()));\n\n        let txunew:TxUnsigned = new TxUnsigned();\n        txunew.fromBuffer(txu.toBuffer());\n        expect(txunew.toBuffer().toString(\"hex\")).toBe(txu.toBuffer().toString(\"hex\"));\n        expect(txunew.toString()).toBe(txu.toString());\n    });\n\n    test('Creation TxUnsigned Check Amount', () => {\n        expect(() => {\n            set.makeUnsignedTx(\n                netid, blockchainID,\n                new BN(amnt * 1000), \n                addrs3, addrs1, addrs1, assetID\n            );\n        }).toThrow();\n    });\n\n    test('Creation Tx1', () => {\n        let txu:TxUnsigned = set.makeUnsignedTx(\n            netid, blockchainID,\n            new BN(9000), \n            addrs3, addrs1, addrs1, assetID, \n            UnixNow(), UnixNow().add(new BN(50)), 1\n        );\n        let tx:Tx = keymgr1.signTx(txu);\n\n        let tx2:Tx = new Tx();\n        tx2.fromString(tx.toString());\n        expect(tx2.toBuffer().toString(\"hex\")).toBe(tx.toBuffer().toString(\"hex\"));\n        expect(tx2.toString()).toBe(tx.toString());\n    });\n    test('Creation Tx2', () => {\n        let txu:TxUnsigned = set.makeUnsignedTx(\n            netid, blockchainID,\n            new BN(9000), \n            addrs3, addrs1, addrs1, assetID\n        );\n        let tx:Tx = keymgr1.signTx(txu);\n        let tx2:Tx = new Tx();\n        tx2.fromString(tx.toString());\n        expect(tx2.toBuffer().toString(\"hex\")).toBe(tx.toBuffer().toString(\"hex\"));\n        expect(tx2.toString()).toBe(tx.toString());\n    });\n});\n    "]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tx.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/tx.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { UTXOSet, UTXO, SecpUTXO } from 'src/apis/avm/utxos';\nimport { TxUnsigned, TxCreateAsset, Tx } from 'src/apis/avm/tx';\nimport { AVMKeyChain } from 'src/apis/avm/keychain';\nimport { Input, SecpInput } from 'src/apis/avm/inputs';\nimport createHash from 'create-hash';\nimport BinTools from 'src/utils/bintools';\nimport BN from 'bn.js';\nimport {Buffer} from \"buffer/\";\nimport { Output, SecpOutput, SecpOutBase } from 'src/apis/avm/outputs';\nimport { UnixNow, AVMConstants} from 'src/apis/avm/types';\nimport { InitialStates } from '../../../src/apis/avm/types';\n/**\n * @ignore\n */\nconst bintools = BinTools.getInstance();\ndescribe('Transactions', () => {\n    let set:UTXOSet;\n    let keymgr1:AVMKeyChain;\n    let keymgr2:AVMKeyChain;\n    let keymgr3:AVMKeyChain;\n    let addrs1:Array<Buffer>;\n    let addrs2:Array<Buffer>;\n    let addrs3:Array<Buffer>;\n    let utxos:Array<SecpUTXO>;\n    let inputs:Array<SecpInput>;\n    let outputs:Array<Output>;\n    const amnt:number = 10000;\n    let netid:number = 49;\n    let blockchainID:Buffer = Buffer.from(createHash(\"sha256\").update(\"I am the very model of a modern major general\").digest());\n    let alias:string = \"X\";\n    let assetID:Buffer = Buffer.from(createHash(\"sha256\").update(\"mary had a little lamb\").digest());\n    beforeEach(() => {\n        set = new UTXOSet();\n        keymgr1 = new AVMKeyChain(alias);\n        keymgr2 = new AVMKeyChain(alias);\n        keymgr3 = new AVMKeyChain(alias);\n        addrs1 = [];\n        addrs2 = [];\n        addrs3 = [];\n        utxos = [];\n        inputs = [];\n        outputs = [];\n\n        for(let i:number = 0; i < 3; i++){\n            addrs1.push(keymgr1.makeKey());\n            addrs2.push(keymgr2.makeKey());\n            addrs3.push(keymgr3.makeKey());\n        }\n        let amount:BN = new BN(amnt);\n        let addresses:Array<Buffer> = keymgr1.getAddresses();\n        let fallAddresses:Array<Buffer> = keymgr2.getAddresses();\n        let locktime:BN = new BN(54321);\n        let fallLocktime:BN = locktime.add(new BN(50));\n        let threshold:number = 3;\n        let fallThreshold:number = 1;\n        for(let i:number = 0; i < 5; i++){\n            let txid:Buffer = Buffer.from(createHash(\"sha256\").update(bintools.fromBNToBuffer(new BN(i), 32)).digest());\n            let txidx:Buffer = Buffer.from(bintools.fromBNToBuffer(new BN(i), 4));\n            let out:SecpOutput;\n            out = new SecpOutput(assetID, amount, addresses, locktime, threshold);\n            outputs.push(out);\n\n            let u:SecpUTXO = new SecpUTXO();\n            u.fromBuffer(Buffer.concat([txid, txidx, out.toBuffer()]));\n            utxos.push(u);\n\n            txid = u.getTxID();\n            txidx = u.getTxIdx();\n            let asset = u.getAssetID();\n\n            let input:SecpInput = new SecpInput(txid, txidx, amount, asset);\n            inputs.push(input);\n        }\n        set.addArray(utxos);\n    });\n\n    test('Creation TxUnsigned', () => {\n        let txu:TxUnsigned = new TxUnsigned(inputs, outputs, netid, blockchainID, 99);\n        let txins:Array<Input>  = txu.getIns();\n        let txouts:Array<Output> = txu.getOuts();\n        expect(txins.length).toBe(inputs.length);\n        expect(txouts.length).toBe(outputs.length);\n        \n        expect(txu.getTxType()).toBe(99);\n        expect(txu.getNetworkID()).toBe(49);\n        expect(txu.getBlockchainID().toString(\"hex\")).toBe(blockchainID.toString(\"hex\"));\n        \n        let a:Array<string> = [];\n        let b:Array<string> = [];\n        for(let i:number = 0; i < txins.length; i++){\n            a.push(txins[i].toString());\n            b.push(inputs[i].toString());\n        }\n        expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort()));\n        \n        a = [];\n        b = [];\n\n        for(let i:number = 0; i < txouts.length; i++){\n            a.push(txouts[i].toString());\n            b.push(outputs[i].toString());\n        }\n        expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort()));\n\n        let txunew:TxUnsigned = new TxUnsigned();\n        txunew.fromBuffer(txu.toBuffer());\n        expect(txunew.toBuffer().toString(\"hex\")).toBe(txu.toBuffer().toString(\"hex\"));\n        expect(txunew.toString()).toBe(txu.toString());\n    });\n\n    test('Creation TxUnsigned Check Amount', () => {\n        expect(() => {\n            set.makeUnsignedTx(\n                netid, blockchainID,\n                new BN(amnt * 1000), \n                addrs3, addrs1, addrs1, assetID\n            );\n        }).toThrow();\n    });\n\n    test('Creation Tx1', () => {\n        let txu:TxUnsigned = set.makeUnsignedTx(\n            netid, blockchainID,\n            new BN(9000), \n            addrs3, addrs1, addrs1, assetID, \n            UnixNow(), UnixNow().add(new BN(50)), 1\n        );\n        let tx:Tx = keymgr1.signTx(txu);\n\n        let tx2:Tx = new Tx();\n        tx2.fromString(tx.toString());\n        expect(tx2.toBuffer().toString(\"hex\")).toBe(tx.toBuffer().toString(\"hex\"));\n        expect(tx2.toString()).toBe(tx.toString());\n    });\n    test('Creation Tx2', () => {\n        let txu:TxUnsigned = set.makeUnsignedTx(\n            netid, blockchainID,\n            new BN(9000), \n            addrs3, addrs1, addrs1, assetID\n        );\n        let tx:Tx = keymgr1.signTx(txu);\n        let tx2:Tx = new Tx();\n        tx2.fromString(tx.toString());\n        expect(tx2.toBuffer().toString(\"hex\")).toBe(tx.toBuffer().toString(\"hex\"));\n        expect(tx2.toString()).toBe(tx.toString());\n    });\n\n    test('Asset Creation Tx', () => {\n        let secpbase1:SecpOutBase = new SecpOutBase(new BN(777), addrs3);\n        let secpbase2:SecpOutBase = new SecpOutBase(new BN(888), addrs2);\n        let secpbase3:SecpOutBase = new SecpOutBase(new BN(999), addrs2);\n        let initialState:InitialStates = new InitialStates();\n        initialState.addOutput(secpbase1, AVMConstants.SECPFXID);\n        initialState.addOutput(secpbase2, AVMConstants.SECPFXID);\n        initialState.addOutput(secpbase3, AVMConstants.SECPFXID);\n        let name:string = \"Rickcoin is the most intelligent coin\";\n        let symbol:string = \"RICK\";\n        let denomination:number = 9;\n        let txu:TxCreateAsset = new TxCreateAsset(name, symbol, denomination, initialState, inputs, outputs, netid, blockchainID, AVMConstants.CREATEASSETTX);\n        let txins:Array<Input>  = txu.getIns();\n        let txouts:Array<Output> = txu.getOuts();\n        let initState:InitialStates = txu.getInitialStates();\n        expect(txins.length).toBe(inputs.length);\n        expect(txouts.length).toBe(outputs.length);\n        expect(initState.toBuffer().toString(\"hex\")).toBe(initialState.toBuffer().toString(\"hex\"));\n        \n        expect(txu.getTxType()).toBe(AVMConstants.CREATEASSETTX);\n        expect(txu.getNetworkID()).toBe(49);\n        expect(txu.getBlockchainID().toString(\"hex\")).toBe(blockchainID.toString(\"hex\"));\n        expect(txu.getName()).toBe(name);\n        expect(txu.getNameBuffer().toString(\"hex\")).toBe(bintools.stringToBuffer(name).toString(\"hex\"));\n        expect(txu.getSymbol()).toBe(symbol);\n        expect(txu.getSymbolBuffer().toString(\"hex\")).toBe(bintools.stringToBuffer(symbol).toString(\"hex\"));\n        expect(txu.getDenomination()).toBe(denomination);\n        expect(txu.getDenominationBuffer().readUInt8(0)).toBe(denomination);\n\n        let a:Array<string> = [];\n        let b:Array<string> = [];\n        for(let i:number = 0; i < txins.length; i++){\n            a.push(txins[i].toString());\n            b.push(inputs[i].toString());\n        }\n        expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort()));\n        \n        a = [];\n        b = [];\n\n        for(let i:number = 0; i < txouts.length; i++){\n            a.push(txouts[i].toString());\n            b.push(outputs[i].toString());\n        }\n        expect(JSON.stringify(a.sort())).toBe(JSON.stringify(b.sort()));\n\n        let txunew:TxCreateAsset = new TxCreateAsset();\n        txunew.fromBuffer(txu.toBuffer());\n        expect(txunew.toBuffer().toString(\"hex\")).toBe(txu.toBuffer().toString(\"hex\"));\n        expect(txunew.toString()).toBe(txu.toString());\n    });\n});\n    "]} |
@@ -39,4 +39,4 @@ "use strict"; | ||
expect(sigidx.getSize()).toBe(sigidx.toBuffer().length); | ||
sigidx.setSource("abcd"); | ||
expect(sigidx.getSource()).toBe("abcd"); | ||
sigidx.setSource(buffer_1.Buffer.from("abcd", "hex")); | ||
expect(sigidx.getSource().toString("hex")).toBe("abcd"); | ||
}); | ||
@@ -76,2 +76,2 @@ describe('Address', () => { | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/types.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { SigIdx, Signature, Address, UnixNow } from 'src/apis/avm/types';\nimport {Buffer} from \"buffer/\";\nimport BinTools from 'src/utils/bintools';\n\nlet bintools:BinTools = BinTools.getInstance();\n\ndescribe('UnixNow', () => {\n    test('Does it return the right time?', () => {\n        let now = Math.round((new Date()).getTime() / 1000);\n        let unow = UnixNow();\n        expect(now / 10).toBeCloseTo(unow.divn(10).toNumber(), -1);\n    });\n});\n\ndescribe('Signature & NBytes', () => {\n    let sig = new Signature(); \n    let sigpop:Array<number> = [];\n    for(let i:number = 0; i < sig.getSize(); i++){\n        sigpop[i] = i;\n    }\n    let sigbuff:Buffer = Buffer.from(sigpop);\n    let size = sig.fromBuffer(sigbuff);\n    expect(sig.getSize()).toBe(size);\n    expect(size).toBe(sig.getSize());\n    let sigbuff2:Buffer = sig.toBuffer();\n    for(let i:number = 0; i < sigbuff.length; i++){\n        expect(sigbuff2[i]).toBe(sigbuff[i]);\n    }\n    let sigbuffstr:string = bintools.bufferToB58(sigbuff);\n    expect(sig.toString()).toBe(sigbuffstr);\n    sig.fromString(sigbuffstr);\n    expect(sig.toString()).toBe(sigbuffstr);\n});\n\ndescribe('SigIdx', () => {\n    let sigidx:SigIdx = new SigIdx();\n    expect(sigidx.getSize()).toBe(sigidx.toBuffer().length);\n    sigidx.setSource(\"abcd\");\n    expect(sigidx.getSource()).toBe(\"abcd\");\n});\n\ndescribe('Address', () => {\n    let addr1 = new Address();\n    let addr2 = new Address();\n    let smaller:Array<number> = [0,1,2,3,4,5,6,7,8,9,9,8,7,6,5,4,3,2,1,0];\n    let bigger:Array<number> = [0,1,2,3,4,5,6,7,8,9,9,8,7,6,5,4,3,2,1,1]\n    let addr1bytes:Buffer = Buffer.from(smaller);\n    let addr2bytes:Buffer = Buffer.from(bigger);\n    addr1.fromBuffer(addr1bytes);\n    addr2.fromBuffer(addr2bytes);\n    expect(Address.comparitor()(addr1,addr2)).toBe(-1);\n    expect(Address.comparitor()(addr2,addr1)).toBe(1);\n    \n    let addr2str:string = addr2.toString();\n    \n    addr2.fromBuffer(addr1bytes);\n    expect(Address.comparitor()(addr1,addr2)).toBe(0);\n    \n    addr2.fromString(addr2str);\n    expect(Address.comparitor()(addr1,addr2)).toBe(-1);\n    let a1b:Buffer = addr1.toBuffer();\n    let a1s:string = bintools.bufferToB58(a1b);\n    addr2.fromString(a1s);\n    expect(Address.comparitor()(addr1,addr2)).toBe(0);\n\n    let badbuff:Buffer = bintools.copyFrom(addr1bytes);\n    let badbuffout:Buffer = Buffer.concat([badbuff, Buffer.from([1,2])]);\n    let badstr:string = bintools.bufferToB58(badbuffout);\n    let badaddr:Address = new Address();\n\n    expect(() => {\n        badaddr.fromString(badstr)\n    }).toThrow(\"Error - Address.fromString: invalid address\");\n\n    badbuffout = Buffer.concat([badbuff, Buffer.from([1,2,3,4])]);\n    badstr = bintools.bufferToB58(badbuffout);\n    expect(() => {\n        badaddr.fromString(badstr)\n    }).toThrow(\"Error - Address.fromString: invalid checksum on address\");\n\n});"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.test.js","sourceRoot":"","sources":["../../../../tests/apis/avm/types.test.ts"],"names":[],"mappings":";;;;;AAAA,8CAAyE;AACzE,oCAA+B;AAC/B,kEAA0C;AAE1C,IAAI,QAAQ,GAAY,kBAAQ,CAAC,WAAW,EAAE,CAAC;AAE/C,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACrB,IAAI,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;QACpD,IAAI,IAAI,GAAG,eAAO,EAAE,CAAC;QACrB,MAAM,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAChC,IAAI,GAAG,GAAG,IAAI,iBAAS,EAAE,CAAC;IAC1B,IAAI,MAAM,GAAiB,EAAE,CAAC;IAC9B,KAAI,IAAI,CAAC,GAAU,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAC;QACzC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;KACjB;IACD,IAAI,OAAO,GAAU,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACzC,IAAI,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IACnC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IACjC,IAAI,QAAQ,GAAU,GAAG,CAAC,QAAQ,EAAE,CAAC;IACrC,KAAI,IAAI,CAAC,GAAU,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAC;QAC1C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;KACxC;IACD,IAAI,UAAU,GAAU,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IACtD,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACxC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAC3B,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AAC5C,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,QAAQ,EAAE,GAAG,EAAE;IACpB,IAAI,MAAM,GAAU,IAAI,cAAM,EAAE,CAAC;IACjC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC;IACxD,MAAM,CAAC,SAAS,CAAC,eAAM,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;IAC7C,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAC5D,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACrB,IAAI,KAAK,GAAG,IAAI,eAAO,EAAE,CAAC;IAC1B,IAAI,KAAK,GAAG,IAAI,eAAO,EAAE,CAAC;IAC1B,IAAI,OAAO,GAAiB,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC,CAAC;IACtE,IAAI,MAAM,GAAiB,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC,CAAA;IACpE,IAAI,UAAU,GAAU,eAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7C,IAAI,UAAU,GAAU,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5C,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAC7B,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAC7B,MAAM,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,KAAK,EAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACnD,MAAM,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,KAAK,EAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAElD,IAAI,QAAQ,GAAU,KAAK,CAAC,QAAQ,EAAE,CAAC;IAEvC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAC7B,MAAM,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,KAAK,EAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAElD,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC3B,MAAM,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,KAAK,EAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACnD,IAAI,GAAG,GAAU,KAAK,CAAC,QAAQ,EAAE,CAAC;IAClC,IAAI,GAAG,GAAU,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC3C,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IACtB,MAAM,CAAC,eAAO,CAAC,UAAU,EAAE,CAAC,KAAK,EAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAElD,IAAI,OAAO,GAAU,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IACnD,IAAI,UAAU,GAAU,eAAM,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,eAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACrE,IAAI,MAAM,GAAU,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IACrD,IAAI,OAAO,GAAW,IAAI,eAAO,EAAE,CAAC;IAEpC,MAAM,CAAC,GAAG,EAAE;QACR,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IAC9B,CAAC,CAAC,CAAC,OAAO,CAAC,6CAA6C,CAAC,CAAC;IAE1D,UAAU,GAAG,eAAM,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,eAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9D,MAAM,GAAG,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IAC1C,MAAM,CAAC,GAAG,EAAE;QACR,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IAC9B,CAAC,CAAC,CAAC,OAAO,CAAC,yDAAyD,CAAC,CAAC;AAE1E,CAAC,CAAC,CAAC","sourcesContent":["import { SigIdx, Signature, Address, UnixNow } from 'src/apis/avm/types';\nimport {Buffer} from \"buffer/\";\nimport BinTools from 'src/utils/bintools';\n\nlet bintools:BinTools = BinTools.getInstance();\n\ndescribe('UnixNow', () => {\n    test('Does it return the right time?', () => {\n        let now = Math.round((new Date()).getTime() / 1000);\n        let unow = UnixNow();\n        expect(now / 10).toBeCloseTo(unow.divn(10).toNumber(), -1);\n    });\n});\n\ndescribe('Signature & NBytes', () => {\n    let sig = new Signature(); \n    let sigpop:Array<number> = [];\n    for(let i:number = 0; i < sig.getSize(); i++){\n        sigpop[i] = i;\n    }\n    let sigbuff:Buffer = Buffer.from(sigpop);\n    let size = sig.fromBuffer(sigbuff);\n    expect(sig.getSize()).toBe(size);\n    expect(size).toBe(sig.getSize());\n    let sigbuff2:Buffer = sig.toBuffer();\n    for(let i:number = 0; i < sigbuff.length; i++){\n        expect(sigbuff2[i]).toBe(sigbuff[i]);\n    }\n    let sigbuffstr:string = bintools.bufferToB58(sigbuff);\n    expect(sig.toString()).toBe(sigbuffstr);\n    sig.fromString(sigbuffstr);\n    expect(sig.toString()).toBe(sigbuffstr);\n});\n\ndescribe('SigIdx', () => {\n    let sigidx:SigIdx = new SigIdx();\n    expect(sigidx.getSize()).toBe(sigidx.toBuffer().length);\n    sigidx.setSource(Buffer.from(\"abcd\", \"hex\"));\n    expect(sigidx.getSource().toString(\"hex\")).toBe(\"abcd\");\n});\n\ndescribe('Address', () => {\n    let addr1 = new Address();\n    let addr2 = new Address();\n    let smaller:Array<number> = [0,1,2,3,4,5,6,7,8,9,9,8,7,6,5,4,3,2,1,0];\n    let bigger:Array<number> = [0,1,2,3,4,5,6,7,8,9,9,8,7,6,5,4,3,2,1,1]\n    let addr1bytes:Buffer = Buffer.from(smaller);\n    let addr2bytes:Buffer = Buffer.from(bigger);\n    addr1.fromBuffer(addr1bytes);\n    addr2.fromBuffer(addr2bytes);\n    expect(Address.comparitor()(addr1,addr2)).toBe(-1);\n    expect(Address.comparitor()(addr2,addr1)).toBe(1);\n    \n    let addr2str:string = addr2.toString();\n    \n    addr2.fromBuffer(addr1bytes);\n    expect(Address.comparitor()(addr1,addr2)).toBe(0);\n    \n    addr2.fromString(addr2str);\n    expect(Address.comparitor()(addr1,addr2)).toBe(-1);\n    let a1b:Buffer = addr1.toBuffer();\n    let a1s:string = bintools.bufferToB58(a1b);\n    addr2.fromString(a1s);\n    expect(Address.comparitor()(addr1,addr2)).toBe(0);\n\n    let badbuff:Buffer = bintools.copyFrom(addr1bytes);\n    let badbuffout:Buffer = Buffer.concat([badbuff, Buffer.from([1,2])]);\n    let badstr:string = bintools.bufferToB58(badbuffout);\n    let badaddr:Address = new Address();\n\n    expect(() => {\n        badaddr.fromString(badstr)\n    }).toThrow(\"Error - Address.fromString: invalid address\");\n\n    badbuffout = Buffer.concat([badbuff, Buffer.from([1,2,3,4])]);\n    badstr = bintools.bufferToB58(badbuffout);\n    expect(() => {\n        badaddr.fromString(badstr)\n    }).toThrow(\"Error - Address.fromString: invalid checksum on address\");\n\n});"]} |
@@ -32,4 +32,4 @@ "use strict"; | ||
}); | ||
test("createAccount", () => __awaiter(void 0, void 0, void 0, function* () { | ||
let result = keystore.createAccount(username, password); | ||
test("createUser", () => __awaiter(void 0, void 0, void 0, function* () { | ||
let result = keystore.createUser(username, password); | ||
let payload = { | ||
@@ -48,24 +48,8 @@ "result": { | ||
})); | ||
test('can CreateAddress', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let alias = 'randomalias'; | ||
let result = keystore.createAddress(username, password, alias); | ||
let payload = { | ||
"result": { | ||
"address": alias | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(alias); | ||
})); | ||
test('exportAccount', () => __awaiter(void 0, void 0, void 0, function* () { | ||
test('exportUser', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let data = 'data'; | ||
let result = keystore.exportAccount(username, password); | ||
let result = keystore.exportUser(username, password); | ||
let payload = { | ||
"result": { | ||
"accountData": data | ||
"user": data | ||
} | ||
@@ -81,71 +65,6 @@ }; | ||
})); | ||
test('exportKey', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let key = 'sdfglvlj2h3v45'; | ||
let result = keystore.exportKey(username, password, 'alias', 'address'); | ||
test('importUser', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let result = keystore.importUser(username, 'data', password); | ||
let payload = { | ||
"result": { | ||
"privateKey": key | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(key); | ||
})); | ||
test('getAllBalances', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let balances = { | ||
'ATH': 23, | ||
'BTC': 59 | ||
}; | ||
let result = keystore.getAllBalances('alias', 'address'); | ||
let payload = { | ||
"result": { | ||
"balances": balances | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(balances); | ||
})); | ||
test('getBalance', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let balance = 100; | ||
let result = keystore.getBalance('alias', 'address', 'ATH'); | ||
let payload = { | ||
"result": { | ||
"balance": balance | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(balance); | ||
})); | ||
test('getTxHistory', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let history = {}; | ||
let result = keystore.getTxHistory('alias', 'address'); | ||
let payload = { | ||
"result": history | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(history); | ||
})); | ||
test('importAccount', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let result = keystore.importAccount(username, 'data', password); | ||
let payload = { | ||
"result": { | ||
'success': true | ||
@@ -162,24 +81,8 @@ } | ||
})); | ||
test('importKey', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let address = 'asdflashdvfalsdf'; | ||
let result = keystore.importKey(username, password, 'alias', 'key'); | ||
let payload = { | ||
"result": { | ||
'address': address | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(address); | ||
})); | ||
test('listAccounts', () => __awaiter(void 0, void 0, void 0, function* () { | ||
test('listUsers', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let accounts = ['acc1', 'acc2']; | ||
let result = keystore.listAccounts(); | ||
let result = keystore.listUsers(); | ||
let payload = { | ||
"result": { | ||
'accounts': accounts | ||
'users': accounts | ||
} | ||
@@ -195,67 +98,3 @@ }; | ||
})); | ||
test('listAddresses', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let addresses = ['acc1', 'acc2']; | ||
let result = keystore.listAddresses(username, 'alias'); | ||
let payload = { | ||
"result": { | ||
'addresses': addresses | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(addresses); | ||
})); | ||
test('listAssets', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let assets = ['ATH', 'ETH']; | ||
let result = keystore.listAssets(username, 'address'); | ||
let payload = { | ||
"result": { | ||
'assets': assets | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(assets); | ||
})); | ||
test('can ListSubnets', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let subnets = ['net1', 'net2']; | ||
let result = keystore.listSubnets(); | ||
let payload = { | ||
"result": { | ||
'subnetIDs': subnets | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(subnets); | ||
})); | ||
test('can Send', () => __awaiter(void 0, void 0, void 0, function* () { | ||
let txId = 'asdfhvl234'; | ||
let result = keystore.send(username, password, 'alias', 'assetId', 10, 'toAddress', ['fromAddress']); | ||
let payload = { | ||
"result": { | ||
'txID': txId | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(txId); | ||
})); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.test.js","sourceRoot":"","sources":["../../../../tests/apis/keystore/api.test.ts"],"names":[],"mappings":"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","sourcesContent":["import mockAxios from 'jest-mock-axios';\n\n\nimport { Slopes } from \"src\";\nimport KeystoreAPI from \"src/apis/keystore/api\";\n\ndescribe(\"Keystore\", () => {\n    const ip = '127.0.0.1';\n    const port = 9650;\n    const protocol = \"https\";\n\n    let username = 'AvaLabs';\n    let password = 'password';\n\n    let slopes = new Slopes(ip,port,protocol, 49, undefined, true);\n    let keystore:KeystoreAPI;\n\n    beforeAll(() => {\n        keystore = new KeystoreAPI(slopes);\n    });\n\n    afterEach(() => {\n        mockAxios.reset();\n    });\n\n    test(\"createAccount\", async ()=>{\n\n        let result:Promise<boolean> = keystore.createAccount(username, password);\n        let payload:object = {\n            \"result\": {\n                \"success\": true\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:boolean = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(true);\n    });\n\n    test('can CreateAddress', async ()=>{\n        let alias = 'randomalias';\n\n        let result:Promise<string> = keystore.createAddress(username, password, alias);\n        let payload:object = {\n            \"result\": {\n                \"address\": alias\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(alias);\n    });\n\n\n    test('exportAccount', async ()=>{\n        let data = 'data';\n\n        let result:Promise<string> = keystore.exportAccount(username, password);\n        let payload:object = {\n            \"result\": {\n                \"accountData\": data\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(data);\n    });\n\n    test('exportKey', async ()=>{\n        let key = 'sdfglvlj2h3v45';\n\n        let result:Promise<string> = keystore.exportKey(username, password, 'alias', 'address');\n        let payload:object = {\n            \"result\": {\n                \"privateKey\": key\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(key);\n    });\n\n\n    test('getAllBalances', async ()=>{\n        let balances = {\n            'ATH': 23,\n            'BTC': 59\n        };\n\n        let result:Promise<object> = keystore.getAllBalances('alias', 'address');\n        let payload:object = {\n            \"result\": {\n                \"balances\": balances\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:object = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(balances);\n    });\n\n    test('getBalance', async ()=>{\n        let balance = 100;\n\n        let result:Promise<number> = keystore.getBalance('alias', 'address', 'ATH');\n        let payload:object = {\n            \"result\": {\n                \"balance\": balance\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:number = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(balance);\n    });\n\n\n    test('getTxHistory', async ()=>{\n        let history = {};\n\n        let result:Promise<object> = keystore.getTxHistory('alias', 'address');\n        let payload:object = {\n            \"result\": history\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:object = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(history);\n    });\n\n    test('importAccount', async ()=>{\n\n        let result:Promise<boolean> = keystore.importAccount(username, 'data', password);\n        let payload:object = {\n            \"result\": {\n                'success': true\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:boolean = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(true);\n    });\n\n\n    test('importKey', async ()=>{\n        let address = 'asdflashdvfalsdf';\n\n        let result:Promise<string> = keystore.importKey(username,password, 'alias', 'key');\n        let payload:object = {\n            \"result\": {\n                'address': address\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(address);\n    });\n\n    test('listAccounts', async ()=>{\n        let accounts = ['acc1','acc2'];\n\n        let result:Promise<Array<string>> = keystore.listAccounts();\n        let payload:object = {\n            \"result\": {\n                'accounts': accounts\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:Array<string> = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(accounts);\n    });\n\n    test('listAddresses', async ()=>{\n        let addresses = ['acc1','acc2'];\n\n        let result:Promise<Array<string>> = keystore.listAddresses(username, 'alias');\n        let payload:object = {\n            \"result\": {\n                'addresses': addresses\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:Array<string> = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(addresses);\n    });\n\n    test('listAssets', async ()=>{\n        let assets = ['ATH','ETH'];\n\n        let result:Promise<Array<string>> = keystore.listAssets(username, 'address');\n        let payload:object = {\n            \"result\": {\n                'assets': assets\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:Array<string> = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(assets);\n    });\n\n\n    test('can ListSubnets', async ()=>{\n        let subnets = ['net1','net2'];\n\n        let result:Promise<Array<string>> = keystore.listSubnets();\n        let payload:object = {\n            \"result\": {\n                'subnetIDs': subnets\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:Array<string> = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(subnets);\n    });\n\n    test('can Send', async ()=>{\n        let txId = 'asdfhvl234';\n\n        let result:Promise<string> = keystore.send(username,password,'alias', 'assetId', 10, 'toAddress', ['fromAddress']);\n        let payload:object = {\n            \"result\": {\n                'txID': txId\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(txId);\n    });\n\n\n\n\n\n});"]} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0cy9hcGlzL2tleXN0b3JlL2FwaS50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0VBQXdDO0FBR3hDLDZCQUE2QjtBQUM3QixnRUFBZ0Q7QUFFaEQsUUFBUSxDQUFDLFVBQVUsRUFBRSxHQUFHLEVBQUU7SUFDdEIsTUFBTSxFQUFFLEdBQUcsV0FBVyxDQUFDO0lBQ3ZCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQztJQUNsQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUM7SUFFekIsSUFBSSxRQUFRLEdBQUcsU0FBUyxDQUFDO0lBQ3pCLElBQUksUUFBUSxHQUFHLFVBQVUsQ0FBQztJQUUxQixJQUFJLE1BQU0sR0FBRyxJQUFJLFlBQU0sQ0FBQyxFQUFFLEVBQUMsSUFBSSxFQUFDLFFBQVEsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQy9ELElBQUksUUFBb0IsQ0FBQztJQUV6QixTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ1gsUUFBUSxHQUFHLElBQUksYUFBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3ZDLENBQUMsQ0FBQyxDQUFDO0lBRUgsU0FBUyxDQUFDLEdBQUcsRUFBRTtRQUNYLHlCQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFJLENBQUMsWUFBWSxFQUFFLEdBQVEsRUFBRTtRQUV6QixJQUFJLE1BQU0sR0FBb0IsUUFBUSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDdEUsSUFBSSxPQUFPLEdBQVU7WUFDakIsUUFBUSxFQUFFO2dCQUNOLFNBQVMsRUFBRSxJQUFJO2FBQ2xCO1NBQ0osQ0FBQztRQUNGLElBQUksV0FBVyxHQUFHO1lBQ2QsSUFBSSxFQUFFLE9BQU87U0FDaEIsQ0FBQztRQUVGLHlCQUFTLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3BDLElBQUksUUFBUSxHQUFXLE1BQU0sTUFBTSxDQUFDO1FBRXBDLE1BQU0sQ0FBQyx5QkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25ELE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEMsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUVILElBQUksQ0FBQyxZQUFZLEVBQUUsR0FBUSxFQUFFO1FBQ3pCLElBQUksSUFBSSxHQUFHLE1BQU0sQ0FBQztRQUVsQixJQUFJLE1BQU0sR0FBbUIsUUFBUSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDckUsSUFBSSxPQUFPLEdBQVU7WUFDakIsUUFBUSxFQUFFO2dCQUNOLE1BQU0sRUFBRSxJQUFJO2FBQ2Y7U0FDSixDQUFDO1FBQ0YsSUFBSSxXQUFXLEdBQUc7WUFDZCxJQUFJLEVBQUUsT0FBTztTQUNoQixDQUFDO1FBRUYseUJBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxRQUFRLEdBQVUsTUFBTSxNQUFNLENBQUM7UUFFbkMsTUFBTSxDQUFDLHlCQUFTLENBQUMsT0FBTyxDQUFDLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkQsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDLENBQUEsQ0FBQyxDQUFDO0lBRUgsSUFBSSxDQUFDLFlBQVksRUFBRSxHQUFRLEVBQUU7UUFFekIsSUFBSSxNQUFNLEdBQW9CLFFBQVEsQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQztRQUM5RSxJQUFJLE9BQU8sR0FBVTtZQUNqQixRQUFRLEVBQUU7Z0JBQ04sU0FBUyxFQUFFLElBQUk7YUFDbEI7U0FDSixDQUFDO1FBQ0YsSUFBSSxXQUFXLEdBQUc7WUFDZCxJQUFJLEVBQUUsT0FBTztTQUNoQixDQUFDO1FBRUYseUJBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxRQUFRLEdBQVcsTUFBTSxNQUFNLENBQUM7UUFFcEMsTUFBTSxDQUFDLHlCQUFTLENBQUMsT0FBTyxDQUFDLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkQsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDLENBQUEsQ0FBQyxDQUFDO0lBRUgsSUFBSSxDQUFDLFdBQVcsRUFBRSxHQUFRLEVBQUU7UUFDeEIsSUFBSSxRQUFRLEdBQUcsQ0FBQyxNQUFNLEVBQUMsTUFBTSxDQUFDLENBQUM7UUFFL0IsSUFBSSxNQUFNLEdBQTBCLFFBQVEsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUN6RCxJQUFJLE9BQU8sR0FBVTtZQUNqQixRQUFRLEVBQUU7Z0JBQ04sT0FBTyxFQUFFLFFBQVE7YUFDcEI7U0FDSixDQUFDO1FBQ0YsSUFBSSxXQUFXLEdBQUc7WUFDZCxJQUFJLEVBQUUsT0FBTztTQUNoQixDQUFDO1FBRUYseUJBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxRQUFRLEdBQWlCLE1BQU0sTUFBTSxDQUFDO1FBRTFDLE1BQU0sQ0FBQyx5QkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25ELE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDcEMsQ0FBQyxDQUFBLENBQUMsQ0FBQztBQUVQLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IG1vY2tBeGlvcyBmcm9tICdqZXN0LW1vY2stYXhpb3MnO1xuXG5cbmltcG9ydCB7IFNsb3BlcyB9IGZyb20gXCJzcmNcIjtcbmltcG9ydCBLZXlzdG9yZUFQSSBmcm9tIFwic3JjL2FwaXMva2V5c3RvcmUvYXBpXCI7XG5cbmRlc2NyaWJlKFwiS2V5c3RvcmVcIiwgKCkgPT4ge1xuICAgIGNvbnN0IGlwID0gJzEyNy4wLjAuMSc7XG4gICAgY29uc3QgcG9ydCA9IDk2NTA7XG4gICAgY29uc3QgcHJvdG9jb2wgPSBcImh0dHBzXCI7XG5cbiAgICBsZXQgdXNlcm5hbWUgPSAnQXZhTGFicyc7XG4gICAgbGV0IHBhc3N3b3JkID0gJ3Bhc3N3b3JkJztcblxuICAgIGxldCBzbG9wZXMgPSBuZXcgU2xvcGVzKGlwLHBvcnQscHJvdG9jb2wsIDQ5LCB1bmRlZmluZWQsIHRydWUpO1xuICAgIGxldCBrZXlzdG9yZTpLZXlzdG9yZUFQSTtcblxuICAgIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgICAgIGtleXN0b3JlID0gbmV3IEtleXN0b3JlQVBJKHNsb3Blcyk7XG4gICAgfSk7XG5cbiAgICBhZnRlckVhY2goKCkgPT4ge1xuICAgICAgICBtb2NrQXhpb3MucmVzZXQoKTtcbiAgICB9KTtcblxuICAgIHRlc3QoXCJjcmVhdGVVc2VyXCIsIGFzeW5jICgpPT57XG5cbiAgICAgICAgbGV0IHJlc3VsdDpQcm9taXNlPGJvb2xlYW4+ID0ga2V5c3RvcmUuY3JlYXRlVXNlcih1c2VybmFtZSwgcGFzc3dvcmQpO1xuICAgICAgICBsZXQgcGF5bG9hZDpvYmplY3QgPSB7XG4gICAgICAgICAgICBcInJlc3VsdFwiOiB7XG4gICAgICAgICAgICAgICAgXCJzdWNjZXNzXCI6IHRydWVcbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICAgICAgbGV0IHJlc3BvbnNlT2JqID0ge1xuICAgICAgICAgICAgZGF0YTogcGF5bG9hZFxuICAgICAgICB9O1xuXG4gICAgICAgIG1vY2tBeGlvcy5tb2NrUmVzcG9uc2UocmVzcG9uc2VPYmopO1xuICAgICAgICBsZXQgcmVzcG9uc2U6Ym9vbGVhbiA9IGF3YWl0IHJlc3VsdDtcblxuICAgICAgICBleHBlY3QobW9ja0F4aW9zLnJlcXVlc3QpLnRvSGF2ZUJlZW5DYWxsZWRUaW1lcygxKTtcbiAgICAgICAgZXhwZWN0KHJlc3BvbnNlKS50b0JlKHRydWUpO1xuICAgIH0pO1xuXG4gICAgdGVzdCgnZXhwb3J0VXNlcicsIGFzeW5jICgpPT57XG4gICAgICAgIGxldCBkYXRhID0gJ2RhdGEnO1xuXG4gICAgICAgIGxldCByZXN1bHQ6UHJvbWlzZTxzdHJpbmc+ID0ga2V5c3RvcmUuZXhwb3J0VXNlcih1c2VybmFtZSwgcGFzc3dvcmQpO1xuICAgICAgICBsZXQgcGF5bG9hZDpvYmplY3QgPSB7XG4gICAgICAgICAgICBcInJlc3VsdFwiOiB7XG4gICAgICAgICAgICAgICAgXCJ1c2VyXCI6IGRhdGFcbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICAgICAgbGV0IHJlc3BvbnNlT2JqID0ge1xuICAgICAgICAgICAgZGF0YTogcGF5bG9hZFxuICAgICAgICB9O1xuXG4gICAgICAgIG1vY2tBeGlvcy5tb2NrUmVzcG9uc2UocmVzcG9uc2VPYmopO1xuICAgICAgICBsZXQgcmVzcG9uc2U6c3RyaW5nID0gYXdhaXQgcmVzdWx0O1xuXG4gICAgICAgIGV4cGVjdChtb2NrQXhpb3MucmVxdWVzdCkudG9IYXZlQmVlbkNhbGxlZFRpbWVzKDEpO1xuICAgICAgICBleHBlY3QocmVzcG9uc2UpLnRvQmUoZGF0YSk7XG4gICAgfSk7XG5cbiAgICB0ZXN0KCdpbXBvcnRVc2VyJywgYXN5bmMgKCk9PntcblxuICAgICAgICBsZXQgcmVzdWx0OlByb21pc2U8Ym9vbGVhbj4gPSBrZXlzdG9yZS5pbXBvcnRVc2VyKHVzZXJuYW1lLCAnZGF0YScsIHBhc3N3b3JkKTtcbiAgICAgICAgbGV0IHBheWxvYWQ6b2JqZWN0ID0ge1xuICAgICAgICAgICAgXCJyZXN1bHRcIjoge1xuICAgICAgICAgICAgICAgICdzdWNjZXNzJzogdHJ1ZVxuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgICAgICBsZXQgcmVzcG9uc2VPYmogPSB7XG4gICAgICAgICAgICBkYXRhOiBwYXlsb2FkXG4gICAgICAgIH07XG5cbiAgICAgICAgbW9ja0F4aW9zLm1vY2tSZXNwb25zZShyZXNwb25zZU9iaik7XG4gICAgICAgIGxldCByZXNwb25zZTpib29sZWFuID0gYXdhaXQgcmVzdWx0O1xuXG4gICAgICAgIGV4cGVjdChtb2NrQXhpb3MucmVxdWVzdCkudG9IYXZlQmVlbkNhbGxlZFRpbWVzKDEpO1xuICAgICAgICBleHBlY3QocmVzcG9uc2UpLnRvQmUodHJ1ZSk7XG4gICAgfSk7XG5cbiAgICB0ZXN0KCdsaXN0VXNlcnMnLCBhc3luYyAoKT0+e1xuICAgICAgICBsZXQgYWNjb3VudHMgPSBbJ2FjYzEnLCdhY2MyJ107XG5cbiAgICAgICAgbGV0IHJlc3VsdDpQcm9taXNlPEFycmF5PHN0cmluZz4+ID0ga2V5c3RvcmUubGlzdFVzZXJzKCk7XG4gICAgICAgIGxldCBwYXlsb2FkOm9iamVjdCA9IHtcbiAgICAgICAgICAgIFwicmVzdWx0XCI6IHtcbiAgICAgICAgICAgICAgICAndXNlcnMnOiBhY2NvdW50c1xuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgICAgICBsZXQgcmVzcG9uc2VPYmogPSB7XG4gICAgICAgICAgICBkYXRhOiBwYXlsb2FkXG4gICAgICAgIH07XG5cbiAgICAgICAgbW9ja0F4aW9zLm1vY2tSZXNwb25zZShyZXNwb25zZU9iaik7XG4gICAgICAgIGxldCByZXNwb25zZTpBcnJheTxzdHJpbmc+ID0gYXdhaXQgcmVzdWx0O1xuXG4gICAgICAgIGV4cGVjdChtb2NrQXhpb3MucmVxdWVzdCkudG9IYXZlQmVlbkNhbGxlZFRpbWVzKDEpO1xuICAgICAgICBleHBlY3QocmVzcG9uc2UpLnRvQmUoYWNjb3VudHMpO1xuICAgIH0pO1xuXG59KTsiXX0= |
@@ -47,7 +47,12 @@ "use strict"; | ||
})); | ||
test("createSubnet", () => __awaiter(void 0, void 0, void 0, function* () { | ||
let result = platform.createSubnet('txId'); | ||
test("createBlockchain", () => __awaiter(void 0, void 0, void 0, function* () { | ||
let blockchainID = "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh"; | ||
let vmID = "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh"; | ||
let name = "Some Blockchain"; | ||
let method = 'avm.Booyashakalah'; | ||
let genesis = { ruh: "roh" }; | ||
let result = platform.createBlockchain(vmID, name, method, genesis); | ||
let payload = { | ||
"result": { | ||
"success": true | ||
"blockchainID": blockchainID | ||
} | ||
@@ -61,4 +66,20 @@ }; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe(true); | ||
expect(response).toBe(blockchainID); | ||
})); | ||
test("getBlockchainStatus", () => __awaiter(void 0, void 0, void 0, function* () { | ||
let blockchainID = "7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh"; | ||
let result = platform.getBlockchainStatus(blockchainID); | ||
let payload = { | ||
"result": { | ||
"status": "Accepted" | ||
} | ||
}; | ||
let responseObj = { | ||
data: payload | ||
}; | ||
jest_mock_axios_1.default.mockResponse(responseObj); | ||
let response = yield result; | ||
expect(jest_mock_axios_1.default.request).toHaveBeenCalledTimes(1); | ||
expect(response).toBe("Accepted"); | ||
})); | ||
test("listValidators", () => __awaiter(void 0, void 0, void 0, function* () { | ||
@@ -97,2 +118,2 @@ let validators = ['val1', 'val2']; | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0cy9hcGlzL3BsYXRmb3JtL2FwaS50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0VBQXdDO0FBR3hDLDZCQUE2QjtBQUM3QixnRUFBZ0Q7QUFFaEQsUUFBUSxDQUFDLFVBQVUsRUFBRSxHQUFHLEVBQUU7SUFDdEIsTUFBTSxFQUFFLEdBQUcsV0FBVyxDQUFDO0lBQ3ZCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQztJQUNsQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUM7SUFFekIsSUFBSSxRQUFRLEdBQUcsU0FBUyxDQUFDO0lBQ3pCLElBQUksUUFBUSxHQUFHLFVBQVUsQ0FBQztJQUUxQixJQUFJLE1BQU0sR0FBRyxJQUFJLFlBQU0sQ0FBQyxFQUFFLEVBQUMsSUFBSSxFQUFDLFFBQVEsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQy9ELElBQUksUUFBb0IsQ0FBQztJQUV6QixTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ1gsUUFBUSxHQUFHLElBQUksYUFBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3ZDLENBQUMsQ0FBQyxDQUFDO0lBRUgsU0FBUyxDQUFDLEdBQUcsRUFBRTtRQUNYLHlCQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFJLENBQUMsV0FBVyxFQUFFLEdBQVEsRUFBRTtRQUV4QixJQUFJLE1BQU0sR0FBb0IsUUFBUSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN6RCxJQUFJLE9BQU8sR0FBVTtZQUNqQixRQUFRLEVBQUU7Z0JBQ04sU0FBUyxFQUFFLElBQUk7YUFDbEI7U0FDSixDQUFDO1FBQ0YsSUFBSSxXQUFXLEdBQUc7WUFDZCxJQUFJLEVBQUUsT0FBTztTQUNoQixDQUFDO1FBRUYseUJBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxRQUFRLEdBQVcsTUFBTSxNQUFNLENBQUM7UUFFcEMsTUFBTSxDQUFDLHlCQUFTLENBQUMsT0FBTyxDQUFDLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkQsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDLENBQUEsQ0FBQyxDQUFDO0lBR0gsSUFBSSxDQUFDLGNBQWMsRUFBRSxHQUFRLEVBQUU7UUFFM0IsSUFBSSxNQUFNLEdBQW9CLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUQsSUFBSSxPQUFPLEdBQVU7WUFDakIsUUFBUSxFQUFFO2dCQUNOLFNBQVMsRUFBRSxJQUFJO2FBQ2xCO1NBQ0osQ0FBQztRQUNGLElBQUksV0FBVyxHQUFHO1lBQ2QsSUFBSSxFQUFFLE9BQU87U0FDaEIsQ0FBQztRQUVGLHlCQUFTLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3BDLElBQUksUUFBUSxHQUFXLE1BQU0sTUFBTSxDQUFDO1FBRXBDLE1BQU0sQ0FBQyx5QkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25ELE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEMsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUVILElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxHQUFRLEVBQUU7UUFFN0IsSUFBSSxVQUFVLEdBQUcsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDbEMsSUFBSSxNQUFNLEdBQTBCLFFBQVEsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUM5RCxJQUFJLE9BQU8sR0FBVTtZQUNqQixRQUFRLEVBQUU7Z0JBQ04sWUFBWSxFQUFFLFVBQVU7YUFDM0I7U0FDSixDQUFDO1FBQ0YsSUFBSSxXQUFXLEdBQUc7WUFDZCxJQUFJLEVBQUUsT0FBTztTQUNoQixDQUFDO1FBRUYseUJBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxRQUFRLEdBQWlCLE1BQU0sTUFBTSxDQUFDO1FBRTFDLE1BQU0sQ0FBQyx5QkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25ELE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEMsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUVILElBQUksQ0FBQyxrQkFBa0IsRUFBRSxHQUFRLEVBQUU7UUFFL0IsSUFBSSxVQUFVLEdBQUcsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDbEMsSUFBSSxNQUFNLEdBQTBCLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNsRSxJQUFJLE9BQU8sR0FBVTtZQUNqQixRQUFRLEVBQUU7Z0JBQ04sWUFBWSxFQUFFLFVBQVU7YUFDM0I7U0FDSixDQUFDO1FBQ0YsSUFBSSxXQUFXLEdBQUc7WUFDZCxJQUFJLEVBQUUsT0FBTztTQUNoQixDQUFDO1FBRUYseUJBQVMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxRQUFRLEdBQWlCLE1BQU0sTUFBTSxDQUFDO1FBRTFDLE1BQU0sQ0FBQyx5QkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25ELE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEMsQ0FBQyxDQUFBLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IG1vY2tBeGlvcyBmcm9tICdqZXN0LW1vY2stYXhpb3MnO1xuXG5cbmltcG9ydCB7IFNsb3BlcyB9IGZyb20gXCJzcmNcIjtcbmltcG9ydCBQbGF0Zm9ybUFQSSBmcm9tIFwic3JjL2FwaXMvcGxhdGZvcm0vYXBpXCI7XG5cbmRlc2NyaWJlKFwiUGxhdGZvcm1cIiwgKCkgPT4ge1xuICAgIGNvbnN0IGlwID0gJzEyNy4wLjAuMSc7XG4gICAgY29uc3QgcG9ydCA9IDk2NTA7XG4gICAgY29uc3QgcHJvdG9jb2wgPSBcImh0dHBzXCI7XG5cbiAgICBsZXQgdXNlcm5hbWUgPSAnQXZhTGFicyc7XG4gICAgbGV0IHBhc3N3b3JkID0gJ3Bhc3N3b3JkJztcblxuICAgIGxldCBzbG9wZXMgPSBuZXcgU2xvcGVzKGlwLHBvcnQscHJvdG9jb2wsIDQ5LCB1bmRlZmluZWQsIHRydWUpO1xuICAgIGxldCBwbGF0Zm9ybTpQbGF0Zm9ybUFQSTtcblxuICAgIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgICAgIHBsYXRmb3JtID0gbmV3IFBsYXRmb3JtQVBJKHNsb3Blcyk7XG4gICAgfSk7XG5cbiAgICBhZnRlckVhY2goKCkgPT4ge1xuICAgICAgICBtb2NrQXhpb3MucmVzZXQoKTtcbiAgICB9KTtcblxuICAgIHRlc3QoXCJhZGRTdGFrZXJcIiwgYXN5bmMgKCk9PntcblxuICAgICAgICBsZXQgcmVzdWx0OlByb21pc2U8Ym9vbGVhbj4gPSBwbGF0Zm9ybS5hZGRTdGFrZXIoJ3R4SWQnKTtcbiAgICAgICAgbGV0IHBheWxvYWQ6b2JqZWN0ID0ge1xuICAgICAgICAgICAgXCJyZXN1bHRcIjoge1xuICAgICAgICAgICAgICAgIFwic3VjY2Vzc1wiOiB0cnVlXG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgICAgIGxldCByZXNwb25zZU9iaiA9IHtcbiAgICAgICAgICAgIGRhdGE6IHBheWxvYWRcbiAgICAgICAgfTtcblxuICAgICAgICBtb2NrQXhpb3MubW9ja1Jlc3BvbnNlKHJlc3BvbnNlT2JqKTtcbiAgICAgICAgbGV0IHJlc3BvbnNlOmJvb2xlYW4gPSBhd2FpdCByZXN1bHQ7XG5cbiAgICAgICAgZXhwZWN0KG1vY2tBeGlvcy5yZXF1ZXN0KS50b0hhdmVCZWVuQ2FsbGVkVGltZXMoMSk7XG4gICAgICAgIGV4cGVjdChyZXNwb25zZSkudG9CZSh0cnVlKTtcbiAgICB9KTtcblxuXG4gICAgdGVzdChcImNyZWF0ZVN1Ym5ldFwiLCBhc3luYyAoKT0+e1xuXG4gICAgICAgIGxldCByZXN1bHQ6UHJvbWlzZTxib29sZWFuPiA9IHBsYXRmb3JtLmNyZWF0ZVN1Ym5ldCgndHhJZCcpO1xuICAgICAgICBsZXQgcGF5bG9hZDpvYmplY3QgPSB7XG4gICAgICAgICAgICBcInJlc3VsdFwiOiB7XG4gICAgICAgICAgICAgICAgXCJzdWNjZXNzXCI6IHRydWVcbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICAgICAgbGV0IHJlc3BvbnNlT2JqID0ge1xuICAgICAgICAgICAgZGF0YTogcGF5bG9hZFxuICAgICAgICB9O1xuXG4gICAgICAgIG1vY2tBeGlvcy5tb2NrUmVzcG9uc2UocmVzcG9uc2VPYmopO1xuICAgICAgICBsZXQgcmVzcG9uc2U6Ym9vbGVhbiA9IGF3YWl0IHJlc3VsdDtcblxuICAgICAgICBleHBlY3QobW9ja0F4aW9zLnJlcXVlc3QpLnRvSGF2ZUJlZW5DYWxsZWRUaW1lcygxKTtcbiAgICAgICAgZXhwZWN0KHJlc3BvbnNlKS50b0JlKHRydWUpO1xuICAgIH0pO1xuXG4gICAgdGVzdChcImxpc3RWYWxpZGF0b3JzXCIsIGFzeW5jICgpPT57XG5cbiAgICAgICAgbGV0IHZhbGlkYXRvcnMgPSBbJ3ZhbDEnLCAndmFsMiddO1xuICAgICAgICBsZXQgcmVzdWx0OlByb21pc2U8QXJyYXk8c3RyaW5nPj4gPSBwbGF0Zm9ybS5saXN0VmFsaWRhdG9ycygpO1xuICAgICAgICBsZXQgcGF5bG9hZDpvYmplY3QgPSB7XG4gICAgICAgICAgICBcInJlc3VsdFwiOiB7XG4gICAgICAgICAgICAgICAgXCJ2YWxpZGF0b3JzXCI6IHZhbGlkYXRvcnNcbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICAgICAgbGV0IHJlc3BvbnNlT2JqID0ge1xuICAgICAgICAgICAgZGF0YTogcGF5bG9hZFxuICAgICAgICB9O1xuXG4gICAgICAgIG1vY2tBeGlvcy5tb2NrUmVzcG9uc2UocmVzcG9uc2VPYmopO1xuICAgICAgICBsZXQgcmVzcG9uc2U6QXJyYXk8c3RyaW5nPiA9IGF3YWl0IHJlc3VsdDtcblxuICAgICAgICBleHBlY3QobW9ja0F4aW9zLnJlcXVlc3QpLnRvSGF2ZUJlZW5DYWxsZWRUaW1lcygxKTtcbiAgICAgICAgZXhwZWN0KHJlc3BvbnNlKS50b0JlKHZhbGlkYXRvcnMpO1xuICAgIH0pO1xuXG4gICAgdGVzdChcInNhbXBsZVZhbGlkYXRvcnNcIiwgYXN5bmMgKCk9PntcblxuICAgICAgICBsZXQgdmFsaWRhdG9ycyA9IFsndmFsMScsICd2YWwyJ107XG4gICAgICAgIGxldCByZXN1bHQ6UHJvbWlzZTxBcnJheTxzdHJpbmc+PiA9IHBsYXRmb3JtLnNhbXBsZVZhbGlkYXRvcnMoMTApO1xuICAgICAgICBsZXQgcGF5bG9hZDpvYmplY3QgPSB7XG4gICAgICAgICAgICBcInJlc3VsdFwiOiB7XG4gICAgICAgICAgICAgICAgXCJ2YWxpZGF0b3JzXCI6IHZhbGlkYXRvcnNcbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICAgICAgbGV0IHJlc3BvbnNlT2JqID0ge1xuICAgICAgICAgICAgZGF0YTogcGF5bG9hZFxuICAgICAgICB9O1xuXG4gICAgICAgIG1vY2tBeGlvcy5tb2NrUmVzcG9uc2UocmVzcG9uc2VPYmopO1xuICAgICAgICBsZXQgcmVzcG9uc2U6QXJyYXk8c3RyaW5nPiA9IGF3YWl0IHJlc3VsdDtcblxuICAgICAgICBleHBlY3QobW9ja0F4aW9zLnJlcXVlc3QpLnRvSGF2ZUJlZW5DYWxsZWRUaW1lcygxKTtcbiAgICAgICAgZXhwZWN0KHJlc3BvbnNlKS50b0JlKHZhbGlkYXRvcnMpO1xuICAgIH0pO1xufSk7Il19 | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.test.js","sourceRoot":"","sources":["../../../../tests/apis/platform/api.test.ts"],"names":[],"mappings":"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","sourcesContent":["import mockAxios from 'jest-mock-axios';\n\n\nimport { Slopes } from \"src\";\nimport PlatformAPI from \"src/apis/platform/api\";\n\ndescribe(\"Platform\", () => {\n    const ip = '127.0.0.1';\n    const port = 9650;\n    const protocol = \"https\";\n\n    let username = 'AvaLabs';\n    let password = 'password';\n\n    let slopes = new Slopes(ip,port,protocol, 49, undefined, true);\n    let platform:PlatformAPI;\n\n    beforeAll(() => {\n        platform = new PlatformAPI(slopes);\n    });\n\n    afterEach(() => {\n        mockAxios.reset();\n    });\n\n    test(\"addStaker\", async ()=>{\n\n        let result:Promise<boolean> = platform.addStaker('txId');\n        let payload:object = {\n            \"result\": {\n                \"success\": true\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:boolean = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(true);\n    });\n\n    test(\"createBlockchain\", async ()=>{\n        let blockchainID:string = \"7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh\";\n        let vmID:string = \"7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh\";\n        let name:string = \"Some Blockchain\";\n        let method:string = 'avm.Booyashakalah';\n        let genesis:object = {ruh:\"roh\"};\n        let result:Promise<string> = platform.createBlockchain(vmID, name, method, genesis);\n        let payload:object = {\n            \"result\": {\n                \"blockchainID\": blockchainID\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(blockchainID);\n    });\n\n    test(\"getBlockchainStatus\", async ()=>{\n\n        let blockchainID:string = \"7sik3Pr6r1FeLrvK1oWwECBS8iJ5VPuSh\";\n        let result:Promise<string> = platform.getBlockchainStatus(blockchainID);\n        let payload:object = {\n            \"result\": {\n                \"status\": \"Accepted\"\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:string = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(\"Accepted\");\n    });\n\n    test(\"listValidators\", async ()=>{\n\n        let validators = ['val1', 'val2'];\n        let result:Promise<Array<string>> = platform.listValidators();\n        let payload:object = {\n            \"result\": {\n                \"validators\": validators\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:Array<string> = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(validators);\n    });\n\n    test(\"sampleValidators\", async ()=>{\n\n        let validators = ['val1', 'val2'];\n        let result:Promise<Array<string>> = platform.sampleValidators(10);\n        let payload:object = {\n            \"result\": {\n                \"validators\": validators\n            }\n        };\n        let responseObj = {\n            data: payload\n        };\n\n        mockAxios.mockResponse(responseObj);\n        let response:Array<string> = await result;\n\n        expect(mockAxios.request).toHaveBeenCalledTimes(1);\n        expect(response).toBe(validators);\n    });\n});"]} |
@@ -14,2 +14,5 @@ "use strict"; | ||
let hexstr3 = "0001020304050607080909080706050403020101"; | ||
let hexbuffstr1 = "000461736466"; // = asdf | ||
let hexbuffstr2 = "000761626364656667"; // = abcdefg | ||
let hexbuffstr3 = "00076f6b0066696e65"; // = ok<null>fineokfine | ||
let b58str = "1UoWww8DGaVGLtea7zU7p"; | ||
@@ -39,2 +42,22 @@ let b58str2 = "1Bhh3pU9gLXZiJv73kmqZwHJ4F"; | ||
}); | ||
test('bufferToString', () => { | ||
let bres = bintools.bufferToString(buffer_1.Buffer.from(hexbuffstr1, "hex")); | ||
expect(bres).toBe(buffer_1.Buffer.from(hexbuffstr1.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres2 = bintools.bufferToString(buffer_1.Buffer.from(hexbuffstr2, "hex")); | ||
expect(bres2).toBe(buffer_1.Buffer.from(hexbuffstr2.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres3 = bintools.bufferToString(buffer_1.Buffer.from(hexbuffstr3, "hex")); | ||
expect(bres3).toBe(buffer_1.Buffer.from(hexbuffstr3.slice(4), "hex").toString("utf8")); | ||
}); | ||
test('stringToBuffer', () => { | ||
let bres = bintools.stringToBuffer("asdf"); | ||
expect(bres.slice(2).toString()).toBe(buffer_1.Buffer.from(hexbuffstr1.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres2 = bintools.stringToBuffer("abcdefg"); | ||
expect(bres2.slice(2).toString()).toBe(buffer_1.Buffer.from(hexbuffstr2.slice(4), "hex").toString("utf8")); | ||
// testing null character edge case | ||
let bres3 = bintools.stringToBuffer(buffer_1.Buffer.from(hexbuffstr3.slice(4), "hex").toString("utf8")); | ||
expect(bres3.slice(2).toString()).toBe(buffer_1.Buffer.from(hexbuffstr3.slice(4), "hex").toString("utf8")); | ||
}); | ||
test('bufferToB58', () => { | ||
@@ -130,2 +153,2 @@ let b58res = bintools.bufferToB58(buff); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bintools.test.js","sourceRoot":"","sources":["../../../tests/utils/bintools.test.ts"],"names":[],"mappings":"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","sourcesContent":["import BinTools  from \"src/utils/bintools\";\nimport BN  from \"bn.js\";\nimport {Buffer} from \"buffer/\";\n\nconst bintools = BinTools.getInstance();\n\ndescribe('BinTools', () => {\n    let hexstr:string = \"00112233445566778899aabbccddeeff\";\n    let hexstr2:string = \"0001020304050607080909080706050403020100\";\n    let hexstr3:string = \"0001020304050607080909080706050403020101\"\n    let b58str:string = \"1UoWww8DGaVGLtea7zU7p\";\n    let b58str2:string = \"1Bhh3pU9gLXZiJv73kmqZwHJ4F\"\n    let b58str3:string = \"1Bhh3pU9gLXZiJv73kmqZwHJ4G\";\n    let buff:Buffer = Buffer.from(hexstr, \"hex\");\n    let buff2:Buffer = Buffer.from(hexstr2, \"hex\");\n    let buff3:Buffer = Buffer.from(hexstr3, \"hex\");\n    let checksum:string = \"323e6811\";\n    let serializedChecksum:string = \"148vjpuxYXixb8DcbaWyeDE2fEG\"; //serialized hexstr + checksum\n    test('copyFrom conducts a true copy', () => {\n        let buff:Buffer = Buffer.from(hexstr, \"hex\");\n        let newbuff:Buffer = bintools.copyFrom(buff, 0, 10);\n        expect(newbuff.length).toBe(10);\n        expect(newbuff.readUInt8(0)).toBe(0);\n        expect(newbuff.readUInt8(9)).toBe(153);\n        //verify that the original buffer isn't touched by writes\n        newbuff.writeUInt8(153, 4);\n        expect(newbuff.readUInt8(4)).toBe(153);\n        expect(buff.readUInt8(4)).toBe(68);\n        //test with no end specified\n        let newbuff2:Buffer = bintools.copyFrom(buff, 2);\n        expect(newbuff2.length).toBe(14);\n        expect(newbuff2.readUInt8(0)).toBe(34);\n        expect(newbuff2.readUInt8(7)).toBe(153);\n    });\n\n    test('bufferToB58', () => {\n        let b58res:string = bintools.bufferToB58(buff);\n        expect(b58res).toBe(b58str);\n        // testing null character edge case\n        let b58res2:string = bintools.bufferToB58(buff2);\n        expect(b58res2).toBe(b58str2);\n        // testing null character edge case\n        let b58res3:string = bintools.bufferToB58(buff3);\n        expect(b58res3).toBe(b58str3);\n    });\n\n    test('b58ToBuffer', () => {\n        expect(() => {\n            bintools.b58ToBuffer(\"0OO0O not a valid b58 string 0OO0O\")\n        }).toThrow(\"Error - Base58.decode: not a valid base58 string\");\n        \n        let buffres:Buffer = bintools.b58ToBuffer(b58str);\n        expect(buffres.toString()).toBe(buff.toString());\n        // testing zeros character edge case\n        let buffres2:Buffer = bintools.b58ToBuffer(b58str2);\n        expect(buffres2.toString()).toBe(buff2.toString());\n        // testing zeros character edge case\n        let buffres3:Buffer = bintools.b58ToBuffer(b58str3);\n        expect(buffres3.toString()).toBe(buff3.toString());\n    });\n\n    test('fromBufferToArrayBuffer', () => {\n        let arrbuff:ArrayBuffer = bintools.fromBufferToArrayBuffer(buff);\n        expect(arrbuff.byteLength).toBe(buff.length);\n        for(let i:number = 0; i < buff.length; i++){\n            expect(arrbuff[i]).toBe(buff[i]);\n        }\n        //verify that the original buffer isn't touched by writes\n        arrbuff[2] = 55;\n        expect(buff[2]).not.toBe(55);\n    });\n\n    test('fromArrayBufferToBuffer', () => {\n        let arrbuff:ArrayBuffer = new ArrayBuffer(10);\n        for(let i:number = 0; i < 10; i++){\n            arrbuff[i] = i;\n        }\n        let newbuff:Buffer = bintools.fromArrayBufferToBuffer(arrbuff);\n        expect(newbuff.length).toBe(arrbuff.byteLength);\n        for(let i:number = 0; i < newbuff.length; i++){\n            expect(newbuff[i]).toBe(arrbuff[i]);\n        }\n        //verify that the original buffer isnt touched by writes\n        newbuff[3] = 55;\n        expect(arrbuff[3]).not.toBe(newbuff[3]);\n    });\n\n    test('fromBufferToBN', () => {\n        let bign:BN = bintools.fromBufferToBN(buff);\n        expect(bign.toString(\"hex\", hexstr.length)).toBe(hexstr);\n    });\n\n    test('fromBNToBuffer', () => {\n        let bn1:BN = new BN(hexstr, \"hex\", \"be\");\n        let bn2:BN = new BN(hexstr, \"hex\", \"be\");\n        let b1:Buffer = bintools.fromBNToBuffer(bn1);\n        let b2:Buffer = bintools.fromBNToBuffer(bn2, buff.length);\n        \n        expect(b1.length).toBe(buff.length - 1);\n        expect(b1.toString(\"hex\")).toBe(hexstr.slice(2));\n\n        expect(b2.length).toBe(buff.length);\n        expect(b2.toString(\"hex\")).toBe(hexstr);\n        \n    });\n\n    test('addChecksum', () => {\n        let buffchecked:Buffer = bintools.addChecksum(buff);\n        expect(buffchecked.length).toBe(buff.length + 4);\n        expect(buffchecked.slice(16).toString(\"hex\")).toBe(checksum);\n    });\n\n    test('validteChecksum', () => {\n        let checksummed:string = hexstr + checksum;\n        let badsummed:string = hexstr + \"324e7822\";\n        expect(bintools.validateChecksum(Buffer.from(checksummed, \"hex\"))).toBe(true);\n        expect(bintools.validateChecksum(buff)).toBe(false);\n        expect(bintools.validateChecksum(Buffer.from(badsummed, \"hex\"))).toBe(false);\n    });\n\n    test('avaSerialize', () => {\n        let fromBuff:string = bintools.avaSerialize(buff);\n        expect(fromBuff).toBe(serializedChecksum);\n    });\n\n    test('avaDeserialize', () => {\n        let serbuff:Buffer = bintools.b58ToBuffer(serializedChecksum);\n        let dsr1:Buffer = bintools.avaDeserialize(serializedChecksum);\n        let dsr2:Buffer = bintools.avaDeserialize(serbuff);\n        let serbufffaulty:Buffer = bintools.copyFrom(serbuff)\n        serbufffaulty[serbufffaulty.length - 1] = serbufffaulty[serbufffaulty.length - 1] - 1;\n        expect(dsr1.toString(\"hex\")).toBe(hexstr);\n        expect(dsr2.toString(\"hex\")).toBe(hexstr);\n        expect(() => {\n            bintools.avaDeserialize(serbufffaulty);\n        }).toThrow(\"Error - BinTools.avaDeserialize: invalid checksum\");\n    });\n});"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bintools.test.js","sourceRoot":"","sources":["../../../tests/utils/bintools.test.ts"],"names":[],"mappings":"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","sourcesContent":["import BinTools  from \"src/utils/bintools\";\nimport BN  from \"bn.js\";\nimport {Buffer} from \"buffer/\";\n\nconst bintools = BinTools.getInstance();\n\ndescribe('BinTools', () => {\n    let hexstr:string = \"00112233445566778899aabbccddeeff\";\n    let hexstr2:string = \"0001020304050607080909080706050403020100\";\n    let hexstr3:string = \"0001020304050607080909080706050403020101\"\n    let hexbuffstr1:string = \"000461736466\"; // = asdf\n    let hexbuffstr2:string = \"000761626364656667\"; // = abcdefg\n    let hexbuffstr3:string = \"00076f6b0066696e65\"; // = ok<null>fineokfine\n    let b58str:string = \"1UoWww8DGaVGLtea7zU7p\";\n    let b58str2:string = \"1Bhh3pU9gLXZiJv73kmqZwHJ4F\"\n    let b58str3:string = \"1Bhh3pU9gLXZiJv73kmqZwHJ4G\";\n    let buff:Buffer = Buffer.from(hexstr, \"hex\");\n    let buff2:Buffer = Buffer.from(hexstr2, \"hex\");\n    let buff3:Buffer = Buffer.from(hexstr3, \"hex\");\n    let checksum:string = \"323e6811\";\n    let serializedChecksum:string = \"148vjpuxYXixb8DcbaWyeDE2fEG\"; //serialized hexstr + checksum\n    test('copyFrom conducts a true copy', () => {\n        let buff:Buffer = Buffer.from(hexstr, \"hex\");\n        let newbuff:Buffer = bintools.copyFrom(buff, 0, 10);\n        expect(newbuff.length).toBe(10);\n        expect(newbuff.readUInt8(0)).toBe(0);\n        expect(newbuff.readUInt8(9)).toBe(153);\n        //verify that the original buffer isn't touched by writes\n        newbuff.writeUInt8(153, 4);\n        expect(newbuff.readUInt8(4)).toBe(153);\n        expect(buff.readUInt8(4)).toBe(68);\n        //test with no end specified\n        let newbuff2:Buffer = bintools.copyFrom(buff, 2);\n        expect(newbuff2.length).toBe(14);\n        expect(newbuff2.readUInt8(0)).toBe(34);\n        expect(newbuff2.readUInt8(7)).toBe(153);\n    });\n\n    test('bufferToString', () => {\n        let bres:string = bintools.bufferToString(Buffer.from(hexbuffstr1, \"hex\"));\n        expect(bres).toBe(Buffer.from(hexbuffstr1.slice(4), \"hex\").toString(\"utf8\"));\n        // testing null character edge case\n        let bres2:string = bintools.bufferToString(Buffer.from(hexbuffstr2, \"hex\"));\n        expect(bres2).toBe(Buffer.from(hexbuffstr2.slice(4), \"hex\").toString(\"utf8\"));\n        // testing null character edge case\n        let bres3:string = bintools.bufferToString(Buffer.from(hexbuffstr3, \"hex\"));\n        expect(bres3).toBe(Buffer.from(hexbuffstr3.slice(4), \"hex\").toString(\"utf8\"));\n    });\n\n    test('stringToBuffer', () => {\n        let bres:Buffer = bintools.stringToBuffer(\"asdf\");\n        expect(bres.slice(2).toString()).toBe(Buffer.from(hexbuffstr1.slice(4), \"hex\").toString(\"utf8\"));\n        // testing null character edge case\n        let bres2:Buffer = bintools.stringToBuffer(\"abcdefg\");\n        expect(bres2.slice(2).toString()).toBe(Buffer.from(hexbuffstr2.slice(4), \"hex\").toString(\"utf8\"));\n        // testing null character edge case\n        let bres3:Buffer = bintools.stringToBuffer(Buffer.from(hexbuffstr3.slice(4), \"hex\").toString(\"utf8\")); \n        expect(bres3.slice(2).toString()).toBe(Buffer.from(hexbuffstr3.slice(4), \"hex\").toString(\"utf8\"));\n    });\n\n    test('bufferToB58', () => {\n        let b58res:string = bintools.bufferToB58(buff);\n        expect(b58res).toBe(b58str);\n        // testing null character edge case\n        let b58res2:string = bintools.bufferToB58(buff2);\n        expect(b58res2).toBe(b58str2);\n        // testing null character edge case\n        let b58res3:string = bintools.bufferToB58(buff3);\n        expect(b58res3).toBe(b58str3);\n    });\n\n    test('b58ToBuffer', () => {\n        expect(() => {\n            bintools.b58ToBuffer(\"0OO0O not a valid b58 string 0OO0O\")\n        }).toThrow(\"Error - Base58.decode: not a valid base58 string\");\n        \n        let buffres:Buffer = bintools.b58ToBuffer(b58str);\n        expect(buffres.toString()).toBe(buff.toString());\n        // testing zeros character edge case\n        let buffres2:Buffer = bintools.b58ToBuffer(b58str2);\n        expect(buffres2.toString()).toBe(buff2.toString());\n        // testing zeros character edge case\n        let buffres3:Buffer = bintools.b58ToBuffer(b58str3);\n        expect(buffres3.toString()).toBe(buff3.toString());\n    });\n\n    test('fromBufferToArrayBuffer', () => {\n        let arrbuff:ArrayBuffer = bintools.fromBufferToArrayBuffer(buff);\n        expect(arrbuff.byteLength).toBe(buff.length);\n        for(let i:number = 0; i < buff.length; i++){\n            expect(arrbuff[i]).toBe(buff[i]);\n        }\n        //verify that the original buffer isn't touched by writes\n        arrbuff[2] = 55;\n        expect(buff[2]).not.toBe(55);\n    });\n\n    test('fromArrayBufferToBuffer', () => {\n        let arrbuff:ArrayBuffer = new ArrayBuffer(10);\n        for(let i:number = 0; i < 10; i++){\n            arrbuff[i] = i;\n        }\n        let newbuff:Buffer = bintools.fromArrayBufferToBuffer(arrbuff);\n        expect(newbuff.length).toBe(arrbuff.byteLength);\n        for(let i:number = 0; i < newbuff.length; i++){\n            expect(newbuff[i]).toBe(arrbuff[i]);\n        }\n        //verify that the original buffer isnt touched by writes\n        newbuff[3] = 55;\n        expect(arrbuff[3]).not.toBe(newbuff[3]);\n    });\n\n    test('fromBufferToBN', () => {\n        let bign:BN = bintools.fromBufferToBN(buff);\n        expect(bign.toString(\"hex\", hexstr.length)).toBe(hexstr);\n    });\n\n    test('fromBNToBuffer', () => {\n        let bn1:BN = new BN(hexstr, \"hex\", \"be\");\n        let bn2:BN = new BN(hexstr, \"hex\", \"be\");\n        let b1:Buffer = bintools.fromBNToBuffer(bn1);\n        let b2:Buffer = bintools.fromBNToBuffer(bn2, buff.length);\n        \n        expect(b1.length).toBe(buff.length - 1);\n        expect(b1.toString(\"hex\")).toBe(hexstr.slice(2));\n\n        expect(b2.length).toBe(buff.length);\n        expect(b2.toString(\"hex\")).toBe(hexstr);\n        \n    });\n\n    test('addChecksum', () => {\n        let buffchecked:Buffer = bintools.addChecksum(buff);\n        expect(buffchecked.length).toBe(buff.length + 4);\n        expect(buffchecked.slice(16).toString(\"hex\")).toBe(checksum);\n    });\n\n    test('validteChecksum', () => {\n        let checksummed:string = hexstr + checksum;\n        let badsummed:string = hexstr + \"324e7822\";\n        expect(bintools.validateChecksum(Buffer.from(checksummed, \"hex\"))).toBe(true);\n        expect(bintools.validateChecksum(buff)).toBe(false);\n        expect(bintools.validateChecksum(Buffer.from(badsummed, \"hex\"))).toBe(false);\n    });\n\n    test('avaSerialize', () => {\n        let fromBuff:string = bintools.avaSerialize(buff);\n        expect(fromBuff).toBe(serializedChecksum);\n    });\n\n    test('avaDeserialize', () => {\n        let serbuff:Buffer = bintools.b58ToBuffer(serializedChecksum);\n        let dsr1:Buffer = bintools.avaDeserialize(serializedChecksum);\n        let dsr2:Buffer = bintools.avaDeserialize(serbuff);\n        let serbufffaulty:Buffer = bintools.copyFrom(serbuff)\n        serbufffaulty[serbufffaulty.length - 1] = serbufffaulty[serbufffaulty.length - 1] - 1;\n        expect(dsr1.toString(\"hex\")).toBe(hexstr);\n        expect(dsr2.toString(\"hex\")).toBe(hexstr);\n        expect(() => {\n            bintools.avaDeserialize(serbufffaulty);\n        }).toThrow(\"Error - BinTools.avaDeserialize: invalid checksum\");\n    });\n});"]} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
2715102
15123