services: 'tor-service' takes a 'config-file' parameter.
* gnu/services/networking.scm (tor-dmd-service): Take a 'config' parameter and honor it. (tor-service): Take a 'config-file' parameter. Pass it in the service's value. * doc/guix.texi (Networking Services): Adjust accordingly.
This commit is contained in:
parent
c9c282cea0
commit
375c610844
|
@ -6393,11 +6393,13 @@ keep the system clock synchronized with that of @var{servers}.
|
||||||
List of host names used as the default NTP servers.
|
List of host names used as the default NTP servers.
|
||||||
@end defvr
|
@end defvr
|
||||||
|
|
||||||
@deffn {Scheme Procedure} tor-service [#:tor tor]
|
@deffn {Scheme Procedure} tor-service [@var{config-file}] [#:tor @var{tor}]
|
||||||
Return a service to run the @uref{https://torproject.org,Tor} daemon.
|
Return a service to run the @uref{https://torproject.org, Tor} anonymous
|
||||||
|
networking daemon.
|
||||||
|
|
||||||
The daemon runs with the default settings (in particular the default exit
|
The daemon runs as the @code{tor} unprivileged user. It is passed
|
||||||
policy) as the @code{tor} unprivileged user.
|
@var{config-file}, a file-like object, with an additional @code{User tor}
|
||||||
|
line. Run @command{man tor} for information about the configuration file.
|
||||||
@end deffn
|
@end deffn
|
||||||
|
|
||||||
@deffn {Scheme Procedure} bitlbee-service [#:bitlbee bitlbee] @
|
@deffn {Scheme Procedure} bitlbee-service [#:bitlbee bitlbee] @
|
||||||
|
|
|
@ -316,20 +316,33 @@ keep the system clock synchronized with that of @var{servers}."
|
||||||
(home-directory "/var/empty")
|
(home-directory "/var/empty")
|
||||||
(shell #~(string-append #$shadow "/sbin/nologin")))))
|
(shell #~(string-append #$shadow "/sbin/nologin")))))
|
||||||
|
|
||||||
(define (tor-dmd-service tor)
|
(define (tor-dmd-service config)
|
||||||
"Return a <dmd-service> running TOR."
|
"Return a <dmd-service> running TOR."
|
||||||
(let ((torrc (plain-file "torrc" "User tor\n")))
|
(match config
|
||||||
(list (dmd-service
|
((tor config-file)
|
||||||
(provision '(tor))
|
(let ((torrc (computed-file "torrc"
|
||||||
|
#~(begin
|
||||||
|
(use-modules (guix build utils))
|
||||||
|
(call-with-output-file #$output
|
||||||
|
(lambda (port)
|
||||||
|
(display "\
|
||||||
|
User tor # automatically added\n" port)
|
||||||
|
(call-with-input-file #$config-file
|
||||||
|
(lambda (input)
|
||||||
|
(dump-port input port)))
|
||||||
|
#t)))
|
||||||
|
#:modules '((guix build utils)))))
|
||||||
|
(list (dmd-service
|
||||||
|
(provision '(tor))
|
||||||
|
|
||||||
;; Tor needs at least one network interface to be up, hence the
|
;; Tor needs at least one network interface to be up, hence the
|
||||||
;; dependency on 'loopback'.
|
;; dependency on 'loopback'.
|
||||||
(requirement '(user-processes loopback))
|
(requirement '(user-processes loopback))
|
||||||
|
|
||||||
(start #~(make-forkexec-constructor
|
(start #~(make-forkexec-constructor
|
||||||
(list (string-append #$tor "/bin/tor") "-f" #$torrc)))
|
(list (string-append #$tor "/bin/tor") "-f" #$torrc)))
|
||||||
(stop #~(make-kill-destructor))
|
(stop #~(make-kill-destructor))
|
||||||
(documentation "Run the Tor anonymous network overlay.")))))
|
(documentation "Run the Tor anonymous network overlay.")))))))
|
||||||
|
|
||||||
(define tor-service-type
|
(define tor-service-type
|
||||||
(service-type (name 'tor)
|
(service-type (name 'tor)
|
||||||
|
@ -339,12 +352,16 @@ keep the system clock synchronized with that of @var{servers}."
|
||||||
(service-extension account-service-type
|
(service-extension account-service-type
|
||||||
(const %tor-accounts))))))
|
(const %tor-accounts))))))
|
||||||
|
|
||||||
(define* (tor-service #:key (tor tor))
|
(define* (tor-service #:optional
|
||||||
"Return a service to run the @uref{https://torproject.org,Tor} daemon.
|
(config-file (plain-file "empty" ""))
|
||||||
|
#:key (tor tor))
|
||||||
|
"Return a service to run the @uref{https://torproject.org, Tor} anonymous
|
||||||
|
networking daemon.
|
||||||
|
|
||||||
The daemon runs with the default settings (in particular the default exit
|
The daemon runs as the @code{tor} unprivileged user. It is passed
|
||||||
policy) as the @code{tor} unprivileged user."
|
@var{config-file}, a file-like object, with an additional @code{User tor}
|
||||||
(service tor-service-type tor))
|
line. Run @command{man tor} for information about the configuration file."
|
||||||
|
(service tor-service-type (list tor config-file)))
|
||||||
|
|
||||||
|
|
||||||
;;;
|
;;;
|
||||||
|
|
Loading…
Reference in New Issue