0.39.0 • Published 2 years ago
@moneybutton/paymail-client v0.39.0
@moneybutton/paymail-client
Description
Javascript client to interact with BSV paymail protocol.
See the docs
Ussage.
import { PaymailClient, Verifi } from '@moneybutton/paymail-client'
import fetch from 'isomorphic-fetch'
import dns from 'dns'
import PrivKey from 'bsv/lib/priv-key'
import PubKey from 'bsv/lib/pub-key'
const client = new PaymailClient(dns, fetch) // Any implementation of fetch can be used.
const somePaymailAddress = 'some_name@moneybutton.com'
client.getPublicKey(somePaymailAddress).then(pubkey => {
console.log(`Current public key for ${somePaymailAddress} is ${pubkey}`)
})
// You can look for someones public identity key.
const senderPrivateKey = 'L3kZEuaEgdfsV7BXCrwhs8E9BuJaN67HvdkSNTfy3CmKjbXkBEjX'
client.getOutputFor(somePaymailAddress, {
senderHandle: 'sender@moneybutton.com',
amount: 10000, // Amount in satoshis
senderName: 'Mr. Sender',
purpose: 'Pay for your services.',
pubkey: '03aa44757af33e7c9c9ceb1d5655741867ef8efea00bbc3f498424c91a16c85779'
}, senderPrivateKey).then( output => {
console.log(`Now I can send money to ${somePaymailAddress} using this output: ${output}`)
})
// You can also use a previously created signature instead of passing in the private key.
import { VerifiableMessage } from '@moneybutton/paymail-client'
const timestamp = new Date().toISOString()
const preMadeSignature = VerifiableMessage.forBasicAddressResolution({
senderHandle: 'sender@moneybutton.com',
amount: 10000,
dt: timestamp,
purpose: 'Pay for your services.'
}).sign('senderPrivateKey')
client.getOutputFor(somePaymailAddress, {
senderHandle: 'sender@moneybutton.com',
amount: 10000, // Amount in satoshis
senderName: 'Mr. Sender',
purpose: 'Pay for your services.',
pubkey: '03aa44757af33e7c9c9ceb1d5655741867ef8efea00bbc3f498424c91a16c85779',
signature: preMadeSignature
}).then( output => {
console.log(`Now I can send money to ${somePaymailAddress} using this output: ${output}`)
})
// You can check if a given key belongs to a given paymail
const somePubKey = PubKey.fromPrivKey(PrivKey.fromRandom()).toString()
client.verifyPubkeyOwner(somePubKey, 'someuser@moneybutton.com').then(aBoolean => {
console.log(`The key ${somePubKey} ${aBoleean ? 'does' : 'doesn\'t'} belongs to someuser@moneybutton.com`)
})
// Lastly it lets you verify if certain signature is valid for certain paymail address.
const aMessage = new VerifiableMessage(['very', 'important', 'message'])
const aSignature = 'some signature for the message'
client.isValidSignature (aMessage, aSignature, 'someone@moneybutton.com').then( aBoolean => {
if (aBoolean) {
console.log('the signature is valid, yey!')
} else {
console.log('the signature is invalid, don\'t trust them')
}
})
0.39.0
2 years ago
0.38.8
3 years ago
0.38.7
3 years ago
0.38.6
3 years ago
0.38.4
4 years ago
0.38.3
4 years ago
0.38.2
4 years ago
0.38.1
4 years ago
0.37.0
4 years ago
0.36.0
4 years ago
0.35.0
4 years ago
0.34.0
4 years ago
0.33.0
4 years ago
0.32.0
4 years ago
0.31.3
4 years ago
0.31.2
4 years ago
0.31.1
4 years ago
0.31.0
4 years ago
0.30.1
4 years ago
0.30.0
5 years ago
0.28.1
5 years ago
0.29.0
5 years ago
0.28.0
5 years ago
0.27.0
5 years ago
0.26.0
5 years ago
0.25.0
5 years ago
0.24.4
5 years ago
0.24.3
5 years ago
0.24.2
5 years ago
0.24.1
5 years ago
0.24.0
5 years ago
0.23.0
5 years ago
0.22.2
5 years ago
0.22.1
5 years ago
0.21.11
5 years ago
0.21.10
5 years ago