|
|
|
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<StateInit> {
|
|
|
|
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<Context> {
|
|
|
|
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<SendParameters> {
|
|
|
|
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<TokenTransfer> {
|
|
|
|
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<TokenTransferInternal> {
|
|
|
|
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<TokenNotification> {
|
|
|
|
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<TokenBurn> {
|
|
|
|
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<TokenBurnNotification> {
|
|
|
|
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<TokenExcesses> {
|
|
|
|
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<TokenUpdateContent> {
|
|
|
|
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<JettonData> {
|
|
|
|
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<JettonWalletData> {
|
|
|
|
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<SetLinkerNeighbor> {
|
|
|
|
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<InitLinker> {
|
|
|
|
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<bigint, Address>;
|
|
|
|
amounts: Dictionary<bigint, bigint>;
|
|
|
|
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<WithdrawalRequests> {
|
|
|
|
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<ChangeOwner> {
|
|
|
|
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<Deposit> {
|
|
|
|
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<Withdraw> {
|
|
|
|
return {
|
|
|
|
serialize: (src, buidler) => {
|
|
|
|
buidler.storeRef(beginCell().store(storeWithdraw(src)).endCell());
|
|
|
|
},
|
|
|
|
parse: (src) => {
|
|
|
|
return loadWithdraw(src.loadRef().beginParse());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
async function TONB_init(owner: Address, content: Cell | null) {
|
|
|
|
const __init = 'te6ccgEBBwEAhgABFP8A9KQT9LzyyAsBAgFiAgMCAs0EBQAJoUrd4AsAAdQBJWW1tcG0hfwjIzAhEdBYVE9s8yYGAJpQh/oCUAXPFiNus5Z/AcoAE8yWM3BQA8oA4soAASBulTBwAcsBks8W4gEgbpUwcAHLAZLPFuICyIEBAc8AASBulTBwAcsBks8W4skBzA==';
|
|
|
|
const __code = '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';
|
|
|
|
const __system = 'te6cckEClgEADSUAAQHAAQIBIGECAgFYFgMBBbVJcAQBFP8A9KQT9LzyyAsFAgFiCwYCASAKBwIBIAkIAQ25W92zzwDoFABNu70YJwXOw9XSyuex6E7DnWSoUbZoJwndY1LStkfLMi068t/fFiOYAQ2+KO7Z54BsFAICzBEMAgFYEA0CASAPDgAfDH4QW8kW4ERTTIkxwXy9IAAJBAjXwOAAB1E18DgDi9uBDrpOEPypgQa4WP7wFoaYGAuNhgAMi/yLhxAP0gESgzN4J8MIFIrfBBCFn+emDdR8dtngJtnhiIGiCYeAftnnAYeWBBQUExIBGMj4QgHMVTDbPMntVEMANtMfAYIQs/z0wbry4IH6QCHXCwHDAJEBkjFt4gEW7UTQ1AH4Yts8bBQVAESBAQHXAPpAAQH6QAEB1AHQ+kAh1wsBwwCRAZIxbeIxFEMwAQW1AnAXART/APSkE/S88sgLGAIBYiAZAgEgHxoCAUgcGwCVt3owTgudh6ullc9j0J2HOslQo2zQThO6xqWlbI+WZFp15b++LEcwThhMiKTJr7fJFy9sM7TqukCwTggZzq084r86ShYDrC3EyPZQAgFYHh0BEa8W7Z54FngPQF8BEa287Z4qg/gVwF8BDb4o7tnngYxfAgLKUSECASAvIgIBSCgjAgEgJSQAK0MDJVcSnwL1F4oXBAqXBtbW3wJVUUgCASAnJgAXFVw8DA1EGcQVlUDgACs+EFvJDCBGPAzggiYloC+EvL0ZvAugAgEgLCkCASArKgABIAArPhBbyQwgX5uM4IImJaAvhLy9GbwLYAIBIC4tAAkEGdfB4AAdPhBbyQQI18DJ8cF8uCEgAgEgRDACASA8MQIBIDcyAgEgNDMAOT4QW8kECNfA1WA8CoBgRFNAvAkUArHBRny9FUGgAWMEHoQaRBYEEoQOUipKPAqXPAkcHCAQFRBEwIREQIREB/bPBBtFRBOEDxQwvAlEEdVI4DUBDMhVMNs8yTYAQIIQWV8HvFAFyx8Tyz8B+gIBzxYBIG6VMHABywGSzxbiAgEgOzgCwRRoaBVcfAqXPAk+EL4KFRmMPApXPAkcIIJMS0AcAvbPCMQNkQVEDxBwPAlJQWkcPgoIfAjJKUQRwYREQYQNQQREgRVAgvbPHAEEDuCCvrwgANwQxMO8CUQVxBGEDVEAwKA5egEKyAHbPMk6ACyCELP89MFYyx8BIG6VMHABywGSzxbiABM+CjwKmxCMEMwgAgEgQD0CASA/PgANPAqbILwJIAAPPhC+ChY8CeACASBCQQBTAPQ9AQwbQGCAOpLAYAQ9A9vofLghwGCAOpLIgKAEPQXyPQAyVUgBPAogARMbQTIzFAk2zzJgQwA8UDSBAQHPAAHPFgHPFshYIG6VMHABywGSzxbiyQHMAgEgTEUCASBIRgIBIH9HAE0AtD0BDBtAYFghAGAEPQPb6Hy4IcBgWCEIgKAEPQXyPQAyUAD8CaACASBLSQL3MhxAcoBUAcBygBwAcoCUAXPFlAD+gJwAcpoI26zJW6zsY5GfwHKAMhwAcoAcAHKACRus5p/AcoABPABUATMljQDcAHKAOIkbrOafwHKAATwAVAEzJY0A3ABygDicAHKAAJ/AcoAAslYzJczMwFwAcoA4iFus+MPyQH7AIEqEABJ/AcoAAfABAcwASxwWchwAcsBcwHLAXABywASzMzJ+QDIcgHLAXABywASygfL/8nQgAgEgUE0CASBPTgAJPAh8CKAAAzQgAAVcjJgCASBSiAIBzlRTAAsIG7y0ICAEqRwIddJwh+VMCDXCx/eAtDTAwFxsMABkX+RcOIB+kAiUGZvBPhhApFb4CCCECHutge6j5cw2zwI2zwxEHgQZxBWEEUQNEEw8DLbPOAgwAAi10nBIbCBfXlxVBDiPB1vbPPAz2zzgIIIQYFkVELrjAiCCEAwIep66X1xaVgRCj5cw2zwI2zwxEHgQZxBWEEUQNEEw8DXbPOCCEHvdl966X1lcVwNCj5rbPAjbPDQQqxCaEIkQeBBnEFYQRVUC8DbbPOAw8sCCX1hcAEzTHwGCEHvdl9668uCB0z/6APpAAQH6QCHXCwHDAJEBkjFt4hRDMAAu0x8BghAMCHqeuvLggdIAAZHUkm0B4gEDLjDbPAjbPDEQeBBnEFYQRRA0QTDwNNs8X1tcACbTHwGCEGBZFRC68uCBgQEB1wABARjI+EIBzFVw2zzJ7VRdAJpQh/oCUAXPFiNus5Z/AcoAE8yWM3BQA8oA4soAASBulTBwAcsBks8W4gEgbpUwcAHLAZLPFuICyIEBAc8AASBulTBwAcsBks8W4skBzAAg0x8BghAh7rYHuvLggfoAAQEW7UTQ1AH4Yts8bBhgAKT6APpAAQHSAAGR1JJtAeLSAPpAIdcLAcMAkQGSMW3iAfpAIdcLAcMAkQGSMW3iAdQB0IEBAdcA+kAh1wsBwwCRAZIxbeIxECgQJxAmECUQJBAjAQW/BCRiART/APSkE/S88sgLYwIBYmdkAgEgZmUAcb3ejBOC52Hq6WVz2PQnYc6yVCjbNBOE7rGpaVsj5ZkWnXlv74sRzBOE7o8AHy2bAeT+QdWSzWUQnAERv9gW2eeBN4D0lAICyodoAgFIdmkCAUhragBPSAINch0x/TPzH6ADCBNVIighAXjUUZugOCEHvdl966E7ES8vQVoASAIBIG9sAZUW/hBbySBEU1TOscFU0rHBbFTSMcFsfL0UaShggD1/CHC//L0QzBSO/AjMIE+uwGCCcnDgLzy9H9wA4BAVDOI2zxUEwZQM21t8CKBtAQzIVTDbPMluAECCEHvdl95QBcsfE8s/AfoCAc8WASBulTBwAcsBks8W4gLZPhBbyQtbpY8PBA7ECqSNDTiUwzHBbNTG8cFs7COEvhCU9jwJQGBEU0C8CEixwXy9N5R6KCCAPX8IcL/8vQj+CdvECGhggiYloBmtgihggiYloCgoSbCAJYQf1CJXwjjDSdusyLCALCSN1vjDYHNwASJwCPACcATbPBBJQzAZbW3wInEBCsgB2zzJcgAWghDVMnbbWMsfyz8BQkMfUELwI1IwoByhcHAoSBNQdNs8KhBGQxNQVW1t8CJQB3QBDMhVMNs8yXUALIIQc2LQnFAFyx8Tyz8B+gIBzxYBzxYCASCAdwIBIH14AgEgfHkBxRsIvhBbySBEU1TPccF8vRR16GCAPX8IcL/8vRDMFI+8CNxJMIAkjBy3oE+uwKoggkxLQCgggiYloCgErzy9PhCVCCE8CVc8CF/UHZwgEBtbS8EVhAEEDpLq9s8EFYQNFnwIoHoBDMhVcNs8yXsAnIIQF41FGVAJyx8Xyz9QBfoCUAPPFgEgbpUwcAHLAZLPFuIB+gIBzxbIIm6zmn8BygASgQEBzwCVMnBYygDiWCBulTBwAcsBks8W4skBzAARFv4QlMS8CUwgAgEgf34ATQC0PQEMG0BgWCEAYAQ9A9vofLghwGBYIQiAoAQ9BfI9ADJQAPwJIAEZG1tcAXIzAVERNs8yYJMCASCGgQIBIIOCACUbDH6ADFx1yH6ADH6ADCnA6sAgAvcyHEBygFQBwHKAHABygJQBc8WUAP6AnABymgjbrMlbrOxjkZ/AcoAyHABygBwAcoAJG6zmn8BygAE8AJQBMyWNANwAcoA4iRus5p/AcoABPACUATMljQDcAHKAOJwAcoAAn8BygACyVjMlzMzAXABygDiIW6z4w/JAfsAghYQACjFwAcoAABJ/AcoAAfACAcwAS1cFnIcAHLAXMBywFwAcsAEszMyfkAyHIBywFwAcsAEsoHy//J0IAgEgiYgAA6dAAgFii4oAC0IG7y0ICASJRwIddJwh+VMCDXCx/eAtDTAwFxsMABkX+RcOIB+kAiUGZvBPhhAo8JMNs8VQTwKts84CCCEA+KfqW64wIgghAXjUUZuolJKQjAQ+j5Uw2zwF2zw4ELwQqxCaEIlVBvAo2zzgghBZXwe8upSPko0DNo+U2zwF2zw0EHgQZxBWEEVVAvAp2zzgMPLAgpSOkgBM0x8BghBZXwe8uvLggdM/+
|
|
|
|
let systemCell = Cell.fromBase64(__system);
|
|
|
|
let builder = new TupleBuilder();
|
|
|
|
builder.writeCell(systemCell);
|
|
|
|
builder.writeAddress(owner);
|
|
|
|
builder.writeCell(content);
|
|
|
|
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 (TONB_errors[res.exitCode]) {
|
|
|
|
throw new ComputeError(TONB_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 TONB_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 TONB implements Contract {
|
|
|
|
|
|
|
|
static async init(owner: Address, content: Cell | null) {
|
|
|
|
return await TONB_init(owner,content);
|
|
|
|
}
|
|
|
|
|
|
|
|
static async fromInit(owner: Address, content: Cell | null) {
|
|
|
|
const init = await TONB_init(owner,content);
|
|
|
|
const address = contractAddress(0, init);
|
|
|
|
return new TONB(address, init);
|
|
|
|
}
|
|
|
|
|
|
|
|
static fromAddress(address: Address) {
|
|
|
|
return new TONB(address);
|
|
|
|
}
|
|
|
|
|
|
|
|
readonly address: Address;
|
|
|
|
readonly init?: { code: Cell, data: Cell };
|
|
|
|
readonly abi: ContractABI = {
|
|
|
|
errors: TONB_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: Deposit | null | Withdraw | TokenUpdateContent | TokenBurnNotification) {
|
|
|
|
|
|
|
|
let body: Cell | null = null;
|
|
|
|
if (message && typeof message === 'object' && !(message instanceof Slice) && message.$$type === 'Deposit') {
|
|
|
|
body = beginCell().store(storeDeposit(message)).endCell();
|
|
|
|
}
|
|
|
|
if (message === null) {
|
|
|
|
body = new Cell();
|
|
|
|
}
|
|
|
|
if (message && typeof message === 'object' && !(message instanceof Slice) && message.$$type === 'Withdraw') {
|
|
|
|
body = beginCell().store(storeWithdraw(message)).endCell();
|
|
|
|
}
|
|
|
|
if (message && typeof message === 'object' && !(message instanceof Slice) && message.$$type === 'TokenUpdateContent') {
|
|
|
|
body = beginCell().store(storeTokenUpdateContent(message)).endCell();
|
|
|
|
}
|
|
|
|
if (message && typeof message === 'object' && !(message instanceof Slice) && message.$$type === 'TokenBurnNotification') {
|
|
|
|
body = beginCell().store(storeTokenBurnNotification(message)).endCell();
|
|
|
|
}
|
|
|
|
if (body === null) { throw new Error('Invalid message type'); }
|
|
|
|
|
|
|
|
await provider.internal(via, { ...args, body: body });
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
async getGetWalletAddress(provider: ContractProvider, owner: Address) {
|
|
|
|
let builder = new TupleBuilder();
|
|
|
|
builder.writeAddress(owner);
|
|
|
|
let source = (await provider.get('get_wallet_address', builder.build())).stack;
|
|
|
|
let result = source.readAddress();
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
async getGetJettonData(provider: ContractProvider) {
|
|
|
|
let builder = new TupleBuilder();
|
|
|
|
let source = (await provider.get('get_jetton_data', builder.build())).stack;
|
|
|
|
const result = loadTupleJettonData(source);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
async getOwner(provider: ContractProvider) {
|
|
|
|
let builder = new TupleBuilder();
|
|
|
|
let source = (await provider.get('owner', builder.build())).stack;
|
|
|
|
let result = source.readAddress();
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|