Skip to content

An npm library for processing messages on the Bitcoin Cash blockchain using bch-js

License

Notifications You must be signed in to change notification settings

Permissionless-Software-Foundation/bch-message-lib

Repository files navigation

bch-message-lib

An npm library for processing messages on the Bitcoin Cash blockchain. This package depends on minimal-slp-wallet.

This is a utility library that does processing of messages on the Bitcoin Cash blockchain. These messages primarily use the memo.cash protocol or the PS001 Media Sharing Protocol.

These are the primary features provided by this library:

  • Push a normal memo.cash message to the blockchain.
  • Read normal memo.cash messages from the blockchain.
  • Filter memo.cash messages that are prefaced with a flag.
  • Push an PS001 message to the blockchain.
  • Retrieving message notifications and IPFS links from the blockchain that comply with PS001 specification.

By using minimal-slp-wallet, this library can function through the Web 2 infrastructure provided by FullStack.cash, or the free, community-driven Web 3 infrastructure provided by the PSF Cash Stack.

Installation

npm install --save bch-message-lib

Usage

Below are examples of how to use this library in your own code.

Instantiate the Library

Instantiate the library by first instantiating minimal-slp-wallet and passing that instance to the constructor.

// Import the libraries.
const BchWallet = require('minimal-slp-wallet')
const BchMsg = require('bch-message-lib')

// Instantiate the wallet.
const wallet = new BchWallet(WIF)
await uut.wallet.walletInfoPromise

// Instantiate the message library.
const msgLib = new BchMsg({ wallet })

Read Memo.cash Posts for an Address

const addr = 'bitcoincash:qz3s6t7x7040mc7yfm7e88lw0uutd444eujqejjhwr'

const result = await uut.memoRead(addr)
console.log(`result: ${JSON.stringify(result, null, 2)}`)

Filter Memo.cash Posts for an Address

const addr = 'bitcoincash:qz3s6t7x7040mc7yfm7e88lw0uutd444eujqejjhwr'

const result = await uut.memoRead(addr, 'TEST')
console.log(`result: ${JSON.stringify(result, null, 2)}`)

Write a Memo.cash Post to the Blockchain

const hex = await uut.memoPush('This is a memo.cash post')
const txid = await wallet.ar.sendTx(hex)
console.log('txid: ', txid)

Read a PS001 message from the Blockchain

const bchAddr = 'bitcoincash:qzzchl3xlcmmctk36e8dla4ltpr3ef6dsyxm06e8l5'
const result = await uut.readMsgSignal(bchAddr)
console.log(`result: ${JSON.stringify(result, null, 2)}`)

Write a PS001 message from the Blockchain

const recievers = ['bitcoincash:qrnn49rx0p4xh78tts79utf0zv26vyru6vqtl9trd3']

const hex = await uut.writeMsgSignal('testCID', recievers, 'test subject')
const txid = await wallet.ar.sendTx(hex)
console.log(`txid: ${txid}`)

Licence

MIT

About

An npm library for processing messages on the Bitcoin Cash blockchain using bch-js

Resources

License

Stars

Watchers

Forks

Packages

No packages published