guix-glicid/glicid/services/networking.scm

182 lines
5.6 KiB
Scheme
Raw Normal View History

(define-module (glicid services networking)
2022-05-12 10:33:22 +02:00
#:use-module (gnu packages bash)
#:use-module (gnu packages networking)
#:use-module (gnu services)
#:use-module (gnu services shepherd)
#:use-module (gnu system shadow)
#:use-module (guix)
#:use-module (guix records)
#:use-module (ice-9 match)
#: export (
squid-configuration
squid-configuration?
squid-shepherd-service
squid-service-type
)
)
(define-record-type* <squid-configuration>
squid-configuration make-squid-configuration
squid-configuration?
(squid squid-configuration-squid
(default squid)
)
(port squid-configuration-port
(default 3128)
)
2022-05-12 10:33:22 +02:00
(loglevel squid-configuration-loglevel
(default 1)
)
(pid-file squid-configuration-pid-file
2022-05-10 13:15:54 +02:00
(default "/var/run/squid/squid.pid")
)
(config-file squid-configuration-config-file
(default (file-append squid "/etc/squid.conf"))
)
(log-file squid-configuration-log-file
2022-05-10 13:15:54 +02:00
(default "/var/log/squid/squid.log")
)
)
(define squid-shepherd-service
(match-lambda
(($ <squid-configuration> squid port loglevel pid-file config-file log-file)
(list
(shepherd-service
(provision '(squid) )
(documentation "Run squid.")
(requirement '(user-processes))
(respawn? #t)
2022-05-11 10:11:11 +02:00
(start #~(make-forkexec-constructor
(list
#$(file-append squid "/sbin/squid")
2022-05-12 10:33:22 +02:00
"-d" #$loglevel
"-N"
"-f" #$config-file
)
#:pid-file #$pid-file
#:log-file #$log-file
2022-05-12 10:33:22 +02:00
#:user (passwd:uid (getpwnam "squid"))
))
(stop #~(exec-command
(list
#$(file-append squid "/sbin/squid")
2022-05-12 10:33:22 +02:00
"-d" #$loglevel
"-N"
"-k" "shutdown"
"-f" #$config-file
)
#:pid-file #$pid-file
#:log-file #$log-file
2022-05-12 10:33:22 +02:00
#:user (passwd:uid (getpwnam "squid"))
))
(actions (list
(shepherd-action
(name 'reload)
(documentation "Reload the settings file from disk.")
(procedure #~(exec-command
(list
#$(file-append squid "/sbin/squid")
2022-05-12 10:33:22 +02:00
"-d" #$loglevel
"-N"
"-k" "reconfigure"
"-f" #$config-file
)
2022-05-11 10:19:44 +02:00
#:pid-file #$pid-file
#:log-file #$log-file
2022-05-12 10:33:22 +02:00
#:user (passwd:uid (getpwnam "squid"))
))
)
(shepherd-action
(name 'check-config)
(documentation "Check the settings file from disk.")
(procedure #~(exec-command
(list
#$(file-append squid "/sbin/squid")
"-d" #$loglevel
"-N"
"-k" "parse"
"-f" #$config-file
)
#:pid-file #$pid-file
#:log-file #$log-file
#:user (passwd:uid (getpwnam "squid"))
))
)
(shepherd-action
(name 'kill)
(documentation "Ultimatly kill the squid process.")
(procedure #~(exec-command
(list
#$(file-append squid "/sbin/squid")
"-d" #$loglevel
"-N"
"-k" "kill"
"-f" #$config-file
)
#:pid-file #$pid-file
#:log-file #$log-file
#:user (passwd:uid (getpwnam "squid"))
))
)
))
)
)
)
)
)
(define %squid-activation
(with-imported-modules '((guix build utils))
#~(begin
2022-05-10 16:14:04 +02:00
(use-modules (guix build utils))
2022-05-10 13:15:54 +02:00
(define (touch file-name)
(call-with-output-file file-name (const #t))
)
(mkdir-p "/var/run/squid")
2022-05-10 13:15:54 +02:00
(mkdir-p "/var/log/squid")
(mkdir-p "/var/cache/squid")
(mkdir-p "/var/spool/squid")
2022-05-10 13:15:54 +02:00
(touch "/var/log/squid/squid_access.log")
(touch "/var/log/squid/squid_cache.log")
(touch "/var/log/squid/squid_cache_store.log")
(chown "/var/run/squid" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
(chown "/var/cache/squid" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
(chown "/var/log/squid" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
(chown "/var/spool/squid" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
(chown "/var/log/squid/squid_access.log" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
(chown "/var/log/squid/squid_cache.log" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
(chown "/var/log/squid/squid_cache_store.log" (passwd:uid (getpwnam "squid")) (passwd:gid (getpwnam "squid")))
#t
)
)
)
2022-05-12 10:33:22 +02:00
(define %squid-accounts
(list
(user-group (name "squid") (system? #t))
(user-account
(name "squid")
(group "squid")
(system? #t)
(comment "Squid server user")
(home-directory "/var/spool/squid")
(shell (file-append bash "/bin/bash"))
)
)
)
(define squid-service-type
(service-type (name 'squid)
(extensions
(list
(service-extension shepherd-root-service-type squid-shepherd-service)
(service-extension activation-service-type (const %squid-activation))
2022-05-12 10:33:22 +02:00
(service-extension account-service-type (const %squid-accounts))
)
)
(description "Run @uref{http://www.squid-cache.org/, squid} community developped Squid software.")
)
)