Public API
This is the public facing side of the API server.
Tips
POST /tip
Request parameters:
- currency
- string
- international 3 character ISO code
- value
- numeric
- amount being transacted
If currency
equals the special code "SAT", then value
represents the exact numbers of
sats to be invoiced. If currency
is fiat like "USD", the final sats value will be calculated
internally based on the store rate between USD->BTC.
Sample request:
{
"currency": "SAT",
"value": 10000
}
Reply:
{
// document id created in the database, is passed along on the invoice memory currently
"_id": "order-0a798d5f-fcac-4c86-9e8b-be58c82e1cc1",
// internal revision tracking for document
// first step was created,
// second step was processed by the external lightning invoice provider
// third step would be the "settled" state
"_rev": "2-fbef6bbeb5e87f674a844f8c6534ac43",
// will be used for specific product shopping
"products": [],
// local currency in which accounting has to be denominated in
// can be configured in the settings document
"fiat_currency": "EUR",
// total amount charged in the local currency
"fiat_total": 2.68,
// currency in which the order has been presented to the user
"order_currency": "GBP",
// total amount shown to customer
"order_total": 2.34,
// total value in sats after conversion rates were applied
"sats_total": 10000,
// order creation time
"timestamp": "2023-05-06T20:24:41.668Z",
// marker as procesed by the "LN_invoice" plugin
"LN_Invoice": true,
// copied value in sats
"ln_invoice_sats": 10000,
// memo for transaction
// currently it's only the order id, some messages can be embedded as well
"ln_invoice_memo": "order-0a798d5f-fcac-4c86-9e8b-be58c82e1cc1",
// expiration time in miliseconds
"ln_invoice_expire_ms": 86400000,
// test is only true when being generated from the test suite
"test": false,
// lightning invoice code
"ln_invoice_req": "lnbc100u1pj9ddufpp5eqgz4344ws6ep0ryrg43v5ykjc4lztfj27g6njgysadevrxcs05qdzydaexgetj95cxzdee8pjr2e3dve3kzcedx33nsd3d89jnsc3dvfjn2wrr8qex2vtrvd3scqzpgxqyz5vqsp58jzju3j5z2szhwzuw9x4qu05c3459q8x252z4nxrm9nhmel4gkjq9qyyssqxfahy0j8y32u2v5qyyhygajcmwckchtvual32dev9znjvv2vx8ektp64wr5hjpufnd20guhfa6qlwvdj9zxjq39lw46rdjeul03d5jsq3z25na",
// generated qr code
"ln_invoice_qr": "",
// date when document was processed and the linghtning invoice was created
"ln_invoice_created_at": "2023-05-06T20:24:42.281Z"
}
GET /status/{id}
After an order document is created, the returned _id
value can be used to query for
live changes on the state of that document. When a settle operation happens (currently the
only transformation allowed) through the external watch script, the endpoint will return
the new revision if it has settled, or it will stay in a pending state until the settlement
happens or the 1 minute timeout expires.
Proxied directly to the CouchDB changes feed.
Possible Headers:
None
It watches for changes starting from this exact moment going forward (passes since=now
param to changes feed)
X-Rev
When passed, returns the revision of the document right away.
X-Start-Rev
Starts watching since specific database update sequence. If change has already happened it returns it immediately, otherwise is keep watching
All live requests have a timeout period of 1 minute, in which they return an empty result set. In case the payment check needs to continue, the request has to be performed again.
Rates
GET /rates
Retrieve latest currency exchange rates maintained by the cron job.
{
"_id": "rate:10kSATS",
"_rev": "1-da24a4ce39122b009ac447438b9080a8",
"timestamp": "2023-04-23T11:38:20.769Z",
"SAT": 10000,
"EUR": 2.52,
"GBP": 2.23,
"RON": 12.58,
"USD": 2.76
}
The reference value for sats is arbitrarily picked at 10000 to allow for each conversion.