Hi all,

I am about to do a bit of a distro hop, and I am looking at Fedora and its spins, after years on Debian / POP.

I am not looking forward to setting it all up again, it’s a drag.

I wonder, is there a tool that lets me script installs?

I’ll want to check if application exists, and if so, update, otherwise, install. That kind of thing.

Things like:

  • Telegram
  • Joplin
  • Docker
  • Firefox
  • Ungoogle Chromium
  • Sublime Text
  • VSCodium
  • Keepass
  • Thunderbird
  • DBeaver
  • Gimp
  • Inkscape
  • KDENLive
  • Syncthing
  • Steam
  • VLC
  • Localsend
  • Flameshot
  • Element
  • Cherrytree
  • Calibre
  • Anydesk

I show the list, only to give an idea of what might be involved.

I’m new to Fedora, so not sure how it differs beyond the package manager. But, thought I’d ask.

Does such a tool exist, and is it worth my time? I can practice on a VM before trying on the final install/s.

Thank you

  • Nibodhika@lemmy.world
    link
    fedilink
    arrow-up
    2
    ·
    1 day ago

    That’s one of the things I miss the most in Gentoo, having the packages of your system defined in text files so a fresh install was just copying those files and running an update.

    I’ve tried similar things with other distros, but it’s never the same, the list of packages ends up getting out of date or ends up with too much garbage.

    Currently I have a home server so I took the time to get an Ansible playbook setup for running, maintaining, and maybe migrating the server if needed. Since some stuff is also run on other machines that I have (update system, update some docker images I run in multiple systems, etc) I did setup some minimal packages that I need on my main system, it’s easy enough but I wouldn’t recommend using Ansible just for this (but if you also have dotfiles it’s a great tool for automating lots of the initial setup).

    All of that being said, the reason I never bothered with this until I had a home server is that usually there are years between system installs, so even if what you had was exactly what you wanted the last time you installed your system, it’s unlikely to be exactly what you want next time you do. Since the last time I installed my main system I switched from X to Wayland, from i3 to Hyprland and then Sway, etc, etc…

  • Kuadhual@lemm.ee
    link
    fedilink
    arrow-up
    15
    ·
    2 days ago

    Using ansible will help you on your 2nd, 3rd , nth install.

    But getting ansible to do what you want (plus testing) for the first time would takes 10x longer than manual install.

    I think there’s xkcd about that.

    • exu@feditown.com
      link
      fedilink
      English
      arrow-up
      8
      ·
      edit-2
      2 days ago

      Just installing applications is pretty easy though.

      ---
      - hosts: localhost
        become: yes
        tasks:
          - name: Install required software
            dnf:
              state: latest
              name:
                - firefox
                - telegram
                - calibre
      

      ansible-playbook install.yml

      Something like that (untested)

      • timbuck2themoon
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        2 days ago

        I distinctly remember yum/dnf should be using a loop. Forget why but it’s recommended. Here’s a snippet from my playbook. Simply make the vars as you need and run.

          - name: Install flathub as remote
            ansible.builtin.shell:
              cmd: flatpak remote-add --if-not-exists flathub https://dl.flathub.org/repo/flathub.flatpakrepo
            tags:
              - apps
        
          - name: Install flatpak apps
            community.general.flatpak:
              name: "{{ item }}"
              state: present
            loop: "{{ flatpaks }}"
            tags:
              - apps
        
          - name: Remove some default unused packages
            ansible.builtin.dnf:
              name: "{{ item }}"
              state: absent
              update_cache: no
            loop: "{{ remove }}"
            ignore_errors: true
            tags:
              - apps
        
          - name: Install our packages
            ansible.builtin.dnf:
              name: "{{ item }}"
              state: present
              update_cache: yes
            loop: "{{ rpms }}"
            ignore_errors: true
            tags:
              - apps```
        
        On mobile. Apologies if formatting is off.
  • Leaflet@lemmy.world
    link
    fedilink
    English
    arrow-up
    11
    ·
    edit-2
    2 days ago

    I have a bash script I use to script my Silverblue install. Something like this should work.

    # space-separated list of packages to install
    S_RPM_PACKAGES_TO_INSTALL="pkg1 pkg2 pkg3"
    
    # function to install the packages
    dnf_install () {
    	sudo dnf install -y $1
    }
    
    # call to function, passing the list
    dnf_install "$S_RPM_PACKAGES_TO_INSTALL"
    

    I have it set up this way so that I just have a bunch of bash variables describing the stuff I want to install all at the top of the file, but the function definitions and calls lower down since I don’t need to see them.

    It also does other things like removes packages from the system, removes some preinstalled flatpaks, installs flatpaks from Fedora Flatpaks / Flathub / gnome-nightly, and sets up gnome through a list gsettings commands.

    As I use my system, I add new apps to the list I want next time I install and remove apps I don’t use.

    • makingStuffForFun@lemmy.mlOP
      link
      fedilink
      arrow-up
      2
      ·
      2 days ago

      I love this, I will update the script I’ve setup to mirror your idea. Nice and clean.

      I wonder if you can help at all? The only app that fails install is Anydesk. I have to do the following:

      # Anydesk
      sudo tee /etc/yum.repos.d/anydesk.repo<<EOF
      [anydesk]
      name=AnyDesk Fedora Linux
      baseurl=http://rpm.anydesk.com/fedora/x86_64/
      gpgcheck=1
      repo_gpgcheck=1
      gpgkey=https://keys.anydesk.com/repos/RPM-GPG-KEY
      EOF
      

      sudo dnf install anydesk -y

      But it gives an error, saying :

      [anydesk]
      name=AnyDesk Fedora Linux
      baseurl=http://rpm.anydesk.com/fedora/x86_64/
      gpgcheck=1
      repo_gpgcheck=1
      gpgkey=https://keys.anydesk.com/repos/RPM-GPG-KEY
      AnyDesk Fedora Linux                                                                                                                                                         397  B/s | 488  B     00:01    
      AnyDesk Fedora Linux                                                                                                                                                         1.8 kB/s | 1.7 kB     00:00    
      Importing GPG key 0xCDFFDE29:
       Userid     : "philandro Software GmbH <[email protected]>"
       Fingerprint: D563 11E5 FF3B 6F39 D5A1 6ABE 18DF 3741 CDFF DE29
       From       : https://keys.anydesk.com/repos/RPM-GPG-KEY
      AnyDesk Fedora Linux                                                                                                                                                         796  B/s | 1.2 kB     00:01    
      Error: 
       Problem: conflicting requests
        - nothing provides libgtkglext-x11-1_0-0 needed by anydesk-6.3.2-1.x86_64 from anydesk
      (try to add '--skip-broken' to skip uninstallable packages)
      
      

      Is there a special way to add that kind of command to a bash script? All good apart from that though.

  • Samueru@lemmy.ml
    link
    fedilink
    arrow-up
    1
    ·
    2 days ago

    I wonder, is there a tool that lets me script installs?

    I’ll want to check if application exists, and if so, update, otherwise, install. That kind of thing.

    https://github.com/ivan-hc/AM

    Use AppMan to install them in HOME.

  • utopiah@lemmy.ml
    link
    fedilink
    arrow-up
    6
    ·
    2 days ago

    I did more than 5 installs this weekend (for … reasons) and the “trick” IMHO is …

    Do NOT install things ahead of actually needing them. (of course this assume things take minutes to install and thus you will have connectivity)

    For me it meant Firefox was top of the list, VLC or Steam (thus NVIDIA driver) second, vim as I had to edit crontab, etc.

    Quite a few are important to me but NOT urgent, e.g Cura (for 3D printer) and OpenSCAD (for parametric design) or Blender. So I didn’t event install them yet.

    So IMHO as other suggested docker/docker-compose but only for backend.

    Now… if you really want a reproducible desktop install : NixOS. You declare your setup rather than apt install -y and “hope” it will work out. Honestly I was tempted but as install a fresh Debian takes me 1h and I do it maybe once a year, at most, no need for me (yet).

    • utopiah@lemmy.ml
      link
      fedilink
      arrow-up
      1
      ·
      2 days ago

      Another “trick” I use is having an ~/Apps directory in which I have AppImage, binaries, etc that I can bring from an old /home to a new one. It’s not ideal, bypassing the package manager, and makes quite a few assumption, first architecture, but in practice, it works.

      • Samueru@lemmy.ml
        link
        fedilink
        arrow-up
        1
        ·
        2 days ago

        Check this out: https://github.com/ivan-hc/AM

        Use appman and set the install directory to ~/Apps and now you will be able to install appimages/binaries in the ~/Apps dir using a package manager that keeps them up to date and that you can move to any other distro, I have all of this:

        Although more recently for binaries I’ve been using this instead, which pulls from a massive repo of static binaries, though note that dbin needs its own separate directory in HOME to install binaries (you can’t use ~/Apps that is).

        • utopiah@lemmy.ml
          link
          fedilink
          arrow-up
          1
          ·
          5 hours ago

          Hmmm very interesting thanks for the links and explanation!

          I’m not “ready” for it yet so I’ve bookmarked all that (by adding a file in ~/Apps ;) but that’s definitely and interesting, and arguably neater solution.

          Honestly I try to stick to the distribution package manager as much as I can (apt on Debian stable) but sometimes it’s impossible. Getting binaries myself feels a bit “wrong” but usually works. Some, like yt-dlp as I see in your list, do have their own update mechanisms. Interesting to consider stepping back and consider the trade off. Anyway now thanks to you I know there are solutions for a middle ground!

          • utopiah@lemmy.ml
            link
            fedilink
            arrow-up
            1
            ·
            5 hours ago

            Also this is a good way to re-consider integration back, e.g. generating .desktop files for /.local/share/applications/ when using KDE rather than having to manually do it each time.

            • Samueru@lemmy.ml
              link
              fedilink
              arrow-up
              2
              ·
              edit-2
              4 hours ago

              This is already done automatically.

              AM puts the .desktop files in /usr/local/share/applications

              AppMan puts them in ${XDG_DATA_HOME:-~/.local/share}applications

              They also get symlinked in PATH, that is you can launch yt-dlp by typing yt-dlp on the terminal as if you had installed it with your distro package manager.

  • feddylemmy@lemmy.world
    link
    fedilink
    arrow-up
    5
    ·
    2 days ago

    Something like Ansible won’t help you the first time around, but it’ll make the next times easier.

  • qocu [he/him]@hexbear.net
    link
    fedilink
    English
    arrow-up
    5
    ·
    2 days ago

    I didn’t find any script that would install the apps you wanted, but I did find a script that will help you build your own (it’s pretty easy). You can take inspiration from this one and modify it, so that whenever you reinstall your system, you’ll run your script.

    https://gist.github.com/engineervix/ed53aa410a22620013e04baca437abb3

    Research what commands are used in Fedora to install what application and add them to your script. Then, give your .sh file execute permissions and run it. You can do this in a virtual machine first if you want.

    • makingStuffForFun@lemmy.mlOP
      link
      fedilink
      arrow-up
      2
      ·
      2 days ago

      …aaaand DONE and tested. That was amazingly simple, when there’s a framework like that to work, and learn from. Thanks again.

    • Possibly linux@lemmy.zip
      link
      fedilink
      English
      arrow-up
      1
      ·
      2 days ago

      Not to sound rude but I am fairly surprised to see this from a hexbear user. It seems like a lot of hexbear is just going around and trolling.

      I can’t say I agree with hexbear but I appreciate the normal (and very useful) comment

  • merthyr1831@lemmy.ml
    link
    fedilink
    English
    arrow-up
    1
    ·
    2 days ago

    Some distros allow this. Nix for example allows you to save config files that describe your entire system (apps, settings, etc) and then load them in one go. Other distros are following suit with their own tailored solutions too (I think Ubuntu might have something? Manjaro?).

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

      You can even have all nixpkgs on a different distro through the nix package manager

  • lens0021@lemmy.ml
    link
    fedilink
    arrow-up
    3
    arrow-down
    1
    ·
    edit-2
    2 days ago

    Have you tried SaveDesktop? Thought It is limited in the flatpak softwares, but cloud synchronization feature is recently added.

    • TeryVeneno@lemmy.ml
      link
      fedilink
      arrow-up
      1
      ·
      2 days ago

      Was looking for this in this comment section, I see this solution as becoming the goto for moving between installs even though it is limited right now

    • subtext@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      2 days ago

      Or any of the similar tools listed here, based on personal preferences! I currently use Chezmoi, but I like that they help you discover alternatives.

    • LeLachs@lemmy.ml
      link
      fedilink
      arrow-up
      1
      ·
      2 days ago

      It should be possible. Although probably very complicated. Have a look at https://distrobox.it/. It allows you to tightly integrate containers into your desktop, including accelerated graphics, some devices, your homedir, etc. It can even automatically install desktop shortcuts. (You can disable the integrations of course) Even tho it uses Podman instead of docker, AFAIK it should be 1:1 compatible with docker for your usecase.

  • Concave1142@lemmy.world
    link
    fedilink
    arrow-up
    1
    ·
    2 days ago

    I use an Ansible playbook to do fresh install stuff such as app installs & joining my local Samba AD.

    Another option, that I’ve never tried, would be to put your /home directory on another partition. That only solves the settings though and not your app installation bit.

          • Concave1142@lemmy.world
            link
            fedilink
            arrow-up
            1
            ·
            2 days ago

            Correct. I’m running two AD DC’s based on Samba, all running on Zentyal. Super simple to install & setup. I them run a VM in Virtualbox on my laptop for the rare occasions I need to use the Windows RSAT tools.

            Other than that, all my Linux VM’s, ProxMox hosts & unRAID NAS all set to auth against the Samba DC. It has been working perfectly for over a year now.

            https://www.zentyal.com/

            • Possibly linux@lemmy.zip
              link
              fedilink
              English
              arrow-up
              2
              ·
              2 days ago

              I don’t believe Zentyal is supported by the Samba team. I’d just stick to regular Samba DCs.

              I am personally debating on setting up either Samba AD or FreeIPA. FreeIPA is definitely better for Linux but I really like Samba. Thanks for answering my question.