Comparing version 1.3.17 to 1.3.18
{ | ||
"name": "slopes", | ||
"version": "1.3.17", | ||
"version": "1.3.18", | ||
"description": "AVA Platform JS Library", | ||
@@ -5,0 +5,0 @@ "main": "typings/src/index.js", |
@@ -490,12 +490,8 @@ /** | ||
let n49_avm = Object.assign({}, n2_avm); | ||
n49_avm["blockchainID"] = "tHLiSpCwUQQVZ6W4GMjVzx5JiFRgZBrniTBqaxFLdqBJKk8YN"; | ||
let n49_platform = Object.assign({}, n2_avm); | ||
let n49_contracts = Object.assign({}, n2_avm); | ||
let n12345_avm:object = Object.assign({}, n2_avm); | ||
n12345_avm["blockchainID"] = "ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK"; | ||
let n12345_platform = Object.assign({}, n2_avm); | ||
let n12345_contracts = Object.assign({}, n2_avm); | ||
n12345_avm["blockchainID"] = "i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m"; | ||
let n12345_platform = Object.assign({}, n2_platform); | ||
n12345_platform["blockchainID"] = "11111111111111111111111111111111LpoYY"; | ||
let n12345_contracts = Object.assign({}, n2_contracts); | ||
n12345_platform["blockchainID"] = "MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb"; | ||
@@ -522,11 +518,11 @@ export class Defaults { | ||
"X": n12345_avm, | ||
"ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK": n12345_avm, | ||
"i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m": n12345_avm, | ||
"platform": n12345_platform, | ||
"P": n12345_platform, | ||
"BCID1": n12345_platform, | ||
"11111111111111111111111111111111LpoYY": n12345_platform, | ||
"contracts": n12345_contracts, | ||
"C": n12345_contracts, | ||
"BCID2": n12345_contracts | ||
"MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb": n12345_contracts | ||
} | ||
}; | ||
} |
@@ -23,3 +23,3 @@ import mockAxios from 'jest-mock-axios'; | ||
const networkid:number = 12345; | ||
const blockchainid:string = "ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK"; | ||
const blockchainid:string = "i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m"; | ||
const ip:string = '127.0.0.1'; | ||
@@ -26,0 +26,0 @@ const port:number = 9650; |
@@ -297,9 +297,9 @@ /// <reference types="node" /> | ||
"X": object; | ||
"ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK": object; | ||
"i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m": object; | ||
"platform": {} & object; | ||
"P": {} & object; | ||
"BCID1": {} & object; | ||
"11111111111111111111111111111111LpoYY": {} & object; | ||
"contracts": {} & object; | ||
"C": {} & object; | ||
"BCID2": {} & object; | ||
"MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb": {} & object; | ||
}; | ||
@@ -306,0 +306,0 @@ }; |
@@ -365,10 +365,8 @@ "use strict"; | ||
}; | ||
let n49_avm = Object.assign({}, n2_avm); | ||
n49_avm["blockchainID"] = "tHLiSpCwUQQVZ6W4GMjVzx5JiFRgZBrniTBqaxFLdqBJKk8YN"; | ||
let n49_platform = Object.assign({}, n2_avm); | ||
let n49_contracts = Object.assign({}, n2_avm); | ||
let n12345_avm = Object.assign({}, n2_avm); | ||
n12345_avm["blockchainID"] = "ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK"; | ||
let n12345_platform = Object.assign({}, n2_avm); | ||
let n12345_contracts = Object.assign({}, n2_avm); | ||
n12345_avm["blockchainID"] = "i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m"; | ||
let n12345_platform = Object.assign({}, n2_platform); | ||
n12345_platform["blockchainID"] = "11111111111111111111111111111111LpoYY"; | ||
let n12345_contracts = Object.assign({}, n2_contracts); | ||
n12345_platform["blockchainID"] = "MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb"; | ||
class Defaults { | ||
@@ -396,11 +394,11 @@ } | ||
"X": n12345_avm, | ||
"ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK": n12345_avm, | ||
"i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m": n12345_avm, | ||
"platform": n12345_platform, | ||
"P": n12345_platform, | ||
"BCID1": n12345_platform, | ||
"11111111111111111111111111111111LpoYY": n12345_platform, | ||
"contracts": n12345_contracts, | ||
"C": n12345_contracts, | ||
"BCID2": n12345_contracts | ||
"MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb": n12345_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/bc/avm\"\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/bc/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/bc/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\": \"m383Jyn4z9kYmyMamjHwoExocRRV7ondsci862bbv1FSrqvH9\",\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\nlet n49_avm = Object.assign({}, n2_avm);\nn49_avm[\"blockchainID\"] = \"tHLiSpCwUQQVZ6W4GMjVzx5JiFRgZBrniTBqaxFLdqBJKk8YN\";\nlet n49_platform = Object.assign({}, n2_avm);\nlet n49_contracts = Object.assign({}, n2_avm);\n\n\nlet n12345_avm:object = Object.assign({}, n2_avm);\nn12345_avm[\"blockchainID\"] = \"ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK\";\nlet n12345_platform = Object.assign({}, n2_avm);\nlet n12345_contracts = Object.assign({}, n2_avm);\n\nexport class Defaults {\n    static network = {\n        \"1\": {}, //update before mainnet\n        /* \n        This will be set on test network.\n        \"2\": {\n            \"avm\": n2_avm,\n            \"X\": n2_avm,\n            \"m383Jyn4z9kYmyMamjHwoExocRRV7ondsci862bbv1FSrqvH9\": 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        \"12345\": {\n            \"avm\": n12345_avm,\n            \"X\": n12345_avm,\n            \"ddV3GvdmdeQkaxLRo9LH5AbDNyU9bDu6SqWak7x9UXMbupksK\": n12345_avm,\n            \"platform\": n12345_platform,\n            \"P\": n12345_platform,\n            \"BCID1\": n12345_platform,\n            \"contracts\": n12345_contracts,\n            \"C\": n12345_contracts,\n            \"BCID2\": n12345_contracts\n        }\n    };\n}"]} | ||
//# 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/bc/avm\"\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/bc/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/bc/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\": \"m383Jyn4z9kYmyMamjHwoExocRRV7ondsci862bbv1FSrqvH9\",\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\nlet n12345_avm:object = Object.assign({}, n2_avm);\nn12345_avm[\"blockchainID\"] = \"i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m\";\nlet n12345_platform = Object.assign({}, n2_platform);\nn12345_platform[\"blockchainID\"] = \"11111111111111111111111111111111LpoYY\";\nlet n12345_contracts = Object.assign({}, n2_contracts);\nn12345_platform[\"blockchainID\"] = \"MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb\";\n\nexport class Defaults {\n    static network = {\n        \"1\": {}, //update before mainnet\n        /* \n        This will be set on test network.\n        \"2\": {\n            \"avm\": n2_avm,\n            \"X\": n2_avm,\n            \"m383Jyn4z9kYmyMamjHwoExocRRV7ondsci862bbv1FSrqvH9\": 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        \"12345\": {\n            \"avm\": n12345_avm,\n            \"X\": n12345_avm,\n            \"i8KtK2KwLi1o7WaVBbEKpRLPtAEYayfoptqAFYxfQgrus1g6m\": n12345_avm,\n            \"platform\": n12345_platform,\n            \"P\": n12345_platform,\n            \"11111111111111111111111111111111LpoYY\": n12345_platform,\n            \"contracts\": n12345_contracts,\n            \"C\": n12345_contracts,\n            \"MTHoZAP3gGHB4cAUpFB1CuYnh3uDoMkte6FjLb9Sn5Hx8Bkvb\": n12345_contracts\n        }\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
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
9889167
16677