Difference between revisions of "Lazy API"

From Bitcoin Wiki
Jump to: navigation, search
(Solution for sending bitcoins)
(Solution for receiving bitcoins: Removed Instawallet (defunct), added Inputs)
Line 17: Line 17:
 
# After a reasonable amount of time has passed, you can re-use the address for another customer
 
# After a reasonable amount of time has passed, you can re-use the address for another customer
  
You could avoid having a list of addresses and reusing them by getting a new address via API call from one of the wallet services that support this feature (e.g. https://instawallet.org/static/api).
+
You can also use [[File: inputs.png]] Inputs.io's [https://inputs.io/button frictionless payment buttons] that allows visitors to pay Bitcoins without leaving your webpage. Inputs also supports callbacks which saves you the work of having to check for bitcoins, instead new transactions are pushed to you.
  
 
==Risks==
 
==Risks==

Revision as of 11:07, 10 July 2013

For the incredibly lazy and/or incompetent web developer, present is the lazy man's bitcoin API (copied from a forum post):

Problem

Lazy web designer wants to use bitcoins without dealing with installing bitcoin on a server, installing a shopping cart interface, or using ugly merchant services with callbacks.

Solution for sending bitcoins

Use the MtGox API or Inputs.png Inputs.io API which allows you to use the offchain payment network.

Solution for receiving bitcoins

  1. Input a list of bitcoin receiving addresses to your database
  2. Give a bitcoin address to a potential customer
  3. Have the customer tell you when they have sent the coins and have at least 1 confirmation (you can choose a number higher than 1 if you are worried about double-spending)
  4. Check blockexplorer to see if they sent the right amount (i.e. http://blockexplorer.com/q/getreceivedbyaddress/19hMEAaRMbEhfSkeU4GT8mgSuyR4t4M6TH/1) - the /1 is the number of confirmations you require
  5. Give them what they paid for
  6. After a reasonable amount of time has passed, you can re-use the address for another customer

You can also use Inputs.png Inputs.io's frictionless payment buttons that allows visitors to pay Bitcoins without leaving your webpage. Inputs also supports callbacks which saves you the work of having to check for bitcoins, instead new transactions are pushed to you.

Risks

External Service

BlockExplorer is a service that is provided by a private party. There is no guarantee that the information provided by BlockExplorer matches the blockchain.

There have not been any reports that BlockExplorer has reported transaction data incorrectly.

Double Spending

A merchant is exposed to a double-spending attack when recognizing a payment before it has been confirmed with a sufficient number of blocks.

For an attacker to be successful with this double spend tactic a significant effort is required and thus the risk of this attack being made against the typical retail merchant is pretty minimal. It would not be advisable for a merchant with little to no recourse against an attacker to accept payment without a sufficient number of confirmations however.

See Also

  • BitAddress Generate address and private key pairs for an offline wallet
  • BitcoinNotify Register addresses and receive email or SMS alerts when a payment to that address occurs