-
Notifications
You must be signed in to change notification settings - Fork 336
Wallet Merchant Protocol
The purpose of this protocol is to enable a merchant to request payment from the user via a hosted wallet provider or via a browser plugin. We will assume that the wallet is hosted at https://wallet.org and that the merchant is hosted at https://merchant.org.
The goal of this protocol is to maintain user and merchant privacy from the wallet provider which should never have direct access to the invoice data.
To securely pass data from https://merchant.org to the javascript wallet hosted at https://wallet.org, the data will have to be passed after the "#". Assuming the wallet provider is not serving up pages designed to compromise your privacy, only your web browser will have access to the invoice data.
This invoice provides all of the data needed by the wallet to display an invoice to the user.
{
"to" : "merchant_account_name",
"to_label" : "Merchant Name",
"memo" : "Invoice #1234",
"line_items" : [
{ "label" : "Something to Buy", "quantity": 1, "price" : "1000.00 SYMBOL" },
{ "label" : "10 things to Buy", "quantity": 10, "price" : "1000.00 SYMBOL" },
{ "label" : "User Specified Price", "quantity": 1, "price" : "CUSTOM SYMBOL" },
{ "label" : "User Asset and Price", "quantity": 1, "price" : "CUSTOM" }
],
"note" : "Something the merchant wants to say to the user",
"callback" : "https://merchant.org/complete"
}
By itself this data is 579 characters which after URL encoding is 916 character limit and therefore cannot be passed via a URL.
Using [LZMA-JS](https://github.com/nmrugg/LZMA-JS/)
library to compress the JSON into a binary array. This will be the most compact form of the data. After running the compression the example JSON was reduced to 281 bytes from 579 bytes.
Using the [bs58](http://cryptocoinjs.com/modules/misc/bs58/)
library encode the compressed data in base58. Base58 is URL friendly and size efficient. After converting to base58 the string will be 385 characters which can easily be passed in a URL and easily support much larger invoices.
Once the Base58 data is known, it can be passed to the wallet with the following URL: