You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

98 lines
3.9 KiB

;; SPDX-FileCopyrightText: 2022 Hilton Chain <hako@ultrarare.space>
;;
;; SPDX-License-Identifier: GPL-3.0-or-later
(define-module (rosenthal services child-error)
#:use-module (ice-9 match)
#:use-module (guix records)
#:use-module (guix gexp)
#:use-module (gnu home services)
#:use-module (gnu home services shepherd)
#:use-module (gnu packages admin)
#:use-module (gnu services)
#:use-module (gnu services configuration)
#:use-module (gnu services shepherd)
#:use-module (gnu system shadow)
#:use-module (rosenthal utils home-services-utils)
#:export (cloudflare-tunnel-configuration
cloudflare-tunnel-service-type))
;; Child-error: services for packages not available in Guix, currently this
;; means some Go and Rust apps I build locally but don't want to package.
;;
;; Cloudflare Tunnel
;;
(define-record-type* <cloudflare-tunnel-configuration>
cloudflare-tunnel-configuration make-cloudflare-tunnel-configuration
cloudflare-tunnel-configuration?
(cloudflared cloudflare-tunnel-configuration-cloudflared ;string
(default "/bin/cloudflared"))
;; Tunnel command options
(metrics cloudflare-tunnel-configuration-metrics ;string
(default "localhost:"))
(log-level cloudflare-tunnel-configuration-log-level ;string
(default "info"))
(log-file cloudflare-tunnel-configuration-log-file ;string
(default "/var/log/cloudflared.log"))
;; Subcommand options
(token cloudflare-tunnel-configuration-token ;string
(default #f))
(http2-origin? cloudflare-tunnel-configuration-http2-origin? ;boolean
(default #f))
(post-quantum? cloudflare-tunnel-configuration-post-quantum? ;boolean
(default #f))
(extra-options cloudflare-tunnel-configuration-extra-options ;list of string
(default '())))
(define %cloudflare-tunnel-accounts
(list (user-group (name "cloudflared") (system? #t))
(user-account
(name "cloudflared")
(group "cloudflared")
(system? #t)
(comment "Cloudflare Tunnel user")
(home-directory "/var/empty")
(shell (file-append shadow "/sbin/nologin")))))
(define cloudflare-tunnel-shepherd-service
(match-lambda
(($ <cloudflare-tunnel-configuration> cloudflared metrics
log-level log-file
token http2-origin? post-quantum?
extra-options)
(let ((tunnel-options
(list "--no-autoupdate" "--metrics" metrics "--loglevel" log-level)))
(list (shepherd-service
(documentation "Run cloudflared.")
(provision '(cloudflare-tunnel))
(requirement '(networking))
(start #~(make-forkexec-constructor
(list #$cloudflared "tunnel" #$@tunnel-options "run"
"--token" #$token
#$@(if http2-origin?
'("--http2-origin")
'())
#$@(if post-quantum?
'("--post-quantum")
'())
#$@extra-options)
#:user "cloudflared"
#:group "cloudflared"
#:log-file #$log-file))
(stop #~(make-kill-destructor))))))))
(define cloudflare-tunnel-service-type
(service-type
(name 'cloudflare-tunnel)
(extensions
(list (service-extension shepherd-root-service-type
cloudflare-tunnel-shepherd-service)
(service-extension account-service-type
(const %cloudflare-tunnel-accounts))))
(default-value (cloudflare-tunnel-configuration))
(description "Run cloudflared, the Cloudflare Tunnel daemon.")))