;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2016 John Darrington ;;; ;;; 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 . (define-module (gnu services nfs) #:use-module (gnu) #:use-module (gnu services shepherd) #:use-module (gnu packages onc-rpc) #:use-module (gnu packages linux) #:use-module (guix) #:use-module (guix records) #:use-module (ice-9 match) #:use-module (gnu build file-systems) #:export (rpcbind-service-type rpcbind-configuration rpcbind-configuration? pipefs-service-type pipefs-configuration pipefs-configuration? gss-service-type gss-configuration gss-configuration?)) (define-record-type* rpcbind-configuration make-rpcbind-configuration rpcbind-configuration? (rpcbind rpcbind-configuration-rpcbind (default rpcbind)) (warm-start? rpcbind-configuration-warm-start? (default #t))) (define rpcbind-service-type (shepherd-service-type 'rpcbind (lambda (config) (define pkg (rpcbind-configuration-rpcbind config)) (define rpcbind-command #~(list (string-append #$pkg "/bin/rpcbind") "-f" #$@(if (rpcbind-configuration-warm-start? config) '("-w") '()))) (shepherd-service (documentation "Start the RPC bind daemon.") (requirement '(networking)) (provision '(rpcbind-daemon)) (start #~(make-forkexec-constructor #$rpcbind-command)) (stop #~(make-kill-destructor)))))) (define-record-type* pipefs-configuration make-pipefs-configuration pipefs-configuration?) (define pipefs-service-type (shepherd-service-type 'pipefs (lambda (config) (with-imported-modules '((gnu build file-systems) (guix build bournish)) (define pipefs-dir "/var/lib/nfs/rpc_pipefs") (shepherd-service (documentation "Mount the pipefs pseudo filesystem.") (provision '(rpc-pipefs)) (start #~(lambda () (mkdir-p #$pipefs-dir) (mount "rpc_pipefs" #$pipefs-dir "rpc_pipefs"))) (stop #~(lambda (pid . args) (umount #$pipefs-dir MNT_DETACH)))))))) (define-record-type* gss-configuration make-gss-configuration gss-configuration? (nfs-utils gss-configuration-gss (default nfs-utils))) (define gss-service-type (shepherd-service-type 'gss (lambda (config) (define pkg (gss-configuration-gss config)) (define gss-command #~(list (string-append #$pkg "/sbin/rpc.gssd") "-f")) (shepherd-service (documentation "Start the RPC GSS daemon.") (requirement '(rpcbind-daemon rpc-pipefs)) (provision '(gss-daemon)) (start #~(make-forkexec-constructor #$gss-command)) (stop #~(make-kill-destructor))))))