1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#![cfg_attr(not(feature = "std"), no_std)]
#![allow(clippy::too_many_arguments)]
#![allow(clippy::unnecessary_mut_passed)]
#![allow(rustdoc::bare_urls)]
// Strong Documentation Lints
#![deny(
	rustdoc::broken_intra_doc_links,
	rustdoc::missing_crate_level_docs,
	rustdoc::invalid_codeblock_attributes,
	missing_docs
)]

//! Runtime API definition for [Stateful  Storage](../pallet_stateful_storage/index.html)
//!
//! This api must be implemented by the node runtime.
//! Runtime APIs Provide:
//! - An interface between the runtime and Custom RPCs.
//! - Runtime interfaces for end users beyond just State Queries

use common_primitives::{
	handles::{
		BaseHandle, CheckHandleResponse, DisplayHandle, HandleResponse, PresumptiveSuffixesResponse,
	},
	msa::MessageSourceId,
};

// Here we declare the runtime API. It is implemented it the `impl` block in
// runtime files (the `runtime` folder)
sp_api::decl_runtime_apis! {

	/// Runtime Version for Handles
	/// - MUST be incremented if anything changes
	/// - See: https://paritytech.github.io/polkadot/doc/polkadot_primitives/runtime_api/index.html
	#[api_version(2)]

	/// Runtime APIs for [Handles](../pallet_handles/index.html)
	pub trait HandlesRuntimeApi
	{
		/// Retrieve handle for a particular msa
		fn get_handle_for_msa(msa_id: MessageSourceId) -> Option<HandleResponse>;

		/// Retrieve the next `n` suffixes for a given handle
		fn get_next_suffixes(base_handle: BaseHandle, count: u16) -> PresumptiveSuffixesResponse;

		/// Retrieve msa for a particular handle
		fn get_msa_for_handle(display_handle: DisplayHandle) -> Option<MessageSourceId>;

		/// Check if a handle is valid
		fn validate_handle(base_handle: BaseHandle) -> bool;

		#[api_version(3)]
		/// Return information about a given handle
		fn check_handle(base_handle: BaseHandle) -> CheckHandleResponse;
	}
}