aboutsummaryrefslogtreecommitdiff
path: root/gn/packages/slurm.scm
blob: 9e3d063878c918237d1701613ba9ec6638e43992 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2015 Roel Janssen <roel@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 (gn packages slurm)
  #:use-module ((guix licenses) #:prefix license:)
  #:use-module (gnu packages)
  #:use-module (guix packages)
  #:use-module (guix download)
  #:use-module (guix build-system gnu)
  #:use-module (gnu packages tcl)
  #:use-module (gnu packages linux)
  #:use-module (gnu packages textutils)
  #:use-module (gnu packages base)
  #:use-module (gnu packages gnupg)
  #:use-module (gnu packages libedit)
  #:use-module (gnu packages llvm)
  #:use-module (gnu packages perl)
  #:use-module (gnu packages python)
  #:use-module (gnu packages tls)
  #:use-module (gnu packages zip)
  #:use-module (guix git-download))

(define-public slurm-llnl
  (package
   (name "slurm-llnl")
   (version "15-08-6-1")
   (source (origin
             (method url-fetch)
             (uri (string-append "https://github.com/SchedMD/slurm/archive/slurm-"
                                 version ".tar.gz"))
             (file-name (string-append name "-" version ".tar.gz"))
             (sha256
              (base32
               "1h8al21blmrhma9r7qxkba2g5i74m3hrjc9a640j7px54szvg18v"))))
    (inputs `(("openssl" ,openssl)
              ("munge" ,munge)
              ("perl" ,perl)
              ("expect" ,expect)
              ("python" ,python)
              ("linux-pam" , linux-pam)))
    (build-system gnu-build-system)
    (arguments
     `(#:configure-flags '("--enable-pam")
       #:phases
       (modify-phases %standard-phases
         (add-before
          'configure 'rewrite-usr-bin
          (lambda* (#:key inputs #:allow-other-keys)
                   (substitute* "./doc/html/shtml2html.py"
                                (("#!/usr/bin/env python")
                                 (string-append "#!" (which "python3"))))
                   (substitute* "src/common/env.c"
                                (("/usr/bin/env") (which "env"))))))))
    (home-page "http://www.schedmd.com/")
    (synopsis "Tool for cluster computing")
    (description
     "Fault-tolerant, and highly scalable cluster management and job
scheduling system for large and small clusters.")
    (license license:gpl2+)))

(define-public munge
  (package
    (name "munge")
    (version "0.5.11")
    (source (origin
             (method url-fetch)
             (uri (string-append "https://github.com/dun/munge/archive/munge-"
                                 version ".tar.gz"))
             (file-name (string-append name "-" version ".tar.gz"))
             (sha256
              (base32
               "0njplyalwwqh7xr7xc7klc6x06mq0ak8w2pxh85w8n4hxkmqqnf5"))))
    (inputs `(("openssl" ,openssl)
              ("libgcrypt" ,libgcrypt)))
    (build-system gnu-build-system)
    (home-page "https://dun.github.io/munge/")
    (synopsis "Scalable authentication service for creating and validating
credentials on a cluster")
    (description "Munge allows a process to authenticate the UID and
GID of another local or remote process within a group of hosts having
common users and groups.  These hosts form a security realm that is
defined by a shared cryptographic key.  Clients within this security
realm can create and validate credentials without the use of root
privileges, reserved ports, or platform-specific methods.")
    (license license:gpl2+)))