0xweb
Version:
Contract package manager and other web3 tools
215 lines (168 loc) • 8.76 kB
text/typescript
/**
* AUTO-Generated Class: 2024-05-17 00:25
* Implementation: ./node_modules/@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol
*/
import di from 'a-di';
import { TAddress } from '@dequanto/models/TAddress';
import { TAccount } from '@dequanto/models/TAccount';
import { TBufferLike } from '@dequanto/models/TBufferLike';
import { ClientEventsStream, TClientEventsStreamData } from '@dequanto/clients/ClientEventsStream';
import { ContractBase } from '@dequanto/contracts/ContractBase';
import { ContractBaseUtils } from '@dequanto/contracts/utils/ContractBaseUtils';
import { ContractStorageReaderBase } from '@dequanto/contracts/ContractStorageReaderBase';
import { TxWriter } from '@dequanto/txs/TxWriter';
import { ITxLogItem } from '@dequanto/txs/receipt/ITxLogItem';
import { Web3Client } from '@dequanto/clients/Web3Client';
import { IBlockchainExplorer } from '@dequanto/explorer/IBlockchainExplorer';
import { SubjectStream } from '@dequanto/class/SubjectStream';
import type { ContractWriter } from '@dequanto/contracts/ContractWriter';
import type { TAbiItem } from '@dequanto/types/TAbi';
import type { TEth } from '@dequanto/models/TEth';
import type { TOverrideReturns } from '@dequanto/utils/types';
import { Etherscan } from '@dequanto/explorer/Etherscan'
import { EthWeb3Client } from '@dequanto/clients/EthWeb3Client'
export class TransparentUpgradeableProxy extends ContractBase {
constructor(
public address: TEth.Address = null,
public client: Web3Client = di.resolve(EthWeb3Client, ),
public explorer: IBlockchainExplorer = di.resolve(Etherscan, ),
) {
super(address, client, explorer)
this.storage = new TransparentUpgradeableProxyStorageReader(this.address, this.client, this.explorer);
}
Types: TTransparentUpgradeableProxyTypes;
$meta = {
"source": "./node_modules/@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol",
"class": "./src/prebuilt/openzeppelin/compiled/TransparentUpgradeableProxy/TransparentUpgradeableProxy.ts"
}
async $constructor (deployer: TSender, _logic: TAddress, admin_: TAddress, _data: TEth.Hex): Promise<TxWriter> {
throw new Error('Not implemented. Typing purpose. Use the ContractDeployer class to deploy the contract');
}
$call () {
return super.$call() as ITransparentUpgradeableProxyTxCaller;
}
$signed (): TOverrideReturns<ITransparentUpgradeableProxyTxCaller, Promise<{ signed: TEth.Hex, error?: Error & { data?: { type: string, params } } }>> {
return super.$signed() as any;
}
$data (): ITransparentUpgradeableProxyTxData {
return super.$data() as ITransparentUpgradeableProxyTxData;
}
$gas (): TOverrideReturns<ITransparentUpgradeableProxyTxCaller, Promise<{ gas?: bigint, price?: bigint, error?: Error & { data?: { type: string, params } } }>> {
return super.$gas() as any;
}
onTransaction <TMethod extends keyof TTransparentUpgradeableProxyTypes['Methods']> (method: TMethod, options: Parameters<ContractBase['$onTransaction']>[0]): SubjectStream<{
tx: TEth.Tx
block: TEth.Block<TEth.Hex>
calldata: {
method: TMethod
arguments: TTransparentUpgradeableProxyTypes['Methods'][TMethod]['arguments']
}
}> {
options ??= {};
options.filter ??= {};
options.filter.method = method;
return <any> this.$onTransaction(options);
}
onLog (event: keyof TEvents, cb?: (event: TClientEventsStreamData) => void): ClientEventsStream<TClientEventsStreamData> {
return this.$onLog(event, cb);
}
async getPastLogs <TEventName extends keyof TEvents> (
events: TEventName[]
, options?: TEventLogOptions<TEventParams<TEventName>>
): Promise<ITxLogItem<TEventParams<TEventName>, TEventName>[]>
async getPastLogs <TEventName extends keyof TEvents> (
event: TEventName
, options?: TEventLogOptions<TEventParams<TEventName>>
): Promise<ITxLogItem<TEventParams<TEventName>, TEventName>[]>
async getPastLogs (mix: any, options?): Promise<any> {
return await super.getPastLogs(mix, options) as any;
}
onUpgraded (fn?: (event: TClientEventsStreamData<TEventArguments<'Upgraded'>>) => void): ClientEventsStream<TClientEventsStreamData<TEventArguments<'Upgraded'>>> {
return this.$onLog('Upgraded', fn);
}
onAdminChanged (fn?: (event: TClientEventsStreamData<TEventArguments<'AdminChanged'>>) => void): ClientEventsStream<TClientEventsStreamData<TEventArguments<'AdminChanged'>>> {
return this.$onLog('AdminChanged', fn);
}
onBeaconUpgraded (fn?: (event: TClientEventsStreamData<TEventArguments<'BeaconUpgraded'>>) => void): ClientEventsStream<TClientEventsStreamData<TEventArguments<'BeaconUpgraded'>>> {
return this.$onLog('BeaconUpgraded', fn);
}
extractLogsUpgraded (tx: TEth.TxReceipt): ITxLogItem<TEventParams<'Upgraded'>>[] {
let abi = this.$getAbiItem('event', 'Upgraded');
return this.$extractLogs(tx, abi) as any as ITxLogItem<TEventParams<'Upgraded'>>[];
}
extractLogsAdminChanged (tx: TEth.TxReceipt): ITxLogItem<TEventParams<'AdminChanged'>>[] {
let abi = this.$getAbiItem('event', 'AdminChanged');
return this.$extractLogs(tx, abi) as any as ITxLogItem<TEventParams<'AdminChanged'>>[];
}
extractLogsBeaconUpgraded (tx: TEth.TxReceipt): ITxLogItem<TEventParams<'BeaconUpgraded'>>[] {
let abi = this.$getAbiItem('event', 'BeaconUpgraded');
return this.$extractLogs(tx, abi) as any as ITxLogItem<TEventParams<'BeaconUpgraded'>>[];
}
async getPastLogsUpgraded (options?: {
fromBlock?: number | Date
toBlock?: number | Date
params?: { implementation?: TAddress }
}): Promise<ITxLogItem<TEventParams<'Upgraded'>>[]> {
return await this.$getPastLogsParsed('Upgraded', options) as any;
}
async getPastLogsAdminChanged (options?: {
fromBlock?: number | Date
toBlock?: number | Date
params?: { }
}): Promise<ITxLogItem<TEventParams<'AdminChanged'>>[]> {
return await this.$getPastLogsParsed('AdminChanged', options) as any;
}
async getPastLogsBeaconUpgraded (options?: {
fromBlock?: number | Date
toBlock?: number | Date
params?: { beacon?: TAddress }
}): Promise<ITxLogItem<TEventParams<'BeaconUpgraded'>>[]> {
return await this.$getPastLogsParsed('BeaconUpgraded', options) as any;
}
abi: TAbiItem[] = [{"type":"fallback","inputs":[],"outputs":[],"stateMutability":"payable"},{"type":"event","name":"Upgraded","inputs":[{"name":"implementation","type":"address","indexed":true}]},{"type":"event","name":"AdminChanged","inputs":[{"name":"previousAdmin","type":"address","indexed":false},{"name":"newAdmin","type":"address","indexed":false}]},{"type":"event","name":"BeaconUpgraded","inputs":[{"name":"beacon","type":"address","indexed":true}]},{"type":"constructor","name":"constructor","inputs":[{"name":"_logic","type":"address"},{"name":"admin_","type":"address"},{"name":"_data","type":"bytes"}],"outputs":[],"stateMutability":"payable"}]
declare storage: TransparentUpgradeableProxyStorageReader
}
type TSender = TAccount & {
value?: string | number | bigint
}
type TEventLogOptions<TParams> = {
fromBlock?: number | Date
toBlock?: number | Date
params?: TParams
}
export type TTransparentUpgradeableProxyTypes = {
Events: {
Upgraded: {
outputParams: { implementation: TAddress },
outputArgs: [ implementation: TAddress ],
}
AdminChanged: {
outputParams: { previousAdmin: TAddress, newAdmin: TAddress },
outputArgs: [ previousAdmin: TAddress, newAdmin: TAddress ],
}
BeaconUpgraded: {
outputParams: { beacon: TAddress },
outputArgs: [ beacon: TAddress ],
}
},
Methods: {
}
}
class TransparentUpgradeableProxyStorageReader extends ContractStorageReaderBase {
constructor(
public address: TAddress,
public client: Web3Client,
public explorer: IBlockchainExplorer,
) {
super(address, client, explorer);
this.$createHandler(this.$slots);
}
$slots = []
}
interface ITransparentUpgradeableProxyTxCaller {
}
interface ITransparentUpgradeableProxyTxData {
}
type TEvents = TTransparentUpgradeableProxyTypes['Events'];
type TEventParams<TEventName extends keyof TEvents> = Partial<TEvents[TEventName]['outputParams']>;
type TEventArguments<TEventName extends keyof TEvents> = Partial<TEvents[TEventName]['outputArgs']>;