UNPKG

@gmsol-labs/gmsol-sdk

Version:

GMX-Solana is an extension of GMX on the Solana blockchain.

1,622 lines (1,518 loc) 75.2 kB
let wasm; export function __wbg_set_wasm(val) { wasm = val; } let WASM_VECTOR_LEN = 0; let cachedUint8ArrayMemory0 = null; function getUint8ArrayMemory0() { if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) { cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer); } return cachedUint8ArrayMemory0; } const lTextEncoder = typeof TextEncoder === 'undefined' ? (0, module.require)('util').TextEncoder : TextEncoder; let cachedTextEncoder = new lTextEncoder('utf-8'); const encodeString = (typeof cachedTextEncoder.encodeInto === 'function' ? function (arg, view) { return cachedTextEncoder.encodeInto(arg, view); } : function (arg, view) { const buf = cachedTextEncoder.encode(arg); view.set(buf); return { read: arg.length, written: buf.length }; }); function passStringToWasm0(arg, malloc, realloc) { if (realloc === undefined) { const buf = cachedTextEncoder.encode(arg); const ptr = malloc(buf.length, 1) >>> 0; getUint8ArrayMemory0().subarray(ptr, ptr + buf.length).set(buf); WASM_VECTOR_LEN = buf.length; return ptr; } let len = arg.length; let ptr = malloc(len, 1) >>> 0; const mem = getUint8ArrayMemory0(); let offset = 0; for (; offset < len; offset++) { const code = arg.charCodeAt(offset); if (code > 0x7F) break; mem[ptr + offset] = code; } if (offset !== len) { if (offset !== 0) { arg = arg.slice(offset); } ptr = realloc(ptr, len, len = offset + arg.length * 3, 1) >>> 0; const view = getUint8ArrayMemory0().subarray(ptr + offset, ptr + len); const ret = encodeString(arg, view); offset += ret.written; ptr = realloc(ptr, len, offset, 1) >>> 0; } WASM_VECTOR_LEN = offset; return ptr; } let cachedDataViewMemory0 = null; function getDataViewMemory0() { if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) { cachedDataViewMemory0 = new DataView(wasm.memory.buffer); } return cachedDataViewMemory0; } function addToExternrefTable0(obj) { const idx = wasm.__externref_table_alloc(); wasm.__wbindgen_export_4.set(idx, obj); return idx; } function handleError(f, args) { try { return f.apply(this, args); } catch (e) { const idx = addToExternrefTable0(e); wasm.__wbindgen_exn_store(idx); } } const lTextDecoder = typeof TextDecoder === 'undefined' ? (0, module.require)('util').TextDecoder : TextDecoder; let cachedTextDecoder = new lTextDecoder('utf-8', { ignoreBOM: true, fatal: true }); cachedTextDecoder.decode(); function getStringFromWasm0(ptr, len) { ptr = ptr >>> 0; return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len)); } function getArrayU8FromWasm0(ptr, len) { ptr = ptr >>> 0; return getUint8ArrayMemory0().subarray(ptr / 1, ptr / 1 + len); } function isLikeNone(x) { return x === undefined || x === null; } function debugString(val) { // primitive types const type = typeof val; if (type == 'number' || type == 'boolean' || val == null) { return `${val}`; } if (type == 'string') { return `"${val}"`; } if (type == 'symbol') { const description = val.description; if (description == null) { return 'Symbol'; } else { return `Symbol(${description})`; } } if (type == 'function') { const name = val.name; if (typeof name == 'string' && name.length > 0) { return `Function(${name})`; } else { return 'Function'; } } // objects if (Array.isArray(val)) { const length = val.length; let debug = '['; if (length > 0) { debug += debugString(val[0]); } for(let i = 1; i < length; i++) { debug += ', ' + debugString(val[i]); } debug += ']'; return debug; } // Test for built-in const builtInMatches = /\[object ([^\]]+)\]/.exec(toString.call(val)); let className; if (builtInMatches && builtInMatches.length > 1) { className = builtInMatches[1]; } else { // Failed to match the standard '[object ClassName]' return toString.call(val); } if (className == 'Object') { // we're a user defined class or Object // JSON.stringify avoids problems with cycles, and is generally much // easier than looping through ownProperties of `val`. try { return 'Object(' + JSON.stringify(val) + ')'; } catch (_) { return 'Object'; } } // errors if (val instanceof Error) { return `${val.name}: ${val.message}\n${val.stack}`; } // TODO we could test for more things here, like `Set`s and `Map`s. return className; } /** * Get default [`StoreProgram`]. * @returns {StoreProgram} */ export function default_store_program() { const ret = wasm.default_store_program(); return ret; } function takeFromExternrefTable0(idx) { const value = wasm.__wbindgen_export_4.get(idx); wasm.__externref_table_dealloc(idx); return value; } function passArray8ToWasm0(arg, malloc) { const ptr = malloc(arg.length * 1, 1) >>> 0; getUint8ArrayMemory0().set(arg, ptr / 1); WASM_VECTOR_LEN = arg.length; return ptr; } function getArrayJsValueFromWasm0(ptr, len) { ptr = ptr >>> 0; const mem = getDataViewMemory0(); const result = []; for (let i = ptr; i < ptr + 4 * len; i += 4) { result.push(wasm.__wbindgen_export_4.get(mem.getUint32(i, true))); } wasm.__externref_drop_slice(ptr, len); return result; } function _assertClass(instance, klass) { if (!(instance instanceof klass)) { throw new Error(`expected instance of ${klass.name}`); } } function passArrayJsValueToWasm0(array, malloc) { const ptr = malloc(array.length * 4, 4) >>> 0; for (let i = 0; i < array.length; i++) { const add = addToExternrefTable0(array[i]); getDataViewMemory0().setUint32(ptr + 4 * i, add, true); } WASM_VECTOR_LEN = array.length; return ptr; } /** * Create transaction builder for create-order ixs. * @param {CreateOrderKind} kind * @param {CreateOrderParams[]} orders * @param {CreateOrderOptions} options * @returns {CreateOrdersBuilder} */ export function create_orders_builder(kind, orders, options) { const ptr0 = passArrayJsValueToWasm0(orders, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.create_orders_builder(kind, ptr0, len0, options); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return CreateOrdersBuilder.__wrap(ret[0]); } /** * Build transactions for creating orders. * @param {CreateOrderKind} kind * @param {CreateOrderParams[]} orders * @param {CreateOrderOptions} options * @returns {TransactionGroup} */ export function create_orders(kind, orders, options) { const ptr0 = passArrayJsValueToWasm0(orders, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.create_orders(kind, ptr0, len0, options); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return TransactionGroup.__wrap(ret[0]); } /** * Build transactions for closing orders. * @param {CloseOrderArgs} args * @returns {TransactionGroup} */ export function close_orders(args) { const ret = wasm.close_orders(args); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return TransactionGroup.__wrap(ret[0]); } /** * Build transactions for updating orders. * @param {UpdateOrderArgs} args * @returns {TransactionGroup} */ export function update_orders(args) { const ret = wasm.update_orders(args); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return TransactionGroup.__wrap(ret[0]); } /** * Apply `factor` to the `value`. * @param {bigint} value * @param {bigint} factor * @returns {bigint | undefined} */ export function apply_factor(value, factor) { const ret = wasm.apply_factor(value, value >> BigInt(64), factor, factor >> BigInt(64)); return ret[0] === 0 ? undefined : (BigInt.asUintN(64, ret[1]) | (BigInt.asUintN(64, ret[2]) << BigInt(64))); } /** * Initialize Javascript logging and panic handler */ export function solana_program_init() { wasm.solana_program_init(); } const CreateOrdersBuilderFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_createordersbuilder_free(ptr >>> 0, 1)); /** * Builder for create-order ixs. */ export class CreateOrdersBuilder { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(CreateOrdersBuilder.prototype); obj.__wbg_ptr = ptr; CreateOrdersBuilderFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; CreateOrdersBuilderFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_createordersbuilder_free(ptr, 0); } /** * Build transactions. * @param {TransactionGroupOptions | null} [transaction_group] * @param {BuildTransactionOptions | null} [build] * @returns {TransactionGroup} */ build_with_options(transaction_group, build) { const ptr = this.__destroy_into_raw(); const ret = wasm.createordersbuilder_build_with_options(ptr, isLikeNone(transaction_group) ? 0 : addToExternrefTable0(transaction_group), isLikeNone(build) ? 0 : addToExternrefTable0(build)); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return TransactionGroup.__wrap(ret[0]); } /** * Merge with the other [`CreateOrderBuilder`]. * @param {CreateOrdersBuilder} other */ merge(other) { _assertClass(other, CreateOrdersBuilder); const ret = wasm.createordersbuilder_merge(this.__wbg_ptr, other.__wbg_ptr); if (ret[1]) { throw takeFromExternrefTable0(ret[0]); } } } const ElGamalKeypairFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_elgamalkeypair_free(ptr >>> 0, 1)); /** * A (twisted) ElGamal encryption keypair. * * The instances of the secret key are zeroized on drop. */ export class ElGamalKeypair { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(ElGamalKeypair.prototype); obj.__wbg_ptr = ptr; ElGamalKeypairFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; ElGamalKeypairFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_elgamalkeypair_free(ptr, 0); } /** * Generates the public and secret keys for ElGamal encryption. * * This function is randomized. It internally samples a scalar element using `OsRng`. * @returns {ElGamalKeypair} */ static new_rand() { const ret = wasm.elgamalkeypair_new_rand(); return ElGamalKeypair.__wrap(ret); } /** * @returns {ElGamalPubkey} */ pubkey_owned() { const ret = wasm.elgamalkeypair_pubkey_owned(this.__wbg_ptr); return ElGamalPubkey.__wrap(ret); } } const ElGamalPubkeyFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_elgamalpubkey_free(ptr >>> 0, 1)); /** * Public key for the ElGamal encryption scheme. */ export class ElGamalPubkey { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(ElGamalPubkey.prototype); obj.__wbg_ptr = ptr; ElGamalPubkeyFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; ElGamalPubkeyFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_elgamalpubkey_free(ptr, 0); } } const HashFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_hash_free(ptr >>> 0, 1)); /** * A hash; the 32-byte output of a hashing algorithm. * * This struct is used most often in `solana-sdk` and related crates to contain * a [SHA-256] hash, but may instead contain a [blake3] hash. * * [SHA-256]: https://en.wikipedia.org/wiki/SHA-2 * [blake3]: https://github.com/BLAKE3-team/BLAKE3 */ export class Hash { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Hash.prototype); obj.__wbg_ptr = ptr; HashFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; HashFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_hash_free(ptr, 0); } /** * Create a new Hash object * * * `value` - optional hash as a base58 encoded string, `Uint8Array`, `[number]` * @param {any} value */ constructor(value) { const ret = wasm.hash_constructor(value); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } this.__wbg_ptr = ret[0] >>> 0; HashFinalization.register(this, this.__wbg_ptr, this); return this; } /** * Return the base58 string representation of the hash * @returns {string} */ toString() { let deferred1_0; let deferred1_1; try { const ret = wasm.hash_toString(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } /** * Checks if two `Hash`s are equal * @param {Hash} other * @returns {boolean} */ equals(other) { _assertClass(other, Hash); const ret = wasm.hash_equals(this.__wbg_ptr, other.__wbg_ptr); return ret !== 0; } /** * Return the `Uint8Array` representation of the hash * @returns {Uint8Array} */ toBytes() { const ret = wasm.hash_toBytes(this.__wbg_ptr); var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice(); wasm.__wbindgen_free(ret[0], ret[1] * 1, 1); return v1; } } const InstructionFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_instruction_free(ptr >>> 0, 1)); /** * wasm-bindgen version of the Instruction struct. * This duplication is required until https://github.com/rustwasm/wasm-bindgen/issues/3671 * is fixed. This must not diverge from the regular non-wasm Instruction struct. */ export class Instruction { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Instruction.prototype); obj.__wbg_ptr = ptr; InstructionFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; InstructionFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_instruction_free(ptr, 0); } } const InstructionsFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_instructions_free(ptr >>> 0, 1)); export class Instructions { __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; InstructionsFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_instructions_free(ptr, 0); } constructor() { const ret = wasm.instructions_constructor(); this.__wbg_ptr = ret >>> 0; InstructionsFinalization.register(this, this.__wbg_ptr, this); return this; } /** * @param {Instruction} instruction */ push(instruction) { _assertClass(instruction, Instruction); var ptr0 = instruction.__destroy_into_raw(); wasm.instructions_push(this.__wbg_ptr, ptr0); } } const KeypairFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_keypair_free(ptr >>> 0, 1)); /** * A vanilla Ed25519 key pair */ export class Keypair { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Keypair.prototype); obj.__wbg_ptr = ptr; KeypairFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; KeypairFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_keypair_free(ptr, 0); } /** * Create a new `Keypair ` */ constructor() { const ret = wasm.keypair_constructor(); this.__wbg_ptr = ret >>> 0; KeypairFinalization.register(this, this.__wbg_ptr, this); return this; } /** * Convert a `Keypair` to a `Uint8Array` * @returns {Uint8Array} */ toBytes() { const ret = wasm.keypair_toBytes(this.__wbg_ptr); var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice(); wasm.__wbindgen_free(ret[0], ret[1] * 1, 1); return v1; } /** * Recover a `Keypair` from a `Uint8Array` * @param {Uint8Array} bytes * @returns {Keypair} */ static fromBytes(bytes) { const ptr0 = passArray8ToWasm0(bytes, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.keypair_fromBytes(ptr0, len0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Keypair.__wrap(ret[0]); } /** * Return the `Pubkey` for this `Keypair` * @returns {Pubkey} */ pubkey() { const ret = wasm.keypair_pubkey(this.__wbg_ptr); return Pubkey.__wrap(ret); } } const MarketFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_market_free(ptr >>> 0, 1)); /** * Wrapper of [`Market`]. */ export class Market { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Market.prototype); obj.__wbg_ptr = ptr; MarketFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; MarketFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_market_free(ptr, 0); } /** * Create from base64 encoded account data with options. * @param {string} data * @param {boolean | null} [no_discriminator] * @returns {Market} */ static decode_from_base64_with_options(data, no_discriminator) { const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.market_decode_from_base64_with_options(ptr0, len0, isLikeNone(no_discriminator) ? 0xFFFFFF : no_discriminator ? 1 : 0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Market.__wrap(ret[0]); } /** * Create from base64 encoded account data. * @param {string} data * @returns {Market} */ static decode_from_base64(data) { const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.market_decode_from_base64(ptr0, len0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Market.__wrap(ret[0]); } /** * Create from account data. * @param {Uint8Array} data * @returns {Market} */ static decode(data) { const ptr0 = passArray8ToWasm0(data, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.market_decode(ptr0, len0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Market.__wrap(ret[0]); } /** * Convert into [`JsMarketModel`] * @param {bigint} supply * @returns {MarketModel} */ to_model(supply) { const ret = wasm.market_to_model(this.__wbg_ptr, supply); return MarketModel.__wrap(ret); } /** * Get market token address. * @returns {string} */ market_token_address() { let deferred1_0; let deferred1_1; try { const ret = wasm.market_market_token_address(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } /** * Get index token address. * @returns {string} */ index_token_address() { let deferred1_0; let deferred1_1; try { const ret = wasm.market_index_token_address(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } /** * Get long token address. * @returns {string} */ long_token_address() { let deferred1_0; let deferred1_1; try { const ret = wasm.market_long_token_address(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } /** * Get short token address. * @returns {string} */ short_token_address() { let deferred1_0; let deferred1_1; try { const ret = wasm.market_short_token_address(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } } const MarketGraphFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_marketgraph_free(ptr >>> 0, 1)); /** * A JS binding for [`MarketGraph`]. */ export class MarketGraph { __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; MarketGraphFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_marketgraph_free(ptr, 0); } /** * Create an empty market graph. * @param {MarketGraphConfig} config */ constructor(config) { const ret = wasm.marketgraph_new(config); this.__wbg_ptr = ret >>> 0; MarketGraphFinalization.register(this, this.__wbg_ptr, this); return this; } /** * Insert market from base64 encoded data. * @param {string} data * @param {bigint} supply * @returns {boolean} */ insert_market_from_base64(data, supply) { const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.marketgraph_insert_market_from_base64(this.__wbg_ptr, ptr0, len0, supply); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return ret[0] !== 0; } /** * Update token price. * @param {string} token * @param {Value} price */ update_token_price(token, price) { const ptr0 = passStringToWasm0(token, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.marketgraph_update_token_price(this.__wbg_ptr, ptr0, len0, price); if (ret[1]) { throw takeFromExternrefTable0(ret[0]); } } /** * Update value. * @param {bigint} value */ update_value(value) { wasm.marketgraph_update_value(this.__wbg_ptr, value, value >> BigInt(64)); } /** * Update base cost. * @param {bigint} base_cost */ update_base_cost(base_cost) { wasm.marketgraph_update_base_cost(this.__wbg_ptr, base_cost, base_cost >> BigInt(64)); } /** * Update max steps. * @param {number} max_steps */ update_max_steps(max_steps) { wasm.marketgraph_update_max_steps(this.__wbg_ptr, max_steps); } /** * Get market by its market token. * @param {string} market_token * @returns {MarketModel | undefined} */ get_market(market_token) { const ptr0 = passStringToWasm0(market_token, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.marketgraph_get_market(this.__wbg_ptr, ptr0, len0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return ret[0] === 0 ? undefined : MarketModel.__wrap(ret[0]); } /** * Get all market tokens. * @returns {string[]} */ market_tokens() { const ret = wasm.marketgraph_market_tokens(this.__wbg_ptr); var v1 = getArrayJsValueFromWasm0(ret[0], ret[1]).slice(); wasm.__wbindgen_free(ret[0], ret[1] * 4, 4); return v1; } /** * Get all index tokens. * @returns {string[]} */ index_tokens() { const ret = wasm.marketgraph_index_tokens(this.__wbg_ptr); var v1 = getArrayJsValueFromWasm0(ret[0], ret[1]).slice(); wasm.__wbindgen_free(ret[0], ret[1] * 4, 4); return v1; } /** * Compute best swap path. * @param {string} source * @param {string} target * @param {boolean} skip_bellman_ford * @returns {BestSwapPath} */ best_swap_path(source, target, skip_bellman_ford) { const ptr0 = passStringToWasm0(source, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ptr1 = passStringToWasm0(target, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len1 = WASM_VECTOR_LEN; const ret = wasm.marketgraph_best_swap_path(this.__wbg_ptr, ptr0, len0, ptr1, len1, skip_bellman_ford); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } /** * Simulates order execution. * @param {SimulateOrderArgs} args * @param {Position | null} [position] * @returns {OrderSimulationOutput} */ simulate_order(args, position) { let ptr0 = 0; if (!isLikeNone(position)) { _assertClass(position, Position); ptr0 = position.__destroy_into_raw(); } const ret = wasm.marketgraph_simulate_order(this.__wbg_ptr, args, ptr0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return OrderSimulationOutput.__wrap(ret[0]); } } const MarketModelFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_marketmodel_free(ptr >>> 0, 1)); /** * Wrapper of [`MarketModel`]. */ export class MarketModel { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(MarketModel.prototype); obj.__wbg_ptr = ptr; MarketModelFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; MarketModelFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_marketmodel_free(ptr, 0); } /** * Get market token price. * @param {MarketTokenPriceParams} params * @returns {bigint} */ market_token_price(params) { const ret = wasm.marketmodel_market_token_price(this.__wbg_ptr, params); if (ret[3]) { throw takeFromExternrefTable0(ret[2]); } return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64))); } /** * Get market status. * @param {MarketStatusParams} params * @returns {MarketStatus} */ status(params) { const ret = wasm.marketmodel_status(this.__wbg_ptr, params); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } } const MessageFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_message_free(ptr >>> 0, 1)); /** * wasm-bindgen version of the Message struct. * This duplication is required until https://github.com/rustwasm/wasm-bindgen/issues/3671 * is fixed. This must not diverge from the regular non-wasm Message struct. */ export class Message { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Message.prototype); obj.__wbg_ptr = ptr; MessageFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; MessageFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_message_free(ptr, 0); } /** * The id of a recent ledger entry. * @returns {Hash} */ get recent_blockhash() { const ret = wasm.__wbg_get_message_recent_blockhash(this.__wbg_ptr); return Hash.__wrap(ret); } /** * The id of a recent ledger entry. * @param {Hash} arg0 */ set recent_blockhash(arg0) { _assertClass(arg0, Hash); var ptr0 = arg0.__destroy_into_raw(); wasm.__wbg_set_message_recent_blockhash(this.__wbg_ptr, ptr0); } } const OrderSimulationOutputFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_ordersimulationoutput_free(ptr >>> 0, 1)); /** * A JS binding for [`OrderSimulationOutput`]. */ export class OrderSimulationOutput { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(OrderSimulationOutput.prototype); obj.__wbg_ptr = ptr; OrderSimulationOutputFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; OrderSimulationOutputFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_ordersimulationoutput_free(ptr, 0); } /** * Returns increase order simulation output. * @returns {IncreaseOrderSimulationOutput | undefined} */ increase() { const ret = wasm.ordersimulationoutput_increase(this.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } /** * Returns decrease order simulation output. * @returns {DecreaseOrderSimulationOutput | undefined} */ decrease() { const ret = wasm.ordersimulationoutput_decrease(this.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } /** * Returns swap order simulation output. * @returns {SwapOrderSimulationOutput | undefined} */ swap() { const ret = wasm.ordersimulationoutput_swap(this.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } } const PodElGamalPubkeyFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_podelgamalpubkey_free(ptr >>> 0, 1)); /** * The `ElGamalPubkey` type as a `Pod`. */ export class PodElGamalPubkey { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(PodElGamalPubkey.prototype); obj.__wbg_ptr = ptr; PodElGamalPubkeyFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; PodElGamalPubkeyFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_podelgamalpubkey_free(ptr, 0); } /** * Create a new `PodElGamalPubkey` object * * * `value` - optional public key as a base64 encoded string, `Uint8Array`, `[number]` * @param {any} value */ constructor(value) { const ret = wasm.podelgamalpubkey_constructor(value); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } this.__wbg_ptr = ret[0] >>> 0; PodElGamalPubkeyFinalization.register(this, this.__wbg_ptr, this); return this; } /** * Return the base64 string representation of the public key * @returns {string} */ toString() { let deferred1_0; let deferred1_1; try { const ret = wasm.podelgamalpubkey_toString(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } /** * Checks if two `ElGamalPubkey`s are equal * @param {PodElGamalPubkey} other * @returns {boolean} */ equals(other) { _assertClass(other, PodElGamalPubkey); const ret = wasm.podelgamalpubkey_equals(this.__wbg_ptr, other.__wbg_ptr); return ret !== 0; } /** * Return the `Uint8Array` representation of the public key * @returns {Uint8Array} */ toBytes() { const ret = wasm.podelgamalpubkey_toBytes(this.__wbg_ptr); var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice(); wasm.__wbindgen_free(ret[0], ret[1] * 1, 1); return v1; } /** * @param {ElGamalPubkey} decoded * @returns {PodElGamalPubkey} */ static compressed(decoded) { _assertClass(decoded, ElGamalPubkey); const ret = wasm.podelgamalpubkey_compressed(decoded.__wbg_ptr); return PodElGamalPubkey.__wrap(ret); } /** * @returns {ElGamalPubkey} */ decompressed() { const ret = wasm.podelgamalpubkey_decompressed(this.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return ElGamalPubkey.__wrap(ret[0]); } } const PositionFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_position_free(ptr >>> 0, 1)); /** * JS version of [`Position`]. */ export class Position { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Position.prototype); obj.__wbg_ptr = ptr; PositionFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; PositionFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_position_free(ptr, 0); } /** * Create from base64 encoded account data with options. * @param {string} data * @param {boolean | null} [no_discriminator] * @returns {Position} */ static decode_from_base64_with_options(data, no_discriminator) { const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.position_decode_from_base64_with_options(ptr0, len0, isLikeNone(no_discriminator) ? 0xFFFFFF : no_discriminator ? 1 : 0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Position.__wrap(ret[0]); } /** * Create from base64 encoded account data. * @param {string} data * @returns {Position} */ static decode_from_base64(data) { const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.position_decode_from_base64(ptr0, len0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Position.__wrap(ret[0]); } /** * Create from account data. * @param {Uint8Array} data * @returns {Position} */ static decode(data) { const ptr0 = passArray8ToWasm0(data, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; const ret = wasm.position_decode(ptr0, len0); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Position.__wrap(ret[0]); } /** * Convert to a [`JsPositionModel`]. * @param {MarketModel} market * @returns {PositionModel} */ to_model(market) { _assertClass(market, MarketModel); const ret = wasm.position_to_model(this.__wbg_ptr, market.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return PositionModel.__wrap(ret[0]); } } const PositionModelFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_positionmodel_free(ptr >>> 0, 1)); /** * JS version of [`PositionModel`]. */ export class PositionModel { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(PositionModel.prototype); obj.__wbg_ptr = ptr; PositionModelFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; PositionModelFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_positionmodel_free(ptr, 0); } /** * Get position status. * @param {Prices} prices * @returns {PositionStatus} */ status(prices) { const ret = wasm.positionmodel_status(this.__wbg_ptr, prices); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } /** * Get position size. * @returns {bigint} */ size() { const ret = wasm.positionmodel_size(this.__wbg_ptr); return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64))); } /** * Get position size in tokens. * @returns {bigint} */ size_in_tokens() { const ret = wasm.positionmodel_size_in_tokens(this.__wbg_ptr); return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64))); } /** * Get collateral amount. * @returns {bigint} */ collateral_amount() { const ret = wasm.positionmodel_collateral_amount(this.__wbg_ptr); return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64))); } /** * Returns the inner [`JsPosition`]. * @returns {Position} */ position() { const ret = wasm.positionmodel_position(this.__wbg_ptr); return Position.__wrap(ret); } } const PubkeyFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_pubkey_free(ptr >>> 0, 1)); /** * The address of a [Solana account][acc]. * * Some account addresses are [ed25519] public keys, with corresponding secret * keys that are managed off-chain. Often, though, account addresses do not * have corresponding secret keys &mdash; as with [_program derived * addresses_][pdas] &mdash; or the secret key is not relevant to the operation * of a program, and may have even been disposed of. As running Solana programs * can not safely create or manage secret keys, the full [`Keypair`] is not * defined in `solana-program` but in `solana-sdk`. * * [acc]: https://solana.com/docs/core/accounts * [ed25519]: https://ed25519.cr.yp.to/ * [pdas]: https://solana.com/docs/core/cpi#program-derived-addresses * [`Keypair`]: https://docs.rs/solana-sdk/latest/solana_sdk/signer/keypair/struct.Keypair.html */ export class Pubkey { static __wrap(ptr) { ptr = ptr >>> 0; const obj = Object.create(Pubkey.prototype); obj.__wbg_ptr = ptr; PubkeyFinalization.register(obj, obj.__wbg_ptr, obj); return obj; } __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; PubkeyFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_pubkey_free(ptr, 0); } /** * Create a new Pubkey object * * * `value` - optional public key as a base58 encoded string, `Uint8Array`, `[number]` * @param {any} value */ constructor(value) { const ret = wasm.pubkey_constructor(value); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } this.__wbg_ptr = ret[0] >>> 0; PubkeyFinalization.register(this, this.__wbg_ptr, this); return this; } /** * Return the base58 string representation of the public key * @returns {string} */ toString() { let deferred1_0; let deferred1_1; try { const ret = wasm.pubkey_toString(this.__wbg_ptr); deferred1_0 = ret[0]; deferred1_1 = ret[1]; return getStringFromWasm0(ret[0], ret[1]); } finally { wasm.__wbindgen_free(deferred1_0, deferred1_1, 1); } } /** * Check if a `Pubkey` is on the ed25519 curve. * @returns {boolean} */ isOnCurve() { const ret = wasm.pubkey_isOnCurve(this.__wbg_ptr); return ret !== 0; } /** * Checks if two `Pubkey`s are equal * @param {Pubkey} other * @returns {boolean} */ equals(other) { _assertClass(other, Pubkey); const ret = wasm.pubkey_equals(this.__wbg_ptr, other.__wbg_ptr); return ret !== 0; } /** * Return the `Uint8Array` representation of the public key * @returns {Uint8Array} */ toBytes() { const ret = wasm.pubkey_toBytes(this.__wbg_ptr); var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice(); wasm.__wbindgen_free(ret[0], ret[1] * 1, 1); return v1; } /** * Derive a Pubkey from another Pubkey, string seed, and a program id * @param {Pubkey} base * @param {string} seed * @param {Pubkey} owner * @returns {Pubkey} */ static createWithSeed(base, seed, owner) { _assertClass(base, Pubkey); const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; _assertClass(owner, Pubkey); const ret = wasm.pubkey_createWithSeed(base.__wbg_ptr, ptr0, len0, owner.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Pubkey.__wrap(ret[0]); } /** * Derive a program address from seeds and a program id * @param {any[]} seeds * @param {Pubkey} program_id * @returns {Pubkey} */ static createProgramAddress(seeds, program_id) { const ptr0 = passArrayJsValueToWasm0(seeds, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; _assertClass(program_id, Pubkey); const ret = wasm.pubkey_createProgramAddress(ptr0, len0, program_id.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return Pubkey.__wrap(ret[0]); } /** * Find a valid program address * * Returns: * * `[PubKey, number]` - the program address and bump seed * @param {any[]} seeds * @param {Pubkey} program_id * @returns {any} */ static findProgramAddress(seeds, program_id) { const ptr0 = passArrayJsValueToWasm0(seeds, wasm.__wbindgen_malloc); const len0 = WASM_VECTOR_LEN; _assertClass(program_id, Pubkey); const ret = wasm.pubkey_findProgramAddress(ptr0, len0, program_id.__wbg_ptr); if (ret[2]) { throw takeFromExternrefTable0(ret[1]); } return takeFromExternrefTable0(ret[0]); } } const SystemInstructionFinalization = (typeof FinalizationRegistry === 'undefined') ? { register: () => {}, unregister: () => {} } : new FinalizationRegistry(ptr => wasm.__wbg_systeminstruction_free(ptr >>> 0, 1)); export class SystemInstruction { __destroy_into_raw() { const ptr = this.__wbg_ptr; this.__wbg_ptr = 0; SystemInstructionFinalization.unregister(this); return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_systeminstruction_free(ptr, 0); } /** * @param {Pubkey} from_pubkey * @param {Pubkey} to_pubkey * @param {bigint} lamports * @param {bigint} space * @param {Pubkey} owner * @returns {Instruction} */ static createAccount(from_pubkey, to_pubkey, lamports, space, owner) { _assertClass(from_pubkey, Pubkey); _assertClass(to_pubkey, Pubkey); _assertClass(owner, Pubkey); const ret = wasm.systeminstruction_createAccount(from_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, lamports, space, owner.__wbg_ptr); return Instruction.__wrap(ret); } /** * @param {Pubkey} from_pubkey * @param {Pubkey} to_pubkey * @param {Pubkey} base * @param {string} seed * @param {bigint} lamports * @param {bigint} space * @param {Pubkey} owner * @returns {Instruction} */ static createAccountWithSeed(from_pubkey, to_pubkey, base, seed, lamports, space, owner) { _assertClass(from_pubkey, Pubkey); _assertClass(to_pubkey, Pubkey); _assertClass(base, Pubkey); const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; _assertClass(owner, Pubkey); const ret = wasm.systeminstruction_createAccountWithSeed(from_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, base.__wbg_ptr, ptr0, len0, lamports, space, owner.__wbg_ptr); return Instruction.__wrap(ret); } /** * @param {Pubkey} pubkey * @param {Pubkey} owner * @returns {Instruction} */ static assign(pubkey, owner) { _assertClass(pubkey, Pubkey); _assertClass(owner, Pubkey); const ret = wasm.systeminstruction_assign(pubkey.__wbg_ptr, owner.__wbg_ptr); return Instruction.__wrap(ret); } /** * @param {Pubkey} pubkey * @param {Pubkey} base * @param {string} seed * @param {Pubkey} owner * @returns {Instruction} */ static assignWithSeed(pubkey, base, seed, owner) { _assertClass(pubkey, Pubkey); _assertClass(base, Pubkey); const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc); const len0 = WASM_VECTOR_LEN; _assertClass(owner, Pubkey); const ret = wasm.systeminstruction_assignWithSeed(pubkey.__wbg_ptr, base.__wbg_ptr, ptr0, len0, owner.__wbg_ptr); return Instruction.__wrap(ret); } /** * @param {Pubkey} from_pubkey * @param {Pubkey} to_pubkey * @param {bigint} lamports * @returns {Instruction} */ static transfer(from_pubkey, to_pubkey, lamports) { _assertClass(from_pubkey, Pubkey); _assertClass(to_pubkey, Pubkey); const ret = wasm.systeminstruction_transfer(from_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, lamports); return Instruction.__wrap(ret); } /** * @param {Pubkey} from_pubkey * @param {Pubkey} from_base * @param {string} from