2146 lines
90 KiB
Scheme
2146 lines
90 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
||
;;; Copyright © 2017, 2018, 2020–2022 Tobias Geerinckx-Rice <me@tobias.gr>
|
||
;;; Copyright © 2017 Gábor Boskovits <boskovits@gmail.com>
|
||
;;; Copyright © 2017, 2018, 2021, 2023 Ricardo Wurmus <rekado@elephly.net>
|
||
;;; Copyright © 2018 Leo Famulari <leo@famulari.name>
|
||
;;; Copyright © 2019-2023 Efraim Flashner <efraim@flashner.co.il>
|
||
;;; Copyright © 2020 Raghav Gururajan <raghavgururajan@disroot.org>
|
||
;;; Copyright © 2020 Morgan Smith <Morgan.J.Smith@outlook.com>
|
||
;;; Copyright © 2021 raid5atemyhomework <raid5atemyhomework@protonmail.com>
|
||
;;; Copyright © 2021 Stefan Reichör <stefan@xsteve.at>
|
||
;;; Copyright © 2021 Noisytoot <noisytoot@disroot.org>
|
||
;;; Copyright © 2021, 2023 Kaelyn Takata <kaelyn.alexi@protonmail.com>
|
||
;;; Copyright © 2022 Brian Cully <bjc@spork.org>
|
||
;;; Copyright © 2023 Aaron Covrig <aaron.covrig.us@ieee.org>
|
||
;;;
|
||
;;; This file is part of GNU Guix.
|
||
;;;
|
||
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
||
;;; under the terms of the GNU General Public License as published by
|
||
;;; the Free Software Foundation; either version 3 of the License, or (at
|
||
;;; your option) any later version.
|
||
;;;
|
||
;;; GNU Guix is distributed in the hope that it will be useful, but
|
||
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
;;; GNU General Public License for more details.
|
||
;;;
|
||
;;; You should have received a copy of the GNU General Public License
|
||
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
||
|
||
(define-module (gnu packages file-systems)
|
||
#:use-module (guix gexp)
|
||
#:use-module ((guix licenses) #:prefix license:)
|
||
#:use-module (guix packages)
|
||
#:use-module (guix download)
|
||
#:use-module (guix git-download)
|
||
#:use-module (guix build-system cmake)
|
||
#:use-module (guix build-system copy)
|
||
#:use-module (guix build-system gnu)
|
||
#:use-module (guix build-system go)
|
||
#:use-module (guix build-system linux-module)
|
||
#:use-module (guix build-system python)
|
||
#:use-module (guix build-system trivial)
|
||
#:use-module (guix utils)
|
||
#:use-module (gnu packages)
|
||
#:use-module (gnu packages acl)
|
||
#:use-module (gnu packages admin)
|
||
#:use-module (gnu packages algebra)
|
||
#:use-module (gnu packages attr)
|
||
#:use-module (gnu packages autotools)
|
||
#:use-module (gnu packages backup)
|
||
#:use-module (gnu packages base)
|
||
#:use-module (gnu packages bash)
|
||
#:use-module (gnu packages bison)
|
||
#:use-module (gnu packages boost)
|
||
#:use-module (gnu packages check)
|
||
#:use-module (gnu packages compression)
|
||
#:use-module (gnu packages cpp)
|
||
#:use-module (gnu packages crypto)
|
||
#:use-module (gnu packages curl)
|
||
#:use-module (gnu packages cyrus-sasl)
|
||
#:use-module (gnu packages datastructures)
|
||
#:use-module (gnu packages digest)
|
||
#:use-module (gnu packages documentation)
|
||
#:use-module (gnu packages docbook)
|
||
#:use-module (gnu packages elf)
|
||
#:use-module (gnu packages flex)
|
||
#:use-module (gnu packages freedesktop)
|
||
#:use-module (gnu packages gawk)
|
||
#:use-module (gnu packages glib)
|
||
#:use-module (gnu packages gnome)
|
||
#:use-module (gnu packages gnupg)
|
||
#:use-module (gnu packages golang)
|
||
#:use-module (gnu packages golang-check)
|
||
#:use-module (gnu packages guile)
|
||
#:use-module (gnu packages jemalloc)
|
||
#:use-module (gnu packages kerberos)
|
||
#:use-module (gnu packages libevent)
|
||
#:use-module (gnu packages libffi)
|
||
#:use-module (gnu packages libunwind)
|
||
#:use-module (gnu packages linux)
|
||
#:use-module (gnu packages maths)
|
||
#:use-module (gnu packages man)
|
||
#:use-module (gnu packages nfs)
|
||
#:use-module (gnu packages onc-rpc)
|
||
#:use-module (gnu packages openldap)
|
||
#:use-module (gnu packages password-utils)
|
||
#:use-module (gnu packages pcre)
|
||
#:use-module (gnu packages perl)
|
||
#:use-module (gnu packages photo)
|
||
#:use-module (gnu packages pkg-config)
|
||
#:use-module (gnu packages popt)
|
||
#:use-module (gnu packages pretty-print)
|
||
#:use-module (gnu packages python)
|
||
#:use-module (gnu packages python-crypto)
|
||
#:use-module (gnu packages python-web)
|
||
#:use-module (gnu packages python-xyz)
|
||
#:use-module (gnu packages qt)
|
||
#:use-module (gnu packages readline)
|
||
#:use-module (gnu packages rsync)
|
||
#:use-module (gnu packages sssd)
|
||
#:use-module (gnu packages sqlite)
|
||
#:use-module (gnu packages textutils)
|
||
#:use-module (gnu packages time)
|
||
#:use-module (gnu packages tls)
|
||
#:use-module (gnu packages valgrind)
|
||
#:use-module (gnu packages version-control)
|
||
#:use-module (gnu packages xml))
|
||
|
||
(define-public autofs
|
||
(package
|
||
(name "autofs")
|
||
(version "5.1.8")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://kernel.org/linux/daemons/autofs/"
|
||
"v" (version-major version) "/"
|
||
"autofs-" version ".tar.xz"))
|
||
(sha256
|
||
(base32 "1zf0fgf6kr9amxq5amlgsp1v13sizwl3wvx2xl7b4r2nhmci0gdk"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:configure-flags
|
||
(list "--enable-ignore-busy" ; during shutdown
|
||
"--enable-sloppy-mount" ; support mount(8) -s
|
||
"--with-libtirpc"
|
||
(string-append "--with-openldap="
|
||
(assoc-ref %build-inputs "openldap"))
|
||
(string-append "--with-sasl="
|
||
(assoc-ref %build-inputs "cyrus-sasl"))
|
||
"HAVE_SSS_AUTOFS=1" ; required to make sssldir click
|
||
(string-append "sssldir="
|
||
(assoc-ref %build-inputs "sssd")
|
||
"/lib/sssd/modules"))
|
||
#:tests? #f ; no test suite
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-before 'configure 'fix-hard-coded-search-path
|
||
(lambda _
|
||
(substitute* "configure"
|
||
(("^searchpath=\".*\"")
|
||
"searchpath=\"$PATH\""))))
|
||
(add-before 'configure 'fix-rpath
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
(substitute* "Makefile.rules"
|
||
(("^AUTOFS_LIB_LINK.*=" match)
|
||
(string-append match " -Wl,-rpath=" out "/lib"))))))
|
||
(add-before 'install 'omit-obsolete-lookup_nis.so-link
|
||
;; Building lookup_yp.so depends on $(YPCLNT) but this doesn't,
|
||
;; leading to a make error. Since it's broken, comment it out.
|
||
(lambda _
|
||
(substitute* "modules/Makefile"
|
||
(("ln -fs lookup_yp.so" match)
|
||
(string-append "# " match))))))))
|
||
(native-inputs
|
||
(list bison flex pkg-config rpcsvc-proto))
|
||
(inputs
|
||
(list cyrus-sasl
|
||
e2fsprogs ; for e[234]fsck
|
||
libtirpc
|
||
libxml2 ; needed for LDAP, SASL
|
||
mit-krb5 ; needed for LDAP, SASL
|
||
nfs-utils ; for mount.nfs
|
||
openldap
|
||
openssl ; needed for SASL
|
||
sssd
|
||
util-linux)) ; for mount, umount
|
||
;; XXX A directory index is the closest thing this has to a home page.
|
||
(home-page "https://www.kernel.org/pub/linux/daemons/autofs/")
|
||
(synopsis "Kernel-based automounter for Linux")
|
||
(description
|
||
"Autofs is a kernel-based automounter for use with the Linux autofs4
|
||
module. It automatically mounts selected file systems when they are used and
|
||
unmounts them after a set period of inactivity. This provides
|
||
centrally-managed, consistent file names for users and applications, even in a
|
||
large and/or frequently changing (network) environment.")
|
||
;; fedfs/ is GPL-2-only but not built.
|
||
(license (list license:bsd-3 ; modules/cyrus-sasl.c
|
||
license:gpl2+)))) ; the rest
|
||
|
||
(define-public bindfs
|
||
(package
|
||
(name "bindfs")
|
||
(version "1.17.4")
|
||
(source (origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://bindfs.org/downloads/bindfs-"
|
||
version ".tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"1k1xkyjk8ms11djbhlmykkzfbcids6ls5vpq7rhdnazcladszm3g"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
;; XXX: The tests have no hope of passing until there is a "nogroup"
|
||
;; entry (or at least some group to which the guix builder does
|
||
;; not belong) in the /etc/group file of the build environment.
|
||
;; Currently we do not have such a group. Disable tests for now.
|
||
'(#:tests? #f))
|
||
(native-inputs
|
||
;; Native inputs to run the tests
|
||
;; ("ruby" ,ruby)
|
||
;; ("valgrind" ,valgrind)
|
||
;; ("which" ,which)
|
||
(list pkg-config))
|
||
(inputs
|
||
(list fuse-2))
|
||
(home-page "https://bindfs.org")
|
||
(synopsis "Bind mount a directory and alter permission bits")
|
||
(description
|
||
"@command{bindfs} is a FUSE file system for mounting a directory to
|
||
another location, similar to @command{mount --bind}. It can be used for:
|
||
@itemize
|
||
@item Making a directory read-only.
|
||
@item Making all executables non-executable.
|
||
@item Sharing a directory with a list of users (or groups).
|
||
@item Modifying permission bits using rules with chmod-like syntax.
|
||
@item Changing the permissions with which files are created.
|
||
@end itemize")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public cachefilesd-inotify
|
||
(package
|
||
(name "cachefilesd-inotify")
|
||
(version "0.11.0")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://gitlab.com/tomalok/cachefilesd-inotify")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "0qkrpz69ql6fb3fwh0l35hhf9znnqyxhgv5fzd1gl2a2kz13rq5a"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:make-flags
|
||
(list (string-append "CC=" ,(cc-for-target))
|
||
;; The Makefile doesn't support prefix= or similar.
|
||
(string-append "DESTDIR=" (assoc-ref %outputs "out"))
|
||
"MANDIR=/share/man")
|
||
#:tests? #f ; no test suite
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure)))) ; no configure script
|
||
(home-page "https://gitlab.com/tomalok/cachefilesd-inotify")
|
||
(synopsis
|
||
"CacheFiles file system cache management daemon (using @code{inotify})")
|
||
(description
|
||
"This package provides the user space component of CacheFiles, a caching
|
||
back end that uses a directory on a locally mounted file system (such as ext4)
|
||
as a cache to speed up (by reducing) access to a slower file system and make it
|
||
appear more reliable.
|
||
|
||
The cached file system is often a network file system such as NFS or CIFS, but
|
||
can also be a local file system like ISO 9660 on a slow optical drive.
|
||
|
||
CacheFiles itself is part of the kernel but relies on this user space
|
||
@command{cachefilesd} daemon to perform maintenance tasks like culling and
|
||
reaping stale nodes. Only one such daemon can be running at a time, and
|
||
communicates with the kernel through the @file{/dev/cachefiles} character
|
||
device.
|
||
|
||
This version modifies David Howells original cachefilesd---which appears
|
||
unmaintained---to use the @code{inotify} API instead of the deprecated
|
||
@code{dnotify} to monitor file changes.")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public avfs
|
||
(package
|
||
(name "avfs")
|
||
(version "1.1.5")
|
||
(source (origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://sourceforge/avf/avfs/" version
|
||
"/avfs-" version ".tar.bz2"))
|
||
(sha256
|
||
(base32
|
||
"1kvjaaj2dlps98alpc8rhnzhk4vriw46f3y7b2h0jq2d21j3p7xd"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
'(#:configure-flags '("--enable-library" "--enable-fuse")))
|
||
(native-inputs (list pkg-config))
|
||
(inputs (list xz fuse-2))
|
||
(synopsis "Virtual file system that allows browsing of compressed files")
|
||
(description
|
||
"AVFS is a FUSE-based filesystem that allows browsing of compressed
|
||
files. It provides the @command{mountavfs} command that starts a small
|
||
@command{avfsd} daemon. When a specially formatted path under @file{~/.avfs}
|
||
is accessed, the daemon provides listings and content access on the fly. The
|
||
canonical form of virtual file name is:
|
||
|
||
@example
|
||
[basepath]#handler[options][:parameters][/internalpath]
|
||
@end example
|
||
|
||
Example file names:
|
||
@itemize
|
||
@item @file{~/.avfs/home/user/archive.tar.gz#ugz#utar/path/file}
|
||
@item @file{~/.avfs/#http:localhost|some|path}
|
||
@end itemize
|
||
|
||
@code{emacs-dired-hacks} has @code{dired-avfs} module which enables seamless
|
||
integration with @code{avfs}.")
|
||
(home-page "https://avf.sourceforge.net")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public davfs2
|
||
(package
|
||
(name "davfs2")
|
||
(version "1.6.1")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://download.savannah.nongnu.org/releases/"
|
||
"davfs2/davfs2-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "1h65j2py59b97wbzzjhp4wbkk6351v3hrjscjcfab0p5xi4bjgnf"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:configure-flags
|
||
(list "--sysconfdir=/etc" ; so man pages & binaries contain /etc
|
||
(string-append "--docdir=" (assoc-ref %outputs "out")
|
||
"/share/doc/" ,name "-" ,version)
|
||
(string-append "ssbindir=" (assoc-ref %outputs "out") "/sbin")
|
||
;; The default ‘davfs2’ user and group don't exist on most systems.
|
||
"dav_user=nobody"
|
||
"dav_group=nogroup")
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-after 'unpack 'omit-redundancy
|
||
;; Don't install redundant copies of /etc examples into /share.
|
||
(lambda _
|
||
(substitute* "etc/Makefile.in"
|
||
(("(dist_pkgdata_DATA =.*) davfs2.conf secrets(.*)"
|
||
_ prefix suffix)
|
||
(string-append prefix suffix)))))
|
||
(add-after 'unpack 'patch-file-names
|
||
(lambda _
|
||
;; Don't auto-load the FUSE kernel module. That's up to root.
|
||
;; XXX If/when we restore the previous behaviour, make sure not
|
||
;; to introduce a security hole when mount.davfs is setuid.
|
||
(substitute* "src/kernel_interface.c"
|
||
(("/sbin/modprobe") "/modprobe/disabled"))))
|
||
(replace 'install
|
||
(lambda* (#:key make-flags outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
(apply invoke "make" "install"
|
||
(string-append "pkgsysconfdir=" out "/etc")
|
||
make-flags)))))))
|
||
(inputs
|
||
(list neon
|
||
;; Neon requires but doesn't propagate zlib, nor would we want that.
|
||
;; XZ as well, but that's already present in the build environment.
|
||
zlib))
|
||
(home-page "https://savannah.nongnu.org/projects/davfs2")
|
||
(synopsis "Mount remote WebDAV resources in the local file system")
|
||
(description
|
||
"The @acronym{WebDAV, Web Distributed Authoring and Versioning} extension
|
||
to the HTTP protocol defines a standard way to author resources on a remote Web
|
||
server. Davfs2 exposes such resources as a typical file system which can be
|
||
used by standard applications with no built-in support for WebDAV, such as the
|
||
GNU coreutils (@command{cp}, @command{mv}, etc.) or a graphical word processor.
|
||
|
||
Davfs2 works with most WebDAV servers with no or little configuration. It
|
||
supports TLS (HTTPS), HTTP proxies, HTTP basic and digest authentication, and
|
||
client certificates. It performs extensive caching to avoid unnecessary network
|
||
traffic, stay responsive even over slow or unreliable connections, and prevent
|
||
data loss. It aims to make use by unprivileged users as easy and secure as
|
||
possible.
|
||
|
||
However, davfs2 is not a full-featured WebDAV client. The file system interface
|
||
and the WebDAV protocol are quite different. Translating between the two is not
|
||
always possible.")
|
||
(license (list license:bsd-2 ; src/fuse_kernel.h
|
||
license:gpl3+)))) ; everything else
|
||
|
||
(define-public exfat-utils
|
||
(package
|
||
(name "exfat-utils")
|
||
(version "1.4.0")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append
|
||
"https://github.com/relan/exfat/releases/download/v"
|
||
version "/exfat-utils-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0sdzflmwcxjjliq1yqhidy46kbkvj16kxrbrgsj0ci0hjgx7a594"))))
|
||
(build-system gnu-build-system)
|
||
(home-page "https://github.com/relan/exfat")
|
||
(synopsis "Utilities to manipulate exFAT file systems")
|
||
(description
|
||
"This package provides an implementation of the exFAT file system,
|
||
including command-line tools to validate exFAT file systems and to create new
|
||
ones.")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public fsarchiver
|
||
(package
|
||
(name "fsarchiver")
|
||
(version "0.8.7")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri
|
||
(git-reference
|
||
(url "https://github.com/fdupoux/fsarchiver")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "1vy8ay0fn32i298bx9scqghi7xm9z2101zxk5xshbrkl00b2m4nm"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
(list autoconf automake pkg-config))
|
||
(inputs
|
||
(list bzip2
|
||
e2fsprogs
|
||
libgcrypt
|
||
lz4
|
||
lzo
|
||
`(,util-linux "lib")
|
||
xz
|
||
zlib
|
||
`(,zstd "lib")))
|
||
(synopsis "File system back-up, deployment, and migration tool")
|
||
(description
|
||
"FSArchiver saves the contents of a file system to a compressed archive
|
||
file, and restores it to a different file system and/or partition. This
|
||
partition can be of a different size than the original and FSArchiver will
|
||
create a new file system if none exists.
|
||
|
||
All standard file attributes supported by the kernel are preserved, including
|
||
file permissions, timestamps, symbolic and hard links, and extended attributes.
|
||
|
||
Each file in the archive is protected by a checksum. If part of the archive
|
||
is corrupted you'll lose the affected file(s) but not the whole back-up.")
|
||
(home-page "https://www.fsarchiver.org/")
|
||
(license license:gpl2)))
|
||
|
||
(define-public fstransform
|
||
(package
|
||
(name "fstransform")
|
||
(version "0.9.4")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/cosmos72/fstransform")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "0vhypb6pbghja95av62ds4mhldbg0h8g4yg94k9r7lsxm7bgpfr3"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
(list #:phases
|
||
#~(modify-phases %standard-phases
|
||
(add-after 'install 'install-README
|
||
;; There are no man pages. Install a poor substitute.
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(doc (string-append out "/share/doc/" #$name)))
|
||
(install-file "README" doc)))))))
|
||
(inputs (list e2fsprogs))
|
||
(home-page "https://github.com/cosmos72/fstransform")
|
||
(synopsis "Convert file system types in place without copying all data")
|
||
(description
|
||
"This package provides several command-line tools to transform a supported
|
||
file system, such as XFS, into one of a different supported type, such as ext4.
|
||
All existing file contents, names, and directories are preserved.
|
||
|
||
The conversion happens @dfn{in place}, without the need to create a complete
|
||
copy of the original data. This lets you transform almost full file systems on
|
||
systems where adding (sufficient) additional storage space is not an option.
|
||
|
||
Do @emph{not} use this package when you could simply create an empty file system
|
||
from scratch and restore from a back-up. Transformation is limited, slow, and
|
||
significantly increases the risk of irreversible data loss!")
|
||
;; Please follow <https://github.com/cosmos72/fstransform/issues/46>.
|
||
(license (list license:gpl2 ; fsattr/src/e4attr.* → sbin/fsattr
|
||
license:gpl3+)))) ; the rest
|
||
|
||
(define-public gocryptfs
|
||
(package
|
||
(name "gocryptfs")
|
||
(version "2.4.0")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/rfjakob/gocryptfs")
|
||
(commit (string-append "v" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"08pdfx6bs1dc2k7xv54x7i1qbych4a7dlf31qwcm9wlz7lr5lawm"))))
|
||
(build-system go-build-system)
|
||
(arguments
|
||
(list
|
||
#:import-path "github.com/rfjakob/gocryptfs"
|
||
#:build-flags
|
||
#~(list
|
||
"-ldflags" (string-append
|
||
"-X main.GitVersion=" #$version
|
||
" -X main.GitVersionFuse=" #$(package-version
|
||
go-github-com-hanwen-go-fuse-v2)
|
||
" -X main.BuildDate=" "[reproducible]"))
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
;; after 'check phase, should maybe unmount leftover mounts as in
|
||
;; https://github.com/rfjakob/gocryptfs/blob/a55b3cc15a6d9bce116a90f33df4bc99d9dd6a10/test.bash#L28
|
||
(replace 'build
|
||
(lambda arguments
|
||
(for-each
|
||
(lambda (directory)
|
||
(apply (assoc-ref %standard-phases 'build)
|
||
(append arguments (list #:import-path directory))))
|
||
(list
|
||
"github.com/rfjakob/gocryptfs"
|
||
"github.com/rfjakob/gocryptfs/gocryptfs-xray"
|
||
"github.com/rfjakob/gocryptfs/contrib/statfs"
|
||
"github.com/rfjakob/gocryptfs/contrib/findholes"
|
||
"github.com/rfjakob/gocryptfs/contrib/atomicrename")))))))
|
||
(native-inputs (list
|
||
go-github-com-hanwen-go-fuse-v2
|
||
go-github-com-aperturerobotics-jacobsa-crypto
|
||
go-github-com-jacobsa-oglematchers
|
||
go-github-com-jacobsa-oglemock
|
||
go-github-com-jacobsa-ogletest
|
||
go-github-com-jacobsa-reqtrace
|
||
go-github-com-pkg-xattr
|
||
go-github-com-rfjakob-eme
|
||
go-github-com-sabhiram-go-gitignore
|
||
go-github-com-spf13-pflag
|
||
go-golang-org-x-crypto
|
||
go-golang-org-x-net
|
||
go-golang-org-x-sys
|
||
go-golang-org-x-term
|
||
openssl
|
||
pkg-config))
|
||
(home-page "https://github.com/rfjakob/gocryptfs")
|
||
(synopsis "Encrypted overlay filesystem")
|
||
(description
|
||
"Gocryptfs is an encrypted overlay filesystem written in Go. It
|
||
features a file-based encryption that is implemented as a mountable
|
||
FUSE filesystem.
|
||
|
||
Gocryptfs was inspired by EncFS and strives to fix its security issues
|
||
while providing good performance. Gocryptfs is as fast as EncFS in the
|
||
default mode and significantly faster than paranoia mode in EncFS,
|
||
which provides a security level comparable to Gocryptfs.
|
||
|
||
On CPUs without AES-NI, gocryptfs uses OpenSSL through a thin wrapper
|
||
called stupidgcm. This provides a 4x speedup compared to Go's builtin
|
||
AES-GCM implementation.")
|
||
(license license:expat)))
|
||
|
||
(define-public gphotofs
|
||
(package
|
||
(name "gphotofs")
|
||
(version "0.5.0")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri
|
||
(string-append "mirror://sourceforge/gphoto/gphotofs/" version
|
||
"/gphotofs-0.5.tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"04slwhr6ap9xcc27wphk22ad8yn79ngyy5z10lxams3k5liahvc2"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
(list pkg-config))
|
||
(inputs
|
||
(list fuse-2 glib libgphoto2))
|
||
(synopsis "Virtual file system for libgphoto2 using FUSE")
|
||
(description "GPhotoFS is a FUSE file system module to mount your camera as
|
||
a file system on Linux. This allow using your camera with any tool able to read
|
||
from a mounted file system.")
|
||
(home-page "http://www.gphoto.org/proj/gphotofs/")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public bcachefs-tools
|
||
(let ((commit "1e358401ecdf1963e5799de19ab69111e82e5ebc")
|
||
(revision "0"))
|
||
(package
|
||
(name "bcachefs-tools")
|
||
(version (git-version "1.2" revision commit))
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://evilpiepirate.org/git/bcachefs-tools.git")
|
||
(commit commit)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "0bflgqb3q9jikyyrv6hywv6m1fapzzn874hlhf86pn6abxrlf5fa"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
(list #:make-flags
|
||
#~(list (string-append "VERSION=" #$version) ; ‘v…-nogit’ otherwise
|
||
(string-append "PREFIX=" #$output)
|
||
"INITRAMFS_DIR=$(PREFIX)/share/initramfs-tools"
|
||
(string-append "CC=" #$(cc-for-target))
|
||
(string-append "PKG_CONFIG=" #$(pkg-config-for-target))
|
||
;; ‘This will be less of an option in the future, as more
|
||
;; code gets rewritten in Rust.’
|
||
"NO_RUST=better")
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(replace 'check
|
||
;; The test suite is moribund upstream (‘never been useful’),
|
||
;; but let's keep running it as a sanity check until then.
|
||
(lambda* (#:key tests? make-flags #:allow-other-keys)
|
||
(when tests?
|
||
;; We must manually build the test_helper first.
|
||
(apply invoke "make" "tests" make-flags)
|
||
(invoke (string-append
|
||
#$(this-package-native-input "python-pytest")
|
||
"/bin/pytest") "-k"
|
||
;; These fail (‘invalid argument’) on kernels
|
||
;; with a previous bcachefs version.
|
||
(string-append "not test_format and "
|
||
"not test_fsck and "
|
||
"not test_list and "
|
||
"not test_list_inodes and "
|
||
"not test_list_dirent")))))
|
||
(add-after 'install 'promote-mount.bcachefs.sh
|
||
;; The (optional) ‘mount.bcachefs’ requires rust:cargo.
|
||
;; This shell alternative does the job well enough for now.
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(define (whence file)
|
||
(dirname (search-input-file inputs file)))
|
||
(let ((mount (string-append #$output
|
||
"/sbin/mount.bcachefs")))
|
||
(delete-file mount) ; symlink to ‘bcachefs’
|
||
(copy-file "mount.bcachefs.sh" mount)
|
||
;; WRAP-SCRIPT causes bogus ‘Insufficient arguments’ errors.
|
||
(wrap-program mount
|
||
`("PATH" ":" prefix
|
||
,(list (getcwd)
|
||
(whence "bin/tail")
|
||
(whence "bin/awk")
|
||
(whence "bin/mount"))))))))))
|
||
(native-inputs
|
||
(cons* pkg-config
|
||
;; For generating documentation with rst2man.
|
||
python
|
||
python-docutils
|
||
;; For tests.
|
||
python-pytest
|
||
(if (member (%current-system) (package-supported-systems valgrind))
|
||
(list valgrind)
|
||
'())))
|
||
(inputs
|
||
(list eudev
|
||
keyutils
|
||
libaio
|
||
libscrypt
|
||
libsodium
|
||
liburcu
|
||
`(,util-linux "lib")
|
||
lz4
|
||
zlib
|
||
`(,zstd "lib")
|
||
|
||
;; Only for mount.bcachefs.sh.
|
||
coreutils-minimal
|
||
gawk
|
||
util-linux))
|
||
(home-page "https://bcachefs.org/")
|
||
(synopsis "Tools to create and manage bcachefs file systems")
|
||
(description
|
||
"The bcachefs-tools are command-line utilities for creating, checking,
|
||
and otherwise managing bcachefs file systems.
|
||
|
||
Bcachefs is a @acronym{CoW, copy-on-write} file system supporting native
|
||
encryption, compression, snapshots, and (meta)data checksums. It can use
|
||
multiple block devices for replication and/or performance, similar to RAID.
|
||
|
||
In addition, bcachefs provides all the functionality of bcache, a block-layer
|
||
caching system, and lets you assign different roles to each device based on its
|
||
performance and other characteristics.")
|
||
(license license:gpl2+))))
|
||
|
||
(define-public bcachefs-tools/static
|
||
(package
|
||
(inherit bcachefs-tools)
|
||
(name "bcachefs-tools-static")
|
||
(arguments
|
||
(substitute-keyword-arguments (package-arguments bcachefs-tools)
|
||
((#:make-flags make-flags)
|
||
#~(append #$make-flags
|
||
(list "LDFLAGS=-static")))))
|
||
(inputs (modify-inputs (package-inputs bcachefs-tools)
|
||
(prepend `(,eudev "static")
|
||
`(,keyutils "static")
|
||
`(,libscrypt "static")
|
||
`(,lz4 "static")
|
||
`(,util-linux "static")
|
||
`(,zlib "static")
|
||
`(,zstd "static"))))))
|
||
|
||
(define-public bcachefs/static
|
||
(package
|
||
(name "bcachefs-static")
|
||
(version (package-version bcachefs-tools))
|
||
(source #f)
|
||
(build-system trivial-build-system)
|
||
(arguments
|
||
(list #:modules '((guix build utils))
|
||
#:builder
|
||
#~(begin
|
||
(use-modules (guix build utils)
|
||
(ice-9 ftw)
|
||
(srfi srfi-26))
|
||
(mkdir-p #$output)
|
||
(with-directory-excursion #$output
|
||
(install-file (string-append #$(this-package-input
|
||
"bcachefs-tools-static")
|
||
"/sbin/bcachefs")
|
||
"sbin")
|
||
(remove-store-references "sbin/bcachefs")
|
||
(invoke "sbin/bcachefs" "version"))))) ; test suite
|
||
(inputs
|
||
(list bcachefs-tools/static))
|
||
(home-page (package-home-page bcachefs-tools))
|
||
(synopsis "Statically-linked bcachefs command from bcachefs-tools")
|
||
(description "This package provides the statically-linked @command{bcachefs}
|
||
from the bcachefs-tools package. It is meant to be used in initrds.")
|
||
(license (package-license bcachefs-tools))))
|
||
|
||
(define-public exfatprogs
|
||
(package
|
||
(name "exfatprogs")
|
||
(version "1.2.1")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/exfatprogs/exfatprogs")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "1g5aqhjz0l58kvmis1j5b5qkn58hjs582f36ygiqkgxvp4njkny4"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:configure-flags
|
||
(list "--disable-static")))
|
||
(native-inputs
|
||
(list autoconf automake libtool pkg-config))
|
||
(home-page "https://github.com/exfatprogs/exfatprogs")
|
||
(synopsis "Tools to create, check, and repair exFAT file systems")
|
||
(description
|
||
"These are command-line user space tools for the @acronym{exFAT,
|
||
Extensible File Allocation Table} file systems. Included are
|
||
@command{mkfs.exfat} to create (format) new exFAT file systems, and
|
||
@command{fsck.exfat} to check their consistency and repair them.")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public httpfs2
|
||
(package
|
||
(name "httpfs2")
|
||
(version "0.1.5")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://sourceforge/httpfs/httpfs2/"
|
||
"httpfs2-" version ".tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"1h8ggvhw30n2r6w11n1s458ypggdqx6ldwd61ma4yd7binrlpjq1"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
(list asciidoc docbook-xml libxml2 libxslt pkg-config))
|
||
(inputs
|
||
(list fuse-2 gnutls))
|
||
(arguments
|
||
(list #:phases
|
||
#~(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(replace 'install
|
||
;; There's no ‘install’ target. Install all variants manually.
|
||
(lambda _
|
||
(let* ((bin (string-append #$output "/bin"))
|
||
(man1 (string-append #$output "/share/man/man1")))
|
||
(mkdir-p bin)
|
||
(mkdir-p man1)
|
||
(for-each
|
||
(lambda (variant)
|
||
(let ((man1-page (string-append variant ".1")))
|
||
(install-file variant bin)
|
||
(install-file man1-page man1)))
|
||
(list "httpfs2"
|
||
"httpfs2-mt"
|
||
"httpfs2-ssl"
|
||
"httpfs2-ssl-mt"))))))
|
||
#:make-flags
|
||
#~(list (string-append "CC=" #$(cc-for-target)))
|
||
#:parallel-build? #f ; can result in missing man pages
|
||
#:tests? #f)) ; no tests
|
||
(home-page "https://sourceforge.net/projects/httpfs/")
|
||
(synopsis "Mount remote files over HTTP")
|
||
(description "httpfs2 is a @code{fuse} file system for mounting any
|
||
@dfn{HyperText} (HTTP or HTTPS) URL. It uses HTTP/1.1 byte ranges to request
|
||
arbitrary bytes from the web server, without needing to download the entire
|
||
file. This is particularly useful with large archives such as ZIP files and
|
||
ISO images when you only need to inspect their contents or extract specific
|
||
files. Since the HTTP protocol itself has no notion of directories, only a
|
||
single file can be mounted.")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public jfsutils
|
||
(package
|
||
(name "jfsutils")
|
||
(version "1.1.15")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "http://jfs.sourceforge.net/project/pub/jfsutils-"
|
||
version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0kbsy2sk1jv4m82rxyl25gwrlkzvl3hzdga9gshkxkhm83v1aji4"))
|
||
(patches (search-patches "jfsutils-add-sysmacros.patch"
|
||
"jfsutils-gcc-compat.patch"
|
||
"jfsutils-include-systypes.patch"))))
|
||
(build-system gnu-build-system)
|
||
(inputs
|
||
(list `(,util-linux "lib")))
|
||
(home-page "https://jfs.sourceforge.net/home.html")
|
||
(synopsis "Utilities for managing JFS file systems")
|
||
(description
|
||
"The JFSutils are a collection of utilities for managing the @acronym{JFS,
|
||
Journaled File System}, a 64-bit journaling file system created by IBM and later
|
||
ported to the kernel Linux. The following commands are available:
|
||
@enumerate
|
||
@item @command{fsck.jfs}: check and repair a JFS file system or replay its
|
||
transaction log.
|
||
@item @command{logdump}: dump the JFS journal log.
|
||
@item @command{logredo}: replay the JFS journal log.
|
||
@item @command{mkfs.jfs}: create a new JFS file system.
|
||
@item @command{xchklog}: save a JFS fsck log to a file.
|
||
@item @command{xchkdmp}: dump the contents of such a log file.
|
||
@item @command{xpeek}: a JFS file system editor with a shell-like interface.
|
||
@end enumerate\n")
|
||
(license license:gpl3+))) ; no explicit version given
|
||
|
||
(define-public jfsutils/static
|
||
(static-package
|
||
(package
|
||
(inherit jfsutils)
|
||
(name "jfsutils-static")
|
||
(inputs
|
||
`(("util-linux:static" ,util-linux "static")
|
||
,@(package-inputs jfsutils))))))
|
||
|
||
(define-public jfs_fsck/static
|
||
(package
|
||
(name "jfs_fsck-static")
|
||
(version (package-version jfsutils))
|
||
(source #f)
|
||
(build-system trivial-build-system)
|
||
(arguments
|
||
`(#:modules ((guix build utils))
|
||
#:builder
|
||
(begin
|
||
(use-modules (guix build utils)
|
||
(ice-9 ftw)
|
||
(srfi srfi-26))
|
||
(let* ((jfsutils (assoc-ref %build-inputs "jfsutils"))
|
||
(fsck "jfs_fsck")
|
||
(out (assoc-ref %outputs "out"))
|
||
(sbin (string-append out "/sbin")))
|
||
(mkdir-p sbin)
|
||
(with-directory-excursion sbin
|
||
(install-file (string-append jfsutils "/sbin/" fsck)
|
||
".")
|
||
(remove-store-references fsck)
|
||
(chmod fsck #o555))
|
||
#t))))
|
||
(inputs
|
||
`(("jfsutils" ,jfsutils/static)))
|
||
(home-page (package-home-page jfsutils))
|
||
(synopsis "Statically-linked jfs_fsck command from jfsutils")
|
||
(description "This package provides statically-linked jfs_fsck command taken
|
||
from the jfsutils package. It is meant to be used in initrds.")
|
||
(license (package-license jfsutils))))
|
||
|
||
(define-public nilfs-utils
|
||
(package
|
||
(name "nilfs-utils")
|
||
(version "2.2.9")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://nilfs.sourceforge.io/download"
|
||
"/nilfs-utils-" version ".tar.bz2"))
|
||
(sha256
|
||
(base32 "15vsayvzr8nc29n939sz9ddq46vpn53rp8h8qv484h88qac3kxjx"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
(list
|
||
#:configure-flags
|
||
#~(list "--enable-static=no")
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
(add-before 'bootstrap 'force-bootstrap
|
||
(lambda _
|
||
(delete-file "configure")
|
||
(substitute* "configure.ac"
|
||
(("\\[/etc\\]") "[${prefix}/etc]")
|
||
(("\\[/sbin\\]") "[${prefix}/sbin]")))))))
|
||
(inputs
|
||
(list (list util-linux "lib")))
|
||
(native-inputs (list autoconf automake libtool))
|
||
(home-page "https://nilfs.sourceforge.io/")
|
||
(synopsis "Continuous Snapshotting Filesystem")
|
||
(description
|
||
"NILFS is a log-structured file system supporting versioning of the entire
|
||
file system and continuous snapshotting, which allows users to even restore
|
||
files mistakenly overwritten or destroyed just a few seconds ago.")
|
||
(license license:gpl3+)))
|
||
|
||
(define-public disorderfs
|
||
(package
|
||
(name "disorderfs")
|
||
(version "0.5.11")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://salsa.debian.org/reproducible-builds/disorderfs.git")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"1pnrj0h8sgqwgsc18vz3fkqsp6vhigdbi75vdj0si1r6wgslnr7z"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
(list pkg-config))
|
||
(inputs
|
||
(list fuse-2 attr))
|
||
(arguments
|
||
`(#:phases (modify-phases %standard-phases
|
||
(delete 'configure)) ; no configure script
|
||
#:make-flags (let ((out (assoc-ref %outputs "out")))
|
||
(list (string-append "PREFIX=" out)))
|
||
#:test-target "test"
|
||
;; FIXME: Tests require 'run-parts' which is not in Guix yet.
|
||
#:tests? #f))
|
||
(home-page "https://salsa.debian.org/reproducible-builds/disorderfs")
|
||
(synopsis "FUSE file system that introduces non-determinism")
|
||
(description
|
||
"An overlay FUSE file system that introduces non-determinism
|
||
into file system metadata. For example, it can randomize the order
|
||
in which directory entries are read. This is useful for detecting
|
||
non-determinism in the build process.")
|
||
(license license:gpl3+)))
|
||
|
||
(define-public glusterfs
|
||
(package
|
||
(name "glusterfs")
|
||
(version "7.0")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://download.gluster.org/pub/gluster/glusterfs/"
|
||
(version-major version) "/"
|
||
(version-major+minor version) "/"
|
||
"glusterfs-" version ".tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"0yzhx710ypj0j3m5dcgmmgvkp7p0rmmp2p7ld0axrm4vpwc2b1wa"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:configure-flags
|
||
(let ((out (assoc-ref %outputs "out"))
|
||
(p2 (assoc-ref %build-inputs "python-2")))
|
||
(list (string-append "PYTHON=" p2 "/bin/python")
|
||
(string-append "--with-initdir=" out "/etc/init.d")
|
||
(string-append "--with-mountutildir=" out "/sbin")
|
||
"--enable-cmocka" ; unit tests
|
||
;; "--enable-debug" ; debug build options
|
||
;; "--enable-asan" ; Address Sanitizer
|
||
;; "--enable-tsan" ; ThreadSanitizer
|
||
))
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-before 'configure 'autogen
|
||
(lambda _ (invoke "./autogen.sh"))))))
|
||
(native-inputs
|
||
`(("pkg-config" ,pkg-config)
|
||
("libtirpc" ,libtirpc)
|
||
("rpcsvc-proto" ,rpcsvc-proto)
|
||
("python-2" ,python-2) ; must be version 2
|
||
("flex" ,flex)
|
||
("bison" ,bison)
|
||
("libtool" ,libtool)
|
||
("autoconf" ,autoconf)
|
||
("automake" ,automake)
|
||
("cmocka" ,cmocka)))
|
||
(inputs
|
||
`(("acl" ,acl)
|
||
("fuse" ,fuse-2)
|
||
("openssl" ,openssl)
|
||
("liburcu" ,liburcu)
|
||
("libuuid" ,util-linux "lib")
|
||
("libxml2" ,libxml2)
|
||
("readline" ,readline)
|
||
("zlib" ,zlib)
|
||
("libaio" ,libaio)
|
||
("rdma-core" ,rdma-core)))
|
||
(home-page "https://www.gluster.org")
|
||
(synopsis "Distributed file system")
|
||
(description "GlusterFS is a distributed scalable network file system
|
||
suitable for data-intensive tasks such as cloud storage and media streaming.
|
||
It allows rapid provisioning of additional storage based on your storage
|
||
consumption needs. It incorporates automatic failover as a primary feature.
|
||
All of this is accomplished without a centralized metadata server.")
|
||
;; The user may choose either LGPLv3+ or GPLv2 only.
|
||
(license (list license:lgpl3+ license:gpl2+))))
|
||
|
||
(define-public curlftpfs
|
||
(package
|
||
(name "curlftpfs")
|
||
(version "0.9.2")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://sourceforge/curlftpfs/curlftpfs/" version
|
||
"/curlftpfs-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0n397hmv21jsr1j7zx3m21i7ryscdhkdsyqpvvns12q7qwwlgd2f"))
|
||
(patches
|
||
(search-patches "curlftpfs-fix-error-closing-file.patch"
|
||
"curlftpfs-fix-file-names.patch"
|
||
"curlftpfs-fix-memory-leak.patch"
|
||
"curlftpfs-fix-no_verify_hostname.patch"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:phases
|
||
(modify-phases %standard-phases
|
||
(add-after 'unpack 'fix-test
|
||
(lambda _
|
||
;; One of the 512-Byte block counts is definitely wrong.
|
||
;; See <https://sourceforge.net/p/curlftpfs/bugs/73/>.
|
||
(substitute* "tests/ftpfs-ls_unittest.c"
|
||
(("4426192") "12814800"))
|
||
#t)))))
|
||
(inputs
|
||
(list curl glib fuse-2))
|
||
(native-inputs
|
||
(list pkg-config))
|
||
(home-page "https://curlftpfs.sourceforge.net/")
|
||
(synopsis "Mount remote file systems over FTP")
|
||
(description
|
||
"This is a file system client based on the FTP File Transfer Protocol.")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public libeatmydata
|
||
(package
|
||
(name "libeatmydata")
|
||
(version "131") ; also update the "debian-files" input if available
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://www.flamingspork.com/projects/libeatmydata/"
|
||
"libeatmydata-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "1i5bp9a2vmljci3ihzlxf8482106di2ayy1lpr0qb8rq472sh66g"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
;; All tests pass---but only if the host kernel allows PTRACE_TRACEME.
|
||
`(#:tests? #f
|
||
#:configure-flags
|
||
(list "--disable-static")
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-after 'unpack 'patch-file-names
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(substitute* (list "eatmydata.in" "eatmydata.sh.in")
|
||
(("basename|readlink|uname" command)
|
||
(search-input-file inputs
|
||
(string-append "bin/" command))))))
|
||
(add-before 'patch-file-names 'tighten-symlink-mode
|
||
;; When the ‘eatmydata’ helper detects that it's a symlink, it will
|
||
;; transparently invoke the command of the same name. However, it's
|
||
;; *always* a link in Guix profiles and doesn't handle that well.
|
||
;; Patch it to treat its own $name specially.
|
||
(lambda _
|
||
(substitute* "eatmydata.in"
|
||
(("-L \"\\$0\"" match)
|
||
(string-append match " ] && [ "
|
||
"\"x$(basename \"$0\")\" != \"x$name\"")))))
|
||
(add-after 'install 'install-debian-files
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let* ((debian (assoc-ref inputs "debian-files"))
|
||
(out (assoc-ref outputs "out"))
|
||
(share (string-append out "/share")))
|
||
(invoke "tar" "xvf" debian)
|
||
(with-directory-excursion "debian"
|
||
(install-file "eatmydata.1" (string-append share "/man/man1"))
|
||
(install-file "eatmydata.bash-completion"
|
||
(string-append share "/bash-completion"
|
||
"/completions")))))))))
|
||
(native-inputs
|
||
`(("debian-files" ; for the man page
|
||
,(origin
|
||
;; Debian being what it is, its version can lag behind a bit. This
|
||
;; is tolerable as the man page is general and the command stable.
|
||
(method url-fetch)
|
||
(uri (string-append "https://deb.debian.org/debian/pool/main/"
|
||
"libe/libeatmydata/libeatmydata_130-2"
|
||
".debian.tar.xz"))
|
||
(sha256
|
||
(base32 "1sg9g1nv3wl9ymzz33ig4ns563npkbxj67a64m7p34cc813jl95w"))))
|
||
;; For the test suite.
|
||
("strace" ,strace)
|
||
("which" ,which)))
|
||
(inputs
|
||
(list coreutils))
|
||
(home-page "https://www.flamingspork.com/projects/libeatmydata/")
|
||
(synopsis "Transparently ignore calls to synchronize data safely to disk")
|
||
(description
|
||
"Libeatmydata transparently disables most ways a program might force data
|
||
to be written to the file system, such as @code{fsync()} or @code{open(O_SYNC)}.
|
||
|
||
Such synchronisation calls provide important data integrity guarantees but are
|
||
expensive to perform and can significantly slow down software that (over)uses
|
||
them.
|
||
|
||
This price is worth paying if you care about the files being modified---which is
|
||
typically the case---or when manipulating important components of your system.
|
||
Please, @emph{do not} use something called ``eat my data'' in such cases!
|
||
|
||
However, it does not make sense to accept this performance hit if the data is
|
||
unimportant and you can afford to lose all of it in the event of a crash, for
|
||
example when running a software test suite. Adding @file{libeatmydata.so} to
|
||
the @env{LD_PRELOAD} environment of such tasks will override all C library data
|
||
synchronisation functions with custom @i{no-op} ones that do nothing and
|
||
immediately return success.
|
||
|
||
A simple @command{eatmydata} script is included that does this for you.")
|
||
(license license:gpl3+)))
|
||
|
||
(define-public libnfs
|
||
(package
|
||
(name "libnfs")
|
||
(version "4.0.0")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/sahlberg/libnfs")
|
||
(commit (string-append "libnfs-" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"0i27wd4zvhjz7620q043p4d4mkx8zv2yz9adm1byin47dynahyda"))))
|
||
(build-system gnu-build-system)
|
||
(home-page "https://github.com/sahlberg/libnfs")
|
||
(native-inputs
|
||
(list autoconf automake libtool pkg-config))
|
||
(synopsis "Client library for accessing NFS shares")
|
||
(description "LIBNFS is a client library for accessing NFS shares over a
|
||
network. LIBNFS offers three different APIs, for different use :
|
||
|
||
@enumerate
|
||
@item RAW, a fully asynchronous low level RPC library for NFS protocols. This
|
||
API provides very flexible and precise control of the RPC issued.
|
||
@item NFS ASYNC, a fully asynchronous library for high level vfs functions
|
||
@item NFS SYNC, a synchronous library for high level vfs functions.
|
||
@end enumerate\n")
|
||
(license (list license:lgpl2.1+ ; library
|
||
license:gpl3+ ; tests
|
||
license:bsd-3 ; copied nsf4 files
|
||
))))
|
||
|
||
(define-public apfs-fuse
|
||
(let ((commit "66b86bd525e8cb90f9012543be89b1f092b75cf3")
|
||
(revision "2"))
|
||
(package
|
||
(name "apfs-fuse")
|
||
(version (git-version "0.0.0" revision commit))
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/sgan81/apfs-fuse")
|
||
(recursive? #t) ; for lzfse
|
||
(commit commit)))
|
||
(sha256
|
||
(base32 "0f63slyzv8fbgshpzrx2g01x9h73g5yvh5kis4yazl19fjm2b05r"))
|
||
(file-name (git-file-name name version))))
|
||
(build-system cmake-build-system)
|
||
(arguments
|
||
`(#:tests? #f ; No test suite
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
;; No 'install' target in CMakeLists.txt
|
||
(replace 'install
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(bin (string-append out "/bin"))
|
||
(lib (string-append out "/lib"))
|
||
(doc (string-append out "/share/doc/"
|
||
(string-append ,name "-" ,version))))
|
||
(install-file "apfs-dump" bin)
|
||
(install-file "apfs-dump-quick" bin)
|
||
(install-file "apfs-fuse" bin)
|
||
(install-file "../source/README.md" doc)))))))
|
||
(inputs
|
||
(list bzip2 fuse zlib))
|
||
(synopsis "Read-only FUSE driver for the APFS file system")
|
||
(description "APFS-FUSE is a read-only FUSE driver for the @dfn{Apple File
|
||
System} (APFS). It is currently in an experimental state — it may not be able
|
||
to read all files, and it does not support all the compression methods in
|
||
APFS.")
|
||
(home-page "https://github.com/sgan81/apfs-fuse")
|
||
(license license:gpl2+))))
|
||
|
||
(define-public xfstests
|
||
;; The last release (1.1.0) is from 2011.
|
||
(let ((revision "3")
|
||
(commit "8de535c53887bb49adae74a1b2e83e77d7e8457d"))
|
||
(package
|
||
(name "xfstests")
|
||
(version (git-version "1.1.0" revision commit))
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "git://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git")
|
||
(commit commit)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "1sbkryl04xflrk6jb4fsl3h2whilj5m3vpdkpwwb26idp7ckjjv6"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
(list
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
(add-after 'unpack 'patch-tool-locations
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(substitute* "common/config"
|
||
;; Make absolute file names relative.
|
||
(("(MKFS_PROG=\").*(\")" _ pre post)
|
||
(string-append pre "mkfs" post)))
|
||
(for-each (lambda (file)
|
||
(substitute* file
|
||
(("( -s|#.|[= ])(/bin/sh|/bin/bash)" _ pre match)
|
||
(string-append pre
|
||
(search-input-file inputs match)))
|
||
(("/bin/(rm|true)" match)
|
||
(search-input-file inputs match))
|
||
(("/usr(/bin/time)" _ match)
|
||
(search-input-file inputs match))))
|
||
(append (find-files "common" ".*")
|
||
(find-files "tests" ".*")
|
||
(find-files "tools" ".*")
|
||
(find-files "src" "\\.(c|sh)$")))))
|
||
(replace 'bootstrap
|
||
(lambda* (#:key make-flags #:allow-other-keys)
|
||
(substitute* "Makefile"
|
||
;; Avoid a mysterious (to me) ‘permission denied’ error.
|
||
(("cp ") "cp -f "))
|
||
(substitute* "m4/package_utilies.m4"
|
||
;; Fix the bogus hard-coded paths for every single binary.
|
||
(("(AC_PATH_PROG\\(.*, ).*(\\))" _ pre post)
|
||
(string-append pre (getenv "PATH") post)))
|
||
(apply invoke "make" "configure" make-flags)))
|
||
(add-after 'install 'wrap-xfstests/check
|
||
;; Keep wrapping distinct from 'create-helper-script below: users
|
||
;; must be able to invoke xfstests/check directly if they prefer.
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(wrap-program (string-append #$output "/xfstests/check")
|
||
;; Prefix the user's PATH with the minimum required tools.
|
||
;; The suite has many other optional dependencies and will
|
||
;; automatically select tests based on the original PATH.
|
||
`("PATH" ":" prefix
|
||
,(map (lambda (file)
|
||
(dirname (search-input-file inputs file)))
|
||
(list "bin/setfacl" ; acl
|
||
"bin/attr" ; attr
|
||
"bin/bc" ; bc
|
||
"bin/df" ; coreutils
|
||
"bin/hostname" ; inetutils
|
||
"bin/perl" ; perl
|
||
"sbin/mkfs.xfs")))))) ; xfsprogs
|
||
(add-after 'install 'create-helper
|
||
;; Upstream installs only a ‘check’ script that's not in $PATH and
|
||
;; would try to write to the store without explaining how to change
|
||
;; that. Install a simple helper script to make it discoverable.
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(let* ((check (string-append #$output "/xfstests/check"))
|
||
(bin (string-append #$output "/bin"))
|
||
(helper (string-append bin "/xfstests-check")))
|
||
(mkdir-p bin)
|
||
(with-output-to-file helper
|
||
(lambda _
|
||
(format #t "#!~a --no-auto-compile\n!#\n"
|
||
(search-input-file inputs "/bin/guile"))
|
||
(write
|
||
`(begin
|
||
(define (try proc dir)
|
||
"Try to PROC DIR. Return DIR on success, else #f."
|
||
(with-exception-handler (const #f)
|
||
(lambda _ (proc dir) dir)
|
||
#:unwind? #t))
|
||
|
||
(define args
|
||
(cdr (command-line)))
|
||
|
||
(when (or (member "--help" args)
|
||
(member "-h" args))
|
||
(format #t "Usage: ~a [OPTION]...
|
||
This Guix helper sets up a new writable RESULT_BASE if it's unset, then executes
|
||
xfstest's \"~a\" command (with any OPTIONs) as documented below.\n\n"
|
||
,(basename helper)
|
||
,(basename check)))
|
||
|
||
(let* ((gotenv-base (getenv "RESULT_BASE"))
|
||
(base (or gotenv-base
|
||
(let loop ((count 0))
|
||
(or (try mkdir
|
||
(format #f "xfstests.~a"
|
||
count))
|
||
(loop (+ 1 count))))))
|
||
(result-base (if (string-prefix? "/" base)
|
||
base
|
||
(string-append (getcwd) "/"
|
||
base))))
|
||
(setenv "RESULT_BASE" result-base)
|
||
;; CHECK must run in its own directory or will fail.
|
||
(chdir ,(dirname check))
|
||
(let ((status
|
||
(status:exit-val (apply system* ,check args))))
|
||
(unless gotenv-base
|
||
(try rmdir result-base))
|
||
status))))))
|
||
(chmod helper #o755)))))))
|
||
(native-inputs
|
||
(list autoconf automake libtool))
|
||
(inputs
|
||
(list acl
|
||
attr
|
||
bc
|
||
guile-3.0 ; for our xfstests-check helper script
|
||
inetutils
|
||
`(,util-linux "lib")
|
||
perl
|
||
time
|
||
xfsprogs))
|
||
(home-page "https://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git")
|
||
(synopsis "File system @acronym{QA, Quality Assurance} test suite")
|
||
(description
|
||
"The @acronym{FSQA, File System Quality Assurance} regression test suite,
|
||
more commonly known as xfstests, comprises over 1,500 tests that exercise
|
||
(@dfn{torture}) both the user- and kernel-space parts of many different file
|
||
systems.
|
||
|
||
As the package's name subtly implies, it was originally developed to test the
|
||
XFS file system. Today, xfstests is the primary test suite for all major file
|
||
systems supported by the kernel Linux including XFS, ext4, and Btrfs, but also
|
||
virtual and network file systems such as NFS, 9P, and the overlay file system.
|
||
|
||
The packaged @command{check} script is not in @env{PATH} but can be invoked
|
||
with the included @command{xfstests-check} helper.")
|
||
(license license:gpl2))))
|
||
|
||
(define-public zfs
|
||
(package
|
||
(name "zfs")
|
||
(version "2.1.14")
|
||
(outputs '("out" "module" "src"))
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://github.com/openzfs/zfs/releases"
|
||
"/download/zfs-" version
|
||
"/zfs-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0gzansmin40llxxh2zkgpdyp41ikd8s5hv5mpwhpcivk1q8fv7sh"))))
|
||
(build-system linux-module-build-system)
|
||
(arguments
|
||
(list
|
||
;; The ZFS kernel module should not be downloaded since the license
|
||
;; terms don't allow for distributing it, only building it locally.
|
||
#:substitutable? #f
|
||
;; Tests cannot run in an unprivileged build environment.
|
||
#:tests? #f
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
(add-after 'configure 'really-configure
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(substitute* "configure"
|
||
(("-/bin/sh") (string-append "-" (which "sh"))))
|
||
(invoke "./configure"
|
||
"--with-config=all"
|
||
(string-append "--prefix=" #$output)
|
||
(string-append "--with-dracutdir=" #$output
|
||
"/lib/dracut")
|
||
(string-append "--with-udevdir=" #$output
|
||
"/lib/udev")
|
||
(string-append "--with-mounthelperdir=" #$output
|
||
"/sbin")
|
||
(string-append "--with-linux="
|
||
(search-input-directory
|
||
inputs
|
||
"lib/modules/build")))))
|
||
(add-after 'unpack 'patch-source
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
;; New feature "compatibility=" in 2.1.0.
|
||
;; This feature looks up in two locations:
|
||
;; /etc/zfs/compatibility.d/
|
||
;; /usr/share/zfs/compatibility.d/
|
||
;; The first is intended for system-specific compatibility
|
||
;; sets, while the second is what is installed with the
|
||
;; OpenZFS package, so use the absolute path for the first
|
||
;; (which requires patching in the file) and the store path
|
||
;; for the second (which it gets by default).
|
||
(substitute* "include/sys/fs/zfs.h"
|
||
(("#define\tZPOOL_SYSCONF_COMPAT_D.*$")
|
||
;; Use absolute path.
|
||
"#define\tZPOOL_SYSCONF_COMPAT_D\t\"/etc/zfs/compatibility.d\"\n"))
|
||
;; Also update the manual, which uses absolute paths, so that
|
||
;; /usr/share/zfs/compatibility.d/ is referred via the store.
|
||
(substitute* '("man/man7/zpoolprops.7"
|
||
"man/man7/zpool-features.7")
|
||
(("/usr/share/zfs/compatibility.d")
|
||
(string-append #$output "/share/zfs/compatibility.d")))
|
||
(substitute* "etc/Makefile.in"
|
||
;; This just contains an example configuration file for
|
||
;; configuring ZFS on traditional init systems, skip it
|
||
;; since we cannot use it anyway; the install target becomes
|
||
;; misdirected.
|
||
(("= default ") "= "))
|
||
(substitute* "lib/libzfs/os/linux/libzfs_util_os.c"
|
||
;; Use path to /gnu/store/*-kmod in actual path that is
|
||
;; exec'ed.
|
||
(("\"/sbin/modprobe\"")
|
||
(string-append "\""
|
||
(search-input-file inputs "/bin/modprobe")
|
||
"\""))
|
||
;; Just use 'modprobe' in message to user, since Guix
|
||
;; does not have a traditional /sbin/
|
||
(("'/sbin/modprobe ") "'modprobe "))
|
||
(substitute* "contrib/Makefile.in"
|
||
;; This is not configurable nor is its hard-coded /usr prefix.
|
||
((" initramfs") ""))
|
||
(substitute* "module/os/linux/zfs/zfs_ctldir.c"
|
||
(("/usr/bin/env\", \"umount")
|
||
(string-append (search-input-file inputs "/bin/umount")
|
||
"\", \"-n"))
|
||
(("/usr/bin/env\", \"mount")
|
||
(string-append (search-input-file inputs "/bin/mount")
|
||
"\", \"-n")))
|
||
(substitute* "lib/libzfs/os/linux/libzfs_mount_os.c"
|
||
(("/bin/mount") (search-input-file inputs "/bin/mount"))
|
||
(("/bin/umount") (search-input-file inputs "/bin/umount")))
|
||
(substitute* "lib/libshare/os/linux/nfs.c"
|
||
(("/usr/sbin/exportfs")
|
||
(search-input-file inputs "/sbin/exportfs")))
|
||
(substitute* "config/zfs-build.m4"
|
||
(("\\$sysconfdir/init.d")
|
||
(string-append #$output "/etc/init.d")))
|
||
(substitute* '("etc/zfs/Makefile.am"
|
||
"cmd/zed/Makefile.am")
|
||
(("\\$\\(sysconfdir)") (string-append #$output "/etc")))
|
||
(substitute* "cmd/vdev_id/vdev_id"
|
||
(("PATH=/bin:/sbin:/usr/bin:/usr/sbin")
|
||
(string-append "PATH="
|
||
(dirname (which "chmod")) ":"
|
||
(dirname (which "grep")) ":"
|
||
(dirname (which "sed")) ":"
|
||
(dirname (which "gawk")))))
|
||
(substitute* "contrib/pyzfs/Makefile.in"
|
||
((".*install-lib.*") ""))
|
||
(substitute* '("Makefile.am" "Makefile.in")
|
||
(("\\$\\(prefix)/src") (string-append #$output:src "/src")))
|
||
(substitute* (find-files "udev/rules.d/" ".rules.in$")
|
||
(("/sbin/modprobe")
|
||
(search-input-file inputs "/bin/modprobe")))))
|
||
(replace 'build
|
||
(lambda _ (invoke "make")))
|
||
(replace 'install
|
||
(lambda* (#:key inputs native-inputs #:allow-other-keys)
|
||
(let* ((kmod (assoc-ref (or native-inputs inputs) "kmod")))
|
||
(invoke "make" "install"
|
||
(string-append "DEFAULT_INITCONF_DIR="
|
||
#$output "/etc/default")
|
||
(string-append "DEPMOD="
|
||
(search-input-file
|
||
(or native-inputs inputs)
|
||
"/bin/depmod"))
|
||
(string-append "INSTALL_PATH=" #$output)
|
||
(string-append "INSTALL_MOD_PATH=" #$output:module)
|
||
"INSTALL_MOD_STRIP=1")
|
||
(install-file
|
||
"contrib/bash_completion.d/zfs"
|
||
(string-append #$output
|
||
"/share/bash-completion/completions"))))))))
|
||
(native-inputs
|
||
(list attr kmod pkg-config))
|
||
(inputs (list eudev
|
||
kmod
|
||
libaio
|
||
libtirpc
|
||
nfs-utils
|
||
openssl
|
||
python
|
||
python-cffi
|
||
util-linux
|
||
`(,util-linux "lib")
|
||
zlib))
|
||
(home-page "https://zfsonlinux.org/")
|
||
(synopsis "OpenZFS on Linux")
|
||
(description
|
||
"OpenZFS is an advanced file system and volume manager which was
|
||
originally developed for Solaris and is now maintained by the OpenZFS
|
||
community.")
|
||
(license license:cddl1.0)))
|
||
|
||
(define-public zfs-auto-snapshot
|
||
(package
|
||
(name "zfs-auto-snapshot")
|
||
(version "1.2.4")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url
|
||
(string-append "https://github.com/zfsonlinux/" name))
|
||
(commit
|
||
(string-append "upstream/" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "0m4xw7h5qlbn5zdf9wb137pcr5l7hyrr7w2dgr16dfm5ay64vvfq"))))
|
||
(build-system gnu-build-system)
|
||
(inputs
|
||
;; Note: if you are inheriting from the above zfs package in order
|
||
;; to provide a specific stable kernel version, you should also
|
||
;; inherit this package and replace the sole input below.
|
||
(list zfs))
|
||
(arguments
|
||
`(#:tests? #f ; No tests
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure)
|
||
(delete 'build)
|
||
;; Guix System may not have a traditional cron system, but
|
||
;; the cron scripts installed by this package are convenient
|
||
;; to use as targets for an mcron job specification, so make
|
||
;; sure they can be run in-store.
|
||
(add-before 'install 'fix-scripts
|
||
(lambda* (#:key outputs inputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(zfs-auto-snapshot (string-append
|
||
out
|
||
"/sbin/zfs-auto-snapshot"))
|
||
(zfs-package (assoc-ref inputs "zfs"))
|
||
(zpool (string-append
|
||
zfs-package
|
||
"/sbin/zpool"))
|
||
(zfs (string-append
|
||
zfs-package
|
||
"/sbin/zfs")))
|
||
(substitute* '("etc/zfs-auto-snapshot.cron.daily"
|
||
"etc/zfs-auto-snapshot.cron.frequent"
|
||
"etc/zfs-auto-snapshot.cron.hourly"
|
||
"etc/zfs-auto-snapshot.cron.monthly"
|
||
"etc/zfs-auto-snapshot.cron.weekly")
|
||
(("zfs-auto-snapshot")
|
||
zfs-auto-snapshot))
|
||
(substitute* "src/zfs-auto-snapshot.sh"
|
||
(("LC_ALL=C zfs list")
|
||
(string-append "LC_ALL=C " zfs " list"))
|
||
(("LC_ALL=C zpool status")
|
||
(string-append "LC_ALL=C " zpool " status"))
|
||
(("zfs snapshot")
|
||
(string-append zfs " snapshot"))
|
||
(("zfs destroy")
|
||
(string-append zfs " destroy"))))))
|
||
;; Provide DESTDIR and PREFIX on make command.
|
||
(replace 'install
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
(invoke "make" "install"
|
||
"PREFIX="
|
||
(string-append "DESTDIR=" out)))
|
||
#t)))))
|
||
(home-page "https://github.com/zfsonlinux/zfs-auto-snapshot")
|
||
(synopsis "Automatically create, rotate and destroy ZFS snapshots")
|
||
(description "An alternative implementation of the zfs-auto-snapshot
|
||
service for Linux that is compatible with zfs-linux (now OpenZFS) and
|
||
zfs-fuse.
|
||
|
||
On Guix System, you will need to invoke the included shell scripts as
|
||
@code{job} definitions in your @code{operating-system} declaration.")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public mergerfs
|
||
(package
|
||
(name "mergerfs")
|
||
(version "2.33.5")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://github.com/trapexit/mergerfs/"
|
||
"releases/download/" version "/"
|
||
"mergerfs-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0m0fg191ax855yb20vqpvn6v2gc3i5xdizx09pgpymj1ybxc7yyw"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:make-flags
|
||
(list (string-append "CC=" ,(cc-for-target))
|
||
(string-append "CXX=" ,(cxx-for-target))
|
||
(string-append "PREFIX=" (assoc-ref %outputs "out")))
|
||
#:tests? #f ; all require a kernel with FUSE loaded
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(add-after 'unpack 'set-file-names
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(substitute* "libfuse/Makefile"
|
||
(("/sbin") "$(EXEC_PREFIX)/sbin")
|
||
(("chown") "true") ; disallowed in the build environment
|
||
(("strip") "true")) ; breaks cross-compilation
|
||
;; These were copied from the fuse-2 package.
|
||
(substitute* '("libfuse/lib/mount_util.c"
|
||
"libfuse/util/mount_util.c")
|
||
(("/bin/(u?)mount" _ maybe-u)
|
||
(search-input-file inputs
|
||
(string-append "bin/" maybe-u
|
||
"mount"))))
|
||
(substitute* '("libfuse/util/mount.mergerfs.c")
|
||
(("/bin/sh" command)
|
||
(string-append (assoc-ref inputs "bash-minimal") command))
|
||
;; mount.mergerfs tries to execute `mergerfs`, which cannot be found
|
||
;; without an absolute path. Hard-coding the path is fine, since we don’t
|
||
;; link mount.mergerfs to mount.fuse anyway.
|
||
(("add_arg\\(&command, type\\);")
|
||
(string-append "add_arg(&command, \"" (assoc-ref outputs "out")
|
||
"/bin/mergerfs\");"))))))))
|
||
;; Mergerfs bundles a heavily modified copy of fuse.
|
||
(inputs
|
||
(list bash-minimal util-linux))
|
||
(home-page "https://github.com/trapexit/mergerfs")
|
||
(synopsis "Featureful union file system")
|
||
(description "mergerfs is a union file system geared towards simplifying
|
||
storage and management of files across numerous commodity storage devices. It
|
||
is similar to mhddfs, unionfs, and aufs.")
|
||
(license (list
|
||
license:isc ; mergerfs
|
||
license:gpl2 license:lgpl2.0 ; Imported libfuse code.
|
||
))))
|
||
|
||
(define-public mergerfs-tools
|
||
(let ((commit "3b6fe008517aeda715c306eaf4914f6f537da88d")
|
||
(revision "3"))
|
||
(package
|
||
(name "mergerfs-tools")
|
||
;; No released version exists.
|
||
(version (git-version "0.0.0" revision commit))
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/trapexit/mergerfs-tools")
|
||
(commit commit)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "15pgym6c4viy57ccgp28dnqwh12f3gr02axg86y578aqa2yaa0ad"))))
|
||
(build-system copy-build-system)
|
||
(inputs
|
||
(list python python-xattr rsync))
|
||
(arguments
|
||
'(#:install-plan
|
||
'(("src/" "bin/"))
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-after 'unpack 'patch-paths
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(substitute* (find-files "src" "^mergerfs\\.")
|
||
(("'rsync'")
|
||
(string-append "'" (assoc-ref inputs "rsync") "/bin/rsync'"))
|
||
(("'rm'")
|
||
(string-append "'" (assoc-ref inputs "coreutils") "/bin/rm'")))
|
||
(substitute* "src/mergerfs.mktrash"
|
||
(("xattr")
|
||
(search-input-file inputs "/bin/xattr"))
|
||
(("mkdir")
|
||
(search-input-file inputs "/bin/mkdir"))))))))
|
||
(synopsis "Tools to help manage data in a mergerfs pool")
|
||
(description "mergerfs-tools is a suite of programs that can audit
|
||
permissions and ownership of files and directories on a mergerfs volume,
|
||
duplicates files and directories across branches in its pool, find and remove
|
||
duplicate files, balance pool drives, consolidate files in a single mergerfs
|
||
directory onto a single drive and create FreeDesktop.org Trash specification
|
||
compatible directories.")
|
||
(home-page "https://github.com/trapexit/mergerfs-tools")
|
||
(license license:isc))))
|
||
|
||
(define-public python-dropbox
|
||
(package
|
||
(name "python-dropbox")
|
||
(version "11.36.2")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (pypi-uri "dropbox" version))
|
||
(sha256
|
||
(base32 "00650gk8557x3f38nd8a1mdby7v1l8l4l72aq48qpiw6shb3v3fl"))
|
||
(snippet
|
||
'(begin
|
||
(use-modules (guix build utils))
|
||
(substitute* "setup.py"
|
||
(("pytest-runner == 5\\.2\\.0") "pytest-runner"))))))
|
||
(build-system python-build-system)
|
||
(arguments '(#:tests? #f)) ; Tests require a network connection.
|
||
(native-inputs
|
||
(list python-pytest python-pytest-runner))
|
||
(propagated-inputs
|
||
(list python-requests python-six python-stone))
|
||
(home-page "https://www.dropbox.com/developers")
|
||
(synopsis "Official Dropbox API Client")
|
||
(description "This package provides a Python SDK for integrating with the
|
||
Dropbox API v2.")
|
||
(license license:expat)))
|
||
|
||
(define-public dbxfs
|
||
(package
|
||
(name "dbxfs")
|
||
(version "1.0.63")
|
||
(source
|
||
(origin
|
||
;; Release tarball contains files not in git repository.
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://thelig.ht/code/dbxfs")
|
||
(commit (string-append "v" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"1vzfhw3z2r0rb6s0qdzirh3pl7rv1z8xmxa0z5h7h1wqhpl05ai7"))
|
||
(patches (search-patches "dbxfs-remove-sentry-sdk.patch"))
|
||
(snippet
|
||
#~(begin (use-modules (guix build utils))
|
||
;; Don't check for package updates.
|
||
(substitute* "dbxfs/main.py"
|
||
(("if version") "if False"))))))
|
||
(build-system python-build-system)
|
||
(arguments
|
||
'(#:tests? #f)) ; tests requires safefs
|
||
(propagated-inputs
|
||
(list python-appdirs
|
||
python-block-tracing
|
||
python-dropbox
|
||
python-keyring
|
||
python-keyrings.alt
|
||
python-privy
|
||
python-userspacefs))
|
||
(home-page "https://thelig.ht/code/dbxfs/")
|
||
(synopsis "User-space file system for Dropbox")
|
||
(description
|
||
"@code{dbxfs} allows you to mount your Dropbox folder as if it were a
|
||
local file system using FUSE.")
|
||
(license license:gpl3+)))
|
||
|
||
(define-public go-github-com-hanwen-fuse
|
||
(package
|
||
(name "go-github-com-hanwen-fuse")
|
||
(version "2.0.3")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/hanwen/go-fuse")
|
||
(commit (string-append "v" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"1y44d08fxyis99s6jxdr6dbbw5kv3wb8lkhq3xmr886i4w41lz03"))))
|
||
(build-system go-build-system)
|
||
(arguments
|
||
`(#:import-path "github.com/hanwen/go-fuse"))
|
||
(propagated-inputs
|
||
(list go-golang-org-x-sys))
|
||
(home-page "https://github.com/hanwen/go-fuse")
|
||
(synopsis "FUSE bindings for Go")
|
||
(description
|
||
"This package provides Go native bindings for the FUSE kernel module.")
|
||
(license license:bsd-3)))
|
||
|
||
(define-public rewritefs
|
||
(let ((revision "1")
|
||
(commit "3a56de8b5a2d44968b8bc3885c7d661d46367306"))
|
||
(package
|
||
(name "rewritefs")
|
||
(version (git-version "0.0.0" revision commit))
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/sloonz/rewritefs")
|
||
(commit commit)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "1w2rik0lhqm3wr68x51zs45gqfx79l7fi4p0sqznlfq7sz5s8xxn"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
(list
|
||
#:modules
|
||
'((guix build gnu-build-system)
|
||
(guix build utils)
|
||
(srfi srfi-26))
|
||
#:make-flags
|
||
#~(list (string-append "PREFIX=" #$output))
|
||
#:test-target "test"
|
||
#:tests? #f ; all require a kernel with FUSE loaded
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(add-after 'install 'install-examples
|
||
(lambda _
|
||
(let ((doc (string-append #$output "/share/doc/"
|
||
#$name "-" #$version)))
|
||
(for-each (cut install-file <> (string-append doc "/examples"))
|
||
(find-files "." "^config\\."))))))))
|
||
(native-inputs
|
||
(list pkg-config))
|
||
(inputs
|
||
(list fuse pcre))
|
||
(home-page "https://github.com/sloonz/rewritefs")
|
||
(synopsis "FUSE file system that changes particular file names")
|
||
(description
|
||
"RewriteFS is a @acronym{FUSE, File system in USEr space} to change the
|
||
name of accessed files on the fly based on any number of regular expressions.
|
||
It's like the @code{rewrite} action of many Web servers, but for your file
|
||
system. For example, it can help keep your home directory tidy by transparently
|
||
rewriting the location of configuration files of software that doesn't follow
|
||
the XDG directory specification from @file{~/.@var{name}} to
|
||
@file{~/.config/@var{name}}.")
|
||
(license license:gpl2+))))
|
||
|
||
(define-public squashfuse
|
||
(package
|
||
(name "squashfuse")
|
||
(version "0.1.105")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/vasi/squashfuse")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32 "03aw8pw8694jyrzpnbry05rk9718sqw66kiyq878bbb679gl7224"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs (list autoconf automake libtool pkg-config))
|
||
(inputs (list attr fuse-2 xz zlib `(,zstd "lib")))
|
||
(home-page "https://github.com/vasi/squashfuse")
|
||
(synopsis "Fuse filesystem to mount squashfs archives")
|
||
(description
|
||
"Squashfuse lets you mount SquashFS archives in user-space. It supports
|
||
almost all features of the SquashFS format, yet is still fast and
|
||
memory-efficient.")
|
||
(license license:bsd-2)))
|
||
|
||
(define-public tmsu
|
||
(package
|
||
(name "tmsu")
|
||
(version "0.7.5")
|
||
(source
|
||
(origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/oniony/TMSU")
|
||
(commit (string-append "v" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"0834hah7p6ad81w60ifnxyh9zn09ddfgrll04kwjxwp7ypbv38wq"))))
|
||
(build-system go-build-system)
|
||
(arguments
|
||
`(#:import-path "github.com/oniony/TMSU"
|
||
#:unpack-path ".."
|
||
#:install-source? #f
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-after 'install 'post-install
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
;; The go build system produces /bin/TMSU -> install as /bin/tmsu
|
||
(rename-file (string-append out "/bin/TMSU")
|
||
(string-append out "/bin/tmsu"))))))))
|
||
(inputs
|
||
(list go-github-com-mattn-go-sqlite3 go-github-com-hanwen-fuse))
|
||
(home-page "https://github.com/oniony/TMSU")
|
||
(synopsis "Tag files and access them through a virtual file system")
|
||
(description
|
||
"TMSU is a tool for tagging your files. It provides a simple
|
||
command-line utility for applying tags and a virtual file system to give you a
|
||
tag-based view of your files from any other program. TMSU does not alter your
|
||
files in any way: they remain unchanged on disk, or on the network, wherever
|
||
your put them. TMSU maintains its own database and you simply gain an
|
||
additional view, which you can mount where you like, based upon the tags you
|
||
set up.")
|
||
(license license:gpl3+)))
|
||
|
||
(define-public udftools
|
||
(package
|
||
(name "udftools")
|
||
(version "2.3")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/pali/udftools")
|
||
(commit version)))
|
||
(sha256
|
||
(base32
|
||
"1nl2s61znyzaap23zhbdg3znj6l6akr313fchn5wwvjzj8k70is9"))
|
||
(file-name (git-file-name name version))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:configure-flags
|
||
(list (string-append "--docdir=" (assoc-ref %outputs "out")
|
||
"/share/doc/" ,name "-" ,version))))
|
||
(native-inputs
|
||
(list automake autoconf libtool pkg-config))
|
||
(home-page "https://github.com/pali/udftools")
|
||
(synopsis "Tools to manage UDF file systems and DVD/CD-R(W) drives")
|
||
(description "@code{udftools} is a set of programs for reading
|
||
and modifying @acronym{UDF, Universal Disk Format} file systems.
|
||
@acronym{UDF, Universal Disk Format} is a file system mostly used for DVDs
|
||
and other optical media. It supports read-only media (DVD/CD-R)
|
||
and rewritable media that wears out (DVD/CD-RW).")
|
||
(license license:gpl2+)))
|
||
|
||
(define-public fuse-overlayfs
|
||
(package
|
||
(name "fuse-overlayfs")
|
||
(version "1.13")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/containers/fuse-overlayfs")
|
||
(commit (string-append "v" version))))
|
||
(sha256
|
||
(base32
|
||
"03gqb4czswqhx6zrv9jj88mf3mczk4m7azcjgr785c2lmga442ly"))
|
||
(file-name (git-file-name name version))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
(list automake autoconf libtool pkg-config))
|
||
(inputs
|
||
(list fuse))
|
||
(home-page "https://github.com/containers/fuse-overlayfs")
|
||
(synopsis "FUSE implementation of overlayfs")
|
||
(description "This package provides an implementation of overlay+shiftfs
|
||
in FUSE for rootless containers.")
|
||
(license license:gpl3)))
|
||
|
||
(define-public bees
|
||
(package
|
||
(name "bees")
|
||
(version "0.10")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/Zygo/bees")
|
||
(commit (string-append "v" version))))
|
||
(file-name (git-file-name name version))
|
||
(modules '((guix build utils)))
|
||
(snippet
|
||
;; Unbundle cityhash.
|
||
#~(begin
|
||
(for-each delete-file
|
||
'("lib/city.cc" "include/crucible/city.h"))
|
||
(substitute* "lib/Makefile"
|
||
(("city.o.*") ""))
|
||
(substitute* "src/bees-hash.cc"
|
||
(("#include .crucible/city.h.") "#include <city.h>"))))
|
||
(sha256
|
||
(base32
|
||
"1j1v9bxijs8gvrb7rg0q1158xjvmfc8dlzwx768fxf3w8w2gfwvz"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
(list #:test-target "test"
|
||
#:make-flags
|
||
#~(list (string-append "CC=" #$(cc-for-target))
|
||
(string-append "DESTDIR=" #$output)
|
||
(string-append "BEES_VERSION=" #$version)
|
||
"PREFIX=''")
|
||
#:phases
|
||
#~(modify-phases %standard-phases
|
||
(delete 'configure)
|
||
(add-after 'unpack 'fixpath
|
||
(lambda* (#:key inputs #:allow-other-keys)
|
||
(substitute* "scripts/beesd.in"
|
||
(((string-append "\\<(" (string-join (list "realpath"
|
||
"uuidparse"
|
||
"grep"
|
||
"false"
|
||
"sed"
|
||
"true"
|
||
"head"
|
||
"mkdir"
|
||
"mount"
|
||
"touch"
|
||
"du"
|
||
"cut"
|
||
"rm"
|
||
"truncate"
|
||
"chmod")
|
||
"|") ")\\>") command)
|
||
(search-input-file inputs (string-append "/bin/" command)))
|
||
|
||
(("btrfs sub")
|
||
(string-append (search-input-file inputs "/bin/btrfs")
|
||
" sub"))))))))
|
||
(inputs (list btrfs-progs cityhash util-linux))
|
||
(home-page "https://github.com/Zygo/bees")
|
||
(synopsis "Deduplication agent for btrfs file systems")
|
||
(description
|
||
"@acronym{BEES, Best-Effort Extent-Same} is a block-oriented, user-space
|
||
deduplication agent designed for large btrfs file systems. It combines off-line
|
||
data deduplication with incremental scanning to minimize the time your data
|
||
spend on disk between being written and being deduplicated.")
|
||
(license (list license:gpl3+ ; the combined work
|
||
license:zlib ; lib/crc64.cc
|
||
license:gpl2)))) ; include/crucible/btrfs.h
|
||
|
||
(define-public dwarfs
|
||
(package
|
||
(name "dwarfs")
|
||
(version "0.6.2")
|
||
(source (origin
|
||
(method url-fetch)
|
||
;; The release archive is needed so that version.h is included.
|
||
(uri (string-append "https://github.com/mhx/dwarfs/releases/download/v"
|
||
version "/dwarfs-" version ".tar.xz"))
|
||
(sha256
|
||
(base32
|
||
"1kncxf85gsj3anck8ccjmxn2azp5ifqbgkiky2kharmvphkbmfcv"))
|
||
(snippet
|
||
#~(begin
|
||
(use-modules (guix build utils))
|
||
;; Prefer system libraries instead of submodules.
|
||
;; TODO: Package fbthrift.
|
||
;; TODO: Can we use Guix own folly? There is no CMake option for it.
|
||
;; TODO: Package parallel-hashmap.
|
||
(for-each delete-file-recursively
|
||
'(;; "fbthrift"
|
||
;; "folly"
|
||
;; "parallel-hashmap"
|
||
"xxHash"
|
||
"zstd"))))))
|
||
(build-system cmake-build-system)
|
||
(arguments
|
||
'(#:tests? #f ; TODO: 1 test fails because 'modprobe fuse' needs privileged access.
|
||
#:configure-flags
|
||
(list "-DPREFER_SYSTEM_ZSTD=ON"
|
||
"-DPREFER_SYSTEM_XXHASH=ON"
|
||
"-DPREFER_SYSTEM_GTEST=ON"
|
||
"-DWITH_TESTS=ON"
|
||
;; Disable man pages since ronn fails to run without hpricot.
|
||
"-DWITH_MAN_PAGES=OFF")))
|
||
(native-inputs
|
||
(list
|
||
;; FIXME: Building with ronn fails because hpricot is missing from Guix.
|
||
folly googletest libdwarf libevent pkg-config))
|
||
(inputs
|
||
(list
|
||
boost
|
||
double-conversion
|
||
fmt
|
||
fuse
|
||
gflags
|
||
jemalloc
|
||
libarchive
|
||
libunwind
|
||
lz4
|
||
openssl
|
||
xxhash
|
||
xz
|
||
`(,zstd "lib")))
|
||
(home-page "https://github.com/mhx/dwarfs")
|
||
(synopsis "Fast high compression read-only file system")
|
||
(description "DwarFS is a read-only file system with a focus on achieving
|
||
very high compression ratios in particular for very redundant data.
|
||
|
||
DwarFS also doesn't compromise on speed and for some cases it is on par with
|
||
or performs better than SquashFS. For the primary use case, DwarFS
|
||
compression is an order of magnitude better than SquashFS compression, it's 6
|
||
times faster to build the file system, it's typically faster to access files
|
||
on DwarFS and it uses less CPU resources.
|
||
|
||
Distinct features of DwarFS are:
|
||
|
||
@itemize
|
||
|
||
@item Clustering of files by similarity using a similarity hash function. This
|
||
makes it easier to exploit the redundancy across file boundaries.
|
||
|
||
@item Segmentation analysis across file system blocks in order to reduce the
|
||
size of the uncompressed file system. This saves memory when using the
|
||
compressed file system and thus potentially allows for higher cache hit rates
|
||
as more data can be kept in the cache.
|
||
|
||
@item Highly multi-threaded implementation. Both the file system creation tool
|
||
as well as the FUSE driver are able to make good use of the many cores of your
|
||
system.
|
||
|
||
@item Optional experimental Python scripting support to provide custom
|
||
filtering and ordering functionality.
|
||
|
||
@end itemize\n")
|
||
(license license:gpl3)))
|
||
|
||
(define-public sirikali
|
||
(package
|
||
(name "sirikali")
|
||
(version "1.5.1")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/mhogomchungu/sirikali")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"1l52s8rxkfcxcx3s2fnsh08wy6hhjjvp7gcggdi84aqc4dq3rdnm"))))
|
||
(build-system cmake-build-system)
|
||
(arguments
|
||
'(#:tests? #f ;No tests
|
||
#:configure-flags '("-DQT5=true")))
|
||
(inputs (list xdg-utils libpwquality libgcrypt libsecret qtbase-5))
|
||
(native-inputs (list pkg-config))
|
||
(home-page "https://mhogomchungu.github.io/sirikali/")
|
||
(synopsis "Graphical program for managing encrypted file-systems")
|
||
(description "@dfn{SiriKali} is a Qt / C++ @acronym{GUI, graphical user
|
||
interface} application that manages ecryptfs, cryfs, encfs, gocryptfs, fscrypt
|
||
and securefs based encrypted folders.")
|
||
(license license:gpl2+)))
|