description: >- Create hierarchies and includes of Atomicals digital objects with recursion and references

Recursion and References

The following URNs are defined to simplify including and referencing different Atomicals resources.

NOTE: When referring to references in an Atomical, it is recommended to. use the ctx top level field in the data to import or include references to other Atomicals and data files. The ctx top level is reserved specially for this reason.

Examples of Recursion with References in the ctx field:

{
  // Any Atomical data above...
  "ctx": {
     // Implied to always get the latest data for an atomical:
     "resourcename": "atom:btc:id:<atomical_id>/mydata",
     // Gets permanent data file image.png at the dat_id
     "icon": "atom:btc:dat:<dat_id>/image.png",
     // Gets the minted "name" property for a collection
     "collection-name": "atom:btc:container:<dat_id>$name",
     // Gets the latest version of import.js located at a realm name
     "assetbuilder.js": "atom:btc:realm:<realm_name>/import.js",
  },
  // Another other Atomical data ...
}

Note: It is preferably to use the "dat" command to refer to on-chain assets where applicable. When using containers, realms or the dynamic references (using slash "/") it is possible the resource.

Conventions

The convention is to use the prefix "atom:btc" to indicate the Atomicals Protocol on the Bitcoin (BTC) network. It is possible to reference digital objects by atomical_id, container name, or (sub)realms and immutable file data by the data_id.

The basic form of the Atomicals Universal Resource Name (URN) is:

atom:<chain>:<ref_type>:<identifier>[$ or /[<file>]]

Where:

chain: The referenced blockchain, set to "BTC" for Bitcoin

ref_type: The type of reference. Currently supported "id", "container", "realm", and "dat"

identifier: The identifier corresponding to the ref_type. Such as atomical_id, container name, realm name, or the reveal location of the immutable data in the case of "dat"

$ or /: Whether to refer to the mint (original) data (using dollar sign or / is acceptable and will return the same data regardless.

file: The name of the file is optional, if omitted then general information about the resource is returned

The philosophy is that we should be able to unambiguously reference Atomicals digital objects based on their types. At the base level every type such as container and realm can also be referenced by the atomical_id. Furthermore, we should always be able to get the original mint data, and also get the latest version of files stored, including every revision of that file either by txid, version number, or block height.

References by Atomical ID

Get general information

atom:btc:id:<atomical_id>

Ex: atom:btc:id:14a0d7c98304bf5ac9a5addceb1de0ce4e840641f82d71d84cebbdac427c1fc3i0

Get original minted data as JSON

atom:btc:id:<atomical_id>$

Get original minted file

atom:btc:id:<atomical_id>$links

atom:btc:id:<atomical_id>$info.pdf

Get latest dynamic data state

atom:btc:id:<atomical_id>/

Get latest version of a file

atom:btc:id:<atomical_id>/image.png

Get specific version of a file

atom:btc:id:<atomical_id>/image.png@[txid or version number or blockheight]

The [txid or version number or blockheight] can be of the form:

  • hexadecimal of the txid that was one of the valid updates to the file
  • Version number starting with "v" such as "v1"
  • Block height for the state of the file as of that block height

References by Container Name

Get general information

atom:btc:container:<containerName>

Examples:
atom:btc:id:my-coolcontainer-name

Get original minted data

atom:btc:container:<containerName>$

Get latest dynamic data state

atom:btc:container:<containerName>/

Get original minted file

atom:btc:container:<containerName>$image.jpg

Get latest version of a file

atom:btc:container:<containerName>/items

Get specific version of a file

atom:btc:container:<containerName>/items@[txid or version number]

References by Realms

Get general information

atom:btc:realm:<realmName>

Where realmName can be a Top Realm or any Sub Realm

Examples:
atom:btc:realm:myrealm
atom:btc:realm:myrealm.somesubrealm
atom:btc:realm:myrealm.somesubrealm.thirdlevel-subrealm

Get latest version of a file

atom:btc:realm:<realmName>/profile

Get specific version of a file

atom:btc:realm:<realmName>/profile@[txid or version number]

The [txid or version number or blockheight] can be of the form:

  • hexadecimal of the txid that was one of the valid updates to the file
  • Version number starting with "v" such as "v1"
  • Block height for the state of the file as of that block height

References by ARC20 (Fungible Tokens)

Get general information

atom:btc:arc:<ticker>

Where ticker can be a ticker name of an ARC20 token

Get mint original data

atom:btc:arc:<ticker>$

atom:btc:arc:<ticker>/icon.png

Get event feed at ticker

atom:btc:arc:<ticker>/events (To be determined - TBD)

References to Immutable Data

To store immutable (non digital object data) use the "dat" command (store-file) and reference it using the dat URN of the form:

atom:btc:dat:<data_id>/image.png

Notice that the dat immutable data storage can use either the $ or the / since there is only one version of the immutable data and both will return the same data.