18 comments

  • CodeWriter23 3 minutes ago
    So. Does this methodology mean someone can surreptitiously boot up a Linux VM running Wireguard in your browser and be inside your firewall via chrome.sockets API?
  • morpheuskafka 5 hours ago
    If you are using an LLM, wouldn't it have been a lot easier to just have the LLM find the relevant CUPS driver decompile or just capture the USB traffic, and rewrite it in Go or something native? (No need to deal with the system printing framework, the goal was just an app that accepts JPEG input.)
    • gmac 5 hours ago
      Interesting suggestion: I guess that would have been possible. On the other hand I think this is a more general solution, and it does minimal reinventing-the-wheel.
    • dolmen 4 hours ago
      Or ask the agent to write a Dockerfile (to abstract the build environment) that builds CUPS and all your stuff around it directl in WASM, instead of targeting x86 and then emulating x86 with WASM.
      • jojomodding 4 hours ago
        Is there a Docker-to-WASM pipeline, and how does it do anything differently from emulating x86?
    • huflungdung 4 hours ago
      [dead]
  • hexmiles 1 hour ago
    I know that it is a heavyweight solution, but it could be useful for some situations with old driver/devices/applications. I have some old hardware that is compatible only with pre-WinNT OS, and I could do something similar to provide a simple solution for the end user.
    • Narishma 1 hour ago
      Would such old hardware even be able to run a modern browser needed for this?
      • CodeWriter23 8 minutes ago
        You run old operating system in browser as a gateway.
      • hexmiles 1 hour ago
        Sorry, I wasn't clear. By old hardware, I meant peripherals connected to the computer via serial or USB. We are at a level of performance where running an entire VM as a driver is kind of feasible, if wasteful.
  • ale42 2 hours ago
    I'm using an ancient Canon Selphy photo printer... on Windows 11 without any issues. Using the Windows 7 64-bit driver, worked basically out-of-the-box. It's definitely not officially supported, but to date it works totally fine.
    • gmac 2 hours ago
      Huh, interesting. Is the driver built in to Windows, downloaded from Canon, or acquired some other way?

      TBH the web app story on Windows isn’t ideal anyway because you have to install Zadig before it will work.

  • Gabrys1 3 hours ago
    > I must apologise that I haven’t so far open-sourced any part of this that I don’t have to. Mainly that’s because I think this would be an awesomely sticky web property for a printer consumables firm to integrate with their sales site. And I’d much prefer it if they paid me to white-label it for them, rather than just forking a repo and getting it all for free.

    They might be interested if they cared at all about the ease of use of their printers

    • zamadatix 1 hour ago
      The hardest part would probably be convincing someone to pay to white label something for which most of the key design choices and implementation came from one unfamiliar dev prompting an £18 Claude Code subscription.
    • jeroenhd 2 hours ago
      These printer makers have the source code and the ability to write firmware. If they wanted to support WebUSB, they could and would.
    • kube-system 3 hours ago
      They are referring to aftermarket ink cartridge companies, not the printer OEM.
  • bityard 4 hours ago
    Okay, this is reasonably genius. I have quite a few USB devices lying around that are either old enough or were niche enough that they don't work on modern _anything_, even Linux. One of them is a GameBoy Advance flash cartridge.
    • yjftsjthsd-h 4 hours ago
      Oh, there's a thought - v86 supports lots of old DOS/Windows versions too, so assuming you could get the right port through (probably easy with anything USB, maybe possible with other things?) you could probably use your choice of old drivers:)
  • PunchyHamster 2 hours ago
    Doesn't Apple outright uses CUPS in the first place ? Did they just removed old drivers in their version ?
    • nubinetwork 1 minute ago
      I'd be curious if cups works on wsl as well...
  • juancn 4 hours ago
    Thank you, loved this and it made me "duh!".

    I have an old-ish Samsung laser printer that works perfectly and a Linux file server at home and the printer no longer supports AirPrint.

    I never thought about using the Linux box as an AirPrint server! This will free me from all the odd print requests from my kids! (probably)

    • asteroidburger 3 hours ago
      It’ll work great if you can get the drivers all aligned properly. I’ve tried a few times to get my 12 year old Brother laser setup like that, and each time I end up throwing in the towel.

      Maybe I’ll try it again someday with an LLM assisting.

    • mikepurvis 4 hours ago
      I have a Samsung ML-1740 kicking around still that I just can't bear to part with; I've been meaning forever to RasPi-ify it, but it's one of those projects that feels like it's going to end up being a rabbit hole.
  • SoftTalker 4 hours ago
    I have an old Epson MX80 dot-matrix printer in the closet, have thought about getting a Raspberry Pi and setting that up so we can wirelessly print to it. But... who would really want that?
    • mrighele 4 hours ago
      For a printer like an Epson MX80 an esp32 should be enough to share the printer on a raw TCP interface (AppSocket I think the protocol is named) on port 9100. It is supported by Windows and CUPS.

      Very easy implementation as it essentially it just forwards the data to the printer. Since it's a raw interface you need the proper driver, but luckily Epson provides a Windows 10 driver for the Epson MX-80 (!) [1] CUPS doesn't have driver for the MX-80 but it has a number of generic Epson drivers and my guess is that one of those will work.

      The most difficult part is probably the parallel interface (unless you have a printer with a serial interface in which case it will be much easier)

      [1] https://epson.com/Support/Printers/Impact-Printers/MX-Series...

  • hahn-kev 5 hours ago
    This is pretty cool! Thanks for sharing.
  • monocasa 4 hours ago
    Isn't cups a de facto apple project? What's the VM getting you?
    • yjftsjthsd-h 4 hours ago
      The gutenprint drivers to support the specific printer don't support darwin
      • monocasa 4 hours ago
        Gutenprint supports macos as a first class citizen, including this particular printer AFAICT.
        • gmac 4 hours ago
          From the Gutenprint home page, https://gimp-print.sourceforge.io/:

          As of July 7, 2024 the Gutenprint project has formally deprecated MacOS support. This means that no further MacOS-compatible binaries will be produced.

          Gutenprint has not had an active MacOS maintainer for over three years, and the remaining developers lack the technical ability to produce MacOS binaries, much less undertake the substantial amount of work necessary to produce, test, and support binaries on newer (post-Mojave/10.14) MacOS releases.

          • monocasa 3 hours ago
            It looks like it's just because they had no way to test, and bandwidth to deal with it. But should still mostly work, once whatever issue (that sounds like app notrization) is fixed.

            It seems like the better option would have been to fix whatever was blocking them just two years ago, rather than this wild rube goldberg machine of a Linux VM emulated in a browser tab.

            • gmac 3 hours ago
              I mean, anyone is welcome to do just that! But I guess coding Rube Goldberg machines in JS (to push the boundaries of the web) is a thing I really kind of enjoy.
    • merb 4 hours ago
      • monocasa 4 hours ago
        Oh, OK, new information, thanks!

        But this driver is older than OpenPrinting's fork from Apple CUPS.

  • DeathArrow 3 hours ago
    I would have asked Claude to write a driver. But this works, too. :)
  • leptons 4 hours ago
    Too bad Apple is still preventing the WebUSB spec from being standardized. They won't even make suggestions to get it through committee because WebUSB might cut into their native app store.
    • davsti4 3 hours ago
      From: https://developer.mozilla.org/en-US/docs/Web/API/WebUSB_API "WebUSB provides a way for these non-standardized USB device services to be exposed to the web. This means that hardware manufacturers will be able to provide a way for their device to be accessed from the web, without having to provide their own API."

      That doesn't sound secure at all!

      • monocasa 2 hours ago
        Which is why Firefox doesn't support it either.
    • cosmic_cheese 3 hours ago
      Mozilla doesn’t want it either.
  • simoncion 1 hour ago
    Oh neat. v86 is mentioned in the FOSDEM 2025 slides [0] for another wasm port of QEMU. Interesting that what appears to be v86's inability to run x86 executables didn't fuck you.

    I wonder why the decision wasn't made to use the network sharing features of SANE and CUPS, instead of requiring one to use Chrome due to the WebUSB dependency. Seems to me that you'd have a way more general solution if you could usefully deploy your VM both in any major web browser and as a standalone program.

    [0] <https://archive.fosdem.org/2025/events/attachments/fosdem-20...>

    • gmac 1 hour ago
      Can you elaborate on how using the network sharing features of CUPS would let you achieve the same thing (printing to old USB printers) in any major web browser?
      • simoncion 1 hour ago
        Given your commercial aspirations, I'm happy to consult on your project as a paid contractor.
        • gmac 1 hour ago
          Fair enough! I just don’t think I fully understand what you’re suggesting.
  • randusername 3 hours ago
    what the heck we're not in web 1.0 anymore are we
  • minutesmith 1 hour ago
    [flagged]
  • hulitu 5 hours ago
    Another AI add.
  • redeeman 5 hours ago
    surely a glorious OS like osx would not be without support for hardware that linux supports? when will it be year of osx desktop?
    • akdev1l 4 hours ago
      wdym?

      OSX has literally always been supported only on very limited hardware so how would it support anything else?

      • redeeman 3 hours ago
        did you read what this is about? support for a printer people buy in stores. the kinda thing people expect working?