services: cuirass: Cache defaults to /var/cache/cuirass.
The previous default value depended on the 'HOME' environment variable, which happened to be unset. Thus, /.cache was being used. * gnu/services/cuirass.scm (<cuirass-configuration>)[cache-directory]: Change default value to "/var/cache/cuirass". (cuirass-shepherd-service): Always pass "--cache-directory". (cuirass-activation): New procedure. (cuirass-service-type): Use it as an extension to ACTIVATION-SERVICE-TYPE. * doc/guix.texi (Continuous Integration): Adjust accordingly.
This commit is contained in:
parent
831071b84f
commit
463995da0c
|
@ -11993,7 +11993,7 @@ Data type representing the configuration of Cuirass.
|
||||||
@item @code{log-file} (default: @code{"/var/log/cuirass.log"})
|
@item @code{log-file} (default: @code{"/var/log/cuirass.log"})
|
||||||
Location of the log file.
|
Location of the log file.
|
||||||
|
|
||||||
@item @code{cache-directory} (default: @code{""})
|
@item @code{cache-directory} (default: @code{"/var/cache/cuirass"})
|
||||||
Location of the repository cache.
|
Location of the repository cache.
|
||||||
|
|
||||||
@item @code{user} (default: @code{"cuirass"})
|
@item @code{user} (default: @code{"cuirass"})
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2016 Mathieu Lirzin <mthl@gnu.org>
|
;;; Copyright © 2016 Mathieu Lirzin <mthl@gnu.org>
|
||||||
|
;;; Copyright © 2016 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -45,7 +46,7 @@
|
||||||
(log-file cuirass-configuration-log-file ;string
|
(log-file cuirass-configuration-log-file ;string
|
||||||
(default "/var/log/cuirass.log"))
|
(default "/var/log/cuirass.log"))
|
||||||
(cache-directory cuirass-configuration-cache-directory ;string (dir-name)
|
(cache-directory cuirass-configuration-cache-directory ;string (dir-name)
|
||||||
(default ""))
|
(default "/var/cache/cuirass"))
|
||||||
(user cuirass-configuration-user ;string
|
(user cuirass-configuration-user ;string
|
||||||
(default "cuirass"))
|
(default "cuirass"))
|
||||||
(group cuirass-configuration-group ;string
|
(group cuirass-configuration-group ;string
|
||||||
|
@ -80,9 +81,7 @@
|
||||||
(requirement '(guix-daemon))
|
(requirement '(guix-daemon))
|
||||||
(start #~(make-forkexec-constructor
|
(start #~(make-forkexec-constructor
|
||||||
(list (string-append #$cuirass "/bin/cuirass")
|
(list (string-append #$cuirass "/bin/cuirass")
|
||||||
#$@(if (string=? "" cache-directory)
|
"--cache-directory" #$cache-directory
|
||||||
'()
|
|
||||||
(list "--cache-directory" cache-directory))
|
|
||||||
#$@(if (null? specs)
|
#$@(if (null? specs)
|
||||||
'()
|
'()
|
||||||
(let ((str (format #f "'~S" specs)))
|
(let ((str (format #f "'~S" specs)))
|
||||||
|
@ -112,11 +111,27 @@
|
||||||
(home-directory (string-append "/var/run/" cuirass-user))
|
(home-directory (string-append "/var/run/" cuirass-user))
|
||||||
(shell #~(string-append #$shadow "/sbin/nologin"))))))
|
(shell #~(string-append #$shadow "/sbin/nologin"))))))
|
||||||
|
|
||||||
|
(define (cuirass-activation config)
|
||||||
|
"Return the activation code for CONFIG."
|
||||||
|
(let ((cache (cuirass-configuration-cache-directory config))
|
||||||
|
(user (cuirass-configuration-user config))
|
||||||
|
(group (cuirass-configuration-group config)))
|
||||||
|
(with-imported-modules '((guix build utils))
|
||||||
|
#~(begin
|
||||||
|
(use-modules (guix build utils))
|
||||||
|
|
||||||
|
(mkdir-p #$cache)
|
||||||
|
|
||||||
|
(let ((uid (passwd:uid (getpw #$user)))
|
||||||
|
(gid (group:gid (getgr #$group))))
|
||||||
|
(chown #$cache uid gid))))))
|
||||||
|
|
||||||
(define cuirass-service-type
|
(define cuirass-service-type
|
||||||
(service-type
|
(service-type
|
||||||
(name 'cuirass)
|
(name 'cuirass)
|
||||||
(extensions
|
(extensions
|
||||||
(list
|
(list
|
||||||
|
(service-extension activation-service-type cuirass-activation)
|
||||||
(service-extension shepherd-root-service-type cuirass-shepherd-service)
|
(service-extension shepherd-root-service-type cuirass-shepherd-service)
|
||||||
(service-extension account-service-type cuirass-account)))))
|
(service-extension account-service-type cuirass-account)))))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue