guix-glicid/glicid/services/authentication.scm

65 lines
2.3 KiB
Scheme
Raw Normal View History

2022-11-23 17:12:55 +01:00
(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
))
2022-11-23 17:12:10 +01:00
(define-record-type*
<sssd-configuration>
2023-06-20 11:43:34 +02:00
sssd-configuration make-sssd-configuration
sssd-configuration?
(sssd-pkg sssd-pkg (default sssd))
2023-10-20 08:50:41 +00:00
(pid-file pid-file (default "/var/run/sssd.pid"))
2023-06-20 11:43:34 +02:00
(config-file config-file (default (file-append sssd "/etc/sssd/sssd.conf")))
(logger logger (default "stderr"))
(debug-level debug-level (default "3"))
2023-06-20 11:43:34 +02:00
(log-file log-file (default "/var/log/sssd.log")))
2022-11-23 17:12:10 +01:00
2023-06-20 11:43:34 +02:00
(define sssd-shepherd-service
2022-11-23 17:12:10 +01:00
(match-lambda
2023-06-20 11:48:46 +02:00
(($ <sssd-configuration> sssd-pkg pid-file config-file logger debug-level log-file)
(list
(shepherd-service
2023-06-21 14:59:31 +02:00
(provision '(sssd))
(documentation "Run sssd.")
2023-06-20 11:43:34 +02:00
(requirement '(user-processes))
(respawn? #t)
(start #~(make-forkexec-constructor
(list
2023-06-20 11:48:46 +02:00
#$(file-append sssd-pkg "/sbin/sssd")
"-i"
"-c" #$config-file
"--logger" #$logger
"-d" #$debug-level
)
2023-06-20 11:43:34 +02:00
#:pid-file #$pid-file
#:log-file #$log-file ))
(stop #~(make-kill-destructor)))))))
2022-11-23 17:12:10 +01:00
(define %sssd-activation
#~(begin
2022-11-24 15:23:48 +01:00
(mkdir-p "/etc/sssd/conf.d")
(mkdir-p "/var/log/sssd")
(mkdir-p "/var/lib/sss/db")
2022-11-24 15:41:33 +01:00
(mkdir-p "/var/lib/sss/mc")
(mkdir-p "/var/lib/sss/pipes/private")
#t ))
2022-11-23 17:12:10 +01:00
(define sssd-service-type
(service-type
(name 'sssd)
(extensions (list
2023-06-20 11:59:41 +02:00
(service-extension shepherd-root-service-type sssd-shepherd-service)
(service-extension activation-service-type (const %sssd-activation))))
(description "Run sssd")))