packages/types-support/src/metadata/v13/polkadot-json.json
{
"magicNumber": 1635018093,
"metadata": {
"v13": {
"modules": [
{
"name": "System",
"storage": {
"prefix": "System",
"items": [
{
"name": "Account",
"modifier": "Default",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "AccountInfo",
"linked": false
}
},
"fallback": "0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" The full account information for a particular account ID."
]
},
{
"name": "ExtrinsicCount",
"modifier": "Optional",
"type": {
"plain": "u32"
},
"fallback": "0x00",
"docs": [
" Total extrinsics count for the current block."
]
},
{
"name": "BlockWeight",
"modifier": "Default",
"type": {
"plain": "ConsumedWeight"
},
"fallback": "0x000000000000000000000000000000000000000000000000",
"docs": [
" The current weight for the block."
]
},
{
"name": "AllExtrinsicsLen",
"modifier": "Optional",
"type": {
"plain": "u32"
},
"fallback": "0x00",
"docs": [
" Total length (in bytes) for all extrinsics put together, for the current block."
]
},
{
"name": "BlockHash",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "BlockNumber",
"value": "Hash",
"linked": false
}
},
"fallback": "0x0000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" Map of block numbers to block hashes."
]
},
{
"name": "ExtrinsicData",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "u32",
"value": "Bytes",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Extrinsics data for the current block (maps an extrinsic's index to its data)."
]
},
{
"name": "Number",
"modifier": "Default",
"type": {
"plain": "BlockNumber"
},
"fallback": "0x00000000",
"docs": [
" The current block number being processed. Set by `execute_block`."
]
},
{
"name": "ParentHash",
"modifier": "Default",
"type": {
"plain": "Hash"
},
"fallback": "0x0000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" Hash of the previous block."
]
},
{
"name": "Digest",
"modifier": "Default",
"type": {
"plain": "DigestOf"
},
"fallback": "0x00",
"docs": [
" Digest of the current block, also part of the block header."
]
},
{
"name": "Events",
"modifier": "Default",
"type": {
"plain": "Vec<EventRecord>"
},
"fallback": "0x00",
"docs": [
" Events deposited for the current block.",
"",
" NOTE: This storage item is explicitly unbounded since it is never intended to be read",
" from within the runtime."
]
},
{
"name": "EventCount",
"modifier": "Default",
"type": {
"plain": "EventIndex"
},
"fallback": "0x00000000",
"docs": [
" The number of events in the `Events<T>` list."
]
},
{
"name": "EventTopics",
"modifier": "Default",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "Hash",
"value": "Vec<(BlockNumber,EventIndex)>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Mapping between a topic (represented by T::Hash) and a vector of indexes",
" of events in the `<Events<T>>` list.",
"",
" All topic vectors have deterministic storage locations depending on the topic. This",
" allows light-clients to leverage the changes trie storage tracking mechanism and",
" in case of changes fetch the list of events of interest.",
"",
" The value has the type `(T::BlockNumber, EventIndex)` because if we used only just",
" the `EventIndex` then in case if the topic has the same contents on the next block",
" no notification will be triggered thus the event might be lost."
]
},
{
"name": "LastRuntimeUpgrade",
"modifier": "Optional",
"type": {
"plain": "LastRuntimeUpgradeInfo"
},
"fallback": "0x00",
"docs": [
" Stores the `spec_version` and `spec_name` of when the last runtime upgrade happened."
]
},
{
"name": "UpgradedToU32RefCount",
"modifier": "Default",
"type": {
"plain": "bool"
},
"fallback": "0x00",
"docs": [
" True if we have upgraded so that `type RefCount` is `u32`. False (default) if not."
]
},
{
"name": "UpgradedToTripleRefCount",
"modifier": "Default",
"type": {
"plain": "bool"
},
"fallback": "0x00",
"docs": [
" True if we have upgraded so that AccountInfo contains three types of `RefCount`. False",
" (default) if not."
]
},
{
"name": "ExecutionPhase",
"modifier": "Optional",
"type": {
"plain": "Phase"
},
"fallback": "0x00",
"docs": [
" The execution phase of the block."
]
}
]
},
"calls": [
{
"name": "fill_block",
"args": [
{
"name": "_ratio",
"type": "Perbill"
}
],
"docs": [
" A dispatch that will fill the block weight up to the given ratio."
]
},
{
"name": "remark",
"args": [
{
"name": "_remark",
"type": "Bytes"
}
],
"docs": [
" Make some on-chain remark.",
"",
" # <weight>",
" - `O(1)`",
" # </weight>"
]
},
{
"name": "set_heap_pages",
"args": [
{
"name": "pages",
"type": "u64"
}
],
"docs": [
" Set the number of pages in the WebAssembly environment's heap.",
"",
" # <weight>",
" - `O(1)`",
" - 1 storage write.",
" - Base Weight: 1.405 µs",
" - 1 write to HEAP_PAGES",
" # </weight>"
]
},
{
"name": "set_code",
"args": [
{
"name": "code",
"type": "Bytes"
}
],
"docs": [
" Set the new runtime code.",
"",
" # <weight>",
" - `O(C + S)` where `C` length of `code` and `S` complexity of `can_set_code`",
" - 1 storage write (codec `O(C)`).",
" - 1 call to `can_set_code`: `O(S)` (calls `sp_io::misc::runtime_version` which is",
" expensive).",
" - 1 event.",
" The weight of this function is dependent on the runtime, but generally this is very",
" expensive. We will treat this as a full block.",
" # </weight>"
]
},
{
"name": "set_code_without_checks",
"args": [
{
"name": "code",
"type": "Bytes"
}
],
"docs": [
" Set the new runtime code without doing any checks of the given `code`.",
"",
" # <weight>",
" - `O(C)` where `C` length of `code`",
" - 1 storage write (codec `O(C)`).",
" - 1 event.",
" The weight of this function is dependent on the runtime. We will treat this as a full",
" block. # </weight>"
]
},
{
"name": "set_changes_trie_config",
"args": [
{
"name": "changes_trie_config",
"type": "Option<ChangesTrieConfiguration>"
}
],
"docs": [
" Set the new changes trie configuration.",
"",
" # <weight>",
" - `O(1)`",
" - 1 storage write or delete (codec `O(1)`).",
" - 1 call to `deposit_log`: Uses `append` API, so O(1)",
" - Base Weight: 7.218 µs",
" - DB Weight:",
" - Writes: Changes Trie, System Digest",
" # </weight>"
]
},
{
"name": "set_storage",
"args": [
{
"name": "items",
"type": "Vec<KeyValue>"
}
],
"docs": [
" Set some items of storage.",
"",
" # <weight>",
" - `O(I)` where `I` length of `items`",
" - `I` storage writes (`O(1)`).",
" - Base Weight: 0.568 * i µs",
" - Writes: Number of items",
" # </weight>"
]
},
{
"name": "kill_storage",
"args": [
{
"name": "keys",
"type": "Vec<Key>"
}
],
"docs": [
" Kill some items from storage.",
"",
" # <weight>",
" - `O(IK)` where `I` length of `keys` and `K` length of one key",
" - `I` storage deletions.",
" - Base Weight: .378 * i µs",
" - Writes: Number of items",
" # </weight>"
]
},
{
"name": "kill_prefix",
"args": [
{
"name": "prefix",
"type": "Key"
},
{
"name": "_subkeys",
"type": "u32"
}
],
"docs": [
" Kill all storage items with a key that starts with the given prefix.",
"",
" **NOTE:** We rely on the Root origin to provide us the number of subkeys under",
" the prefix we are removing to accurately calculate the weight of this function.",
"",
" # <weight>",
" - `O(P)` where `P` amount of keys with prefix `prefix`",
" - `P` storage deletions.",
" - Base Weight: 0.834 * P µs",
" - Writes: Number of subkeys + 1",
" # </weight>"
]
},
{
"name": "remark_with_event",
"args": [
{
"name": "remark",
"type": "Bytes"
}
],
"docs": [
" Make some on-chain remark and emit event.",
"",
" # <weight>",
" - `O(b)` where b is the length of the remark.",
" - 1 event.",
" # </weight>"
]
}
],
"events": [
{
"name": "ExtrinsicSuccess",
"args": [
"DispatchInfo"
],
"docs": [
" An extrinsic completed successfully. \\[info\\]"
]
},
{
"name": "ExtrinsicFailed",
"args": [
"DispatchError",
"DispatchInfo"
],
"docs": [
" An extrinsic failed. \\[error, info\\]"
]
},
{
"name": "CodeUpdated",
"args": [],
"docs": [
" `:code` was updated."
]
},
{
"name": "NewAccount",
"args": [
"AccountId"
],
"docs": [
" A new \\[account\\] was created."
]
},
{
"name": "KilledAccount",
"args": [
"AccountId"
],
"docs": [
" An \\[account\\] was reaped."
]
},
{
"name": "Remarked",
"args": [
"AccountId",
"Hash"
],
"docs": [
" On on-chain remark happened. \\[origin, remark_hash\\]"
]
}
],
"constants": [
{
"name": "BlockWeights",
"type": "BlockWeights",
"value": "0x00f2052a0100000000204aa9d1010000405973070000000001c0766c8f58010000010098f73e5d010000010000000000000000405973070000000001c0febef9cc0100000100204aa9d1010000010088526a740000004059730700000000000000",
"docs": [
" Block & extrinsics weights: base values and limits."
]
},
{
"name": "BlockLength",
"type": "BlockLength",
"value": "0x00003c000000500000005000",
"docs": [
" The maximum length of a block (in bytes)."
]
},
{
"name": "BlockHashCount",
"type": "BlockNumber",
"value": "0x60090000",
"docs": [
" Maximum number of block number to block hash mappings to keep (oldest pruned first)."
]
},
{
"name": "DbWeight",
"type": "RuntimeDbWeight",
"value": "0x40787d010000000000e1f50500000000",
"docs": [
" The weight of runtime database operations the runtime can invoke."
]
},
{
"name": "Version",
"type": "RuntimeVersion",
"value": "0x20706f6c6b61646f743c7061726974792d706f6c6b61646f74000000008c2300000000000038df6acb689907609b0300000037e397fc7c91f5e40100000040fe3ad401f8959a05000000d2bc9897eed08f1503000000f78b278be53f454c02000000af2c0297a23e6d3d0100000049eaaf1b548a0cb00100000091d5df18b0d2cf5801000000ed99c5acb25eedf503000000cbca25e39f14238702000000687ad44ad37f03c201000000ab3c0572291feb8b01000000bc9d89904f5b923f0100000037c8bb1350a9a2a80100000007000000",
"docs": [
" Get the chain's current version."
]
},
{
"name": "SS58Prefix",
"type": "u16",
"value": "0x0000",
"docs": [
" The designated SS85 prefix of this chain.",
"",
" This replaces the \"ss58Format\" property declared in the chain spec. Reason is",
" that the runtime should know about the prefix in order to make use of it as",
" an identifier of the chain."
]
}
],
"errors": [
{
"name": "InvalidSpecName",
"docs": [
" The name of specification does not match between the current runtime",
" and the new runtime."
]
},
{
"name": "SpecVersionNeedsToIncrease",
"docs": [
" The specification version is not allowed to decrease between the current runtime",
" and the new runtime."
]
},
{
"name": "FailedToExtractRuntimeVersion",
"docs": [
" Failed to extract the runtime version from the new runtime.",
"",
" Either calling `Core_version` or decoding `RuntimeVersion` failed."
]
},
{
"name": "NonDefaultComposite",
"docs": [
" Suicide called when the account has non-default composite data."
]
},
{
"name": "NonZeroRefCount",
"docs": [
" There is a non-zero reference count preventing the account from being purged."
]
}
],
"index": 0
},
{
"name": "Scheduler",
"storage": {
"prefix": "Scheduler",
"items": [
{
"name": "Agenda",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "BlockNumber",
"value": "Vec<Option<Scheduled>>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Items to be executed, indexed by the block number that they should be executed on."
]
},
{
"name": "Lookup",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "Bytes",
"value": "TaskAddress",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Lookup from identity to the block number and index of the task."
]
},
{
"name": "StorageVersion",
"modifier": "Default",
"type": {
"plain": "Releases"
},
"fallback": "0x00",
"docs": [
" Storage version of the pallet.",
"",
" New networks start with last version."
]
}
]
},
"calls": [
{
"name": "schedule",
"args": [
{
"name": "when",
"type": "BlockNumber"
},
{
"name": "maybe_periodic",
"type": "Option<Period>"
},
{
"name": "priority",
"type": "Priority"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Anonymously schedule a task.",
"",
" # <weight>",
" - S = Number of already scheduled calls",
" - Base Weight: 22.29 + .126 * S µs",
" - DB Weight:",
" - Read: Agenda",
" - Write: Agenda",
" - Will use base weight of 25 which should be good for up to 30 scheduled calls",
" # </weight>"
]
},
{
"name": "cancel",
"args": [
{
"name": "when",
"type": "BlockNumber"
},
{
"name": "index",
"type": "u32"
}
],
"docs": [
" Cancel an anonymously scheduled task.",
"",
" # <weight>",
" - S = Number of already scheduled calls",
" - Base Weight: 22.15 + 2.869 * S µs",
" - DB Weight:",
" - Read: Agenda",
" - Write: Agenda, Lookup",
" - Will use base weight of 100 which should be good for up to 30 scheduled calls",
" # </weight>"
]
},
{
"name": "schedule_named",
"args": [
{
"name": "id",
"type": "Bytes"
},
{
"name": "when",
"type": "BlockNumber"
},
{
"name": "maybe_periodic",
"type": "Option<Period>"
},
{
"name": "priority",
"type": "Priority"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Schedule a named task.",
"",
" # <weight>",
" - S = Number of already scheduled calls",
" - Base Weight: 29.6 + .159 * S µs",
" - DB Weight:",
" - Read: Agenda, Lookup",
" - Write: Agenda, Lookup",
" - Will use base weight of 35 which should be good for more than 30 scheduled calls",
" # </weight>"
]
},
{
"name": "cancel_named",
"args": [
{
"name": "id",
"type": "Bytes"
}
],
"docs": [
" Cancel a named scheduled task.",
"",
" # <weight>",
" - S = Number of already scheduled calls",
" - Base Weight: 24.91 + 2.907 * S µs",
" - DB Weight:",
" - Read: Agenda, Lookup",
" - Write: Agenda, Lookup",
" - Will use base weight of 100 which should be good for up to 30 scheduled calls",
" # </weight>"
]
},
{
"name": "schedule_after",
"args": [
{
"name": "after",
"type": "BlockNumber"
},
{
"name": "maybe_periodic",
"type": "Option<Period>"
},
{
"name": "priority",
"type": "Priority"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Anonymously schedule a task after a delay.",
"",
" # <weight>",
" Same as [`schedule`].",
" # </weight>"
]
},
{
"name": "schedule_named_after",
"args": [
{
"name": "id",
"type": "Bytes"
},
{
"name": "after",
"type": "BlockNumber"
},
{
"name": "maybe_periodic",
"type": "Option<Period>"
},
{
"name": "priority",
"type": "Priority"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Schedule a named task after a delay.",
"",
" # <weight>",
" Same as [`schedule_named`](Self::schedule_named).",
" # </weight>"
]
}
],
"events": [
{
"name": "Scheduled",
"args": [
"BlockNumber",
"u32"
],
"docs": [
" Scheduled some task. \\[when, index\\]"
]
},
{
"name": "Canceled",
"args": [
"BlockNumber",
"u32"
],
"docs": [
" Canceled some task. \\[when, index\\]"
]
},
{
"name": "Dispatched",
"args": [
"TaskAddress",
"Option<Bytes>",
"DispatchResult"
],
"docs": [
" Dispatched some task. \\[task, id, result\\]"
]
}
],
"constants": [
{
"name": "MaximumWeight",
"type": "Weight",
"value": "0x00806e8774010000",
"docs": [
" The maximum weight that may be scheduled per block for any dispatchables of less",
" priority than `schedule::HARD_DEADLINE`."
]
},
{
"name": "MaxScheduledPerBlock",
"type": "u32",
"value": "0x32000000",
"docs": [
" The maximum number of scheduled calls in the queue for a single block.",
" Not strictly enforced, but used for weight estimation."
]
}
],
"errors": [
{
"name": "FailedToSchedule",
"docs": [
" Failed to schedule a call"
]
},
{
"name": "NotFound",
"docs": [
" Cannot find the scheduled call."
]
},
{
"name": "TargetBlockNumberInPast",
"docs": [
" Given target block number is in the past."
]
},
{
"name": "RescheduleNoChange",
"docs": [
" Reschedule failed because it does not change scheduled time."
]
}
],
"index": 1
},
{
"name": "Babe",
"storage": {
"prefix": "Babe",
"items": [
{
"name": "EpochIndex",
"modifier": "Default",
"type": {
"plain": "u64"
},
"fallback": "0x0000000000000000",
"docs": [
" Current epoch index."
]
},
{
"name": "Authorities",
"modifier": "Default",
"type": {
"plain": "Vec<(AuthorityId,BabeAuthorityWeight)>"
},
"fallback": "0x00",
"docs": [
" Current epoch authorities."
]
},
{
"name": "GenesisSlot",
"modifier": "Default",
"type": {
"plain": "Slot"
},
"fallback": "0x0000000000000000",
"docs": [
" The slot at which the first epoch actually started. This is 0",
" until the first block of the chain."
]
},
{
"name": "CurrentSlot",
"modifier": "Default",
"type": {
"plain": "Slot"
},
"fallback": "0x0000000000000000",
"docs": [
" Current slot number."
]
},
{
"name": "Randomness",
"modifier": "Default",
"type": {
"plain": "Randomness"
},
"fallback": "0x0000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" The epoch randomness for the *current* epoch.",
"",
" # Security",
"",
" This MUST NOT be used for gambling, as it can be influenced by a",
" malicious validator in the short term. It MAY be used in many",
" cryptographic protocols, however, so long as one remembers that this",
" (like everything else on-chain) it is public. For example, it can be",
" used where a number is needed that cannot have been chosen by an",
" adversary, for purposes such as public-coin zero-knowledge proofs."
]
},
{
"name": "PendingEpochConfigChange",
"modifier": "Optional",
"type": {
"plain": "NextConfigDescriptor"
},
"fallback": "0x00",
"docs": [
" Pending epoch configuration change that will be applied when the next epoch is enacted."
]
},
{
"name": "NextRandomness",
"modifier": "Default",
"type": {
"plain": "Randomness"
},
"fallback": "0x0000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" Next epoch randomness."
]
},
{
"name": "NextAuthorities",
"modifier": "Default",
"type": {
"plain": "Vec<(AuthorityId,BabeAuthorityWeight)>"
},
"fallback": "0x00",
"docs": [
" Next epoch authorities."
]
},
{
"name": "SegmentIndex",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" Randomness under construction.",
"",
" We make a tradeoff between storage accesses and list length.",
" We store the under-construction randomness in segments of up to",
" `UNDER_CONSTRUCTION_SEGMENT_LENGTH`.",
"",
" Once a segment reaches this length, we begin the next one.",
" We reset all segments and return to `0` at the beginning of every",
" epoch."
]
},
{
"name": "UnderConstruction",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "u32",
"value": "Vec<Randomness>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" TWOX-NOTE: `SegmentIndex` is an increasing integer, so this is okay."
]
},
{
"name": "Initialized",
"modifier": "Optional",
"type": {
"plain": "MaybeRandomness"
},
"fallback": "0x00",
"docs": [
" Temporary value (cleared at block finalization) which is `Some`",
" if per-block initialization has already been called for current block."
]
},
{
"name": "AuthorVrfRandomness",
"modifier": "Default",
"type": {
"plain": "MaybeRandomness"
},
"fallback": "0x00",
"docs": [
" This field should always be populated during block processing unless",
" secondary plain slots are enabled (which don't contain a VRF output).",
"",
" It is set in `on_initialize`, before it will contain the value from the last block."
]
},
{
"name": "EpochStart",
"modifier": "Default",
"type": {
"plain": "(BlockNumber,BlockNumber)"
},
"fallback": "0x0000000000000000",
"docs": [
" The block numbers when the last and current epoch have started, respectively `N-1` and",
" `N`.",
" NOTE: We track this is in order to annotate the block number when a given pool of",
" entropy was fixed (i.e. it was known to chain observers). Since epochs are defined in",
" slots, which may be skipped, the block numbers may not line up with the slot numbers."
]
},
{
"name": "Lateness",
"modifier": "Default",
"type": {
"plain": "BlockNumber"
},
"fallback": "0x00000000",
"docs": [
" How late the current block is compared to its parent.",
"",
" This entry is populated as part of block execution and is cleaned up",
" on block finalization. Querying this storage entry outside of block",
" execution context should always yield zero."
]
},
{
"name": "EpochConfig",
"modifier": "Optional",
"type": {
"plain": "BabeEpochConfiguration"
},
"fallback": "0x00",
"docs": [
" The configuration for the current epoch. Should never be `None` as it is initialized in",
" genesis."
]
},
{
"name": "NextEpochConfig",
"modifier": "Optional",
"type": {
"plain": "BabeEpochConfiguration"
},
"fallback": "0x00",
"docs": [
" The configuration for the next epoch, `None` if the config will not change",
" (you can fallback to `EpochConfig` instead in that case)."
]
}
]
},
"calls": [
{
"name": "report_equivocation",
"args": [
{
"name": "equivocation_proof",
"type": "BabeEquivocationProof"
},
{
"name": "key_owner_proof",
"type": "KeyOwnerProof"
}
],
"docs": [
" Report authority equivocation/misbehavior. This method will verify",
" the equivocation proof and validate the given key ownership proof",
" against the extracted offender. If both are valid, the offence will",
" be reported."
]
},
{
"name": "report_equivocation_unsigned",
"args": [
{
"name": "equivocation_proof",
"type": "BabeEquivocationProof"
},
{
"name": "key_owner_proof",
"type": "KeyOwnerProof"
}
],
"docs": [
" Report authority equivocation/misbehavior. This method will verify",
" the equivocation proof and validate the given key ownership proof",
" against the extracted offender. If both are valid, the offence will",
" be reported.",
" This extrinsic must be called unsigned and it is expected that only",
" block authors will call it (validated in `ValidateUnsigned`), as such",
" if the block author is defined it will be defined as the equivocation",
" reporter."
]
},
{
"name": "plan_config_change",
"args": [
{
"name": "config",
"type": "NextConfigDescriptor"
}
],
"docs": [
" Plan an epoch config change. The epoch config change is recorded and will be enacted on",
" the next call to `enact_epoch_change`. The config will be activated one epoch after.",
" Multiple calls to this method will replace any existing planned config change that had",
" not been enacted yet."
]
}
],
"events": null,
"constants": [
{
"name": "EpochDuration",
"type": "u64",
"value": "0x6009000000000000",
"docs": [
" The amount of time, in slots, that each epoch should last.",
" NOTE: Currently it is not possible to change the epoch duration after",
" the chain has started. Attempting to do so will brick block production."
]
},
{
"name": "ExpectedBlockTime",
"type": "Moment",
"value": "0x7017000000000000",
"docs": [
" The expected average block time at which BABE should be creating",
" blocks. Since BABE is probabilistic it is not trivial to figure out",
" what the expected average block time should be based on the slot",
" duration and the security parameter `c` (where `1 - c` represents",
" the probability of a slot being empty)."
]
}
],
"errors": [
{
"name": "InvalidEquivocationProof",
"docs": [
" An equivocation proof provided as part of an equivocation report is invalid."
]
},
{
"name": "InvalidKeyOwnershipProof",
"docs": [
" A key ownership proof provided as part of an equivocation report is invalid."
]
},
{
"name": "DuplicateOffenceReport",
"docs": [
" A given equivocation report is valid but already previously reported."
]
}
],
"index": 2
},
{
"name": "Timestamp",
"storage": {
"prefix": "Timestamp",
"items": [
{
"name": "Now",
"modifier": "Default",
"type": {
"plain": "Moment"
},
"fallback": "0x0000000000000000",
"docs": [
" Current time for the current block."
]
},
{
"name": "DidUpdate",
"modifier": "Default",
"type": {
"plain": "bool"
},
"fallback": "0x00",
"docs": [
" Did the timestamp get updated in this block?"
]
}
]
},
"calls": [
{
"name": "set",
"args": [
{
"name": "now",
"type": "Compact<Moment>"
}
],
"docs": [
" Set the current time.",
"",
" This call should be invoked exactly once per block. It will panic at the finalization",
" phase, if this call hasn't been invoked by that time.",
"",
" The timestamp should be greater than the previous one by the amount specified by",
" `MinimumPeriod`.",
"",
" The dispatch origin for this call must be `Inherent`.",
"",
" # <weight>",
" - `O(1)` (Note that implementations of `OnTimestampSet` must also be `O(1)`)",
" - 1 storage read and 1 storage mutation (codec `O(1)`). (because of `DidUpdate::take` in",
" `on_finalize`)",
" - 1 event handler `on_timestamp_set`. Must be `O(1)`.",
" # </weight>"
]
}
],
"events": null,
"constants": [
{
"name": "MinimumPeriod",
"type": "Moment",
"value": "0xb80b000000000000",
"docs": [
" The minimum period between blocks. Beware that this is different to the *expected*",
" period that the block production apparatus provides. Your chosen consensus system will",
" generally work with this to determine a sensible block time. e.g. For Aura, it will be",
" double this period on default settings."
]
}
],
"errors": [],
"index": 3
},
{
"name": "Indices",
"storage": {
"prefix": "Indices",
"items": [
{
"name": "Accounts",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountIndex",
"value": "(AccountId,BalanceOf,bool)",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The lookup from index to account."
]
}
]
},
"calls": [
{
"name": "claim",
"args": [
{
"name": "index",
"type": "AccountIndex"
}
],
"docs": [
" Assign an previously unassigned index.",
"",
" Payment: `Deposit` is reserved from the sender account.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `index`: the index to be claimed. This must not be in use.",
"",
" Emits `IndexAssigned` if successful.",
"",
" # <weight>",
" - `O(1)`.",
" - One storage mutation (codec `O(1)`).",
" - One reserve operation.",
" - One event.",
" -------------------",
" - DB Weight: 1 Read/Write (Accounts)",
" # </weight>"
]
},
{
"name": "transfer",
"args": [
{
"name": "new",
"type": "AccountId"
},
{
"name": "index",
"type": "AccountIndex"
}
],
"docs": [
" Assign an index already owned by the sender to another account. The balance reservation",
" is effectively transferred to the new account.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `index`: the index to be re-assigned. This must be owned by the sender.",
" - `new`: the new owner of the index. This function is a no-op if it is equal to sender.",
"",
" Emits `IndexAssigned` if successful.",
"",
" # <weight>",
" - `O(1)`.",
" - One storage mutation (codec `O(1)`).",
" - One transfer operation.",
" - One event.",
" -------------------",
" - DB Weight:",
" - Reads: Indices Accounts, System Account (recipient)",
" - Writes: Indices Accounts, System Account (recipient)",
" # </weight>"
]
},
{
"name": "free",
"args": [
{
"name": "index",
"type": "AccountIndex"
}
],
"docs": [
" Free up an index owned by the sender.",
"",
" Payment: Any previous deposit placed for the index is unreserved in the sender account.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must own the index.",
"",
" - `index`: the index to be freed. This must be owned by the sender.",
"",
" Emits `IndexFreed` if successful.",
"",
" # <weight>",
" - `O(1)`.",
" - One storage mutation (codec `O(1)`).",
" - One reserve operation.",
" - One event.",
" -------------------",
" - DB Weight: 1 Read/Write (Accounts)",
" # </weight>"
]
},
{
"name": "force_transfer",
"args": [
{
"name": "new",
"type": "AccountId"
},
{
"name": "index",
"type": "AccountIndex"
},
{
"name": "freeze",
"type": "bool"
}
],
"docs": [
" Force an index to an account. This doesn't require a deposit. If the index is already",
" held, then any deposit is reimbursed to its current owner.",
"",
" The dispatch origin for this call must be _Root_.",
"",
" - `index`: the index to be (re-)assigned.",
" - `new`: the new owner of the index. This function is a no-op if it is equal to sender.",
" - `freeze`: if set to `true`, will freeze the index so it cannot be transferred.",
"",
" Emits `IndexAssigned` if successful.",
"",
" # <weight>",
" - `O(1)`.",
" - One storage mutation (codec `O(1)`).",
" - Up to one reserve operation.",
" - One event.",
" -------------------",
" - DB Weight:",
" - Reads: Indices Accounts, System Account (original owner)",
" - Writes: Indices Accounts, System Account (original owner)",
" # </weight>"
]
},
{
"name": "freeze",
"args": [
{
"name": "index",
"type": "AccountIndex"
}
],
"docs": [
" Freeze an index so it will always point to the sender account. This consumes the",
" deposit.",
"",
" The dispatch origin for this call must be _Signed_ and the signing account must have a",
" non-frozen account `index`.",
"",
" - `index`: the index to be frozen in place.",
"",
" Emits `IndexFrozen` if successful.",
"",
" # <weight>",
" - `O(1)`.",
" - One storage mutation (codec `O(1)`).",
" - Up to one slash operation.",
" - One event.",
" -------------------",
" - DB Weight: 1 Read/Write (Accounts)",
" # </weight>"
]
}
],
"events": [
{
"name": "IndexAssigned",
"args": [
"AccountId",
"AccountIndex"
],
"docs": [
" A account index was assigned. \\[index, who\\]"
]
},
{
"name": "IndexFreed",
"args": [
"AccountIndex"
],
"docs": [
" A account index has been freed up (unassigned). \\[index\\]"
]
},
{
"name": "IndexFrozen",
"args": [
"AccountIndex",
"AccountId"
],
"docs": [
" A account index has been frozen to its current account ID. \\[index, who\\]"
]
}
],
"constants": [
{
"name": "Deposit",
"type": "BalanceOf",
"value": "0x00e87648170000000000000000000000",
"docs": [
" The deposit needed for reserving an index."
]
}
],
"errors": [
{
"name": "NotAssigned",
"docs": [
" The index was not already assigned."
]
},
{
"name": "NotOwner",
"docs": [
" The index is assigned to another account."
]
},
{
"name": "InUse",
"docs": [
" The index was not available."
]
},
{
"name": "NotTransfer",
"docs": [
" The source and destination accounts are identical."
]
},
{
"name": "Permanent",
"docs": [
" The index is permanent and may not be freed/changed."
]
}
],
"index": 4
},
{
"name": "Balances",
"storage": {
"prefix": "Balances",
"items": [
{
"name": "TotalIssuance",
"modifier": "Default",
"type": {
"plain": "Balance"
},
"fallback": "0x00000000000000000000000000000000",
"docs": [
" The total units issued in the system."
]
},
{
"name": "Account",
"modifier": "Default",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "AccountData",
"linked": false
}
},
"fallback": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" The balance of an account.",
"",
" NOTE: This is only used in the case that this pallet is used to store balances."
]
},
{
"name": "Locks",
"modifier": "Default",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "Vec<BalanceLock>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Any liquidity locks on some account balances.",
" NOTE: Should only be accessed when setting, changing and freeing a lock."
]
},
{
"name": "Reserves",
"modifier": "Default",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "Vec<ReserveData>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Named reserves on some account balances."
]
},
{
"name": "StorageVersion",
"modifier": "Default",
"type": {
"plain": "Releases"
},
"fallback": "0x00",
"docs": [
" Storage version of the pallet.",
"",
" This is set to v2.0.0 for new networks."
]
}
]
},
"calls": [
{
"name": "transfer",
"args": [
{
"name": "dest",
"type": "LookupSource"
},
{
"name": "value",
"type": "Compact<Balance>"
}
],
"docs": [
" Transfer some liquid free balance to another account.",
"",
" `transfer` will set the `FreeBalance` of the sender and receiver.",
" It will decrease the total issuance of the system by the `TransferFee`.",
" If the sender's account is below the existential deposit as a result",
" of the transfer, the account will be reaped.",
"",
" The dispatch origin for this call must be `Signed` by the transactor.",
"",
" # <weight>",
" - Dependent on arguments but not critical, given proper implementations for input config",
" types. See related functions below.",
" - It contains a limited number of reads and writes internally and no complex",
" computation.",
"",
" Related functions:",
"",
" - `ensure_can_withdraw` is always called internally but has a bounded complexity.",
" - Transferring balances to accounts that did not exist before will cause",
" `T::OnNewAccount::on_new_account` to be called.",
" - Removing enough funds from an account will trigger `T::DustRemoval::on_unbalanced`.",
" - `transfer_keep_alive` works the same way as `transfer`, but has an additional check",
" that the transfer will not kill the origin account.",
" ---------------------------------",
" - Base Weight: 73.64 µs, worst case scenario (account created, account removed)",
" - DB Weight: 1 Read and 1 Write to destination account",
" - Origin account is already in memory, so no DB operations for them.",
" # </weight>"
]
},
{
"name": "set_balance",
"args": [
{
"name": "who",
"type": "LookupSource"
},
{
"name": "new_free",
"type": "Compact<Balance>"
},
{
"name": "new_reserved",
"type": "Compact<Balance>"
}
],
"docs": [
" Set the balances of a given account.",
"",
" This will alter `FreeBalance` and `ReservedBalance` in storage. it will",
" also decrease the total issuance of the system (`TotalIssuance`).",
" If the new free or reserved balance is below the existential deposit,",
" it will reset the account nonce (`frame_system::AccountNonce`).",
"",
" The dispatch origin for this call is `root`.",
"",
" # <weight>",
" - Independent of the arguments.",
" - Contains a limited number of reads and writes.",
" ---------------------",
" - Base Weight:",
" - Creating: 27.56 µs",
" - Killing: 35.11 µs",
" - DB Weight: 1 Read, 1 Write to `who`",
" # </weight>"
]
},
{
"name": "force_transfer",
"args": [
{
"name": "source",
"type": "LookupSource"
},
{
"name": "dest",
"type": "LookupSource"
},
{
"name": "value",
"type": "Compact<Balance>"
}
],
"docs": [
" Exactly as `transfer`, except the origin must be root and the source account may be",
" specified.",
" # <weight>",
" - Same as transfer, but additional read and write because the source account is not",
" assumed to be in the overlay.",
" # </weight>"
]
},
{
"name": "transfer_keep_alive",
"args": [
{
"name": "dest",
"type": "LookupSource"
},
{
"name": "value",
"type": "Compact<Balance>"
}
],
"docs": [
" Same as the [`transfer`] call, but with a check that the transfer will not kill the",
" origin account.",
"",
" 99% of the time you want [`transfer`] instead.",
"",
" [`transfer`]: struct.Pallet.html#method.transfer",
" # <weight>",
" - Cheaper than transfer because account cannot be killed.",
" - Base Weight: 51.4 µs",
" - DB Weight: 1 Read and 1 Write to dest (sender is in overlay already)",
" #</weight>"
]
},
{
"name": "transfer_all",
"args": [
{
"name": "dest",
"type": "LookupSource"
},
{
"name": "keep_alive",
"type": "bool"
}
],
"docs": [
" Transfer the entire transferable balance from the caller account.",
"",
" NOTE: This function only attempts to transfer _transferable_ balances. This means that",
" any locked, reserved, or existential deposits (when `keep_alive` is `true`), will not be",
" transferred by this function. To ensure that this function results in a killed account,",
" you might need to prepare the account by removing any reference counters, storage",
" deposits, etc...",
"",
" The dispatch origin of this call must be Signed.",
"",
" - `dest`: The recipient of the transfer.",
" - `keep_alive`: A boolean to determine if the `transfer_all` operation should send all",
" of the funds the account has, causing the sender account to be killed (false), or",
" transfer everything except at least the existential deposit, which will guarantee to",
" keep the sender account alive (true). # <weight>",
" - O(1). Just like transfer, but reading the user's transferable balance first.",
" #</weight>"
]
}
],
"events": [
{
"name": "Endowed",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account was created with some free balance. \\[account, free_balance\\]"
]
},
{
"name": "DustLost",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account was removed whose balance was non-zero but below ExistentialDeposit,",
" resulting in an outright loss. \\[account, balance\\]"
]
},
{
"name": "Transfer",
"args": [
"AccountId",
"AccountId",
"Balance"
],
"docs": [
" Transfer succeeded. \\[from, to, value\\]"
]
},
{
"name": "BalanceSet",
"args": [
"AccountId",
"Balance",
"Balance"
],
"docs": [
" A balance was set by root. \\[who, free, reserved\\]"
]
},
{
"name": "Deposit",
"args": [
"AccountId",
"Balance"
],
"docs": [
" Some amount was deposited (e.g. for transaction fees). \\[who, deposit\\]"
]
},
{
"name": "Reserved",
"args": [
"AccountId",
"Balance"
],
"docs": [
" Some balance was reserved (moved from free to reserved). \\[who, value\\]"
]
},
{
"name": "Unreserved",
"args": [
"AccountId",
"Balance"
],
"docs": [
" Some balance was unreserved (moved from reserved to free). \\[who, value\\]"
]
},
{
"name": "ReserveRepatriated",
"args": [
"AccountId",
"AccountId",
"Balance",
"BalanceStatus"
],
"docs": [
" Some balance was moved from the reserve of the first account to the second account.",
" Final argument indicates the destination balance type.",
" \\[from, to, balance, destination_status\\]"
]
}
],
"constants": [
{
"name": "ExistentialDeposit",
"type": "Balance",
"value": "0x00e40b54020000000000000000000000",
"docs": [
" The minimum amount required to keep an account open."
]
},
{
"name": "MaxLocks",
"type": "u32",
"value": "0x32000000",
"docs": [
" The maximum number of locks that should exist on an account.",
" Not strictly enforced, but used for weight estimation."
]
},
{
"name": "MaxReserves",
"type": "u32",
"value": "0x32000000",
"docs": [
" The maximum number of named reserves that can exist on an account."
]
}
],
"errors": [
{
"name": "VestingBalance",
"docs": [
" Vesting balance too high to send value"
]
},
{
"name": "LiquidityRestrictions",
"docs": [
" Account liquidity restrictions prevent withdrawal"
]
},
{
"name": "InsufficientBalance",
"docs": [
" Balance too low to send value"
]
},
{
"name": "ExistentialDeposit",
"docs": [
" Value too low to create account due to existential deposit"
]
},
{
"name": "KeepAlive",
"docs": [
" Transfer/payment would kill account"
]
},
{
"name": "ExistingVestingSchedule",
"docs": [
" A vesting schedule already exists for this account"
]
},
{
"name": "DeadAccount",
"docs": [
" Beneficiary account must pre-exist"
]
},
{
"name": "TooManyReserves",
"docs": [
" Number of named reserves exceed MaxReserves"
]
}
],
"index": 5
},
{
"name": "TransactionPayment",
"storage": {
"prefix": "TransactionPayment",
"items": [
{
"name": "NextFeeMultiplier",
"modifier": "Default",
"type": {
"plain": "Multiplier"
},
"fallback": "0x000064a7b3b6e00d0000000000000000",
"docs": []
},
{
"name": "StorageVersion",
"modifier": "Default",
"type": {
"plain": "Releases"
},
"fallback": "0x00",
"docs": []
}
]
},
"calls": null,
"events": null,
"constants": [
{
"name": "TransactionByteFee",
"type": "BalanceOf",
"value": "0x40420f00000000000000000000000000",
"docs": [
" The fee to be paid for making a transaction; the per-byte portion."
]
},
{
"name": "WeightToFee",
"type": "Vec<WeightToFeeCoefficient>",
"value": "0x040000000000000000000000000000000000b4c4040001",
"docs": [
" The polynomial that is applied in order to derive fee from weight."
]
}
],
"errors": [],
"index": 32
},
{
"name": "Authorship",
"storage": {
"prefix": "Authorship",
"items": [
{
"name": "Uncles",
"modifier": "Default",
"type": {
"plain": "Vec<UncleEntryItem>"
},
"fallback": "0x00",
"docs": [
" Uncles"
]
},
{
"name": "Author",
"modifier": "Optional",
"type": {
"plain": "AccountId"
},
"fallback": "0x00",
"docs": [
" Author of current block."
]
},
{
"name": "DidSetUncles",
"modifier": "Default",
"type": {
"plain": "bool"
},
"fallback": "0x00",
"docs": [
" Whether uncles were already set in this block."
]
}
]
},
"calls": [
{
"name": "set_uncles",
"args": [
{
"name": "new_uncles",
"type": "Vec<Header>"
}
],
"docs": [
" Provide a set of uncles."
]
}
],
"events": null,
"constants": [
{
"name": "UncleGenerations",
"type": "BlockNumber",
"value": "0x00000000",
"docs": [
" The number of blocks back we should accept uncles.",
" This means that we will deal with uncle-parents that are",
" `UncleGenerations + 1` before `now`."
]
}
],
"errors": [
{
"name": "InvalidUncleParent",
"docs": [
" The uncle parent not in the chain."
]
},
{
"name": "UnclesAlreadySet",
"docs": [
" Uncles already set in the block."
]
},
{
"name": "TooManyUncles",
"docs": [
" Too many uncles."
]
},
{
"name": "GenesisUncle",
"docs": [
" The uncle is genesis."
]
},
{
"name": "TooHighUncle",
"docs": [
" The uncle is too high in chain."
]
},
{
"name": "UncleAlreadyIncluded",
"docs": [
" The uncle is already included."
]
},
{
"name": "OldUncle",
"docs": [
" The uncle isn't recent enough to be included."
]
}
],
"index": 6
},
{
"name": "Staking",
"storage": {
"prefix": "Staking",
"items": [
{
"name": "HistoryDepth",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x54000000",
"docs": [
" Number of eras to keep in history.",
"",
" Information is kept for eras in `[current_era - history_depth; current_era]`.",
"",
" Must be more than the number of eras delayed by session otherwise. I.e. active era must",
" always be in history. I.e. `active_era > current_era - history_depth` must be",
" guaranteed."
]
},
{
"name": "ValidatorCount",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" The ideal number of staking participants."
]
},
{
"name": "MinimumValidatorCount",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" Minimum number of staking participants before emergency conditions are imposed."
]
},
{
"name": "Invulnerables",
"modifier": "Default",
"type": {
"plain": "Vec<AccountId>"
},
"fallback": "0x00",
"docs": [
" Any validators that may never be slashed or forcibly kicked. It's a Vec since they're",
" easy to initialize and the performance hit is minimal (we expect no more than four",
" invulnerables) and restricted to testnets."
]
},
{
"name": "Bonded",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "AccountId",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Map from all locked \"stash\" accounts to the controller account."
]
},
{
"name": "MinNominatorBond",
"modifier": "Default",
"type": {
"plain": "BalanceOf"
},
"fallback": "0x00000000000000000000000000000000",
"docs": [
" The minimum active bond to become and maintain the role of a nominator."
]
},
{
"name": "MinValidatorBond",
"modifier": "Default",
"type": {
"plain": "BalanceOf"
},
"fallback": "0x00000000000000000000000000000000",
"docs": [
" The minimum active bond to become and maintain the role of a validator."
]
},
{
"name": "Ledger",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "StakingLedger",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Map from all (unlocked) \"controller\" accounts to the info regarding the staking."
]
},
{
"name": "Payee",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "RewardDestination",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Where the reward payment should be made. Keyed by stash."
]
},
{
"name": "Validators",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "ValidatorPrefs",
"linked": false
}
},
"fallback": "0x0000",
"docs": [
" The map from (wannabe) validator stash key to the preferences of that validator.",
"",
" When updating this storage item, you must also update the `CounterForValidators`."
]
},
{
"name": "CounterForValidators",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" A tracker to keep count of the number of items in the `Validators` map."
]
},
{
"name": "MaxValidatorsCount",
"modifier": "Optional",
"type": {
"plain": "u32"
},
"fallback": "0x00",
"docs": [
" The maximum validator count before we stop allowing new validators to join.",
"",
" When this value is not set, no limits are enforced."
]
},
{
"name": "Nominators",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "Nominations",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The map from nominator stash key to the set of stash keys of all validators to nominate.",
"",
" When updating this storage item, you must also update the `CounterForNominators`."
]
},
{
"name": "CounterForNominators",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" A tracker to keep count of the number of items in the `Nominators` map."
]
},
{
"name": "MaxNominatorsCount",
"modifier": "Optional",
"type": {
"plain": "u32"
},
"fallback": "0x00",
"docs": [
" The maximum nominator count before we stop allowing new validators to join.",
"",
" When this value is not set, no limits are enforced."
]
},
{
"name": "CurrentEra",
"modifier": "Optional",
"type": {
"plain": "EraIndex"
},
"fallback": "0x00",
"docs": [
" The current era index.",
"",
" This is the latest planned era, depending on how the Session pallet queues the validator",
" set, it might be active or not."
]
},
{
"name": "ActiveEra",
"modifier": "Optional",
"type": {
"plain": "ActiveEraInfo"
},
"fallback": "0x00",
"docs": [
" The active era information, it holds index and start.",
"",
" The active era is the era being currently rewarded. Validator set of this era must be",
" equal to [`SessionInterface::validators`]."
]
},
{
"name": "ErasStartSessionIndex",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "EraIndex",
"value": "SessionIndex",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The session index at which the era start for the last `HISTORY_DEPTH` eras.",
"",
" Note: This tracks the starting session (i.e. session index when era start being active)",
" for the eras in `[CurrentEra - HISTORY_DEPTH, CurrentEra]`."
]
},
{
"name": "ErasStakers",
"modifier": "Default",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "EraIndex",
"key2": "AccountId",
"value": "Exposure",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x000000",
"docs": [
" Exposure of validator at era.",
"",
" This is keyed first by the era index to allow bulk deletion and then the stash account.",
"",
" Is it removed after `HISTORY_DEPTH` eras.",
" If stakers hasn't been set or has been removed then empty exposure is returned."
]
},
{
"name": "ErasStakersClipped",
"modifier": "Default",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "EraIndex",
"key2": "AccountId",
"value": "Exposure",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x000000",
"docs": [
" Clipped Exposure of validator at era.",
"",
" This is similar to [`ErasStakers`] but number of nominators exposed is reduced to the",
" `T::MaxNominatorRewardedPerValidator` biggest stakers.",
" (Note: the field `total` and `own` of the exposure remains unchanged).",
" This is used to limit the i/o cost for the nominator payout.",
"",
" This is keyed fist by the era index to allow bulk deletion and then the stash account.",
"",
" Is it removed after `HISTORY_DEPTH` eras.",
" If stakers hasn't been set or has been removed then empty exposure is returned."
]
},
{
"name": "ErasValidatorPrefs",
"modifier": "Default",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "EraIndex",
"key2": "AccountId",
"value": "ValidatorPrefs",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x0000",
"docs": [
" Similar to `ErasStakers`, this holds the preferences of validators.",
"",
" This is keyed first by the era index to allow bulk deletion and then the stash account.",
"",
" Is it removed after `HISTORY_DEPTH` eras."
]
},
{
"name": "ErasValidatorReward",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "EraIndex",
"value": "BalanceOf",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The total validator era payout for the last `HISTORY_DEPTH` eras.",
"",
" Eras that haven't finished yet or has been removed doesn't have reward."
]
},
{
"name": "ErasRewardPoints",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "EraIndex",
"value": "EraRewardPoints",
"linked": false
}
},
"fallback": "0x0000000000",
"docs": [
" Rewards for the last `HISTORY_DEPTH` eras.",
" If reward hasn't been set or has been removed then 0 reward is returned."
]
},
{
"name": "ErasTotalStake",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "EraIndex",
"value": "BalanceOf",
"linked": false
}
},
"fallback": "0x00000000000000000000000000000000",
"docs": [
" The total amount staked for the last `HISTORY_DEPTH` eras.",
" If total hasn't been set or has been removed then 0 stake is returned."
]
},
{
"name": "ForceEra",
"modifier": "Default",
"type": {
"plain": "Forcing"
},
"fallback": "0x00",
"docs": [
" Mode of era forcing."
]
},
{
"name": "SlashRewardFraction",
"modifier": "Default",
"type": {
"plain": "Perbill"
},
"fallback": "0x00000000",
"docs": [
" The percentage of the slash that is distributed to reporters.",
"",
" The rest of the slashed value is handled by the `Slash`."
]
},
{
"name": "CanceledSlashPayout",
"modifier": "Default",
"type": {
"plain": "BalanceOf"
},
"fallback": "0x00000000000000000000000000000000",
"docs": [
" The amount of currency given to reporters of a slash event which was",
" canceled by extraordinary circumstances (e.g. governance)."
]
},
{
"name": "UnappliedSlashes",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "EraIndex",
"value": "Vec<UnappliedSlash>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" All unapplied slashes that are queued for later."
]
},
{
"name": "BondedEras",
"modifier": "Default",
"type": {
"plain": "Vec<(EraIndex,SessionIndex)>"
},
"fallback": "0x00",
"docs": [
" A mapping from still-bonded eras to the first session index of that era.",
"",
" Must contains information for eras for the range:",
" `[active_era - bounding_duration; active_era]`"
]
},
{
"name": "ValidatorSlashInEra",
"modifier": "Optional",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "EraIndex",
"key2": "AccountId",
"value": "(Perbill,BalanceOf)",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x00",
"docs": [
" All slashing events on validators, mapped by era to the highest slash proportion",
" and slash value of the era."
]
},
{
"name": "NominatorSlashInEra",
"modifier": "Optional",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "EraIndex",
"key2": "AccountId",
"value": "BalanceOf",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x00",
"docs": [
" All slashing events on nominators, mapped by era to the highest slash value of the era."
]
},
{
"name": "SlashingSpans",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "SlashingSpans",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Slashing spans for stash accounts."
]
},
{
"name": "SpanSlash",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "(AccountId,SpanIndex)",
"value": "SpanRecord",
"linked": false
}
},
"fallback": "0x0000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" Records information about the maximum slash of a stash within a slashing span,",
" as well as how much reward has been paid out."
]
},
{
"name": "EarliestUnappliedSlash",
"modifier": "Optional",
"type": {
"plain": "EraIndex"
},
"fallback": "0x00",
"docs": [
" The earliest era for which we have a pending, unapplied slash."
]
},
{
"name": "CurrentPlannedSession",
"modifier": "Default",
"type": {
"plain": "SessionIndex"
},
"fallback": "0x00000000",
"docs": [
" The last planned session scheduled by the session pallet.",
"",
" This is basically in sync with the call to [`pallet_session::SessionManager::new_session`]."
]
},
{
"name": "StorageVersion",
"modifier": "Default",
"type": {
"plain": "Releases"
},
"fallback": "0x06",
"docs": [
" True if network has been upgraded to this version.",
" Storage version of the pallet.",
"",
" This is set to v7.0.0 for new networks."
]
},
{
"name": "ChillThreshold",
"modifier": "Optional",
"type": {
"plain": "Percent"
},
"fallback": "0x00",
"docs": [
" The threshold for when users can start calling `chill_other` for other validators /",
" nominators. The threshold is compared to the actual number of validators / nominators",
" (`CountFor*`) in the system compared to the configured max (`Max*Count`)."
]
}
]
},
"calls": [
{
"name": "bond",
"args": [
{
"name": "controller",
"type": "LookupSource"
},
{
"name": "value",
"type": "Compact<BalanceOf>"
},
{
"name": "payee",
"type": "RewardDestination"
}
],
"docs": [
" Take the origin account as a stash and lock up `value` of its balance. `controller` will",
" be the account that controls it.",
"",
" `value` must be more than the `minimum_balance` specified by `T::Currency`.",
"",
" The dispatch origin for this call must be _Signed_ by the stash account.",
"",
" Emits `Bonded`.",
" # <weight>",
" - Independent of the arguments. Moderate complexity.",
" - O(1).",
" - Three extra DB entries.",
"",
" NOTE: Two of the storage writes (`Self::bonded`, `Self::payee`) are _never_ cleaned",
" unless the `origin` falls below _existential deposit_ and gets removed as dust.",
" ------------------",
" # </weight>"
]
},
{
"name": "bond_extra",
"args": [
{
"name": "max_additional",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Add some extra amount that have appeared in the stash `free_balance` into the balance up",
" for staking.",
"",
" The dispatch origin for this call must be _Signed_ by the stash, not the controller.",
"",
" Use this if there are additional funds in your stash account that you wish to bond.",
" Unlike [`bond`](Self::bond) or [`unbond`](Self::unbond) this function does not impose",
" any limitation on the amount that can be added.",
"",
" Emits `Bonded`.",
"",
" # <weight>",
" - Independent of the arguments. Insignificant complexity.",
" - O(1).",
" # </weight>"
]
},
{
"name": "unbond",
"args": [
{
"name": "value",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Schedule a portion of the stash to be unlocked ready for transfer out after the bond",
" period ends. If this leaves an amount actively bonded less than",
" T::Currency::minimum_balance(), then it is increased to the full amount.",
"",
" The dispatch origin for this call must be _Signed_ by the controller, not the stash.",
"",
" Once the unlock period is done, you can call `withdraw_unbonded` to actually move",
" the funds out of management ready for transfer.",
"",
" No more than a limited number of unlocking chunks (see `MAX_UNLOCKING_CHUNKS`)",
" can co-exists at the same time. In that case, [`Call::withdraw_unbonded`] need",
" to be called first to remove some of the chunks (if possible).",
"",
" If a user encounters the `InsufficientBond` error when calling this extrinsic,",
" they should call `chill` first in order to free up their bonded funds.",
"",
" Emits `Unbonded`.",
"",
" See also [`Call::withdraw_unbonded`]."
]
},
{
"name": "withdraw_unbonded",
"args": [
{
"name": "num_slashing_spans",
"type": "u32"
}
],
"docs": [
" Remove any unlocked chunks from the `unlocking` queue from our management.",
"",
" This essentially frees up that balance to be used by the stash account to do",
" whatever it wants.",
"",
" The dispatch origin for this call must be _Signed_ by the controller.",
"",
" Emits `Withdrawn`.",
"",
" See also [`Call::unbond`].",
"",
" # <weight>",
" Complexity O(S) where S is the number of slashing spans to remove",
" NOTE: Weight annotation is the kill scenario, we refund otherwise.",
" # </weight>"
]
},
{
"name": "validate",
"args": [
{
"name": "prefs",
"type": "ValidatorPrefs"
}
],
"docs": [
" Declare the desire to validate for the origin controller.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_ by the controller, not the stash."
]
},
{
"name": "nominate",
"args": [
{
"name": "targets",
"type": "Vec<LookupSource>"
}
],
"docs": [
" Declare the desire to nominate `targets` for the origin controller.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_ by the controller, not the stash.",
"",
" # <weight>",
" - The transaction's complexity is proportional to the size of `targets` (N)",
" which is capped at CompactAssignments::LIMIT (MAX_NOMINATIONS).",
" - Both the reads and writes follow a similar pattern.",
" # </weight>"
]
},
{
"name": "chill",
"args": [],
"docs": [
" Declare no desire to either validate or nominate.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_ by the controller, not the stash.",
"",
" # <weight>",
" - Independent of the arguments. Insignificant complexity.",
" - Contains one read.",
" - Writes are limited to the `origin` account key.",
" # </weight>"
]
},
{
"name": "set_payee",
"args": [
{
"name": "payee",
"type": "RewardDestination"
}
],
"docs": [
" (Re-)set the payment target for a controller.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_ by the controller, not the stash.",
"",
" # <weight>",
" - Independent of the arguments. Insignificant complexity.",
" - Contains a limited number of reads.",
" - Writes are limited to the `origin` account key.",
" ---------",
" - Weight: O(1)",
" - DB Weight:",
" - Read: Ledger",
" - Write: Payee",
" # </weight>"
]
},
{
"name": "set_controller",
"args": [
{
"name": "controller",
"type": "LookupSource"
}
],
"docs": [
" (Re-)set the controller of a stash.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_ by the stash, not the controller.",
"",
" # <weight>",
" - Independent of the arguments. Insignificant complexity.",
" - Contains a limited number of reads.",
" - Writes are limited to the `origin` account key.",
" ----------",
" Weight: O(1)",
" DB Weight:",
" - Read: Bonded, Ledger New Controller, Ledger Old Controller",
" - Write: Bonded, Ledger New Controller, Ledger Old Controller",
" # </weight>"
]
},
{
"name": "set_validator_count",
"args": [
{
"name": "new",
"type": "Compact<u32>"
}
],
"docs": [
" Sets the ideal number of validators.",
"",
" The dispatch origin must be Root.",
"",
" # <weight>",
" Weight: O(1)",
" Write: Validator Count",
" # </weight>"
]
},
{
"name": "increase_validator_count",
"args": [
{
"name": "additional",
"type": "Compact<u32>"
}
],
"docs": [
" Increments the ideal number of validators.",
"",
" The dispatch origin must be Root.",
"",
" # <weight>",
" Same as [`Self::set_validator_count`].",
" # </weight>"
]
},
{
"name": "scale_validator_count",
"args": [
{
"name": "factor",
"type": "Percent"
}
],
"docs": [
" Scale up the ideal number of validators by a factor.",
"",
" The dispatch origin must be Root.",
"",
" # <weight>",
" Same as [`Self::set_validator_count`].",
" # </weight>"
]
},
{
"name": "force_no_eras",
"args": [],
"docs": [
" Force there to be no new eras indefinitely.",
"",
" The dispatch origin must be Root.",
"",
" # Warning",
"",
" The election process starts multiple blocks before the end of the era.",
" Thus the election process may be ongoing when this is called. In this case the",
" election will continue until the next era is triggered.",
"",
" # <weight>",
" - No arguments.",
" - Weight: O(1)",
" - Write: ForceEra",
" # </weight>"
]
},
{
"name": "force_new_era",
"args": [],
"docs": [
" Force there to be a new era at the end of the next session. After this, it will be",
" reset to normal (non-forced) behaviour.",
"",
" The dispatch origin must be Root.",
"",
" # Warning",
"",
" The election process starts multiple blocks before the end of the era.",
" If this is called just before a new era is triggered, the election process may not",
" have enough blocks to get a result.",
"",
" # <weight>",
" - No arguments.",
" - Weight: O(1)",
" - Write ForceEra",
" # </weight>"
]
},
{
"name": "set_invulnerables",
"args": [
{
"name": "invulnerables",
"type": "Vec<AccountId>"
}
],
"docs": [
" Set the validators who cannot be slashed (if any).",
"",
" The dispatch origin must be Root.",
"",
" # <weight>",
" - O(V)",
" - Write: Invulnerables",
" # </weight>"
]
},
{
"name": "force_unstake",
"args": [
{
"name": "stash",
"type": "AccountId"
},
{
"name": "num_slashing_spans",
"type": "u32"
}
],
"docs": [
" Force a current staker to become completely unstaked, immediately.",
"",
" The dispatch origin must be Root.",
"",
" # <weight>",
" O(S) where S is the number of slashing spans to be removed",
" Reads: Bonded, Slashing Spans, Account, Locks",
" Writes: Bonded, Slashing Spans (if S > 0), Ledger, Payee, Validators, Nominators,",
" Account, Locks Writes Each: SpanSlash * S",
" # </weight>"
]
},
{
"name": "force_new_era_always",
"args": [],
"docs": [
" Force there to be a new era at the end of sessions indefinitely.",
"",
" The dispatch origin must be Root.",
"",
" # Warning",
"",
" The election process starts multiple blocks before the end of the era.",
" If this is called just before a new era is triggered, the election process may not",
" have enough blocks to get a result.",
"",
" # <weight>",
" - Weight: O(1)",
" - Write: ForceEra",
" # </weight>"
]
},
{
"name": "cancel_deferred_slash",
"args": [
{
"name": "era",
"type": "EraIndex"
},
{
"name": "slash_indices",
"type": "Vec<u32>"
}
],
"docs": [
" Cancel enactment of a deferred slash.",
"",
" Can be called by the `T::SlashCancelOrigin`.",
"",
" Parameters: era and indices of the slashes for that era to kill.",
"",
" # <weight>",
" Complexity: O(U + S)",
" with U unapplied slashes weighted with U=1000",
" and S is the number of slash indices to be canceled.",
" - Read: Unapplied Slashes",
" - Write: Unapplied Slashes",
" # </weight>"
]
},
{
"name": "payout_stakers",
"args": [
{
"name": "validator_stash",
"type": "AccountId"
},
{
"name": "era",
"type": "EraIndex"
}
],
"docs": [
" Pay out all the stakers behind a single validator for a single era.",
"",
" - `validator_stash` is the stash account of the validator. Their nominators, up to",
" `T::MaxNominatorRewardedPerValidator`, will also receive their rewards.",
" - `era` may be any era between `[current_era - history_depth; current_era]`.",
"",
" The origin of this call must be _Signed_. Any account can call this function, even if",
" it is not one of the stakers.",
"",
" # <weight>",
" - Time complexity: at most O(MaxNominatorRewardedPerValidator).",
" - Contains a limited number of reads and writes.",
" -----------",
" N is the Number of payouts for the validator (including the validator)",
" Weight:",
" - Reward Destination Staked: O(N)",
" - Reward Destination Controller (Creating): O(N)",
"",
" NOTE: weights are assuming that payouts are made to alive stash account (Staked).",
" Paying even a dead controller is cheaper weight-wise. We don't do any refunds here.",
" # </weight>"
]
},
{
"name": "rebond",
"args": [
{
"name": "value",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Rebond a portion of the stash scheduled to be unlocked.",
"",
" The dispatch origin must be signed by the controller.",
"",
" # <weight>",
" - Time complexity: O(L), where L is unlocking chunks",
" - Bounded by `MAX_UNLOCKING_CHUNKS`.",
" - Storage changes: Can't increase storage, only decrease it.",
" # </weight>"
]
},
{
"name": "set_history_depth",
"args": [
{
"name": "new_history_depth",
"type": "Compact<EraIndex>"
},
{
"name": "_era_items_deleted",
"type": "Compact<u32>"
}
],
"docs": [
" Set `HistoryDepth` value. This function will delete any history information",
" when `HistoryDepth` is reduced.",
"",
" Parameters:",
" - `new_history_depth`: The new history depth you would like to set.",
" - `era_items_deleted`: The number of items that will be deleted by this dispatch. This",
" should report all the storage items that will be deleted by clearing old era history.",
" Needed to report an accurate weight for the dispatch. Trusted by `Root` to report an",
" accurate number.",
"",
" Origin must be root.",
"",
" # <weight>",
" - E: Number of history depths removed, i.e. 10 -> 7 = 3",
" - Weight: O(E)",
" - DB Weight:",
" - Reads: Current Era, History Depth",
" - Writes: History Depth",
" - Clear Prefix Each: Era Stakers, EraStakersClipped, ErasValidatorPrefs",
" - Writes Each: ErasValidatorReward, ErasRewardPoints, ErasTotalStake,",
" ErasStartSessionIndex",
" # </weight>"
]
},
{
"name": "reap_stash",
"args": [
{
"name": "stash",
"type": "AccountId"
},
{
"name": "num_slashing_spans",
"type": "u32"
}
],
"docs": [
" Remove all data structure concerning a staker/stash once its balance is at the minimum.",
" This is essentially equivalent to `withdraw_unbonded` except it can be called by anyone",
" and the target `stash` must have no funds left beyond the ED.",
"",
" This can be called from any origin.",
"",
" - `stash`: The stash account to reap. Its balance must be zero.",
"",
" # <weight>",
" Complexity: O(S) where S is the number of slashing spans on the account.",
" DB Weight:",
" - Reads: Stash Account, Bonded, Slashing Spans, Locks",
" - Writes: Bonded, Slashing Spans (if S > 0), Ledger, Payee, Validators, Nominators,",
" Stash Account, Locks",
" - Writes Each: SpanSlash * S",
" # </weight>"
]
},
{
"name": "kick",
"args": [
{
"name": "who",
"type": "Vec<LookupSource>"
}
],
"docs": [
" Remove the given nominations from the calling validator.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_ by the controller, not the stash.",
"",
" - `who`: A list of nominator stash accounts who are nominating this validator which",
" should no longer be nominating this validator.",
"",
" Note: Making this call only makes sense if you first set the validator preferences to",
" block any further nominations."
]
},
{
"name": "set_staking_limits",
"args": [
{
"name": "min_nominator_bond",
"type": "BalanceOf"
},
{
"name": "min_validator_bond",
"type": "BalanceOf"
},
{
"name": "max_nominator_count",
"type": "Option<u32>"
},
{
"name": "max_validator_count",
"type": "Option<u32>"
},
{
"name": "threshold",
"type": "Option<Percent>"
}
],
"docs": [
" Update the various staking limits this pallet.",
"",
" * `min_nominator_bond`: The minimum active bond needed to be a nominator.",
" * `min_validator_bond`: The minimum active bond needed to be a validator.",
" * `max_nominator_count`: The max number of users who can be a nominator at once. When",
" set to `None`, no limit is enforced.",
" * `max_validator_count`: The max number of users who can be a validator at once. When",
" set to `None`, no limit is enforced.",
"",
" Origin must be Root to call this function.",
"",
" NOTE: Existing nominators and validators will not be affected by this update.",
" to kick people under the new limits, `chill_other` should be called."
]
},
{
"name": "chill_other",
"args": [
{
"name": "controller",
"type": "AccountId"
}
],
"docs": [
" Declare a `controller` to stop participating as either a validator or nominator.",
"",
" Effects will be felt at the beginning of the next era.",
"",
" The dispatch origin for this call must be _Signed_, but can be called by anyone.",
"",
" If the caller is the same as the controller being targeted, then no further checks are",
" enforced, and this function behaves just like `chill`.",
"",
" If the caller is different than the controller being targeted, the following conditions",
" must be met:",
" * A `ChillThreshold` must be set and checked which defines how close to the max",
" nominators or validators we must reach before users can start chilling one-another.",
" * A `MaxNominatorCount` and `MaxValidatorCount` must be set which is used to determine",
" how close we are to the threshold.",
" * A `MinNominatorBond` and `MinValidatorBond` must be set and checked, which determines",
" if this is a person that should be chilled because they have not met the threshold",
" bond required.",
"",
" This can be helpful if bond requirements are updated, and we need to remove old users",
" who do not satisfy these requirements."
]
}
],
"events": [
{
"name": "EraPaid",
"args": [
"EraIndex",
"Balance",
"Balance"
],
"docs": [
" The era payout has been set; the first balance is the validator-payout; the second is",
" the remainder from the maximum amount of reward.",
" \\[era_index, validator_payout, remainder\\]"
]
},
{
"name": "Rewarded",
"args": [
"AccountId",
"Balance"
],
"docs": [
" The nominator has been rewarded by this amount. \\[stash, amount\\]"
]
},
{
"name": "Slashed",
"args": [
"AccountId",
"Balance"
],
"docs": [
" One validator (and its nominators) has been slashed by the given amount.",
" \\[validator, amount\\]"
]
},
{
"name": "OldSlashingReportDiscarded",
"args": [
"SessionIndex"
],
"docs": [
" An old slashing report from a prior era was discarded because it could",
" not be processed. \\[session_index\\]"
]
},
{
"name": "StakersElected",
"args": [],
"docs": [
" A new set of stakers was elected."
]
},
{
"name": "Bonded",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account has bonded this amount. \\[stash, amount\\]",
"",
" NOTE: This event is only emitted when funds are bonded via a dispatchable. Notably,",
" it will not be emitted for staking rewards when they are added to stake."
]
},
{
"name": "Unbonded",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account has unbonded this amount. \\[stash, amount\\]"
]
},
{
"name": "Withdrawn",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account has called `withdraw_unbonded` and removed unbonding chunks worth `Balance`",
" from the unlocking queue. \\[stash, amount\\]"
]
},
{
"name": "Kicked",
"args": [
"AccountId",
"AccountId"
],
"docs": [
" A nominator has been kicked from a validator. \\[nominator, stash\\]"
]
},
{
"name": "StakingElectionFailed",
"args": [],
"docs": [
" The election failed. No new era is planned."
]
},
{
"name": "Chilled",
"args": [
"AccountId"
],
"docs": [
" An account has stopped participating as either a validator or nominator.",
" \\[stash\\]"
]
},
{
"name": "PayoutStarted",
"args": [
"EraIndex",
"AccountId"
],
"docs": [
" The stakers' rewards are getting paid. \\[era_index, validator_stash\\]"
]
}
],
"constants": [
{
"name": "SessionsPerEra",
"type": "SessionIndex",
"value": "0x06000000",
"docs": [
" Number of sessions per era."
]
},
{
"name": "BondingDuration",
"type": "EraIndex",
"value": "0x1c000000",
"docs": [
" Number of eras that staked funds must remain bonded for."
]
},
{
"name": "SlashDeferDuration",
"type": "EraIndex",
"value": "0x1b000000",
"docs": [
" Number of eras that slashes are deferred by, after computation.",
"",
" This should be less than the bonding duration. Set to 0 if slashes",
" should be applied immediately, without opportunity for intervention."
]
},
{
"name": "MaxNominatorRewardedPerValidator",
"type": "u32",
"value": "0x00010000",
"docs": [
" The maximum number of nominators rewarded for each validator.",
"",
" For each validator only the `$MaxNominatorRewardedPerValidator` biggest stakers can",
" claim their reward. This used to limit the i/o cost for the nominator payout."
]
},
{
"name": "MaxNominations",
"type": "u32",
"value": "0x10000000",
"docs": []
}
],
"errors": [
{
"name": "NotController",
"docs": [
" Not a controller account."
]
},
{
"name": "NotStash",
"docs": [
" Not a stash account."
]
},
{
"name": "AlreadyBonded",
"docs": [
" Stash is already bonded."
]
},
{
"name": "AlreadyPaired",
"docs": [
" Controller is already paired."
]
},
{
"name": "EmptyTargets",
"docs": [
" Targets cannot be empty."
]
},
{
"name": "DuplicateIndex",
"docs": [
" Duplicate index."
]
},
{
"name": "InvalidSlashIndex",
"docs": [
" Slash record index out of bounds."
]
},
{
"name": "InsufficientBond",
"docs": [
" Can not bond with value less than minimum required."
]
},
{
"name": "NoMoreChunks",
"docs": [
" Can not schedule more unlock chunks."
]
},
{
"name": "NoUnlockChunk",
"docs": [
" Can not rebond without unlocking chunks."
]
},
{
"name": "FundedTarget",
"docs": [
" Attempting to target a stash that still has funds."
]
},
{
"name": "InvalidEraToReward",
"docs": [
" Invalid era to reward."
]
},
{
"name": "InvalidNumberOfNominations",
"docs": [
" Invalid number of nominations."
]
},
{
"name": "NotSortedAndUnique",
"docs": [
" Items are not sorted and unique."
]
},
{
"name": "AlreadyClaimed",
"docs": [
" Rewards for this era have already been claimed for this validator."
]
},
{
"name": "IncorrectHistoryDepth",
"docs": [
" Incorrect previous history depth input provided."
]
},
{
"name": "IncorrectSlashingSpans",
"docs": [
" Incorrect number of slashing spans provided."
]
},
{
"name": "BadState",
"docs": [
" Internal state has become somehow corrupted and the operation cannot continue."
]
},
{
"name": "TooManyTargets",
"docs": [
" Too many nomination targets supplied."
]
},
{
"name": "BadTarget",
"docs": [
" A nomination target was supplied that was blocked or otherwise not a validator."
]
},
{
"name": "CannotChillOther",
"docs": [
" The user has enough bond and thus cannot be chilled forcefully by an external person."
]
},
{
"name": "TooManyNominators",
"docs": [
" There are too many nominators in the system. Governance needs to adjust the staking",
" settings to keep things safe for the runtime."
]
},
{
"name": "TooManyValidators",
"docs": [
" There are too many validators in the system. Governance needs to adjust the staking",
" settings to keep things safe for the runtime."
]
}
],
"index": 7
},
{
"name": "Offences",
"storage": {
"prefix": "Offences",
"items": [
{
"name": "Reports",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "ReportIdOf",
"value": "OffenceDetails",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The primary structure that holds all offence records keyed by report identifiers."
]
},
{
"name": "ConcurrentReportsIndex",
"modifier": "Default",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "Kind",
"key2": "OpaqueTimeSlot",
"value": "Vec<ReportIdOf>",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x00",
"docs": [
" A vector of reports of the same kind that happened at the same time slot."
]
},
{
"name": "ReportsByKindIndex",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "Kind",
"value": "Bytes",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Enumerates all reports of a kind along with the time they happened.",
"",
" All reports are sorted by the time of offence.",
"",
" Note that the actual type of this mapping is `Vec<u8>`, this is because values of",
" different types are not supported at the moment so we are doing the manual serialization."
]
}
]
},
"calls": null,
"events": [
{
"name": "Offence",
"args": [
"Kind",
"OpaqueTimeSlot"
],
"docs": [
" There is an offence reported of the given `kind` happened at the `session_index` and",
" (kind-specific) time slot. This event is not deposited for duplicate slashes.",
" \\[kind, timeslot\\]."
]
}
],
"constants": [],
"errors": [],
"index": 8
},
{
"name": "Historical",
"storage": null,
"calls": null,
"events": null,
"constants": [],
"errors": [],
"index": 33
},
{
"name": "Session",
"storage": {
"prefix": "Session",
"items": [
{
"name": "Validators",
"modifier": "Default",
"type": {
"plain": "Vec<ValidatorId>"
},
"fallback": "0x00",
"docs": [
" The current set of validators."
]
},
{
"name": "CurrentIndex",
"modifier": "Default",
"type": {
"plain": "SessionIndex"
},
"fallback": "0x00000000",
"docs": [
" Current index of the session."
]
},
{
"name": "QueuedChanged",
"modifier": "Default",
"type": {
"plain": "bool"
},
"fallback": "0x00",
"docs": [
" True if the underlying economic identities or weighting behind the validators",
" has changed in the queued validator set."
]
},
{
"name": "QueuedKeys",
"modifier": "Default",
"type": {
"plain": "Vec<(ValidatorId,Keys)>"
},
"fallback": "0x00",
"docs": [
" The queued keys for the next session. When the next session begins, these keys",
" will be used to determine the validator's session keys."
]
},
{
"name": "DisabledValidators",
"modifier": "Default",
"type": {
"plain": "Vec<u32>"
},
"fallback": "0x00",
"docs": [
" Indices of disabled validators.",
"",
" The set is cleared when `on_session_ending` returns a new set of identities."
]
},
{
"name": "NextKeys",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "ValidatorId",
"value": "Keys",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The next session keys for a validator."
]
},
{
"name": "KeyOwner",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "(KeyTypeId,Bytes)",
"value": "ValidatorId",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The owner of a key. The key is the `KeyTypeId` + the encoded key."
]
}
]
},
"calls": [
{
"name": "set_keys",
"args": [
{
"name": "keys",
"type": "Keys"
},
{
"name": "proof",
"type": "Bytes"
}
],
"docs": [
" Sets the session key(s) of the function caller to `keys`.",
" Allows an account to set its session key prior to becoming a validator.",
" This doesn't take effect until the next session.",
"",
" The dispatch origin of this function must be signed.",
"",
" # <weight>",
" - Complexity: `O(1)`",
" Actual cost depends on the number of length of `T::Keys::key_ids()` which is fixed.",
" - DbReads: `origin account`, `T::ValidatorIdOf`, `NextKeys`",
" - DbWrites: `origin account`, `NextKeys`",
" - DbReads per key id: `KeyOwner`",
" - DbWrites per key id: `KeyOwner`",
" # </weight>"
]
},
{
"name": "purge_keys",
"args": [],
"docs": [
" Removes any session key(s) of the function caller.",
" This doesn't take effect until the next session.",
"",
" The dispatch origin of this function must be signed.",
"",
" # <weight>",
" - Complexity: `O(1)` in number of key types.",
" Actual cost depends on the number of length of `T::Keys::key_ids()` which is fixed.",
" - DbReads: `T::ValidatorIdOf`, `NextKeys`, `origin account`",
" - DbWrites: `NextKeys`, `origin account`",
" - DbWrites per key id: `KeyOwner`",
" # </weight>"
]
}
],
"events": [
{
"name": "NewSession",
"args": [
"SessionIndex"
],
"docs": [
" New session has happened. Note that the argument is the \\[session_index\\], not the",
" block number as the type might suggest."
]
}
],
"constants": [],
"errors": [
{
"name": "InvalidProof",
"docs": [
" Invalid ownership proof."
]
},
{
"name": "NoAssociatedValidatorId",
"docs": [
" No associated validator ID for account."
]
},
{
"name": "DuplicatedKey",
"docs": [
" Registered duplicate key."
]
},
{
"name": "NoKeys",
"docs": [
" No keys are associated with this account."
]
},
{
"name": "NoAccount",
"docs": [
" Key setting account is not live, so it's impossible to associate keys."
]
}
],
"index": 9
},
{
"name": "Grandpa",
"storage": {
"prefix": "Grandpa",
"items": [
{
"name": "State",
"modifier": "Default",
"type": {
"plain": "StoredState"
},
"fallback": "0x00",
"docs": [
" State of the current authority set."
]
},
{
"name": "PendingChange",
"modifier": "Optional",
"type": {
"plain": "StoredPendingChange"
},
"fallback": "0x00",
"docs": [
" Pending change: (signaled at, scheduled change)."
]
},
{
"name": "NextForced",
"modifier": "Optional",
"type": {
"plain": "BlockNumber"
},
"fallback": "0x00",
"docs": [
" next block number where we can force a change."
]
},
{
"name": "Stalled",
"modifier": "Optional",
"type": {
"plain": "(BlockNumber,BlockNumber)"
},
"fallback": "0x00",
"docs": [
" `true` if we are currently stalled."
]
},
{
"name": "CurrentSetId",
"modifier": "Default",
"type": {
"plain": "SetId"
},
"fallback": "0x0000000000000000",
"docs": [
" The number of changes (both in terms of keys and underlying economic responsibilities)",
" in the \"set\" of Grandpa validators from genesis."
]
},
{
"name": "SetIdSession",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "SetId",
"value": "SessionIndex",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" A mapping from grandpa set ID to the index of the *most recent* session for which its",
" members were responsible.",
"",
" TWOX-NOTE: `SetId` is not under user control."
]
}
]
},
"calls": [
{
"name": "report_equivocation",
"args": [
{
"name": "equivocation_proof",
"type": "GrandpaEquivocationProof"
},
{
"name": "key_owner_proof",
"type": "KeyOwnerProof"
}
],
"docs": [
" Report voter equivocation/misbehavior. This method will verify the",
" equivocation proof and validate the given key ownership proof",
" against the extracted offender. If both are valid, the offence",
" will be reported."
]
},
{
"name": "report_equivocation_unsigned",
"args": [
{
"name": "equivocation_proof",
"type": "GrandpaEquivocationProof"
},
{
"name": "key_owner_proof",
"type": "KeyOwnerProof"
}
],
"docs": [
" Report voter equivocation/misbehavior. This method will verify the",
" equivocation proof and validate the given key ownership proof",
" against the extracted offender. If both are valid, the offence",
" will be reported.",
"",
" This extrinsic must be called unsigned and it is expected that only",
" block authors will call it (validated in `ValidateUnsigned`), as such",
" if the block author is defined it will be defined as the equivocation",
" reporter."
]
},
{
"name": "note_stalled",
"args": [
{
"name": "delay",
"type": "BlockNumber"
},
{
"name": "best_finalized_block_number",
"type": "BlockNumber"
}
],
"docs": [
" Note that the current authority set of the GRANDPA finality gadget has",
" stalled. This will trigger a forced authority set change at the beginning",
" of the next session, to be enacted `delay` blocks after that. The delay",
" should be high enough to safely assume that the block signalling the",
" forced change will not be re-orged (e.g. 1000 blocks). The GRANDPA voters",
" will start the new authority set using the given finalized block as base.",
" Only callable by root."
]
}
],
"events": [
{
"name": "NewAuthorities",
"args": [
"AuthorityList"
],
"docs": [
" New authority set has been applied. \\[authority_set\\]"
]
},
{
"name": "Paused",
"args": [],
"docs": [
" Current authority set has been paused."
]
},
{
"name": "Resumed",
"args": [],
"docs": [
" Current authority set has been resumed."
]
}
],
"constants": [],
"errors": [
{
"name": "PauseFailed",
"docs": [
" Attempt to signal GRANDPA pause when the authority set isn't live",
" (either paused or already pending pause)."
]
},
{
"name": "ResumeFailed",
"docs": [
" Attempt to signal GRANDPA resume when the authority set isn't paused",
" (either live or already pending resume)."
]
},
{
"name": "ChangePending",
"docs": [
" Attempt to signal GRANDPA change with one already pending."
]
},
{
"name": "TooSoon",
"docs": [
" Cannot signal forced change so soon after last."
]
},
{
"name": "InvalidKeyOwnershipProof",
"docs": [
" A key ownership proof provided as part of an equivocation report is invalid."
]
},
{
"name": "InvalidEquivocationProof",
"docs": [
" An equivocation proof provided as part of an equivocation report is invalid."
]
},
{
"name": "DuplicateOffenceReport",
"docs": [
" A given equivocation report is valid but already previously reported."
]
}
],
"index": 11
},
{
"name": "ImOnline",
"storage": {
"prefix": "ImOnline",
"items": [
{
"name": "HeartbeatAfter",
"modifier": "Default",
"type": {
"plain": "BlockNumber"
},
"fallback": "0x00000000",
"docs": [
" The block number after which it's ok to send heartbeats in the current",
" session.",
"",
" At the beginning of each session we set this to a value that should fall",
" roughly in the middle of the session duration. The idea is to first wait for",
" the validators to produce a block in the current session, so that the",
" heartbeat later on will not be necessary.",
"",
" This value will only be used as a fallback if we fail to get a proper session",
" progress estimate from `NextSessionRotation`, as those estimates should be",
" more accurate then the value we calculate for `HeartbeatAfter`."
]
},
{
"name": "Keys",
"modifier": "Default",
"type": {
"plain": "Vec<AuthorityId>"
},
"fallback": "0x00",
"docs": [
" The current set of keys that may issue a heartbeat."
]
},
{
"name": "ReceivedHeartbeats",
"modifier": "Optional",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "SessionIndex",
"key2": "AuthIndex",
"value": "Bytes",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x00",
"docs": [
" For each session index, we keep a mapping of `AuthIndex` to",
" `offchain::OpaqueNetworkState`."
]
},
{
"name": "AuthoredBlocks",
"modifier": "Default",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "SessionIndex",
"key2": "ValidatorId",
"value": "u32",
"key2Hasher": "Twox64Concat"
}
},
"fallback": "0x00000000",
"docs": [
" For each session index, we keep a mapping of `ValidatorId<T>` to the",
" number of blocks authored by the given authority."
]
}
]
},
"calls": [
{
"name": "heartbeat",
"args": [
{
"name": "heartbeat",
"type": "Heartbeat"
},
{
"name": "_signature",
"type": "Signature"
}
],
"docs": [
" # <weight>",
" - Complexity: `O(K + E)` where K is length of `Keys` (heartbeat.validators_len) and E is",
" length of `heartbeat.network_state.external_address`",
" - `O(K)`: decoding of length `K`",
" - `O(E)`: decoding/encoding of length `E`",
" - DbReads: pallet_session `Validators`, pallet_session `CurrentIndex`, `Keys`,",
" `ReceivedHeartbeats`",
" - DbWrites: `ReceivedHeartbeats`",
" # </weight>"
]
}
],
"events": [
{
"name": "HeartbeatReceived",
"args": [
"AuthorityId"
],
"docs": [
" A new heartbeat was received from `AuthorityId` \\[authority_id\\]"
]
},
{
"name": "AllGood",
"args": [],
"docs": [
" At the end of the session, no offence was committed."
]
},
{
"name": "SomeOffline",
"args": [
"Vec<IdentificationTuple>"
],
"docs": [
" At the end of the session, at least one validator was found to be \\[offline\\]."
]
}
],
"constants": [
{
"name": "UnsignedPriority",
"type": "TransactionPriority",
"value": "0xffffffffffffffff",
"docs": [
" A configuration for base priority of unsigned transactions.",
"",
" This is exposed so that it can be tuned for particular runtime, when",
" multiple pallets send unsigned transactions."
]
}
],
"errors": [
{
"name": "InvalidKey",
"docs": [
" Non existent public key."
]
},
{
"name": "DuplicatedHeartbeat",
"docs": [
" Duplicated heartbeat."
]
}
],
"index": 12
},
{
"name": "AuthorityDiscovery",
"storage": null,
"calls": null,
"events": null,
"constants": [],
"errors": [],
"index": 13
},
{
"name": "Democracy",
"storage": {
"prefix": "Democracy",
"items": [
{
"name": "PublicPropCount",
"modifier": "Default",
"type": {
"plain": "PropIndex"
},
"fallback": "0x00000000",
"docs": [
" The number of (public) proposals that have been made so far."
]
},
{
"name": "PublicProps",
"modifier": "Default",
"type": {
"plain": "Vec<(PropIndex,Hash,AccountId)>"
},
"fallback": "0x00",
"docs": [
" The public proposals. Unsorted. The second item is the proposal's hash."
]
},
{
"name": "DepositOf",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "PropIndex",
"value": "(Vec<AccountId>,BalanceOf)",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Those who have locked a deposit.",
"",
" TWOX-NOTE: Safe, as increasing integer keys are safe."
]
},
{
"name": "Preimages",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "PreimageStatus",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Map of hashes to the proposal preimage, along with who registered it and their deposit.",
" The block number is the block at which it was deposited."
]
},
{
"name": "ReferendumCount",
"modifier": "Default",
"type": {
"plain": "ReferendumIndex"
},
"fallback": "0x00000000",
"docs": [
" The next free referendum index, aka the number of referenda started so far."
]
},
{
"name": "LowestUnbaked",
"modifier": "Default",
"type": {
"plain": "ReferendumIndex"
},
"fallback": "0x00000000",
"docs": [
" The lowest referendum index representing an unbaked referendum. Equal to",
" `ReferendumCount` if there isn't a unbaked referendum."
]
},
{
"name": "ReferendumInfoOf",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "ReferendumIndex",
"value": "ReferendumInfo",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Information concerning any given referendum.",
"",
" TWOX-NOTE: SAFE as indexes are not under an attacker’s control."
]
},
{
"name": "VotingOf",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "Voting",
"linked": false
}
},
"fallback": "0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" All votes for a particular voter. We store the balance for the number of votes that we",
" have recorded. The second item is the total amount of delegations, that will be added.",
"",
" TWOX-NOTE: SAFE as `AccountId`s are crypto hashes anyway."
]
},
{
"name": "Locks",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "BlockNumber",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Accounts for which there are locks in action which may be removed at some point in the",
" future. The value is the block number at which the lock expires and may be removed.",
"",
" TWOX-NOTE: OK ― `AccountId` is a secure hash."
]
},
{
"name": "LastTabledWasExternal",
"modifier": "Default",
"type": {
"plain": "bool"
},
"fallback": "0x00",
"docs": [
" True if the last referendum tabled was submitted externally. False if it was a public",
" proposal."
]
},
{
"name": "NextExternal",
"modifier": "Optional",
"type": {
"plain": "(Hash,VoteThreshold)"
},
"fallback": "0x00",
"docs": [
" The referendum to be tabled whenever it would be valid to table an external proposal.",
" This happens when a referendum needs to be tabled and one of two conditions are met:",
" - `LastTabledWasExternal` is `false`; or",
" - `PublicProps` is empty."
]
},
{
"name": "Blacklist",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "(BlockNumber,Vec<AccountId>)",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" A record of who vetoed what. Maps proposal hash to a possible existent block number",
" (until when it may not be resubmitted) and who vetoed it."
]
},
{
"name": "Cancellations",
"modifier": "Default",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "bool",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Record of all proposals that have been subject to emergency cancellation."
]
},
{
"name": "StorageVersion",
"modifier": "Optional",
"type": {
"plain": "Releases"
},
"fallback": "0x00",
"docs": [
" Storage version of the pallet.",
"",
" New networks start with last version."
]
}
]
},
"calls": [
{
"name": "propose",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "value",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Propose a sensitive action to be taken.",
"",
" The dispatch origin of this call must be _Signed_ and the sender must",
" have funds to cover the deposit.",
"",
" - `proposal_hash`: The hash of the proposal preimage.",
" - `value`: The amount of deposit (must be at least `MinimumDeposit`).",
"",
" Emits `Proposed`.",
"",
" Weight: `O(p)`"
]
},
{
"name": "second",
"args": [
{
"name": "proposal",
"type": "Compact<PropIndex>"
},
{
"name": "seconds_upper_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Signals agreement with a particular proposal.",
"",
" The dispatch origin of this call must be _Signed_ and the sender",
" must have funds to cover the deposit, equal to the original deposit.",
"",
" - `proposal`: The index of the proposal to second.",
" - `seconds_upper_bound`: an upper bound on the current number of seconds on this",
" proposal. Extrinsic is weighted according to this value with no refund.",
"",
" Weight: `O(S)` where S is the number of seconds a proposal already has."
]
},
{
"name": "vote",
"args": [
{
"name": "ref_index",
"type": "Compact<ReferendumIndex>"
},
{
"name": "vote",
"type": "AccountVote"
}
],
"docs": [
" Vote in a referendum. If `vote.is_aye()`, the vote is to enact the proposal;",
" otherwise it is a vote to keep the status quo.",
"",
" The dispatch origin of this call must be _Signed_.",
"",
" - `ref_index`: The index of the referendum to vote for.",
" - `vote`: The vote configuration.",
"",
" Weight: `O(R)` where R is the number of referendums the voter has voted on."
]
},
{
"name": "emergency_cancel",
"args": [
{
"name": "ref_index",
"type": "ReferendumIndex"
}
],
"docs": [
" Schedule an emergency cancellation of a referendum. Cannot happen twice to the same",
" referendum.",
"",
" The dispatch origin of this call must be `CancellationOrigin`.",
"",
" -`ref_index`: The index of the referendum to cancel.",
"",
" Weight: `O(1)`."
]
},
{
"name": "external_propose",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
}
],
"docs": [
" Schedule a referendum to be tabled once it is legal to schedule an external",
" referendum.",
"",
" The dispatch origin of this call must be `ExternalOrigin`.",
"",
" - `proposal_hash`: The preimage hash of the proposal.",
"",
" Weight: `O(V)` with V number of vetoers in the blacklist of proposal.",
" Decoding vec of length V. Charged as maximum"
]
},
{
"name": "external_propose_majority",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
}
],
"docs": [
" Schedule a majority-carries referendum to be tabled next once it is legal to schedule",
" an external referendum.",
"",
" The dispatch of this call must be `ExternalMajorityOrigin`.",
"",
" - `proposal_hash`: The preimage hash of the proposal.",
"",
" Unlike `external_propose`, blacklisting has no effect on this and it may replace a",
" pre-scheduled `external_propose` call.",
"",
" Weight: `O(1)`"
]
},
{
"name": "external_propose_default",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
}
],
"docs": [
" Schedule a negative-turnout-bias referendum to be tabled next once it is legal to",
" schedule an external referendum.",
"",
" The dispatch of this call must be `ExternalDefaultOrigin`.",
"",
" - `proposal_hash`: The preimage hash of the proposal.",
"",
" Unlike `external_propose`, blacklisting has no effect on this and it may replace a",
" pre-scheduled `external_propose` call.",
"",
" Weight: `O(1)`"
]
},
{
"name": "fast_track",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "voting_period",
"type": "BlockNumber"
},
{
"name": "delay",
"type": "BlockNumber"
}
],
"docs": [
" Schedule the currently externally-proposed majority-carries referendum to be tabled",
" immediately. If there is no externally-proposed referendum currently, or if there is one",
" but it is not a majority-carries referendum then it fails.",
"",
" The dispatch of this call must be `FastTrackOrigin`.",
"",
" - `proposal_hash`: The hash of the current external proposal.",
" - `voting_period`: The period that is allowed for voting on this proposal. Increased to",
" `FastTrackVotingPeriod` if too low.",
" - `delay`: The number of block after voting has ended in approval and this should be",
" enacted. This doesn't have a minimum amount.",
"",
" Emits `Started`.",
"",
" Weight: `O(1)`"
]
},
{
"name": "veto_external",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
}
],
"docs": [
" Veto and blacklist the external proposal hash.",
"",
" The dispatch origin of this call must be `VetoOrigin`.",
"",
" - `proposal_hash`: The preimage hash of the proposal to veto and blacklist.",
"",
" Emits `Vetoed`.",
"",
" Weight: `O(V + log(V))` where V is number of `existing vetoers`"
]
},
{
"name": "cancel_referendum",
"args": [
{
"name": "ref_index",
"type": "Compact<ReferendumIndex>"
}
],
"docs": [
" Remove a referendum.",
"",
" The dispatch origin of this call must be _Root_.",
"",
" - `ref_index`: The index of the referendum to cancel.",
"",
" # Weight: `O(1)`."
]
},
{
"name": "cancel_queued",
"args": [
{
"name": "which",
"type": "ReferendumIndex"
}
],
"docs": [
" Cancel a proposal queued for enactment.",
"",
" The dispatch origin of this call must be _Root_.",
"",
" - `which`: The index of the referendum to cancel.",
"",
" Weight: `O(D)` where `D` is the items in the dispatch queue. Weighted as `D = 10`."
]
},
{
"name": "delegate",
"args": [
{
"name": "to",
"type": "AccountId"
},
{
"name": "conviction",
"type": "Conviction"
},
{
"name": "balance",
"type": "BalanceOf"
}
],
"docs": [
" Delegate the voting power (with some given conviction) of the sending account.",
"",
" The balance delegated is locked for as long as it's delegated, and thereafter for the",
" time appropriate for the conviction's lock period.",
"",
" The dispatch origin of this call must be _Signed_, and the signing account must either:",
" - be delegating already; or",
" - have no voting activity (if there is, then it will need to be removed/consolidated",
" through `reap_vote` or `unvote`).",
"",
" - `to`: The account whose voting the `target` account's voting power will follow.",
" - `conviction`: The conviction that will be attached to the delegated votes. When the",
" account is undelegated, the funds will be locked for the corresponding period.",
" - `balance`: The amount of the account's balance to be used in delegating. This must not",
" be more than the account's current balance.",
"",
" Emits `Delegated`.",
"",
" Weight: `O(R)` where R is the number of referendums the voter delegating to has",
" voted on. Weight is charged as if maximum votes."
]
},
{
"name": "undelegate",
"args": [],
"docs": [
" Undelegate the voting power of the sending account.",
"",
" Tokens may be unlocked following once an amount of time consistent with the lock period",
" of the conviction with which the delegation was issued.",
"",
" The dispatch origin of this call must be _Signed_ and the signing account must be",
" currently delegating.",
"",
" Emits `Undelegated`.",
"",
" Weight: `O(R)` where R is the number of referendums the voter delegating to has",
" voted on. Weight is charged as if maximum votes."
]
},
{
"name": "clear_public_proposals",
"args": [],
"docs": [
" Clears all public proposals.",
"",
" The dispatch origin of this call must be _Root_.",
"",
" Weight: `O(1)`."
]
},
{
"name": "note_preimage",
"args": [
{
"name": "encoded_proposal",
"type": "Bytes"
}
],
"docs": [
" Register the preimage for an upcoming proposal. This doesn't require the proposal to be",
" in the dispatch queue but does require a deposit, returned once enacted.",
"",
" The dispatch origin of this call must be _Signed_.",
"",
" - `encoded_proposal`: The preimage of a proposal.",
"",
" Emits `PreimageNoted`.",
"",
" Weight: `O(E)` with E size of `encoded_proposal` (protected by a required deposit)."
]
},
{
"name": "note_preimage_operational",
"args": [
{
"name": "encoded_proposal",
"type": "Bytes"
}
],
"docs": [
" Same as `note_preimage` but origin is `OperationalPreimageOrigin`."
]
},
{
"name": "note_imminent_preimage",
"args": [
{
"name": "encoded_proposal",
"type": "Bytes"
}
],
"docs": [
" Register the preimage for an upcoming proposal. This requires the proposal to be",
" in the dispatch queue. No deposit is needed. When this call is successful, i.e.",
" the preimage has not been uploaded before and matches some imminent proposal,",
" no fee is paid.",
"",
" The dispatch origin of this call must be _Signed_.",
"",
" - `encoded_proposal`: The preimage of a proposal.",
"",
" Emits `PreimageNoted`.",
"",
" Weight: `O(E)` with E size of `encoded_proposal` (protected by a required deposit)."
]
},
{
"name": "note_imminent_preimage_operational",
"args": [
{
"name": "encoded_proposal",
"type": "Bytes"
}
],
"docs": [
" Same as `note_imminent_preimage` but origin is `OperationalPreimageOrigin`."
]
},
{
"name": "reap_preimage",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "proposal_len_upper_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Remove an expired proposal preimage and collect the deposit.",
"",
" The dispatch origin of this call must be _Signed_.",
"",
" - `proposal_hash`: The preimage hash of a proposal.",
" - `proposal_length_upper_bound`: an upper bound on length of the proposal. Extrinsic is",
" weighted according to this value with no refund.",
"",
" This will only work after `VotingPeriod` blocks from the time that the preimage was",
" noted, if it's the same account doing it. If it's a different account, then it'll only",
" work an additional `EnactmentPeriod` later.",
"",
" Emits `PreimageReaped`.",
"",
" Weight: `O(D)` where D is length of proposal."
]
},
{
"name": "unlock",
"args": [
{
"name": "target",
"type": "AccountId"
}
],
"docs": [
" Unlock tokens that have an expired lock.",
"",
" The dispatch origin of this call must be _Signed_.",
"",
" - `target`: The account to remove the lock on.",
"",
" Weight: `O(R)` with R number of vote of target."
]
},
{
"name": "remove_vote",
"args": [
{
"name": "index",
"type": "ReferendumIndex"
}
],
"docs": [
" Remove a vote for a referendum.",
"",
" If:",
" - the referendum was cancelled, or",
" - the referendum is ongoing, or",
" - the referendum has ended such that",
" - the vote of the account was in opposition to the result; or",
" - there was no conviction to the account's vote; or",
" - the account made a split vote",
" ...then the vote is removed cleanly and a following call to `unlock` may result in more",
" funds being available.",
"",
" If, however, the referendum has ended and:",
" - it finished corresponding to the vote of the account, and",
" - the account made a standard vote with conviction, and",
" - the lock period of the conviction is not over",
" ...then the lock will be aggregated into the overall account's lock, which may involve",
" *overlocking* (where the two locks are combined into a single lock that is the maximum",
" of both the amount locked and the time is it locked for).",
"",
" The dispatch origin of this call must be _Signed_, and the signer must have a vote",
" registered for referendum `index`.",
"",
" - `index`: The index of referendum of the vote to be removed.",
"",
" Weight: `O(R + log R)` where R is the number of referenda that `target` has voted on.",
" Weight is calculated for the maximum number of vote."
]
},
{
"name": "remove_other_vote",
"args": [
{
"name": "target",
"type": "AccountId"
},
{
"name": "index",
"type": "ReferendumIndex"
}
],
"docs": [
" Remove a vote for a referendum.",
"",
" If the `target` is equal to the signer, then this function is exactly equivalent to",
" `remove_vote`. If not equal to the signer, then the vote must have expired,",
" either because the referendum was cancelled, because the voter lost the referendum or",
" because the conviction period is over.",
"",
" The dispatch origin of this call must be _Signed_.",
"",
" - `target`: The account of the vote to be removed; this account must have voted for",
" referendum `index`.",
" - `index`: The index of referendum of the vote to be removed.",
"",
" Weight: `O(R + log R)` where R is the number of referenda that `target` has voted on.",
" Weight is calculated for the maximum number of vote."
]
},
{
"name": "enact_proposal",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "index",
"type": "ReferendumIndex"
}
],
"docs": [
" Enact a proposal from a referendum. For now we just make the weight be the maximum."
]
},
{
"name": "blacklist",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "maybe_ref_index",
"type": "Option<ReferendumIndex>"
}
],
"docs": [
" Permanently place a proposal into the blacklist. This prevents it from ever being",
" proposed again.",
"",
" If called on a queued public or external proposal, then this will result in it being",
" removed. If the `ref_index` supplied is an active referendum with the proposal hash,",
" then it will be cancelled.",
"",
" The dispatch origin of this call must be `BlacklistOrigin`.",
"",
" - `proposal_hash`: The proposal hash to blacklist permanently.",
" - `ref_index`: An ongoing referendum whose hash is `proposal_hash`, which will be",
" cancelled.",
"",
" Weight: `O(p)` (though as this is an high-privilege dispatch, we assume it has a",
" reasonable value)."
]
},
{
"name": "cancel_proposal",
"args": [
{
"name": "prop_index",
"type": "Compact<PropIndex>"
}
],
"docs": [
" Remove a proposal.",
"",
" The dispatch origin of this call must be `CancelProposalOrigin`.",
"",
" - `prop_index`: The index of the proposal to cancel.",
"",
" Weight: `O(p)` where `p = PublicProps::<T>::decode_len()`"
]
}
],
"events": [
{
"name": "Proposed",
"args": [
"PropIndex",
"Balance"
],
"docs": [
" A motion has been proposed by a public account. \\[proposal_index, deposit\\]"
]
},
{
"name": "Tabled",
"args": [
"PropIndex",
"Balance",
"Vec<AccountId>"
],
"docs": [
" A public proposal has been tabled for referendum vote. \\[proposal_index, deposit,",
" depositors\\]"
]
},
{
"name": "ExternalTabled",
"args": [],
"docs": [
" An external proposal has been tabled."
]
},
{
"name": "Started",
"args": [
"ReferendumIndex",
"VoteThreshold"
],
"docs": [
" A referendum has begun. \\[ref_index, threshold\\]"
]
},
{
"name": "Passed",
"args": [
"ReferendumIndex"
],
"docs": [
" A proposal has been approved by referendum. \\[ref_index\\]"
]
},
{
"name": "NotPassed",
"args": [
"ReferendumIndex"
],
"docs": [
" A proposal has been rejected by referendum. \\[ref_index\\]"
]
},
{
"name": "Cancelled",
"args": [
"ReferendumIndex"
],
"docs": [
" A referendum has been cancelled. \\[ref_index\\]"
]
},
{
"name": "Executed",
"args": [
"ReferendumIndex",
"DispatchResult"
],
"docs": [
" A proposal has been enacted. \\[ref_index, result\\]"
]
},
{
"name": "Delegated",
"args": [
"AccountId",
"AccountId"
],
"docs": [
" An account has delegated their vote to another account. \\[who, target\\]"
]
},
{
"name": "Undelegated",
"args": [
"AccountId"
],
"docs": [
" An \\[account\\] has cancelled a previous delegation operation."
]
},
{
"name": "Vetoed",
"args": [
"AccountId",
"Hash",
"BlockNumber"
],
"docs": [
" An external proposal has been vetoed. \\[who, proposal_hash, until\\]"
]
},
{
"name": "PreimageNoted",
"args": [
"Hash",
"AccountId",
"Balance"
],
"docs": [
" A proposal's preimage was noted, and the deposit taken. \\[proposal_hash, who, deposit\\]"
]
},
{
"name": "PreimageUsed",
"args": [
"Hash",
"AccountId",
"Balance"
],
"docs": [
" A proposal preimage was removed and used (the deposit was returned).",
" \\[proposal_hash, provider, deposit\\]"
]
},
{
"name": "PreimageInvalid",
"args": [
"Hash",
"ReferendumIndex"
],
"docs": [
" A proposal could not be executed because its preimage was invalid.",
" \\[proposal_hash, ref_index\\]"
]
},
{
"name": "PreimageMissing",
"args": [
"Hash",
"ReferendumIndex"
],
"docs": [
" A proposal could not be executed because its preimage was missing.",
" \\[proposal_hash, ref_index\\]"
]
},
{
"name": "PreimageReaped",
"args": [
"Hash",
"AccountId",
"Balance",
"AccountId"
],
"docs": [
" A registered preimage was removed and the deposit collected by the reaper.",
" \\[proposal_hash, provider, deposit, reaper\\]"
]
},
{
"name": "Blacklisted",
"args": [
"Hash"
],
"docs": [
" A proposal \\[hash\\] has been blacklisted permanently."
]
}
],
"constants": [
{
"name": "EnactmentPeriod",
"type": "BlockNumber",
"value": "0x00270600",
"docs": [
" The period between a proposal being approved and enacted.",
"",
" It should generally be a little more than the unstake period to ensure that",
" voting stakers have an opportunity to remove themselves from the system in the case",
" where they are on the losing side of a vote."
]
},
{
"name": "LaunchPeriod",
"type": "BlockNumber",
"value": "0x00270600",
"docs": [
" How often (in blocks) new public referenda are launched."
]
},
{
"name": "VotingPeriod",
"type": "BlockNumber",
"value": "0x00270600",
"docs": [
" How often (in blocks) to check for new votes."
]
},
{
"name": "VoteLockingPeriod",
"type": "BlockNumber",
"value": "0x00270600",
"docs": [
" The minimum period of vote locking.",
"",
" It should be no shorter than enactment period to ensure that in the case of an approval,",
" those successful voters are locked into the consequences that their votes entail."
]
},
{
"name": "MinimumDeposit",
"type": "BalanceOf",
"value": "0x0010a5d4e80000000000000000000000",
"docs": [
" The minimum amount to be used as a deposit for a public referendum proposal."
]
},
{
"name": "InstantAllowed",
"type": "bool",
"value": "0x01",
"docs": [
" Indicator for whether an emergency origin is even allowed to happen. Some chains may",
" want to set this permanently to `false`, others may want to condition it on things such",
" as an upgrade having happened recently."
]
},
{
"name": "FastTrackVotingPeriod",
"type": "BlockNumber",
"value": "0x08070000",
"docs": [
" Minimum voting period allowed for a fast-track referendum."
]
},
{
"name": "CooloffPeriod",
"type": "BlockNumber",
"value": "0xc0890100",
"docs": [
" Period in blocks where an external proposal may not be re-submitted after being vetoed."
]
},
{
"name": "PreimageByteDeposit",
"type": "BalanceOf",
"value": "0x00e1f505000000000000000000000000",
"docs": [
" The amount of balance that must be deposited per byte of preimage stored."
]
},
{
"name": "MaxVotes",
"type": "u32",
"value": "0x64000000",
"docs": [
" The maximum number of votes for an account.",
"",
" Also used to compute weight, an overly big value can",
" lead to extrinsic with very big weight: see `delegate` for instance."
]
},
{
"name": "MaxProposals",
"type": "u32",
"value": "0x64000000",
"docs": [
" The maximum number of public proposals that can exist at any time."
]
}
],
"errors": [
{
"name": "ValueLow",
"docs": [
" Value too low"
]
},
{
"name": "ProposalMissing",
"docs": [
" Proposal does not exist"
]
},
{
"name": "AlreadyCanceled",
"docs": [
" Cannot cancel the same proposal twice"
]
},
{
"name": "DuplicateProposal",
"docs": [
" Proposal already made"
]
},
{
"name": "ProposalBlacklisted",
"docs": [
" Proposal still blacklisted"
]
},
{
"name": "NotSimpleMajority",
"docs": [
" Next external proposal not simple majority"
]
},
{
"name": "InvalidHash",
"docs": [
" Invalid hash"
]
},
{
"name": "NoProposal",
"docs": [
" No external proposal"
]
},
{
"name": "AlreadyVetoed",
"docs": [
" Identity may not veto a proposal twice"
]
},
{
"name": "DuplicatePreimage",
"docs": [
" Preimage already noted"
]
},
{
"name": "NotImminent",
"docs": [
" Not imminent"
]
},
{
"name": "TooEarly",
"docs": [
" Too early"
]
},
{
"name": "Imminent",
"docs": [
" Imminent"
]
},
{
"name": "PreimageMissing",
"docs": [
" Preimage not found"
]
},
{
"name": "ReferendumInvalid",
"docs": [
" Vote given for invalid referendum"
]
},
{
"name": "PreimageInvalid",
"docs": [
" Invalid preimage"
]
},
{
"name": "NoneWaiting",
"docs": [
" No proposals waiting"
]
},
{
"name": "NotVoter",
"docs": [
" The given account did not vote on the referendum."
]
},
{
"name": "NoPermission",
"docs": [
" The actor has no permission to conduct the action."
]
},
{
"name": "AlreadyDelegating",
"docs": [
" The account is already delegating."
]
},
{
"name": "InsufficientFunds",
"docs": [
" Too high a balance was provided that the account cannot afford."
]
},
{
"name": "NotDelegating",
"docs": [
" The account is not currently delegating."
]
},
{
"name": "VotesExist",
"docs": [
" The account currently has votes attached to it and the operation cannot succeed until",
" these are removed, either through `unvote` or `reap_vote`."
]
},
{
"name": "InstantNotAllowed",
"docs": [
" The instant referendum origin is currently disallowed."
]
},
{
"name": "Nonsense",
"docs": [
" Delegation to oneself makes no sense."
]
},
{
"name": "WrongUpperBound",
"docs": [
" Invalid upper bound."
]
},
{
"name": "MaxVotesReached",
"docs": [
" Maximum number of votes reached."
]
},
{
"name": "TooManyProposals",
"docs": [
" Maximum number of proposals reached."
]
}
],
"index": 14
},
{
"name": "Council",
"storage": {
"prefix": "Council",
"items": [
{
"name": "Proposals",
"modifier": "Default",
"type": {
"plain": "Vec<Hash>"
},
"fallback": "0x00",
"docs": [
" The hashes of the active proposals."
]
},
{
"name": "ProposalOf",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "Proposal",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Actual proposal for a given hash, if it's current."
]
},
{
"name": "Voting",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "Votes",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Votes on a given proposal, if it is ongoing."
]
},
{
"name": "ProposalCount",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" Proposals so far."
]
},
{
"name": "Members",
"modifier": "Default",
"type": {
"plain": "Vec<AccountId>"
},
"fallback": "0x00",
"docs": [
" The current members of the collective. This is stored sorted (just by value)."
]
},
{
"name": "Prime",
"modifier": "Optional",
"type": {
"plain": "AccountId"
},
"fallback": "0x00",
"docs": [
" The prime member that helps determine the default vote behavior in case of absentations."
]
}
]
},
"calls": [
{
"name": "set_members",
"args": [
{
"name": "new_members",
"type": "Vec<AccountId>"
},
{
"name": "prime",
"type": "Option<AccountId>"
},
{
"name": "old_count",
"type": "MemberCount"
}
],
"docs": [
" Set the collective's membership.",
"",
" - `new_members`: The new member list. Be nice to the chain and provide it sorted.",
" - `prime`: The prime member whose vote sets the default.",
" - `old_count`: The upper bound for the previous number of members in storage. Used for",
" weight estimation.",
"",
" Requires root origin.",
"",
" NOTE: Does not enforce the expected `MaxMembers` limit on the amount of members, but",
" the weight estimations rely on it to estimate dispatchable weight.",
"",
" # <weight>",
" ## Weight",
" - `O(MP + N)` where:",
" - `M` old-members-count (code- and governance-bounded)",
" - `N` new-members-count (code- and governance-bounded)",
" - `P` proposals-count (code-bounded)",
" - DB:",
" - 1 storage mutation (codec `O(M)` read, `O(N)` write) for reading and writing the",
" members",
" - 1 storage read (codec `O(P)`) for reading the proposals",
" - `P` storage mutations (codec `O(M)`) for updating the votes for each proposal",
" - 1 storage write (codec `O(1)`) for deleting the old `prime` and setting the new one",
" # </weight>"
]
},
{
"name": "execute",
"args": [
{
"name": "proposal",
"type": "Proposal"
},
{
"name": "length_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Dispatch a proposal from a member using the `Member` origin.",
"",
" Origin must be a member of the collective.",
"",
" # <weight>",
" ## Weight",
" - `O(M + P)` where `M` members-count (code-bounded) and `P` complexity of dispatching",
" `proposal`",
" - DB: 1 read (codec `O(M)`) + DB access of `proposal`",
" - 1 event",
" # </weight>"
]
},
{
"name": "propose",
"args": [
{
"name": "threshold",
"type": "Compact<MemberCount>"
},
{
"name": "proposal",
"type": "Proposal"
},
{
"name": "length_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Add a new proposal to either be voted on or executed directly.",
"",
" Requires the sender to be member.",
"",
" `threshold` determines whether `proposal` is executed directly (`threshold < 2`)",
" or put up for voting.",
"",
" # <weight>",
" ## Weight",
" - `O(B + M + P1)` or `O(B + M + P2)` where:",
" - `B` is `proposal` size in bytes (length-fee-bounded)",
" - `M` is members-count (code- and governance-bounded)",
" - branching is influenced by `threshold` where:",
" - `P1` is proposal execution complexity (`threshold < 2`)",
" - `P2` is proposals-count (code-bounded) (`threshold >= 2`)",
" - DB:",
" - 1 storage read `is_member` (codec `O(M)`)",
" - 1 storage read `ProposalOf::contains_key` (codec `O(1)`)",
" - DB accesses influenced by `threshold`:",
" - EITHER storage accesses done by `proposal` (`threshold < 2`)",
" - OR proposal insertion (`threshold <= 2`)",
" - 1 storage mutation `Proposals` (codec `O(P2)`)",
" - 1 storage mutation `ProposalCount` (codec `O(1)`)",
" - 1 storage write `ProposalOf` (codec `O(B)`)",
" - 1 storage write `Voting` (codec `O(M)`)",
" - 1 event",
" # </weight>"
]
},
{
"name": "vote",
"args": [
{
"name": "proposal",
"type": "Hash"
},
{
"name": "index",
"type": "Compact<ProposalIndex>"
},
{
"name": "approve",
"type": "bool"
}
],
"docs": [
" Add an aye or nay vote for the sender to the given proposal.",
"",
" Requires the sender to be a member.",
"",
" Transaction fees will be waived if the member is voting on any particular proposal",
" for the first time and the call is successful. Subsequent vote changes will charge a",
" fee.",
" # <weight>",
" ## Weight",
" - `O(M)` where `M` is members-count (code- and governance-bounded)",
" - DB:",
" - 1 storage read `Members` (codec `O(M)`)",
" - 1 storage mutation `Voting` (codec `O(M)`)",
" - 1 event",
" # </weight>"
]
},
{
"name": "close",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "index",
"type": "Compact<ProposalIndex>"
},
{
"name": "proposal_weight_bound",
"type": "Compact<Weight>"
},
{
"name": "length_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Close a vote that is either approved, disapproved or whose voting period has ended.",
"",
" May be called by any signed account in order to finish voting and close the proposal.",
"",
" If called before the end of the voting period it will only close the vote if it is",
" has enough votes to be approved or disapproved.",
"",
" If called after the end of the voting period abstentions are counted as rejections",
" unless there is a prime member set and the prime member cast an approval.",
"",
" If the close operation completes successfully with disapproval, the transaction fee will",
" be waived. Otherwise execution of the approved operation will be charged to the caller.",
"",
" + `proposal_weight_bound`: The maximum amount of weight consumed by executing the closed",
" proposal.",
" + `length_bound`: The upper bound for the length of the proposal in storage. Checked via",
" `storage::read` so it is `size_of::<u32>() == 4` larger than the pure length.",
"",
" # <weight>",
" ## Weight",
" - `O(B + M + P1 + P2)` where:",
" - `B` is `proposal` size in bytes (length-fee-bounded)",
" - `M` is members-count (code- and governance-bounded)",
" - `P1` is the complexity of `proposal` preimage.",
" - `P2` is proposal-count (code-bounded)",
" - DB:",
" - 2 storage reads (`Members`: codec `O(M)`, `Prime`: codec `O(1)`)",
" - 3 mutations (`Voting`: codec `O(M)`, `ProposalOf`: codec `O(B)`, `Proposals`: codec",
" `O(P2)`)",
" - any mutations done while executing `proposal` (`P1`)",
" - up to 3 events",
" # </weight>"
]
},
{
"name": "disapprove_proposal",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
}
],
"docs": [
" Disapprove a proposal, close, and remove it from the system, regardless of its current",
" state.",
"",
" Must be called by the Root origin.",
"",
" Parameters:",
" * `proposal_hash`: The hash of the proposal that should be disapproved.",
"",
" # <weight>",
" Complexity: O(P) where P is the number of max proposals",
" DB Weight:",
" * Reads: Proposals",
" * Writes: Voting, Proposals, ProposalOf",
" # </weight>"
]
}
],
"events": [
{
"name": "Proposed",
"args": [
"AccountId",
"ProposalIndex",
"Hash",
"MemberCount"
],
"docs": [
" A motion (given hash) has been proposed (by given account) with a threshold (given",
" `MemberCount`).",
" \\[account, proposal_index, proposal_hash, threshold\\]"
]
},
{
"name": "Voted",
"args": [
"AccountId",
"Hash",
"bool",
"MemberCount",
"MemberCount"
],
"docs": [
" A motion (given hash) has been voted on by given account, leaving",
" a tally (yes votes and no votes given respectively as `MemberCount`).",
" \\[account, proposal_hash, voted, yes, no\\]"
]
},
{
"name": "Approved",
"args": [
"Hash"
],
"docs": [
" A motion was approved by the required threshold.",
" \\[proposal_hash\\]"
]
},
{
"name": "Disapproved",
"args": [
"Hash"
],
"docs": [
" A motion was not approved by the required threshold.",
" \\[proposal_hash\\]"
]
},
{
"name": "Executed",
"args": [
"Hash",
"DispatchResult"
],
"docs": [
" A motion was executed; result will be `Ok` if it returned without error.",
" \\[proposal_hash, result\\]"
]
},
{
"name": "MemberExecuted",
"args": [
"Hash",
"DispatchResult"
],
"docs": [
" A single member did some action; result will be `Ok` if it returned without error.",
" \\[proposal_hash, result\\]"
]
},
{
"name": "Closed",
"args": [
"Hash",
"MemberCount",
"MemberCount"
],
"docs": [
" A proposal was closed because its threshold was reached or after its duration was up.",
" \\[proposal_hash, yes, no\\]"
]
}
],
"constants": [],
"errors": [
{
"name": "NotMember",
"docs": [
" Account is not a member"
]
},
{
"name": "DuplicateProposal",
"docs": [
" Duplicate proposals not allowed"
]
},
{
"name": "ProposalMissing",
"docs": [
" Proposal must exist"
]
},
{
"name": "WrongIndex",
"docs": [
" Mismatched index"
]
},
{
"name": "DuplicateVote",
"docs": [
" Duplicate vote ignored"
]
},
{
"name": "AlreadyInitialized",
"docs": [
" Members are already initialized!"
]
},
{
"name": "TooEarly",
"docs": [
" The close call was made too early, before the end of the voting."
]
},
{
"name": "TooManyProposals",
"docs": [
" There can only be a maximum of `MaxProposals` active proposals."
]
},
{
"name": "WrongProposalWeight",
"docs": [
" The given weight bound for the proposal was too low."
]
},
{
"name": "WrongProposalLength",
"docs": [
" The given length bound for the proposal was too low."
]
}
],
"index": 15
},
{
"name": "TechnicalCommittee",
"storage": {
"prefix": "TechnicalCommittee",
"items": [
{
"name": "Proposals",
"modifier": "Default",
"type": {
"plain": "Vec<Hash>"
},
"fallback": "0x00",
"docs": [
" The hashes of the active proposals."
]
},
{
"name": "ProposalOf",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "Proposal",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Actual proposal for a given hash, if it's current."
]
},
{
"name": "Voting",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "Votes",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Votes on a given proposal, if it is ongoing."
]
},
{
"name": "ProposalCount",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" Proposals so far."
]
},
{
"name": "Members",
"modifier": "Default",
"type": {
"plain": "Vec<AccountId>"
},
"fallback": "0x00",
"docs": [
" The current members of the collective. This is stored sorted (just by value)."
]
},
{
"name": "Prime",
"modifier": "Optional",
"type": {
"plain": "AccountId"
},
"fallback": "0x00",
"docs": [
" The prime member that helps determine the default vote behavior in case of absentations."
]
}
]
},
"calls": [
{
"name": "set_members",
"args": [
{
"name": "new_members",
"type": "Vec<AccountId>"
},
{
"name": "prime",
"type": "Option<AccountId>"
},
{
"name": "old_count",
"type": "MemberCount"
}
],
"docs": [
" Set the collective's membership.",
"",
" - `new_members`: The new member list. Be nice to the chain and provide it sorted.",
" - `prime`: The prime member whose vote sets the default.",
" - `old_count`: The upper bound for the previous number of members in storage. Used for",
" weight estimation.",
"",
" Requires root origin.",
"",
" NOTE: Does not enforce the expected `MaxMembers` limit on the amount of members, but",
" the weight estimations rely on it to estimate dispatchable weight.",
"",
" # <weight>",
" ## Weight",
" - `O(MP + N)` where:",
" - `M` old-members-count (code- and governance-bounded)",
" - `N` new-members-count (code- and governance-bounded)",
" - `P` proposals-count (code-bounded)",
" - DB:",
" - 1 storage mutation (codec `O(M)` read, `O(N)` write) for reading and writing the",
" members",
" - 1 storage read (codec `O(P)`) for reading the proposals",
" - `P` storage mutations (codec `O(M)`) for updating the votes for each proposal",
" - 1 storage write (codec `O(1)`) for deleting the old `prime` and setting the new one",
" # </weight>"
]
},
{
"name": "execute",
"args": [
{
"name": "proposal",
"type": "Proposal"
},
{
"name": "length_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Dispatch a proposal from a member using the `Member` origin.",
"",
" Origin must be a member of the collective.",
"",
" # <weight>",
" ## Weight",
" - `O(M + P)` where `M` members-count (code-bounded) and `P` complexity of dispatching",
" `proposal`",
" - DB: 1 read (codec `O(M)`) + DB access of `proposal`",
" - 1 event",
" # </weight>"
]
},
{
"name": "propose",
"args": [
{
"name": "threshold",
"type": "Compact<MemberCount>"
},
{
"name": "proposal",
"type": "Proposal"
},
{
"name": "length_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Add a new proposal to either be voted on or executed directly.",
"",
" Requires the sender to be member.",
"",
" `threshold` determines whether `proposal` is executed directly (`threshold < 2`)",
" or put up for voting.",
"",
" # <weight>",
" ## Weight",
" - `O(B + M + P1)` or `O(B + M + P2)` where:",
" - `B` is `proposal` size in bytes (length-fee-bounded)",
" - `M` is members-count (code- and governance-bounded)",
" - branching is influenced by `threshold` where:",
" - `P1` is proposal execution complexity (`threshold < 2`)",
" - `P2` is proposals-count (code-bounded) (`threshold >= 2`)",
" - DB:",
" - 1 storage read `is_member` (codec `O(M)`)",
" - 1 storage read `ProposalOf::contains_key` (codec `O(1)`)",
" - DB accesses influenced by `threshold`:",
" - EITHER storage accesses done by `proposal` (`threshold < 2`)",
" - OR proposal insertion (`threshold <= 2`)",
" - 1 storage mutation `Proposals` (codec `O(P2)`)",
" - 1 storage mutation `ProposalCount` (codec `O(1)`)",
" - 1 storage write `ProposalOf` (codec `O(B)`)",
" - 1 storage write `Voting` (codec `O(M)`)",
" - 1 event",
" # </weight>"
]
},
{
"name": "vote",
"args": [
{
"name": "proposal",
"type": "Hash"
},
{
"name": "index",
"type": "Compact<ProposalIndex>"
},
{
"name": "approve",
"type": "bool"
}
],
"docs": [
" Add an aye or nay vote for the sender to the given proposal.",
"",
" Requires the sender to be a member.",
"",
" Transaction fees will be waived if the member is voting on any particular proposal",
" for the first time and the call is successful. Subsequent vote changes will charge a",
" fee.",
" # <weight>",
" ## Weight",
" - `O(M)` where `M` is members-count (code- and governance-bounded)",
" - DB:",
" - 1 storage read `Members` (codec `O(M)`)",
" - 1 storage mutation `Voting` (codec `O(M)`)",
" - 1 event",
" # </weight>"
]
},
{
"name": "close",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
},
{
"name": "index",
"type": "Compact<ProposalIndex>"
},
{
"name": "proposal_weight_bound",
"type": "Compact<Weight>"
},
{
"name": "length_bound",
"type": "Compact<u32>"
}
],
"docs": [
" Close a vote that is either approved, disapproved or whose voting period has ended.",
"",
" May be called by any signed account in order to finish voting and close the proposal.",
"",
" If called before the end of the voting period it will only close the vote if it is",
" has enough votes to be approved or disapproved.",
"",
" If called after the end of the voting period abstentions are counted as rejections",
" unless there is a prime member set and the prime member cast an approval.",
"",
" If the close operation completes successfully with disapproval, the transaction fee will",
" be waived. Otherwise execution of the approved operation will be charged to the caller.",
"",
" + `proposal_weight_bound`: The maximum amount of weight consumed by executing the closed",
" proposal.",
" + `length_bound`: The upper bound for the length of the proposal in storage. Checked via",
" `storage::read` so it is `size_of::<u32>() == 4` larger than the pure length.",
"",
" # <weight>",
" ## Weight",
" - `O(B + M + P1 + P2)` where:",
" - `B` is `proposal` size in bytes (length-fee-bounded)",
" - `M` is members-count (code- and governance-bounded)",
" - `P1` is the complexity of `proposal` preimage.",
" - `P2` is proposal-count (code-bounded)",
" - DB:",
" - 2 storage reads (`Members`: codec `O(M)`, `Prime`: codec `O(1)`)",
" - 3 mutations (`Voting`: codec `O(M)`, `ProposalOf`: codec `O(B)`, `Proposals`: codec",
" `O(P2)`)",
" - any mutations done while executing `proposal` (`P1`)",
" - up to 3 events",
" # </weight>"
]
},
{
"name": "disapprove_proposal",
"args": [
{
"name": "proposal_hash",
"type": "Hash"
}
],
"docs": [
" Disapprove a proposal, close, and remove it from the system, regardless of its current",
" state.",
"",
" Must be called by the Root origin.",
"",
" Parameters:",
" * `proposal_hash`: The hash of the proposal that should be disapproved.",
"",
" # <weight>",
" Complexity: O(P) where P is the number of max proposals",
" DB Weight:",
" * Reads: Proposals",
" * Writes: Voting, Proposals, ProposalOf",
" # </weight>"
]
}
],
"events": [
{
"name": "Proposed",
"args": [
"AccountId",
"ProposalIndex",
"Hash",
"MemberCount"
],
"docs": [
" A motion (given hash) has been proposed (by given account) with a threshold (given",
" `MemberCount`).",
" \\[account, proposal_index, proposal_hash, threshold\\]"
]
},
{
"name": "Voted",
"args": [
"AccountId",
"Hash",
"bool",
"MemberCount",
"MemberCount"
],
"docs": [
" A motion (given hash) has been voted on by given account, leaving",
" a tally (yes votes and no votes given respectively as `MemberCount`).",
" \\[account, proposal_hash, voted, yes, no\\]"
]
},
{
"name": "Approved",
"args": [
"Hash"
],
"docs": [
" A motion was approved by the required threshold.",
" \\[proposal_hash\\]"
]
},
{
"name": "Disapproved",
"args": [
"Hash"
],
"docs": [
" A motion was not approved by the required threshold.",
" \\[proposal_hash\\]"
]
},
{
"name": "Executed",
"args": [
"Hash",
"DispatchResult"
],
"docs": [
" A motion was executed; result will be `Ok` if it returned without error.",
" \\[proposal_hash, result\\]"
]
},
{
"name": "MemberExecuted",
"args": [
"Hash",
"DispatchResult"
],
"docs": [
" A single member did some action; result will be `Ok` if it returned without error.",
" \\[proposal_hash, result\\]"
]
},
{
"name": "Closed",
"args": [
"Hash",
"MemberCount",
"MemberCount"
],
"docs": [
" A proposal was closed because its threshold was reached or after its duration was up.",
" \\[proposal_hash, yes, no\\]"
]
}
],
"constants": [],
"errors": [
{
"name": "NotMember",
"docs": [
" Account is not a member"
]
},
{
"name": "DuplicateProposal",
"docs": [
" Duplicate proposals not allowed"
]
},
{
"name": "ProposalMissing",
"docs": [
" Proposal must exist"
]
},
{
"name": "WrongIndex",
"docs": [
" Mismatched index"
]
},
{
"name": "DuplicateVote",
"docs": [
" Duplicate vote ignored"
]
},
{
"name": "AlreadyInitialized",
"docs": [
" Members are already initialized!"
]
},
{
"name": "TooEarly",
"docs": [
" The close call was made too early, before the end of the voting."
]
},
{
"name": "TooManyProposals",
"docs": [
" There can only be a maximum of `MaxProposals` active proposals."
]
},
{
"name": "WrongProposalWeight",
"docs": [
" The given weight bound for the proposal was too low."
]
},
{
"name": "WrongProposalLength",
"docs": [
" The given length bound for the proposal was too low."
]
}
],
"index": 16
},
{
"name": "PhragmenElection",
"storage": {
"prefix": "PhragmenElection",
"items": [
{
"name": "Members",
"modifier": "Default",
"type": {
"plain": "Vec<SeatHolder>"
},
"fallback": "0x00",
"docs": [
" The current elected members.",
"",
" Invariant: Always sorted based on account id."
]
},
{
"name": "RunnersUp",
"modifier": "Default",
"type": {
"plain": "Vec<SeatHolder>"
},
"fallback": "0x00",
"docs": [
" The current reserved runners-up.",
"",
" Invariant: Always sorted based on rank (worse to best). Upon removal of a member, the",
" last (i.e. _best_) runner-up will be replaced."
]
},
{
"name": "Candidates",
"modifier": "Default",
"type": {
"plain": "Vec<(AccountId,BalanceOf)>"
},
"fallback": "0x00",
"docs": [
" The present candidate list. A current member or runner-up can never enter this vector",
" and is always implicitly assumed to be a candidate.",
"",
" Second element is the deposit.",
"",
" Invariant: Always sorted based on account id."
]
},
{
"name": "ElectionRounds",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" The total number of vote rounds that have happened, excluding the upcoming one."
]
},
{
"name": "Voting",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "Voter",
"linked": false
}
},
"fallback": "0x000000000000000000000000000000000000000000000000000000000000000000",
"docs": [
" Votes and locked stake of a particular voter.",
"",
" TWOX-NOTE: SAFE as `AccountId` is a crypto hash."
]
}
]
},
"calls": [
{
"name": "vote",
"args": [
{
"name": "votes",
"type": "Vec<AccountId>"
},
{
"name": "value",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Vote for a set of candidates for the upcoming round of election. This can be called to",
" set the initial votes, or update already existing votes.",
"",
" Upon initial voting, `value` units of `who`'s balance is locked and a deposit amount is",
" reserved. The deposit is based on the number of votes and can be updated over time.",
"",
" The `votes` should:",
" - not be empty.",
" - be less than the number of possible candidates. Note that all current members and",
" runners-up are also automatically candidates for the next round.",
"",
" If `value` is more than `who`'s total balance, then the maximum of the two is used.",
"",
" The dispatch origin of this call must be signed.",
"",
" ### Warning",
"",
" It is the responsibility of the caller to **NOT** place all of their balance into the",
" lock and keep some for further operations.",
"",
" # <weight>",
" We assume the maximum weight among all 3 cases: vote_equal, vote_more and vote_less.",
" # </weight>"
]
},
{
"name": "remove_voter",
"args": [],
"docs": [
" Remove `origin` as a voter.",
"",
" This removes the lock and returns the deposit.",
"",
" The dispatch origin of this call must be signed and be a voter."
]
},
{
"name": "submit_candidacy",
"args": [
{
"name": "candidate_count",
"type": "Compact<u32>"
}
],
"docs": [
" Submit oneself for candidacy. A fixed amount of deposit is recorded.",
"",
" All candidates are wiped at the end of the term. They either become a member/runner-up,",
" or leave the system while their deposit is slashed.",
"",
" The dispatch origin of this call must be signed.",
"",
" ### Warning",
"",
" Even if a candidate ends up being a member, they must call [`Call::renounce_candidacy`]",
" to get their deposit back. Losing the spot in an election will always lead to a slash.",
"",
" # <weight>",
" The number of current candidates must be provided as witness data.",
" # </weight>"
]
},
{
"name": "renounce_candidacy",
"args": [
{
"name": "renouncing",
"type": "Renouncing"
}
],
"docs": [
" Renounce one's intention to be a candidate for the next election round. 3 potential",
" outcomes exist:",
"",
" - `origin` is a candidate and not elected in any set. In this case, the deposit is",
" unreserved, returned and origin is removed as a candidate.",
" - `origin` is a current runner-up. In this case, the deposit is unreserved, returned and",
" origin is removed as a runner-up.",
" - `origin` is a current member. In this case, the deposit is unreserved and origin is",
" removed as a member, consequently not being a candidate for the next round anymore.",
" Similar to [`remove_member`](Self::remove_member), if replacement runners exists, they",
" are immediately used. If the prime is renouncing, then no prime will exist until the",
" next round.",
"",
" The dispatch origin of this call must be signed, and have one of the above roles.",
"",
" # <weight>",
" The type of renouncing must be provided as witness data.",
" # </weight>"
]
},
{
"name": "remove_member",
"args": [
{
"name": "who",
"type": "LookupSource"
},
{
"name": "has_replacement",
"type": "bool"
}
],
"docs": [
" Remove a particular member from the set. This is effective immediately and the bond of",
" the outgoing member is slashed.",
"",
" If a runner-up is available, then the best runner-up will be removed and replaces the",
" outgoing member. Otherwise, a new phragmen election is started.",
"",
" The dispatch origin of this call must be root.",
"",
" Note that this does not affect the designated block number of the next election.",
"",
" # <weight>",
" If we have a replacement, we use a small weight. Else, since this is a root call and",
" will go into phragmen, we assume full block for now.",
" # </weight>"
]
},
{
"name": "clean_defunct_voters",
"args": [
{
"name": "_num_voters",
"type": "u32"
},
{
"name": "_num_defunct",
"type": "u32"
}
],
"docs": [
" Clean all voters who are defunct (i.e. they do not serve any purpose at all). The",
" deposit of the removed voters are returned.",
"",
" This is an root function to be used only for cleaning the state.",
"",
" The dispatch origin of this call must be root.",
"",
" # <weight>",
" The total number of voters and those that are defunct must be provided as witness data.",
" # </weight>"
]
}
],
"events": [
{
"name": "NewTerm",
"args": [
"Vec<(AccountId,Balance)>"
],
"docs": [
" A new term with \\[new_members\\]. This indicates that enough candidates existed to run",
" the election, not that enough have has been elected. The inner value must be examined",
" for this purpose. A `NewTerm(\\[\\])` indicates that some candidates got their bond",
" slashed and none were elected, whilst `EmptyTerm` means that no candidates existed to",
" begin with."
]
},
{
"name": "EmptyTerm",
"args": [],
"docs": [
" No (or not enough) candidates existed for this round. This is different from",
" `NewTerm(\\[\\])`. See the description of `NewTerm`."
]
},
{
"name": "ElectionError",
"args": [],
"docs": [
" Internal error happened while trying to perform election."
]
},
{
"name": "MemberKicked",
"args": [
"AccountId"
],
"docs": [
" A \\[member\\] has been removed. This should always be followed by either `NewTerm` or",
" `EmptyTerm`."
]
},
{
"name": "Renounced",
"args": [
"AccountId"
],
"docs": [
" Someone has renounced their candidacy."
]
},
{
"name": "CandidateSlashed",
"args": [
"AccountId",
"Balance"
],
"docs": [
" A \\[candidate\\] was slashed by \\[amount\\] due to failing to obtain a seat as member or",
" runner-up.",
"",
" Note that old members and runners-up are also candidates."
]
},
{
"name": "SeatHolderSlashed",
"args": [
"AccountId",
"Balance"
],
"docs": [
" A \\[seat holder\\] was slashed by \\[amount\\] by being forcefully removed from the set."
]
}
],
"constants": [
{
"name": "PalletId",
"type": "LockIdentifier",
"value": "0x706872656c656374",
"docs": [
" Identifier for the elections-phragmen pallet's lock"
]
},
{
"name": "CandidacyBond",
"type": "BalanceOf",
"value": "0x0010a5d4e80000000000000000000000",
"docs": [
" How much should be locked up in order to submit one's candidacy."
]
},
{
"name": "VotingBondBase",
"type": "BalanceOf",
"value": "0x007013b72e0000000000000000000000",
"docs": [
" Base deposit associated with voting.",
"",
" This should be sensibly high to economically ensure the pallet cannot be attacked by",
" creating a gigantic number of votes."
]
},
{
"name": "VotingBondFactor",
"type": "BalanceOf",
"value": "0x00d01213000000000000000000000000",
"docs": [
" The amount of bond that need to be locked for each vote (32 bytes)."
]
},
{
"name": "DesiredMembers",
"type": "u32",
"value": "0x0d000000",
"docs": [
" Number of members to elect."
]
},
{
"name": "DesiredRunnersUp",
"type": "u32",
"value": "0x14000000",
"docs": [
" Number of runners_up to keep."
]
},
{
"name": "TermDuration",
"type": "BlockNumber",
"value": "0xc0890100",
"docs": [
" How long each seat is kept. This defines the next block number at which an election",
" round will happen. If set to zero, no elections are ever triggered and the module will",
" be in passive mode."
]
}
],
"errors": [
{
"name": "UnableToVote",
"docs": [
" Cannot vote when no candidates or members exist."
]
},
{
"name": "NoVotes",
"docs": [
" Must vote for at least one candidate."
]
},
{
"name": "TooManyVotes",
"docs": [
" Cannot vote more than candidates."
]
},
{
"name": "MaximumVotesExceeded",
"docs": [
" Cannot vote more than maximum allowed."
]
},
{
"name": "LowBalance",
"docs": [
" Cannot vote with stake less than minimum balance."
]
},
{
"name": "UnableToPayBond",
"docs": [
" Voter can not pay voting bond."
]
},
{
"name": "MustBeVoter",
"docs": [
" Must be a voter."
]
},
{
"name": "ReportSelf",
"docs": [
" Cannot report self."
]
},
{
"name": "DuplicatedCandidate",
"docs": [
" Duplicated candidate submission."
]
},
{
"name": "MemberSubmit",
"docs": [
" Member cannot re-submit candidacy."
]
},
{
"name": "RunnerUpSubmit",
"docs": [
" Runner cannot re-submit candidacy."
]
},
{
"name": "InsufficientCandidateFunds",
"docs": [
" Candidate does not have enough funds."
]
},
{
"name": "NotMember",
"docs": [
" Not a member."
]
},
{
"name": "InvalidWitnessData",
"docs": [
" The provided count of number of candidates is incorrect."
]
},
{
"name": "InvalidVoteCount",
"docs": [
" The provided count of number of votes is incorrect."
]
},
{
"name": "InvalidRenouncing",
"docs": [
" The renouncing origin presented a wrong `Renouncing` parameter."
]
},
{
"name": "InvalidReplacement",
"docs": [
" Prediction regarding replacement after member removal is wrong."
]
}
],
"index": 17
},
{
"name": "TechnicalMembership",
"storage": {
"prefix": "TechnicalMembership",
"items": [
{
"name": "Members",
"modifier": "Default",
"type": {
"plain": "Vec<AccountId>"
},
"fallback": "0x00",
"docs": [
" The current membership, stored as an ordered Vec."
]
},
{
"name": "Prime",
"modifier": "Optional",
"type": {
"plain": "AccountId"
},
"fallback": "0x00",
"docs": [
" The current prime member, if one exists."
]
}
]
},
"calls": [
{
"name": "add_member",
"args": [
{
"name": "who",
"type": "AccountId"
}
],
"docs": [
" Add a member `who` to the set.",
"",
" May only be called from `T::AddOrigin`."
]
},
{
"name": "remove_member",
"args": [
{
"name": "who",
"type": "AccountId"
}
],
"docs": [
" Remove a member `who` from the set.",
"",
" May only be called from `T::RemoveOrigin`."
]
},
{
"name": "swap_member",
"args": [
{
"name": "remove",
"type": "AccountId"
},
{
"name": "add",
"type": "AccountId"
}
],
"docs": [
" Swap out one member `remove` for another `add`.",
"",
" May only be called from `T::SwapOrigin`.",
"",
" Prime membership is *not* passed from `remove` to `add`, if extant."
]
},
{
"name": "reset_members",
"args": [
{
"name": "members",
"type": "Vec<AccountId>"
}
],
"docs": [
" Change the membership to a new set, disregarding the existing membership. Be nice and",
" pass `members` pre-sorted.",
"",
" May only be called from `T::ResetOrigin`."
]
},
{
"name": "change_key",
"args": [
{
"name": "new",
"type": "AccountId"
}
],
"docs": [
" Swap out the sending member for some other key `new`.",
"",
" May only be called from `Signed` origin of a current member.",
"",
" Prime membership is passed from the origin account to `new`, if extant."
]
},
{
"name": "set_prime",
"args": [
{
"name": "who",
"type": "AccountId"
}
],
"docs": [
" Set the prime member. Must be a current member.",
"",
" May only be called from `T::PrimeOrigin`."
]
},
{
"name": "clear_prime",
"args": [],
"docs": [
" Remove the prime member if it exists.",
"",
" May only be called from `T::PrimeOrigin`."
]
}
],
"events": [
{
"name": "MemberAdded",
"args": [],
"docs": [
" The given member was added; see the transaction for who."
]
},
{
"name": "MemberRemoved",
"args": [],
"docs": [
" The given member was removed; see the transaction for who."
]
},
{
"name": "MembersSwapped",
"args": [],
"docs": [
" Two members were swapped; see the transaction for who."
]
},
{
"name": "MembersReset",
"args": [],
"docs": [
" The membership was reset; see the transaction for who the new set is."
]
},
{
"name": "KeyChanged",
"args": [],
"docs": [
" One of the members' keys changed."
]
},
{
"name": "Dummy",
"args": [
"PhantomData"
],
"docs": [
" Phantom member, never used."
]
}
],
"constants": [],
"errors": [
{
"name": "AlreadyMember",
"docs": [
" Already a member."
]
},
{
"name": "NotMember",
"docs": [
" Not a member."
]
}
],
"index": 18
},
{
"name": "Treasury",
"storage": {
"prefix": "Treasury",
"items": [
{
"name": "ProposalCount",
"modifier": "Default",
"type": {
"plain": "ProposalIndex"
},
"fallback": "0x00000000",
"docs": [
" Number of proposals that have been made."
]
},
{
"name": "Proposals",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "ProposalIndex",
"value": "TreasuryProposal",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Proposals that have been made."
]
},
{
"name": "Approvals",
"modifier": "Default",
"type": {
"plain": "Vec<ProposalIndex>"
},
"fallback": "0x00",
"docs": [
" Proposal indices that have been approved but not yet awarded."
]
}
]
},
"calls": [
{
"name": "propose_spend",
"args": [
{
"name": "value",
"type": "Compact<BalanceOf>"
},
{
"name": "beneficiary",
"type": "LookupSource"
}
],
"docs": [
" Put forward a suggestion for spending. A deposit proportional to the value",
" is reserved and slashed if the proposal is rejected. It is returned once the",
" proposal is awarded.",
"",
" # <weight>",
" - Complexity: O(1)",
" - DbReads: `ProposalCount`, `origin account`",
" - DbWrites: `ProposalCount`, `Proposals`, `origin account`",
" # </weight>"
]
},
{
"name": "reject_proposal",
"args": [
{
"name": "proposal_id",
"type": "Compact<ProposalIndex>"
}
],
"docs": [
" Reject a proposed spend. The original deposit will be slashed.",
"",
" May only be called from `T::RejectOrigin`.",
"",
" # <weight>",
" - Complexity: O(1)",
" - DbReads: `Proposals`, `rejected proposer account`",
" - DbWrites: `Proposals`, `rejected proposer account`",
" # </weight>"
]
},
{
"name": "approve_proposal",
"args": [
{
"name": "proposal_id",
"type": "Compact<ProposalIndex>"
}
],
"docs": [
" Approve a proposal. At a later time, the proposal will be allocated to the beneficiary",
" and the original deposit will be returned.",
"",
" May only be called from `T::ApproveOrigin`.",
"",
" # <weight>",
" - Complexity: O(1).",
" - DbReads: `Proposals`, `Approvals`",
" - DbWrite: `Approvals`",
" # </weight>"
]
}
],
"events": [
{
"name": "Proposed",
"args": [
"ProposalIndex"
],
"docs": [
" New proposal. \\[proposal_index\\]"
]
},
{
"name": "Spending",
"args": [
"Balance"
],
"docs": [
" We have ended a spend period and will now allocate funds. \\[budget_remaining\\]"
]
},
{
"name": "Awarded",
"args": [
"ProposalIndex",
"Balance",
"AccountId"
],
"docs": [
" Some funds have been allocated. \\[proposal_index, award, beneficiary\\]"
]
},
{
"name": "Rejected",
"args": [
"ProposalIndex",
"Balance"
],
"docs": [
" A proposal was rejected; funds were slashed. \\[proposal_index, slashed\\]"
]
},
{
"name": "Burnt",
"args": [
"Balance"
],
"docs": [
" Some of our funds have been burnt. \\[burn\\]"
]
},
{
"name": "Rollover",
"args": [
"Balance"
],
"docs": [
" Spending has finished; this is the amount that rolls over until next spend.",
" \\[budget_remaining\\]"
]
},
{
"name": "Deposit",
"args": [
"Balance"
],
"docs": [
" Some funds have been deposited. \\[deposit\\]"
]
}
],
"constants": [
{
"name": "ProposalBond",
"type": "Permill",
"value": "0x50c30000",
"docs": [
" Fraction of a proposal's value that should be bonded in order to place the proposal.",
" An accepted proposal gets these back. A rejected proposal does not."
]
},
{
"name": "ProposalBondMinimum",
"type": "BalanceOf",
"value": "0x0010a5d4e80000000000000000000000",
"docs": [
" Minimum amount of funds that should be placed in a deposit for making a proposal."
]
},
{
"name": "SpendPeriod",
"type": "BlockNumber",
"value": "0x00460500",
"docs": [
" Period between successive spends."
]
},
{
"name": "Burn",
"type": "Permill",
"value": "0x10270000",
"docs": [
" Percentage of spare funds (if any) that are burnt per spend period."
]
},
{
"name": "PalletId",
"type": "PalletId",
"value": "0x70792f7472737279",
"docs": [
" The treasury's pallet id, used for deriving its sovereign account ID."
]
},
{
"name": "MaxApprovals",
"type": "u32",
"value": "0x64000000",
"docs": [
" The maximum number of approvals that can wait in the spending queue."
]
}
],
"errors": [
{
"name": "InsufficientProposersBalance",
"docs": [
" Proposer's balance is too low."
]
},
{
"name": "InvalidIndex",
"docs": [
" No proposal or bounty at that index."
]
},
{
"name": "TooManyApprovals",
"docs": [
" Too many approvals in the queue."
]
}
],
"index": 19
},
{
"name": "Claims",
"storage": {
"prefix": "Claims",
"items": [
{
"name": "Claims",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "EthereumAddress",
"value": "BalanceOf",
"linked": false
}
},
"fallback": "0x00",
"docs": []
},
{
"name": "Total",
"modifier": "Default",
"type": {
"plain": "BalanceOf"
},
"fallback": "0x00000000000000000000000000000000",
"docs": []
},
{
"name": "Vesting",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "EthereumAddress",
"value": "(BalanceOf,BalanceOf,BlockNumber)",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Vesting schedule for a claim.",
" First balance is the total amount that should be held for vesting.",
" Second balance is how much should be unlocked per block.",
" The block number is when the vesting should start."
]
},
{
"name": "Signing",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "EthereumAddress",
"value": "StatementKind",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The statement kind that must be signed, if any."
]
},
{
"name": "Preclaims",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "AccountId",
"value": "EthereumAddress",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Pre-claimed Ethereum accounts, by the Account ID that they are claimed to."
]
}
]
},
"calls": [
{
"name": "claim",
"args": [
{
"name": "dest",
"type": "AccountId"
},
{
"name": "ethereum_signature",
"type": "EcdsaSignature"
}
],
"docs": [
" Make a claim to collect your DOTs.",
"",
" The dispatch origin for this call must be _None_.",
"",
" Unsigned Validation:",
" A call to claim is deemed valid if the signature provided matches",
" the expected signed message of:",
"",
" > Ethereum Signed Message:",
" > (configured prefix string)(address)",
"",
" and `address` matches the `dest` account.",
"",
" Parameters:",
" - `dest`: The destination account to payout the claim.",
" - `ethereum_signature`: The signature of an ethereum signed message",
" matching the format described above.",
"",
" <weight>",
" The weight of this call is invariant over the input parameters.",
" Weight includes logic to validate unsigned `claim` call.",
"",
" Total Complexity: O(1)",
" </weight>"
]
},
{
"name": "mint_claim",
"args": [
{
"name": "who",
"type": "EthereumAddress"
},
{
"name": "value",
"type": "BalanceOf"
},
{
"name": "vesting_schedule",
"type": "Option<(BalanceOf,BalanceOf,BlockNumber)>"
},
{
"name": "statement",
"type": "Option<StatementKind>"
}
],
"docs": [
" Mint a new claim to collect DOTs.",
"",
" The dispatch origin for this call must be _Root_.",
"",
" Parameters:",
" - `who`: The Ethereum address allowed to collect this claim.",
" - `value`: The number of DOTs that will be claimed.",
" - `vesting_schedule`: An optional vesting schedule for these DOTs.",
"",
" <weight>",
" The weight of this call is invariant over the input parameters.",
" We assume worst case that both vesting and statement is being inserted.",
"",
" Total Complexity: O(1)",
" </weight>"
]
},
{
"name": "claim_attest",
"args": [
{
"name": "dest",
"type": "AccountId"
},
{
"name": "ethereum_signature",
"type": "EcdsaSignature"
},
{
"name": "statement",
"type": "Bytes"
}
],
"docs": [
" Make a claim to collect your DOTs by signing a statement.",
"",
" The dispatch origin for this call must be _None_.",
"",
" Unsigned Validation:",
" A call to `claim_attest` is deemed valid if the signature provided matches",
" the expected signed message of:",
"",
" > Ethereum Signed Message:",
" > (configured prefix string)(address)(statement)",
"",
" and `address` matches the `dest` account; the `statement` must match that which is",
" expected according to your purchase arrangement.",
"",
" Parameters:",
" - `dest`: The destination account to payout the claim.",
" - `ethereum_signature`: The signature of an ethereum signed message",
" matching the format described above.",
" - `statement`: The identity of the statement which is being attested to in the signature.",
"",
" <weight>",
" The weight of this call is invariant over the input parameters.",
" Weight includes logic to validate unsigned `claim_attest` call.",
"",
" Total Complexity: O(1)",
" </weight>"
]
},
{
"name": "attest",
"args": [
{
"name": "statement",
"type": "Bytes"
}
],
"docs": [
" Attest to a statement, needed to finalize the claims process.",
"",
" WARNING: Insecure unless your chain includes `PrevalidateAttests` as a `SignedExtension`.",
"",
" Unsigned Validation:",
" A call to attest is deemed valid if the sender has a `Preclaim` registered",
" and provides a `statement` which is expected for the account.",
"",
" Parameters:",
" - `statement`: The identity of the statement which is being attested to in the signature.",
"",
" <weight>",
" The weight of this call is invariant over the input parameters.",
" Weight includes logic to do pre-validation on `attest` call.",
"",
" Total Complexity: O(1)",
" </weight>"
]
},
{
"name": "move_claim",
"args": [
{
"name": "old",
"type": "EthereumAddress"
},
{
"name": "new",
"type": "EthereumAddress"
},
{
"name": "maybe_preclaim",
"type": "Option<AccountId>"
}
],
"docs": []
}
],
"events": [
{
"name": "Claimed",
"args": [
"AccountId",
"EthereumAddress",
"Balance"
],
"docs": [
" Someone claimed some DOTs. `[who, ethereum_address, amount]`"
]
}
],
"constants": [
{
"name": "Prefix",
"type": "Bytes",
"value": "0x8450617920444f547320746f2074686520506f6c6b61646f74206163636f756e743a",
"docs": []
}
],
"errors": [
{
"name": "InvalidEthereumSignature",
"docs": [
" Invalid Ethereum signature."
]
},
{
"name": "SignerHasNoClaim",
"docs": [
" Ethereum address has no claim."
]
},
{
"name": "SenderHasNoClaim",
"docs": [
" Account ID sending transaction has no claim."
]
},
{
"name": "PotUnderflow",
"docs": [
" There's not enough in the pot to pay out some unvested amount. Generally implies a logic",
" error."
]
},
{
"name": "InvalidStatement",
"docs": [
" A needed statement was not included."
]
},
{
"name": "VestedBalanceExists",
"docs": [
" The account already has a vested balance."
]
}
],
"index": 24
},
{
"name": "Vesting",
"storage": {
"prefix": "Vesting",
"items": [
{
"name": "Vesting",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "Vec<VestingInfo>",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Information regarding the vesting of a given account."
]
},
{
"name": "StorageVersion",
"modifier": "Default",
"type": {
"plain": "Releases"
},
"fallback": "0x00",
"docs": [
" Storage version of the pallet.",
"",
" New networks start with latest version, as determined by the genesis build."
]
}
]
},
"calls": [
{
"name": "vest",
"args": [],
"docs": [
" Unlock any vested funds of the sender account.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have funds still",
" locked under this pallet.",
"",
" Emits either `VestingCompleted` or `VestingUpdated`.",
"",
" # <weight>",
" - `O(1)`.",
" - DbWeight: 2 Reads, 2 Writes",
" - Reads: Vesting Storage, Balances Locks, [Sender Account]",
" - Writes: Vesting Storage, Balances Locks, [Sender Account]",
" # </weight>"
]
},
{
"name": "vest_other",
"args": [
{
"name": "target",
"type": "LookupSource"
}
],
"docs": [
" Unlock any vested funds of a `target` account.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `target`: The account whose vested funds should be unlocked. Must have funds still",
" locked under this pallet.",
"",
" Emits either `VestingCompleted` or `VestingUpdated`.",
"",
" # <weight>",
" - `O(1)`.",
" - DbWeight: 3 Reads, 3 Writes",
" - Reads: Vesting Storage, Balances Locks, Target Account",
" - Writes: Vesting Storage, Balances Locks, Target Account",
" # </weight>"
]
},
{
"name": "vested_transfer",
"args": [
{
"name": "target",
"type": "LookupSource"
},
{
"name": "schedule",
"type": "VestingInfo"
}
],
"docs": [
" Create a vested transfer.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `target`: The account receiving the vested funds.",
" - `schedule`: The vesting schedule attached to the transfer.",
"",
" Emits `VestingCreated`.",
"",
" NOTE: This will unlock all schedules through the current block.",
"",
" # <weight>",
" - `O(1)`.",
" - DbWeight: 3 Reads, 3 Writes",
" - Reads: Vesting Storage, Balances Locks, Target Account, [Sender Account]",
" - Writes: Vesting Storage, Balances Locks, Target Account, [Sender Account]",
" # </weight>"
]
},
{
"name": "force_vested_transfer",
"args": [
{
"name": "source",
"type": "LookupSource"
},
{
"name": "target",
"type": "LookupSource"
},
{
"name": "schedule",
"type": "VestingInfo"
}
],
"docs": [
" Force a vested transfer.",
"",
" The dispatch origin for this call must be _Root_.",
"",
" - `source`: The account whose funds should be transferred.",
" - `target`: The account that should be transferred the vested funds.",
" - `schedule`: The vesting schedule attached to the transfer.",
"",
" Emits `VestingCreated`.",
"",
" NOTE: This will unlock all schedules through the current block.",
"",
" # <weight>",
" - `O(1)`.",
" - DbWeight: 4 Reads, 4 Writes",
" - Reads: Vesting Storage, Balances Locks, Target Account, Source Account",
" - Writes: Vesting Storage, Balances Locks, Target Account, Source Account",
" # </weight>"
]
},
{
"name": "merge_schedules",
"args": [
{
"name": "schedule1_index",
"type": "u32"
},
{
"name": "schedule2_index",
"type": "u32"
}
],
"docs": [
" Merge two vesting schedules together, creating a new vesting schedule that unlocks over",
" the highest possible start and end blocks. If both schedules have already started the",
" current block will be used as the schedule start; with the caveat that if one schedule",
" is finished by the current block, the other will be treated as the new merged schedule,",
" unmodified.",
"",
" NOTE: If `schedule1_index == schedule2_index` this is a no-op.",
" NOTE: This will unlock all schedules through the current block prior to merging.",
" NOTE: If both schedules have ended by the current block, no new schedule will be created",
" and both will be removed.",
"",
" Merged schedule attributes:",
" - `starting_block`: `MAX(schedule1.starting_block, scheduled2.starting_block,",
" current_block)`.",
" - `ending_block`: `MAX(schedule1.ending_block, schedule2.ending_block)`.",
" - `locked`: `schedule1.locked_at(current_block) + schedule2.locked_at(current_block)`.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `schedule1_index`: index of the first schedule to merge.",
" - `schedule2_index`: index of the second schedule to merge."
]
}
],
"events": [
{
"name": "VestingUpdated",
"args": [
"AccountId",
"Balance"
],
"docs": [
" The amount vested has been updated. This could indicate a change in funds available.",
" The balance given is the amount which is left unvested (and thus locked).",
" \\[account, unvested\\]"
]
},
{
"name": "VestingCompleted",
"args": [
"AccountId"
],
"docs": [
" An \\[account\\] has become fully vested."
]
}
],
"constants": [
{
"name": "MinVestedTransfer",
"type": "BalanceOf",
"value": "0x00e40b54020000000000000000000000",
"docs": [
" The minimum amount transferred to call `vested_transfer`."
]
},
{
"name": "MaxVestingSchedules",
"type": "u32",
"value": "0x1c000000",
"docs": []
}
],
"errors": [
{
"name": "NotVesting",
"docs": [
" The account given is not vesting."
]
},
{
"name": "AtMaxVestingSchedules",
"docs": [
" The account already has `MaxVestingSchedules` count of schedules and thus",
" cannot add another one. Consider merging existing schedules in order to add another."
]
},
{
"name": "AmountLow",
"docs": [
" Amount being transferred is too low to create a vesting schedule."
]
},
{
"name": "ScheduleIndexOutOfBounds",
"docs": [
" An index was out of bounds of the vesting schedules."
]
},
{
"name": "InvalidScheduleParams",
"docs": [
" Failed to create a new schedule because some parameter was invalid."
]
}
],
"index": 25
},
{
"name": "Utility",
"storage": null,
"calls": [
{
"name": "batch",
"args": [
{
"name": "calls",
"type": "Vec<Call>"
}
],
"docs": [
" Send a batch of dispatch calls.",
"",
" May be called from any origin.",
"",
" - `calls`: The calls to be dispatched from the same origin. The number of call must not",
" exceed the constant: `batched_calls_limit` (available in constant metadata).",
"",
" If origin is root then call are dispatch without checking origin filter. (This includes",
" bypassing `frame_system::Config::BaseCallFilter`).",
"",
" # <weight>",
" - Complexity: O(C) where C is the number of calls to be batched.",
" # </weight>",
"",
" This will return `Ok` in all circumstances. To determine the success of the batch, an",
" event is deposited. If a call failed and the batch was interrupted, then the",
" `BatchInterrupted` event is deposited, along with the number of successful calls made",
" and the error of the failed call. If all were successful, then the `BatchCompleted`",
" event is deposited."
]
},
{
"name": "as_derivative",
"args": [
{
"name": "index",
"type": "u16"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Send a call through an indexed pseudonym of the sender.",
"",
" Filter from origin are passed along. The call will be dispatched with an origin which",
" use the same filter as the origin of this call.",
"",
" NOTE: If you need to ensure that any account-based filtering is not honored (i.e.",
" because you expect `proxy` to have been used prior in the call stack and you do not want",
" the call restrictions to apply to any sub-accounts), then use `as_multi_threshold_1`",
" in the Multisig pallet instead.",
"",
" NOTE: Prior to version *12, this was called `as_limited_sub`.",
"",
" The dispatch origin for this call must be _Signed_."
]
},
{
"name": "batch_all",
"args": [
{
"name": "calls",
"type": "Vec<Call>"
}
],
"docs": [
" Send a batch of dispatch calls and atomically execute them.",
" The whole transaction will rollback and fail if any of the calls failed.",
"",
" May be called from any origin.",
"",
" - `calls`: The calls to be dispatched from the same origin. The number of call must not",
" exceed the constant: `batched_calls_limit` (available in constant metadata).",
"",
" If origin is root then call are dispatch without checking origin filter. (This includes",
" bypassing `frame_system::Config::BaseCallFilter`).",
"",
" # <weight>",
" - Complexity: O(C) where C is the number of calls to be batched.",
" # </weight>"
]
}
],
"events": [
{
"name": "BatchInterrupted",
"args": [
"u32",
"DispatchError"
],
"docs": [
" Batch of dispatches did not complete fully. Index of first failing dispatch given, as",
" well as the error. \\[index, error\\]"
]
},
{
"name": "BatchCompleted",
"args": [],
"docs": [
" Batch of dispatches completed fully with no error."
]
},
{
"name": "ItemCompleted",
"args": [],
"docs": [
" A single item within a Batch of dispatches has completed with no error."
]
}
],
"constants": [
{
"name": "batched_calls_limit",
"type": "u32",
"value": "0x0cc30000",
"docs": [
" The limit on the number of batched calls."
]
}
],
"errors": [
{
"name": "TooManyCalls",
"docs": [
" Too many calls batched."
]
}
],
"index": 26
},
{
"name": "Identity",
"storage": {
"prefix": "Identity",
"items": [
{
"name": "IdentityOf",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "Registration",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Information that is pertinent to identify the entity behind an account.",
"",
" TWOX-NOTE: OK ― `AccountId` is a secure hash."
]
},
{
"name": "SuperOf",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Blake2_128Concat",
"key": "AccountId",
"value": "(AccountId,Data)",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The super-identity of an alternative \"sub\" identity together with its name, within that",
" context. If the account is not some other account's sub-identity, then just `None`."
]
},
{
"name": "SubsOf",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "(BalanceOf,Vec<AccountId>)",
"linked": false
}
},
"fallback": "0x0000000000000000000000000000000000",
"docs": [
" Alternative \"sub\" identities of this account.",
"",
" The first item is the deposit, the second is a vector of the accounts.",
"",
" TWOX-NOTE: OK ― `AccountId` is a secure hash."
]
},
{
"name": "Registrars",
"modifier": "Default",
"type": {
"plain": "Vec<Option<RegistrarInfo>>"
},
"fallback": "0x00",
"docs": [
" The set of registrars. Not expected to get very big as can only be added through a",
" special origin (likely a council motion).",
"",
" The index into this can be cast to `RegistrarIndex` to get a valid value."
]
}
]
},
"calls": [
{
"name": "add_registrar",
"args": [
{
"name": "account",
"type": "AccountId"
}
],
"docs": [
" Add a registrar to the system.",
"",
" The dispatch origin for this call must be `T::RegistrarOrigin`.",
"",
" - `account`: the account of the registrar.",
"",
" Emits `RegistrarAdded` if successful.",
"",
" # <weight>",
" - `O(R)` where `R` registrar-count (governance-bounded and code-bounded).",
" - One storage mutation (codec `O(R)`).",
" - One event.",
" # </weight>"
]
},
{
"name": "set_identity",
"args": [
{
"name": "info",
"type": "IdentityInfo"
}
],
"docs": [
" Set an account's identity information and reserve the appropriate deposit.",
"",
" If the account already has identity information, the deposit is taken as part payment",
" for the new deposit.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `info`: The identity information.",
"",
" Emits `IdentitySet` if successful.",
"",
" # <weight>",
" - `O(X + X' + R)`",
" - where `X` additional-field-count (deposit-bounded and code-bounded)",
" - where `R` judgements-count (registrar-count-bounded)",
" - One balance reserve operation.",
" - One storage mutation (codec-read `O(X' + R)`, codec-write `O(X + R)`).",
" - One event.",
" # </weight>"
]
},
{
"name": "set_subs",
"args": [
{
"name": "subs",
"type": "Vec<(AccountId,Data)>"
}
],
"docs": [
" Set the sub-accounts of the sender.",
"",
" Payment: Any aggregate balance reserved by previous `set_subs` calls will be returned",
" and an amount `SubAccountDeposit` will be reserved for each item in `subs`.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a registered",
" identity.",
"",
" - `subs`: The identity's (new) sub-accounts.",
"",
" # <weight>",
" - `O(P + S)`",
" - where `P` old-subs-count (hard- and deposit-bounded).",
" - where `S` subs-count (hard- and deposit-bounded).",
" - At most one balance operations.",
" - DB:",
" - `P + S` storage mutations (codec complexity `O(1)`)",
" - One storage read (codec complexity `O(P)`).",
" - One storage write (codec complexity `O(S)`).",
" - One storage-exists (`IdentityOf::contains_key`).",
" # </weight>"
]
},
{
"name": "clear_identity",
"args": [],
"docs": [
" Clear an account's identity info and all sub-accounts and return all deposits.",
"",
" Payment: All reserved balances on the account are returned.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a registered",
" identity.",
"",
" Emits `IdentityCleared` if successful.",
"",
" # <weight>",
" - `O(R + S + X)`",
" - where `R` registrar-count (governance-bounded).",
" - where `S` subs-count (hard- and deposit-bounded).",
" - where `X` additional-field-count (deposit-bounded and code-bounded).",
" - One balance-unreserve operation.",
" - `2` storage reads and `S + 2` storage deletions.",
" - One event.",
" # </weight>"
]
},
{
"name": "request_judgement",
"args": [
{
"name": "reg_index",
"type": "Compact<RegistrarIndex>"
},
{
"name": "max_fee",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Request a judgement from a registrar.",
"",
" Payment: At most `max_fee` will be reserved for payment to the registrar if judgement",
" given.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a",
" registered identity.",
"",
" - `reg_index`: The index of the registrar whose judgement is requested.",
" - `max_fee`: The maximum fee that may be paid. This should just be auto-populated as:",
"",
" ```nocompile",
" Self::registrars().get(reg_index).unwrap().fee",
" ```",
"",
" Emits `JudgementRequested` if successful.",
"",
" # <weight>",
" - `O(R + X)`.",
" - One balance-reserve operation.",
" - Storage: 1 read `O(R)`, 1 mutate `O(X + R)`.",
" - One event.",
" # </weight>"
]
},
{
"name": "cancel_request",
"args": [
{
"name": "reg_index",
"type": "RegistrarIndex"
}
],
"docs": [
" Cancel a previous request.",
"",
" Payment: A previously reserved deposit is returned on success.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a",
" registered identity.",
"",
" - `reg_index`: The index of the registrar whose judgement is no longer requested.",
"",
" Emits `JudgementUnrequested` if successful.",
"",
" # <weight>",
" - `O(R + X)`.",
" - One balance-reserve operation.",
" - One storage mutation `O(R + X)`.",
" - One event",
" # </weight>"
]
},
{
"name": "set_fee",
"args": [
{
"name": "index",
"type": "Compact<RegistrarIndex>"
},
{
"name": "fee",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Set the fee required for a judgement to be requested from a registrar.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must be the account",
" of the registrar whose index is `index`.",
"",
" - `index`: the index of the registrar whose fee is to be set.",
" - `fee`: the new fee.",
"",
" # <weight>",
" - `O(R)`.",
" - One storage mutation `O(R)`.",
" - Benchmark: 7.315 + R * 0.329 µs (min squares analysis)",
" # </weight>"
]
},
{
"name": "set_account_id",
"args": [
{
"name": "index",
"type": "Compact<RegistrarIndex>"
},
{
"name": "new",
"type": "AccountId"
}
],
"docs": [
" Change the account associated with a registrar.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must be the account",
" of the registrar whose index is `index`.",
"",
" - `index`: the index of the registrar whose fee is to be set.",
" - `new`: the new account ID.",
"",
" # <weight>",
" - `O(R)`.",
" - One storage mutation `O(R)`.",
" - Benchmark: 8.823 + R * 0.32 µs (min squares analysis)",
" # </weight>"
]
},
{
"name": "set_fields",
"args": [
{
"name": "index",
"type": "Compact<RegistrarIndex>"
},
{
"name": "fields",
"type": "IdentityFields"
}
],
"docs": [
" Set the field information for a registrar.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must be the account",
" of the registrar whose index is `index`.",
"",
" - `index`: the index of the registrar whose fee is to be set.",
" - `fields`: the fields that the registrar concerns themselves with.",
"",
" # <weight>",
" - `O(R)`.",
" - One storage mutation `O(R)`.",
" - Benchmark: 7.464 + R * 0.325 µs (min squares analysis)",
" # </weight>"
]
},
{
"name": "provide_judgement",
"args": [
{
"name": "reg_index",
"type": "Compact<RegistrarIndex>"
},
{
"name": "target",
"type": "LookupSource"
},
{
"name": "judgement",
"type": "IdentityJudgement"
}
],
"docs": [
" Provide a judgement for an account's identity.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must be the account",
" of the registrar whose index is `reg_index`.",
"",
" - `reg_index`: the index of the registrar whose judgement is being made.",
" - `target`: the account whose identity the judgement is upon. This must be an account",
" with a registered identity.",
" - `judgement`: the judgement of the registrar of index `reg_index` about `target`.",
"",
" Emits `JudgementGiven` if successful.",
"",
" # <weight>",
" - `O(R + X)`.",
" - One balance-transfer operation.",
" - Up to one account-lookup operation.",
" - Storage: 1 read `O(R)`, 1 mutate `O(R + X)`.",
" - One event.",
" # </weight>"
]
},
{
"name": "kill_identity",
"args": [
{
"name": "target",
"type": "LookupSource"
}
],
"docs": [
" Remove an account's identity and sub-account information and slash the deposits.",
"",
" Payment: Reserved balances from `set_subs` and `set_identity` are slashed and handled by",
" `Slash`. Verification request deposits are not returned; they should be cancelled",
" manually using `cancel_request`.",
"",
" The dispatch origin for this call must match `T::ForceOrigin`.",
"",
" - `target`: the account whose identity the judgement is upon. This must be an account",
" with a registered identity.",
"",
" Emits `IdentityKilled` if successful.",
"",
" # <weight>",
" - `O(R + S + X)`.",
" - One balance-reserve operation.",
" - `S + 2` storage mutations.",
" - One event.",
" # </weight>"
]
},
{
"name": "add_sub",
"args": [
{
"name": "sub",
"type": "LookupSource"
},
{
"name": "data",
"type": "Data"
}
],
"docs": [
" Add the given account to the sender's subs.",
"",
" Payment: Balance reserved by a previous `set_subs` call for one sub will be repatriated",
" to the sender.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a registered",
" sub identity of `sub`."
]
},
{
"name": "rename_sub",
"args": [
{
"name": "sub",
"type": "LookupSource"
},
{
"name": "data",
"type": "Data"
}
],
"docs": [
" Alter the associated name of the given sub-account.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a registered",
" sub identity of `sub`."
]
},
{
"name": "remove_sub",
"args": [
{
"name": "sub",
"type": "LookupSource"
}
],
"docs": [
" Remove the given account from the sender's subs.",
"",
" Payment: Balance reserved by a previous `set_subs` call for one sub will be repatriated",
" to the sender.",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a registered",
" sub identity of `sub`."
]
},
{
"name": "quit_sub",
"args": [],
"docs": [
" Remove the sender as a sub-account.",
"",
" Payment: Balance reserved by a previous `set_subs` call for one sub will be repatriated",
" to the sender (*not* the original depositor).",
"",
" The dispatch origin for this call must be _Signed_ and the sender must have a registered",
" super-identity.",
"",
" NOTE: This should not normally be used, but is provided in the case that the non-",
" controller of an account is maliciously registered as a sub-account."
]
}
],
"events": [
{
"name": "IdentitySet",
"args": [
"AccountId"
],
"docs": [
" A name was set or reset (which will remove all judgements). \\[who\\]"
]
},
{
"name": "IdentityCleared",
"args": [
"AccountId",
"Balance"
],
"docs": [
" A name was cleared, and the given balance returned. \\[who, deposit\\]"
]
},
{
"name": "IdentityKilled",
"args": [
"AccountId",
"Balance"
],
"docs": [
" A name was removed and the given balance slashed. \\[who, deposit\\]"
]
},
{
"name": "JudgementRequested",
"args": [
"AccountId",
"RegistrarIndex"
],
"docs": [
" A judgement was asked from a registrar. \\[who, registrar_index\\]"
]
},
{
"name": "JudgementUnrequested",
"args": [
"AccountId",
"RegistrarIndex"
],
"docs": [
" A judgement request was retracted. \\[who, registrar_index\\]"
]
},
{
"name": "JudgementGiven",
"args": [
"AccountId",
"RegistrarIndex"
],
"docs": [
" A judgement was given by a registrar. \\[target, registrar_index\\]"
]
},
{
"name": "RegistrarAdded",
"args": [
"RegistrarIndex"
],
"docs": [
" A registrar was added. \\[registrar_index\\]"
]
},
{
"name": "SubIdentityAdded",
"args": [
"AccountId",
"AccountId",
"Balance"
],
"docs": [
" A sub-identity was added to an identity and the deposit paid. \\[sub, main, deposit\\]"
]
},
{
"name": "SubIdentityRemoved",
"args": [
"AccountId",
"AccountId",
"Balance"
],
"docs": [
" A sub-identity was removed from an identity and the deposit freed.",
" \\[sub, main, deposit\\]"
]
},
{
"name": "SubIdentityRevoked",
"args": [
"AccountId",
"AccountId",
"Balance"
],
"docs": [
" A sub-identity was cleared, and the given deposit repatriated from the",
" main identity account to the sub-identity account. \\[sub, main, deposit\\]"
]
}
],
"constants": [
{
"name": "BasicDeposit",
"type": "BalanceOf",
"value": "0x007db52a2f0000000000000000000000",
"docs": [
" The amount held on deposit for a registered identity"
]
},
{
"name": "FieldDeposit",
"type": "BalanceOf",
"value": "0x00cd5627000000000000000000000000",
"docs": [
" The amount held on deposit per additional field for a registered identity."
]
},
{
"name": "SubAccountDeposit",
"type": "BalanceOf",
"value": "0x80f884b02e0000000000000000000000",
"docs": [
" The amount held on deposit for a registered subaccount. This should account for the fact",
" that one storage item's value will increase by the size of an account ID, and there will",
" be another trie item whose value is the size of an account ID plus 32 bytes."
]
},
{
"name": "MaxSubAccounts",
"type": "u32",
"value": "0x64000000",
"docs": [
" The maximum number of sub-accounts allowed per identified account."
]
},
{
"name": "MaxAdditionalFields",
"type": "u32",
"value": "0x64000000",
"docs": [
" Maximum number of additional fields that may be stored in an ID. Needed to bound the I/O",
" required to access an identity, but can be pretty high."
]
},
{
"name": "MaxRegistrars",
"type": "u32",
"value": "0x14000000",
"docs": [
" Maxmimum number of registrars allowed in the system. Needed to bound the complexity",
" of, e.g., updating judgements."
]
}
],
"errors": [
{
"name": "TooManySubAccounts",
"docs": [
" Too many subs-accounts."
]
},
{
"name": "NotFound",
"docs": [
" Account isn't found."
]
},
{
"name": "NotNamed",
"docs": [
" Account isn't named."
]
},
{
"name": "EmptyIndex",
"docs": [
" Empty index."
]
},
{
"name": "FeeChanged",
"docs": [
" Fee is changed."
]
},
{
"name": "NoIdentity",
"docs": [
" No identity found."
]
},
{
"name": "StickyJudgement",
"docs": [
" Sticky judgement."
]
},
{
"name": "JudgementGiven",
"docs": [
" Judgement given."
]
},
{
"name": "InvalidJudgement",
"docs": [
" Invalid judgement."
]
},
{
"name": "InvalidIndex",
"docs": [
" The index is invalid."
]
},
{
"name": "InvalidTarget",
"docs": [
" The target is invalid."
]
},
{
"name": "TooManyFields",
"docs": [
" Too many additional fields."
]
},
{
"name": "TooManyRegistrars",
"docs": [
" Maximum amount of registrars reached. Cannot add any more."
]
},
{
"name": "AlreadyClaimed",
"docs": [
" Account ID is already named."
]
},
{
"name": "NotSub",
"docs": [
" Sender is not a sub-account."
]
},
{
"name": "NotOwned",
"docs": [
" Sub-account isn't owned by sender."
]
}
],
"index": 28
},
{
"name": "Proxy",
"storage": {
"prefix": "Proxy",
"items": [
{
"name": "Proxies",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "(Vec<ProxyDefinition>,BalanceOf)",
"linked": false
}
},
"fallback": "0x0000000000000000000000000000000000",
"docs": [
" The set of account proxies. Maps the account which has delegated to the accounts",
" which are being delegated to, together with the amount held on deposit."
]
},
{
"name": "Announcements",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "AccountId",
"value": "(Vec<ProxyAnnouncement>,BalanceOf)",
"linked": false
}
},
"fallback": "0x0000000000000000000000000000000000",
"docs": [
" The announcements made by the proxy (key)."
]
}
]
},
"calls": [
{
"name": "proxy",
"args": [
{
"name": "real",
"type": "AccountId"
},
{
"name": "force_proxy_type",
"type": "Option<ProxyType>"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Dispatch the given `call` from an account that the sender is authorised for through",
" `add_proxy`.",
"",
" Removes any corresponding announcement(s).",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Parameters:",
" - `real`: The account that the proxy will make a call on behalf of.",
" - `force_proxy_type`: Specify the exact proxy type to be used and checked for this call.",
" - `call`: The call to be made by the `real` account.",
"",
" # <weight>",
" Weight is a function of the number of proxies the user has (P).",
" # </weight>"
]
},
{
"name": "add_proxy",
"args": [
{
"name": "delegate",
"type": "AccountId"
},
{
"name": "proxy_type",
"type": "ProxyType"
},
{
"name": "delay",
"type": "BlockNumber"
}
],
"docs": [
" Register a proxy account for the sender that is able to make calls on its behalf.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Parameters:",
" - `proxy`: The account that the `caller` would like to make a proxy.",
" - `proxy_type`: The permissions allowed for this proxy account.",
" - `delay`: The announcement period required of the initial proxy. Will generally be",
" zero.",
"",
" # <weight>",
" Weight is a function of the number of proxies the user has (P).",
" # </weight>"
]
},
{
"name": "remove_proxy",
"args": [
{
"name": "delegate",
"type": "AccountId"
},
{
"name": "proxy_type",
"type": "ProxyType"
},
{
"name": "delay",
"type": "BlockNumber"
}
],
"docs": [
" Unregister a proxy account for the sender.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Parameters:",
" - `proxy`: The account that the `caller` would like to remove as a proxy.",
" - `proxy_type`: The permissions currently enabled for the removed proxy account.",
"",
" # <weight>",
" Weight is a function of the number of proxies the user has (P).",
" # </weight>"
]
},
{
"name": "remove_proxies",
"args": [],
"docs": [
" Unregister all proxy accounts for the sender.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" WARNING: This may be called on accounts created by `anonymous`, however if done, then",
" the unreserved fees will be inaccessible. **All access to this account will be lost.**",
"",
" # <weight>",
" Weight is a function of the number of proxies the user has (P).",
" # </weight>"
]
},
{
"name": "anonymous",
"args": [
{
"name": "proxy_type",
"type": "ProxyType"
},
{
"name": "delay",
"type": "BlockNumber"
},
{
"name": "index",
"type": "u16"
}
],
"docs": [
" Spawn a fresh new account that is guaranteed to be otherwise inaccessible, and",
" initialize it with a proxy of `proxy_type` for `origin` sender.",
"",
" Requires a `Signed` origin.",
"",
" - `proxy_type`: The type of the proxy that the sender will be registered as over the",
" new account. This will almost always be the most permissive `ProxyType` possible to",
" allow for maximum flexibility.",
" - `index`: A disambiguation index, in case this is called multiple times in the same",
" transaction (e.g. with `utility::batch`). Unless you're using `batch` you probably just",
" want to use `0`.",
" - `delay`: The announcement period required of the initial proxy. Will generally be",
" zero.",
"",
" Fails with `Duplicate` if this has already been called in this transaction, from the",
" same sender, with the same parameters.",
"",
" Fails if there are insufficient funds to pay for deposit.",
"",
" # <weight>",
" Weight is a function of the number of proxies the user has (P).",
" # </weight>",
" TODO: Might be over counting 1 read"
]
},
{
"name": "kill_anonymous",
"args": [
{
"name": "spawner",
"type": "AccountId"
},
{
"name": "proxy_type",
"type": "ProxyType"
},
{
"name": "index",
"type": "u16"
},
{
"name": "height",
"type": "Compact<BlockNumber>"
},
{
"name": "ext_index",
"type": "Compact<u32>"
}
],
"docs": [
" Removes a previously spawned anonymous proxy.",
"",
" WARNING: **All access to this account will be lost.** Any funds held in it will be",
" inaccessible.",
"",
" Requires a `Signed` origin, and the sender account must have been created by a call to",
" `anonymous` with corresponding parameters.",
"",
" - `spawner`: The account that originally called `anonymous` to create this account.",
" - `index`: The disambiguation index originally passed to `anonymous`. Probably `0`.",
" - `proxy_type`: The proxy type originally passed to `anonymous`.",
" - `height`: The height of the chain when the call to `anonymous` was processed.",
" - `ext_index`: The extrinsic index in which the call to `anonymous` was processed.",
"",
" Fails with `NoPermission` in case the caller is not a previously created anonymous",
" account whose `anonymous` call has corresponding parameters.",
"",
" # <weight>",
" Weight is a function of the number of proxies the user has (P).",
" # </weight>"
]
},
{
"name": "announce",
"args": [
{
"name": "real",
"type": "AccountId"
},
{
"name": "call_hash",
"type": "CallHashOf"
}
],
"docs": [
" Publish the hash of a proxy-call that will be made in the future.",
"",
" This must be called some number of blocks before the corresponding `proxy` is attempted",
" if the delay associated with the proxy relationship is greater than zero.",
"",
" No more than `MaxPending` announcements may be made at any one time.",
"",
" This will take a deposit of `AnnouncementDepositFactor` as well as",
" `AnnouncementDepositBase` if there are no other pending announcements.",
"",
" The dispatch origin for this call must be _Signed_ and a proxy of `real`.",
"",
" Parameters:",
" - `real`: The account that the proxy will make a call on behalf of.",
" - `call_hash`: The hash of the call to be made by the `real` account.",
"",
" # <weight>",
" Weight is a function of:",
" - A: the number of announcements made.",
" - P: the number of proxies the user has.",
" # </weight>"
]
},
{
"name": "remove_announcement",
"args": [
{
"name": "real",
"type": "AccountId"
},
{
"name": "call_hash",
"type": "CallHashOf"
}
],
"docs": [
" Remove a given announcement.",
"",
" May be called by a proxy account to remove a call they previously announced and return",
" the deposit.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Parameters:",
" - `real`: The account that the proxy will make a call on behalf of.",
" - `call_hash`: The hash of the call to be made by the `real` account.",
"",
" # <weight>",
" Weight is a function of:",
" - A: the number of announcements made.",
" - P: the number of proxies the user has.",
" # </weight>"
]
},
{
"name": "reject_announcement",
"args": [
{
"name": "delegate",
"type": "AccountId"
},
{
"name": "call_hash",
"type": "CallHashOf"
}
],
"docs": [
" Remove the given announcement of a delegate.",
"",
" May be called by a target (proxied) account to remove a call that one of their delegates",
" (`delegate`) has announced they want to execute. The deposit is returned.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Parameters:",
" - `delegate`: The account that previously announced the call.",
" - `call_hash`: The hash of the call to be made.",
"",
" # <weight>",
" Weight is a function of:",
" - A: the number of announcements made.",
" - P: the number of proxies the user has.",
" # </weight>"
]
},
{
"name": "proxy_announced",
"args": [
{
"name": "delegate",
"type": "AccountId"
},
{
"name": "real",
"type": "AccountId"
},
{
"name": "force_proxy_type",
"type": "Option<ProxyType>"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Dispatch the given `call` from an account that the sender is authorized for through",
" `add_proxy`.",
"",
" Removes any corresponding announcement(s).",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Parameters:",
" - `real`: The account that the proxy will make a call on behalf of.",
" - `force_proxy_type`: Specify the exact proxy type to be used and checked for this call.",
" - `call`: The call to be made by the `real` account.",
"",
" # <weight>",
" Weight is a function of:",
" - A: the number of announcements made.",
" - P: the number of proxies the user has.",
" # </weight>"
]
}
],
"events": [
{
"name": "ProxyExecuted",
"args": [
"DispatchResult"
],
"docs": [
" A proxy was executed correctly, with the given \\[result\\]."
]
},
{
"name": "AnonymousCreated",
"args": [
"AccountId",
"AccountId",
"ProxyType",
"u16"
],
"docs": [
" Anonymous account has been created by new proxy with given",
" disambiguation index and proxy type. \\[anonymous, who, proxy_type,",
" disambiguation_index\\]"
]
},
{
"name": "Announced",
"args": [
"AccountId",
"AccountId",
"Hash"
],
"docs": [
" An announcement was placed to make a call in the future. \\[real, proxy, call_hash\\]"
]
},
{
"name": "ProxyAdded",
"args": [
"AccountId",
"AccountId",
"ProxyType",
"BlockNumber"
],
"docs": [
" A proxy was added. \\[delegator, delegatee, proxy_type, delay\\]"
]
}
],
"constants": [
{
"name": "ProxyDepositBase",
"type": "BalanceOf",
"value": "0x0084b2952e0000000000000000000000",
"docs": [
" The base amount of currency needed to reserve for creating a proxy.",
"",
" This is held for an additional storage item whose value size is",
" `sizeof(Balance)` bytes and whose key size is `sizeof(AccountId)` bytes."
]
},
{
"name": "ProxyDepositFactor",
"type": "BalanceOf",
"value": "0x8066ab13000000000000000000000000",
"docs": [
" The amount of currency needed per proxy added.",
"",
" This is held for adding 32 bytes plus an instance of `ProxyType` more into a",
" pre-existing storage value. Thus, when configuring `ProxyDepositFactor` one should take",
" into account `32 + proxy_type.encode().len()` bytes of data."
]
},
{
"name": "MaxProxies",
"type": "u32",
"value": "0x20000000",
"docs": [
" The maximum amount of proxies allowed for a single account."
]
},
{
"name": "MaxPending",
"type": "u32",
"value": "0x20000000",
"docs": [
" The maximum amount of time-delayed announcements that are allowed to be pending."
]
},
{
"name": "AnnouncementDepositBase",
"type": "BalanceOf",
"value": "0x0084b2952e0000000000000000000000",
"docs": [
" The base amount of currency needed to reserve for creating an announcement.",
"",
" This is held when a new storage item holding a `Balance` is created (typically 16",
" bytes)."
]
},
{
"name": "AnnouncementDepositFactor",
"type": "BalanceOf",
"value": "0x00cd5627000000000000000000000000",
"docs": [
" The amount of currency needed per announcement made.",
"",
" This is held for adding an `AccountId`, `Hash` and `BlockNumber` (typically 68 bytes)",
" into a pre-existing storage value."
]
}
],
"errors": [
{
"name": "TooMany",
"docs": [
" There are too many proxies registered or too many announcements pending."
]
},
{
"name": "NotFound",
"docs": [
" Proxy registration not found."
]
},
{
"name": "NotProxy",
"docs": [
" Sender is not a proxy of the account to be proxied."
]
},
{
"name": "Unproxyable",
"docs": [
" A call which is incompatible with the proxy type's filter was attempted."
]
},
{
"name": "Duplicate",
"docs": [
" Account is already a proxy."
]
},
{
"name": "NoPermission",
"docs": [
" Call may not be made by proxy because it may escalate its privileges."
]
},
{
"name": "Unannounced",
"docs": [
" Announcement, if made at all, was made too recently."
]
},
{
"name": "NoSelfProxy",
"docs": [
" Cannot add self as proxy."
]
}
],
"index": 29
},
{
"name": "Multisig",
"storage": {
"prefix": "Multisig",
"items": [
{
"name": "Multisigs",
"modifier": "Optional",
"type": {
"doubleMap": {
"hasher": "Twox64Concat",
"key1": "AccountId",
"key2": "[u8;32]",
"value": "Multisig",
"key2Hasher": "Blake2_128Concat"
}
},
"fallback": "0x00",
"docs": [
" The set of open multisig operations."
]
},
{
"name": "Calls",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "[u8;32]",
"value": "(OpaqueCall,AccountId,BalanceOf)",
"linked": false
}
},
"fallback": "0x00",
"docs": []
}
]
},
"calls": [
{
"name": "as_multi_threshold_1",
"args": [
{
"name": "other_signatories",
"type": "Vec<AccountId>"
},
{
"name": "call",
"type": "Call"
}
],
"docs": [
" Immediately dispatch a multi-signature call using a single approval from the caller.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `other_signatories`: The accounts (other than the sender) who are part of the",
" multi-signature, but do not participate in the approval process.",
" - `call`: The call to be executed.",
"",
" Result is equivalent to the dispatched result.",
"",
" # <weight>",
" O(Z + C) where Z is the length of the call and C its execution weight.",
" -------------------------------",
" - DB Weight: None",
" - Plus Call Weight",
" # </weight>"
]
},
{
"name": "as_multi",
"args": [
{
"name": "threshold",
"type": "u16"
},
{
"name": "other_signatories",
"type": "Vec<AccountId>"
},
{
"name": "maybe_timepoint",
"type": "Option<Timepoint>"
},
{
"name": "call",
"type": "OpaqueCall"
},
{
"name": "store_call",
"type": "bool"
},
{
"name": "max_weight",
"type": "Weight"
}
],
"docs": [
" Register approval for a dispatch to be made from a deterministic composite account if",
" approved by a total of `threshold - 1` of `other_signatories`.",
"",
" If there are enough, then dispatch the call.",
"",
" Payment: `DepositBase` will be reserved if this is the first approval, plus",
" `threshold` times `DepositFactor`. It is returned once this dispatch happens or",
" is cancelled.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `threshold`: The total number of approvals for this dispatch before it is executed.",
" - `other_signatories`: The accounts (other than the sender) who can approve this",
" dispatch. May not be empty.",
" - `maybe_timepoint`: If this is the first approval, then this must be `None`. If it is",
" not the first approval, then it must be `Some`, with the timepoint (block number and",
" transaction index) of the first approval transaction.",
" - `call`: The call to be executed.",
"",
" NOTE: Unless this is the final approval, you will generally want to use",
" `approve_as_multi` instead, since it only requires a hash of the call.",
"",
" Result is equivalent to the dispatched result if `threshold` is exactly `1`. Otherwise",
" on success, result is `Ok` and the result from the interior call, if it was executed,",
" may be found in the deposited `MultisigExecuted` event.",
"",
" # <weight>",
" - `O(S + Z + Call)`.",
" - Up to one balance-reserve or unreserve operation.",
" - One passthrough operation, one insert, both `O(S)` where `S` is the number of",
" signatories. `S` is capped by `MaxSignatories`, with weight being proportional.",
" - One call encode & hash, both of complexity `O(Z)` where `Z` is tx-len.",
" - One encode & hash, both of complexity `O(S)`.",
" - Up to one binary search and insert (`O(logS + S)`).",
" - I/O: 1 read `O(S)`, up to 1 mutate `O(S)`. Up to one remove.",
" - One event.",
" - The weight of the `call`.",
" - Storage: inserts one item, value size bounded by `MaxSignatories`, with a deposit",
" taken for its lifetime of `DepositBase + threshold * DepositFactor`.",
" -------------------------------",
" - DB Weight:",
" - Reads: Multisig Storage, [Caller Account], Calls (if `store_call`)",
" - Writes: Multisig Storage, [Caller Account], Calls (if `store_call`)",
" - Plus Call Weight",
" # </weight>"
]
},
{
"name": "approve_as_multi",
"args": [
{
"name": "threshold",
"type": "u16"
},
{
"name": "other_signatories",
"type": "Vec<AccountId>"
},
{
"name": "maybe_timepoint",
"type": "Option<Timepoint>"
},
{
"name": "call_hash",
"type": "[u8;32]"
},
{
"name": "max_weight",
"type": "Weight"
}
],
"docs": [
" Register approval for a dispatch to be made from a deterministic composite account if",
" approved by a total of `threshold - 1` of `other_signatories`.",
"",
" Payment: `DepositBase` will be reserved if this is the first approval, plus",
" `threshold` times `DepositFactor`. It is returned once this dispatch happens or",
" is cancelled.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `threshold`: The total number of approvals for this dispatch before it is executed.",
" - `other_signatories`: The accounts (other than the sender) who can approve this",
" dispatch. May not be empty.",
" - `maybe_timepoint`: If this is the first approval, then this must be `None`. If it is",
" not the first approval, then it must be `Some`, with the timepoint (block number and",
" transaction index) of the first approval transaction.",
" - `call_hash`: The hash of the call to be executed.",
"",
" NOTE: If this is the final approval, you will want to use `as_multi` instead.",
"",
" # <weight>",
" - `O(S)`.",
" - Up to one balance-reserve or unreserve operation.",
" - One passthrough operation, one insert, both `O(S)` where `S` is the number of",
" signatories. `S` is capped by `MaxSignatories`, with weight being proportional.",
" - One encode & hash, both of complexity `O(S)`.",
" - Up to one binary search and insert (`O(logS + S)`).",
" - I/O: 1 read `O(S)`, up to 1 mutate `O(S)`. Up to one remove.",
" - One event.",
" - Storage: inserts one item, value size bounded by `MaxSignatories`, with a deposit",
" taken for its lifetime of `DepositBase + threshold * DepositFactor`.",
" ----------------------------------",
" - DB Weight:",
" - Read: Multisig Storage, [Caller Account]",
" - Write: Multisig Storage, [Caller Account]",
" # </weight>"
]
},
{
"name": "cancel_as_multi",
"args": [
{
"name": "threshold",
"type": "u16"
},
{
"name": "other_signatories",
"type": "Vec<AccountId>"
},
{
"name": "timepoint",
"type": "Timepoint"
},
{
"name": "call_hash",
"type": "[u8;32]"
}
],
"docs": [
" Cancel a pre-existing, on-going multisig transaction. Any deposit reserved previously",
" for this operation will be unreserved on success.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" - `threshold`: The total number of approvals for this dispatch before it is executed.",
" - `other_signatories`: The accounts (other than the sender) who can approve this",
" dispatch. May not be empty.",
" - `timepoint`: The timepoint (block number and transaction index) of the first approval",
" transaction for this dispatch.",
" - `call_hash`: The hash of the call to be executed.",
"",
" # <weight>",
" - `O(S)`.",
" - Up to one balance-reserve or unreserve operation.",
" - One passthrough operation, one insert, both `O(S)` where `S` is the number of",
" signatories. `S` is capped by `MaxSignatories`, with weight being proportional.",
" - One encode & hash, both of complexity `O(S)`.",
" - One event.",
" - I/O: 1 read `O(S)`, one remove.",
" - Storage: removes one item.",
" ----------------------------------",
" - DB Weight:",
" - Read: Multisig Storage, [Caller Account], Refund Account, Calls",
" - Write: Multisig Storage, [Caller Account], Refund Account, Calls",
" # </weight>"
]
}
],
"events": [
{
"name": "NewMultisig",
"args": [
"AccountId",
"AccountId",
"CallHash"
],
"docs": [
" A new multisig operation has begun. \\[approving, multisig, call_hash\\]"
]
},
{
"name": "MultisigApproval",
"args": [
"AccountId",
"Timepoint",
"AccountId",
"CallHash"
],
"docs": [
" A multisig operation has been approved by someone.",
" \\[approving, timepoint, multisig, call_hash\\]"
]
},
{
"name": "MultisigExecuted",
"args": [
"AccountId",
"Timepoint",
"AccountId",
"CallHash",
"DispatchResult"
],
"docs": [
" A multisig operation has been executed. \\[approving, timepoint, multisig, call_hash\\]"
]
},
{
"name": "MultisigCancelled",
"args": [
"AccountId",
"Timepoint",
"AccountId",
"CallHash"
],
"docs": [
" A multisig operation has been cancelled. \\[cancelling, timepoint, multisig, call_hash\\]"
]
}
],
"constants": [
{
"name": "DepositBase",
"type": "BalanceOf",
"value": "0x008c61c52e0000000000000000000000",
"docs": [
" The base amount of currency needed to reserve for creating a multisig execution or to",
" store a dispatch call for later.",
"",
" This is held for an additional storage item whose value size is",
" `4 + sizeof((BlockNumber, Balance, AccountId))` bytes and whose key size is",
" `32 + sizeof(AccountId)` bytes."
]
},
{
"name": "DepositFactor",
"type": "BalanceOf",
"value": "0x00d01213000000000000000000000000",
"docs": [
" The amount of currency needed per unit threshold when creating a multisig execution.",
"",
" This is held for adding 32 bytes more into a pre-existing storage value."
]
},
{
"name": "MaxSignatories",
"type": "u16",
"value": "0x6400",
"docs": [
" The maximum amount of signatories allowed in the multisig."
]
}
],
"errors": [
{
"name": "MinimumThreshold",
"docs": [
" Threshold must be 2 or greater."
]
},
{
"name": "AlreadyApproved",
"docs": [
" Call is already approved by this signatory."
]
},
{
"name": "NoApprovalsNeeded",
"docs": [
" Call doesn't need any (more) approvals."
]
},
{
"name": "TooFewSignatories",
"docs": [
" There are too few signatories in the list."
]
},
{
"name": "TooManySignatories",
"docs": [
" There are too many signatories in the list."
]
},
{
"name": "SignatoriesOutOfOrder",
"docs": [
" The signatories were provided out of order; they should be ordered."
]
},
{
"name": "SenderInSignatories",
"docs": [
" The sender was contained in the other signatories; it shouldn't be."
]
},
{
"name": "NotFound",
"docs": [
" Multisig operation not found when attempting to cancel."
]
},
{
"name": "NotOwner",
"docs": [
" Only the account that originally created the multisig is able to cancel it."
]
},
{
"name": "NoTimepoint",
"docs": [
" No timepoint was given, yet the multisig operation is already underway."
]
},
{
"name": "WrongTimepoint",
"docs": [
" A different timepoint was given to the multisig operation that is underway."
]
},
{
"name": "UnexpectedTimepoint",
"docs": [
" A timepoint was given, yet no multisig operation is underway."
]
},
{
"name": "MaxWeightTooLow",
"docs": [
" The maximum weight information provided was too low."
]
},
{
"name": "AlreadyStored",
"docs": [
" The data to be stored is already stored."
]
}
],
"index": 30
},
{
"name": "Bounties",
"storage": {
"prefix": "Treasury",
"items": [
{
"name": "BountyCount",
"modifier": "Default",
"type": {
"plain": "BountyIndex"
},
"fallback": "0x00000000",
"docs": [
" Number of bounty proposals that have been made."
]
},
{
"name": "Bounties",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "BountyIndex",
"value": "Bounty",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Bounties that have been made."
]
},
{
"name": "BountyDescriptions",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "BountyIndex",
"value": "Bytes",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" The description of each bounty."
]
},
{
"name": "BountyApprovals",
"modifier": "Default",
"type": {
"plain": "Vec<BountyIndex>"
},
"fallback": "0x00",
"docs": [
" Bounty indices that have been approved but not yet funded."
]
}
]
},
"calls": [
{
"name": "propose_bounty",
"args": [
{
"name": "value",
"type": "Compact<BalanceOf>"
},
{
"name": "description",
"type": "Bytes"
}
],
"docs": [
" Propose a new bounty.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Payment: `TipReportDepositBase` will be reserved from the origin account, as well as",
" `DataDepositPerByte` for each byte in `reason`. It will be unreserved upon approval,",
" or slashed when rejected.",
"",
" - `curator`: The curator account whom will manage this bounty.",
" - `fee`: The curator fee.",
" - `value`: The total payment amount of this bounty, curator fee included.",
" - `description`: The description of this bounty."
]
},
{
"name": "approve_bounty",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
}
],
"docs": [
" Approve a bounty proposal. At a later time, the bounty will be funded and become active",
" and the original deposit will be returned.",
"",
" May only be called from `T::ApproveOrigin`.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "propose_curator",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
},
{
"name": "curator",
"type": "LookupSource"
},
{
"name": "fee",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Assign a curator to a funded bounty.",
"",
" May only be called from `T::ApproveOrigin`.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "unassign_curator",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
}
],
"docs": [
" Unassign curator from a bounty.",
"",
" This function can only be called by the `RejectOrigin` a signed origin.",
"",
" If this function is called by the `RejectOrigin`, we assume that the curator is malicious",
" or inactive. As a result, we will slash the curator when possible.",
"",
" If the origin is the curator, we take this as a sign they are unable to do their job and",
" they willingly give up. We could slash them, but for now we allow them to recover their",
" deposit and exit without issue. (We may want to change this if it is abused.)",
"",
" Finally, the origin can be anyone if and only if the curator is \"inactive\". This allows",
" anyone in the community to call out that a curator is not doing their due diligence, and",
" we should pick a new curator. In this case the curator should also be slashed.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "accept_curator",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
}
],
"docs": [
" Accept the curator role for a bounty.",
" A deposit will be reserved from curator and refund upon successful payout.",
"",
" May only be called from the curator.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "award_bounty",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
},
{
"name": "beneficiary",
"type": "LookupSource"
}
],
"docs": [
" Award bounty to a beneficiary account. The beneficiary will be able to claim the funds after a delay.",
"",
" The dispatch origin for this call must be the curator of this bounty.",
"",
" - `bounty_id`: Bounty ID to award.",
" - `beneficiary`: The beneficiary account whom will receive the payout.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "claim_bounty",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
}
],
"docs": [
" Claim the payout from an awarded bounty after payout delay.",
"",
" The dispatch origin for this call must be the beneficiary of this bounty.",
"",
" - `bounty_id`: Bounty ID to claim.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "close_bounty",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
}
],
"docs": [
" Cancel a proposed or active bounty. All the funds will be sent to treasury and",
" the curator deposit will be unreserved if possible.",
"",
" Only `T::RejectOrigin` is able to cancel a bounty.",
"",
" - `bounty_id`: Bounty ID to cancel.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
},
{
"name": "extend_bounty_expiry",
"args": [
{
"name": "bounty_id",
"type": "Compact<BountyIndex>"
},
{
"name": "_remark",
"type": "Bytes"
}
],
"docs": [
" Extend the expiry time of an active bounty.",
"",
" The dispatch origin for this call must be the curator of this bounty.",
"",
" - `bounty_id`: Bounty ID to extend.",
" - `remark`: additional information.",
"",
" # <weight>",
" - O(1).",
" # </weight>"
]
}
],
"events": [
{
"name": "BountyProposed",
"args": [
"BountyIndex"
],
"docs": [
" New bounty proposal. \\[index\\]"
]
},
{
"name": "BountyRejected",
"args": [
"BountyIndex",
"Balance"
],
"docs": [
" A bounty proposal was rejected; funds were slashed. \\[index, bond\\]"
]
},
{
"name": "BountyBecameActive",
"args": [
"BountyIndex"
],
"docs": [
" A bounty proposal is funded and became active. \\[index\\]"
]
},
{
"name": "BountyAwarded",
"args": [
"BountyIndex",
"AccountId"
],
"docs": [
" A bounty is awarded to a beneficiary. \\[index, beneficiary\\]"
]
},
{
"name": "BountyClaimed",
"args": [
"BountyIndex",
"Balance",
"AccountId"
],
"docs": [
" A bounty is claimed by beneficiary. \\[index, payout, beneficiary\\]"
]
},
{
"name": "BountyCanceled",
"args": [
"BountyIndex"
],
"docs": [
" A bounty is cancelled. \\[index\\]"
]
},
{
"name": "BountyExtended",
"args": [
"BountyIndex"
],
"docs": [
" A bounty expiry is extended. \\[index\\]"
]
}
],
"constants": [
{
"name": "DataDepositPerByte",
"type": "BalanceOf",
"value": "0x00e1f505000000000000000000000000",
"docs": [
" The amount held on deposit per byte within bounty description."
]
},
{
"name": "BountyDepositBase",
"type": "BalanceOf",
"value": "0x00e40b54020000000000000000000000",
"docs": [
" The amount held on deposit for placing a bounty proposal."
]
},
{
"name": "BountyDepositPayoutDelay",
"type": "BlockNumber",
"value": "0x00c20100",
"docs": [
" The delay period for which a bounty beneficiary need to wait before claim the payout."
]
},
{
"name": "BountyUpdatePeriod",
"type": "BlockNumber",
"value": "0x80c61300",
"docs": [
" Bounty duration in blocks."
]
},
{
"name": "BountyCuratorDeposit",
"type": "Permill",
"value": "0x20a10700",
"docs": [
" Percentage of the curator fee that will be reserved upfront as deposit for bounty curator."
]
},
{
"name": "BountyValueMinimum",
"type": "BalanceOf",
"value": "0x00e87648170000000000000000000000",
"docs": [
" Minimum value for a bounty."
]
},
{
"name": "MaximumReasonLength",
"type": "u32",
"value": "0x00400000",
"docs": [
" Maximum acceptable reason length."
]
}
],
"errors": [
{
"name": "InsufficientProposersBalance",
"docs": [
" Proposer's balance is too low."
]
},
{
"name": "InvalidIndex",
"docs": [
" No proposal or bounty at that index."
]
},
{
"name": "ReasonTooBig",
"docs": [
" The reason given is just too big."
]
},
{
"name": "UnexpectedStatus",
"docs": [
" The bounty status is unexpected."
]
},
{
"name": "RequireCurator",
"docs": [
" Require bounty curator."
]
},
{
"name": "InvalidValue",
"docs": [
" Invalid bounty value."
]
},
{
"name": "InvalidFee",
"docs": [
" Invalid bounty fee."
]
},
{
"name": "PendingPayout",
"docs": [
" A bounty payout is pending.",
" To cancel the bounty, you must unassign and slash the curator."
]
},
{
"name": "Premature",
"docs": [
" The bounties cannot be claimed/closed because it's still in the countdown period."
]
}
],
"index": 34
},
{
"name": "Tips",
"storage": {
"prefix": "Tips",
"items": [
{
"name": "Tips",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "Hash",
"value": "OpenTip",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" TipsMap that are not yet completed. Keyed by the hash of `(reason, who)` from the value.",
" This has the insecure enumerable hash function since the key itself is already",
" guaranteed to be a secure hash."
]
},
{
"name": "Reasons",
"modifier": "Optional",
"type": {
"map": {
"hasher": "Identity",
"key": "Hash",
"value": "Bytes",
"linked": false
}
},
"fallback": "0x00",
"docs": [
" Simple preimage lookup from the reason's hash to the original data. Again, has an",
" insecure enumerable hash since the key is guaranteed to be the result of a secure hash."
]
}
]
},
"calls": [
{
"name": "report_awesome",
"args": [
{
"name": "reason",
"type": "Bytes"
},
{
"name": "who",
"type": "AccountId"
}
],
"docs": [
" Report something `reason` that deserves a tip and claim any eventual the finder's fee.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" Payment: `TipReportDepositBase` will be reserved from the origin account, as well as",
" `DataDepositPerByte` for each byte in `reason`.",
"",
" - `reason`: The reason for, or the thing that deserves, the tip; generally this will be",
" a UTF-8-encoded URL.",
" - `who`: The account which should be credited for the tip.",
"",
" Emits `NewTip` if successful.",
"",
" # <weight>",
" - Complexity: `O(R)` where `R` length of `reason`.",
" - encoding and hashing of 'reason'",
" - DbReads: `Reasons`, `Tips`",
" - DbWrites: `Reasons`, `Tips`",
" # </weight>"
]
},
{
"name": "retract_tip",
"args": [
{
"name": "hash",
"type": "Hash"
}
],
"docs": [
" Retract a prior tip-report from `report_awesome`, and cancel the process of tipping.",
"",
" If successful, the original deposit will be unreserved.",
"",
" The dispatch origin for this call must be _Signed_ and the tip identified by `hash`",
" must have been reported by the signing account through `report_awesome` (and not",
" through `tip_new`).",
"",
" - `hash`: The identity of the open tip for which a tip value is declared. This is formed",
" as the hash of the tuple of the original tip `reason` and the beneficiary account ID.",
"",
" Emits `TipRetracted` if successful.",
"",
" # <weight>",
" - Complexity: `O(1)`",
" - Depends on the length of `T::Hash` which is fixed.",
" - DbReads: `Tips`, `origin account`",
" - DbWrites: `Reasons`, `Tips`, `origin account`",
" # </weight>"
]
},
{
"name": "tip_new",
"args": [
{
"name": "reason",
"type": "Bytes"
},
{
"name": "who",
"type": "AccountId"
},
{
"name": "tip_value",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Give a tip for something new; no finder's fee will be taken.",
"",
" The dispatch origin for this call must be _Signed_ and the signing account must be a",
" member of the `Tippers` set.",
"",
" - `reason`: The reason for, or the thing that deserves, the tip; generally this will be",
" a UTF-8-encoded URL.",
" - `who`: The account which should be credited for the tip.",
" - `tip_value`: The amount of tip that the sender would like to give. The median tip",
" value of active tippers will be given to the `who`.",
"",
" Emits `NewTip` if successful.",
"",
" # <weight>",
" - Complexity: `O(R + T)` where `R` length of `reason`, `T` is the number of tippers.",
" - `O(T)`: decoding `Tipper` vec of length `T`. `T` is charged as upper bound given by",
" `ContainsLengthBound`. The actual cost depends on the implementation of",
" `T::Tippers`.",
" - `O(R)`: hashing and encoding of reason of length `R`",
" - DbReads: `Tippers`, `Reasons`",
" - DbWrites: `Reasons`, `Tips`",
" # </weight>"
]
},
{
"name": "tip",
"args": [
{
"name": "hash",
"type": "Hash"
},
{
"name": "tip_value",
"type": "Compact<BalanceOf>"
}
],
"docs": [
" Declare a tip value for an already-open tip.",
"",
" The dispatch origin for this call must be _Signed_ and the signing account must be a",
" member of the `Tippers` set.",
"",
" - `hash`: The identity of the open tip for which a tip value is declared. This is formed",
" as the hash of the tuple of the hash of the original tip `reason` and the beneficiary",
" account ID.",
" - `tip_value`: The amount of tip that the sender would like to give. The median tip",
" value of active tippers will be given to the `who`.",
"",
" Emits `TipClosing` if the threshold of tippers has been reached and the countdown period",
" has started.",
"",
" # <weight>",
" - Complexity: `O(T)` where `T` is the number of tippers. decoding `Tipper` vec of length",
" `T`, insert tip and check closing, `T` is charged as upper bound given by",
" `ContainsLengthBound`. The actual cost depends on the implementation of `T::Tippers`.",
"",
" Actually weight could be lower as it depends on how many tips are in `OpenTip` but it",
" is weighted as if almost full i.e of length `T-1`.",
" - DbReads: `Tippers`, `Tips`",
" - DbWrites: `Tips`",
" # </weight>"
]
},
{
"name": "close_tip",
"args": [
{
"name": "hash",
"type": "Hash"
}
],
"docs": [
" Close and payout a tip.",
"",
" The dispatch origin for this call must be _Signed_.",
"",
" The tip identified by `hash` must have finished its countdown period.",
"",
" - `hash`: The identity of the open tip for which a tip value is declared. This is formed",
" as the hash of the tuple of the original tip `reason` and the beneficiary account ID.",
"",
" # <weight>",
" - Complexity: `O(T)` where `T` is the number of tippers. decoding `Tipper` vec of length",
" `T`. `T` is charged as upper bound given by `ContainsLengthBound`. The actual cost",
" depends on the implementation of `T::Tippers`.",
" - DbReads: `Tips`, `Tippers`, `tip finder`",
" - DbWrites: `Reasons`, `Tips`, `Tippers`, `tip finder`",
" # </weight>"
]
},
{
"name": "slash_tip",
"args": [
{
"name": "hash",
"type": "Hash"
}
],
"docs": [
" Remove and slash an already-open tip.",
"",
" May only be called from `T::RejectOrigin`.",
"",
" As a result, the finder is slashed and the deposits are lost.",
"",
" Emits `TipSlashed` if successful.",
"",
" # <weight>",
" `T` is charged as upper bound given by `ContainsLengthBound`.",
" The actual cost depends on the implementation of `T::Tippers`.",
" # </weight>"
]
}
],
"events": [
{
"name": "NewTip",
"args": [
"Hash"
],
"docs": [
" A new tip suggestion has been opened. \\[tip_hash\\]"
]
},
{
"name": "TipClosing",
"args": [
"Hash"
],
"docs": [
" A tip suggestion has reached threshold and is closing. \\[tip_hash\\]"
]
},
{
"name": "TipClosed",
"args": [
"Hash",
"AccountId",
"Balance"
],
"docs": [
" A tip suggestion has been closed. \\[tip_hash, who, payout\\]"
]
},
{
"name": "TipRetracted",
"args": [
"Hash"
],
"docs": [
" A tip suggestion has been retracted. \\[tip_hash\\]"
]
},
{
"name": "TipSlashed",
"args": [
"Hash",
"AccountId",
"Balance"
],
"docs": [
" A tip suggestion has been slashed. \\[tip_hash, finder, deposit\\]"
]
}
],
"constants": [
{
"name": "MaximumReasonLength",
"type": "u32",
"value": "0x00400000",
"docs": [
" Maximum acceptable reason length."
]
},
{
"name": "DataDepositPerByte",
"type": "BalanceOf",
"value": "0x00e1f505000000000000000000000000",
"docs": [
" The amount held on deposit per byte within the tip report reason or bounty description."
]
},
{
"name": "TipCountdown",
"type": "BlockNumber",
"value": "0x40380000",
"docs": [
" The period for which a tip remains open after is has achieved threshold tippers."
]
},
{
"name": "TipFindersFee",
"type": "Percent",
"value": "0x14",
"docs": [
" The percent of the final tip which goes to the original reporter of the tip."
]
},
{
"name": "TipReportDepositBase",
"type": "BalanceOf",
"value": "0x00e40b54020000000000000000000000",
"docs": [
" The amount held on deposit for placing a tip report."
]
}
],
"errors": [
{
"name": "ReasonTooBig",
"docs": [
" The reason given is just too big."
]
},
{
"name": "AlreadyKnown",
"docs": [
" The tip was already found/started."
]
},
{
"name": "UnknownTip",
"docs": [
" The tip hash is unknown."
]
},
{
"name": "NotFinder",
"docs": [
" The account attempting to retract the tip is not the finder of the tip."
]
},
{
"name": "StillOpen",
"docs": [
" The tip cannot be claimed/closed because there are not enough tippers yet."
]
},
{
"name": "Premature",
"docs": [
" The tip cannot be claimed/closed because it's still in the countdown period."
]
}
],
"index": 35
},
{
"name": "ElectionProviderMultiPhase",
"storage": {
"prefix": "ElectionProviderMultiPhase",
"items": [
{
"name": "Round",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x01000000",
"docs": [
" Internal counter for the number of rounds.",
"",
" This is useful for de-duplication of transactions submitted to the pool, and general",
" diagnostics of the pallet.",
"",
" This is merely incremented once per every time that an upstream `elect` is called."
]
},
{
"name": "CurrentPhase",
"modifier": "Default",
"type": {
"plain": "ElectionPhase"
},
"fallback": "0x00",
"docs": [
" Current phase."
]
},
{
"name": "QueuedSolution",
"modifier": "Optional",
"type": {
"plain": "ReadySolution"
},
"fallback": "0x00",
"docs": [
" Current best solution, signed or unsigned, queued to be returned upon `elect`."
]
},
{
"name": "Snapshot",
"modifier": "Optional",
"type": {
"plain": "RoundSnapshot"
},
"fallback": "0x00",
"docs": [
" Snapshot data of the round.",
"",
" This is created at the beginning of the signed phase and cleared upon calling `elect`."
]
},
{
"name": "DesiredTargets",
"modifier": "Optional",
"type": {
"plain": "u32"
},
"fallback": "0x00",
"docs": [
" Desired number of targets to elect for this round.",
"",
" Only exists when [`Snapshot`] is present."
]
},
{
"name": "SnapshotMetadata",
"modifier": "Optional",
"type": {
"plain": "SolutionOrSnapshotSize"
},
"fallback": "0x00",
"docs": [
" The metadata of the [`RoundSnapshot`]",
"",
" Only exists when [`Snapshot`] is present."
]
},
{
"name": "SignedSubmissionNextIndex",
"modifier": "Default",
"type": {
"plain": "u32"
},
"fallback": "0x00000000",
"docs": [
" The next index to be assigned to an incoming signed submission.",
"",
" Every accepted submission is assigned a unique index; that index is bound to that particular",
" submission for the duration of the election. On election finalization, the next index is",
" reset to 0.",
"",
" We can't just use `SignedSubmissionIndices.len()`, because that's a bounded set; past its",
" capacity, it will simply saturate. We can't just iterate over `SignedSubmissionsMap`,",
" because iteration is slow. Instead, we store the value here."
]
},
{
"name": "SignedSubmissionIndices",
"modifier": "Default",
"type": {
"plain": "SubmissionIndicesOf"
},
"fallback": "0x00",
"docs": [
" A sorted, bounded set of `(score, index)`, where each `index` points to a value in",
" `SignedSubmissions`.",
"",
" We never need to process more than a single signed submission at a time. Signed submissions",
" can be quite large, so we're willing to pay the cost of multiple database accesses to access",
" them one at a time instead of reading and decoding all of them at once."
]
},
{
"name": "SignedSubmissionsMap",
"modifier": "Default",
"type": {
"map": {
"hasher": "Twox64Concat",
"key": "u32",
"value": "SignedSubmissionOf",
"linked": false
}
},
"fallback": "0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000",
"docs": [
" Unchecked, signed solutions.",
"",
" Together with `SubmissionIndices`, this stores a bounded set of `SignedSubmissions` while",
" allowing us to keep only a single one in memory at a time.",
"",
" Twox note: the key of the map is an auto-incrementing index which users cannot inspect or",
" affect; we shouldn't need a cryptographically secure hasher."
]
},
{
"name": "MinimumUntrustedScore",
"modifier": "Optional",
"type": {
"plain": "ElectionScore"
},
"fallback": "0x00",
"docs": [
" The minimum score that each 'untrusted' solution must attain in order to be considered",
" feasible.",
"",
" Can be set via `set_minimum_untrusted_score`."
]
}
]
},
"calls": [
{
"name": "submit_unsigned",
"args": [
{
"name": "raw_solution",
"type": "RawSolution"
},
{
"name": "witness",
"type": "SolutionOrSnapshotSize"
}
],
"docs": [
" Submit a solution for the unsigned phase.",
"",
" The dispatch origin fo this call must be __none__.",
"",
" This submission is checked on the fly. Moreover, this unsigned solution is only",
" validated when submitted to the pool from the **local** node. Effectively, this means",
" that only active validators can submit this transaction when authoring a block (similar",
" to an inherent).",
"",
" To prevent any incorrect solution (and thus wasted time/weight), this transaction will",
" panic if the solution submitted by the validator is invalid in any way, effectively",
" putting their authoring reward at risk.",
"",
" No deposit or reward is associated with this submission."
]
},
{
"name": "set_minimum_untrusted_score",
"args": [
{
"name": "maybe_next_score",
"type": "Option<ElectionScore>"
}
],
"docs": [
" Set a new value for `MinimumUntrustedScore`.",
"",
" Dispatch origin must be aligned with `T::ForceOrigin`.",
"",
" This check can be turned off by setting the value to `None`."
]
},
{
"name": "set_emergency_election_result",
"args": [
{
"name": "supports",
"type": "Supports"
}
],
"docs": [
" Set a solution in the queue, to be handed out to the client of this pallet in the next",
" call to `ElectionProvider::elect`.",
"",
" This can only be set by `T::ForceOrigin`, and only when the phase is `Emergency`.",
"",
" The solution is not checked for any feasibility and is assumed to be trustworthy, as any",
" feasibility check itself can in principle cause the election process to fail (due to",
" memory/weight constrains)."
]
},
{
"name": "submit",
"args": [
{
"name": "raw_solution",
"type": "RawSolution"
},
{
"name": "num_signed_submissions",
"type": "u32"
}
],
"docs": [
" Submit a solution for the signed phase.",
"",
" The dispatch origin fo this call must be __signed__.",
"",
" The solution is potentially queued, based on the claimed score and processed at the end",
" of the signed phase.",
"",
" A deposit is reserved and recorded for the solution. Based on the outcome, the solution",
" might be rewarded, slashed, or get all or a part of the deposit back.",
"",
" # <weight>",
" Queue size must be provided as witness data.",
" # </weight>"
]
}
],
"events": [
{
"name": "SolutionStored",
"args": [
"ElectionCompute",
"bool"
],
"docs": [
" A solution was stored with the given compute.",
"",
" If the solution is signed, this means that it hasn't yet been processed. If the",
" solution is unsigned, this means that it has also been processed.",
"",
" The `bool` is `true` when a previous solution was ejected to make room for this one."
]
},
{
"name": "ElectionFinalized",
"args": [
"Option<ElectionCompute>"
],
"docs": [
" The election has been finalized, with `Some` of the given computation, or else if the",
" election failed, `None`."
]
},
{
"name": "Rewarded",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account has been rewarded for their signed submission being finalized."
]
},
{
"name": "Slashed",
"args": [
"AccountId",
"Balance"
],
"docs": [
" An account has been slashed for submitting an invalid signed submission."
]
},
{
"name": "SignedPhaseStarted",
"args": [
"u32"
],
"docs": [
" The signed phase of the given round has started."
]
},
{
"name": "UnsignedPhaseStarted",
"args": [
"u32"
],
"docs": [
" The unsigned phase of the given round has started."
]
}
],
"constants": [
{
"name": "UnsignedPhase",
"type": "BlockNumber",
"value": "0x58020000",
"docs": [
" Duration of the unsigned phase."
]
},
{
"name": "SignedPhase",
"type": "BlockNumber",
"value": "0x58020000",
"docs": [
" Duration of the signed phase."
]
},
{
"name": "SolutionImprovementThreshold",
"type": "Perbill",
"value": "0x20a10700",
"docs": [
" The minimum amount of improvement to the solution score that defines a solution as",
" \"better\" (in any phase)."
]
},
{
"name": "OffchainRepeat",
"type": "BlockNumber",
"value": "0x05000000",
"docs": [
" The repeat threshold of the offchain worker.",
"",
" For example, if it is 5, that means that at least 5 blocks will elapse between attempts",
" to submit the worker's solution."
]
},
{
"name": "MinerTxPriority",
"type": "TransactionPriority",
"value": "0x65666666666666e6",
"docs": [
" The priority of the unsigned transaction submitted in the unsigned-phase"
]
},
{
"name": "MinerMaxWeight",
"type": "Weight",
"value": "0xc084666557010000",
"docs": [
" Maximum weight that the miner should consume.",
"",
" The miner will ensure that the total weight of the unsigned solution will not exceed",
" this value, based on [`WeightInfo::submit_unsigned`]."
]
},
{
"name": "SignedMaxSubmissions",
"type": "u32",
"value": "0x10000000",
"docs": [
" Maximum number of signed submissions that can be queued.",
"",
" It is best to avoid adjusting this during an election, as it impacts downstream data",
" structures. In particular, `SignedSubmissionIndices<T>` is bounded on this value. If you",
" update this value during an election, you _must_ ensure that",
" `SignedSubmissionIndices.len()` is less than or equal to the new value. Otherwise,",
" attempts to submit new solutions may cause a runtime panic."
]
},
{
"name": "SignedMaxWeight",
"type": "Weight",
"value": "0xc084666557010000",
"docs": [
" Maximum weight of a signed solution.",
"",
" This should probably be similar to [`Config::MinerMaxWeight`]."
]
},
{
"name": "SignedRewardBase",
"type": "BalanceOf",
"value": "0x00e40b54020000000000000000000000",
"docs": [
" Base reward for a signed solution"
]
},
{
"name": "SignedDepositBase",
"type": "BalanceOf",
"value": "0x00a0db215d0000000000000000000000",
"docs": [
" Base deposit for a signed solution."
]
},
{
"name": "SignedDepositByte",
"type": "BalanceOf",
"value": "0x787d0100000000000000000000000000",
"docs": [
" Per-byte deposit for a signed solution."
]
},
{
"name": "SignedDepositWeight",
"type": "BalanceOf",
"value": "0x00000000000000000000000000000000",
"docs": [
" Per-weight deposit for a signed solution."
]
},
{
"name": "MinerMaxLength",
"type": "u32",
"value": "0x00003600",
"docs": [
" Maximum length (bytes) that the mined solution should consume.",
"",
" The miner will ensure that the total length of the unsigned solution will not exceed",
" this value."
]
}
],
"errors": [
{
"name": "PreDispatchEarlySubmission",
"docs": [
" Submission was too early."
]
},
{
"name": "PreDispatchWrongWinnerCount",
"docs": [
" Wrong number of winners presented."
]
},
{
"name": "PreDispatchWeakSubmission",
"docs": [
" Submission was too weak, score-wise."
]
},
{
"name": "SignedQueueFull",
"docs": [
" The queue was full, and the solution was not better than any of the existing ones."
]
},
{
"name": "SignedCannotPayDeposit",
"docs": [
" The origin failed to pay the deposit."
]
},
{
"name": "SignedInvalidWitness",
"docs": [
" Witness data to dispatchable is invalid."
]
},
{
"name": "SignedTooMuchWeight",
"docs": [
" The signed submission consumes too much weight"
]
},
{
"name": "OcwCallWrongEra",
"docs": [
" OCW submitted solution for wrong round"
]
},
{
"name": "MissingSnapshotMetadata",
"docs": [
" Snapshot metadata should exist but didn't."
]
},
{
"name": "InvalidSubmissionIndex",
"docs": [
" `Self::insert_submission` returned an invalid index."
]
},
{
"name": "CallNotAllowed",
"docs": [
" The call is not allowed at this point."
]
}
],
"index": 36
}
],
"extrinsic": {
"version": 4,
"signedExtensions": [
"CheckSpecVersion",
"CheckTxVersion",
"CheckGenesis",
"CheckMortality",
"CheckNonce",
"CheckWeight",
"ChargeTransactionPayment",
"PrevalidateAttests"
]
}
}
}
}