Group: Guix/Wishlist
The below list contains software that users of GNU Guix would like to see packaged. If you are interested in contributing to Guix, please consider packaging something in this list while keeping in mind that some may have been listed because they are "difficult" or elusive. If the package you're interested in is already listed, feel free to either add a "(+1)" next to its name or increment the vote count, e.g. "(+1)" -> "(+2)", etc.
So Before adding a package to this list, please verify that it hasn't already been packaged.
In addition, Guix is a distribution that follows the Free System Distribution Guidelines (GNU FSDG) and as such not only it only has free software but these guidelines also have additional requirements (like for instance not steering users toward the installation of nonfree software, no Malware, etc).
So it would be a really good idea to point if the package is already packaged by either a Free GNU/Linux Distribution or a Free Non-GNU Distribution, or at least try to see if that software is fully free software and doesn't have any nonfree dependencies (like nonfree firmwares, libraries, other nonfree packages and so on) or if not indicate if it wasn't checked in order to prevent accidental inclusion of nonfree software in Guix (that could happen for instance if each party assumes that the other people checked while no one checked).
Parabola also has a blacklist repository which contains list of nonfree software found in Arch that Parabola blacklisted and sometimes replaced. It also contains perfectly fine software which is blacklisted for other purposes, like renaming "Arch Linux" in "Parabola" in some packages, but the reason of the blacklist is specified.
This page should be synced with Free software replacements recommended by the FSF.
Contents
Packages
Communication
Multimedia communication
- Ekiga (+3)
- Empathy (+3)
- Jitsi Desktop (+5)
- KDE Telepathy
- Signal Desktop (+4)
Instant messaging client
- briar-gtk
- Cryptocat
- Delta Chat
- Ricochet (+3)
- Scli (+1)
- The Lounge
- Tiny
- tkabber
- Tox (with clients such as Venom, and MuTox) (+1)
- Zulip
Social networking
- Aether
- Diaspora (+2)
- GNU Social (WIP) (+1)
- microblog.pub
- Pleroma (requires elixir build-system) (+2)
- Pump.io (requires nodejs-build-system) (+1)
- Whalebird-desktop
Matrix
Production
Editor
- arduino IDE (+4)
- Helix
- Light Table
- Neovide
- notepadqq
- PlatformIO
- Tau
- Traditional Vi
- VSCodium (+3)
- xi-editor
Graphics
- App Icon Preview
- DIGImend
- Dynamic Wallpaper Editor
- Icon Library
- Identity
- ImEditor
- LDtk
- Obfuscate
- Ronin
- Sweet Home 3D (+2)
- Le Biniou
- Shutter
- OpenTabletDriver
- OpenToonz *Note: Already available pre-packaged in Parabola GNU/Linux. So the hard work for this one is already done.*
- Natron *Note: On the github releases page, recommended to use precompiled binaries with patches for qt4 and python2 are provided. That one should be used for GNU Guix.*
Office
- Zotero Desktop (+4)
- KOReader (+2)
- Minder
- ProjectLibre
System
Backup
Booting
- Support booting from pre-existing systemd-boot, i.e. "grub-install --no-nvram".
DEs & WMs
Fonts
- Estedad
- Leggie
- Lemon
- ProFont (+1)
- Proggy
- Scientifica
- Spleen
- Terrarum Sans Bitmap
- Tewi
- Iosevka Other Styles
-- It would be nice to have the other versions of iosevka.
Hardware
- bricxcc
- dualsensectl
- Jumpdrive
- M33-Fio
- OctoPrint (patch) (+2)
- BambuStudio AGPLv3. An attempt to package for nix can be seen here.
- openrazer
- OSCAR
- Pok3rConf
- pok3rtool
- qmk_firmware
-
rtl8821cuWhile the firmware binary has been released under the GPLv2(+?), it lacks corresponding source code. So someone needs to do the work to reconstruct the source code from the binary. See the link in Group:Hardware/research/WiFi/Realtek for more details. -
rtl88x2buWhile the firmware binary has been released under the GPLv2(+?), it lacks corresponding source code. So someone needs to do the work to reconstruct the source code from the binary. See the link in Group:Hardware/research/WiFi/Realtek for more details. - Swapspace (+1)
- undervolt
- Vial
Input
Media Transfer Protocol
Shell
- 3dsconv
- aria2p
- bashmount
- binmerge
- btdu
- castero
- cbftp
- crazydiskinfo
- diana
- duf
- Elvish
- extract_url
- FanFicFare
- Fbv
- goodls
- kcc
- lsix
- payload-dumper-go
- pmbootstrap
- termdbms
- tut
- Twin
- twitch-curses
- unaesgcm
- urlview
Tools
- Bleachbit
- Bundlewrap wip, Parabola
- chntpw (+1)
- distcc
- libguestfs
- libsixel
- mat2 (+1): wip, Parabola, most probably fully free without nonfree dependencies and FSDG compliant. Some work might still be needed to make sure test passes as we probably want to avoid bugs in software that people might rely on to stay alive.
- Pijul Old version available in a community channel pijul.scm
- unrar-free
- Ventoy (+1) This could yield a fantastic bootloader type.
- JCryptool
Wayland
X11
- arc-firefox-theme
- Digital Clock 4
- Gambas
- imgbrd-grabber
- NewBreeze
- PulseAudio-Applet
- QGnomePlatform
- qtstyleplugins
- sc-controller
- Trackma
- X2Go
Programming
Version control
Programming languages
Ada
Clojure
Common Lisp
Eiffel
Emacs
Erlang
Guile
Haskell
- stack (build tool)
Java
- gradle (+1)
- ns-usbloader
Perl
- SpamAssassin (written in Perl) (+4)
Python
Scheme
Standard ML
Misc
- FlashGBX
- Gollum
- Gtkhash
- Rage (+1)
- Gephi
- Health
- Kooha
- Metadata Cleaner
- Passbook
- OnlyKey App
- Newaita Icons
- GPXSee
- YacY
- lsplug
hamradio
Emulation
Live USB
Audio
Music
Video
Education
Feed Readers
- NewsFlash (+1)
Games
- Airshipper
- beatoraja
- Bouncy Bunny
- Cataclysm: Bright Nights
- Cemu
- Cube 2: Sauerbraten
- Deliantra (server + client require special version of perl.)
- EasyRPG-Editor (Would require an update to liblcf and prompt an update to easyrpg-player.)
- Elona foobar
- FreeCol
- FreeCS
- HamSandwich
- iortcw
- itch-client (+1)
- IVAN
- Kye
- Liblast
- Mesen
- Mesen2
- Mindustry (requires a gradle-build-system because the build needs a plugin that at least depends on gradle) (+3)
- Oolite
- OpenArena
- OpenNefia
-
Open RuneScape Classic(derived from proprietary Runescape Classic) - OpenSpades
- opsu!
- osu! (+1)
- Panel Attack
- Performous
- Quaver
- Rigs of Rods
- Ryujinx
- Robust Toolbox
- Ryzom (+1)
- Shuvit
- Sil (WIP needs patches to handle readonly installpath) (+1)
- sil-q (can be packaged with Sil)
- Soldat
- Space Station 14
- Stunt Rally
- sucle
- Terasology
- Terrarium (patch)
- The Dark Mod (+1)
- Tivoli Cloud VR
- Tuxemon (patch)
- Uebergame
- VDrift
- Veloren
- Vircadi
- Warfork
- Xye
- yuzu-emu
Network
- asuka
- ELinks (patch)
- Falkon
- Fragments
- Freenet (+1)
- fwknop
- geth
- I2P (+3)
- LibreWolf (+1)
- matterbridge: Update it and also package in its dependencies in Guix instead of relying on the Go build system to fetch and build them.
- metasploit-framework
- metasploit-payloads
- ncgopher
- Pi-hole
- profile-sync-daemon
- Puppet
- Qv2ray
- shadowsocks-rust
- sqlmap
- stig
- Syncplay
- transgui
- transmission-qt
- Tribler
- Urbit
- V2Ray
- visurf
- Wvdial
- wyeb
- Yukko
- ZeroNet
- Vieb Browser
- Insomnia
Tor Browser
-
Tor Browser(+11) (has been packaged)
The Tor Browser has an issue that makes it incompatible with the Free System Distribution Guidelines (GNU FSDG): it is configured to use Mozilla the addons repository.
Several strategies are possible to get it in Guix and it might be possible to combine some of them together.
The Tor Browser project might find it very interesting to use Guix instead of Ubuntu for building the Tor Browser as Guix goes way beyond reproducible builds: It has extensive work that has been done to make Guix bootstrapable. Most other distributions only care about reproducible builds and so if the compilers binaries had a backdoor, software built with such compilers could then have a reproducible backdoor.
The issue is that the Tor Browser supports several operating systems (GNU/Linux, Android, Microsoft Windows, MacOS) and currently Guix only supports building software for GNU/Linux, GNU/Hurd and Microsoft Windows (this was contributed by someone wanting to build bitcoin with Guix precisely because extensive work has been made to make Guix bootstrapable).
Adding the ability to build applications for Android should probably be doable but I've no clue at all about MacOS.
In addition Guix already supports i686 and x86_64 for both Windows and GNU/Linux, and we might gain the ability to get the Tor browser for armhf, ARM 64bit (aarch64), powerpc, powerpc64le (the architecture used in the Talos II), riscV64.
And finally Guix pack also support several formats, like tarballs and Debian packages, and more can also be added as well. That would enable the tor-browser to be installed as a regular package. That could be handy with Tails for instance as last time I checked it was just a tarball being extracted.
In any case, it would really be a good idea to make the upstream Tor Browser project switch to Guix for their releases as we would avoid having to do any Q/A to verify that our version of the tor-browser looks exactly the same on the networks and that websites can't distinguish Guix users because it has been patched or built differently. And other FSDG distributions with less strict policies on bootstrapability could either build it though Guix or ship the tor-browser installer as it would then only ship software that is FSDG compliant.
We'd also need to make sure that users don't mess up trying versions that are not exactly the same as the released one (that might happens if the dependencies gets updated in Guix for instance). In any case we could then easily package the tor-browser installer in Guix too.
In addition it could push them to fix or accept fixes for the addon repository problem as Guix is probably not going to accept a tor-browser that is not FSDG compliant.
Now with the addon repository, several approaches could be taken:
- It could be removed completely. The Tor Project advise against installing addons anyway as it could de-anonymize users. That's probably the best option here.
- It could be moved to another list, for instance the one maintained the GNU project or one maintained by the Tor project.
- It could also be fixed at Mozilla but I've no idea how easy it is, especially because we might need to check if the addons are really free software and can be built with free software, etc.
In any case it's probably not super important what option is chosen here as long as it's fixed.
References:
Self-hosting
- anki-sync-server (+1)
- Alps Webmail
- EtherCalc (+1)
- Etherpad (+1)
- Gitlab (+2)
- Gitea (+2)
- Gogs
- Hugo
- JMP.chat, which is related to Soprani.ca
- Kareha
- Matomo
- Mediagoblin (+2)
- Nextcloud (+4)
- Nextcloud-Client (+1)
- Sandstorm
- sr.ht (+1)
- Wakaba
- WordPress (patch)
- YOURLS
Science
Translator
Features
- Add more cross toolchains for more CPU architectures
- armv4t looks like a good idea as many older ARM boards that boot with free software could then be supported. Debian still officially supports armv4t, so it might be possible to copy their settings and fixes.
- Add an xtensa-elf target as it's probably already supported within packages for building the ath9k_htc firmware
- Find if other firmwares from other architectures are being built
- Add more cross toolchains for more OSes
- It would be a good idea to be able to build binaries for Android, we already have a bit of Android components in Guix but they can only be used on GNU/Linux or other already officially supported toolchains or OS. It would be a good idea to add an Android / bionic target. We'd need to check how much bionic is linked to the kernel version being used on the Android device.
- Add more Guix pack or guix system image formats
- We could add Arch Linux packages to guix pack be able to be used on Parabola.
- We could enable to ship multiple package in one Debian package (currently that works with the tarball format of guix pack but not with Debian packages)
- Add a way to deploy Guix in a directory in a way compatible with LXC
-
LVM-Support (+5)Guix now has LVM support but it might not be fully complete. I for instance managed to boot a Guix SD system from an ext4 rootfs that is in a LVM partition that is in a LUKS encrypted partition with this guide and by following the official documentation. - Integrate better letsencrypt/certbot. Currently certbot works fine if you already have certificates: it can renew them and so on. But if you use webroot you need the web server to be started for certbot to create or update certificates, but nginx (which is the web server best supported by guixSD API) won't start without the certificates. People deploying services with Guix typically have to do workarounds because of this issue. A solution would be to add a --standalone option for certbot and once the certificate is obtained to trigger the switch to webroot and starting the web server with a hook like it's done when renewing certificates.
- Add a better way to deal with secrets or external files: Currently it's up to users to do the provisioning of secrets like VPN credential files. If they package it somehow they end up being in the store and being a security risk as any users could see them. Having to manually provision such files might work in some cases but it doesn't scale well as to do it right we'd need to make a provionning method that works for all the cases (all the different types of images, etc). A solution would be to add some extra option to guix to also include extra files or tarballs. This way the files would be added for all images types (docker, qcow2 system images, disk images, with guix system init, etc).
- Add generic ways to generate very small rootfs. For instance there is some support for initramfs already. Now that there is ppc64le support, if we can make images that fit into (128M?) of flash and that OpenBMC is packaged in Guix, it could probably completely support RYF computers like the Talos II. If we have a good enough abstraction like a target OS for instance, we could probably add the software we want in initramfs and/or in the BMC and configure them like a regular Guix system from the host computer. There is already support for managing VMs through a ganetti API in guix and there are also childhurds in Guix.
- Cross distributions bootstrap
- Enable to install Parabola and Hyperbola from Guix. Status: wip. I've got some failures with pacstrap on GuixSD because the PATH is not the same than Parabola's path. I don't know where Parabola's PATH comes from though as /etc/environment is empty by default. Note that some packages need to be refreshed to work as Parabola and/or Hyperbola don't keep many older packages and sources. But once all that lands in Guix it shound't be an issue anymore as the source should be made available though software heritage, and guix will fallback to it.
- Package Guix in Parabola. Currently Guix package only worked on x86_64, so I added a guix-installer package to make sure we could still install it in a safe way (where we have some chain of trust with gpg during the installation).
Documentation
Other
- There are many bugs and patches on https://issues.guix.gnu.org/, so if you want to help it might be a good idea to try to fix bugs, review patches and so on.
TODO
- When libreplanet.org is upgraded to a new version of MediaWiki, use interwiki links to link to the Free Software Directory for descriptions of wishlisted software.
- Sandboxes (in containers/VMs/Websites) where you can play around and learn about
- administrative package operations (remove, install, upgrade)
- packaging software (like the debian packaging tutorials)
- learning the in and outs of the language which is used for packaging
- how to package software which has dependencies in some language-specific artefactories (pip, crates, maven and so on), especially if you want to one-shot them, so you have them and do it properly later.
This page was a featured resource in February 2019.