On Debian-based distros, when an app is available as a DEB or an AppImage (that doesn’t self-update), but no APT repository, PPA or Flatpak, the only option is to manually download each update, and usually manually check even whether there are updates.

But, what if those would be upgraded at the same time as everything else using the tools you’re familiar with ?

dynapt is a local web server that fetches those DEBs (and AppImages to be wrapped into DEBs) wherever those are, then serves these to APT like any package repository does.

I started building it a few months ago, and after using it to upgrade apps on my computers and servers for some time, I pre-released it for the first time last week.

The stable version will come with a CLI wizard to avoid this manual configuration.

Feedback is welcome :)

  • Daeraxa@lemmy.ml
    link
    fedilink
    arrow-up
    1
    ·
    1 day ago

    Willing to give this a go. My go-to for getting non-repo debs automatically has been deb-get which works well but seems susceptible to issues when changes in the software it lists causes it to break and whilst the fix itself is usually made pretty quickly, it seems to go long periods of time between PR merges and releases (which includes adding new software). If this is a viable replacement for it then i’d love to start using it.

    • KaKi87@jlai.luOP
      link
      fedilink
      arrow-up
      1
      ·
      10 hours ago

      Willing to give this a go.

      Alright, don’t hesitate to ask questions if you have any and request help if you need any

      My go-to for getting non-repo debs automatically has been deb-get

      Yes, I mentioned it in the Differences with deb-get & AM section of my tutorial.

      it seems to go long periods of time between PR merges and releases (which includes adding new software)

      Yeah, I could reiterate in that section that my app allows the user to add apps themselves.

      • Semperverus@lemmy.world
        link
        fedilink
        English
        arrow-up
        8
        ·
        13 days ago

        I’d say going directly to a developer’s github page for packages isnt too bad, especially now with all of the security features github has in the background, but yea technically true.

        • KaKi87@jlai.luOP
          link
          fedilink
          arrow-up
          3
          ·
          12 days ago

          I’d be willing to implement additional features for people who are extra careful about security.

          Could you please explain what does this consist in ?

          Thanks

  • bizdelnick@lemmy.ml
    link
    fedilink
    arrow-up
    10
    ·
    edit-2
    13 days ago

    If I’d decide to implement something like this, I’d consider two options: local repo with file:// scheme or custom apt-transport. HTTP server is needless here. (But I’ll never do this because I prefer to rebuild packages myself if there’s no repo for my distro.)

    • KaKi87@jlai.luOP
      link
      fedilink
      English
      arrow-up
      8
      ·
      13 days ago

      local repo with file:// scheme

      With that, I couldn’t trigger a download when apt update is ran, I could only do a cron, i.e. a delay, that I do not want.

      custom apt-transport

      I thought about that, but found no documentation on how to do it. If you have any, I’m interested.

      Even just finding documentation on how to generate DEBs and APT repository metadata files was very hard.

      • bizdelnick@lemmy.ml
        link
        fedilink
        arrow-up
        8
        ·
        13 days ago

        It is documented in libapt-pkg-doc (/usr/share/doc/libapt-pkg-doc/method.html/index.html).

        • KaKi87@jlai.luOP
          link
          fedilink
          arrow-up
          6
          ·
          13 days ago

          In an APT package OMG 😂

          I found an online version though, which I would never have found through my search engine (and on a site that doesn’t even support HTTPS) 😅

          Looks like difficult reading too 😭

          Thanks anyway.

        • KaKi87@jlai.luOP
          link
          fedilink
          English
          arrow-up
          3
          ·
          13 days ago

          Yeah, I don’t have the skill for this. I’d be very happy if someone else would make this, but if not then I’m sticking to HTTP.

          • keturn@sh.itjust.works
            link
            fedilink
            English
            arrow-up
            3
            ·
            13 days ago

            I went way down the rabbit hole on this one and ended up with a proof of concept that’s probably close enough to be able to wire it up: https://gitlab.com/-/snippets/3745244

            I guess it didn’t end up too much code, but I’m not entirely sure it’s worth it.

            (it’s after 3 AM? oh no what have I done)

            • KaKi87@jlai.luOP
              link
              fedilink
              arrow-up
              1
              ·
              12 days ago

              Why the OOP structure and syntax ? Sorry but it makes it difficult to read for me even in my own language 😅

              • keturn@sh.itjust.works
                link
                fedilink
                arrow-up
                1
                ·
                11 days ago

                uh, because TypeScript is an object-oriented language, as are the Deno APIs? I’m not sure I understand the question.

                • KaKi87@jlai.luOP
                  link
                  fedilink
                  arrow-up
                  1
                  ·
                  11 days ago

                  It’s more functional than object-oriented and I read the former better than the latter. 😅

      • keturn@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        12 days ago

        differently hacky idea:

        since you do end up with all the packages in a repository on the filesystem, and you just want to have it do this just-in-time updating when the Packages file is accessed…

        what if you list it as a normal file apt source, but you make the Packages file a FIFO?

        it’s a cursed idea but I’m not sure it is any less cursed than the other options we’ve come up with.

        it may or may not help to have systemd.socket manage creating the FIFO and running the service.

        • KaKi87@jlai.luOP
          link
          fedilink
          arrow-up
          1
          ·
          12 days ago

          What’s a FIFO ?

          I’ve also looked into VFS but found nothing I’d have the skills to implement. 😅

  • JubilantJaguar@lemmy.world
    link
    fedilink
    arrow-up
    8
    ·
    edit-2
    13 days ago

    Looks great, well done.

    Personally, the deb-related annoyance that I have encountered most often in recent years is that there is an APT repo but I have to jump thru hoops to add it. An example is signal-desktop, where the handy one-click installation goes like this:

    # 1. Install our official public software signing key:
    wget -O- https://updates.signal.org/desktop/apt/keys.asc | gpg --dearmor > signal-desktop-keyring.gpg
    cat signal-desktop-keyring.gpg | sudo tee /usr/share/keyrings/signal-desktop-keyring.gpg > /dev/null
    
    # 2. Add our repository to your list of repositories:
    echo 'deb [arch=amd64 signed-by=/usr/share/keyrings/signal-desktop-keyring.gpg] https://updates.signal.org/desktop/apt xenial main' |\
      sudo tee /etc/apt/sources.list.d/signal-xenial.list
    
    # 3. Update your package database and install Signal:
    sudo apt update && sudo apt install signal-desktop
    

    Why does Debian-Ubuntu not provide a simple command for this? Yes there is add-apt-repository but for some reason it doesn’t deal with keys. I’ve had to deal with this PITA on multiple occasions, what’s up with this?

    • KaKi87@jlai.luOP
      link
      fedilink
      arrow-up
      2
      ·
      13 days ago

      Thanks, and agreed !

      Fortunately, copy/pasting works and you only have to do it once.

    • cqst@lemmy.blahaj.zone
      link
      fedilink
      arrow-up
      3
      arrow-down
      2
      ·
      edit-2
      12 days ago

      Why does Debian-Ubuntu not provide a simple command for this?

      You aren’t supposed to add repos. Ever. https://wiki.debian.org/UntrustedDebs

      Apt is not built with security in mind, at all. The partial sandboxing it does do is trivial to bypass. Adding a repo is basically a RAT Trojan on your computer.

      An example is signal-desktop Yeah don’t use signal. They restrict freedom 3 by making distribution difficult. Thats why they trick you into using their RAT repo.

      https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=842943

      The least bad option is the unofficial flatpak.

      • JubilantJaguar@lemmy.world
        link
        fedilink
        arrow-up
        3
        ·
        12 days ago

        Apt is not built with security in mind, at all. The partial sandboxing it does do is trivial to bypass. Adding a repo is basically a RAT Trojan on your computer.

        OK. I suppose this is the correct answer.

        The least bad option [for Signal] is the unofficial flatpak.

        Unless I’m missing something, here we will disagree. Secure or not, FOSS principle-respecting or not, if I’m choosing to install software by X then I’m going to get it straight from X and not involve third-party Y too.

        • cqst@lemmy.blahaj.zone
          link
          fedilink
          arrow-up
          1
          arrow-down
          1
          ·
          11 days ago

          Unless I’m missing something, here we will disagree. Secure or not, FOSS principle-respecting or not, if I’m choosing to install software by X then I’m going to get it straight from X and not involve third-party Y too.

          Source code is like a recipe. Getting your food from the chef who made the recipe is fine, but getting it from another chef who… followed the same exact recipe is no different.

          This is how the linux software distribution model works, distro maintainers are a CHECK on upstream.

  • JustARegularNerd@aussie.zone
    link
    fedilink
    English
    arrow-up
    7
    ·
    edit-2
    12 days ago

    This might be for the better, but Discord was so infuriating about updates and forcing you to download them what felt like 50% of the time I opened it, I gave up and just use it in Ungoogled Chromium now. I’m pretty sure within a few months I ended up having 15+ debs of Discord in my Downloads folder.

    For anyone else trying to use the native Discord app on Debian, I think they’ll find this a major treat.

    • KaKi87@jlai.luOP
      link
      fedilink
      arrow-up
      5
      ·
      12 days ago

      Discord not automating downloads of DEBs is one of the reasons motivating me to do this.

      Personally I need the desktop client because I mod it with plugins that are so useful that I can’t do without these anymore.

      Alternatively, there are third-party repositories here and here.

      There still is delay between Discord releases and repository updates so I still believe dynapt to be the better solution.

      • KaKi87@jlai.luOP
        link
        fedilink
        arrow-up
        5
        ·
        12 days ago

        I didn’t know there was one, that’s interesting, thanks.

        Updates must still be delayed because of being third-party though.

  • Telorand@reddthat.com
    link
    fedilink
    arrow-up
    4
    ·
    13 days ago

    I like it. Wonder if this could be retooled to work on rpm-ostree systems, because any layered packages installed from RPM files have the same limitation of needing to be manually upgraded.

    • KaKi87@jlai.luOP
      link
      fedilink
      arrow-up
      3
      ·
      13 days ago

      I don’t know anything about RPMs, but if you or anyone is familiar with it then perhaps !

  • markstos@lemmy.world
    link
    fedilink
    arrow-up
    1
    ·
    12 days ago

    This is somewhat re-inventing some things Ansible can do, which is download and install software whether it has a formal or informal source.

    Ansible is the automation I use to manage personal and professional servers.

  • skimm@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    1
    ·
    12 days ago

    Neat project!

    While this might not solve all of your use cases, did you consider a tool like mise?

    Theres a number of other options out there such as asdf-vm and others who’s names I can’t recall. I recently moved from asdf to miss but its a great way to install things on different machines and track it with your dotfiles, or any other repo you want to use. Mise has tons of configuration options for allowing overrides and local machine specific versions.

    It won’t tie into apt for your upgrades but you could just alias your apt update to include && mise up.

  • Shdwdrgn@mander.xyz
    link
    fedilink
    English
    arrow-up
    3
    arrow-down
    3
    ·
    13 days ago

    Sorry to ask, but isn’t this basically the same thing as apt-cacher-ng?

    • KaKi87@jlai.luOP
      link
      fedilink
      arrow-up
      7
      ·
      13 days ago

      Sorry to ask

      Don’t be. I would love to know that an existing and more experienced program does what mine does.

      I’ve been looking for it myself for a long time before deciding to build it.

      isn’t this basically the same thing as apt-cacher-ng?

      Here’s what I’m reading :

      Apt-Cache-ng is A caching proxy. Specialized for package files from Linux distributors, primarily for Debian (and Debian based) distributions but not limited to those.

      A caching proxy have the following benefits:

      • Lower latency
      • Reduce WAN traffic
      • Higher speed for cached contents
      +------------+         +------------+        +------------+
      | Apt Client |  <------+ Apt Cache  | <------+ Apt Mirror |
      +------------+         +------------+        +------------+
      

      So, not the same thing.

      It locally mirrors existing repositories containing existing packages, it doesn’t locally create a new repository for new packages from standalone DEBs.

      • Shdwdrgn@mander.xyz
        link
        fedilink
        English
        arrow-up
        3
        ·
        13 days ago

        OK yeah, I wasn’t sure if it had a way to collect debs from other sources. I’ve been using it for years to locally cache the standard Debian repos so I don’t need to re-download packages every time I update my various servers and VMs, but I haven’t really tried using it for anything beyond that.