Merge branch 'devel' of gitlab.univ-nantes.fr:glicid-public/guix-glicid into devel

This commit is contained in:
Yann Dupont 2022-12-01 10:19:01 +01:00
commit 3bc68fbfb6
6 changed files with 345 additions and 457 deletions

View file

@ -1,376 +1,306 @@
(define-module (glicid packages nginx) (define-module (glicid packages nginx)
#:use-module (ice-9 match) #:use-module (ice-9 match)
#:use-module (guix) #:use-module (guix)
#:use-module (guix build-system gnu) #:use-module (guix build-system gnu)
#:use-module (guix download) #:use-module (guix download)
#:use-module (guix git-download) #:use-module (guix git-download)
#:use-module ((guix licenses) #:prefix license:) #:use-module ((guix licenses) #:prefix license:)
#:use-module (guix utils) #:use-module (guix utils)
#:use-module (gnu packages compression) #:use-module (gnu packages compression)
#:use-module (gnu packages curl) #:use-module (gnu packages curl)
#:use-module (gnu packages geo) #:use-module (gnu packages geo)
#:use-module (gnu packages pcre) #:use-module (gnu packages pcre)
#:use-module (gnu packages perl) #:use-module (gnu packages perl)
#:use-module (gnu packages pkg-config) #:use-module (gnu packages pkg-config)
#:use-module (gnu packages web) #:use-module (gnu packages web)
#:use-module (gnu packages xml) #:use-module (gnu packages xml)
#:use-module (gnu packages tls) #:use-module (gnu packages tls)
#:use-module (glicid packages openldap) #:use-module (glicid packages openldap))
)
(define-public nginx (define-public nginx
(package (package
(name "nginx") (name "nginx")
(version "1.23.2") (version "1.23.2")
(source (origin (source (origin
(method url-fetch) (method url-fetch)
(uri (string-append "https://nginx.org/download/nginx-" version ".tar.gz")) (uri (string-append "https://nginx.org/download/nginx-" version ".tar.gz"))
(sha256 (base32 "0ihbkfcqlqadzkdk813raq15qqrahss1gdd81bkswanpsdrc4358")))) (sha256 (base32 "0ihbkfcqlqadzkdk813raq15qqrahss1gdd81bkswanpsdrc4358"))))
(build-system gnu-build-system) (build-system gnu-build-system)
(inputs (list libxml2 libxslt openssl pcre zlib)) (inputs (list libxml2 libxslt openssl pcre zlib))
(arguments (arguments
`(#:tests? #f `(#:tests? #f
#:phases #:phases
(modify-phases %standard-phases (modify-phases
(add-before 'configure 'patch-/bin/sh %standard-phases
(lambda _ (add-before 'configure 'patch-/bin/sh
(substitute* "auto/feature" (lambda _
(("/bin/sh") (which "sh"))) (substitute* "auto/feature"
#t)) (("/bin/sh") (which "sh")))
(replace 'configure #t))
;; The configure script is hand-written, not from GNU autotools. (replace 'configure
(lambda* (#:key configure-flags inputs outputs #:allow-other-keys) ;; The configure script is hand-written, not from GNU autotools.
(let ((flags (lambda* (#:key configure-flags inputs outputs #:allow-other-keys)
(append (list (string-append "--prefix=" (assoc-ref outputs "out")) (let ((flags
"--with-http_ssl_module" (append (list (string-append "--prefix=" (assoc-ref outputs "out"))
"--with-http_v2_module" "--with-http_ssl_module"
"--with-http_xslt_module" "--with-http_v2_module"
"--with-http_gzip_static_module" "--with-http_xslt_module"
"--with-http_gunzip_module" "--with-http_gzip_static_module"
"--with-http_addition_module" "--with-http_gunzip_module"
"--with-http_sub_module" "--with-http_addition_module"
"--with-pcre-jit" "--with-http_sub_module"
"--with-debug" "--with-pcre-jit"
"--with-stream" "--with-debug"
;; Even when not cross-building, we pass the "--with-stream"
;; --crossbuild option to avoid customizing for the ;; Even when not cross-building, we pass the
;; kernel version on the build machine. ;; --crossbuild option to avoid customizing for the
,(let ((system "Linux") ; uname -s ;; kernel version on the build machine.
(release "3.2.0") ; uname -r ,(let ((system "Linux") ; uname -s
;; uname -m (release "3.2.0") ; uname -r
(machine (match (or (%current-target-system) ;; uname -m
(%current-system)) (machine (match (or (%current-target-system)
("x86_64-linux" "x86_64") (%current-system))
("i686-linux" "i686") ("x86_64-linux" "x86_64")
("mips64el-linux" "mips64") ("i686-linux" "i686")
(_ "UNSUPPORTED")))) ("mips64el-linux" "mips64")
(string-append "--crossbuild=" system ":" release ":" machine) (_ "UNSUPPORTED"))))
)) (string-append "--crossbuild=" system ":" release ":" machine)
configure-flags))) ))
(setenv "CC" ,(cc-for-target)) configure-flags)))
(setenv "CFLAGS" ; CPPFLAGS is not respected (setenv "CC" ,(cc-for-target))
(string-append "-I" (assoc-ref inputs "libxml2") (setenv "CFLAGS" ; CPPFLAGS is not respected
"/include/libxml2")) (string-append "-I" (assoc-ref inputs "libxml2")
(format #t "configure flags: ~s~%" flags) "/include/libxml2"))
(apply invoke "./configure" flags) (format #t "configure flags: ~s~%" flags)
#t))) (apply invoke "./configure" flags)
(add-after 'install 'install-man-page #t)))
(lambda* (#:key outputs #:allow-other-keys) (add-after 'install 'install-man-page
(let* ((out (assoc-ref outputs "out")) (lambda* (#:key outputs #:allow-other-keys)
(man (string-append out "/share/man"))) (let* ((out (assoc-ref outputs "out"))
(install-file "objs/nginx.8" (string-append man "/man8")) (man (string-append out "/share/man")))
#t))) (install-file "objs/nginx.8" (string-append man "/man8"))
(add-after 'install 'fix-root-dirs #t)))
(lambda* (#:key outputs #:allow-other-keys) (add-after 'install 'fix-root-dirs
(let* ((out (assoc-ref outputs "out")) (lambda* (#:key outputs #:allow-other-keys)
(share (string-append out "/share/nginx"))) (let* ((out (assoc-ref outputs "out"))
(rmdir (string-append out "/logs")) (share (string-append out "/share/nginx")))
(mkdir-p share) (rmdir (string-append out "/logs"))
(rename-file (string-append out "/conf") (mkdir-p share)
(string-append share "/conf")) (rename-file (string-append out "/conf")
(rename-file (string-append out "/html") (string-append share "/conf"))
(string-append share "/html")) (rename-file (string-append out "/html")
#t)))))) (string-append share "/html"))
(home-page "https://nginx.org") #t))))))
(synopsis "HTTP and reverse proxy server") (home-page "https://nginx.org")
(description (synopsis "HTTP and reverse proxy server")
"Nginx (\"engine X\") is a high-performance web and reverse proxy server (description
created by Igor Sysoev. It can be used both as a stand-alone web server "Nginx (\"engine X\") is a high-performance web and reverse proxy server
and as a proxy to reduce the load on back-end HTTP or mail servers.") created by Igor Sysoev. It can be used both as a stand-alone web server
(license (list license:bsd-2 license:expat license:bsd-3 license:bsd-4)))) and as a proxy to reduce the load on back-end HTTP or mail servers.")
(license (list license:bsd-2 license:expat license:bsd-3 license:bsd-4))))
(define-public nginx-ldap-auth-module (define-public nginx-ldap-auth-module
(package (package
(inherit nginx) (inherit nginx)
(name "nginx-ldap-auth-module") (name "nginx-ldap-auth-module")
(version "83c059b73566c2ee9cbda920d91b66657cf120b7") (version "83c059b73566c2ee9cbda920d91b66657cf120b7")
(source (source
(origin (origin
(method git-fetch) (method git-fetch)
(uri (git-reference (uri (git-reference
(url "https://github.com/kvspb/nginx-auth-ldap") (url "https://github.com/kvspb/nginx-auth-ldap")
(commit version) (commit version)))
) (file-name (git-file-name "nginx-ldap-auth-module" version))
) (sha256 (base32 "023zmdir7w92dnb508ggskkc7kmd7k71hc597sb7i4xfgpwxzq1s"))))
(file-name (git-file-name "nginx-ldap-auth-module" version)) (synopsis "LDAP Authentication module for nginx")
(sha256 (base32 "023zmdir7w92dnb508ggskkc7kmd7k71hc597sb7i4xfgpwxzq1s")) (description "LDAP module for nginx which supports authentication against multiple LDAP servers.")
) (build-system gnu-build-system)
) (inputs
(synopsis "LDAP Authentication module for nginx") `(("nginx-sources" ,(package-source nginx))
(description "LDAP module for nginx which supports authentication against multiple LDAP servers.") ("openldap", openldap)
(build-system gnu-build-system) ,@(package-inputs nginx)))
(inputs (arguments
`(("nginx-sources" ,(package-source nginx)) (substitute-keyword-arguments
("openldap", openldap) `(#:configure-flags '("--add-dynamic-module=.")
,@(package-inputs nginx))) #:make-flags '("modules") ,@(package-arguments nginx))
(arguments ((#:phases phases)
(substitute-keyword-arguments `(modify-phases ,phases
`(#:configure-flags '("--add-dynamic-module=.") (add-after 'unpack 'unpack-nginx-sources
#:make-flags '("modules") (lambda* (#:key inputs native-inputs #:allow-other-keys)
,@(package-arguments nginx) (begin
) (format #t "decompressing nginx source code~%")
((#:phases phases) (let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources")))
`(modify-phases ,phases (invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1"))
(add-after 'unpack 'unpack-nginx-sources #t )))
(lambda* (#:key inputs native-inputs #:allow-other-keys) (replace 'install
(begin (lambda* (#:key outputs #:allow-other-keys)
;; The nginx source code is part of the modules source. (let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
(format #t "decompressing nginx source code~%") (install-file "objs/ngx_http_auth_ldap_module.so" modules-dir)
(let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources"))) #t )))
(invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1") (delete 'fix-root-dirs)
) (delete 'install-man-page)))))))
#t
)
)
)
(replace 'install
(lambda* (#:key outputs #:allow-other-keys)
(let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
(install-file "objs/ngx_http_auth_ldap_module.so" modules-dir)
#t
)
)
)
(delete 'fix-root-dirs)
(delete 'install-man-page)
)
)
)
)
)
)
(define-public modsecurity (define-public modsecurity
(package (package
(name "modsecurity") (name "modsecurity")
(version "3.0.8") (version "3.0.8")
(source (source
(origin (origin
(method url-fetch) (method url-fetch)
(uri (list (uri (list
(string-append "https://github.com/SpiderLabs/ModSecurity/releases/download/v" version "/modsecurity-v" version ".tar.gz") (string-append "https://github.com/SpiderLabs/ModSecurity/releases/download/v" version "/modsecurity-v" version ".tar.gz")
)) ))
(sha256 (base32 "1isng4z2xijqq92105si1zxkzlx4ifdnn38d7n38mrfp7jdwhhg2")) (sha256 (base32 "1isng4z2xijqq92105si1zxkzlx4ifdnn38d7n38mrfp7jdwhhg2"))))
) (synopsis "modsecurity module for nginx")
) (description "modsecurity module for nginx.")
(synopsis "modsecurity module for nginx") (license license:asl2.0)
(description "modsecurity module for nginx.") (home-page "https://github.com/SpiderLabs/ModSecurity")
(license license:asl2.0) (build-system gnu-build-system)
(home-page "https://github.com/SpiderLabs/ModSecurity") (inputs `(
(build-system gnu-build-system) ("curl", curl)
(inputs `( ("libxml2", libxml2)
("curl", curl) ("libxslt", libxslt)
("libxml2", libxml2) ("openssl", openssl)
("libxslt", libxslt) ("pcre", pcre)
("openssl", openssl) ("pcre:bin", pcre "bin")
("pcre", pcre) ("zlib", zlib)
("pcre:bin", pcre "bin") ("pkg-config", pkg-config)
("zlib", zlib) ("nginx-sources", (package-source nginx))
("pkg-config", pkg-config) ))
("nginx-sources", (package-source nginx)) (arguments
)) `( #:configure-flags (list
(arguments `( (string-append "--with-curl=" (assoc-ref %build-inputs "curl"))
#:configure-flags (list (string-append "--with-pcre=" (assoc-ref %build-inputs "pcre:bin") "/bin/pcre-config")
(string-append "--with-curl=" (assoc-ref %build-inputs "curl")) (string-append "--with-libxml=" (assoc-ref %build-inputs "libxml2"))
(string-append "--with-pcre=" (assoc-ref %build-inputs "pcre:bin") "/bin/pcre-config") "--enable-standalone-module" )))))
(string-append "--with-libxml=" (assoc-ref %build-inputs "libxml2"))
"--enable-standalone-module"
)
))
)
)
(define-public nginx-modsecurity-module (define-public nginx-modsecurity-module
(package (package
(inherit nginx) (inherit nginx)
(name "nginx-modsecurity-module") (name "nginx-modsecurity-module")
(version "1.0.3") (version "1.0.3")
(source (source
(origin (origin
(method url-fetch) (method url-fetch)
(uri (list (uri (list
(string-append "https://github.com/SpiderLabs/ModSecurity-nginx/releases/download/v" version "/modsecurity-nginx-v" version ".tar.gz") (string-append "https://github.com/SpiderLabs/ModSecurity-nginx/releases/download/v" version "/modsecurity-nginx-v" version ".tar.gz")
)) ))
(sha256 (base32 "1pcayz0kkpr0fvs8fwai0xv7jw9r7ph66vwxm6vrq0mc11r1r0df")) (sha256 (base32 "1pcayz0kkpr0fvs8fwai0xv7jw9r7ph66vwxm6vrq0mc11r1r0df"))
) )
) )
(synopsis "ModSecurity module for nginx") (synopsis "ModSecurity module for nginx")
(description "ModSecurity module for nginx.") (description "ModSecurity module for nginx.")
(build-system gnu-build-system) (build-system gnu-build-system)
(inputs (inputs
`(("nginx-sources" ,(package-source nginx)) `(("nginx-sources" ,(package-source nginx))
("modsecurity", modsecurity) ("modsecurity", modsecurity)
,@(package-inputs nginx))) ,@(package-inputs nginx)))
(arguments (arguments
(substitute-keyword-arguments (substitute-keyword-arguments
`(#:configure-flags '("--add-dynamic-module=.") `(#:configure-flags '("--add-dynamic-module=.")
#:make-flags '("modules") #:make-flags '("modules")
,@(package-arguments nginx) ,@(package-arguments nginx)
) )
((#:phases phases) ((#:phases phases)
`(modify-phases ,phases `(modify-phases ,phases
(add-after 'unpack 'unpack-nginx-sources (add-after 'unpack 'unpack-nginx-sources
(lambda* (#:key inputs native-inputs #:allow-other-keys) (lambda* (#:key inputs native-inputs #:allow-other-keys)
(begin (begin
;; The nginx source code is part of the modules source. ;; The nginx source code is part of the modules source.
(format #t "decompressing nginx source code~%") (format #t "decompressing nginx source code~%")
(let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources"))) (let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources")))
(invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1") (invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1")
) )
#t #t )))
) (replace 'install
) (lambda* (#:key outputs #:allow-other-keys)
) (let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
(replace 'install (install-file "objs/ngx_http_modsecurity_module.so" modules-dir)
(lambda* (#:key outputs #:allow-other-keys) #t )))
(let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules"))) (delete 'fix-root-dirs)
(install-file "objs/ngx_http_modsecurity_module.so" modules-dir) (delete 'install-man-page)))))))
#t
)
)
)
(delete 'fix-root-dirs)
(delete 'install-man-page)
)
)
)
)
)
)
(define-public nginx-geoip2-module (define-public nginx-geoip2-module
(package (package
(inherit nginx) (inherit nginx)
(name "nginx-geoip2-module") (name "nginx-geoip2-module")
(version "3.4") (version "3.4")
(source (source
(origin (origin
(method url-fetch) (method url-fetch)
(uri (list (uri (list
(string-append "https://github.com/leev/ngx_http_geoip2_module/archive/refs/tags/" version ".tar.gz") (string-append "https://github.com/leev/ngx_http_geoip2_module/archive/refs/tags/" version ".tar.gz")
)) ))
(sha256 (base32 "0lllgnasd97r6xkj70q42rp61cxrz8qlb64l14rmlwcd6hizqwmd")) (sha256 (base32 "0lllgnasd97r6xkj70q42rp61cxrz8qlb64l14rmlwcd6hizqwmd"))))
) (synopsis "GeoIP2 module for nginx")
) (description "GeoIP2 module for nginx.")
(synopsis "GeoIP2 module for nginx") (build-system gnu-build-system)
(description "GeoIP2 module for nginx.") (inputs
(build-system gnu-build-system) `(("nginx-sources" ,(package-source nginx))
(inputs ("libmaxminddb", libmaxminddb)
`(("nginx-sources" ,(package-source nginx)) ,@(package-inputs nginx)))
("libmaxminddb", libmaxminddb) (arguments
,@(package-inputs nginx))) (substitute-keyword-arguments
(arguments `(#:configure-flags '("--add-dynamic-module=.")
(substitute-keyword-arguments #:make-flags '("modules") ,@(package-arguments nginx))
`(#:configure-flags '("--add-dynamic-module=.") ((#:phases phases)
#:make-flags '("modules") `(modify-phases ,phases
,@(package-arguments nginx) (add-after 'unpack 'unpack-nginx-sources
) (lambda* (#:key inputs native-inputs #:allow-other-keys)
((#:phases phases) (begin
`(modify-phases ,phases ;; The nginx source code is part of the modules source.
(add-after 'unpack 'unpack-nginx-sources (format #t "decompressing nginx source code~%")
(lambda* (#:key inputs native-inputs #:allow-other-keys) (let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources")))
(begin (invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1")
;; The nginx source code is part of the modules source. )
(format #t "decompressing nginx source code~%") #t )))
(let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources"))) (replace 'install
(invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1") (lambda* (#:key outputs #:allow-other-keys)
) (let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
#t (install-file "objs/ngx_http_geoip2_module.so" modules-dir)
) (install-file "objs/ngx_stream_geoip2_module.so" modules-dir)
) #t )))
) (delete 'fix-root-dirs)
(replace 'install (delete 'install-man-page)))))))
(lambda* (#:key outputs #:allow-other-keys)
(let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
(install-file "objs/ngx_http_geoip2_module.so" modules-dir)
(install-file "objs/ngx_stream_geoip2_module.so" modules-dir)
#t
)
)
)
(delete 'fix-root-dirs)
(delete 'install-man-page)
)
)
)
)
)
)
(define-public nginx-http_subs_filter-module (define-public nginx-http_subs_filter-module
(package (package
(inherit nginx) (inherit nginx)
(name "nginx-http_subs_filter-module") (name "nginx-http_subs_filter-module")
(version "e12e965") (version "e12e965")
(source (source
(origin (origin
(method url-fetch) (method url-fetch)
(uri (list (uri (list
(string-append "https://github.com/yaoweibin/ngx_http_substitutions_filter_module/archive/" version ".tar.gz") (string-append "https://github.com/yaoweibin/ngx_http_substitutions_filter_module/archive/" version ".tar.gz")
)) ))
(sha256 (base32 "1cxb3yv6085rj50s001p2vblvz5px2v92whwjhb14kl8fnm2cans")) (sha256 (base32 "1cxb3yv6085rj50s001p2vblvz5px2v92whwjhb14kl8fnm2cans"))))
) (synopsis "substitutions_filter module for nginx")
) (description "substitutions_filter module for nginx.")
(synopsis "substitutions_filter module for nginx") (build-system gnu-build-system)
(description "substitutions_filter module for nginx.") (inputs
(build-system gnu-build-system) `(("nginx-sources" ,(package-source nginx))
(inputs ,@(package-inputs nginx)))
`(("nginx-sources" ,(package-source nginx)) (arguments
,@(package-inputs nginx))) (substitute-keyword-arguments
(arguments `(#:configure-flags '("--add-dynamic-module=.")
(substitute-keyword-arguments #:make-flags '("modules") ,@(package-arguments nginx))
`(#:configure-flags '("--add-dynamic-module=.") ((#:phases phases)
#:make-flags '("modules") `(modify-phases ,phases
,@(package-arguments nginx) (add-after 'unpack 'unpack-nginx-sources
) (lambda* (#:key inputs native-inputs #:allow-other-keys)
((#:phases phases) (begin
`(modify-phases ,phases ;; The nginx source code is part of the modules source.
(add-after 'unpack 'unpack-nginx-sources (format #t "decompressing nginx source code~%")
(lambda* (#:key inputs native-inputs #:allow-other-keys) (let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources")))
(begin (invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1")
;; The nginx source code is part of the modules source. )
(format #t "decompressing nginx source code~%") #t )))
(let ((tar (assoc-ref inputs "tar")) (nginx-srcs (assoc-ref inputs "nginx-sources"))) (replace 'install
(invoke (string-append tar "/bin/tar") "xvf" nginx-srcs "--strip-components=1") (lambda* (#:key outputs #:allow-other-keys)
) (let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
#t (install-file "objs/ngx_http_subs_filter_module.so" modules-dir)
) #t )))
) (delete 'fix-root-dirs)
) (delete 'install-man-page)))))))
(replace 'install
(lambda* (#:key outputs #:allow-other-keys)
(let ((modules-dir (string-append (assoc-ref outputs "out") "/etc/nginx/modules")))
(install-file "objs/ngx_http_subs_filter_module.so" modules-dir)
#t
)
)
)
(delete 'fix-root-dirs)
(delete 'install-man-page)
)
)
)
)
)
)

View file

@ -1,26 +0,0 @@
(define-module (glicid packages sssd)
#:use-module (guix packages)
#:use-module (guix download)
#:use-module (guix git-download)
#:use-module ((gnu packages sssd) #:prefix gnu:)
)
(define-public sssd-upstream-orig
(package
(inherit gnu:sssd)
(name "sssd-upstream")
(version "1_16_5")
(source
(origin
(inherit (package-source gnu:sssd))
(method git-fetch)
(uri (git-reference
(url "https://github.com/SSSD/sssd")
(commit (string-append "sssd-" version))
))
(file-name (git-file-name name version))
(sha256 (base32 "0zbs04lkjbp7y92anmafl7gzamcnq1f147p13hc4byyvjk9rg6f7"))
)
)
)
)

View file

@ -17,15 +17,15 @@
(define-record-type* (define-record-type*
<sssd-configuration> <sssd-configuration>
sssd-configuration make-sssd-configuration sssd-configuration? sssd-configuration make-sssd-configuration sssd-configuration?
(sssd-pkg sssd-pkg (default sssd)) (pkg pkg (default sssd))
(sssd-config-file sssd-config-file (default "/etc/sssd/sssd.conf")) (config-file config-file (default "/etc/sssd/sssd.conf"))
(sssd-logger sssd-logger (default "stderr")) (logger logger (default "stderr"))
(sssd-debug-level sssd-debug-level (default "3")) (debug-level debug-level (default "3"))
(log-file log-file (default "/var/log/sssd/sssd.log"))) (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-config-file sssd-logger sssd-debug-level log-file) (($ <sssd-configuration> pkg config-file logger debug-level log-file)
(list (list
(shepherd-service (shepherd-service
(provision '(sssd)) (provision '(sssd))
@ -34,11 +34,11 @@
(respawn? #t) (respawn? #t)
(start #~(make-forkexec-constructor (start #~(make-forkexec-constructor
(list (list
#$(file-append sssd-pkg "/sbin/sssd") #$(file-append pkg "/sbin/sssd")
"-i" "-i"
"-c" #$sssd-config-file "-c" #$config-file
"--logger" #$sssd-logger "--logger" #$logger
"-d" #$sssd-debug-level "-d" #$debug-level
) )
#:log-file #$log-file #:log-file #$log-file
)) ))
@ -51,7 +51,7 @@
(mkdir-p "/var/lib/sss/db") (mkdir-p "/var/lib/sss/db")
(mkdir-p "/var/lib/sss/mc") (mkdir-p "/var/lib/sss/mc")
(mkdir-p "/var/lib/sss/pipes/private") (mkdir-p "/var/lib/sss/pipes/private")
(install-file #$(file-append sssd-pkg "/lib/sssd/conf/sssd.conf") "/etc/sssd/") (install-file #$(file-append pkg "/lib/sssd/conf/sssd.conf") "/etc/sssd/")
#t )) #t ))
(define sssd-service-type (define sssd-service-type

View file

@ -18,17 +18,16 @@
<squid-configuration> <squid-configuration>
squid-configuration make-squid-configuration squid-configuration make-squid-configuration
squid-configuration? squid-configuration?
(squid-pkg squid-pkg (default squid)) (pkg pkg (default squid))
(squid-port squid-port (default 3128)) (port port (default 3128))
(squid-loglevel squid-loglevel (default 1)) (loglevel loglevel (default 1))
(squid-config-file squid-config-file (default (file-append squid "/etc/squid.conf"))) (config-file config-file (default (file-append squid "/etc/squid.conf")))
(pid-file squid-pid-file (default "/var/run/squid/squid.pid")) (pid-file pid-file (default "/var/run/squid/squid.pid"))
(log-file squid-log-file (default "/var/log/squid/squid.log")) (log-file log-file (default "/var/log/squid/squid.log")))
)
(define squid-shepherd-service (define squid-shepherd-service
(match-lambda (match-lambda
(($ <squid-configuration> squid-pkg squid-port squid-loglevel squid-config-file pid-file log-file) (($ <squid-configuration> pkg port loglevel config-file pid-file log-file)
(list (list
(shepherd-service (shepherd-service
(provision '(squid)) (provision '(squid))
@ -37,8 +36,8 @@
(respawn? #t) (respawn? #t)
(start #~(make-forkexec-constructor (start #~(make-forkexec-constructor
(list (list
#$(file-append squid-pkg "/sbin/squid") #$(file-append pkg "/sbin/squid")
"-f" #$squid-config-file "-f" #$config-file
) )
#:pid-file #$pid-file #:pid-file #$pid-file
#:log-file #$log-file #:log-file #$log-file

View file

@ -17,15 +17,15 @@
openldap-configuration make-openldap-configuration openldap-configuration make-openldap-configuration
openldap-configuration? openldap-configuration?
(openldap-pkg openldap-pkg (default openldap)) (openldap-pkg openldap-pkg (default openldap))
(uri openldap-uri (default "ldapi:// ldap://")) (uri uri (default "ldapi:// ldap://"))
(logflags openldap-logflags (default "0")) (logflags logflags (default "0"))
(pid-file openldap-pid-file (default "/var/run/openldap/slapd.pid")) (pid-file pid-file (default "/var/run/openldap/slapd.pid"))
(config-file openldap--config-file (default (file-append openldap "/etc/openldap/slapd.conf"))) (config-file config-file (default (file-append openldap "/etc/openldap/slapd.conf")))
(log-file openldap-log-file (default "/var/log/slapd.log"))) (log-file log-file (default "/var/log/slapd.log")))
(define openldap-shepherd-service (define openldap-shepherd-service
(match-lambda (match-lambda
(($ <openldap-configuration> openldap-pkg uri logflags pid-file config-file log-file) (($ <openldap-configuration> pkg uri logflags pid-file config-file log-file)
(list (list
(shepherd-service (shepherd-service
(provision '(slapd)) (provision '(slapd))
@ -34,7 +34,7 @@
(respawn? #t) (respawn? #t)
(start #~(make-forkexec-constructor (start #~(make-forkexec-constructor
(list (list
#$(file-append openldap "/libexec/slapd") #$(file-append pkg "/libexec/slapd")
"-h" #$uri "-h" #$uri
"-d" #$logflags "-d" #$logflags
"-f" #$config-file "-f" #$config-file

View file

@ -29,8 +29,7 @@
slurmd-service-type slurmd-service-type
%slurm-group %slurm-group
%slurm-account %slurm-account
%slurm-accounts %slurm-accounts ))
))
; ;
; Munged ; Munged
; ;
@ -58,23 +57,21 @@
"-f" ; until we fix the permissions "-f" ; until we fix the permissions
"--key-file" #$key-file "--key-file" #$key-file
) )
#:log-file #$log-file #:log-file #$log-file ))
))
(stop #~(make-kill-destructor))))))) (stop #~(make-kill-destructor)))))))
(define %munged-activation (define %munged-activation
#~(begin #~(begin
(mkdir-p "/var/run/munge") (mkdir-p "/var/run/munge")
(mkdir-p "/var/lib/munge") (mkdir-p "/var/lib/munge")
#t #t ))
))
(define munged-service-type (define munged-service-type
(service-type (service-type
(name 'munged) (name 'munged)
(extensions (list (extensions (list
(service-extension shepherd-root-service-type munged-service) (service-extension shepherd-root-service-type munged-service)
(service-extension activation-service-type (const %munged-activation)) ) ) (service-extension activation-service-type (const %munged-activation))))
(description "Run munged"))) (description "Run munged")))
; ;
@ -90,8 +87,7 @@
(home-directory "/var/spool/slurm") (home-directory "/var/spool/slurm")
(shell (file-append bash "/bin/bash")))) (shell (file-append bash "/bin/bash"))))
(define %slurm-accounts (define %slurm-accounts (list %slurm-group %slurm-account))
(list %slurm-group %slurm-account))
; ;
; slurmdbd ; slurmdbd
@ -100,9 +96,9 @@
<slurmdbd-configuration> <slurmdbd-configuration>
slurmdbd-configuration make-slurmdbd-configuration slurmdbd-configuration make-slurmdbd-configuration
slurmdbd-configuration? slurmdbd-configuration?
(slurm slurm-configuration-slurm (default slurm)) (slurm slurm (default slurm))
(slurmdbd-conf slurmdbd-slurmdbd-conf (default (file-append slurm "/etc/slurm/slurmdbd.conf"))) (slurmdbd-conf slurmdbd-conf (default (file-append slurm "/etc/slurm/slurmdbd.conf")))
(log-file slurmdbd-log-file (default "/var/log/slurm/slurmdbd.log"))) (log-file log-file (default "/var/log/slurm/slurmdbd.log")))
(define slurmdbd-service (define slurmdbd-service
(match-lambda (match-lambda
@ -116,12 +112,10 @@
(start #~(make-forkexec-constructor (start #~(make-forkexec-constructor
(list (list
#$(file-append slurm "/sbin/slurmdbd") #$(file-append slurm "/sbin/slurmdbd")
"-D" "-D" )
)
#:log-file #$log-file #:log-file #$log-file
#:user (passwd:uid (getpwnam "slurm")) #:user (passwd:uid (getpwnam "slurm"))
#:group (passwd:gid (getpwnam "slurm")) #:group (passwd:gid (getpwnam "slurm"))))
))
(stop #~(make-kill-destructor))))))) (stop #~(make-kill-destructor)))))))
(define %slurmdbd-activation (define %slurmdbd-activation
@ -144,8 +138,7 @@
(chown slurm-file (passwd:uid (getpwnam "slurm")) (passwd:gid (getpwnam "slurm"))) (chown slurm-file (passwd:uid (getpwnam "slurm")) (passwd:gid (getpwnam "slurm")))
(chmod slurm-file #o600) (chmod slurm-file #o600)
)(find-files "/etc/slurm/")) )(find-files "/etc/slurm/"))
#t #t ))
))
(define slurmdbd-service-type (define slurmdbd-service-type
(service-type (service-type
@ -153,7 +146,7 @@
(extensions (list (extensions (list
(service-extension shepherd-root-service-type slurmdbd-service) (service-extension shepherd-root-service-type slurmdbd-service)
(service-extension activation-service-type (const %slurmdbd-activation)) (service-extension activation-service-type (const %slurmdbd-activation))
(service-extension account-service-type (const %slurm-accounts)) ) ) (service-extension account-service-type (const %slurm-accounts))))
(description "Run slurmdbd"))) (description "Run slurmdbd")))
; ;
@ -163,9 +156,9 @@
<slurmctld-configuration> <slurmctld-configuration>
slurmctld-configuration make-slurmctld-configuration slurmctld-configuration make-slurmctld-configuration
slurmctld-configuration? slurmctld-configuration?
(slurm slurm-configuration-slurm (default slurm)) (slurm slurm (default slurm))
(slurmctld-conf slurmctld-slurmctld-conf (default (file-append slurm "/etc/slurm/slurmctld.conf"))) (slurmctld-conf slurmctld-conf (default (file-append slurm "/etc/slurm/slurmctld.conf")))
(log-file slurmctld-log-file (default "/var/log/slurm/slurmctld.log"))) (log-file log-file (default "/var/log/slurm/slurmctld.log")))
(define slurmctld-service (define slurmctld-service
(match-lambda (match-lambda
@ -180,12 +173,10 @@
(list (list
#$(file-append slurm "/sbin/slurmctld") #$(file-append slurm "/sbin/slurmctld")
"-D" "-R" "-D" "-R"
"-f" #$slurmctld-conf "-f" #$slurmctld-conf )
)
#:log-file #$log-file #:log-file #$log-file
#:user (passwd:uid (getpwnam "slurm")) #:user (passwd:uid (getpwnam "slurm"))
#:group (passwd:gid (getpwnam "slurm")) #:group (passwd:gid (getpwnam "slurm"))))
))
(stop #~(make-kill-destructor))))))) (stop #~(make-kill-destructor)))))))
(define %slurmctld-activation (define %slurmctld-activation
@ -216,7 +207,7 @@
(extensions (list (extensions (list
(service-extension shepherd-root-service-type slurmctld-service) (service-extension shepherd-root-service-type slurmctld-service)
(service-extension activation-service-type (const %slurmctld-activation)) (service-extension activation-service-type (const %slurmctld-activation))
(service-extension account-service-type (const %slurm-accounts)) ) ) (service-extension account-service-type (const %slurm-accounts))))
(description "Run slurmctld"))) (description "Run slurmctld")))
; ;
@ -226,12 +217,11 @@
<slurmd-configuration> <slurmd-configuration>
slurmd-configuration make-slurmd-configuration slurmd-configuration make-slurmd-configuration
slurmd-configuration? slurmd-configuration?
(slurm slurm-configuration-slurm (default slurm)) (slurm slurm (default slurm))
(slurmd-conf slurmd-slurmd-conf (default (file-append slurm "/etc/slurm/slurm.conf"))) (slurmd-conf slurmd-conf (default (file-append slurm "/etc/slurm/slurm.conf")))
(log-file slurmd-log-file (default "/var/log/slurm/slurmd.log")) (log-file log-file (default "/var/log/slurm/slurmd.log"))
(slurmctld-host slurmd-slurmctld-host (default #f)); string slurmctld-host[:port] (slurmctld-host slurmctld-host (default #f))
(log-level slurmd-log-level (default #f)); string Verbose mode. Multiple -v's increase verbosity (log-level log-level (default #f)))
)
(define slurmd-service (define slurmd-service
(match-lambda (match-lambda
@ -248,16 +238,11 @@
"-D" "-D"
#$@(if slurmctld-host #$@(if slurmctld-host
(list (string-append "--conf-server" slurmctld-host)) (list (string-append "--conf-server" slurmctld-host))
(list (string-append "-f" slurmd-conf)) (list (string-append "-f" slurmd-conf)))
)
#$@(if log-level #$@(if log-level
(list log-level) (list log-level)
'() '()))
) #:log-file #$log-file ))
)
#:log-file #$log-file
))
(stop #~(make-kill-destructor))))))) (stop #~(make-kill-destructor)))))))
(define %slurmd-activation (define %slurmd-activation
@ -277,5 +262,5 @@
(extensions (list (extensions (list
(service-extension shepherd-root-service-type slurmd-service) (service-extension shepherd-root-service-type slurmd-service)
(service-extension activation-service-type (const %slurmd-activation)) (service-extension activation-service-type (const %slurmd-activation))
(service-extension account-service-type (const %slurm-accounts)) ) ) (service-extension account-service-type (const %slurm-accounts))))
(description "Run slurmd"))) (description "Run slurmd")))