emacs-bug-tracker
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[debbugs-tracker] bug#30003: closed ([PATCH 2/2] gnu: services: Add dark


From: GNU bug Tracking System
Subject: [debbugs-tracker] bug#30003: closed ([PATCH 2/2] gnu: services: Add darkstat service.)
Date: Mon, 08 Jan 2018 13:00:03 +0000

Your message dated Mon, 08 Jan 2018 20:59:26 +0800
with message-id <address@hidden>
and subject line Re: [bug#30003] [PATCH 2/2] gnu: services: Add darkstat 
service.
has caused the debbugs.gnu.org bug report #30003,
regarding [PATCH 2/2] gnu: services: Add darkstat service.
to be marked as done.

(If you believe you have received this mail in error, please contact
address@hidden)


-- 
30003: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=30003
GNU Bug Tracking System
Contact address@hidden with problems
--- Begin Message --- Subject: [PATCH 2/2] gnu: services: Add darkstat service. Date: Sat, 6 Jan 2018 16:45:23 +0800
* gnu/services/monitoring.scm: New file.
* gnu/local.mk (GNU_SYSTEM_MODULES): Add it.
* doc/guix.texi (Monitoring Services): Document it.
---
 doc/guix.texi               | 42 +++++++++++++++++++++
 gnu/local.mk                |  1 +
 gnu/services/monitoring.scm | 91 +++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 134 insertions(+)
 create mode 100644 gnu/services/monitoring.scm

diff --git a/doc/guix.texi b/doc/guix.texi
index 1d1f30f00..f9dec3082 100644
--- a/doc/guix.texi
+++ b/doc/guix.texi
@@ -14697,6 +14697,48 @@ the 2nd element of the pair is the password.
 @end deftp
 
 
address@hidden Darkstat Service
address@hidden darkstat
address@hidden is a packet sniffer that captures network traffic,
+calculates statistics about usage, and serves reports over HTTP.
+
address@hidden {Scheme Variable} darkstat-service-type
+This is the service type for the
address@hidden://unix4lyfe.org/darkstat/, darkstat}
+service,  its value must be a @code{darkstat-configuration} record as in
+this example:
+
address@hidden
+(service darkstat-service-type
+  (darkstat-configuration
+    (interface "eth0")))
address@hidden example
address@hidden defvar
+
address@hidden {Data Type} darkstat-configuration
+Data type representing the configuration of @command{darkstat}.
+
address@hidden @asis
address@hidden @code{package} (default: @code{darstat})
+The darkstat package to use.
+
address@hidden @code{interface}
+Capture traffic on the specified network interface.
+
address@hidden @code{port} (default: @code{"667"})
+Bind the web interface to the specified port.
+
address@hidden @code{bindaddr} (default: @code{"127.0.0.1"})
+Bind the web interface to the specified address.
+
address@hidden @code{base} (default: @code{"/"})
+Specify the path of the base URL.  This can be useful if
address@hidden is accessed via a reverse proxy.
+
address@hidden table
address@hidden deftp
+
+
 @node Kerberos Services
 @subsubsection Kerberos Services
 @cindex Kerberos
diff --git a/gnu/local.mk b/gnu/local.mk
index 679c119a5..62fcd2cd4 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -460,6 +460,7 @@ GNU_SYSTEM_MODULES =                                \
   %D%/services/mail.scm                                \
   %D%/services/mcron.scm                       \
   %D%/services/messaging.scm                   \
+  %D%/services/monitoring.scm                  \
   %D%/services/networking.scm                  \
   %D%/services/nfs.scm                 \
   %D%/services/shepherd.scm                    \
diff --git a/gnu/services/monitoring.scm b/gnu/services/monitoring.scm
new file mode 100644
index 000000000..438d66596
--- /dev/null
+++ b/gnu/services/monitoring.scm
@@ -0,0 +1,91 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2018 Sou Bunnbu <address@hidden>
+;;;
+;;; This file is part of GNU Guix.
+;;;
+;;; GNU Guix is free software; you can redistribute it and/or modify it
+;;; under the terms of the GNU General Public License as published by
+;;; the Free Software Foundation; either version 3 of the License, or (at
+;;; your option) any later version.
+;;;
+;;; GNU Guix is distributed in the hope that it will be useful, but
+;;; WITHOUT ANY WARRANTY; without even the implied warranty of
+;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+;;; GNU General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (gnu services monitoring)
+  #:use-module (gnu services)
+  #:use-module (gnu services shepherd)
+  #:use-module (gnu packages admin)
+  #:use-module (gnu packages monitoring)
+  #:use-module (gnu system shadow)
+  #:use-module (guix gexp)
+  #:use-module (guix records)
+  #:use-module (ice-9 match)
+  #:export (darkstat-configuration
+            darkstat-service-type))
+
+
+;;;
+;;; darkstat
+;;;
+
+(define-record-type* <darkstat-configuration>
+  darkstat-configuration make-darkstat-configuration darkstat-configuration?
+  (package   darkstat-configuration-package
+             (default darkstat))
+  (interface darkstat-configuration-interface)
+  (port      darkstat-configuration-port
+             (default "667"))
+  (bindaddr  darkstat-configuration-bindaddr
+             (default "127.0.0.1"))
+  (base      darkstat-configuration-base
+             (default "/")))
+
+(define %darkstat-accounts
+  (list (user-account
+         (name "darkstat")
+         (group "darkstat")
+         (system? #t)
+         (comment "darkstat daemon user")
+         (home-directory "/var/lib/darkstat")
+         (shell (file-append shadow "/sbin/nologin")))
+        (user-group
+         (name "darkstat")
+         (system? #t))))
+
+(define darkstat-shepherd-service
+  (match-lambda
+    (($ <darkstat-configuration>
+        package interface port bindaddr base)
+     (shepherd-service
+      (documentation "Network statistics gatherer.")
+      (provision '(darkstat))
+      (requirement '(networking))
+      (start #~(make-forkexec-constructor
+                (list #$(file-append package "/sbin/darkstat")
+                      "-i" #$interface
+                      "-p" #$port
+                      "-b" #$bindaddr
+                      "--base" #$base
+                      "--syslog" "--no-daemon"
+                      "--chroot" "/var/lib/darkstat"
+                      "--user" "darkstat"
+                      "--import" "darkstat.db"
+                      "--export" "darkstat.db")))
+      (stop #~(make-kill-destructor))))))
+
+(define darkstat-service-type
+  (service-type
+   (name 'darkstat)
+   (description
+    "Run @command{darkstat} to serve network traffic statictics reports over
+HTTP.")
+   (extensions
+    (list (service-extension account-service-type
+                             (const %darkstat-accounts))
+          (service-extension shepherd-root-service-type
+                             (compose list darkstat-shepherd-service))))))
-- 
2.13.3




--- End Message ---
--- Begin Message --- Subject: Re: [bug#30003] [PATCH 2/2] gnu: services: Add darkstat service. Date: Mon, 08 Jan 2018 20:59:26 +0800 User-agent: Gnus/5.13 (Gnus v5.13) Emacs/25.3 (gnu/linux)
address@hidden (Ludovic Courtès) writes:

> Hello,
>
> 宋文武 <address@hidden> skribis:
>
>> * gnu/services/monitoring.scm: New file.
>> * gnu/local.mk (GNU_SYSTEM_MODULES): Add it.
>> * doc/guix.texi (Monitoring Services): Document it.
>
> Nice!
>
> I only have minor suggestions:
>
>> address@hidden Darkstat Service
>> address@hidden darkstat
>> address@hidden is a packet sniffer that captures network traffic,
>
> I think you can remove @command since you’re referring to the software,
> not to the command.
>
>> address@hidden
>> +(service darkstat-service-type
>> +  (darkstat-configuration
>> +    (interface "eth0")))
>
> This should be aligned to the right.  Also perhaps s/eth0/eno1/ to match
> common names.
>
>> address@hidden @code{package} (default: @code{darstat})
>                                           ^
> Typo.
>
>> address@hidden @code{bindaddr} (default: @code{"127.0.0.1"})
>
> I’d prefer “address” or “listen-address” or “bind-address” (likewise in
> the code.)
>
> Otherwise LGTM, thank you!

Done, thanks for the review!


--- End Message ---

reply via email to

[Prev in Thread] Current Thread [Next in Thread]