Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Monero Research Lab Meeting - Wed 08 January 2025, 17:00 UTC #1138

Open
Rucknium opened this issue Jan 7, 2025 · 1 comment
Open

Monero Research Lab Meeting - Wed 08 January 2025, 17:00 UTC #1138

Rucknium opened this issue Jan 7, 2025 · 1 comment

Comments

@Rucknium
Copy link

Rucknium commented Jan 7, 2025

Location: Libera.chat, #monero-research-lab | Matrix

Time: 17:00 UTC Check in your timezone

Main discussion topics:

  1. Greetings

  2. Updates. What is everyone working on?

  3. Discussion: Post-quantum security and ethical considerations over elliptic curve cryptography

  4. Any other business

  5. Confirm next meeting agenda

Please comment on GitHub in advance of the meeting if you would like to propose an agenda item.

Logs will be posted here after the meeting.

Meeting chairperson: Rucknium

Previous meeting agenda/logs:

#1134

@Rucknium
Copy link
Author

Rucknium commented Jan 9, 2025

Logs

< r​ucknium:monero.social > Meeting time! #1138

< r​ucknium:monero.social > 1) Greetings

< c​haser:monero.social > hello

< v​tnerd:monero.social > Hi

< rbrunner > Hello

< a​rticmine:monero.social > Hi

< j​berman:monero.social > waves

< r​ucknium:monero.social > 2) Updates. What is everyone working on?

< s​yntheticbird:monero.social > Hello

< r​ucknium:monero.social > me: Finishing up milestone 3 of my OSPEAD CCS.

< r​ucknium:monero.social > jeffro256 in case you need a meeting time reminder.

< v​tnerd:monero.social > working on typing another ccs, I’ll likely finally do another one soon

< r​ucknium:monero.social > 3) Discussion: Post-quantum security and ethical considerations over elliptic curve cryptography monero-project/research-lab#131

< r​ucknium:monero.social > I think jeffro256 wanted to discuss something about Carrot and its extra bits when self-sending.

< s​yntheticbird:monero.social > Last time Jeffro talked about monero-project/research-lab#106, as being a quick solution to get post quantum security for monero. However, i still agree with kayabanerve, i hate this UX

< j​berman:monero.social > my update: continuing integrating FCMP++ prove

< s​yntheticbird:monero.social > I think compared to december meeting, we stoped talking about economic viability/amount security with a QC. Afaik FCMP++ doesn't prevent a QC to double spend, iiuc the switch commitment revision for Carrot doesn't address this or help at addressing this?

< r​ucknium:monero.social > I thought that the Carrot switch commitments were proposed to help prevent quantum counterfeiting, in combination with more steps that would have to be taken.

< rbrunner > I don't remember anything so specific about these things, thus I am no help there ...

< r​ucknium:monero.social > With the proposal in MRL issue 106, all transactions would have to have off-chain communication, right? It could not be opt-in like Carrot, correct?

< c​haser:monero.social > FCMP++/Carrot alone can't prevent quantum counterfeiting. I think Jeffro talked about modifying Carrot to prepare the future introduction of switch commitments.

< s​yntheticbird:monero.social > Chaser Rucknium, yes, switch commitment is here to prepare a migration to a pq resistance for amount. But I don't remember it addressing the double spend issue, since a QC can forge two outputs with the same key image.

< v​tnerd:monero.social > why the sudden concern about QC? the hype over recent Google claims? Haven’t they always over-stated QC capabilities (scammers)? Anyway switch commitments don’t really help with counterfeiting unfortunately. They simply allow us to safely “reveal” amounts as we transition to a new system

< s​yntheticbird:monero.social > Yes.

< s​yntheticbird:monero.social > Anticipating worst case scenario. Kayabanerve and other share these concerns. We also have to assume governments might have better advancements in quantum computing than private companies.

< r​ucknium:monero.social > vtnerd: From what I've observed, you can almost draw a separating line between those who are concerned about QC and those who are not, based on age.

< rbrunner > Based on age? Indeed?

< r​ucknium:monero.social > This is my observation as a social scientists hahaha

< r​ucknium:monero.social > Age is strongly correlated with experience, of course

< rbrunner > So old people must mostly not fear those QC, because I am firmly in that camp :)

< j​effro256:monero.social > So sorry I'm late....

< rbrunner > But well, what was described seemed like a pretty cheap thing to have, in comparison, which would help just in case they do arrive

< s​yntheticbird:monero.social > To copy what i said in my mrl issue. It's not a matter of "will we be ready for QC era" but also "we should be ready N years prior to avoid people being in trouble in face of law retroactively, as the current blockchain will be transparent"

< s​yntheticbird:monero.social > In most countries the statute of limitations is of minimum 10 years

< c​haser:monero.social > vtnerd: I think Kayaba's recommendation in their stepping-back note is what created this momentum for the QC theme. personally, I was always concerned, and I think any opportunity is the best yet to start tackling the potential threat.

< s​yntheticbird:monero.social > so we should be PQ 10 years before

< v​tnerd:monero.social > and to clarify on my previous comment, old amounts are “statistical bound” (via hash) to a value, so you cannot create money in old transactions, assume hashes are not broken by QC. IIRC, you could theoretically inflate just before the turnstile/reveal was made mandatory

< v​tnerd:monero.social > so presumably this is why some people dont like switch commitments, a secret ECDLP solver is still wrecking havoc

< a​rticmine:monero.social > I don't see a reason for panic, but given the likely timelines on our, realistically ~ 5 years minimum for a QC main chain HF starting the research and work now is just prudent.

< a​rticmine:monero.social > Our end

< j​effro256:monero.social > Carrot has a 16 byte field per enote called the anchor which is required for normal transfers, but is unused for change outputs and other selfsends (when using the new Carrot key hierarchy). We can use this field to send encrypted transaction memos for free. The question is whether or not we should expose this feature to users to put arbitrary data in there, since a quantum comput<clipped messag

< j​effro256:monero.social > er may come along and decrypt it at some point

< v​tnerd:monero.social > this is insane, we stopped seraphis for fcmp++ to suddenly just drop all the work?

< s​yntheticbird:monero.social > ? we're not planning on dropping fcmp++

< v​tnerd:monero.social > ok, I guess just some people dropped out (temporarily), not the entire thing stopping. Misread the room a bit

< v​tnerd:monero.social > just skimmed through the Ruffing paper on QC, my understanding seems correct if others could follow it

< c​haser:monero.social > FCMP++ is still full steam ahead, from what I gather.

< v​tnerd:monero.social > *on switch commitments

< r​ucknium:monero.social > AFAIK, the plan is still to activate FCMP, hopefully this year. kayabaNerve suggested that after its activation, non-QC-resistant cryptography should not be on the Monero research agenda. Instead, QC-resistant cryptography should be researched.

< c​haser:monero.social > I would be for not exposing that field for such. broken crypto and security bugs could both make a lot of privacy mess out of on-chain memos.

< j​effro256:monero.social > Switch commitments alone can't prevent counterfeiting in Monero, we also nee the key images to be intact. However, they are a crucial component of preventing counterfeiting in the future

< k​ayabanerve:matrix.org > vtnerd: The issue today is to set up integrity even against a QC. There's minimal changes which can be made now which prevent a QC from counterfeiting years from now, and means anyone who uses a wallet made next year won't be at risk at having their funds burnt.

< k​ayabanerve:matrix.org > Yes, the old protocol has to be turned off before a QC becomes active for integrity. The migration scheme would withstand a QC.

< rbrunner > I don't remember, was the hope that we could get those switch commitments into "the" hardfork to FCMP++, in about a year?

< rbrunner > If we don't take too long to research and decide of course ...

< v​tnerd:monero.social > yes, I think the plan was to incorporate switch commitments into the fcmp++ fork

< k​ayabanerve:matrix.org > The rest can be done without a hard fork.

< j​effro256:monero.social > This is correct: mainly switch commitments + key image binding proofs would prevent counterfeiting. Then, we also need PQ resistant proofs of opening of pubkeys to prevent theft

< j​effro256:monero.social > But strictly speaking, if we didn't care about theft, just inflation, we just need switch commitments and key images to be statistically binding

< k​ayabanerve:matrix.org > jeffro256: If the 16 bytes is only for change outputs and uses a key not at risk to a quantum adversary who has your address, I don't see the issue.

< k​ayabanerve:matrix.org > If a quantum adversary with your address can recover these messages, I don't believe we should represent Monero as a private messenger, even njst to yourself. It's reckless and unsafe.

< k​ayabanerve:matrix.org > *just to yourself

< rbrunner > Maybe it will be a bit hard to become really sure those switch commitments do what we hope for, but maybe we could ask the opposite question: Could something go seriously wrong if we add them?

< rbrunner > Right now we don't have any candidates for something else to add instead, do we?

< r​ucknium:monero.social > jeffro256: Say I'm a merchant. My database gets corrupted and I have to sync my wallet from its seed words. I hope to recover my accounting records as much as possible. Could those 16 bytes help me at all? AFAIK, the status quo is that I lose the addresses that I sent funds to.

< r​ucknium:monero.social > By "database" I mean wallet cache file and associated records in my payment system.

< k​ayabanerve:matrix.org > rbrunner: it's an additional hash of the randomness. It can't go wrong. We also can prove the scheme secure for an adversary who can't find preimages to a hash function (chosen collision).

< r​ucknium:monero.social > Or maybe just the wallet cache

< j​effro256:monero.social > Switch commitments could definitely be part of a solution that DOES allow for mitigating of counterfeiting theoretically. And the changes that we have had to make to FCMP / Carrot aren't all that big IMO. For example, for our switch commitments, in Carrot, we just changed how the blinding factor was bound to certain information.

< j​effro256:monero.social > The changes to output pubkeys will likely be similar: hash them a certain way that guarantees opening it and providing a preimage to the opening is computationally intractable even for a QC

< j​effro256:monero.social > I definitely am not proposing we try to stuff PQ proving systems with actual PQ cryptography into the upgrade at the moment

< j​effro256:monero.social > But cheap stuff like this which may (or may not) give us security in the future is just low hanging fruit IMO

< k​ayabanerve:matrix.org > CARROT already implements the necessary output key derivation, no? It's changes to address derivation we'd need?

< j​effro256:monero.social > > I don't remember, was the hope that we could get those switch commitments into "the" hardfork to FCMP++, in about a year?

< j​effro256:monero.social > Much shorter than than, and it doesn't have to be a hard/soft fork decision, it can be completely off-chain loose consensus

< j​effro256:monero.social > Yes

< j​effro256:monero.social > > Maybe it will be a bit hard to become really sure those switch commitments do what we hope for, but maybe we could ask the opposite question: Could something go seriously wrong if we add them?

< j​effro256:monero.social > Not AFAIK

< rbrunner > Thanks for the clarifications. So I guess we go for them? (Maybe the decision was already taken, I just was too busy mentally to really get that)

< k​ayabanerve:matrix.org > We can't change output derivation without synchrony across wallets? Wouldn't we need a hard fork to ensure that?

< s​yntheticbird:monero.social > Reasking what i said at the end of last meeting. Would a PQ addressing protocol using KEM be possible? Afaik, serpahis-pq only made use of DSA, so i wonder.

< k​ayabanerve:matrix.org > The point is switch commitments in this HF, as they need a HF, and the new address derivation later, as that doesn't need a HF.

< k​ayabanerve:matrix.org > SyntheticBird: Completely different discussion to supply integrity.

< s​yntheticbird:monero.social > Ah yes you are right, sry :p

< j​effro256:monero.social > It couldn't help with this specific problem without adding additional data. We could derive the ephemeral private keys deterministically, which is also a piece of data that gets lost after a wallet cache is lost. The ephemeral private keys can be used to proving that you sent payments to another address. However, you still need the public address on-hand. If your wallet cache ge<clipped messag

< j​effro256:monero.social > ts corrupted, and you don't know the address, then you're in the same position. But if you would've known the address, just not the ephemeral private keys, then deterministic derivation of those keys would help you on a corrupted wallet cache

< j​effro256:monero.social > But that doesn't require this 16-byte field

< j​effro256:monero.social > And the field is too small to put a full Monero address in it

< j​effro256:monero.social > So TLDR no

< rbrunner > I think we should leave those 16 bytes in peace. Yes, they are there for free, but using them would complicate things, and it could entice some people to do unfortunate things

< s​yntheticbird:monero.social > yeah i agree, no compelling reason to use them, more risk

< rbrunner > As far as I remember we intend to carry the "traditional" tx_extra forward, so people can still play with that.

< rbrunner > With those 16 bytes we would have two mechanisms then, right?

< k​ayabanerve:matrix.org > The 16 bytes are fixed, unavoidable, and would be encrypted under CARROT so it isn't immediately the same.

< rbrunner > Yeah, but also unused, unless I think of something for me personally?

< j​effro256:monero.social > So it's encrypted by default to your view-balance secret, which is PQ resistant, as it is a uniform 32 byte secret only used in key derivation functions. But it's a 16-byte field, so it could be encrypted to anything, hence it's usability for transaction memos. It would have the same privacy implications characteristics as normal transfers: if a quantum computer could see your pub<clipped messag

< j​effro256:monero.social > lic address, then they could calculate your private view-incoming key and decrypt the memo, as they can the amount received, the address received to, the payment ID, etc. I wonder if the temptation for doing it, with it being indistinguishable on-chain, will be so high that some wallets will implement it anyways.

< j​effro256:monero.social > Quantum computers can already decipher which subaddress the payments go to even knowing just one address in the account

< rbrunner > I think it will still make a difference how we label and comment that field, and what we "officially" recommend

< k​ayabanerve:matrix.org > ACK for internal memos if we care, NACK external memos. Those schemes already largely suck in that they generally assume 2-output so the output the receiver didn't receive is the change output.

< c​haser:monero.social > so, practically, is this only about how the field is labeled?

< j​effro256:monero.social > Basically. It's completely possible to use it this way, and we can't really stop it, it's just a matter of official support

< r​ucknium:monero.social > Is there any benefit from officially supporting the 16 byte arbitrary data that will discourage "third-party" wallet implementors from doing it "badly", if it can be done badly? Or maybe the benefit is that I don't have to add the Nth private memos paper to moneroresearch.info because some researchers needed to "discover" another way to add private messaging to Monero.

< rbrunner > Yes, like many other things that we could not stop. But what we can do is stating clearly that we don't recommend to use it, if we can agree on that.

< c​haser:monero.social > I generally assume all crypto to be broken on a long-enough time frame, so I encourage putting as little data into quasi-permanent storage as possible.

< s​yntheticbird:monero.social > 16 bytes of arbitrary data, we recommend not using them and relying on tx_extra. This will be decrypted by a quantum adversary. cordially, Monero Project.

< rbrunner > Exactly :)

< j​effro256:monero.social > Recommending tx_extra over this field is objectively worse since the memos would be possibly decrypted BUT guaranteed to be distinguishable on-chain trivially

< c​haser:monero.social > I think one of the first references to public key crypto was someone in the 19th century assuming that factoring a 10-digit number is intactable. we are those people for cryptographers in 2150

< s​yntheticbird:monero.social > well, it's always a matter of buying time

< rbrunner > I wait for people to produce 10 change outputs to have 160 bytes to use ...

< c​haser:monero.social > SyntheticBird I think that will do

< c​haser:monero.social > rbrunner: not under the max 8-out regime :)

< r​ucknium:monero.social > Mordinals did something clever with brunt outputs and ring signatures, to show transfer of them. I guess Mordinals in the 16 bytes is unlikely since you could only put a hash there, not a full image, but is there anything about the 16 bytes that is not being considered that could make it more attractive to a Mordinal revival?

< rbrunner > Duh ...

< j​effro256:monero.social > But moving memos to a different part of the transaction doesn't magically make the encryption stronger, it just signals that you're definitely using this feature

< s​yntheticbird:monero.social > Oh no no, i didn't meant that this would be safer, at the opposite; just signaling in the recommendation that they shouldn't expect a stronger encryption. You're still right on the deniability of extra data use.

< j​effro256:monero.social > Not AFAIK over the 1060 bytes we already allow in tx_extra

< s​yntheticbird:monero.social > 1080*

< r​ucknium:monero.social > The 16 bytes is provably linked to a key, right? That's a little different from the data in tx_extra

< c​haser:monero.social > could this field be multiple times larger and then tx_extra, assuming some tweaks to the tx format, be deprecated?

< rbrunner > But it's encrypted with a secret key? The receiver can't read it?

< s​yntheticbird:monero.social > this would fall back into the discussion of whether deprecating tx_extra. What size should user be expecting. Also whether you are using it or not doesn't change the tx will be N time larger than it needs

< s​yntheticbird:monero.social > If a lot of people were using tx_extra it would make sense to make every tx 64 bytes larger for uniformity, but right now tx_extra is rare

< j​effro256:monero.social > Its 1060

< s​yntheticbird:monero.social > If a lot of people were using tx_extra it would make sense to make every tx 64 bytes larger for uniformity, but right now tx_extra is rare afaik

< j​effro256:monero.social > https://github.com/tevador/bitmonero/blob/3771641fc5f40cee20df297f49f0dc2213947a45/src/cryptonote_config.h#L212

< c​haser:monero.social > oh, can of worms.

< r​ucknium:monero.social > Isn't the receiver always yourself? So you could always read it. And if you give they key to someone else, they can read it

< s​yntheticbird:monero.social > thx I literally looked at it yesterday but misread 👓

< rbrunner > I mean that tx_extra is a lot more flexible in this regard. You can even send things in the clear there

< r​ucknium:monero.social > I am just trying to get some adversarial thinking about what a Mordinal reviver might want to do.

< k​ayabanerve:matrix.org > FWIW unless there's an explicit use case posited here, I'd say no official support, acknowledgement of potential for internal use, but no endorsement.

< j​effro256:monero.social > Depends on what you mean by "provably linked". Its just space in some enote that can be written to by anyone signing the transaction

< j​effro256:monero.social > Its not necessarily "linked" by any force greater than convention

< k​ayabanerve:matrix.org > SyntheticBird: I considered advocating for a fixed, encrypted blob in TX extra and decided against it for how much of a mess it'd be. Making TX extra larger to provide uniformity to bad TXs doesn't change how we shouldn't be encouraging bad TXs which are fundamentally bad.

< rbrunner > Can't we tweak the format of change enotes a little bit and get something that we must put into those 16 bytes? So they are not free anymore, discussion closed?

< k​ayabanerve:matrix.org > jeffro256: but the only idea officially posited, and safely posited, is to encrypt with the sender's key which is symmetric and not recoverable by a QC

< rbrunner > (I am about 50% serious with this question)

< k​ayabanerve:matrix.org > So while yes, it's not ZK proven to be encrypted to that key, and is arbitrary, that's not the use-case posited here today

< j​effro256:monero.social > > <r​brunner> Can't we tweak the format of change enotes a little bit and get something that we must put into those 16 bytes? So they are not free anymore, discussion closed?

< j​effro256:monero.social > Like any regular encrypted data, we can't enforce the contents without adding some kind of verifiable encryption scheme which would put compute load on the nodes and probably make transactions sizes bigger

< rbrunner > No, I mean we add some short key, or some hash, or whatever, that is needed for processing change enotes

< rbrunner > So the statement "Those 16 are unused" becomes false

< r​ucknium:monero.social > If I'm a third-party wallet dev and I put the same thing in those 16 bytes every time instead of random data, e.g. 000000, is there any cryptographic risk of re-using plaintext again and again? Just trying to understand how things could go wrong.

< c​haser:monero.social > maybe add something that only the one doing the enote scanning has to compute, not all full nodes.

< rbrunner > Yes

< rbrunner > But well, maybe that whole idea could be just nonsense ...

< k​ayabanerve:matrix.org > Rucknium: You'd create a fingerprint

< r​ucknium:monero.social > I am always thinking about mistakes wallet devs can make since I see them on the blockchain too often

< rbrunner > Which is ... unfortunate, but can happen easily?

< j​effro256:monero.social > > No, I mean we add some short key, or some hash, or whatever, that is needed for processing change enotes

< j​effro256:monero.social > Hmmm I will think about this more but probably not. The field is on an internal selfsend enote , not the transferred one, so it would mean that enotes can fail to scan based on the contents of other enotes which is kind of gross

< rbrunner > Maybe the thing that they want to put in there really does not change much, or hardly at all?

< j​effro256:monero.social > Also if the check is trivial and I lose money adhering to it, I'm probably going to run a wallet which let's me recover those funds even if it means breaking some trivial rule

< rbrunner > If one part of the change enote is encrypted with the key that is in those 16 bytes? How would you circumvent that and still (ab)use the field?

< rbrunner > But I agree that goes pretty far, just to prevent use of the bytes

< j​effro256:monero.social > I think Rucknium meant 0s BEFORE encryption to self, right ?

< r​ucknium:monero.social > Yeah I do mean that. But also after "encryption" if a wallet dev can somehow get around that encryption step

< k​ayabanerve:monero.social > Oh, sorry if I misunderstood Rucknium

< k​ayabanerve:monero.social > A wallet dev can do whatever they want there

< k​ayabanerve:monero.social > *if they sufficiently fork the stack

< r​ucknium:monero.social > IMHO, it is best to have the path of least resistance (least dev work) to be the safest. So if the path is to enable an "easy" API to add data, but make it add no data by default, then maybe that is best.

< r​ucknium:monero.social > And good docs are needed. Don't forget that :)

< s​yntheticbird:monero.social > yeah Docs are the key here

< j​effro256:monero.social > Yeah it could be a fingerprint if they screw it up and put the 0s into the tx without fingerprinting

< r​ucknium:monero.social > Remember, recently Siren (comfy) was adding a fingerprint to their MoneroPay txs accidentally because the docs were not clear.

< v​tnerd:monero.social > Sorry got behind on the list. Probably want to do it a hardfork though, otherwise people might use wrong version and get locked out of the switch phase

< j​effro256:monero.social > If we do it now, then there won't HAVE to be any fork

< r​ucknium:monero.social > The meeting has gone pretty long. I think the 16 free bytes can be put on next agenda's meeting, unless people think that everything is settled.

< j​effro256:monero.social > Out of curiosity, What was the fingerprint ?

< r​ucknium:monero.social > Unlock time 10

< r​ucknium:monero.social > Should be 0

< j​effro256:monero.social > I'm fine for now not officially supporting external memos until it comes back up again downstream

< v​tnerd:monero.social > does this mean no payment id like functionality? I assume thats what you mean by memo?

< v​tnerd:monero.social > I need to re-read your carrot proposal I think, things have changed since I first looked

< j​effro256:monero.social > Payment IDs are separately supported

< j​effro256:monero.social > They also have the same PQ privacy issues

< j​effro256:monero.social > Except that they're smaller so they allow "less" arbitrary data

< r​ucknium:monero.social > --- Meeting end ---

< r​ucknium:monero.social > Feel free to continue discussing :)

< c​haser:monero.social > a remark re: Carrot address format. AFAIK it's he first change in Monero's history where the same mnemonic will be able to resolve to two different key chains (barring a potential feature bit flipping for newly generated Polyseeds, but that's out of scope for my point here).

< c​haser:monero.social > this seems like a good opportunity to unify prefixes, doing away with the 4/8 (primary/subaddress) distinction for Carrot addresses.

< c​haser:monero.social > IMHO, ideally all becoming 8... addresses, so Carrot users can blend into the already existing crowd of legacy subaddress users.

< c​haser:monero.social > *the

< j​effro256:monero.social > You have to have a signifier between main/integrated addresses and subaddresses because the sender handles them differently. Namely, they construct the ephemeral pubkey differently. But Carrot addresses will already be indistinguishable from legacy addresses

< j​effro256:monero.social > Thanks everyone for the meeting BTW!

< s​yntheticbird:monero.social > thanks delicious meeting as always

< c​haser:monero.social > jeffro256 got it, thank you. so is this is a requirement on the consensus side, not related to the derivation scheme?

< c​haser:monero.social > and, likewise, thank you all!

< j​effro256:monero.social > No not a consensus requirement at all. The ephemeral pubkey is indistinguishable as belonging to either a main address or a subaddress, but if you try to make an enote ephemeral pubkey like you would for a subaddresses, when the address is actually a main address, then the payment simply won't be scannable by the receiver

< j​effro256:monero.social > And vice cersa

< j​effro256:monero.social > versa

< a​rticmine:monero.social > There is also an important cultural benefit in China by moving entirely to all becoming 8... Addresses

< s​yntheticbird:monero.social > TIL ArticMine is not only knowledgeable on scalability

< c​haser:monero.social > I once listened to Artic speaking 2 hours about the dynamic block size algorithm, and they eventually drove it back to how holes were arranged on punched cards for 1960s' computers. so, yeah, pretty much.

< v​tnerd:monero.social > I think this may have been asked+answered before, but what happens to the existing ring-ct outputs if we transition to switch comittments? Those outputs have to move before the “switch” occurs, otherwise they have to be locked out. Any existing pre-ringct outputs can still be converted. Anyway, it’s an unfortunate that the only mitigation is a PSA to move outputs, etc.

< s​yntheticbird:monero.social > Yes they will need to transition during the pre-QC period. And after a reasonable amount of time (2~3 years?) the migration will be completed and old outputs will be locked. Pre-ringCT outputs will have to transition too. Kayabnerve argued that most of these outputs are probably lost/burnt.

< v​tnerd:monero.social > yes, I remember the prior discussion now.

< j​effro256:monero.social > Previously, I mistakenly stated that we could migrate pre-RingCT outputs, since they have a cleartext amount, but I didn't take into account how FCMP++ will interact with key images for those outputs

< j​effro256:monero.social > Hypothetically, we might be able to make them spendable if we chose the T generator for FCMP++ in a way that is cryptographically verifiable that guessing the generator before some point in time, after the RingCT hard fork, is intractable

< j​effro256:monero.social > Because the problem with making them spendable is that if pre-RingCT outputs are constructed O = x G + y T with a known y value known s.t. y != 0, then the key image spending in a FCMP++ is L = x Hp(O), which is different than what we expect them to be, which is L = dlog(O, G) * Hp(O)

< j​effro256:monero.social > But if T isn't guessable until some point in the future, then it would be impossible to create a valid key image in a FCMP++ for that output that ISN'T L = dlog(O, G) * Hp(O)

< j​effro256:monero.social > Then, during the PQ migration, we can check that if-and-only-if the originating height of the spent output is < v6 hard fork height, we allow the output to be migrated if the key image is exactly L = dlog(O, G) * Hp(O)

< j​effro256:monero.social > If we made the T generator a function of the current Monero block ID, then the trust assumption for preventing inflation would be 1-of-N honest participants, where N is the number of total transaction creators on the Monero blockchain, ever

< j​effro256:monero.social > Actually, not ever, just sincev6

< k​ayabanerve:matrix.org > jeffro256: FYI, non-RingCT outputs can still be created today.

< j​effro256:monero.social > Yes, namely "unmixable sweep" txs. Hence, the height requirement

< k​ayabanerve:matrix.org > We'd need a HF banning non-RingCT outputs, then to decide T via the blockchain if that's considered secure, then to activate FCMP++.

< k​ayabanerve:matrix.org > Or at least a designation height for which non-RingCT outputs won't be migrateable.

< j​effro256:monero.social > I'd vote the latter

< k​ayabanerve:matrix.org > I'd vote none of this mess.

< j​effro256:monero.social > TBF It's a small tweak to a single value and we don't actually have to handle the implications now

< k​ayabanerve:matrix.org > Also, AFAICT, your security analysis is wrong.

< j​effro256:monero.social > Certainly possible. How so?

< k​ayabanerve:matrix.org > Considering the entire blockchain as a transcript, and T a sampled challenge, makes it effectively impossible to define a key on the blockchain which uses T. It's secure in general, not under a 1-of-n trust assumption.

< k​ayabanerve:matrix.org > An adversary who could could break our proofs.

< k​ayabanerve:matrix.org > But I also don't want to debate this ad infinitum. We should define a migration scheme and rely on it. I don't believe we should work on alternative schemes to expand the class of migratable outputs when the existing class is sufficiently wide to the point this is complexity without sufficient benefit.

< k​ayabanerve:matrix.org > Also, your proposal, if implemented, cryptographically binds a checkpoint into the blockchain and technically means Monero either doesn't follow the chain with most work OR Monero may fork to an chain where the security is broken.

< k​ayabanerve:matrix.org > It also mandates T not be a constant but variable to each network (unless we allow inflation on testnet and co) which would be a mess to implement.

< j​effro256:monero.social > I wonder how well the current reference node can currently handle a 1.9 million block reorg....

< k​ayabanerve:matrix.org > Would that be if you used the RCT activation height?

< j​effro256:monero.social > Pre-RingCT deactivation height, excluding unmixable v1 sweep txs

< j​effro256:monero.social > I don't care to try to migrate those

< j​effro256:monero.social > Or we could just hash in all three block IDs into T and it works across all networks

< k​ayabanerve:matrix.org > Verifying that as a NUMS constant now requires syncing three different blockchains?

< j​effro256:monero.social > If you care about all three blockchains, then yes. But if you just cared about mainnet, it would suffice to check just the mainnet block ID, because adding in more block IDs won't reduce the entropy of the T result

< k​ayabanerve:matrix.org > It does change the security analysis?

< k​ayabanerve:matrix.org > It makes the T generator malleable w.r.t. the mainnet blockchain. There's no longer a single choice but 2512 (which presumably collapse into most of the ~2252 results).

< j​effro256:monero.social > I understand what you're saying, but we're already assuming for our PQ migration that adversaries cannot find hash collisions or preimages, even with large entropy inputs

< j​effro256:monero.social > For example, our switch commitmen blinding factors hash a lot of information, including a 32-byte secret, a 32-byte address, and an amount into a scalar, then the preimage is revealed

< k​ayabanerve:matrix.org > I was trying to point how that your proposal of multiple inclusions can't be so trivially stated, not claiming that breaks the scheme.

< k​ayabanerve:matrix.org > I've somehow allowed this to take half an hour of my time. I still personally find this proposal messy and not sufficiently worthwhile. I will be withdrawing from further conversation on it tonighy.

< j​effro256:monero.social > Fair enough, thanks for the discussion thus far though :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant