Pages:
Author

Topic: Bitcoin card for deposit and payment + Little POS (Read 6930 times)

hero member
Activity: 780
Merit: 510
Bitcoin - helping to end bankster enslavement.
Currently calculators are cheap to produce.  And 720p cameras are small and cheap.  NFC is also cheap as well.

Cram them together with a yes or no button and you have a bitcoin payment system.

How?  

Well the POS would be connected to the internet with the full bitcoinDB the bitcoin card would have the private key but it would not give it up.  It would instead give up the data to sign over the money.

You see a private key allows you to sign something and no one else can write that signature.  Thus the message coming from the NFC of the bitcoin card would be the data stream that needs to be posted to the bitcoin network.  

So a sale would go like this...

Merchant:  It's 5 btc use your bitcoin card to scan this QR that has the address to send and the amount:
Customer:  Uses his bitcoin card to scan the QR code and sees the amount on the one line screen.
Customer:  has an option to hit yes or no to price that includes a transaction fee from the POS system.
Customer:  Customer hits yes and the signed data is created to send over the NFC.
Customer:  touches the POS NFC receiver and the POS system takes the data and posts it to the bitcoin network.
Merchant:  Then decides if he wishes to trust the customer and hand over the merchandise or wait for specific number of confirmations.

This can be expanded to create a trusted DB of public keys where the POS can find out if the public key is trustworthy but the process would be complex to help ensure no public key got a fake trust status.  NOTE: For those that don't know you sign over your bitcoins from your public key to another, thus both sides of the ledger are visible to the POS.  Furthermore a bitcoin card would only have one public key for sending and receiving.

This is my 2 BTC cents.


Davinci
legendary
Activity: 1022
Merit: 1000
Realistically thinking there is no way around e-wallets in the future. The bitcoin network itself if a foundation and quite bulky one. We can not expect anyone else other than geeks running their homeservers 24/7 with bitcoind. Sure, e-wallets is a step back in some sense from the liberties bitcoin offers but in real world most people prefer to trade freedoms and security for convenience and we got to deal with it.

It is for this reason and because I don't like this idea that I raise these cards, personal wallet, remain without centralization or e-wallet, but without the user having no idea of the functioning or operation bitcoin not even need computer . The card can be purchased with balance and can be recharged via sms (as it does blockchain.info) at points of sale or ATM bitcoin ... etc.
full member
Activity: 168
Merit: 100
Realistically thinking there is no way around e-wallets in the future. The bitcoin network itself if a foundation and quite bulky one. We can not expect anyone else other than geeks running their homeservers 24/7 with bitcoind. Sure, e-wallets is a step back in some sense from the liberties bitcoin offers but in real world most people prefer to trade freedoms and security for convenience and we got to deal with it.
legendary
Activity: 1022
Merit: 1000
In any case, the initial idea presented in the OP I think the most feasible comfortable and sufficiently secure to be a valid means of payment.

One of the main reasons that prompted this idea was to provide an easy way as to buy and use bitcoins because the cards could be purchased with credit.

Here https://bitcointalksearch.org/topic/its-coming-87441 the same idea has emerged, but rather seems to have a centralized approach, based on e-wallet, considering that no codes to look at and has to be activated.

Obviously I like more mine  Wink

legendary
Activity: 1022
Merit: 1000
Yes, it is something like that.

I don't like the idea of disposable PVC cards... think what it would be like to throw away your credit card after every grocery-shopping trip!

re-statement:
Instead, having the merchant empty one of your wallets and send to the other would be ideal: he can't access the one he sends the change to. A bitcoind on your home computer would then refill the public address.

Another way of doing it, with the home-hosted bitcoind:
Have a public address 1CUST with a very small amount (~0.01 BTC). The merchant then charges a number of Satoshis from that to 1MERCH. The home-script sees this transaction. It multiplies the satoshis by some number (10,000?) and sends that amount to 1MERCH.


Both of these methods have a problem. They avoid giving out your main private key but:
1. With this method, the merchant could set up a program to rob your address as soon as it is filled back up
2. With this method, the merchant could charge the whole 0.01 BTC, causing your script to send 100 BTC to the merchant. You throw away the card, but the damage is done.

So really, I'm not seeing a viable way to make re-usable PVC bitcoin cards, given that there's no way short of rubber-hose cryptography to prove that someone owns such-and-such an address.

PVC cards would never be disposable, it would be crazy. XD

In a previous post I wrote the following, it seems feasible but depends on the multi signature.
Quote
Does not appear be the case, fear of stolen is very apparent in bitcoin, even above our local currency. Concentrate an impenetrable security system in a single piece of plastic, not even the pvc veterans  have been able even (visa / mastercard ...).

When multisignature transactions are fully implemented in bitcoin clients, the operation of the cards could be adapted to the multisignature, so that each transaction must be authorized for a second private key, so even if we steal the private key of the card and our password to decrypt it, they could not operate ( could even dispense with encryption and key ) . Of course, this would add a further complication to the use of the card, a merchant will not let you go with the merchandise, hoping that later you grant permission the transaction.

Right now I can not think a simple option, anonymous and without relying on a centralized system to implement a system like this. Accepting all these drawbacks, one option would be to use a service like Twilio+CardAuthorizerServer, to link each card to the mobile phone number of user,  in this way when making a transaction the CardAuthorizerServer may call immediately the customer, and through an key ( hold in the mobile keypad ) authorize the transaction, as the CardAuthorizerServer would have the second private key.

One option following this scheme without multi signature, could be as follows:
The card contains only a small amount of Bitcoins, enough for the fee, to make a payment issue an invalid transaction but with all the necessary information for payment. Thus the CardAuthorizerServer detect this transaction, would take the data and perform the transaction, after request phone confirmation.
hero member
Activity: 784
Merit: 1000
0xFB0D8D1534241423
Yes, it is something like that.

I don't like the idea of disposable PVC cards... think what it would be like to throw away your credit card after every grocery-shopping trip!

re-statement:
Instead, having the merchant empty one of your wallets and send to the other would be ideal: he can't access the one he sends the change to. A bitcoind on your home computer would then refill the public address.

Another way of doing it, with the home-hosted bitcoind:
Have a public address 1CUST with a very small amount (~0.01 BTC). The merchant then charges a number of Satoshis from that to 1MERCH. The home-script sees this transaction. It multiplies the satoshis by some number (10,000?) and sends that amount to 1MERCH.


Both of these methods have a problem. They avoid giving out your main private key but:
1. With this method, the merchant could set up a program to rob your address as soon as it is filled back up
2. With this method, the merchant could charge the whole 0.01 BTC, causing your script to send 100 BTC to the merchant. You throw away the card, but the damage is done.

So really, I'm not seeing a viable way to make re-usable PVC bitcoin cards, given that there's no way short of rubber-hose cryptography to prove that someone owns such-and-such an address.
legendary
Activity: 1022
Merit: 1000
I see a simple method which could work for one reusable card. It would make stealing instantly detectable, at which case you punch out the merchant Wink

The card has 2 QR codes on it, but they are not of the same address. Here's how it would work:
  • There are 2 addresses, 1a and 1b.
  • The public address for 1a is shown, as is its QR code.
  • The privkey for 1b is shown, along with a QR code which scans to it.
  • To "load" the card, send bitcoins to 1b.
  • When the merchant takes payment, he transfers *all* of the money in 1b to his address, then sends the "change" to 1a. The merchant cannot take more money now, because he doesn't have the 1a privkey.
  • Finally, in order to re-use the card, the change must be sent from 1a back to 1b. This could be done by bitcoind and a script running on your home computer.

Now the only possibility for stealing is when the merchant doesn't send you the change. But since anyone can check the blockchain from websites like blockexplorer and blockchain.info, this isn't a feasible attack. You'd notice he overcharged, and demand your money back. Then you could sue him or punch him out if he didn't.

Hi,

I think I proposed something like this before. It is something like this?

OK, so the password is hard coded into the QR code, and the POS terminal is trusted not to steal funds. It could work IRL, because an evil POS terminal the stole things would be very obvious, and less likely to happen when a customer is there. However, sending the funds back to the same address is the problem - you have to assume the POS deletes the keys once it has finished with them, but what happens if it doesn't? Or what happens if it is hacked somehow?


If the POS wants to steal, just to keep the wallet generated from the QR and capture the password when you authorize a payment.

Within the limitations of typical resolution of a webcam, you could modify the QR of payment to that contains  a complete wallet with a different address from the side of deposit/change . The problem is that debit function disappears and is removed option to pay multiple times until the balance of cards are empty , because the change would go to another direction, we would have to wait to access the wallet that contains the private key of deposit/change addresses to return the balance to the card

But as recargases the direction of payment, if your fear is they have copied your wallet and password, you're just like before.


EDIT:
For the most paranoid, dispense a nice pvc card for a simple printing and make card wallet of a single use is a good option.

The problem is when you go back to reload, because if someone stole the data the first time, I could monitoring it until I had balance.
But we're assuming they're going to steal, if we were well through life we could not pay our regular cards.
legendary
Activity: 1022
Merit: 1000
Here is what got me thinking:
What if you make PAY QR-code wallets disposable? Lets walk through such scenario:

1) your e-wallet provider generates 10 wallets and 10 corresponding PAY QR-codes
2) Lets say you have 37 BTC and decide to charge each PAY code with 10 BTC. 1st, 2nd and 3rd coders are charged with 10 BTC and the 4th with 7 BTC by your e-wallet provider
3) You pay 6 BTC for a cheeseburger for your cat with the 1st PAY QR-code.
4) Your e-wallet provider senses 6 BTC moving out of your QR-code and moves out the remaining 4.
5) Your e-wallet provider then may refill your unused PAY QR-codes. Filling 4th to full with 3 BTC and moving 1 BTC yo 5th PAY QR-code

How do you like that?


In this situation it is dependent on a centralized operator, e-wallet, which escapes from the initial idea.

I already had proposed something similar but I discard it with the hassle of having to carry a collection of cards.

My approach is the same as the original idea, but in the 1A side that contain the return address, it would show the public key of 2B, in 2A show the public key of 3B and so on. That way when you pay with the first card, all the change will go to the second, and then third to get to the last that if would contain its own.

Agrees with your approach? Correct me if I'm wrong

Following this way could be done with normal cards since PVC It is not profitable and nothing ecological Xd Cheesy
hero member
Activity: 784
Merit: 1000
0xFB0D8D1534241423
I see a simple method which could work for one reusable card. It would make stealing instantly detectable, at which case you punch out the merchant Wink

The card has 2 QR codes on it, but they are not of the same address. Here's how it would work:
  • There are 2 addresses, 1a and 1b.
  • The public address for 1a is shown, as is its QR code.
  • The privkey for 1b is shown, along with a QR code which scans to it.
  • To "load" the card, send bitcoins to 1b.
  • When the merchant takes payment, he transfers *all* of the money in 1b to his address, then sends the "change" to 1a. The merchant cannot take more money now, because he doesn't have the 1a privkey.
  • Finally, in order to re-use the card, the change must be sent from 1a back to 1b. This could be done by bitcoind and a script running on your home computer.

Now the only possibility for stealing is when the merchant doesn't send you the change. But since anyone can check the blockchain from websites like blockexplorer and blockchain.info, this isn't a feasible attack. You'd notice he overcharged, and demand your money back. Then you could sue him or punch him out if he didn't.
full member
Activity: 168
Merit: 100
Here is what got me thinking:
What if you make PAY QR-code wallets disposable? Lets walk through such scenario:

1) your e-wallet provider generates 10 wallets and 10 corresponding PAY QR-codes
2) Lets say you have 37 BTC and decide to charge each PAY code with 10 BTC. 1st, 2nd and 3rd coders are charged with 10 BTC and the 4th with 7 BTC by your e-wallet provider
3) You pay 6 BTC for a cheeseburger for your cat with the 1st PAY QR-code.
4) Your e-wallet provider senses 6 BTC moving out of your QR-code and moves out the remaining 4.
5) Your e-wallet provider then may refill your unused PAY QR-codes. Filling 4th to full with 3 BTC and moving 1 BTC yo 5th PAY QR-code

How do you like that?
legendary
Activity: 1022
Merit: 1000
Today I received the first PVC cards.  Grin

OP updated


legendary
Activity: 1022
Merit: 1000
Although the format and utilization is homologous to debit cards, it really must be seen as a bill or coin of variable value. If you have a $20 bill and pay a product of $9.55, even push, also you give your $20 bill hoping that give you the change, but in this way the change would be like another bill of $10.45 and so on.

That is correct.  Although with bitcoin, it is always possible to push the exact amount.  So there's no need to overpay and expect change (other than the low-level way the bitcoin works, but that's not important to the average user)


What I mean is the need to trust a higher value than pay during the transaction, even in cash or other property material. With these cards also pay the exact amount, as the operation of bitcoin is the same, but you must rely temporarily the total value for the merchant to collect the amount (but really doing push from the card). Like cash, the change is easily verifiable.
hero member
Activity: 742
Merit: 500
Although the format and utilization is homologous to debit cards, it really must be seen as a bill or coin of variable value. If you have a $20 bill and pay a product of $9.55, even push, also you give your $20 bill hoping that give you the change, but in this way the change would be like another bill of $10.45 and so on.

That is correct.  Although with bitcoin, it is always possible to push the exact amount.  So there's no need to overpay and expect change (other than the low-level way the bitcoin works, but that's not important to the average user)
legendary
Activity: 1022
Merit: 1000
I'm not convinced putting private keys out there is really the way to go.

The difference is really between push and pull...

for thousands of years, if you wanted to pay money to someone, whether it was gold, or cash, you just handed them $20 or what you owe them.  piece of cake.  done.

The invention of credit cards flipped it around.  Now, if i want to pay someone $20 with my credit card, I have to give them my account number, and my $20,000 line of credit, and trust them to only pull 20 bucks.  That's crazy when you think about it!

I think the key to bitcoin is getting back to the basics of money.  Push.  I owe you $19.85, ok, I push you $19.85.  You don't get access to my $20,000 line of credit to pull from.  No.

That being said, the key to bitcoin is keeping it in a push transaction.  text message is a push.  email is a push.  the bitcoin clients are all push.  I think this is the right way to do it.

Although the format and utilization is homologous to debit cards, it really must be seen as a bill or coin of variable value. If you have a $20 bill and pay a product of $9.55, even push, also you give your $20 bill hoping that give you the change, but in this way the change would be like another bill of $10.45 and so on.
full member
Activity: 168
Merit: 100
You are right.
As long as the bitcoin holder do not operate any computing and communication he/she has to rely on the merchant for that. And I see no way to do computing with cardboard or plastic tags.
hero member
Activity: 742
Merit: 500
I'm not convinced putting private keys out there is really the way to go.

The difference is really between push and pull...

for thousands of years, if you wanted to pay money to someone, whether it was gold, or cash, you just handed them $20 or what you owe them.  piece of cake.  done.

The invention of credit cards flipped it around.  Now, if i want to pay someone $20 with my credit card, I have to give them my account number, and my $20,000 line of credit, and trust them to only pull 20 bucks.  That's crazy when you think about it!

I think the key to bitcoin is getting back to the basics of money.  Push.  I owe you $19.85, ok, I push you $19.85.  You don't get access to my $20,000 line of credit to pull from.  No.

That being said, the key to bitcoin is keeping it in a push transaction.  text message is a push.  email is a push.  the bitcoin clients are all push.  I think this is the right way to do it.





hero member
Activity: 686
Merit: 500
Wat
Would be nice to create bitcoin business cards with a code on them.
legendary
Activity: 1022
Merit: 1000
Good idea. My proposal of dirt cheap plastic QR-code tags was the same but just for receiving.

As for the pay method criticism I agree with it and I think it is comparable with so-called "Visa Internet" plastic-less cards. They are charged with small sums and often used for just a couple of purchases. So as Mythbusters say - the idea is plausible Smiley

It could be useful where mobile internet penetration is low.

Thanks

Quote
as Mythbusters say - the idea is plausible
is more than I needed to hear  Grin Grin

Deposit cards are and will, increasingly, very useful. The problem of massive printing of these cards is the private key, that the client must have in any other medium.
legendary
Activity: 1190
Merit: 1000
www.bitcointrading.com
sweet project!  /watching
full member
Activity: 168
Merit: 100
Good idea. My proposal of dirt cheap plastic QR-code tags was the same but just for receiving.

As for the pay method criticism I agree with it and I think it is comparable with so-called "Visa Internet" plastic-less cards. They are charged with small sums and often used for just a couple of purchases. So as Mythbusters say - the idea is plausible Smiley

It could be useful where mobile internet penetration is low.
Pages:
Jump to: