bisq-network / proposals

@bisq-network improvement proposals
https://bisq.wiki/Proposals
43 stars 16 forks source link

Improve BSQ accessibility through OTC market and bonded reputation #308

Closed MwithM closed 3 years ago

MwithM commented 3 years ago

This is a Bisq Network proposal. Please familiarize yourself with the submission and review process.

To make BSQ more accessible to traders, I propose to create a #buy-bsq channel to trade small amounts of BSQ outside of Bisq protocol. Payment methods will vary (main option could be lightning). This proposal has been thought after the evolution of #305 and it's inspired on the #buy-bitcoin channel.

This is how it would work:

@chimp1984 is the salt something only known by the one who puts the bond? How would an external viewer verify and associate Keybase/Github identities to a bond?

chimp1984 commented 3 years ago

The salt is the preimage for the hash added to the opReturn. Only the tx creator knows the preimage but once its shared its not secret anymore. So it can be only used once safely. A signature signing tool like we have at proof of burn could be added, that would be more useful if there is a need for that.

chimp1984 commented 3 years ago

We have to take care to not promote the insecure and centralized (keybase can shut us down any time) off-Bisq trade option too much. For users not having Bitcoincoin I think its justified as an experiment, but to extend it if it is not really needed I think its a slippery slope.

huey735 commented 3 years ago

I don't know much about the details of the implementation of BSQ but a multiparty transactions seems like a simple way to do the trade given that the BTC seller wants to pay with an on-chain transaction in a more trustless way.

inputs outputs
BTC buyer's BSQ BTC buyer's BSQ change
BTC seller's BTC BTC seller's BSQ
BTC buyer's BTC
BTC seller's BTC
pazza83 commented 3 years ago

I think this is a good idea it addresses the many complaints of BSQ being inaccessible for small purchases we have seen on Github, Keybase and Reddit.

Eg comments like: https://github.com/bisq-network/bisq/issues/4575#issuecomment-774735656

High mining fees are a barrier to enter for those looking to sell or buy BSQ in small amounts.

I also made a proposal here of how to address this by increasing transaction times to 7 days on BSQ for users that want this.

chimp1984 commented 3 years ago

There might be some new ways for swapping BSQ to BTC: https://github.com/bisq-network/proposals/issues/304#issuecomment-774570675

pazza83 commented 3 years ago

I would like to sell Bisq Starter Packs. Everything you need to trade on Bisq

All instant payment methods accepted Maximum purchase 1 per user No refunds given :)

chimp1984 commented 3 years ago

FYI There are 2 DAO features which might be useful for any off-chain / OTC experiments.

  1. Bonds
  2. Proof of burn

Beside the defined Bisq DAO bonded roles there is bonded reputation which can be used arbitrarily. You can define a salt which is a preimage for the hash which will get added in the opReturn. This can be used as a one-time secret (nobody can derive the preimage from the hash). Once you have shared it with anyone it has lost its secuirty as you cannot guarantee that the other one is not sharing it further. The salt has to be a hex string, I dont remember why that was made a requirement but you could convert any string into that hex. There is no signature tool implemented in the UI but it could be added as well if there is a strong use case for it, that would be more useful. The lock time and the amount can be defined by the user.

Screen Shot 2021-02-10 at 23 30 20

There are quite some bonded reputation and some with quite long unlock time, so it seems some people have found some use case for it.

Screen Shot 2021-02-10 at 23 30 32

The other feature is the Proof of burn. Here the BSQ is burned and could be used to create reputation. If you have invested 1000 USD in burning BSQ and bind your online ID to that you will take care not to damage that reputation as then your investment has no value anymore. It is not that attractive to most people as the funds are gone (to the DAO) but I think it has even stronger security properties as there is no "long con" possible. It comes with the preimage-> hash feature but the preimage can be any string. Additionally you can sign any messages and the peer can verify it in Bisq:

Screen Shot 2021-02-10 at 23 38 19 Screen Shot 2021-02-10 at 23 38 34 Screen Shot 2021-02-10 at 23 38 46

The reason why I share that all is because I have the feeling that those OTC experiments might help us to get to the off-chain trade protocol (which was based on BSQ bonds). If we can solve in a simple low-tech version the conceptual challenges we might get a step closer to be able to implement it.

Mycelial1 commented 3 years ago

I would love a signature tool that proves bonded BSQ. Not so much the "Proof of Burn" signature.

I have sold 0.007 Bitcoin to a few different new users lately so that they can pay their first security deposit. They reached out to me simply because I'm active, but being able to refer to bonded BSQ would be very meaningful to me, for building rep, and meaningful to them, because they know it could get confiscated if I commit foul play.

This would be useful for both the #buy-bsq as well as the #buy-bitcoin OTC channel experiments that we have.

MwithM commented 3 years ago

It could be done in an inverse way, burn BSQ but having a right to claim it back (in USD value). In case the bonded through burning trader misbehaves, claiming it back will be rejected. The best part of it is that it's ready to go, it could be used yesterday for that purpose. We just need to stay vigilant through the chat that trading volume at a time is not over their burnt BSQ.

Mycelial1 commented 3 years ago

Unless anyone has an issue with me claiming back the same amount of BSQ at a later date, I would like to go ahead and burn some BSQ to increase trust when selling BTC away from the Bisq trade protocol.

MwithM commented 3 years ago

I think that in case that burning BSQ with a right to claim the BSQ back again is the way to go, selling BSQ or selling fiat should have separated burning transactions. I think it's better if we keep the discussion about how to use BSQ to bond this trades at https://github.com/bisq-network/proposals/issues/283 @Mycelial1 make this same question there, please.

huey735 commented 3 years ago

@Mycelial1 you can lock BSQ under DAO > Bonding > Bonded Reputation, you don't have to burn it.

MwithM commented 3 years ago

Moved to discussions