ckb-ssri-std
[EN/CN] Script-Sourced Rich Information - 来源于 Script 的富信息: General introduction to SSRI.
ssri-test
: First prototype of SSRI-Compliant contract.
ssri-server
: Server for calling SSRI methods.
Quick Note on SSRI
- SSRI stands for
Script Sourced Rich Information
; it is a protocol for strong bindings of relevant information and conventions to the Script itself on CKB. For more information, please read [EN/CN] Script-Sourced Rich Information - 来源于 Script 的富信息>. - Such bindings would take place in a progressive pattern:
- In the current coding paradigms for all contracts in production, testing, or active development, (or specifically, in Stage 1), the CKB smart contract being SSRI-Compliant would help us:
- In the typical scenario of validating transactions, by specifically using Rust Traits, we recognize the purpose (or more specifically, the
Intent
of running the script) (e.g.,minting UDT
,transferring
) and build relevant validation logics within the scope of the corresponding method. - On the level of reading and organizing contract code, by selectively implementing methods of public module traits (e.g.
UDT
,UDTExtended
,UDTPausable
) in combinations, generic users and devs would be able to quickly understand and organize functionalities of contracts as well as the relevant adaptations / integrations in dApps , especially in use cases involving multiple distinct contracts (and very likely from different projects) within same transactions.
- In the typical scenario of validating transactions, by specifically using Rust Traits, we recognize the purpose (or more specifically, the
- In the current coding paradigms for all contracts in production, testing, or active development, (or specifically, in Stage 1), the CKB smart contract being SSRI-Compliant would help us:
Goals of ckb-ssri-std
- Easier and intuitive implementations and built-in integration support (e.g.
CCC
andckb_ssri_cli
) of SSRI public traits. - Easier and intuitive definitions of customized SSRI traits.
- TODO: Unified entry function;
- Scrip-Sourced code sharing for on-chain verification, off-chain query/integration, and off-chain transaction generations/completions.
Usage
- TODO: SSRI-Compliant Smart Contract Code would have an identifier Type that also implements TypeID mechanism. Please use
ckb-cinnabar
for easier deployment and migration. - SSRI-Compliant Smart Contract would use the unified entry function to run the script and call the exposed methods by specifying the path at
argv[0]
and the arguments atargv[1..]
.- The default namespace is
SSRI
which consists of:SSRI.version() -> u8
SSRI.get_methods(offset: u64, limit: u64) -> Vec<Bytes8>
SSRI.has_methods(methods: Vec<Bytes8>) -> Vec<bool>
- TODO: By using the
#[ssri_module]
macro and#[ssri_method]
attribute, methods can be automatically exposed in the namespace defined by trait name.
- The default namespace is
- By implementing traits from
ckb_ssri_std::public_module_traits
in the SSRI-Compliant Smart Contract, infrastructures would be able to provide richer information off-chain as well for all kinds of purposes based on the SSRI protocol.
Example Contract
pausable-udt
is a real production level contract (instead of a pseudo-project) that exemplifies the usage of SSRI.
[ ] TODO: Defining a SSRI Module with proc-macros
and Implement SSRI Traits
#[ssri_module]
- version: implement a method to get the version of the SSRI module.
#[ssri_method]
- By default, all of the following flags are set to false or empty;
- 'level={ExecutionEnvironmentLevel}': This method can only be run when the execution environment level is above or equal to the specified level;
- 'transaction=true': Will return a transaction object of molecule
struct
that can be sent to directly to RPC. If transaction is set to true, the required level is automatically set to Chain; - 'internal=true': This method is not exposed through SSRI, but it's a dependency for other methods;
Defining a SSRI Public Module Trait
Deployment and Migration
- Deploy and upgrade with ckb-cinnabar for easier deployment and migration with Type ID.
ckb-cinnabar deploy --contract-name pausable-udt --tag transaction.v241112 --payer-address ckt1qzda0cr08m85hc8jlnfp3zer7xulejywt49kt2rr0vthywaa50xwsqtxe0gs9yvwrsc40znvdc6sg4fehd2mttsngg4t4 --type-id
ckb-cinnabar migrate --contract-name pausable-udt --from-tag v241030.1 --to-tag v241030.2
Interacting with SSRI-Compliant Contracts
With SSRI-server and SSRI-VM, users, devs, and admins would have the ability to obtain Script-Source Rich Information directly from the script by calling SSRI methods via SSRI-server (which can be both run locally and for public usage).
The returned information can be just data for display, or a transaction object that can be sent to a CKB RPC, without the need of extra implementations on either dApps or backend applications.
ckb_ssri_cli
Testing
Due to the limitations of ckb_testtools
, it is recommended to test the same SSRI-Compliant Contract on two level:
- On-chain Verification: Test with
ckb_testtools
- Off-chain Query/Integration, Transaction Generations/Completions: Test with
ckb_ssri_cli
against the latest deployment.
Key Concepts
Execution Environment Levels
- Code: If only the code hash is provided, the execution environment level is Code;
- Script: If the code hash and args are both provided, the execution environment level is Script;
- Cell: If the CellInput / Outpoint is provided, the execution environment level is Cell;
- Transaction: If the Transaction Hash is provided, the execution environment level is Transaction; This is also the level of execution environment for regular CKB-VM when submitting transaction;