mirror of
https://gitlab.univ-nantes.fr/glicid-public/guix-glicid.git
synced 2025-04-29 21:58:36 +02:00
63 lines
2.2 KiB
Scheme
63 lines
2.2 KiB
Scheme
(define-module (glicid services authentication)
|
|
#:use-module (gnu services)
|
|
#:use-module (gnu services shepherd)
|
|
#:use-module (guix)
|
|
#:use-module (guix records)
|
|
#:use-module (ice-9 match)
|
|
#:use-module (gnu packages sssd)
|
|
#:use-module (glicid system file-systems)
|
|
#:use-module (glicid utils)
|
|
#:export (
|
|
sssd-configuration
|
|
sssd-configuration?
|
|
sssd-service
|
|
sssd-service-type
|
|
))
|
|
|
|
(define-record-type*
|
|
<sssd-configuration>
|
|
sssd-configuration make-sssd-configuration sssd-configuration?
|
|
(pkg pkg (default sssd))
|
|
(config-file config-file (default "/etc/sssd/sssd.conf"))
|
|
(logger logger (default "stderr"))
|
|
(debug-level debug-level (default "3"))
|
|
(log-file log-file (default "/var/log/sssd/sssd.log")))
|
|
|
|
(define sssd-service
|
|
(match-lambda
|
|
(($ <sssd-configuration> pkg config-file logger debug-level log-file)
|
|
(list
|
|
(shepherd-service
|
|
(provision '(sssd))
|
|
(documentation "Run sssd.")
|
|
(requirement '( user-processes ))
|
|
(respawn? #t)
|
|
(start #~(make-forkexec-constructor
|
|
(list
|
|
#$(file-append pkg "/sbin/sssd")
|
|
"-i"
|
|
"-c" #$config-file
|
|
"--logger" #$logger
|
|
"-d" #$debug-level
|
|
)
|
|
#:log-file #$log-file
|
|
))
|
|
(stop #~(make-kill-destructor)))))))
|
|
|
|
(define %sssd-activation
|
|
#~(begin
|
|
(mkdir-p "/etc/sssd/conf.d")
|
|
(mkdir-p "/var/log/sssd")
|
|
(mkdir-p "/var/lib/sss/db")
|
|
(mkdir-p "/var/lib/sss/mc")
|
|
(mkdir-p "/var/lib/sss/pipes/private")
|
|
(install-file #$(file-append pkg "/lib/sssd/conf/sssd.conf") "/etc/sssd/")
|
|
#t ))
|
|
|
|
(define sssd-service-type
|
|
(service-type
|
|
(name 'sssd)
|
|
(extensions (list
|
|
(service-extension shepherd-root-service-type sssd-service)
|
|
(service-extension activation-service-type (const %sssd-activation))))
|
|
(description "Run sssd")))
|