Settings

Theme

Recreating Epstein PDFs from raw encoded attachments

neosmart.net

500 points by ComputerGuru 2 days ago · 206 comments

Reader

dperfect 20 hours ago

Nerdsnipe confirmed :)

Claude Opus came up with this script:

https://pastebin.com/ntE50PkZ

It produces a somewhat-readable PDF (first page at least) with this text output:

https://pastebin.com/SADsJZHd

(I used the cleaned output at https://pastebin.com/UXRAJdKJ mentioned in a comment by Joe on the blog page)

  • pests 19 hours ago

    So it was a public event attended by 450 people:

    https://www.mountsinai.org/about/newsroom/2012/dubin-breast-...

    https://www.businessinsider.com/dubin-breast-center-benefit-...

    Even names match up, but oddly the date is different.

    • elmomle 19 hours ago

      Your links are for the inaugural (first) ball in December 2011; OP's text referred to a second annual ball in December 2012.

      • pests 16 hours ago

        You are right my first is incorrect but the second does seem to be from 2012.

    • nialv7 17 hours ago

      looks like we have it. in the end it's pretty mundane...

      • JKCalhoun 8 hours ago

        There are plenty of other PDF's with Base64 encoded attachments.

      • klustregrif 14 hours ago

        Which begs the question why was it censored?

        • pbhjpbhj 6 hours ago

          Mighty be they censored all pages mentioning keywords, this one says "Breast" ... perhaps they censored all sexual content?

          • klustregrif 6 hours ago

            At the risk of repeating myself. Which begs the question why?

            • mmastrac 6 hours ago

              To protect the people in power, as always.

              • redeeman 2 hours ago

                what is insane is that everyone just accepts it, knows that this happens, and dont go lynch the ones in charge immediately.

                There was a time when the guy making the cannon had to sit on top of it for the first shot. Perhaps this kind of policy could be adapted to other situations aswell.

                Take the job to guard epstein? take the consequences when things go wrong.

                Protect criminals? take the very real consequences if found out

                • ben_w an hour ago

                  > what is insane is that everyone just accepts it, knows that this happens, and dont go lynch the ones in charge immediately.

                  For a while, my pet conspiracy theory was that this was Epstein's real cause of death: a lynching by a prison guard made to look like suicide.

                  I never took it too seriously, because no actual evidence; now I'm more inclined to think it was a coconspirator hoping it would mean no more evidence getting out.

        • mikeyouse 8 hours ago

          Likely because the named list is a bunch of Trump appointees and mega donors and they're illegally trying to spare them the embarrassment.

        • lanyard-textile 13 hours ago

          Distraction.

    • turtlesdown11 3 hours ago

      interesting, Eva Dubin was highlighted today for offering Epstein her 15 year old daughter and her friends.

      She's a medical doctor, who became amnesic when on the stand for Maxwell's case

      >Pressed about gaps in her memory, Dubin told the court: "It's very hard for me to remember anything far back and sometimes I can't remember things from last month. My family notices it. I notice it."

  • dperfect 4 hours ago

    Letting Claude work a little longer produced this behemoth of a script (which is supposed to be somewhat universal in correcting similar OCR'd PDFs - not yet tested on any others though): https://pastebin.com/PsaFhSP1

    which uses this Rust zlib stream fixer: https://pastebin.com/iy69HWXC

    and gives the best output I've seen it produce: https://imgur.com/itYWblh

    This is using the same OCR'd text posted by commenter Joe.

    • daveguy 3 hours ago

      > which is supposed to be somewhat universal in correcting similar OCR'd PDFs

      Xerox would like a word.

      https://news.ycombinator.com/item?id=29223815

      Point being, "correcting" to "correct looking" may be worse than just accepting errors. Errors are often clearly identified by humans as a nonsense word. "Correcting" OCR can result in plausible, but wrong results that are more difficult for the human in the loop to identify.

      • dperfect 2 hours ago

        That's true if we're correcting OCR of actual output text. In this case, it's operating on the base 64 text, trying to produce chunks that form valid zlib streams and PDF syntax so the file can be intact enough to be opened. "Just accepting errors" would mean not seeing any content in the file because it cannot be read.

        So yes, the "fixed" output has errors, but it’s not hallucinating details like an LLM, nor is it trying to produce output that conforms to any linguistic or stylistic heuristics.

        The phrase "correcting similar OCR'd PDFs" should have been "correcting similar OCR'd base 64 representations of PDFs".

  • notpushkin 17 hours ago

    > It produces a somewhat-readable PDF (first page at least) with this text output

    Any chance you could share a screenshot / re-export it as a (normalized) PDF? I’m curious about what’s in there, but all of my readers refuse to open it.

  • the_real_cher 9 hours ago

    This is cool!

bawolff a day ago

Teseract supports being trained for specific fonts, that would probably be a good starting point

https://pretius.com/blog/ocr-tesseract-training-data

tcgv 5 hours ago

> Then my mom wrote the following: “be careful not to get sucked up in the slime-machine going on here! Since you don’t care that much about money, they can’t buy you at least.”

I'm lucky to have parents with strong values. My whole life they've given me advice, on the small stuff and the big decisions. I didn't always want to hear it when I was younger, but now in my late thirties, I'm really glad they kept sharing it. In hidhsight I can see the life-experience / wisdom in it, and how it's helped and shaped me.

pyrolistical a day ago

It decodes to binary pdf and there are only so many valid encodings. So this is how I would solve it.

1. Get an open source pdf decoder

2. Decode bytes up to first ambiguous char

3. See if next bits are valid with an 1, if not it’s an l

4. Might need to backtrack if both 1 and l were valid

By being able to quickly try each char in the middle of the decoding process you cut out the start time. This makes it feasible to test all permutations automatically and linearly

percentcer a day ago

This is one of those things that seems like a nerd snipe but would be more easily accomplished through brute forcing it. Just get 76 people to manually type out one page each, you'd be done before the blog post was written.

  • quuxplusone 34 minutes ago

    As TFA says, the hard part is that "1" and "l" look the same in the selected typeface. Whether your OCR is done by computers or humans, you still have to deal with that problem somehow. You still need to do the part sketched out e.g. by pyrolistical in [1] and implemented by dperfect in [2].

    [1] - https://news.ycombinator.com/item?id=46906897

    [2] - https://news.ycombinator.com/item?id=46916065

  • sjducb 2 hours ago

    The first week of my PHD was accurately copying DNA sequences from an old paper into a computer file. 10 pages in total. I used OCR to make an initial version then text to speech to check it

    76 pages is a couple of months of work

  • jjwiseman 21 hours ago

    Or one person types 76 pages. This is a thing people used to do, not all that infrequently. Or maybe you have one friend who will help–cool, you just cut the time in half.

    • wildzzz 19 hours ago

      Typing 76 pages is easy when it's words in a language you understand. WPM is going to be incredibly slow when you actually have to read every character. On top of that, no spaces and no spellcheck so hopefully you didn't miss a character.

  • WolfeReader a day ago

    You think compelling 76 people to honestly and accurately transcribe files is something that's easy and quick to accomplish.

    • altairprime 14 hours ago

      Non-engineers are perfectly willing to volunteer their time to do drudgery. It's one of my opseng career's distinguishing specialties: I'll do drudgery rather than code when appropriate, rather than avoiding it or sulking about it (as was a common response at work for some number of decades!). Learned that lesson when I was 18 from an internship (where I completely failed to deliver any work product due to trying to code around the work). It's part of why I'm going into accounting: apparently having the stamina for dreary work is rare?!

      Also look up double/triple data-entry systems, where you have multiple people enter the data and then flag and resolve differences. Won't protect you from your staff banding together to fuck you over with maliciously bad data, but it's incredibly effective to ensure people were Actually Working Their Blocks under healthy circumstances.

    • estimator7292 6 hours ago

      Friend, have you ever heard of secretaries?

    • pbhjpbhj 6 hours ago

      Captcha!

  • fragmede a day ago

    > Just get 76 people

    I consider myself fairly normal in this regard, but I don't have 76 friends to ask to do this, so I don't know how I'd go about doing this. Post an ad on craigslist? Fiverr? Seems like a lot to manage.

legitster 21 hours ago

Given how much of a hot mess PDFs are in general, it seems like it would behoove the government to just develop a new, actually safe format to standardize around for government releases and make it open source.

Unlike every other PDF format that has been attempted, the federal government doesn't have to worry about adoption.

  • gucci-on-fleek 12 hours ago

    XPS [0] seems to meet these criteria. It supports most of the features of PDF, is an "official" standard, has decent software support (including lots of open source programs), and uses a standard file format (XML). But the tooling is quite a bit worse than it is for PDF, and the file format is still complex enough that redaction would probably be just as hard.

    DjVu [1] would be another option. It has really good open source tooling available, but it supports substantially less features than PDF, making it not really suitable as a drop-in replacement. The format is relatively simple though, so redaction should be fairly doable.

    TIFF [2] is already occasionally used for government documents, but it's arguably more complex than PDF, so probably not a good choice for this.

    [0]: https://en.wikipedia.org/wiki/Open_XML_Paper_Specification

    [1]: https://en.wikipedia.org/wiki/DjVu

    [2]: https://en.wikipedia.org/wiki/TIFF

  • Spooky23 20 hours ago

    You’re thinking about this as a nerd.

    It’s not a tools problem, it’s a problem of malicious compliance and contempt for the law.

    • legitster 17 hours ago

      Even the previous justice departments struggled with PDFs. The way they handled it was scrubbing all possible metadata and uploading it as images.

      For example, when the Mueller reports were released with redactions, they had no searchable text or meta data because they were worried about these exact kind of data leaks.

      However, vast troves of unsearchable text is not a huge win for transparency.

      PDFs are just a garbage format and even good administrations struggle.

  • Ekaros 13 hours ago

    I give any new document format 3 to 5 years until it ends up with similar mess. And that is if it starts well designed and limited.

  • derwiki 21 hours ago

    JPEG?

ChocMontePy 20 hours ago

You can use the justice.gov search box to find several different copies of that same email.

The copy linked in the post:

https://www.justice.gov/epstein/files/DataSet%209/EFTA004004...

Three more copies:

https://www.justice.gov/epstein/files/DataSet%2010/EFTA02153...

https://www.justice.gov/epstein/files/DataSet%2010/EFTA02154...

https://www.justice.gov/epstein/files/DataSet%2010/EFTA02154...

Perhaps having several different versions might make it easier.

sorbus-25 17 hours ago

Event details: https://web.archive.org/web/20260206040716/https://what2wear...

kevin_thibedeau a day ago

pdftoppm and Ghostscript (invoked via Imagemagick) re-rasterize full pages to generate their output. That's why it was slow. Even worse with a Q16 build of Imagemagick. Better to extract the scanned page images directly with pdfimages or mutool.

Followup: pdfimages is 13x faster than pdftoppm

  • masfuerte 7 hours ago

    This. Not only is it faster, the images are likely to be of better quality. If you rasterize the pages then the images will be scaled, unless you get very lucky.

pimlottc a day ago

Why not just try every permutation of (1,l)? Let’s see, 76 pages, approx 69 lines per page, say there’s one instance of [1l] per line, that’s only… uh… 2^5244 possibilities…

Hmm. Anyone got some spare CPU time?

  • wahern a day ago

    It should be much easier than that. You should should be able to serially test if each edit decodes to a sane PDF structure, reducing the cost similar to how you can crack passwords when the server doesn't use a constant-time memcmp. Are PDFs typically compressed by default? If so that makes it even easier given built-in checksums. But it's just not something you can do by throwing data at existing tools. You'll need to build a testing harness with instrumentation deep in the bowels of the decoders. This kind of work is the polar opposite of what AI code generators or naive scripting can accomplish.

    • JKCalhoun 8 hours ago

      Not necessarily a PDF attachment?

      Someone who made some progress on one Base64 attachment got some XMP metadata that suggested a photo from an iPhone. Now I don't know if that photo was itself embedded in a PDF, but perhaps getting at least the first few hundred bytes decoded (even if it had to be done manually) would hint at the file-type of the attachment. Then you could run your tests for file fidelity.

      • swsieber 7 hours ago

        I'd say 99% of the time, the first 10 bytes would be enough to know the file type.

    • sznio 12 hours ago

      >It should be much easier than that. You should should be able to serially test if each edit decodes to a sane PDF structure

      that's pointed out in the article. It's easy for plaintext sections, but not for compressed sections. Didn't notice any mention of checksums.

    • pimlottc 20 hours ago

      I wonder if you could leverage some of the fuzzing frameworks tools like Jepsen rely on. I’m sure there’s got to be one for PDF generation.

    • cluckindan a day ago

      On the contrary, that kind of one-off tooling seems a great fit for AI. Just specify the desired inputs, outputs and behavior as accurately as possible.

  • kalleboo 17 hours ago

    Easy, just start a crypto currency (Epsteincoin?) based on solving these base64 scans and you'll have all the compute you could ever want just lining up

bushbaba 19 hours ago

This proves my paranoia that you should print and rescan redactions. That or do screenshots of the pdf redacted and convert back to a pdf

chrisjj a day ago

> it’s safe to say that Pam Bondi’s DoJ did not put its best and brightest on this

Or worse. She did.

  • winddude 18 hours ago

    there are a few messaging conversations between FB agents early on that are kind of interesting. It would be very interesting to see them about the releases. I sometimes wonder if some was malicious compliance... ie, do a shitty job so the info get's out before it get re-redacted... we can hope...

  • krupan 6 hours ago

    I am in no way a republican apologist, but how many people were clamoring for the immediate releasing these documents, saying it "should be easy" and all that? Laws were passed ordering their sudden speedy disclosure. How would you have handled this?

    • chrisjj 4 hours ago

      Sudden speedy immediate didn't happen.

      If I was Pam? I wouldn't have been.

      If she was me, start earlier, hire better, end later.

    • deadbabe 5 hours ago

      Released all files as is, no redactions.

  • eek2121 a day ago

    I mean, the internet is finding all her mistakes for her. She is actually doing alright with this. Crowdsource everything, fix the mistakes. lol.

    • TSiege 21 hours ago

      This would be funnier if it wasn’t child porn being unredacted by our government

    • helterskelter 20 hours ago

      I wonder if this could be intentional. If the datasets are contaminated with CSAM, anybody with a copy is liable to be arrested for possession.

      More likely it's just an oversight, but it could also be CYA for dragging their feet, like "you rushed us, and look at these victims you've retraumatized". There are software solutions to find nudity and they're quite effective.

      • JKCalhoun 8 hours ago

        I'll take Hanlon’s Razor for 500, Alex.

      • adaml_623 14 hours ago

        Or it's distraction. Leave nudity in to use up attention that should be turning to analysis of what's been redacted.

        There's redaction to protect victims and there's redaction to protect specific co-conspirators in Epstein's spy ring

        • SketchySeaBeast 8 hours ago

          It's hilariously revealing that it keeps redacting "Don't".

          • chrisjj 4 hours ago

            Odd indeed. The President's name contains no apostrophe :)

            • lukifer 4 hours ago

              The emails are bizarrely sloppy with spelling and punctuation, perhaps many usages of "don't" ended up being typed as "don t", triggering an automated find-and-replace.

              • SketchySeaBeast 4 hours ago

                The export itself is also sloppy, with characters like equal signs being added in weird places. Seems like they have it set to cast a wide and poorly set up net.

    • dagi3d 21 hours ago

      the issue is that mistakes can't be fixed in the sense once they are discovered, it doesn't matter if they are eventually redacted

    • rockskon 21 hours ago

      Yeah - they'll take these lessons learned for future batches of releases.

    • chrisjj a day ago

      Let's see her sued for leaking PII. Here in Europe, she'd be mincemeat.

      • ISL 20 hours ago

        The US administration is, at present, regularly violating the law and ignoring court orders. Indeed, these very releases are patently in violation of multiple federal laws -- they're simultaneously insufficiently-responsive to meet the requirements of the law requiring the release of the files and fall afoul of CSAM laws by being incompletely redacted.

        The challenge, as we're all experiencing together, is that the law is not inherently self-enforcing.

    • rcakebread 12 hours ago

      Sicko.

velaia 21 hours ago

Bummer that it's not December - the https://www.reddit.com/r/adventofcode/ crows would love this puzzle

nubg 21 hours ago

Wait would this give us the unredacted PDFs?

  • ryanSrich 18 hours ago

    That's the idea yeah. There are other people actively working on this. You can follow vx-underground on twitter. They're tracking it.

  • poyu 20 hours ago

    I think it's the PDF files that were attached to the emails, since they're base64 encoded.

  • sznio 12 hours ago

    From the unredacted attachments you could figure out what the redacted content most likely contains. Just like the other sloppy redactions that sometimes hide one party of the conversation, sometimes the other, so you can easily figure out the both sides.

ks2048 15 hours ago

I wonder if jmail (https://www.jmail.world/) has worked on this?

I tried to find the message in this blog post, but couldn't. (don't see how to search by date).

linuxguy2 a day ago

Love this, absolutely looking forward to some results.

FarmerPotato a day ago

If only Base64 had used a checksum.

  • zahlman a day ago

    "had used"? Base64 is still in very common use, specifically embedded within JSON and in "data URLs" on the Web.

    • bahmboo a day ago

      "had" in the sense of when it was designed and introduced as a standard

wtcactus 14 hours ago

My non political take about this gift that keeps on giving is that: PDF might seem great for the end user that is just expected to read or print the file they are given, but the technology actually sucks.

PDF is basically a prettify layer on top of the older PS that brings an all lot of baggage. The moment you start trying to do what should be simple stuff like editing lines, merging pages, change resolution of the images, it starts giving you a lot of headaches.

I used to have a few scripts around to fight some of its quirks from when I was writing my thesis and had to work daily with it. But well, it was still an improvement over Word.

  • direwolf20 11 hours ago

    It's meant as a printer replacement format, hence "print to PDF". It's a computer file format about equivalent to a printed document. Like a printed document, you can't just change its structure and recompile it.

zahlman a day ago

> …but good luck getting that to work once you get to the flate-compressed sections of the PDF.

A dynamic programming type approach might still be helpful. One version or other of the character might produce invalid flate data while the other is valid, or might give an implausible result.

iwontberude a day ago

This one is irresistible to play with. Indeed a nerd snipe.

  • netsharc a day ago

    I doubt the PDF would be very interesting. There are enough clues in the human-readable parts: it's an invite to a benefit event in New York (filename calls it DBC12) that's scheduled on December 10, 2012, 8pm... Good old-fashioned searching could probably uncover what DBC12 was, although maybe not, it probably wasn't a public event.

    The recipient is also named in there...

    • RajT88 a day ago

      There's potentially a lot of files attached and printed out in this fashion.

      The search on the DOJ website (which we shouldn't trust), given the query: "Content-Type: application/pdf; name=", yields maybe a half dozen or so similarly printed BASE64 attachments.

      There's probably lots of images as well attached in the same way (probably mostly junk). I deleted all my archived copies recently once I learned about how not-quite-redacted they were. I will leave that exercise to someone else.

    • notenlish 15 hours ago

      There's 70 results that come out when searching for "application/pdf" on the doj website

      • netsharc 13 hours ago

        OK, but if the solution is to brute-force them, there's probably a need to choose which files to focus on.

        Of course there are other content-types, e.g. searching for "Content-Type: image/jpeg" gets hits as well. But only a few of them actually have the base64 data, mostly there are just the MIME headers.. Looking for "/9j/" (which is Base64 for FF D8 FF, which is the header for JPEG files), the Trumpian justice.gov website ignores "/" and shows results case-insensitively, but there are 4 or 5 base64'ed JPEG images in there.

        I also saw that the page is vulnerable to code injection, somehow garbage in one search result preview was OCREd as "<s [lots of garbage]>", and the rest of the search results were striken-through because "<s>" is the HTML to do that.

Evidlo 19 hours ago

I took at stab at training Tesseract and holy jeebus is their CLI awful. Just an insanely complicated configuration procedure.

  • subscribed 10 hours ago

    Gods, I had a flashback just from you mentioning that.

    I had a reasonably simple problem to solve, slightly weird font and some 10 words in English (I actually only missed one or two blocks for missing letters to cover all I needed).

    After a couple of days having almost everything (?) I just surrendered. This seems to be intentionally hostile. All the docs scattered across several repositories, no comprehensive examples, etc.

    Absolutely awful piece of software from this end (training the last gen).

winddude 17 hours ago

here's another few to decode,

https://www.justice.gov/epstein/files/DataSet%2010/EFTA01804...

https://www.justice.gov/epstein/files/DataSet%209/EFTA007755...

https://www.justice.gov/epstein/files/DataSet%209/EFTA004349...

and than this one judging by the name of the file (hanna something) and content of the email:

"Here is my girl, sweet sparkling Hanna=E2=80=A6! I am sure she is on Skype "

maybe more sinister (so be careful, i have no ideas what the laws are if you uncover you know what trump and Epstein were into)...

https://www.justice.gov/epstein/files/DataSet%2011/EFTA02715...

[Above is probably a legit modeling CV for HANNA BOUVENG, based on, https://www.justice.gov/epstein/files/DataSet%209/EFTA011204..., but still creepy, and doesn't seem like there's evidence of her being a victim]

  • netsharc 13 hours ago

    Geezus, with the short CV in your profile, you couldn't tell an LLM to decode "filename=utf-8"CV%5F%5F%5FHanna%5FTr%C3%A4ff%5F.pdf"? That's not "Bouveng".

    Anyway searching for the email sender's name, there's a screenshot of an email of hers in English offering him a girl as an assistant who is "in top physical shape" (probably not this Hanna girl). That's fucking creepy: https://www.expressen.se/nyheter/varlden/epsteins-lofte-till...

    • winddude 6 hours ago

      not sure how I missed the url encoding. yea, fuck not sure I want to decode that PDF, and their's a high probability that that's a victims name.

      Wonder why there's so many random case files in the files.

  • Snoozus 17 hours ago

    this one has a better font, might be a simple copy&paste job

    • winddude 16 hours ago

      I've checked for copy and paste, there's so many character flaws, their OCR must have sucked really bad, I may try with deepseekOCR or something. I mean the database would probably more searchable if someone ran every file through a better OCR.

queenkjuul 19 hours ago

I'm only here to shout out fish shell, a shell finally designed for the modern world of the 90s

eek2121 a day ago

Honestly, this is something that should've been kept private, until each and every single one of the files is out in the open. Sure, mistakes are being made, but if you blast them onto the internet, they WILL eventually get fixed.

Cool article, however.

  • misja111 9 hours ago

    Won't that entire DOJ archive already be downloaded for backup by several people? If I'd be a journalist working on those files, this is the very first thing I would do as soon as those files were published. Just to make sure you have the originals before DOJ can start adding more redactions.

SomaticPirate 17 hours ago

Are there archives of this? I have no doubt after this post goes viral some of these files might go “missing” Having a large number of conspiracies validated has lead me to firmly plant my aluminum hat

blindriver 21 hours ago

On one hand, the DOJ gets shit because it was taking too long to produce the documents, and then on another, they get shit because there are mistakes in the redacting because there are 3 million pages of documents.

  • tclancy 9 hours ago

    It really doesn’t matter which foot you use to step on your own dick. This could not have been more mishandled if they gave it to an actual snake.

  • rapind 19 hours ago

    What they are redacting is pretty questionable though. Entire pages being suspiciously redacted with no explanation (which they are supposed to provide). This is just my opinion, but I think it's pretty hard to defend them as making an honest and best effort here. Remember they all lied about and changed their story on the Epstein "files" several times now (by all I mean Bondi, Patel, Bongino, and Trump).

    It's really really hard to give them the benefit of the doubt at this point.

    • Rebelgecko 16 hours ago

      My favorite is that sometimes they redact the word "don't". Not only does it totally change the meaning of whatever sentence it's in, the conspiracy theory is that they had a Big Dumb Regex for redacting /Don\W+T/i to remove Trump references

  • rexpop 16 hours ago

    "On the one hand the chef gets shit for taking too long, and then on another for undercooked, badly plated dishes."

    Incompetence is incompetence.

  • subscribed 10 hours ago

    It's pretty clear who they should be reacting (victims/minors) and who they shouldn't (perpetrators).

    They wasted months erasing Trump from that instead. So it's on them.

  • thereisnospork 21 hours ago

    Considering the justice to document ratio that's kind of on them regardless.

  • krupan 6 hours ago

    Government is bad at stuff, and more news at 11

  • hypeatei 11 hours ago

    The zeitgeist around the files started with MAGA and their QAnon conspiracy. All the right wing podcasters were pushing a narrative that Trump was secretly working to expose and takedown a global child sex trafficking ring. Well, it turns out, unsurprisingly, that Trump was implicated too and that's when they started to do a 180. You can't have your cake and eat it too.

IshKebab 7 hours ago

Disappointing how terrible open source OCR still is.

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection