mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-14 07:00:32 -05:00
9a9e72d5ad
* gnu/packages/system.scm (shadow): New variable.
143 lines
5.9 KiB
Scheme
143 lines
5.9 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
|
;;; Copyright © 2012, 2013 Ludovic Courtès <ludo@gnu.org>
|
|
;;;
|
|
;;; 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 packages system)
|
|
#:use-module (guix licenses)
|
|
#:use-module (guix packages)
|
|
#:use-module (guix download)
|
|
#:use-module (guix build-system gnu)
|
|
#:use-module (gnu packages)
|
|
#:use-module (gnu packages ncurses)
|
|
#:use-module (gnu packages linux))
|
|
|
|
(define-public pies
|
|
(package
|
|
(name "pies")
|
|
(version "1.2")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "mirror://gnu/pies/pies-"
|
|
version ".tar.bz2"))
|
|
(sha256
|
|
(base32
|
|
"18w0dbg77i56cx1bwa789w0qi3l4xkkbascxcv2b6gbm0zmjg1g6"))))
|
|
(build-system gnu-build-system)
|
|
(home-page "http://www.gnu.org/software/pies/")
|
|
(synopsis "Program invocation and execution supervisor")
|
|
(description
|
|
"The name Pies (pronounced \"p-yes\") stands for Program Invocation
|
|
and Execution Supervisor. This utility starts and controls execution of
|
|
external programs, called components. Each component is a stand-alone
|
|
program, which is executed in the foreground. Upon startup, pies reads
|
|
the list of components from its configuration file, starts them, and
|
|
remains in the background, controlling their execution. If any of the
|
|
components terminates, the default action of Pies is to restart it.
|
|
However, it can also be programmed to perform a variety of another
|
|
actions such as, e.g., sending mail notifications to the system
|
|
administrator, invoking another external program, etc.
|
|
|
|
Pies can be used for a wide variety of tasks. Its most obious use is to
|
|
put in backgound a program which normally cannot detach itself from the
|
|
controlling terminal, such as, e.g., minicom. It can launch and control
|
|
components of some complex system, such as Jabberd or MeTA1 (and it
|
|
offers much more control over them than the native utilities). Finally,
|
|
it can replace the inetd utility!")
|
|
(license gpl3+)))
|
|
|
|
(define-public inetutils
|
|
(package
|
|
(name "inetutils")
|
|
(version "1.9.1")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "mirror://gnu/inetutils/inetutils-"
|
|
version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"0azzg6njgq79byl6960kb0wihfhhzf49snslhxgvi30ribgfpa82"))))
|
|
(build-system gnu-build-system)
|
|
(arguments `(#:patches (list (assoc-ref %build-inputs "patch/gets"))
|
|
|
|
;; FIXME: `tftp.sh' relies on `netstat' from utils-linux,
|
|
;; which is currently missing.
|
|
#:tests? #f))
|
|
(inputs `(("patch/gets" ,(search-patch "diffutils-gets-undeclared.patch"))
|
|
("ncurses" ,ncurses)))
|
|
(home-page "http://www.gnu.org/software/inetutils/")
|
|
(synopsis "Basic networking utilities")
|
|
(description
|
|
"The GNU network utilities suite provides the following tools:
|
|
ftp(d), hostname, ifconfig, inetd, logger, ping, rcp, rexec(d),
|
|
rlogin(d), rsh(d), syslogd, talk(d), telnet(d), tftp(d), traceroute,
|
|
uucpd, and whois.")
|
|
(license gpl3+)))
|
|
|
|
(define-public shadow
|
|
(package
|
|
(name "shadow")
|
|
(version "4.1.5.1")
|
|
(source (origin
|
|
(method url-fetch)
|
|
(uri (string-append
|
|
"http://pkg-shadow.alioth.debian.org/releases/shadow-"
|
|
version ".tar.bz2"))
|
|
(sha256
|
|
(base32
|
|
"1yvqx57vzih0jdy3grir8vfbkxp0cl0myql37bnmi2yn90vk6cma"))))
|
|
(build-system gnu-build-system)
|
|
(arguments
|
|
'(;; Assume System V `setpgrp (void)', which is the default on GNU
|
|
;; variants (`AC_FUNC_SETPGRP' is not cross-compilation capable.)
|
|
#:configure-flags '("--with-libpam" "ac_cv_func_setpgrp_void=yes")
|
|
|
|
#:phases (alist-cons-before
|
|
'build 'set-nscd-file-name
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
;; Use the right file name for nscd.
|
|
(let ((libc (assoc-ref inputs "libc")))
|
|
(substitute* "lib/nscd.c"
|
|
(("/usr/sbin/nscd")
|
|
(string-append libc "/sbin/nscd")))))
|
|
(alist-cons-after
|
|
'install 'remove-groups
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
;; Remove `groups', which is already provided by Coreutils.
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
(bin (string-append out "/bin"))
|
|
(man (string-append out "/share/man/man1")))
|
|
(delete-file (string-append bin "/groups"))
|
|
(for-each delete-file (find-files man "^groups\\."))
|
|
#t))
|
|
%standard-phases))))
|
|
|
|
(inputs (if (string-suffix? "-linux"
|
|
(or (%current-target-system)
|
|
(%current-system)))
|
|
`(("linux-pam" ,linux-pam))
|
|
'()))
|
|
(home-page "http://pkg-shadow.alioth.debian.org/")
|
|
(synopsis "Authentication-related tools such as passwd, su, and login")
|
|
(description
|
|
"Shadow provides a number of authentication-related tools, including:
|
|
login, passwd, su, groupadd, and useradd.")
|
|
|
|
;; The `vipw' program is GPLv2+.
|
|
;; libmisc/salt.c is public domain.
|
|
(license bsd-3)))
|