mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-18 00:42:17 -05:00
10343994dc
* gnu/packages/file-systems.scm (udftools): New variable. Signed-off-by: Tobias Geerinckx-Rice <me@tobias.gr>
1561 lines
65 KiB
Scheme
1561 lines
65 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
||
;;; Copyright © 2017, 2018, 2020, 2021 Tobias Geerinckx-Rice <me@tobias.gr>
|
||
;;; Copyright © 2017 Gábor Boskovits <boskovits@gmail.com>
|
||
;;; Copyright © 2017, 2018, 2021 Ricardo Wurmus <rekado@elephly.net>
|
||
;;; Copyright © 2018 Leo Famulari <leo@famulari.name>
|
||
;;; Copyright © 2019, 2020, 2021 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>
|
||
;;;
|
||
;;; 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 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 attr)
|
||
#:use-module (gnu packages autotools)
|
||
#:use-module (gnu packages base)
|
||
#:use-module (gnu packages bison)
|
||
#:use-module (gnu packages check)
|
||
#:use-module (gnu packages compression)
|
||
#: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 documentation)
|
||
#:use-module (gnu packages docbook)
|
||
#:use-module (gnu packages flex)
|
||
#:use-module (gnu packages gawk)
|
||
#:use-module (gnu packages glib)
|
||
#:use-module (gnu packages gnupg)
|
||
#:use-module (gnu packages golang)
|
||
#:use-module (gnu packages guile)
|
||
#:use-module (gnu packages kerberos)
|
||
#:use-module (gnu packages libffi)
|
||
#:use-module (gnu packages linux)
|
||
#:use-module (gnu packages nfs)
|
||
#:use-module (gnu packages onc-rpc)
|
||
#:use-module (gnu packages openldap)
|
||
#:use-module (gnu packages perl)
|
||
#:use-module (gnu packages photo)
|
||
#:use-module (gnu packages pkg-config)
|
||
#: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 readline)
|
||
#:use-module (gnu packages rsync)
|
||
#:use-module (gnu packages sssd)
|
||
#:use-module (gnu packages sqlite)
|
||
#: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.7")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://kernel.org/linux/daemons/autofs/"
|
||
"v" (version-major version) "/"
|
||
"autofs-" version ".tar.xz"))
|
||
(sha256
|
||
(base32 "1myfz6a3wj2c4j9h5g44zj796fdi82jhp1s92w2hg6xp2632csx3"))))
|
||
(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\""))
|
||
#t))
|
||
(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)))
|
||
#t)))))
|
||
(native-inputs
|
||
`(("bison" ,bison)
|
||
("flex" ,flex)
|
||
("pkg-config" ,pkg-config)
|
||
("rpcsvc-proto" ,rpcsvc-proto)))
|
||
(inputs
|
||
`(("cyrus-sasl" ,cyrus-sasl)
|
||
("e2fsprogs" ,e2fsprogs) ; for e[234]fsck
|
||
("libtirpc" ,libtirpc)
|
||
("libxml2" ,libxml2) ; needed for LDAP, SASL
|
||
("mit-krb5" ,mit-krb5) ; needed for LDAP, SASL
|
||
("nfs-utils" ,nfs-utils) ; for mount.nfs
|
||
("openldap" ,openldap)
|
||
("openssl" ,openssl) ; needed for SASL
|
||
("sssd" ,sssd)
|
||
("util-linux" ,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.15.1")
|
||
(source (origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://bindfs.org/downloads/bindfs-"
|
||
version ".tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"1av8dj9i1g0105fs5r9srqqsp7yahlhwc0yl8i1szyfdls23bp84"))))
|
||
(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)
|
||
`(("pkg-config" ,pkg-config)))
|
||
(inputs
|
||
`(("fuse" ,fuse)))
|
||
(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 davfs2
|
||
(package
|
||
(name "davfs2")
|
||
(version "1.6.0")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://download.savannah.nongnu.org/releases/"
|
||
"davfs2/davfs2-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0l1vnv5lfigciwg17p10zxwhzj4qw2d9kw30prr7g4dxhmb6fsrf"))))
|
||
(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)))
|
||
#t))
|
||
(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"))
|
||
#t))
|
||
(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
|
||
`(("neon" ,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" ,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 fsarchiver
|
||
(package
|
||
(name "fsarchiver")
|
||
(version "0.8.6")
|
||
(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 "1ry2sdkfbg4bwcldk42g1i3wa3z4pr9yh9dil6ilhwcvhqiw41zc"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
`(("autoconf" ,autoconf)
|
||
("automake" ,automake)
|
||
("pkg-config" ,pkg-config)))
|
||
(inputs
|
||
`(("bzip2" ,bzip2)
|
||
("e2fsprogs" ,e2fsprogs)
|
||
("libgcrypt" ,libgcrypt)
|
||
("lz4" ,lz4)
|
||
("lzo" ,lzo)
|
||
("util-linux" ,util-linux "lib")
|
||
("xz" ,xz)
|
||
("zlib" ,zlib)
|
||
("zstd:lib" ,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 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
|
||
`(("pkg-config" ,pkg-config)))
|
||
(inputs
|
||
`(("fuse" ,fuse)
|
||
("glib" ,glib)
|
||
("libgphoto2" ,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 "7942d5cab4f02bd4db12ee26a792a6012b4d7b07")
|
||
(revision "7"))
|
||
(package
|
||
(name "bcachefs-tools")
|
||
(version (git-version "0.1" 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 "0k8cnkjm0v9xs7w02sj5151y6h8bj0gxmc3fq8js1wzx6wip9w96"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:make-flags
|
||
(list ,(string-append "VERSION=" version) ; bogus vX.Y-nogit otherwise
|
||
(string-append "PREFIX=" (assoc-ref %outputs "out"))
|
||
"INITRAMFS_DIR=$(PREFIX)/share/initramfs-tools"
|
||
,(string-append "CC=" (cc-for-target))
|
||
,(string-append "PKG_CONFIG=" (pkg-config-for-target))
|
||
"PYTEST=pytest")
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(add-after 'install 'promote-mount.bcachefs.sh
|
||
;; XXX The (optional) mount.bcachefs helper requires rust:cargo.
|
||
;; This alternative shell script does the job well enough for now.
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
(with-directory-excursion (string-append out "/sbin")
|
||
(rename-file "mount.bcachefs.sh" "mount.bcachefs")
|
||
;; WRAP-SCRIPT causes bogus ‘Insufficient arguments’ errors.
|
||
(wrap-program "mount.bcachefs"
|
||
`("PATH" ":" prefix
|
||
,(cons (string-append out "/sbin")
|
||
(map (lambda (input)
|
||
(string-append (assoc-ref inputs input)
|
||
"/bin"))
|
||
(list "coreutils"
|
||
"gawk"
|
||
"util-linux"))))))))))
|
||
#:tests? #f)) ; XXX 6 valgrind tests fail
|
||
(native-inputs
|
||
`(("pkg-config" ,pkg-config)
|
||
|
||
;; For tests.
|
||
("python-pytest" ,python-pytest)
|
||
("valgrind" ,valgrind)))
|
||
(inputs
|
||
`(("eudev" ,eudev)
|
||
("keyutils" ,keyutils)
|
||
("libaio" ,libaio)
|
||
("libscrypt" ,libscrypt)
|
||
("libsodium" ,libsodium)
|
||
("liburcu" ,liburcu)
|
||
("util-linux:lib" ,util-linux "lib") ; lib{blkid,uuid}
|
||
("lz4" ,lz4)
|
||
("zlib" ,zlib)
|
||
("zstd:lib" ,zstd "lib")
|
||
|
||
;; Only for mount.bcachefs.sh.
|
||
("coreutils" ,coreutils-minimal)
|
||
("gawk" ,gawk)
|
||
("util-linux" ,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
|
||
`(("eudev:static" ,eudev "static")
|
||
("libscrypt:static" ,libscrypt "static")
|
||
("lz4:static" ,lz4 "static")
|
||
("util-linux:static" ,util-linux "static") ; lib{blkid,uuid}
|
||
("zlib" ,zlib "static")
|
||
("zstd:static" ,zstd "static")
|
||
,@(package-inputs bcachefs-tools)))))
|
||
|
||
(define-public bcachefs/static
|
||
(package
|
||
(name "bcachefs-static")
|
||
(version (package-version bcachefs-tools))
|
||
(build-system trivial-build-system)
|
||
(source #f)
|
||
(inputs
|
||
`(("bcachefs-tools" ,bcachefs-tools/static)))
|
||
(arguments
|
||
`(#:modules ((guix build utils))
|
||
#:builder
|
||
(begin
|
||
(use-modules (guix build utils)
|
||
(ice-9 ftw)
|
||
(srfi srfi-26))
|
||
(let* ((bcachefs-tools (assoc-ref %build-inputs "bcachefs-tools"))
|
||
(out (assoc-ref %outputs "out")))
|
||
(mkdir-p out)
|
||
(with-directory-excursion out
|
||
(install-file (string-append bcachefs-tools
|
||
"/sbin/bcachefs")
|
||
"sbin")
|
||
(remove-store-references "sbin/bcachefs")
|
||
(invoke "sbin/bcachefs" "version") ; test suite
|
||
#t)))))
|
||
(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.1.2")
|
||
(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 "19pbybgbfnvjb3n944ihrn1r8ch4dm8dr0d44d6w7p63dcp372xy"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:configure-flags
|
||
(list "--disable-static")))
|
||
(native-inputs
|
||
`(("autoconf" ,autoconf)
|
||
("automake" ,automake)
|
||
("libtool" ,libtool)
|
||
("pkg-config" ,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
|
||
`(("asciidoc" ,asciidoc)
|
||
("docbook-xml" ,docbook-xml)
|
||
("libxml2" ,libxml2)
|
||
("libxslt" ,libxslt)
|
||
("pkg-config" ,pkg-config)))
|
||
(inputs
|
||
`(("fuse" ,fuse)
|
||
("gnutls" ,gnutls)))
|
||
(arguments
|
||
`(#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(replace 'install
|
||
;; There's no ‘install’ target. Install all variants manually.
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(bin (string-append out "/bin"))
|
||
(man1 (string-append out "/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")))
|
||
#t)))
|
||
#:make-flags (list "CC=gcc")
|
||
#: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-include-systypes.patch"))))
|
||
(build-system gnu-build-system)
|
||
(inputs
|
||
`(("util-linux" ,util-linux "lib")))
|
||
(home-page "http://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 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
|
||
`(("pkg-config" ,pkg-config)))
|
||
(inputs
|
||
`(("fuse" ,fuse)
|
||
("attr" ,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)
|
||
("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"))))
|
||
(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
|
||
`(("curl" ,curl)
|
||
("glib" ,glib)
|
||
("fuse" ,fuse)))
|
||
(native-inputs
|
||
`(("pkg-config" ,pkg-config)))
|
||
(home-page "http://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 "129")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://www.flamingspork.com/projects/libeatmydata/"
|
||
"libeatmydata-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "1qycv1cvy6fr3v5rxilnsqxllwyfbqlcairlh31x2dnjsx28jnqf"))))
|
||
(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)
|
||
(string-append (assoc-ref inputs "coreutils") "/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
|
||
(method url-fetch)
|
||
(uri (string-append "https://deb.debian.org/debian/pool/main/"
|
||
"libe/libeatmydata/libeatmydata_" version
|
||
"-1.debian.tar.xz"))
|
||
(sha256
|
||
(base32 "0q6kx1bf870jj52a2vm5p5xlrr89g2zs8wyhlpn80pys9p28nikx"))))
|
||
;; For the test suite.
|
||
("strace" ,strace)
|
||
("which" ,which)))
|
||
(inputs
|
||
`(("coreutils" ,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 @code{}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 "3.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
|
||
"115p55y2cbs92z5lmcnjx1v29lwinpgq4sha9v1kq1vd8674h404"))))
|
||
(build-system gnu-build-system)
|
||
(home-page "https://github.com/sahlberg/libnfs")
|
||
(native-inputs
|
||
`(("autoconf" ,autoconf)
|
||
("automake" ,automake)
|
||
("libtool" ,libtool)
|
||
("pkg-config" ,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
|
||
;; Later versions require FUSE 3.
|
||
(let ((commit "7b89418e8dc27103d3c4f8fa348086ffcd634c17")
|
||
(revision "1"))
|
||
(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
|
||
"0x2siy3cmnm9wsdfazg3xc8r3kbg73gijmnn1vjw33pp71ckylxr"))
|
||
(file-name (git-file-name name version))))
|
||
(build-system cmake-build-system)
|
||
(arguments
|
||
`(#:tests? #f ; No test suite
|
||
#:configure-flags
|
||
'("-DUSE_FUSE3=OFF") ; FUSE 3 is not packaged yet.
|
||
#: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 "libapfs.a" lib)
|
||
(install-file "../source/README.md" doc)
|
||
#t))))))
|
||
(inputs
|
||
`(("bzip2" ,bzip2)
|
||
("fuse" ,fuse)
|
||
("zlib" ,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 "0")
|
||
(commit "1c18b9ec2fcc94bd05ecdd136aa51c97bf3fa70d"))
|
||
(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 "0rrv0rs9nhaza0jk5k0bj27w4lcd1s4a1ls8nr679qi02bgx630x"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#: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
|
||
(assoc-ref inputs "bash")
|
||
match))
|
||
(("/bin/(rm|true)" match)
|
||
(string-append (assoc-ref inputs "coreutils")
|
||
match))
|
||
(("/usr(/bin/time)" _ match)
|
||
(string-append (assoc-ref inputs "time")
|
||
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 outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out")))
|
||
(wrap-program (string-append out "/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 (name)
|
||
(let ((input (assoc-ref inputs name)))
|
||
(string-append input "/bin:"
|
||
input "/sbin")))
|
||
(list "acl"
|
||
"attr"
|
||
"coreutils"
|
||
"inetutils"
|
||
"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 outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(check (string-append out "/xfstests/check"))
|
||
(bin (string-append out "/bin"))
|
||
(helper (string-append bin "/xfstests-check")))
|
||
(mkdir-p bin)
|
||
(with-output-to-file helper
|
||
(lambda _
|
||
(format #t "#!~a --no-auto-compile\n!#\n"
|
||
(string-append (assoc-ref inputs "guile")
|
||
"/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
|
||
`(("autoconf" ,autoconf)
|
||
("automake" ,automake)
|
||
("libtool" ,libtool)))
|
||
(inputs
|
||
`(("acl" ,acl)
|
||
("attr" ,attr)
|
||
("guile" ,guile-3.0) ; for our xfstests-check helper script
|
||
("inetutils" ,inetutils) ; for ‘hostname’
|
||
("libuuid" ,util-linux "lib")
|
||
("perl" ,perl) ; to automagically patch shebangs
|
||
("time" ,time)
|
||
("xfsprogs" ,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.0.4")
|
||
(outputs '("out" "module" "src"))
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://github.com/zfsonlinux/zfs/releases"
|
||
"/download/zfs-" version
|
||
"/zfs-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "0v2zshimz5miyj8mbskb52pnzyl1s4rhpr6208zq549v8g2l84vx"))))
|
||
(build-system linux-module-build-system)
|
||
(arguments
|
||
`(;; 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 outputs inputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
(substitute* "configure"
|
||
(("-/bin/sh") (string-append "-" (which "sh"))))
|
||
(invoke "./configure"
|
||
"--with-config=all"
|
||
(string-append "--prefix=" out)
|
||
(string-append "--with-dracutdir=" out "/lib/dracut")
|
||
(string-append "--with-udevdir=" out "/lib/udev")
|
||
(string-append "--with-mounthelperdir=" out "/sbin")
|
||
(string-append "--with-linux="
|
||
(assoc-ref inputs "linux-module-builder")
|
||
"/lib/modules/build")))))
|
||
(add-after 'unpack 'patch-source
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out"))
|
||
(src (assoc-ref outputs "src"))
|
||
(util-linux (assoc-ref inputs "util-linux"))
|
||
(nfs-utils (assoc-ref inputs "nfs-utils"))
|
||
(kmod (assoc-ref inputs "kmod-runtime")))
|
||
(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 "\"" kmod "/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 util-linux "/bin/umount\", \"-n"))
|
||
(("/usr/bin/env\", \"mount")
|
||
(string-append util-linux "/bin/mount\", \"-n")))
|
||
(substitute* "lib/libzfs/os/linux/libzfs_mount_os.c"
|
||
(("/bin/mount") (string-append util-linux "/bin/mount"))
|
||
(("/bin/umount") (string-append util-linux "/bin/umount")))
|
||
(substitute* "lib/libshare/os/linux/nfs.c"
|
||
(("/usr/sbin/exportfs")
|
||
(string-append nfs-utils "/sbin/exportfs")))
|
||
(substitute* "config/zfs-build.m4"
|
||
(("\\$sysconfdir/init.d") (string-append out "/etc/init.d")))
|
||
(substitute* '("etc/zfs/Makefile.am"
|
||
"cmd/zed/Makefile.am")
|
||
(("\\$\\(sysconfdir)") (string-append out "/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 src "/src")))
|
||
(substitute* (find-files "udev/rules.d/" ".rules.in$")
|
||
(("/sbin/modprobe") (string-append kmod "/bin/modprobe"))))
|
||
#t))
|
||
(replace 'build
|
||
(lambda _ (invoke "make")))
|
||
(replace 'install
|
||
(lambda* (#:key outputs inputs native-inputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(moddir (assoc-ref outputs "module"))
|
||
(kmod (assoc-ref (or native-inputs inputs) "kmod")))
|
||
(invoke "make" "install"
|
||
(string-append "DEFAULT_INITCONF_DIR=" out "/etc/default")
|
||
(string-append "DEPMOD=" kmod "/bin/depmod")
|
||
(string-append "INSTALL_PATH=" out)
|
||
(string-append "INSTALL_MOD_PATH=" moddir)
|
||
"INSTALL_MOD_STRIP=1")
|
||
(install-file "contrib/bash_completion.d/zfs"
|
||
(string-append out "/share/bash-completion/completions"))
|
||
#t))))))
|
||
(native-inputs
|
||
`(("attr" ,attr)
|
||
("kmod" ,kmod)
|
||
("pkg-config" ,pkg-config)))
|
||
(inputs
|
||
`(("eudev" ,eudev)
|
||
("kmod-runtime" ,kmod)
|
||
("libaio" ,libaio)
|
||
("libtirpc" ,libtirpc)
|
||
("nfs-utils" ,nfs-utils)
|
||
("openssl" ,openssl)
|
||
("python" ,python)
|
||
("python-cffi" ,python-cffi)
|
||
("util-linux" ,util-linux)
|
||
("util-linux:lib" ,util-linux "lib")
|
||
("zlib" ,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.
|
||
`(("zfs" ,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.32.4")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://github.com/trapexit/mergerfs/releases/download/"
|
||
version "/mergerfs-" version ".tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"0yz7nljx6axcj6hb09sgc0waspgfhp535228rjqvqgyd8y74jc3s"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:tests? #f ; No tests exist.
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure)
|
||
(add-after 'unpack 'fix-paths
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(setenv "CC" "gcc")
|
||
;; These were copied from the package libfuse.
|
||
(substitute* '("libfuse/lib/mount_util.c" "libfuse/util/mount_util.c")
|
||
(("/bin/(u?)mount" _ maybe-u)
|
||
(string-append (assoc-ref inputs "util-linux")
|
||
"/bin/" maybe-u "mount")))
|
||
(substitute* '("libfuse/util/mount.mergerfs.c")
|
||
(("/bin/sh")
|
||
(which "sh")))
|
||
;; The Makefile does not allow overriding PREFIX via make variables.
|
||
(substitute* '("Makefile" "libfuse/Makefile")
|
||
(("= /usr/local") (string-append "= " (assoc-ref outputs "out")))
|
||
(("= /sbin") "= $(EXEC_PREFIX)/sbin")
|
||
;; cannot chown as build user
|
||
(("chown root(:root)?") "true"))
|
||
#t)))))
|
||
;; mergerfs bundles a heavily modified copy of libfuse.
|
||
(inputs `(("util-linux" ,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 "480296ed03d1c3c7909697d7ef96d35840ee26b8")
|
||
(revision "2"))
|
||
(package
|
||
(name "mergerfs-tools")
|
||
;; No released version exists.
|
||
(version (git-version "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
|
||
"0xr06gi4xcr832rzy0hkp5c1n231s7w5iq1nkjvx9kvm0dl7chpq"))))
|
||
(build-system copy-build-system)
|
||
(inputs
|
||
`(("python" ,python)
|
||
("python-xattr" ,python-xattr)
|
||
("rsync" ,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")
|
||
(string-append (assoc-ref inputs "python-xattr") "/bin/xattr"))
|
||
(("mkdir")
|
||
(string-append (assoc-ref inputs "coreutils") "/bin/mkdir")))
|
||
#t)))))
|
||
(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.5.0")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (pypi-uri "dropbox" version))
|
||
(sha256
|
||
(base32
|
||
"16bxx9xqx2s4d9khrw57a0bj4q7nc6kq355wl4pfddn9cqvh9rg2"))))
|
||
(build-system python-build-system)
|
||
(arguments '(#:tests? #f)) ; Tests require a network connection.
|
||
(native-inputs
|
||
`(("python-pytest" ,python-pytest)
|
||
("python-pytest-runner" ,python-pytest-runner)))
|
||
(propagated-inputs
|
||
`(("python-certifi" ,python-certifi)
|
||
("python-chardet" ,python-chardet)
|
||
("python-requests" ,python-requests)
|
||
("python-six" ,python-six)
|
||
("python-stone" ,python-stone)
|
||
("python-urllib3" ,python-urllib3)))
|
||
(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.51")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (pypi-uri "dbxfs" version))
|
||
(sha256
|
||
(base32
|
||
"1zz82d0mnql55397x4jx7z5rn857rf9zhjv895j93wpxdq10xwvk"))
|
||
(patches (search-patches "dbxfs-remove-sentry-sdk.patch"))))
|
||
(build-system python-build-system)
|
||
(arguments
|
||
'(#:tests? #f)) ; tests requires safefs
|
||
(propagated-inputs
|
||
`(("python-appdirs" ,python-appdirs)
|
||
("python-block-tracing" ,python-block-tracing)
|
||
("python-dropbox" ,python-dropbox)
|
||
("python-keyring" ,python-keyring)
|
||
("python-keyrings.alt" ,python-keyrings.alt)
|
||
("python-privy" ,python-privy)
|
||
("python-userspacefs" ,python-userspacefs)))
|
||
(home-page "https://github.com/rianhunter/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
|
||
`(("go-golang-org-x-sys" ,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 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
|
||
`(("go-github-com-mattn-go-sqlite3" ,go-github-com-mattn-go-sqlite3)
|
||
("go-github-com-hanwen-fuse" ,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
|
||
`(("automake" ,automake)
|
||
("autoconf" ,autoconf)
|
||
("libtool" ,libtool)
|
||
("pkg-config" ,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+)))
|