Skip to content

Commit

Permalink
Merge pull request #288 from ChainAgnostic/new-caip/caip-2-update
Browse files Browse the repository at this point in the history
Information CAIP to overview caveats and usage updates to CAIP-2 since it went final
  • Loading branch information
bumblefudge authored Aug 15, 2024
2 parents c88ef39 + 20e5f18 commit 8e3dc85
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 7 deletions.
15 changes: 8 additions & 7 deletions CAIPs/caip-104.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,15 +14,15 @@ in single stand-alone CAIPs alongside cross-chain CAIPs. Now, as the system has
matured and expanded, it has become clear that namespaces are more complex and
multi-dimensional than can be efficiently governed over time in the current CAIP
single-document structure; instead, a Namespace Reference is proposed that
splits out the application of each cross-chain CAIP to a given namespace as a
splits out the application of each cross-namespace CAIP to a given namespace as a
distinct document with its own ratification/supersession lifecycle. This way,
long-term specifications for low-level primitives like Chain IDs and addresses
can be defined once and not be superseded by the addition or modification of
higher-level specifications for RPC interfaces or multiple asset types.

In practical terms, that means each blockchain ecosystem's namespace is defined
In practical terms, that means each bounded ecosystem's namespace is defined
by a folder containing a distinct document for _each CAIP_ applied to that
namespace. At a high level, the important facts about a namespace, its
namespace. How namespaces get bounded is irreducibly subjective, but overlapping or contentious boundaries are to be avoided where possible, and overlaps or redundancies should be justified in technological and interoperability terms. At a high level, the important facts about a namespace, its
governance, and its nomenclature can be defined/introduced in a `README.md`
file, and each CAIP can be defined in a `caip{X}.md` file, where X is the number
of the ratified CAIP.
Expand All @@ -42,11 +42,12 @@ and documenting dissenting opinions or rejected alternatives.

## Namespace Reference Rationale

Cross-chain engineering is difficult and often requires one to know both sides
Cross-system engineering is difficult and often requires one to know both sides
of a cross-namespace/cross-ecosystem interaction deeply to avoid serious
security, UX, and design problems. The primary function of defining a namespace
reference is to map the cross-chain CAIPs against the specifics of a given
ecosystem and namespace, ideally written for a reader with very little context in that namespace.
security, UX, and design problems.
The primary function of defining a namespace
reference is to map the cross-namespace CAIPs against the specifics of a given
ecosystem and namespace, ideally written for a reader with very little context in that ecosystem and its technical decisions to date.

## Reference Formats and Templates

Expand Down
47 changes: 47 additions & 0 deletions CAIPs/caip-288.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
---
caip: 288
title: Best Practices for using CAIP 2 - Blockchain ID Specification
author: Bumblefudge (@bumblefudge)
discussions-to: /~https://github.com/ChainAgnostic/namespaces/pull/107, /~https://github.com/ChainAgnostic/CASA/issues/107, /~https://github.com/ChainAgnostic/CAIPs/issues/22, /~https://github.com/ChainAgnostic/namespaces/issues/55
status: Draft
type: Informational
replaces: CAIP-2
created: 2024-06-14
updated: 2024-06-14
---

## Simple Summary

Since being finalized, [CAIP-2] usage has expanded and has new caveats worth specifying publicly.

## Motivation

CAIP-2 defined a way to identify a blockchain (e.g. Ethereum Mainnet, Görli, Bitcoin, Cosmos Hub) in a human-readable, developer-friendly and transaction-friendly way.
It formed the basis first for [CAIP-10] and [CAIP-19], which were later generalized into a more extensible and general [URN] framework first specified in [CAIP-104].
Adoption since finalizing the specification has surfaced corner cases, which led to terminological changes and new features.

## Changes to CAIP-2 Usage

### Language

Originally conceived as a translation layer between the identifier schemes for "chains" in different "blockchain communities," there has been interest in writing [104] namespace documents for cryptographic systems that do not organize instances into "chains" but the more general sense of networks of nodes with data in common; for this reason, "network" is preferred as the referent for [CAIP-2] identifiers, particularly when applied to DAGs, git-based systems, and other distributed systems not organized primarily around linked-list data structures.

### Non-Uniqueness of Addressed Resources

As mentioned in [CAIPs#22], a given network is assumed to be unique within a namespace, but not unique across all namespaces.
Concretely, this means that a given network addressable by a specific [CAIP-2] identifier in one namespace might also be addressable by the same or different identifiers in other namespaces.

### Special Case for non-network identifer

Implementer feedback from the Ethereum community led to PR [namespaces#107] describing an emerging pattern whereby a static identifier could be used to refer not to a specific entry in the `eip155`-defined namespace of networks, but to the wallet software itself as an actor outside of them, such as when a website communicates over direct RPC methods with a user-agent controlling an account (an "externally-owned account" or EOA in Ethereum parlance).
This may be generalizable to other namespaces over time, or may be superseded by complementary or competing solutions such as a [distinct `wallet` namespace][namespaces#55]. It is unclear if all namespaces have an equivalent or other non-network identifer needs.

## References

[namespaces#55]: /~https://github.com/ChainAgnostic/namespaces/issues/55
[namespaces#107]: /~https://github.com/ChainAgnostic/namespaces/pulls/107
[CAIPs#22]: /~https://github.com/ChainAgnostic/CAIPs/issues/22
[CAIP-2]: https://chainagnostic.org/CAIPs/caip-2
[CAIP-10]: https://chainagnostic.org/CAIPs/caip-10
[CAIP-104]: https://chainagnostic.org/CAIPs/caip-104
[URN]: https://www.rfc-editor.org/rfc/rfc8141

0 comments on commit 8e3dc85

Please sign in to comment.