|
|
|
|
;; 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-configuration/no-serialization cloudflare-tunnel-configuration
|
|
|
|
|
(cloudflared
|
|
|
|
|
(string "/bin/cloudflared")
|
|
|
|
|
"The cloudflared executable.")
|
|
|
|
|
|
|
|
|
|
;; Tunnel options
|
|
|
|
|
(metrics
|
|
|
|
|
(string "localhost:")
|
|
|
|
|
"Listen address for metrics reporting.")
|
|
|
|
|
(log-level
|
|
|
|
|
(string "info")
|
|
|
|
|
"Application logging level (@code{debug}, @code{info}, @code{warn},
|
|
|
|
|
@code{error}, @code{fatal}). At debug level cloudflared will log request URL,
|
|
|
|
|
method, protocol, content length, as well as, all request and response
|
|
|
|
|
headers. This can expose sensitive information in your logs.")
|
|
|
|
|
(log-file
|
|
|
|
|
(string "/var/log/cloudflared.log")
|
|
|
|
|
"File path to store logs.")
|
|
|
|
|
|
|
|
|
|
;; Subcommand options
|
|
|
|
|
(token
|
|
|
|
|
(string "")
|
|
|
|
|
"The Tunnel token.")
|
|
|
|
|
(http2-origin?
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Enable HTTP/2 origin servers.")
|
|
|
|
|
(post-quantum?
|
|
|
|
|
(boolean #f)
|
|
|
|
|
"Create an experimental post-quantum secure tunnel.")
|
|
|
|
|
(extra-options
|
|
|
|
|
(list-of-strings '())
|
|
|
|
|
"List of extra options."))
|
|
|
|
|
|
|
|
|
|
(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.")))
|