1 unstable release
0.3.0 | Sep 24, 2024 |
---|
#3 in #inscription
77 downloads per month
175KB
4K
SLoC
ord-rs
A library for working with Ordinal inscriptions.
Status
Done
- inscription:
Brc20
andNft
inscription types. - wallet: Transaction builder, signer, and parser.
TODO
- indexer: Scans the Bitcoin blockchain to catalog, organize, and provide information about Ordinal inscriptions.
Get started
Examples
Deploy
You can see the example in examples/deploy.rs
to see how to deploy a BRC20 token:
cargo run --example deploy --
-T <tick>
-a <total-supply>
-l <mint-limit>
-p <WIF private key>
-n <network>
<tx_input_id:tx_input_index> <tx_input_id:tx_input_index> <tx_input_id:tx_input_index>
Mint
You can see the example in examples/mint.rs
to see how to mint BRC20 tokens to your address.
cargo run --example mint --
-T <tick>
-a <mint-amount>
-p <WIF private key>
-n <network>
<tx_input_id:tx_input_index> <tx_input_id:tx_input_index> <tx_input_id:tx_input_index>
Transfer
You can use the example in examples/transfer.rs
to transfer BRC20 token to another address.
To transfer tokens run the following command:
cargo run --example transfer --
-T <tick>
-a <token amount>
-p <WIF private key>
-n <network>
<tx_input_id:tx_input_index> <tx_input_id:tx_input_index> <tx_input_id:tx_input_index>
An example:
cargo run --example transfer --
-T ordi
-a 100
-p "xxxxx"
-n testnet
"b6d2f6ebbf791f58cf5c15ca7ef936dc5485b27360c5e10c55b0170cf7429468:1" "f9832ed4eaf8eb32f619fe0e24f6ab352a73c16ee456b03792f13c6329e6a1e4:1"
Then you need to send the UTXO to the actual recipient of the transaction. Let's say the previous command returned this output:
Reveal transaction broadcasted: a9d7b9b6062a3609e9526b46540c6702185e612a2936f6382bf3b910cdab5b8f
Then to send the transfer to the recipient, run the following command:
cargo run --example send-inscription --
-t tb1qg0707euju8jmjr0f2erdukcttwwc0lt7p4at93
-p "xxxx"
-n test
-i "a9d7b9b6062a3609e9526b46540c6702185e612a2936f6382bf3b910cdab5b8f:0" "0c86a1ba63234546c234a6e253a0844bb693d8093dc65a6cf28f200d475bd675:1"
Where -i
takes the reveal transaction and then, the positional arguments are the transactions which will fund the fees for the transaction.
How transfers works
The transfer involves two steps actually, let's see an example where Alice sends 100 ordi to Bob:
- First the Alice sends a commit transaction from her source address to a random P2TR derived from her
- Then Alice reveals the inscription in the reveal transaction from the P2TR address to her source address.
- Finally, Alice sends the UTXO from the reveal transaction to Bob's Address.
Inscription parsing
In order to parse an inscription you can use the OrdParser::parse
function, which will use the parse
function from the Inscription
trait, for the given Inscription type.
For example, given the transaction ff314aebaa91a3f10cfba576d3be958127aba982d29146735e612869567e7808
from the testnet, we'll parse a valid Brc20
.
let transaction = get_transaction_by_id(
"ff314aebaa91a3f10cfba576d3be958127aba982d29146735e612869567e7808",
bitcoin::Network::Testnet,
)
.await
.unwrap();
let inscription: Brc20 = OrdParser::parse(&transaction).unwrap().unwrap();
assert_eq!(inscription, Brc20::transfer("mona", 100));
References
License
See license in LICENSE
Legal notice
Finity Technologies encourages developers to evaluate their own regulatory obligations when using this code, including, but not limited to, those related to compliance.
THE CODE (THE “CODE”) PROVIDED BY FINITY TECHNOLOGIES LTD (THE “COMPANY”) IS PROVIDED ON AN AS IS BASIS. THE COMPANY DOES NOT GIVE ANY WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE AND/OR NONINFRINGEMENT. IN NO EVENT SHALL THE COMPANY BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE CODE, AND/OR THE USE OF OR OTHER DEALINGS IN THE CODE.
USERS SHOULD BE AWARE OF THE RISKS ASSOCIATED WITH USING OPEN-SOURCE CODE WHICH INCLUDE, BUT ARE NOT LIMITED TO, LACK OF SECURITY, OPERATIONAL INSUFFICIENCIES, SOFTWARE QUALITY. BY USING THE CODE USERS ACCEPT THESE RISKS. FOR THE AVOIDANCE OF DOUBT, THE COMPANY IS NOT RESPONSIBLE FOR AND ACCEPTS NO LIABILITY FOR ANY LOSS WHICH RESULTS FROM ANY SUCH RISK MATERIALISING OR ANY OTHER ISSUE WITH THE CODE.
Dependencies
~10MB
~152K SLoC