import { Cell, Slice, Address, Builder, beginCell, ComputeError, TupleItem, TupleReader, Dictionary, contractAddress, ContractProvider, Sender, Contract, ContractABI, TupleBuilder, DictionaryValue } from 'ton-core'; import { ContractSystem, ContractExecutor } from 'ton-emulator'; export type StateInit = { $$type: 'StateInit'; code: Cell; data: Cell; } export function storeStateInit(src: StateInit) { return (builder: Builder) => { let b_0 = builder; b_0.storeRef(src.code); b_0.storeRef(src.data); }; } export function loadStateInit(slice: Slice) { let sc_0 = slice; let _code = sc_0.loadRef(); let _data = sc_0.loadRef(); return { $$type: 'StateInit' as const, code: _code, data: _data }; } function loadTupleStateInit(source: TupleReader) { let _code = source.readCell(); let _data = source.readCell(); return { $$type: 'StateInit' as const, code: _code, data: _data }; } function storeTupleStateInit(source: StateInit) { let builder = new TupleBuilder(); builder.writeCell(source.code); builder.writeCell(source.data); return builder.build(); } function dictValueParserStateInit(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeStateInit(src)).endCell()); }, parse: (src) => { return loadStateInit(src.loadRef().beginParse()); } } } export type Context = { $$type: 'Context'; bounced: boolean; sender: Address; value: bigint; raw: Cell; } export function storeContext(src: Context) { return (builder: Builder) => { let b_0 = builder; b_0.storeBit(src.bounced); b_0.storeAddress(src.sender); b_0.storeInt(src.value, 257); b_0.storeRef(src.raw); }; } export function loadContext(slice: Slice) { let sc_0 = slice; let _bounced = sc_0.loadBit(); let _sender = sc_0.loadAddress(); let _value = sc_0.loadIntBig(257); let _raw = sc_0.loadRef(); return { $$type: 'Context' as const, bounced: _bounced, sender: _sender, value: _value, raw: _raw }; } function loadTupleContext(source: TupleReader) { let _bounced = source.readBoolean(); let _sender = source.readAddress(); let _value = source.readBigNumber(); let _raw = source.readCell(); return { $$type: 'Context' as const, bounced: _bounced, sender: _sender, value: _value, raw: _raw }; } function storeTupleContext(source: Context) { let builder = new TupleBuilder(); builder.writeBoolean(source.bounced); builder.writeAddress(source.sender); builder.writeNumber(source.value); builder.writeSlice(source.raw); return builder.build(); } function dictValueParserContext(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeContext(src)).endCell()); }, parse: (src) => { return loadContext(src.loadRef().beginParse()); } } } export type SendParameters = { $$type: 'SendParameters'; bounce: boolean; to: Address; value: bigint; mode: bigint; body: Cell | null; code: Cell | null; data: Cell | null; } export function storeSendParameters(src: SendParameters) { return (builder: Builder) => { let b_0 = builder; b_0.storeBit(src.bounce); b_0.storeAddress(src.to); b_0.storeInt(src.value, 257); b_0.storeInt(src.mode, 257); if (src.body !== null && src.body !== undefined) { b_0.storeBit(true).storeRef(src.body); } else { b_0.storeBit(false); } if (src.code !== null && src.code !== undefined) { b_0.storeBit(true).storeRef(src.code); } else { b_0.storeBit(false); } if (src.data !== null && src.data !== undefined) { b_0.storeBit(true).storeRef(src.data); } else { b_0.storeBit(false); } }; } export function loadSendParameters(slice: Slice) { let sc_0 = slice; let _bounce = sc_0.loadBit(); let _to = sc_0.loadAddress(); let _value = sc_0.loadIntBig(257); let _mode = sc_0.loadIntBig(257); let _body = sc_0.loadBit() ? sc_0.loadRef() : null; let _code = sc_0.loadBit() ? sc_0.loadRef() : null; let _data = sc_0.loadBit() ? sc_0.loadRef() : null; return { $$type: 'SendParameters' as const, bounce: _bounce, to: _to, value: _value, mode: _mode, body: _body, code: _code, data: _data }; } function loadTupleSendParameters(source: TupleReader) { let _bounce = source.readBoolean(); let _to = source.readAddress(); let _value = source.readBigNumber(); let _mode = source.readBigNumber(); let _body = source.readCellOpt(); let _code = source.readCellOpt(); let _data = source.readCellOpt(); return { $$type: 'SendParameters' as const, bounce: _bounce, to: _to, value: _value, mode: _mode, body: _body, code: _code, data: _data }; } function storeTupleSendParameters(source: SendParameters) { let builder = new TupleBuilder(); builder.writeBoolean(source.bounce); builder.writeAddress(source.to); builder.writeNumber(source.value); builder.writeNumber(source.mode); builder.writeCell(source.body); builder.writeCell(source.code); builder.writeCell(source.data); return builder.build(); } function dictValueParserSendParameters(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeSendParameters(src)).endCell()); }, parse: (src) => { return loadSendParameters(src.loadRef().beginParse()); } } } export type TokenTransfer = { $$type: 'TokenTransfer'; queryId: bigint; amount: bigint; destination: Address; responseDestination: Address | null; customPayload: Cell | null; forwardTonAmount: bigint; forwardPayload: Cell; } export function storeTokenTransfer(src: TokenTransfer) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(260734629, 32); b_0.storeUint(src.queryId, 64); b_0.storeCoins(src.amount); b_0.storeAddress(src.destination); b_0.storeAddress(src.responseDestination); if (src.customPayload !== null && src.customPayload !== undefined) { b_0.storeBit(true).storeRef(src.customPayload); } else { b_0.storeBit(false); } b_0.storeCoins(src.forwardTonAmount); b_0.storeBuilder(src.forwardPayload.asBuilder()); }; } export function loadTokenTransfer(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 260734629) { throw Error('Invalid prefix'); } let _queryId = sc_0.loadUintBig(64); let _amount = sc_0.loadCoins(); let _destination = sc_0.loadAddress(); let _responseDestination = sc_0.loadMaybeAddress(); let _customPayload = sc_0.loadBit() ? sc_0.loadRef() : null; let _forwardTonAmount = sc_0.loadCoins(); let _forwardPayload = sc_0.asCell(); return { $$type: 'TokenTransfer' as const, queryId: _queryId, amount: _amount, destination: _destination, responseDestination: _responseDestination, customPayload: _customPayload, forwardTonAmount: _forwardTonAmount, forwardPayload: _forwardPayload }; } function loadTupleTokenTransfer(source: TupleReader) { let _queryId = source.readBigNumber(); let _amount = source.readBigNumber(); let _destination = source.readAddress(); let _responseDestination = source.readAddressOpt(); let _customPayload = source.readCellOpt(); let _forwardTonAmount = source.readBigNumber(); let _forwardPayload = source.readCell(); return { $$type: 'TokenTransfer' as const, queryId: _queryId, amount: _amount, destination: _destination, responseDestination: _responseDestination, customPayload: _customPayload, forwardTonAmount: _forwardTonAmount, forwardPayload: _forwardPayload }; } function storeTupleTokenTransfer(source: TokenTransfer) { let builder = new TupleBuilder(); builder.writeNumber(source.queryId); builder.writeNumber(source.amount); builder.writeAddress(source.destination); builder.writeAddress(source.responseDestination); builder.writeCell(source.customPayload); builder.writeNumber(source.forwardTonAmount); builder.writeSlice(source.forwardPayload); return builder.build(); } function dictValueParserTokenTransfer(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenTransfer(src)).endCell()); }, parse: (src) => { return loadTokenTransfer(src.loadRef().beginParse()); } } } export type TokenTransferInternal = { $$type: 'TokenTransferInternal'; queryId: bigint; amount: bigint; from: Address; responseAddress: Address | null; forwardTonAmount: bigint; forwardPayload: Cell; setLinker: bigint | null; setLinkerAddress: Address | null; } export function storeTokenTransferInternal(src: TokenTransferInternal) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(395134233, 32); b_0.storeUint(src.queryId, 64); b_0.storeCoins(src.amount); b_0.storeAddress(src.from); b_0.storeAddress(src.responseAddress); b_0.storeCoins(src.forwardTonAmount); b_0.storeBuilder(src.forwardPayload.asBuilder()); let b_1 = new Builder(); if (src.setLinker !== null && src.setLinker !== undefined) { b_1.storeBit(true).storeInt(src.setLinker, 257); } else { b_1.storeBit(false); } b_1.storeAddress(src.setLinkerAddress); b_0.storeRef(b_1.endCell()); }; } export function loadTokenTransferInternal(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 395134233) { throw Error('Invalid prefix'); } let _queryId = sc_0.loadUintBig(64); let _amount = sc_0.loadCoins(); let _from = sc_0.loadAddress(); let _responseAddress = sc_0.loadMaybeAddress(); let _forwardTonAmount = sc_0.loadCoins(); let _forwardPayload = sc_0.asCell(); let sc_1 = sc_0.loadRef().beginParse(); let _setLinker = sc_1.loadBit() ? sc_1.loadIntBig(257) : null; let _setLinkerAddress = sc_1.loadMaybeAddress(); return { $$type: 'TokenTransferInternal' as const, queryId: _queryId, amount: _amount, from: _from, responseAddress: _responseAddress, forwardTonAmount: _forwardTonAmount, forwardPayload: _forwardPayload, setLinker: _setLinker, setLinkerAddress: _setLinkerAddress }; } function loadTupleTokenTransferInternal(source: TupleReader) { let _queryId = source.readBigNumber(); let _amount = source.readBigNumber(); let _from = source.readAddress(); let _responseAddress = source.readAddressOpt(); let _forwardTonAmount = source.readBigNumber(); let _forwardPayload = source.readCell(); let _setLinker = source.readBigNumberOpt(); let _setLinkerAddress = source.readAddressOpt(); return { $$type: 'TokenTransferInternal' as const, queryId: _queryId, amount: _amount, from: _from, responseAddress: _responseAddress, forwardTonAmount: _forwardTonAmount, forwardPayload: _forwardPayload, setLinker: _setLinker, setLinkerAddress: _setLinkerAddress }; } function storeTupleTokenTransferInternal(source: TokenTransferInternal) { let builder = new TupleBuilder(); builder.writeNumber(source.queryId); builder.writeNumber(source.amount); builder.writeAddress(source.from); builder.writeAddress(source.responseAddress); builder.writeNumber(source.forwardTonAmount); builder.writeSlice(source.forwardPayload); builder.writeNumber(source.setLinker); builder.writeAddress(source.setLinkerAddress); return builder.build(); } function dictValueParserTokenTransferInternal(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenTransferInternal(src)).endCell()); }, parse: (src) => { return loadTokenTransferInternal(src.loadRef().beginParse()); } } } export type TokenNotification = { $$type: 'TokenNotification'; queryId: bigint; amount: bigint; from: Address; forwardPayload: Cell; } export function storeTokenNotification(src: TokenNotification) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(1935855772, 32); b_0.storeUint(src.queryId, 64); b_0.storeCoins(src.amount); b_0.storeAddress(src.from); b_0.storeBuilder(src.forwardPayload.asBuilder()); }; } export function loadTokenNotification(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 1935855772) { throw Error('Invalid prefix'); } let _queryId = sc_0.loadUintBig(64); let _amount = sc_0.loadCoins(); let _from = sc_0.loadAddress(); let _forwardPayload = sc_0.asCell(); return { $$type: 'TokenNotification' as const, queryId: _queryId, amount: _amount, from: _from, forwardPayload: _forwardPayload }; } function loadTupleTokenNotification(source: TupleReader) { let _queryId = source.readBigNumber(); let _amount = source.readBigNumber(); let _from = source.readAddress(); let _forwardPayload = source.readCell(); return { $$type: 'TokenNotification' as const, queryId: _queryId, amount: _amount, from: _from, forwardPayload: _forwardPayload }; } function storeTupleTokenNotification(source: TokenNotification) { let builder = new TupleBuilder(); builder.writeNumber(source.queryId); builder.writeNumber(source.amount); builder.writeAddress(source.from); builder.writeSlice(source.forwardPayload); return builder.build(); } function dictValueParserTokenNotification(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenNotification(src)).endCell()); }, parse: (src) => { return loadTokenNotification(src.loadRef().beginParse()); } } } export type TokenBurn = { $$type: 'TokenBurn'; queryId: bigint; amount: bigint; owner: Address; responseAddress: Address | null; } export function storeTokenBurn(src: TokenBurn) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(1499400124, 32); b_0.storeUint(src.queryId, 64); b_0.storeCoins(src.amount); b_0.storeAddress(src.owner); b_0.storeAddress(src.responseAddress); }; } export function loadTokenBurn(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 1499400124) { throw Error('Invalid prefix'); } let _queryId = sc_0.loadUintBig(64); let _amount = sc_0.loadCoins(); let _owner = sc_0.loadAddress(); let _responseAddress = sc_0.loadMaybeAddress(); return { $$type: 'TokenBurn' as const, queryId: _queryId, amount: _amount, owner: _owner, responseAddress: _responseAddress }; } function loadTupleTokenBurn(source: TupleReader) { let _queryId = source.readBigNumber(); let _amount = source.readBigNumber(); let _owner = source.readAddress(); let _responseAddress = source.readAddressOpt(); return { $$type: 'TokenBurn' as const, queryId: _queryId, amount: _amount, owner: _owner, responseAddress: _responseAddress }; } function storeTupleTokenBurn(source: TokenBurn) { let builder = new TupleBuilder(); builder.writeNumber(source.queryId); builder.writeNumber(source.amount); builder.writeAddress(source.owner); builder.writeAddress(source.responseAddress); return builder.build(); } function dictValueParserTokenBurn(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenBurn(src)).endCell()); }, parse: (src) => { return loadTokenBurn(src.loadRef().beginParse()); } } } export type TokenBurnNotification = { $$type: 'TokenBurnNotification'; queryId: bigint; amount: bigint; owner: Address; responseAddress: Address | null; } export function storeTokenBurnNotification(src: TokenBurnNotification) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(2078119902, 32); b_0.storeUint(src.queryId, 64); b_0.storeCoins(src.amount); b_0.storeAddress(src.owner); b_0.storeAddress(src.responseAddress); }; } export function loadTokenBurnNotification(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 2078119902) { throw Error('Invalid prefix'); } let _queryId = sc_0.loadUintBig(64); let _amount = sc_0.loadCoins(); let _owner = sc_0.loadAddress(); let _responseAddress = sc_0.loadMaybeAddress(); return { $$type: 'TokenBurnNotification' as const, queryId: _queryId, amount: _amount, owner: _owner, responseAddress: _responseAddress }; } function loadTupleTokenBurnNotification(source: TupleReader) { let _queryId = source.readBigNumber(); let _amount = source.readBigNumber(); let _owner = source.readAddress(); let _responseAddress = source.readAddressOpt(); return { $$type: 'TokenBurnNotification' as const, queryId: _queryId, amount: _amount, owner: _owner, responseAddress: _responseAddress }; } function storeTupleTokenBurnNotification(source: TokenBurnNotification) { let builder = new TupleBuilder(); builder.writeNumber(source.queryId); builder.writeNumber(source.amount); builder.writeAddress(source.owner); builder.writeAddress(source.responseAddress); return builder.build(); } function dictValueParserTokenBurnNotification(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenBurnNotification(src)).endCell()); }, parse: (src) => { return loadTokenBurnNotification(src.loadRef().beginParse()); } } } export type TokenExcesses = { $$type: 'TokenExcesses'; queryId: bigint; } export function storeTokenExcesses(src: TokenExcesses) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(3576854235, 32); b_0.storeUint(src.queryId, 64); }; } export function loadTokenExcesses(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 3576854235) { throw Error('Invalid prefix'); } let _queryId = sc_0.loadUintBig(64); return { $$type: 'TokenExcesses' as const, queryId: _queryId }; } function loadTupleTokenExcesses(source: TupleReader) { let _queryId = source.readBigNumber(); return { $$type: 'TokenExcesses' as const, queryId: _queryId }; } function storeTupleTokenExcesses(source: TokenExcesses) { let builder = new TupleBuilder(); builder.writeNumber(source.queryId); return builder.build(); } function dictValueParserTokenExcesses(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenExcesses(src)).endCell()); }, parse: (src) => { return loadTokenExcesses(src.loadRef().beginParse()); } } } export type TokenUpdateContent = { $$type: 'TokenUpdateContent'; content: Cell | null; } export function storeTokenUpdateContent(src: TokenUpdateContent) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(201882270, 32); if (src.content !== null && src.content !== undefined) { b_0.storeBit(true).storeRef(src.content); } else { b_0.storeBit(false); } }; } export function loadTokenUpdateContent(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 201882270) { throw Error('Invalid prefix'); } let _content = sc_0.loadBit() ? sc_0.loadRef() : null; return { $$type: 'TokenUpdateContent' as const, content: _content }; } function loadTupleTokenUpdateContent(source: TupleReader) { let _content = source.readCellOpt(); return { $$type: 'TokenUpdateContent' as const, content: _content }; } function storeTupleTokenUpdateContent(source: TokenUpdateContent) { let builder = new TupleBuilder(); builder.writeCell(source.content); return builder.build(); } function dictValueParserTokenUpdateContent(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeTokenUpdateContent(src)).endCell()); }, parse: (src) => { return loadTokenUpdateContent(src.loadRef().beginParse()); } } } export type JettonData = { $$type: 'JettonData'; totalSupply: bigint; mintable: boolean; owner: Address; content: Cell | null; walletCode: Cell; } export function storeJettonData(src: JettonData) { return (builder: Builder) => { let b_0 = builder; b_0.storeInt(src.totalSupply, 257); b_0.storeBit(src.mintable); b_0.storeAddress(src.owner); if (src.content !== null && src.content !== undefined) { b_0.storeBit(true).storeRef(src.content); } else { b_0.storeBit(false); } b_0.storeRef(src.walletCode); }; } export function loadJettonData(slice: Slice) { let sc_0 = slice; let _totalSupply = sc_0.loadIntBig(257); let _mintable = sc_0.loadBit(); let _owner = sc_0.loadAddress(); let _content = sc_0.loadBit() ? sc_0.loadRef() : null; let _walletCode = sc_0.loadRef(); return { $$type: 'JettonData' as const, totalSupply: _totalSupply, mintable: _mintable, owner: _owner, content: _content, walletCode: _walletCode }; } function loadTupleJettonData(source: TupleReader) { let _totalSupply = source.readBigNumber(); let _mintable = source.readBoolean(); let _owner = source.readAddress(); let _content = source.readCellOpt(); let _walletCode = source.readCell(); return { $$type: 'JettonData' as const, totalSupply: _totalSupply, mintable: _mintable, owner: _owner, content: _content, walletCode: _walletCode }; } function storeTupleJettonData(source: JettonData) { let builder = new TupleBuilder(); builder.writeNumber(source.totalSupply); builder.writeBoolean(source.mintable); builder.writeAddress(source.owner); builder.writeCell(source.content); builder.writeCell(source.walletCode); return builder.build(); } function dictValueParserJettonData(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeJettonData(src)).endCell()); }, parse: (src) => { return loadJettonData(src.loadRef().beginParse()); } } } export type JettonWalletData = { $$type: 'JettonWalletData'; balance: bigint; owner: Address; master: Address; walletCode: Cell; } export function storeJettonWalletData(src: JettonWalletData) { return (builder: Builder) => { let b_0 = builder; b_0.storeInt(src.balance, 257); b_0.storeAddress(src.owner); b_0.storeAddress(src.master); b_0.storeRef(src.walletCode); }; } export function loadJettonWalletData(slice: Slice) { let sc_0 = slice; let _balance = sc_0.loadIntBig(257); let _owner = sc_0.loadAddress(); let _master = sc_0.loadAddress(); let _walletCode = sc_0.loadRef(); return { $$type: 'JettonWalletData' as const, balance: _balance, owner: _owner, master: _master, walletCode: _walletCode }; } function loadTupleJettonWalletData(source: TupleReader) { let _balance = source.readBigNumber(); let _owner = source.readAddress(); let _master = source.readAddress(); let _walletCode = source.readCell(); return { $$type: 'JettonWalletData' as const, balance: _balance, owner: _owner, master: _master, walletCode: _walletCode }; } function storeTupleJettonWalletData(source: JettonWalletData) { let builder = new TupleBuilder(); builder.writeNumber(source.balance); builder.writeAddress(source.owner); builder.writeAddress(source.master); builder.writeCell(source.walletCode); return builder.build(); } function dictValueParserJettonWalletData(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeJettonWalletData(src)).endCell()); }, parse: (src) => { return loadJettonWalletData(src.loadRef().beginParse()); } } } export type SetLinkerNeighbor = { $$type: 'SetLinkerNeighbor'; neighbor: Address | null; } export function storeSetLinkerNeighbor(src: SetLinkerNeighbor) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(3019699393, 32); b_0.storeAddress(src.neighbor); }; } export function loadSetLinkerNeighbor(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 3019699393) { throw Error('Invalid prefix'); } let _neighbor = sc_0.loadMaybeAddress(); return { $$type: 'SetLinkerNeighbor' as const, neighbor: _neighbor }; } function loadTupleSetLinkerNeighbor(source: TupleReader) { let _neighbor = source.readAddressOpt(); return { $$type: 'SetLinkerNeighbor' as const, neighbor: _neighbor }; } function storeTupleSetLinkerNeighbor(source: SetLinkerNeighbor) { let builder = new TupleBuilder(); builder.writeAddress(source.neighbor); return builder.build(); } function dictValueParserSetLinkerNeighbor(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeSetLinkerNeighbor(src)).endCell()); }, parse: (src) => { return loadSetLinkerNeighbor(src.loadRef().beginParse()); } } } export type InitLinker = { $$type: 'InitLinker'; neighbor: Address | null; walletAmount: bigint; walletCode: Cell; walletData: Cell; walletAddress: Address; responseAddress: Address | null; } export function storeInitLinker(src: InitLinker) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(1740669268, 32); b_0.storeAddress(src.neighbor); b_0.storeInt(src.walletAmount, 257); b_0.storeRef(src.walletCode); b_0.storeRef(src.walletData); b_0.storeAddress(src.walletAddress); let b_1 = new Builder(); b_1.storeAddress(src.responseAddress); b_0.storeRef(b_1.endCell()); }; } export function loadInitLinker(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 1740669268) { throw Error('Invalid prefix'); } let _neighbor = sc_0.loadMaybeAddress(); let _walletAmount = sc_0.loadIntBig(257); let _walletCode = sc_0.loadRef(); let _walletData = sc_0.loadRef(); let _walletAddress = sc_0.loadAddress(); let sc_1 = sc_0.loadRef().beginParse(); let _responseAddress = sc_1.loadMaybeAddress(); return { $$type: 'InitLinker' as const, neighbor: _neighbor, walletAmount: _walletAmount, walletCode: _walletCode, walletData: _walletData, walletAddress: _walletAddress, responseAddress: _responseAddress }; } function loadTupleInitLinker(source: TupleReader) { let _neighbor = source.readAddressOpt(); let _walletAmount = source.readBigNumber(); let _walletCode = source.readCell(); let _walletData = source.readCell(); let _walletAddress = source.readAddress(); let _responseAddress = source.readAddressOpt(); return { $$type: 'InitLinker' as const, neighbor: _neighbor, walletAmount: _walletAmount, walletCode: _walletCode, walletData: _walletData, walletAddress: _walletAddress, responseAddress: _responseAddress }; } function storeTupleInitLinker(source: InitLinker) { let builder = new TupleBuilder(); builder.writeAddress(source.neighbor); builder.writeNumber(source.walletAmount); builder.writeCell(source.walletCode); builder.writeCell(source.walletData); builder.writeAddress(source.walletAddress); builder.writeAddress(source.responseAddress); return builder.build(); } function dictValueParserInitLinker(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeInitLinker(src)).endCell()); }, parse: (src) => { return loadInitLinker(src.loadRef().beginParse()); } } } export type WithdrawalRequests = { $$type: 'WithdrawalRequests'; addresses: Dictionary; amounts: Dictionary; n_requests: bigint; } export function storeWithdrawalRequests(src: WithdrawalRequests) { return (builder: Builder) => { let b_0 = builder; b_0.storeDict(src.addresses, Dictionary.Keys.BigInt(257), Dictionary.Values.Address()); b_0.storeDict(src.amounts, Dictionary.Keys.BigInt(257), Dictionary.Values.BigInt(257)); b_0.storeInt(src.n_requests, 257); }; } export function loadWithdrawalRequests(slice: Slice) { let sc_0 = slice; let _addresses = Dictionary.load(Dictionary.Keys.BigInt(257), Dictionary.Values.Address(), sc_0); let _amounts = Dictionary.load(Dictionary.Keys.BigInt(257), Dictionary.Values.BigInt(257), sc_0); let _n_requests = sc_0.loadIntBig(257); return { $$type: 'WithdrawalRequests' as const, addresses: _addresses, amounts: _amounts, n_requests: _n_requests }; } function loadTupleWithdrawalRequests(source: TupleReader) { let _addresses = Dictionary.loadDirect(Dictionary.Keys.BigInt(257), Dictionary.Values.Address(), source.readCellOpt()); let _amounts = Dictionary.loadDirect(Dictionary.Keys.BigInt(257), Dictionary.Values.BigInt(257), source.readCellOpt()); let _n_requests = source.readBigNumber(); return { $$type: 'WithdrawalRequests' as const, addresses: _addresses, amounts: _amounts, n_requests: _n_requests }; } function storeTupleWithdrawalRequests(source: WithdrawalRequests) { let builder = new TupleBuilder(); builder.writeCell(source.addresses.size > 0 ? beginCell().storeDictDirect(source.addresses, Dictionary.Keys.BigInt(257), Dictionary.Values.Address()).endCell() : null); builder.writeCell(source.amounts.size > 0 ? beginCell().storeDictDirect(source.amounts, Dictionary.Keys.BigInt(257), Dictionary.Values.BigInt(257)).endCell() : null); builder.writeNumber(source.n_requests); return builder.build(); } function dictValueParserWithdrawalRequests(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeWithdrawalRequests(src)).endCell()); }, parse: (src) => { return loadWithdrawalRequests(src.loadRef().beginParse()); } } } export type ChangeOwner = { $$type: 'ChangeOwner'; newOwner: Address; } export function storeChangeOwner(src: ChangeOwner) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(256331011, 32); b_0.storeAddress(src.newOwner); }; } export function loadChangeOwner(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 256331011) { throw Error('Invalid prefix'); } let _newOwner = sc_0.loadAddress(); return { $$type: 'ChangeOwner' as const, newOwner: _newOwner }; } function loadTupleChangeOwner(source: TupleReader) { let _newOwner = source.readAddress(); return { $$type: 'ChangeOwner' as const, newOwner: _newOwner }; } function storeTupleChangeOwner(source: ChangeOwner) { let builder = new TupleBuilder(); builder.writeAddress(source.newOwner); return builder.build(); } function dictValueParserChangeOwner(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeChangeOwner(src)).endCell()); }, parse: (src) => { return loadChangeOwner(src.loadRef().beginParse()); } } } export type Deposit = { $$type: 'Deposit'; amount: bigint; } export function storeDeposit(src: Deposit) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(569292295, 32); b_0.storeCoins(src.amount); }; } export function loadDeposit(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 569292295) { throw Error('Invalid prefix'); } let _amount = sc_0.loadCoins(); return { $$type: 'Deposit' as const, amount: _amount }; } function loadTupleDeposit(source: TupleReader) { let _amount = source.readBigNumber(); return { $$type: 'Deposit' as const, amount: _amount }; } function storeTupleDeposit(source: Deposit) { let builder = new TupleBuilder(); builder.writeNumber(source.amount); return builder.build(); } function dictValueParserDeposit(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeDeposit(src)).endCell()); }, parse: (src) => { return loadDeposit(src.loadRef().beginParse()); } } } export type Withdraw = { $$type: 'Withdraw'; amount: bigint; } export function storeWithdraw(src: Withdraw) { return (builder: Builder) => { let b_0 = builder; b_0.storeUint(1616450832, 32); b_0.storeInt(src.amount, 257); }; } export function loadWithdraw(slice: Slice) { let sc_0 = slice; if (sc_0.loadUint(32) !== 1616450832) { throw Error('Invalid prefix'); } let _amount = sc_0.loadIntBig(257); return { $$type: 'Withdraw' as const, amount: _amount }; } function loadTupleWithdraw(source: TupleReader) { let _amount = source.readBigNumber(); return { $$type: 'Withdraw' as const, amount: _amount }; } function storeTupleWithdraw(source: Withdraw) { let builder = new TupleBuilder(); builder.writeNumber(source.amount); return builder.build(); } function dictValueParserWithdraw(): DictionaryValue { return { serialize: (src, buidler) => { buidler.storeRef(beginCell().store(storeWithdraw(src)).endCell()); }, parse: (src) => { return loadWithdraw(src.loadRef().beginParse()); } } } async function Linker_init(index: bigint, owner: Address, master: Address) { const __init = 'te6ccgEBBwEATgABFP8A9KQT9LzyyAsBAgFiAgMCAs0EBQAJoUrd4AsAAdQBE2W0EyMxQJNs8yYGADxQNIEBAc8AAc8WAc8WyFggbpUwcAHLAZLPFuLJAcw='; const __code = 'te6ccgECEwEAAVAAART/APSkE/S88sgLAQIBYgIDAgLMBAUCASANDgOL24EOuk4Q/KmBBrhY/vAWhpgYC42GAAyL/IuHEA/SARKDM3gnwwgUit8EEIWf56YN1Hx22eAm2eGIgaIJh4B+2ecBh5YEFBEGBwIBWAkKADbTHwGCELP89MG68uCB+kAh1wsBwwCRAZIxbeIBGMj4QgHMVTDbPMntVAgAPFA0gQEBzwABzxYBzxbIWCBulTBwAcsBks8W4skBzAAHUTXwOAIBIAsMAAkECNfA4AAfDH4QW8kW4ERTTIkxwXy9IAENviju2eeAbBECASAPEABNu70YJwXOw9XSyuex6E7DnWSoUbZoJwndY1LStkfLMi068t/fFiOYAQ25W92zzwDoEQEW7UTQ1AH4Yts8bBQSAESBAQHXAPpAAQH6QAEB1AHQ+kAh1wsBwwCRAZIxbeIxFEMw'; const __system = 'te6cckECFQEAAVoAAQHAAQEFodSXAgEU/wD0pBP0vPLICwMCAWIJBAIBIAgFAgEgBwYBDblb3bPPAOgTAE27vRgnBc7D1dLK57HoTsOdZKhRtmgnCd1jUtK2R8syLTry398WI5gBDb4o7tnngGwTAgLMDwoCAVgOCwIBIA0MAB8MfhBbyRbgRFNMiTHBfL0gAAkECNfA4AAHUTXwOAOL24EOuk4Q/KmBBrhY/vAWhpgYC42GAAyL/IuHEA/SARKDM3gnwwgUit8EEIWf56YN1Hx22eAm2eGIgaIJh4B+2ecBh5YEFBMSEAEYyPhCAcxVMNs8ye1UEQA8UDSBAQHPAAHPFgHPFshYIG6VMHABywGSzxbiyQHMADbTHwGCELP89MG68uCB+kAh1wsBwwCRAZIxbeIBFu1E0NQB+GLbPGwUFABEgQEB1wD6QAEB+kABAdQB0PpAIdcLAcMAkQGSMW3iMRRDMEhMYDc='; let systemCell = Cell.fromBase64(__system); let builder = new TupleBuilder(); builder.writeCell(systemCell); builder.writeNumber(index); builder.writeAddress(owner); builder.writeAddress(master); let __stack = builder.build(); let codeCell = Cell.fromBoc(Buffer.from(__code, 'base64'))[0]; let initCell = Cell.fromBoc(Buffer.from(__init, 'base64'))[0]; let system = await ContractSystem.create(); let executor = await ContractExecutor.create({ code: initCell, data: new Cell() }, system); let res = await executor.get('init', __stack); if (!res.success) { throw Error(res.error); } if (res.exitCode !== 0 && res.exitCode !== 1) { if (Linker_errors[res.exitCode]) { throw new ComputeError(Linker_errors[res.exitCode].message, res.exitCode); } else { throw new ComputeError('Exit code: ' + res.exitCode, res.exitCode); } } let data = res.stack.readCell(); return { code: codeCell, data }; } const Linker_errors: { [key: number]: { message: string } } = { 2: { message: `Stack undeflow` }, 3: { message: `Stack overflow` }, 4: { message: `Integer overflow` }, 5: { message: `Integer out of expected range` }, 6: { message: `Invalid opcode` }, 7: { message: `Type check error` }, 8: { message: `Cell overflow` }, 9: { message: `Cell underflow` }, 10: { message: `Dictionary error` }, 13: { message: `Out of gas error` }, 32: { message: `Method ID not found` }, 34: { message: `Action is invalid or not supported` }, 37: { message: `Not enough TON` }, 38: { message: `Not enough extra-currencies` }, 128: { message: `Null reference exception` }, 129: { message: `Invalid serialization prefix` }, 130: { message: `Invalid incoming message` }, 131: { message: `Constraints error` }, 132: { message: `Access denied` }, 133: { message: `Contract stopped` }, 134: { message: `Invalid argument` }, 135: { message: `Code of a contract was not found` }, 136: { message: `Invalid address` }, 4429: { message: `Invalid sender` }, 6384: { message: `not enough money for withdraw` }, 13650: { message: `Invalid bounced message` }, 16059: { message: `Invalid value` }, 32366: { message: `not enough money for deposit` }, 62972: { message: `Invalid balance` }, } export class Linker implements Contract { static async init(index: bigint, owner: Address, master: Address) { return await Linker_init(index,owner,master); } static async fromInit(index: bigint, owner: Address, master: Address) { const init = await Linker_init(index,owner,master); const address = contractAddress(0, init); return new Linker(address, init); } static fromAddress(address: Address) { return new Linker(address); } readonly address: Address; readonly init?: { code: Cell, data: Cell }; readonly abi: ContractABI = { errors: Linker_errors }; private constructor(address: Address, init?: { code: Cell, data: Cell }) { this.address = address; this.init = init; } async send(provider: ContractProvider, via: Sender, args: { value: bigint, bounce?: boolean| null | undefined }, message: SetLinkerNeighbor) { let body: Cell | null = null; if (message && typeof message === 'object' && !(message instanceof Slice) && message.$$type === 'SetLinkerNeighbor') { body = beginCell().store(storeSetLinkerNeighbor(message)).endCell(); } if (body === null) { throw new Error('Invalid message type'); } await provider.internal(via, { ...args, body: body }); } async getOwner(provider: ContractProvider) { let builder = new TupleBuilder(); let source = (await provider.get('owner', builder.build())).stack; let result = source.readAddressOpt(); return result; } async getMaster(provider: ContractProvider) { let builder = new TupleBuilder(); let source = (await provider.get('master', builder.build())).stack; let result = source.readAddress(); return result; } }