mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-11-07 07:26:13 -05:00
services: Add wsdd service.
* doc/guix.texi: Add documentation for wsdd service. * gnu/services/samba.scm (<wsdd-configuration>): New record. (wsdd-service-type): New variable. (wsdd-shepherd-services): New procedure. * gnu/tests/samba.scm (%wsdd-os): Add variable. (run-wsdd-test): New procedure. (%test-wsdd): New variable. Signed-off-by: Lars-Dominik Braun <lars@6xq.net>
This commit is contained in:
parent
14359befa9
commit
e1ce100915
3 changed files with 232 additions and 2 deletions
|
@ -31350,6 +31350,75 @@ Manually enable the @code{winbindd} daemon.
|
|||
@end table
|
||||
@end deftp
|
||||
|
||||
@cindex wsdd
|
||||
@subsubheading Web Service Discovery Daemon
|
||||
|
||||
Web Service Discovery Daemon implements
|
||||
@uref{http://docs.oasis-open.org/ws-dd/discovery/1.1/os/wsdd-discovery-1.1-spec-os.html,
|
||||
Web Services Dynamic Discovery} protocol that enables host discovery --
|
||||
similar to Avahi -- over Multicast DNS. It is a drop-in replacement for
|
||||
SMB hosts that have had SMBv1 disabled for security reasons.
|
||||
|
||||
@defvr {Scheme Variable} wsdd-service-type
|
||||
|
||||
Service type for the WSD host daemon. The value for
|
||||
this service type is a @code{wsdd-configuration} record. The details
|
||||
for the @code{wsdd-configuration} record type are given below.
|
||||
@end defvr
|
||||
|
||||
@deftp{Data Type} wsdd-configuration This data type represents the
|
||||
configuration for the wsdd service.
|
||||
|
||||
@table @asis
|
||||
|
||||
@item @code{package} (default: @code{wsdd})
|
||||
The wsdd package to use.
|
||||
|
||||
@item @code{ipv4only?} (default: @code{#f})
|
||||
Only listen to IPv4 addresses.
|
||||
|
||||
@item @code{ipv6only} (default: @code{#f})
|
||||
Only listen to IPv6 addresses. Please note: Activating both options is
|
||||
not possible, since there would be no IP versions to listen to.
|
||||
|
||||
@item @code{chroot} (default: @code{#f})
|
||||
Chroot into a separate directory to prevent access to other directories.
|
||||
This is to increase security in case there is a vulnerability in
|
||||
@command{wsdd}.
|
||||
|
||||
@item @code{hop-limit} (default: @code{1})
|
||||
Limit to the level of hops for multicast packets. The default is
|
||||
@var{1} which should prevent packets from leaving the local network.
|
||||
|
||||
@item @code{interface} (default: @code{'()})
|
||||
Limit to the given list of interfaces to listen to. By default wsdd
|
||||
will listen to all interfaces. Except the loopback interface is never
|
||||
used.
|
||||
|
||||
@item @code{uuid-device} (default: @code{#f})
|
||||
The WSD protocol requires a device to have a UUID. Set this to manually
|
||||
assign the service a UUID.
|
||||
|
||||
@item @code{domain} (default: @code{#f})
|
||||
Notify this host is a member of an Active Directory.
|
||||
|
||||
@item @code{host-name} (default: @code{#f})
|
||||
Manually set the hostname rather than letting @command{wsdd} inherit
|
||||
this host's hostname. Only the host name part of a possible FQDN will
|
||||
be used in the default case.
|
||||
|
||||
@item @code{preserve-case?} (default: @code{#f})
|
||||
By default @command{wsdd} will convert the hostname in workgroup to all
|
||||
uppercase. The opposite is true for hostnames in domains. Setting this
|
||||
parameter will preserve case.
|
||||
|
||||
@item @code{workgroup} (default: @var{"WORKGROUP"})
|
||||
Change the name of the workgroup. By default @command{wsdd} reports
|
||||
this host being member of a workgroup.
|
||||
|
||||
@end table
|
||||
@end deftp
|
||||
|
||||
@node Continuous Integration
|
||||
@subsection Continuous Integration
|
||||
|
||||
|
|
|
@ -41,7 +41,10 @@ (define-module (gnu services samba)
|
|||
|
||||
#:export (samba-service-type
|
||||
samba-configuration
|
||||
samba-smb-conf))
|
||||
samba-smb-conf
|
||||
|
||||
wsdd-service-type
|
||||
wsdd-configuration))
|
||||
|
||||
(define %smb-conf
|
||||
(plain-file "smb.conf" "[global]
|
||||
|
@ -180,3 +183,104 @@ (define samba-service-type
|
|||
(service-extension profile-service-type
|
||||
(compose list samba-configuration-package))))
|
||||
(default-value (samba-configuration))))
|
||||
|
||||
|
||||
;;;
|
||||
;;; WSDD
|
||||
;;;
|
||||
|
||||
(define-record-type* <wsdd-configuration>
|
||||
wsdd-configuration
|
||||
make-wsdd-configuration
|
||||
wsdd-configuration?
|
||||
(package wsdd-configuration-package
|
||||
(default wsdd))
|
||||
(ipv4only? wsdd-configuration-ipv4only?
|
||||
(default #f))
|
||||
(ipv6only? wsdd-configuration-ipv6only?
|
||||
(default #f))
|
||||
(chroot wsdd-configuration-chroot
|
||||
(default #f))
|
||||
(hop-limit wsdd-configuration-hop-limit
|
||||
(default 1))
|
||||
(interfaces wsdd-configuration-interfaces
|
||||
(default '()))
|
||||
(uuid-device wsdd-configuration-uuid-device
|
||||
(default #f))
|
||||
(domain wsdd-configuration-domain
|
||||
(default #f))
|
||||
(host-name wsdd-configuration-host-name
|
||||
(default #f))
|
||||
(preserve-case? wsdd-configuration-preserve-case?
|
||||
(default #f))
|
||||
(workgroup wsdd-configuration-workgroup
|
||||
(default "WORKGROUP")))
|
||||
|
||||
(define wsdd-accounts
|
||||
(list
|
||||
(user-group (name "wsdd"))
|
||||
(user-account (name "wsdd")
|
||||
(group "wsdd")
|
||||
(comment "Web Service Discovery user")
|
||||
(home-directory "/var/empty")
|
||||
(shell (file-append shadow "/sbin/nologin")))))
|
||||
|
||||
(define (wsdd-shepherd-service config)
|
||||
(match-record config <wsdd-configuration>
|
||||
(package ipv4only? ipv6only? chroot hop-limit interfaces uuid-device
|
||||
domain host-name preserve-case? workgroup)
|
||||
(list (shepherd-service
|
||||
(documentation "The Web Service Discovery daemon enables (Samba) hosts,
|
||||
like your local NAS device, to be found by Web Service Discovery Clients
|
||||
like Windows.")
|
||||
(provision '(wsdd))
|
||||
(requirement '(networking))
|
||||
(start #~(make-forkexec-constructor
|
||||
(list #$(file-append package "/bin/wsdd")
|
||||
#$@(if ipv4only?
|
||||
#~("--ipv4only")
|
||||
'())
|
||||
#$@(if ipv6only?
|
||||
#~("--ipv6only")
|
||||
'())
|
||||
#$@(if chroot
|
||||
#~("--chroot" #$chroot)
|
||||
'())
|
||||
#$@(if hop-limit
|
||||
#~("--hoplimit" #$(number->string hop-limit))
|
||||
'())
|
||||
#$@(map (lambda (interfaces)
|
||||
(string-append "--interface=" interfaces))
|
||||
interfaces)
|
||||
#$@(if uuid-device
|
||||
#~("--uuid" #$uuid-device)
|
||||
'())
|
||||
#$@(if domain
|
||||
#~("--domain" #$domain)
|
||||
'())
|
||||
#$@(if host-name
|
||||
#~("--hostname" #$host-name)
|
||||
'())
|
||||
#$@(if preserve-case?
|
||||
#~("--preserve-case")
|
||||
'())
|
||||
#$@(if workgroup
|
||||
#~("--workgroup" #$workgroup)
|
||||
'()))
|
||||
#:user "wsdd"
|
||||
#:group "wsdd"
|
||||
#:log-file "/var/log/wsdd.log"))
|
||||
(stop #~(make-kill-destructor))))))
|
||||
|
||||
(define wsdd-service-type
|
||||
(service-type
|
||||
(name 'wsdd)
|
||||
(description "Web Service Discovery Daemon")
|
||||
(extensions
|
||||
(list (service-extension shepherd-root-service-type
|
||||
wsdd-shepherd-service)
|
||||
(service-extension account-service-type
|
||||
(const wsdd-accounts))
|
||||
(service-extension profile-service-type
|
||||
(compose list wsdd-configuration-package))))
|
||||
(default-value (wsdd-configuration))))
|
||||
|
|
|
@ -26,7 +26,8 @@ (define-module (gnu tests samba)
|
|||
#:use-module (gnu packages samba)
|
||||
#:use-module (guix gexp)
|
||||
#:use-module (guix store)
|
||||
#:export (%test-samba))
|
||||
#:export (%test-samba
|
||||
%test-wsdd))
|
||||
|
||||
|
||||
;;;
|
||||
|
@ -156,3 +157,59 @@ (define %test-samba
|
|||
(name "samba")
|
||||
(description "Connect to a running Samba daemon.")
|
||||
(value (run-samba-test))))
|
||||
|
||||
|
||||
;;;
|
||||
;;; The wsdd service.
|
||||
;;;
|
||||
|
||||
(define %wsdd-os
|
||||
(let ((base-os (simple-operating-system
|
||||
(service dhcp-client-service-type)
|
||||
(service wsdd-service-type))))
|
||||
(operating-system
|
||||
(inherit base-os)
|
||||
(packages (cons wsdd (operating-system-packages base-os))))))
|
||||
|
||||
(define* (run-wsdd-test)
|
||||
"Return a test of an OS running wsdd service."
|
||||
|
||||
(define vm
|
||||
(virtual-machine
|
||||
(operating-system (marionette-operating-system
|
||||
%wsdd-os
|
||||
#:imported-modules '((gnu services herd))))
|
||||
(port-forwardings '((3702 . 3702)
|
||||
(5357 . 5357)))))
|
||||
|
||||
(define test
|
||||
(with-imported-modules '((gnu build marionette))
|
||||
#~(begin
|
||||
(use-modules (gnu build marionette)
|
||||
(srfi srfi-26)
|
||||
(srfi srfi-64))
|
||||
|
||||
(define marionette
|
||||
(make-marionette '(#$vm)))
|
||||
|
||||
(test-runner-current (system-test-runner #$output))
|
||||
(test-begin "wsdd")
|
||||
|
||||
;; Here shall be more tests to begin with.
|
||||
|
||||
(test-assert "wsdd running"
|
||||
(marionette-eval
|
||||
'(begin
|
||||
(use-modules (gnu services herd))
|
||||
(start-service 'wsdd))
|
||||
marionette))
|
||||
|
||||
(test-end))))
|
||||
|
||||
(gexp->derivation "wsdd-test" test))
|
||||
|
||||
(define %test-wsdd
|
||||
(system-test
|
||||
(name "wsdd")
|
||||
(description "Connect to a running wsdd daemon.")
|
||||
(value (run-wsdd-test))))
|
||||
|
|
Loading…
Reference in a new issue