Prad Nukala 0ec2f7d86a
feature/1214 session fetch refactor (#1215)
* chore(docs): remove token economy guide

* refactor(context): update GatewayContext to use Querier interface

* chore(database): update schema path

* docs: Update READMEs for x/did, x/dwn, and x/svc with UCAN integration

* chore(pkg): update database scope name

* refactor(did): optimize GenesisState proto methods

* refactor(svc): update Service proto to use repeated fields

* refactor(api): rename MsgSpawn to MsgInitialize
2024-12-24 15:38:17 +00:00
..

x/dwn

The DWN module is responsible for the management of IPFS deployed Decentralized Web Nodes (DWNs) and their associated data. This module now incorporates UCAN (User Controlled Authorization Networks) for enhanced authorization and access control.

Concepts

The DWN module introduces several key concepts:

  1. Decentralized Web Node (DWN): A distributed network for storing and sharing data.
  2. Schema: A structure defining the format of various data types in the dwn.
  3. IPFS Integration: The module can interact with IPFS for decentralized data storage.
  4. UCAN Authorization: The module utilizes UCANs for a decentralized and user-centric authorization mechanism.

State

The DWN module maintains the following state:

DWN State

The DWN state is stored using the following structure:

message DWN {
  uint64 id = 1;
  string alias = 2;
  string cid = 3;
  string resolver = 4;
}

This state is indexed by ID, alias, and CID for efficient querying.

Params State

The module parameters are stored in the following structure:

message Params {
  bool ipfs_active = 1;
  bool local_registration_enabled = 2;
  Schema schema = 4;
  repeated string allowed_operators = 5;
}

Schema State

The Schema state defines the structure for various data types:

message Schema {
  int32 version = 1;
  string account = 2;
  string asset = 3;
  string chain = 4;
  string credential = 5;
  string did = 6;
  string jwk = 7;
  string grant = 8;
  string keyshare = 9;
  string profile = 10;
}

State Transitions

State transitions in the DWN module are primarily triggered by:

  1. Updating module parameters (including UCAN-related parameters)
  2. Allocating new dwns (with UCAN authorization checks)
  3. Syncing DID documents (with UCAN authorization checks)

Messages

The DWN module defines the following message:

  1. MsgUpdateParams: Used to update the module parameters, including UCAN permissions.
message MsgUpdateParams {
  string authority = 1;
  Params params = 2;
}

Begin Block

No specific begin-block operations are defined for this module.

End Block

No specific end-block operations are defined for this module.

UCAN Authorization

This module utilizes UCAN (User Controlled Authorization Networks) to provide a decentralized and user-centric authorization mechanism. UCANs are self-contained authorization tokens that allow users to delegate specific capabilities to other entities without relying on a central authority.

UCAN Integration

  • The module parameters include a UcanPermissions field that defines the default UCAN permissions required for actions within the module, such as allocating new DWNs or syncing DID documents.
  • Message handlers in the MsgServer perform UCAN authorization checks by:
    • Retrieving the UCAN permissions from the context (injected by a middleware).
    • Retrieving the required UCAN permissions from the module parameters.
    • Verifying that the provided UCAN permissions satisfy the required permissions.
  • A dedicated middleware is responsible for:
    • Parsing incoming requests for UCAN tokens.
    • Verifying UCAN token signatures and validity.
    • Extracting UCAN permissions.
    • Injecting UCAN permissions into the context.
  • UCAN verification logic involves:
    • Checking UCAN token signatures against the issuer's public key (resolved via the x/did module).
    • Validating token expiration and other constraints.
    • Parsing token capabilities and extracting relevant permissions.

Hooks

The DWN module does not define any hooks.

Events

The DWN module does not explicitly define any events. However, standard Cosmos SDK events may be emitted during state transitions, including those related to UCAN authorization.

Client

The DWN module provides the following gRPC query endpoints:

  1. Params: Queries all parameters of the module, including UCAN-related parameters.
  2. Schema: Queries the DID document schema.
  3. Allocate: Initializes a Target DWN available for claims (subject to UCAN authorization).
  4. Sync: Queries the DID document by its ID and returns required information (subject to UCAN authorization).

Params

The module parameters include:

  • ipfs_active (bool): Indicates if IPFS integration is active.
  • local_registration_enabled (bool): Indicates if local registration is enabled.
  • schema (Schema): Defines the structure for various data types in the dwn.
  • UcanPermissions: Specifies the required UCAN permissions for various actions within the module.

Future Improvements

Potential future improvements could include:

  1. Enhanced IPFS integration features.
  2. Additional authentication mechanisms beyond WebAuthn.
  3. Improved DID document management and querying capabilities.

Tests

Acceptance tests should cover:

  1. Parameter updates
  2. DWN state management
  3. Schema queries
  4. DWN allocation process
  5. DID document syncing

Appendix

Concept Description
Decentralized Web Node (DWN) A decentralized, distributed, and secure network of nodes that store and share data. It is a decentralized alternative to traditional web hosting services.
Decentralized Identifier (DID) A unique identifier that is created, owned, and controlled by the user. It is used to establish a secure and verifiable digital identity.
HTMX (Hypertext Markup Language eXtensions) A set of extensions to HTML that allow for the creation of interactive web pages. It is used to enhance the user experience and provide additional functionality to web applications.
IPFS (InterPlanetary File System) A decentralized, peer-to-peer network for storing and sharing data. It is a distributed file system that allows for the creation and sharing of content across a network of nodes.
WebAuthn (Web Authentication) A set of APIs that allow websites to request user authentication using biometric or non-biometric factors.
WebAssembly (Web Assembly) A binary instruction format for a stack-based virtual machine.
Verifiable Credential (VC) A digital statement that can be cryptographically verified.