CIP: 26
Title: STAMP Protocol
Author: MikeInSpace & Jeremy Johnson (J-Dog)
Discussions-To: https://forums.counterparty.io/t/cip-26-stamp-protocol/6563
Status: Draft
Type: Process
Created: 2023-04-20
Enable linking of a file
to an asset
via a stamp
.
Define a process for encoding a file
into a transaction and associating the file
with an asset
via an issuance
.
The Bitcoin Stamps
spec first proposed the basic guidelines for how to create a stamp
, as well as additional guidelines for the Bitcoin Stamps
project.
This CIP has been created to clarify the technical process to stamp
a file
to any asset
, and remove any project-specific requirements from the protocol.
stamp
- Anyissuance
transaction with thestamp:
prefix in thedescription
fieldfile
- Any file typeasset
- Any asset type (numeric, named, subassets)mime-type
- Any of the currently defined MIME / Media Types according to the IANA Spec
Any issuance
will be considered a stamp
if the description
field begins with the prefix stamp:
(case-insensitive). This ensures a stable numbering system for stamps and allows for expansion of the protocol in the future to support additional encoding formats.
The stamp:
prefix should immediately be followed by file
data in one of the following formats:
base64_data
mime-type:base64_data
data:mime-type;base64,base64_data
Multiple files can be encoded in a single stamp
transaction by specifying a ;
character to separate the files, followed by one of the above formats.
Single file
example:
stamp:iVBORw0KGgoAAAANSU...
stamp:image/png;iVBORw0KGgoAAAANSU...
stamp:...
Multiple file
Example:
stamp:iVBORw0KGgoAAAANSU...;iVBORw0KGgoAAAANSU...
stamp:image/png;iVBORw0KGgoAAAANSU...;image/png;iVBORw0KGgoAAAANSU...
stamp:...;image/png;base64,iVBORw0KGgoAAAANSU...
This document is placed in the public domain.