Content pfp
Content
@
0 reply
0 recast
0 reaction

kripcat.eth 🎩 pfp
kripcat.eth 🎩
@kripcat.eth
Calling @polymutex.eth This cast reminded me of your story from a couple days back. I’m no fan of Musk and this screenshot seems believable based on verifiable past behaviour from Musk, so there is a threat of confirmation bias here. It could be a fake account or a fake image entirely. Short of me trawling through Twitter myself to confirm something which is pretty immaterial to my life. How could the original caster use EAS or ZK Proofs to provide verification that this image is genuine when casting? If it’s not possible today, what are the roadblocks?
3 replies
0 recast
26 reactions

polymutex pfp
polymutex
@polymutex.eth
All the pieces to make this work exist and work in theory, but no one has hooked them up all together to make this a reality in practice. You need: 1: A way to retrieve tweet data from X 2: A way to post them onchain in a way that everyone can tell they came from X 3: A way to prove that they match a screenshot ⤵️
2 replies
0 recast
2 reactions

polymutex pfp
polymutex
@polymutex.eth
Steps 1 and 2 are handled by @tlsnotary or zkTLS or @reclaimprotocol. Any of them allows you to make an HTTPS connection to a website (in this case X) and post the contents of what you retrieved through this connection onchain, in such a way that all can see that the content was verifiably retrieved from X. ⤵️
1 reply
0 recast
1 reaction

polymutex pfp
polymutex
@polymutex.eth
One challenge in this screenshot's case is that you don't need just one tweet, you need 2, and need to prove their relationship to each other (one is a reply of the other). This is difficult because X has forbidden logged-out users from retrieving more than 1 tweet at a time, and shut down the API for doing so. ⤵️
1 reply
0 recast
1 reaction

polymutex pfp
polymutex
@polymutex.eth
That said, you can still prove the existence of the tweets individually, and probably to prove that the second one is a reply (because the "reply to" data may still be on single-tweet pages). So let's assume we get past this problem. Having an onchain proof is good, but how do we surface this to actual humans? ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
This is where it gets a bit hairy. The image is a set of pixels and it's pretty blurry. It's not obvious to a computer that these pixels are text, and that the text is two tweets, and that these two tweets correspond to onchain proof data that these tweets exist. Multiple ways we can go about that problem. ⤵️
2 replies
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
The easiest way is that the original poster of the screenshot is a well-intended person and voluntarily posts the proof of the tweets' existence as part of their cast along with the screenshot. In this case it is easy for the Farcaster client to show this data and display it next to the cast. ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
If the original poster did not post this proof and just posts the screenshot, this is where it gets harder. We need some way to link up the two together. The easiest way is for some good person to come along and create+post the proof that the original poster didn't. But that takes work. Can we automate this? ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
Imagine a world with something like @bountycaster but for requesting such proofs. Someone who wishes to verify this screenshot can post a bounty about it. Then a bounty-hunter bot can come around and find+post the proof, then claim the reward. How can this process work in an automated way? ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
First, the bot needs to understand the request. This is well within the means of current OCR technology (convert the image to text), and LLMs can easily understand that this image is a tweet and that the request is to post existence proof of these tweets. So off goes the bot searching X for these tweets. ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
Let's assume the tweet does exist. The bot posts the proof onchain, and then publishes it on Farcaster. But now they need to get their bounty. Humans can manually verify and accept that the bot deserves the bounty, but that still means there's a human in the loop. Can we do better? ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
The bot can do something more: it can provide an onchain proof that the tweet-existence-proofs it has posted match those in the screenshot. This is where current technology is stretched to its limits, because it involves running machine-learning models in zero-knowledge (yes, this is zkML). ⤵️
2 replies
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
zkML proofs are ZK proofs that a model given a certain input gives a certain output. Here the input prompt can be: "Is this image a screenshot of 2 tweets, one from person A saying <thing>, and the other from person B replying <reply>? Answer with only yes or no." Then ZK-proving that the model answered 'yes'. ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
Then the @bountycaster system needs to verify this proof, then run its own ML models to ascertain whether this proof is a sufficient proof to fulfill the original bounty request. This part may also need to run onchain if Bountycaster was a fully-autonomous system, but in today's world that's not the case yet. ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
Either way, the Bountycaster bot treats the bounty as fulfilled, the money goes to the bounty-hunter bot, and everyone is happy. Now for the hairier case: What if the tweets don't actually exist and the screenshot is fabricated? ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
It is harder to prove the *non-existence* of a tweet, because tweets can be edited, deleted, etc. and there is no easy public interface to query a user's entire timeline over logged-out TLS. One way is to not do logged-out TLS, but this is trickier and requires a valid X account that doesn't get flagged as bot. ⤵️
1 reply
0 recast
0 reaction

polymutex pfp
polymutex
@polymutex.eth
It's trickier because you do not want to reveal the login information being used to retrieve the user's timeline. But it's possible to do a partial proof, ie. prove that the HTTPS connection contained <timeline> without revealing the whole contents of the HTTPS request (which would leak the login cookie). ⤵️
1 reply
0 recast
0 reaction