sssd's service + define a touch directive

This commit is contained in:
Jean-François GUILLAUME 2022-11-24 13:03:48 +01:00
parent 4f75a36f47
commit dd7cfd50e4
GPG key ID: 38751DAE145EFB5A
2 changed files with 72 additions and 111 deletions

View file

@ -1,91 +1,62 @@
(define-module (glicid services authentication) (define-module (glicid services authentication)
#:use-module (gnu services) #:use-module (gnu services)
#:use-module (gnu services shepherd) #:use-module (gnu services shepherd)
#:use-module (guix) #:use-module (guix)
#:use-module (guix records) #:use-module (guix records)
#:use-module (ice-9 match) #:use-module (ice-9 match)
#:use-module (gnu packages sssd) #:use-module (gnu packages sssd)
#:use-module (glicid system file-systems) #:use-module (glicid system file-systems)
#:export ( #:use-module (glicid utils)
sssd-configuration #:export (
sssd-configuration? sssd-configuration
sssd-service sssd-configuration?
sssd-service-type sssd-service
) sssd-service-type
) ))
(define-record-type* <sssd-configuration> (define-record-type*
<sssd-configuration>
sssd-configuration make-sssd-configuration sssd-configuration? sssd-configuration make-sssd-configuration sssd-configuration?
(sssd-pkg sssd-pkg (sssd-pkg sssd-pkg (default sssd))
(default sssd) (sssd-conf sssd-conf (default "/etc/sssd/sssd.conf"))
) (sssd-logger sssd-logger (default "stderr"))
(sssd-conf sssd-conf (sssd-debug-level sssd-debug-level (default "3"))
(default (file-append sssd-pkg "/lib/sssd/conf/sssd.conf")) (log-file log-file (default "/var/log/sssd/sssd.log")))
)
(sssd-logger sssd-logger
(default "stderr")
)
(sssd-debug-level sssd-debug-level
(default #f)
)
(log-file log-file
(default "/var/log/sssd/sssd.log")
)
)
(define sssd-service (define sssd-service
(match-lambda (match-lambda
(($ <sssd-configuration> sssd-pkg sssd-conf sssd-logger sssd-debug-level log-file) (($ <sssd-configuration> sssd-pkg sssd-conf sssd-logger sssd-debug-level log-file)
(list (list
(shepherd-service (shepherd-service
(provision '(sssd) ) (provision '(sssd))
(documentation "Run sssd.") (documentation "Run sssd.")
(requirement '( (requirement '( user-processes ))
user-processes (respawn? #t)
)) (start #~(make-forkexec-constructor
(respawn? #t) (list
(start #~(make-forkexec-constructor #$(file-append sssd-pkg "/sbin/sssd")
(list "-i"
#$(file-append sssd-pkg "/sbin/sssd") "-c" sssd-conf
; "--interactive" "--logger" sssd-logger
(string-append "--config=" sssd-conf) "-d" sssd-debug-level
(string-append "--logger=" sssd-logger) )
#$@(if sssd-debug-level #:log-file #$log-file
list (string-append "--debug-level=" sssd-debug-level) ))
'() (stop #~(make-kill-destructor)))))))
)
)
#:log-file #$log-file
))
(stop #~(make-kill-destructor))
)
)
)
)
)
(define %sssd-activation (define %sssd-activation
(with-imported-modules '((guix build utils)) (with-imported-modules '((guix build utils))
#~(begin #~(begin
(use-modules (guix build utils)) (touch "/var/log/toto.log")
(define (touch file-name) (mkdir-p "/etc/sssd")
(call-with-output-file file-name (const #t)) (mkdir-p "/var/log/sssd")
) (mkdir-p "/var/lib/sss/db")
(mkdir-p "/var/log/sssd") #t )))
(mkdir-p "/var/lib/sssd")
#t
)
)
)
(define sssd-service-type (define sssd-service-type
(service-type (name 'sssd) (service-type
(extensions (name 'sssd)
(list (extensions (list
(service-extension shepherd-root-service-type sssd-service) (service-extension shepherd-root-service-type sssd-service)
(service-extension activation-service-type (const %sssd-activation)) (service-extension activation-service-type (const %sssd-activation))))
) (description "Run sssd")))
)
(description "Run sssd")
)
)

View file

@ -1,43 +1,33 @@
(define-module (glicid utils) (define-module (glicid utils)
#:use-module (guix packages) #:use-module (guix packages)
#:use-module (guix transformations) #:use-module (guix transformations)
#:use-module (guix utils) #:use-module (guix utils)
#:use-module (gnu packages gcc) #:use-module (gnu packages gcc)
#:use-module (glicid packages gcc) #:use-module (glicid packages gcc)
#:use-module (gnu packages commencement) #:use-module (gnu packages commencement)
#:use-module (gnu packages) #:use-module (gnu packages)
#:export (latest-version) #:export (latest-version)
#:export (gcc11-instead-of-gcc) #:export (gcc11-instead-of-gcc)
#:export (transform-package) #:export (transform-package)
#:export (instead-of) #:export (instead-of)
) )
;(define (latest-version v1 v2) (if (string> (package-version v1) (package-version v2)) v1 v2))
(define (latest-version v1 v2) (define (latest-version v1 v2)
(case (version-compare (package-version v1) (package-version v2))
(case (version-compare (package-version v1) (package-version v2)) ((>) v1)
((>) v1) ((=) v1)
((=) v1) ((<) v2)))
((<) v2)
)
)
(define gcc11-instead-of-gcc (define gcc11-instead-of-gcc
(package-input-rewriting `( (package-input-rewriting
(,gcc-toolchain . ,gcc-toolchain-11) `((,gcc-toolchain . ,gcc-toolchain-11)
(,gfortran-toolchain . ,gfortran-toolchain-11) (,gfortran-toolchain . ,gfortran-toolchain-11)
)) )))
)
(define (transform-package original-package suffix) (define (transform-package original-package suffix)
(package (package
(inherit original-package) (inherit original-package)
(name (string-append (package-name original-package) "-" suffix )) (name (string-append (package-name original-package) "-" suffix ))))
)
)
(define (instead-of package-a-spec package-b) (define (instead-of package-a-spec package-b)
(package-input-rewriting/spec `( (package-input-rewriting/spec `(
(,package-a-spec . ,(const package-b)) (,package-a-spec . ,(const package-b)))))
))
)