< luke-jr>
if not adjusting BIP158 to BIP37, maybe some other kind of address filter that could be compatible? (it won't help BIP37 then, but might reduce CPU time implementing BIP158 searches still)
< luke-jr>
could that be fixed, or would that hurt BIP158 filters somehow?
< sipa>
luke-jr: to answer your question, you can't compute the intersection between a bloom filter and a bip158 filter, as they use incompatible hash functions
< luke-jr>
sipa: but the current standard for this is BIP37 (and I would expect such bloom filters to be smaller than sending every address?)
< sipa>
and that can definitely be optimized using bip158 filters
< pierre_rochard>
"I think his desire is to allow people to immediately start using LND and the LN wallet using BIP157 filters served from his node while their Bitcoin Core node syncs."
< sipa>
it should be called BIP158, there is no p2p protocol support in there :)
< harding>
gmaxwell: yeah, and any client that supports BIP157 must, by necessity, also support grabbing and parsing full blocks anyway, so supporting grabbing all blocks after a certain height ought to be a trivial addition.
< gmaxwell>
harding: yea okay, I'd even say BIP157/158 is a pretty weak way to accomplish that particular case. ... deploying a new protocol would take a lot of time in the best case, while just fetching the blocks works now against the existing network.
< harding>
I've been trying to use "BIP157" for the filters themselves and "BIP158" for the P2P parts, but it's not always that clearcut.
< harding>
gmaxwell: AFAIU, he just wants some way for people to start using an LN wallet in the SPV trust model while their node syncs. I'm not sure he cares how it happens. I myself don't know why BIP157/158 is entangled in this, except that he might think it's necessary to accomplish that.
< gmaxwell>
I'm not really aware of the twitter stuff (other than having been given that link) ... but my thought for many months is that I'm super excited about having the filters to make rescans usable again... and super concerned about them starting a new wave of bip37 like wallets that just blindly trust things.
< sipa>
only partially related, i think there is a lot of confusion about what "bip157" means; there is (a) the spec, allowing software to implement the filters in a private protocol like wasabi does (b) support for it in bitcoin core via RPC (what the current PRs do) (c) exposing it in core and other software via P2P for trusting peers to use (d) exposing it in core via P2P for non-trusting peers (e) a
< moneyball>
My understanding is that pierre_rochard is focused on onboarding new Bitcoin users via Lightning (with his Lightning Powered Users), and he would like as many of them as possible to run full nodes, but he wants them to be able to use Bitcoin immediately so wants to support BIP157 style light clients. He's also saying if Core doesn't merge support for BIP157, he'd maintain a version of Core with it merged, and run
< harding>
gmaxwell: pierre_rochard maintains an installer that installs Bitcoin Core, LND, and a LN wallet that's capable of using BIP157/158. I think his desire is to allow people to immediately start using LND and the LN wallet using BIP157 filters served from his node while their Bitcoin Core node syncs. That is, I don't think he's talking about hybrid SPV in Bitcoin Core by hybrid SPV via LND/Neutrino/some other wallet.
< gmaxwell>
Can someone explain this tweet people were passing around? https://twitter.com/pierre_rochard/status/1104785795523719169 I don't understand how fullblock spv mode and the BIP157 related PRs are at all compariable/substutiable for each other.
< gribble>
https://github.com/bitcoin/bitcoin/issues/13134 | net: Add option `-enablebip61` to configure sending of BIP61 notifications by laanwj · Pull Request #13134 · bitcoin/bitcoin · GitHub
2019-03-13
< dta_>
bip16?
2019-03-12
< bitcoin-git>
[bitcoin] fanquake opened pull request #15584: build: disable BIP70 support by default (master...disable-bip70-by-default) https://github.com/bitcoin/bitcoin/pull/15584
2019-03-11
< bitcoin-git>
[bitcoin] MarcoFalke merged pull request #15566: cli: replace testnet with chain and return network name as per BIP70. (master...cli-testnet-to-network) https://github.com/bitcoin/bitcoin/pull/15566
< bitcoin-git>
bitcoin/master 890396c fanquake: cli: replace testnet with chain and return network name as per BIP70.
2019-03-09
< bitcoin-git>
[bitcoin] fanquake opened pull request #15566: cli: replace testnet with chain and return network name as per BIP70. (master...cli-testnet-to-network) https://github.com/bitcoin/bitcoin/pull/15566
2019-03-08
< pinheadmz>
thanks guys, going to get the team on BIP130
< sipa>
bip130 is a step being headers-first sync
< sipa>
and with BIP130, new blocks are also announced using headers instead of invs
< pinheadmz>
looking into it now... is the deprecation of getblocks documented? I was about to start work on BIP159 (NETWORK_LIMITED) but maybe I should checkout the existing networkprotocol behavior first. bcoin does send `sendcmpct` and then `getblocks` which will retrieve compact blocks from the peer.
< gmaxwell>
it would be like sticking a warning on BIP69 txn. They're a minority of transactions so in that sense they hurt the user's privacy.
< gmaxwell>
bip69 also just didn't add anything in and of itself, it's not like there was a "this is much better but its inconsistent so don't do it"
< shesek>
re "(esp if everyone isn't suicide packed into never improving)" - for a wallet that wants to maximize its anonymity set, it makes sense to use characteristics that are as common as possible, even if its less ideal for other reasons. for example, payjoin are intentionally trying to avoid uih-2 to enjoy a bigger anonymity set. and some of the arguments against bip69 lexicographical ordering were on a similar basis, that wallets that do
2019-03-07
< wumpus>
I... don't understand why such a high-level discussion of the desirability of those things comes now, while BIP150/151 have existed for ages
< jonasschnelli>
Auth. is BIP150 which is still in discussion
< jonasschnelli>
BIP151 (or the new #) is opportunistic encryption
< jonasschnelli>
Also, there is a BIP150 weakness if used with plain (old) BIP151
< sipa>
jonasschnelli: it looks like you plan to overwrite BIP151... given that it already has a bip number, and you're substantially changing the design, maybe it should be a separate one
< sipa>
(and abandon bip151)
< jonasschnelli>
Though we must discourage to use BIP151
< wumpus>
gmaxwell: I tend to agree at this point, years ago it was differnt but makes sense to prioritize BIP150/151 now
2019-03-06
< andytoshi>
i'd like to start a wiki page or github issue or something to collect a wishlist for a bip174/psbt extension BIP draft. where is the best place to do that?
2019-03-05
< gmaxwell>
mmgen: hardend bip32 is a hash derrived private key, you are spreading disinformation claiming that it has any different security properties.
< mmgen>
gwillen: my concern with bip32 is that is uses ecc, which could be a problem after the advent of quantum computing
<@gwillen>
FWIW I think your tool looks cool, although I am skeptical that your alternative to BIP32 is an improvement but I'd be interested to hear about the motivation behind it (but not in this channel, perhaps #bitcoin-dev would accept such a conversation)
< jonasschnelli>
Which shows a tendency that something like BIP151 may speed up processing performance on ARM... especially small packets
< luke-jr>
rafalcpp: this is not a BIPable topic
2019-03-04
< jonasschnelli>
The current BIP151 way is ECDH_SECRET->HKDF->k1 for AAD encryption, ECDH->HKDF->k2 for the payload encryption
2019-03-01
< provoostenator>
Although it would be safer when combined with native-descriptor wallets, because the behavior of getnewaddress doesn't jive well with BIP44/49/84 that wallets use.
2019-02-26
< bitcoin-git>
[bitcoin] MarcoFalke closed pull request #13972: Remove 16 bits from versionbits signalling system (BIP320) (master...reservedbits2) https://github.com/bitcoin/bitcoin/pull/13972
< bitcoin-git>
[bitcoin] MarcoFalke reopened pull request #13972: Remove 16 bits from versionbits signalling system (BIP320) (master...reservedbits2) https://github.com/bitcoin/bitcoin/pull/13972
< gribble>
https://github.com/bitcoin/bitcoin/issues/15482 | Implement BIPXXXs new softfork rules (The Great Consensus Cleanup) by TheBlueMatt · Pull Request #15482 · bitcoin/bitcoin · GitHub
2019-02-25
< bitcoin-git>
[bitcoin] TheBlueMatt opened pull request #15482: Implement BIPXXX's new softfork rules (The Great Consensus Cleanup) (master...2019-02-great-consensus-cleanup) https://github.com/bitcoin/bitcoin/pull/15482
< sipa>
bip32 derived keys are always compressed
< sipa>
but xpub serializations always uses compressed... so integrating bip32 with uncompressed keys seems hard in any case
< sipa>
and bip32 only supports compressed keys, iirc
< dongcarl>
For BIP32, is the identifier the Hash160 of the compressed or uncompressed serialization of the ECDSA public key?
< MarcoFalke>
BIP320 could make sense to make it explicit, but that can be done for 0.19 or not at all
< wumpus>
I also wonder how much it matters, it's not that BIP9 is reliable anymore for those bits
< MarcoFalke>
Is there any chance that there will be a softfork deployed not via BIP9?
< provoostenator>
The nUpgraded warning says "It's possible unknown rules are in effect", but that's only possible if a lower threshold or some other upgrade mechanism than BIP9 is introduced.
< provoostenator>
If we change that to tracking each bit individually, then there wouuld have been no alerts expect for SegWit and BIP91.
2019-02-19
< provoostenator>
In addition I think the same or a similar dialog can be used to recover wallets. Could be loading a wallet dump file, entering some descriptors or even bip39 phrases.
2019-02-18
< palfun>
luke-jr: right, so importing "used" bip32 wallets will be slow to detect all previous usage. does that still get done automatically, do I kick that off, or do it manually?
< palfun>
so for the bip32 case, you'd just feed it your first 20 addresses, see what turns up, and then proceed as appropriate
< luke-jr>
you mean server-side for BIP37, right?
< sipa>
bip37 is server side filtering
< sipa>
bip37 allows client-side filtering (it has severe privacy concerns, and is not advised), or client-side filtering (bip157, which is still new)
< palfun>
wait, but, then how do bip32 wallet clients work? they need to scan large amounts of addresses for outputs/transaction history right?
< jarthur>
bitcoinEnthusias: the BIPs are designed to be readable and reviewable, and Python tends to work well for that.
< jarthur>
bitcoinEnthusias: on the protocol side, sipa has been organizing a BIP for Schnorr signatures. It hasn't officially been proposed yet, and typically an implementation would follow a proposal. https://github.com/sipa/bips/blob/bip-schnorr/bip-schnorr.mediawiki if you want to see the current state. bitcoin-dev mailing list a fine place to discuss the proposal
< luke-jr>
wumpus: BIP150/151 solve authentication when they're finally done, but I don't see any better solution for dynamic IPs and NAT traversal (when UPnP/NAT-PMP are unavailable).. at the end of the day, I'm not sure it makes sense to reinvent what already exists
< provoostenator>
Agreed, the combination of PMP/UPNP and ~BIP150 seems a more precise tool for this job.
< gmaxwell>
technically BIP150 (or whatever replaces it... sipa and I really need to finish that)
< wumpus>
also I've always believed the way forward would be to improve the bitcoin protocol itself; BIP150/151, Dandelion, as well as lightning onion routing
< bitcoin-git>
[bitcoin] MarcoFalke opened pull request #15411: travis: Combine --disable-bip70 into existing job (master...Mf1902-travisBIP70) https://github.com/bitcoin/bitcoin/pull/15411
< bitcoin-git>
[bitcoin] jonasschnelli merged pull request #15063: GUI: If BIP70 is disabled, attempt to fall back to BIP21 parsing (master...bip70_fallback_to_bip21) https://github.com/bitcoin/bitcoin/pull/15063
< bitcoin-git>
bitcoin/master 84f5315 Luke Dashjr: Travis: Add test without BIP70 (but still full wallet + tests)
< bitcoin-git>
bitcoin/master 113f000 Luke Dashjr: GUI: If BIP70 is disabled, give a proper error when trying to open a payme...
< bitcoin-git>
bitcoin/master 9975282 Luke Dashjr: GUI: If BIP70 is disabled, attempt to fall back to BIP21 parsing
2019-02-13
< sipa>
it's testing that pushing a script hash using the OP_PUSHDATA opcodes doesn't cause it to be detected as P2SH (because BIP16 gives the exact encoding)
< sipa>
but something like bip32 is already somewhat harder to do for ed25519
2019-02-07
< jl2012>
in BIP143, out-of-bound SINGLE is treated like NONE
< stevenroose>
luke-jr: people don't like BIP70, though :)
2019-01-28
< luke-jr>
stevenroose: BIP70 had chain ids as strings
< stevenroose>
I think magic bytes are quite solid. More available in implementations than BIP44 coin type ids, f.e..
< stevenroose>
I could do network magic bytes, psbt prefix, BIP44 coin type id, base58check address prefix byte (f.e. fixed at p2pkh), ... Address-specific ones are probably very bad.
2019-01-25
< gmaxwell>
talk of multiwallet gui makes me wonder if anyone is working on using BIP157 filters for rescan? Personally I found multiwallet not super useful, due to the need to rescan wallets that were left unloaded, and it taking 8 hours to do so...
2019-01-24
< sipa>
so you can use hardened bip32 keys as descriptor; they need access to the private key to derive, but not to otherwise use
< gmaxwell>
They are but they need to be part of any BIP70 alternative that doesn't immediately broadcast txn.
< gmaxwell>
At the time BIP70 was written, the only 'used' metric bitcoin core really had was "spent by the mempool"
< gmaxwell>
BIP70 could have been defined that way, varrious people advocated for it.
2019-01-09
< gmaxwell>
roasbeef: their bip70 violates the spec and can't be used with bitcoin core regardless.
< roasbeef>
luke-jr: orly? iirc they enforce it and there's no other way to pay them other than via bip70
< luke-jr>
phantomcircuit: BitPay isn't even BIP70-compatible
< phantomcircuit>
gmaxwell, as far as i know literally only bitpay uses bip70
< gmaxwell>
yea, I think bip70 as an external program would be nice, except no one cares about it...
< echeveria>
if this was my software I'd be putting a bounty in the bip70 payment window to see if anybody notices it. you found the secret bit! send a letter to this address and we'll mail you a prize!
< echeveria>
gmaxwell: sipa: bip70 could kinda be a different binary at this point, but I don't think it's level of use justifies any sort of investment in development.
< gmaxwell>
Also BIP70s implementation inherently had to be run from a wallet.
< provoostenator>
BIP70 is depreacted so depending on when disaster happens, we could then just ship a new binary with OpenSSL removed.
< gmaxwell>
via bip 70 though it could actually introduce vulnerabilities, though thats really a question about getting rid of bip70, not openssl.
< gmaxwell>
[ignoring BIP70] Now we're just stuck issuing new binaries the next time there is some zomg panic about openssl because we statically link to it.
2019-01-03
< jamesob>
oops I'm sorry -- that jimpo PR isn't critical path for BIP157; I meant #14085
< jamesob>
can I nominate jimpo's BIP157/8-related PRs that've been hanging out for a while? maybe starting with #14111?
2018-12-30
< bitcoin-git>
[bitcoin] luke-jr opened pull request #15064: [PoC] GUI: Migrate BIP70 merchant info to mapValue["to"] (master...bip70_merchant_to_to) https://github.com/bitcoin/bitcoin/pull/15064
< bitcoin-git>
[bitcoin] luke-jr opened pull request #15063: GUI: If BIP70 is disabled, attempt to fall back to BIP21 parsing (master...bip70_fallback_to_bip21) https://github.com/bitcoin/bitcoin/pull/15063
< gmaxwell>
Perhaps because they realized if they kept it up BIP37 was just going to end up removed and then they'd lose their toy. Who knows.
< gmaxwell>
roasbeef: quite a few nodes just disable BIP37 completely (which seemed to stop the BIP37 based attacks)
< roasbeef>
it's a win for full nodes at least, serving the filters is much less intensive (and also stateless) compared to serving bip37, you also can't trigger worst case matching behavior over the entire chain
< gmaxwell>
One should also consider the effect of incentiving varrious kinds of trouble making. (like generally we've found that when we added vulnerablities like BIP37 attackers emerged that didn't exist previously, and then made more trouble even for people that didn't care about using BIP37)
< gmaxwell>
I'm very glad, e.g. that nothing about BIP37 ended up softforked in... that protocol turned out to be a lemon in a number of ways, but it took a couple years of use to realize that.
< sipa>
it's pretty trivial to do, but mucb easier to get agreement on once bip157 itself is deployed and used
2018-12-20
< jonasschnelli>
I think the initial design came from the two step BIP151 handshare where v1 protocol was required for the initial messages
< jonasschnelli>
So there could be two serialization instance (legacy p2p and BIP151 p2p) where each node would hold a shared pointer to that instance?
< gmaxwell>
phantomcircuit: indeed. But for that case, you'd still probably be just as well off with bip157 filters on disk, and sequential scanning those.
< sipa>
provoostenator: yes, i think BIP157 may be useful for a new class of clients that may become popular
< gmaxwell>
(it's worse because it takes a client more time to scan the chain than with BIP37, as it has to get quite a bit more data)
< gmaxwell>
and that doesn't really have anything to do with bip158 vs bip37.
< gmaxwell>
(in fact BIP158 is somewhat worse, but slightly less of a privacy disaster)
< jamesob>
good point - but I guess if existing light wallets switched to bip157 it'd at least ease load on existing full nodes
< provoostenator>
gmawell is that _because_ of bip158 or just because there aren't that many developers working on light (non web, non electrum) wallets? That could change over time.
< gmaxwell>
jamesob: history has shown otherwise, bip158 doesn't make lite wallets fundimentally more usable than they are now. They're still massively worse than server driven wallets like electrum or web wallets.
< sipa>
luke-jr: BIP158 helps our local wallet too
< jamesob>
are any of the BIP157/158 PRs on the high prio list? if not, they should be
< gmaxwell>
jonasschnelli: e.g. saved the bip157 filters locally, and scan against them.
< provoostenator>
jonasschnelli: BIP44 recovery can be handled once we have descriptor support for importmulti and slightly more sane behavior (or a replacement for) the keypool.
< jonasschnelli>
Sadly people expect fast BIP44 recovery (incl. history). This seems to be the most prominent real-world usecase for an address index
2018-12-07
< sipa>
jamesob: i think bip157/158 are great
< jamesob>
it sounds like BIP-0157/0158 would go a long way towards the scan approach which is also something I'd like to talk about at some point... is anyone aware of any outstanding concerns with these BIPs and any reason we shouldn't be pushing forward on jimpo's related PRs?
2018-12-06
< bitcoin-git>
[bitcoin] MarcoFalke closed pull request #14564: Adjust configure so that only bip70 is disabled when protobuf is missing instead of the GUI (master...bip70-disable-check) https://github.com/bitcoin/bitcoin/pull/14564
< bitcoin-git>
bitcoin/master 23a1fa0 MarcoFalke: Merge #14564: Adjust configure so that only bip70 is disabled when protobuf is missing instead of the GUI...
< bitcoin-git>
bitcoin/master 58c5cc9 James Hilliard: Adjust configure so that only bip70 is disabled when protobuf is missing instead of the GUI
2018-11-30
< provoostenator>
By default we ask for a standard BIP44/49/84 path
< luke-jr>
[17:57:13] <gmaxwell> We could, in the future, introduce a replacement to that rpc that does it implicitly, for example. <-- breaking all compatibility with the BIPs and existing software? :/
2018-11-19
< gmaxwell>
It just sounded vaguely related to me (new distro + bip70 + crash on start)
< BlueMatt>
anyway, can I just remove bip70 now? :p
< gmaxwell>
sipa: which is technically a violation of BIP125.
2018-11-07
< provoostenator>
This in the case of a wallet with no private keys. Yes, the bip32 bool at the end is true
2018-11-03
< provoostenator>
BIP157 does make sense as a faster-enough alternative to an address index for the above use case.
< sipa>
with bip157 it's also much less needed
2018-11-01
< warren>
sipa: "<sipa> warren: BIP150/BIP151 just need a bit of entropy at connect time" ... but connect time is an event triggered by arbitrary network connections.
2018-10-31
< sipa>
warren: BIP150/BIP151 just need a bit of entropy at connect time
< warren>
sipa: Is it fast enough to supply randomness for BIP150 and BIP151 when they happen later? (I'm not sure how demanding they are.)
2018-10-27
< bitcoin-git>
[bitcoin] MarcoFalke reopened pull request #14564: Adjust configure so that only bip70 is disabled when protobuf is missing instead of the GUI (master...bip70-disable-check) https://github.com/bitcoin/bitcoin/pull/14564
< bitcoin-git>
[bitcoin] MarcoFalke closed pull request #14564: Adjust configure so that only bip70 is disabled when protobuf is missing instead of the GUI (master...bip70-disable-check) https://github.com/bitcoin/bitcoin/pull/14564
2018-10-26
< wumpus>
also it gives future BIPs that want to use that bit something to refer to, that they can reclaim it
2018-10-25
< gmaxwell>
Until BIP70 is gone we're stuck with openssl regardless. we lost urgency on discontinuing using openssl as a randomness input after bitpay started requiring BIP70 to make payments.
< warren>
I am encouraged that #14451 happened, deprecating BIP70 (huge attack surface, nobody uses it etc.) This means we will eventually be able to remove the openssl dependency. Except for that part.
< gribble>
https://github.com/bitcoin/bitcoin/issues/14451 | Add BIP70 deprecation warning and allow building GUI without BIP70 support by jameshilliard · Pull Request #14451 · bitcoin/bitcoin · GitHub
< warren>
topic proposal: Interested in opinions regarding the risk of bringing back Fortuna. Along with deprecation of BIP70, we are on the path toward eventual removal of the openssl dependency.
< bitcoin-git>
[bitcoin] jameshilliard opened pull request #14564: Adjust configure so that only bip70 is disabled when protobuf is missing instead of the GUI (master...bip70-disable-check) https://github.com/bitcoin/bitcoin/pull/14564
2018-10-24
< luke-jr>
not building bitcoin-qt seems a bit extreme though; might make sense to refactor configure to just change the bip70 option
< gribble>
https://github.com/bitcoin/bitcoin/issues/14451 | Add BIP70 deprecation warning and allow building GUI without BIP70 support by jameshilliard · Pull Request #14451 · bitcoin/bitcoin · GitHub
< bitcoin-git>
[bitcoin] laanwj closed pull request #14451: Add BIP70 deprecation warning and allow building GUI without BIP70 support (master...deprecate-bip70) https://github.com/bitcoin/bitcoin/pull/14451
< bitcoin-git>
bitcoin/master 38b9850 Wladimir J. van der Laan: qt: cleanup: Move BIP70 functions together in paymentserver...
< bitcoin-git>
bitcoin/master fbb643d James Hilliard: Add BIP70 deprecation warning
< bitcoin-git>
bitcoin/master 9dcf6c0 Wladimir J. van der Laan: build: Add --disable-bip70 configure option...
2018-10-18
< wumpus>
hehe yes BIP42
< gmaxwell>
certantly ignorance about the GUI contributes to problems in the software already... (see my above comment that there were _developers_ that though request payment was bip70).
< gmaxwell>
Re "request payment" being confusing, I had an argument with multiple people _in here_ because they believed "Request Payment" was somehow BIP70. So I think it's not disputable that its confusing. :P
2018-10-16
< achow101>
kallewoof: sipa: is it possible that pruned chainstates cannot compute bip9 status?
< sipa>
kallewoof: it should be implementing bip9 exactly
< kallewoof>
How does bitcoin core track bip9 activation states? I have odd cases where a copied chain state will result in all bip9 soft forks turning up as "failed" rather than "activated". If I disable the timeout, they show up as 'started', but with 'possible: false'.
2018-10-12
< Zx3Si>
bipul: achieves the output you want, but my guess is it's not what you want diff -u file1 file2 | awk "NR>3" | grep -E "Header|^-|^\+" | sed -r 's|^.||'
2018-10-11
< TD-Linux>
no I don't care about bip70, I meant plain addresses
< echeveria>
TD-Linux: a good rule of thumb is that literally nothing uses, or supports BIP70 other than Bitpay. it'd be nice to show addresses in that form I suppose, generally well labeled they're usable in the transaction list but only if it was a simple transaction paying it.
< provoostenator>
TD-Linux: BIP70 uses BIP21 style URI's. An app that can handle bitcoin:... may or may not support BIP70, usually not.
< TD-Linux>
echeveria, it pops up a text box with a bip20 uri and an address in the same box
< echeveria>
TD-Linux: it honestly doesn't even show you a BIP20 URI as anything but an options.
< sipa>
TD-Linux: you mean bip20?
< TD-Linux>
oh bip20
< TD-Linux>
yeah I looked in bip70 and saw bitcoin:
< TD-Linux>
gmaxwell, it generates bip70 bitcoin: urls
< gmaxwell>
it doesn't support generating BIP70 invoices.
< gmaxwell>
it's important to keep in mind that BIP-158 is not private either, it basically has the level of non-privacy bip37 was claimed/intended to have but bip37 turned out a lot worse than intended for several reasons.
2018-09-26
< andytoshi>
sipa: verification and bip32 operations all care about the EC identity
< sipa>
andytoshi: my view is that compressed and uncompressed are both legal inside bip174, but it's up to each signer/updater/... to choose what they support anyway; some may only support compressed keys
< sipa>
it's also not all that clear in bip32... it just only talks about serialization using compressed form
< achow101>
bip32 is defined for compressed keys only though, so you should only use compressed keys in the bip32 derivs
< kallewoof>
jimpo: reading https://github.com/bitcoin/bips/pull/725#pullrequestreview-154741923 it looks like you're suggesting the proof of funds should be a (fakeish) transaction, and the messsage signing should not be. Am I understanding that right? If so, it seems like you could just do transaction in both cases to simplify the spec. I.e. for signing message, craft two txs with the latter spending the former and former using
< kallewoof>
Johnson Lau is suggesting reserving OP_MESSAGEONLY = 0xf0 as opcode for message signing, or alternatively "OP_RETURN msgXXX". It feels wasteful to take an opcode, but feedback would be nice: https://github.com/bitcoin/bips/pull/725#issuecomment-420421058
2018-09-11
< EucOcVrFfr2D>
The expected result in that test is equal to the input, the author @achow101 wanted to make sure bitcoind doesn't 'crash' on that scenario but it silently moves on. The scenario is when we're trying to sign a PSBT input but one of the requirement fails -> https://github.com/bitcoin/bips/blame/master/bip-0174.mediawiki#L342
< wumpus>
but if you really want to take on deprecating BIP70 with bitpay against you, I'll support you, but it's not something I want to take up, I don't have the motivation nor energy
< achow101>
no, bip44 uses unhardened derivation. Core uses all hardened
< kallewoof>
Several people on https://github.com/bitcoin/bips/pull/725 (Generic Signed Message Format) are suggesting I use a fake tx that the prover simply signs. I'm not sure what the benefits of doing this are, though..
2018-09-08
< jl2012>
Jmabsd: no. An input may have witness only if it is native segwit or P2SH-segwit (see BIP141)
2018-09-06
< jonasschnelli>
And I just looked up, ... there is no "clear" standard for derivation path (BIP32 doesn't mention it specific)
2018-08-30
< kanzure>
topic: i am collecting topics for coredevtech tokyo; please submit topic suggestions to me, things that you would like to speak about, or things that you would prefer others to speak about, could be anything from source code things to BIPs to mailing list stuff, or complaints about twitter.
2018-08-29
< jonasschnelli>
What sipa said with the disclaimer, that censorship-resistant is not the goal of BIP151
< gmaxwell>
BIP151 sends a 32 byte pubkey, not a 33 byte one. Right? so a test that gives a junk value to the first byte doesn't actually test any case that could be triggered by BIP151. (though it's fine to test that too) The test I'm going for is an x value not on the curve, since failing to check that is a common implementation bug in ECDH implementations.
< Chris_Stewart_5>
BIP157 seems to have the semantics for that
< Chris_Stewart_5>
Hmm, is that only BIP158 though? I don't think that BIP158 includes any p2p networking stuff
< Chris_Stewart_5>
instagibbs: So that is just a refactor PR to make it easier to implement BIP157 right?
< Chris_Stewart_5>
BIP157 doesn't currently have an open PR does it?
2018-08-24
< sipa>
roasbeef: BIP157 will improve things further, i assume?
< gmaxwell>
I never read that stuff, it's not normative (doesn't change the meaning of the datastructures), and expirence from other BIPs suggests tha people ignore them. (see, for example BIP32)
< sipa>
(like bip157)
2018-08-23
< gmaxwell>
e.g. bip32 key derrivation went unused for years.
< sipa>
BIP32 derivation was in the codebase for 3 years before being used :)
< jonasschnelli>
importing keys seems meh-ish for hardware-wallet. IMO the ideal use case for BIP32 pub key derivation
2018-08-22
< MarcoFalke>
you could first push the current master and then rebase the bip151 branch on that?
< MarcoFalke>
hmm, might be related to some bip151 changes?
< jonasschnelli>
Its all on my BIP151 branch
2018-08-11
< jonasschnelli>
I'm going to write an overhaul of BIP151 (I hope nobody complain since it initial draft has been published via the BIPS long long ago). I know Armory has a complete implementation and they may not like the fact that they need to rewrite some parts
< jonasschnelli>
gmaxwell: BIP151 currently require that both peers initiate a ECDH handshake. There are two secrets (one for incomming one for outgoind encryption)
< jonasschnelli>
I think the BIP151 proposed handshake requires some overhaul
2018-08-08
< jonasschnelli>
But we all want to see progress on BIP157...
< satwo>
Hi all. BIP-141 defines 4 ways to measure the size of a transaction: weight, virtual size, base size, and total size. Bitcoin-cli decoderawtransaction returns weight, vsize ("virtual size" - obvious), and size (“total size" - not obvious). I must not be the only one to have found it nontrivial to figure out how base size, total size in BIP141 and “size” in RPC are related. Even once one figures out that “BIP 141
2018-07-22
< bitcoin-git>
[bitcoin] DrahtBot reopened pull request #12676: Show "bip125-replaceable" flag, when retrieving mempool entries (master...rpc-raw-replaceable-flag) https://github.com/bitcoin/bitcoin/pull/12676
< jonasschnelli>
Thinking practical: assume I haven a xpub and I'd like to find funds via scantxoutset (gap limit not possible)... would it make sense to scan for all non hardened keys (assume BIP44 has been used)?
2018-07-18
< sipa>
can anyone still access the BIP174 PR without getting a unicorn?
< cfields>
gmaxwell: as described, bip151 would require us to send the first bytes up for parsing, then have the message handler tell the net handler to deal with encryption from that point on. If encryption could be assumed, net could just handle it transparently.
< gmaxwell>
that sounds silly now, but in two years when 99% of everything has BIP151 it'll be reasonable.
< echeveria>
jonasschnelli: gmaxwell: cfields: personally I'd do something a little more interesting. bind a new socket, say 8383 and *only* accept encrypted connections there. older implementations explicitly avoid non-standard ports, and it gives the option to selectively only use bip151.
< jonasschnelli>
(if non BIP151 supporting peer)
< gmaxwell>
but we're certantly not going to make BIP151 do that. :P
< jonasschnelli>
Okay. If no one else wants to work on the implementation, I will continue then with BIP151 impl.
< jonasschnelli>
cfields: I think BIP151 is almost final (there is some issues with the version handshake)... the only thing that was holding me back where possible network refactors to first wait for
< jonasschnelli>
I think following BIP32 for "hot" wallets with private key export options is not ideal... Electrum does that as example
< jonasschnelli>
The BIP32 based derivation scheme has that security risk
< jonasschnelli>
Some people think its vanilla/native BIP32... but its not... while other do native BIP32
< jonasschnelli>
It came up today in a discussion: Cores BIP32 derivation scheme is not specified in a BIP
< jonasschnelli>
I have a specification draft for a new seed format similar to BIP39 with some neat properties and – before sending to the ML – would appreciate feedback.
< jonasschnelli>
I have two topic requests: a) Cipherseed, b) Cores BIP32 derivation "standard"
< cornfeedhobo>
before i open an issue, could someone look at the french bip39 wordlist and tell me if they see the weird first byte artifact?
2018-06-19
< achow101>
no. there can be multiple bip32 derivation paths, each corresponding to a different key
< jonasschnelli>
achow101: again for my clarification (sorry if I'm bothering you): using the 0x03 type (BIP32 derivation path) would mean, that each Co-Signer (in case of a multisig) would require to use the same masterkey (if we assume they have no capabilities to derive keys based on just the pubkey)?
< achow101>
the pubkey is the key of the KV pair for bip32 derivation paths. so I just worded it to refer to that pubkey
< achow101>
jonasschnelli: not having a bip32 derivation path entry is completely fine. The signers just need to parse the redeemscript for that input to figure out what keys are required and check whether they have them
< jonasschnelli>
achow101: I was just playing an example in my head where cosigner would not share xpubs (not BIP45) since sharing the xpub is a security and privacy risk...
< jonasschnelli>
Would that make sense to have a such field? or allow BIP32 keypath without fingerprint/master key reference?
< jonasschnelli>
Though, we assume now, they are using BIP45 or another deterministic MS address generation scheme...
< jonasschnelli>
achow101: would she just not provide the BIP32 derivation key/value?
< achow101>
a) in the bip45 case, the path would be sufficient. but bip45 is not guaranteed
< jonasschnelli>
By taking the global BIP32 keypath but not looking at the fingerprint/masterkey?
< jonasschnelli>
achow101: so in multisig accoding to Bip45 or similar, this information (BIP32 derivation path) would be of no value to the signers, right?
< jonasschnelli>
Regarding BIP174 (PSBT), the BIP32 derivation path is global, does that mean that each Co-Signer must use the same master key? Or is that global value per PSBT file which is per co-signer different?
2018-06-13
< sipa>
one is that it's not compatible with bip158 based rescanning where you must know the exact scriptPubKeys you're looking for)
< BlueMatt>
oh, quick comment: if you have had ideas about things you want to fork into the protocol in the future, *please* read https://github.com/TheBlueMatt/bips/blob/betterhash/bip-XXXX.mediawiki and make sure that your ideas can be added without protocol modifications so that miners dont need firmware updates
< jonasschnelli>
My core i7 can do 31’775 operations per seconds where an operation is bech32-decode->bip32-ckd->hash160->base58check
< jonasschnelli>
sipa, gmaxwell: guess how long it takes to compute m/0 for possible 4 invalid chars (bech32 decode & bip32 pckd, hash160 base58check)?
2018-05-31
< sipa>
echeveria: you mean BIP34 i assume; yes, except for the first few blocks
< echeveria>
sipa isn't it more than 2 now with BIP30?
<@wumpus>
Chris_Stewart_5: there's no requirement on the coinbase data except for BIP34 afaik
2018-05-30
< achow101>
gmaxwell: a few people have been looking at it and have sent me comments. I have made some changes to the spec since the original was added to the bips repo
2018-05-29
< bitcoin-git>
[bitcoin] laanwj closed pull request #13134: net: Add option `-enablebip61` to configure sending of BIP61 notifications (master...2018_05_optional_bip61) https://github.com/bitcoin/bitcoin/pull/13134
< bitcoin-git>
bitcoin/master 70d3541 Wladimir J. van der Laan: Merge #13134: net: Add option `-enablebip61` to configure sending of BIP61 notifications...
< bitcoin-git>
bitcoin/master fe16dd8 Wladimir J. van der Laan: net: Add option `-enablebip61` to configure sending of BIP61 notifications...
< bitcoin-git>
bitcoin/master 87fe292 Wladimir J. van der Laan: doc: Mention disabling BIP61 in bips.md
< * sipa>
hopes bip174 will help
< jonasschnelli>
BIP174 is a great basepoint...
2018-05-28
< gmaxwell>
with the BIP39 thing someone could also keep demanding your other passphrase while you protest that there isn't one.
< jonasschnelli>
if you have two macs, an attacker could ask for both passphrases,.. while the current BIP39 approach, there are "infinite" possibilities
< gmaxwell>
the BIP39 problem but somewhat less dumb.
< roasbeef>
yes atm it's 128-bits, the current params allow everything to be encoded in 24 words, as to still be familiar w/ users of bip39
< sipa>
jonasschnelli: bip173 addresses are at most 74 characters