UNPKG

0xweb

Version:

Contract package manager and other web3 tools

215 lines (168 loc) 8.76 kB
/** * 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']>;