import type { AnyJson, AnyTuple, AnyU8a, ArgsDef, IMethod, Inspect, IOption } from '@polkadot/types-codec/types'; import type { HexString } from '@polkadot/util/types'; import type { GeneralExtrinsic } from '../index.types.js'; import type { EcdsaSignature, Ed25519Signature, ExtrinsicUnknown, ExtrinsicV5, Sr25519Signature } from '../interfaces/extrinsics/index.js'; import type { FunctionMetadataLatest } from '../interfaces/metadata/index.js'; import type { Address, Call, CodecHash, Hash } from '../interfaces/runtime/index.js'; import type { MultiLocation } from '../interfaces/types.js'; import type { CallBase, ExtrinsicPayloadValue, ICompact, IExtrinsic, IKeyringPair, INumber, Registry, SignatureOptions } from '../types/index.js'; import type { GenericExtrinsicEra } from './ExtrinsicEra.js'; import type { Preamble } from './types.js'; import type { ExtrinsicValueV5 } from './v5/Extrinsic.js'; import { AbstractBase } from '@polkadot/types-codec'; import { LATEST_EXTRINSIC_VERSION } from './constants.js'; interface CreateOptions { version?: number; preamble?: Preamble; } type ExtrinsicVx = ExtrinsicV5 | GeneralExtrinsic; type ExtrinsicValue = ExtrinsicValueV5; export { LATEST_EXTRINSIC_VERSION }; declare abstract class ExtrinsicBase extends AbstractBase { #private; constructor(registry: Registry, value: ExtrinsicVx | ExtrinsicUnknown, initialU8aLength?: number, preamble?: Preamble); isGeneral(): boolean; /** * @description The arguments passed to for the call, exposes args so it is compatible with [[Call]] */ get args(): A; /** * @description The argument definitions, compatible with [[Call]] */ get argsDef(): ArgsDef; /** * @description The actual `[sectionIndex, methodIndex]` as used in the Call */ get callIndex(): Uint8Array; /** * @description The actual data for the Call */ get data(): Uint8Array; /** * @description The era for this extrinsic */ get era(): GenericExtrinsicEra; /** * @description The length of the value when encoded as a Uint8Array */ get encodedLength(): number; /** * @description `true` id the extrinsic is signed */ get isSigned(): boolean; /** * @description The length of the actual data, excluding prefix */ get length(): number; /** * @description The [[FunctionMetadataLatest]] that describes the extrinsic */ get meta(): FunctionMetadataLatest; /** * @description The [[Call]] this extrinsic wraps */ get method(): CallBase; /** * @description The nonce for this extrinsic */ get nonce(): ICompact; /** * @description The actual [[EcdsaSignature]], [[Ed25519Signature]] or [[Sr25519Signature]] */ get signature(): EcdsaSignature | Ed25519Signature | Sr25519Signature; /** * @description The [[Address]] that signed */ get signer(): Address; /** * @description Forwards compat */ get tip(): ICompact; /** * @description Forward compat */ get assetId(): IOption; /** * @description Forward compat */ get metadataHash(): IOption; /** * @description Forward compat */ get mode(): INumber; /** * @description Returns the raw transaction version (not flagged with signing information) */ get type(): number; get inner(): ExtrinsicVx; /** * @description Returns the encoded version flag */ get version(): number; /** * @description Checks if the source matches this in type */ is(other: IMethod): other is IMethod; unwrap(): ExtrinsicVx; } /** * @name GenericExtrinsic * @description * Representation of an Extrinsic in the system. It contains the actual call, * (optional) signature and encodes with an actual length prefix * * {@link https://github.com/paritytech/wiki/blob/master/Extrinsic.md#the-extrinsic-format-for-node}. * * Can be: * - signed, to create a transaction * - left as is, to create an inherent */ export declare class GenericExtrinsic extends ExtrinsicBase implements IExtrinsic { #private; static LATEST_EXTRINSIC_VERSION: number; constructor(registry: Registry, value?: GenericExtrinsic | ExtrinsicValue | AnyU8a | Call, { preamble, version }?: CreateOptions); /** * @description returns a hash of the contents */ get hash(): CodecHash; /** * @description Injects an already-generated signature into the extrinsic */ addSignature(signer: Address | Uint8Array | string, signature: Uint8Array | HexString, payload: ExtrinsicPayloadValue | Uint8Array | HexString): GenericExtrinsic; /** * @description Returns a breakdown of the hex encoding for this Codec */ inspect(): Inspect; /** * @description Sign the extrinsic with a specific keypair */ sign(account: IKeyringPair, options: SignatureOptions): GenericExtrinsic; /** * @describe Adds a fake signature to the extrinsic */ signFake(signer: Address | Uint8Array | string, options: SignatureOptions): GenericExtrinsic; /** * @description Returns a hex string representation of the value */ toHex(isBare?: boolean): HexString; /** * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information */ toHuman(isExpanded?: boolean, disableAscii?: boolean): AnyJson; /** * @description Converts the Object to JSON, typically used for RPC transfers */ toJSON(): string; /** * @description Returns the base runtime type name for this instance */ toRawType(): string; /** * @description Encodes the value as a Uint8Array as per the SCALE specifications * @param isBare true when the value is not length-prefixed */ toU8a(isBare?: boolean): Uint8Array; toU8aInner(): Uint8Array[]; }