aboutsummaryrefslogtreecommitdiff
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2020 Efraim Flashner <efraim@flashner.co.il>
;;; Copyright © 2020 Giacomo Leidi <goodoldpaul@autistici.org>
;;; Copyright © 2021 Noisytoot <noisytoot@disroot.org>
;;; Copyright © 2021 Charles <charles.b.jackson@protonmail.com>
;;; Copyright © 2021 Philip McGrath <philip@philipmcgrath.com>
;;; Copyright © 2021 Dhruvin Gandhi <contact@dhruvin.dev>
;;; Copyright © 2022 Nicolas Graves <ngraves@ngraves.fr>
;;; Copyright © 2023 Jelle Licht <jlicht@fsfe.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 node-xyz)
  #:use-module ((guix licenses) #:prefix license:)
  #:use-module (gnu packages sqlite)
  #:use-module (gnu packages python)
  #:use-module (gnu packages web)
  #:use-module (guix gexp)
  #:use-module (guix packages)
  #:use-module (guix git-download)
  #:use-module (guix build-system node))

;;;
;;; Please: Try to add new module packages in alphabetic order.
;;;

(define-public node-acorn
  (package
    (name "node-acorn")
    (version "8.7.1")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/acornjs/acorn")
             (commit version)))
       (file-name (git-file-name name version))
       (sha256
        (base32  "10lpqbq4wvndx13mh7yjqgpcp3ac81b9zmrn4qb1qpzgy462fa92"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:modules
       ((guix build node-build-system)
        (srfi srfi-1)
        (ice-9 match)
        (guix build utils))
       #:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'change-directory
           (lambda _
             (chdir "acorn")))
         (add-before 'configure 'avoid-prepare-scripts
           (lambda _
             ;; We need to remove the prepare script from "package.json", as
             ;; it would try to use the build environment and would block the
             ;; automatic building by other packages making use of node-acorn.
             ;; TODO: Add utility function
             (with-atomic-json-file-replacement "package.json"
               (match-lambda
                 (('@ . pkg-meta-alist)
                  (cons '@ (map (match-lambda
                                  (("scripts" @ . scripts-alist)
                                   `("scripts" @ ,@(filter (match-lambda
                                                             (("prepare" . _)
                                                              #f)
                                                             (_
                                                              #t))
                                                           scripts-alist)))
                                  (other other))
                                pkg-meta-alist)))))))
         (replace 'build
           (lambda* (#:key inputs native-inputs #:allow-other-keys)
             (let ((esbuild (search-input-file (or native-inputs inputs)
                                        "/bin/esbuild")))
               (invoke esbuild
                     "src/index.js"
                     "--outfile=dist/acorn.js"
                     "--format=cjs"
                     "--bundle"
                     "--platform=node")
               (invoke esbuild
                     "src/index.js"
                     "--outfile=dist/acorn.mjs"
                     "--format=esm"
                     "--bundle"
                     "--platform=node")
               (invoke esbuild
                     "src/bin/acorn.js"
                     "--outfile=dist/bin.js"
                     "--format=cjs"
                     "--platform=node")))))))
    (native-inputs
     (list esbuild))
    (home-page "https://github.com/acornjs/acorn/tree/master/acorn")
    (synopsis "Javascript-based Javascript parser")
    (description "Acornjs is a Javascript parser with many options and an
architecture supporting plugins.")
    (license license:expat)))

(define-public node-addon-api
  (package
    (name "node-addon-api")
    (version "8.3.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/nodejs/node-addon-api")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "1swvhdss2w636l24bnssnwb1rqh7i6lhpkk4knbrvpspqf80kagc"))))
    (inputs
     (list python node-safe-buffer))
    (build-system node-build-system)
    (arguments
     `(#:modules
       ((guix build node-build-system)
        (srfi srfi-1)
        (ice-9 match)
        (guix build utils))
       #:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies
              `("benchmark"
                "bindings"
                "clang-format"
                "eslint"
                "eslint-config-semistandard"
                "eslint-config-standard"
                "eslint-plugin-import"
                "eslint-plugin-node"
                "eslint-plugin-promise"
                "fs-extra"
                "neostandard"
                "path"
                "pre-commit"
                "semver"))))
         (add-after 'unpack 'skip-js-tests
           ;; We can't run the js-based tests,
           ;; but we can still do the C++ parts
           (lambda args
             (define new-test-script
               "echo stopping after pretest on Guix")
             (with-atomic-json-file-replacement "package.json"
               (match-lambda
                 (('@ . pkg-meta-alist)
                  (cons
                   '@
                   (map (match-lambda
                          (("scripts" '@ . scripts-alist)
                           `("scripts" @ ,@(map (match-lambda
                                                  (("test" . _)
                                                   (cons "test"
                                                         new-test-script))
                                                  (other
                                                   other))
                                                scripts-alist)))
                          (other
                           other))
                        pkg-meta-alist))))))))))
    (home-page "https://github.com/nodejs/node-addon-api")
    (synopsis "Node.js API (Node-API) header-only C++ wrappers")
    (description "This module contains header-only C++ wrapper classes which
simplify the use of the C based Node-API provided by Node.js when using C++.
It provides a C++ object model and exception handling semantics with low
overhead.

Node-API is an ABI stable C interface provided by Node.js for building native
addons.  It is intended to insulate native addons from changes in the
underlying JavaScript engine and allow modules compiled for one version to run
on later versions of Node.js without recompilation.  The @code{node-addon-api}
module, which is not part of Node.js, preserves the benefits of the Node-API
as it consists only of inline code that depends only on the stable API
provided by Node-API.

It is important to remember that @emph{other} Node.js interfaces such as
@code{libuv} (included in a project via @code{#include <uv.h>}) are not
ABI-stable across Node.js major versions.")
    (license license:expat)))

(define-public node-bindings
  (package
    (name "node-bindings")
    (version "1.5.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/TooTallNate/node-bindings")
             (commit version)))
       (file-name (git-file-name name version))
       (sha256
        (base32 "100gp6kpjvd4j1dqnp0sbjr1hqx5mz7r61q9qy527jyhk9mj47wk"))))
    (inputs
     (list node-file-uri-to-path))
    (build-system node-build-system)
    (arguments
     ;; there are no tests
     `(#:tests? #f))
    (home-page "https://github.com/TooTallNate/node-bindings")
    (synopsis "Locate native addons")
    (description "This package provides a helper module to locate native
addons in a wide array of potential locations.")
    (license license:expat)))

(define-public node-buffer-crc32
  (package
    (name "node-buffer-crc32")
    (version "0.2.13")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/brianloveswords/buffer-crc32")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "09qx2mnd898190m50mc0rhyvbm7d677sxz9bn09qmqkz6fnsddgf"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("tap")))))))
    (home-page "https://github.com/brianloveswords/buffer-crc32")
    (synopsis "CRC32 implementation in Javascript")
    (description
     "This package provides a CRC32 algorithm that works with binary data
and fancy character sets, signed or unsigned data and has tests, for Node.")
    (license license:expat)))

(define-public node-color-name
  (package
    (name "node-color-name")
    (version "1.1.3")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/colorjs/color-name")
               (commit (string-append "v" version))))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "09rbmj16nfwcwkhrybqxyy66bkrs50vpw6hkdqqb14l3gsyxpr74"))))
    (build-system node-build-system)
    (home-page "https://github.com/colorjs/color-name")
    (synopsis "JSON with CSS color names")
    (description
     "This package provides a JSON list with color names and their values.")
    (license license:expat)))

(define-public node-crx3
  (package
    (name "node-crx3")
    (version "1.1.3")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/ahwayakchih/crx3")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1snqyw8c3s9p2clhqh1172z0rs1was36sfxkk6acgpar32c2rwzw"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'unpack 'replace-mri-by-minimist
                    (lambda _
                      (substitute* "package.json"
                        (("\"mri\": \"\\^1\\.1\\.6\",")
                         "\"minimist\": \"^1.2.6\","))
                      (substitute* "lib/configuration.js"
                        (("mri")
                         "minimist"))))
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("c8"
                                             "docdash"
                                             "eslint"
                                             "eslint-plugin-jsdoc"
                                             "jsdoc"
                                             "tap-diff"
                                             "tape"
                                             "tape-catch")))))))
    (inputs (list node-minimist node-pbf node-yazl))
    (home-page "https://github.com/ahwayakchih/crx3")
    (synopsis "Create CRXv3 browser extensions with Javascript")
    (description
     "This package creates web extension files (CRXv3) for Chromium versions
64.0.3242 and above and all other browsers supporting the file format and API.")
    (license license:bsd-3)))

(define-public node-debug
  (package
    (name "node-debug")
    (version "4.3.3")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/debug-js/debug")
             (commit version)))
       (file-name (git-file-name name version))
       (sha256
        (base32 "0ji0dmdl2xkgxqxvd6xjy7k3mmknmhvqjgc40vyly9ka1mpf20vb"))))
    (inputs
     (list node-ms))
    (build-system node-build-system)
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("brfs"
                                    "browserify"
                                    "coveralls"
                                    "istanbul"
                                    "karma"
                                    "karma-browserify"
                                    "karma-chrome-launcher"
                                    "karma-mocha"
                                    "mocha"
                                    "mocha-lcov-reporter"
                                    "xo"
                                    "supports-color")))))
       #:tests? #f))
    (home-page "https://github.com/debug-js/debug")
    (synopsis "Debugging utility for Node.js")
    (description "The @code{debug} module exposes a function, which if called
with a module name as argument provides a function that writes debug output to
@code{console.error} under that module name.  This output can be controlled in
a more fine-grained manner by binding the @env{DEBUG} variable.")
    (license license:expat)))

(define-public node-env-variable
  (package
    (name "node-env-variable")
    (version "0.0.4")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/bigpipe/env-variable")
               (commit version)))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "0nnpxjxfhy4na7fixb7p3ww6ard5xgggfm83b78i333867r4gmsq"))))
    (build-system node-build-system)
    (arguments '(#:tests? #f)) ; No tests.
    (home-page "https://github.com/bigpipe/env-variable")
    (synopsis "Environment variables for Node with fallbacks")
    (description "This package provides environment variables with
@code{process.env}, @code{window.name}, @code{location.hash} and
@code{localStorage} fallbacks.")
    (license license:expat)))

(define-public node-far
  (package
    (name "node-far")
    (version "0.0.7")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/felixge/node-far")
               (commit (string-append "v" version))))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "083rv1rszjn0i91zcpaghlid0kwhk0angmpj4hiflrlyhd6cmjzw"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (replace 'check
           (lambda _
             ;; We skip the two tests which are supposed to fail.
             (invoke "bin/node-far" "-v" "test/" "-e" "test.*fail.js"))))))
    (inputs
     (list node-oop))
    (home-page "https://github.com/felixge/node-far")
    (synopsis "Node.js test runner")
    (description "This package provides a simple test runner that finds and runs
multiple node.js files, while providing useful information about output and exit
codes.")
    (license license:expat)))

(define-public node-file-uri-to-path
  (package
    (name "node-file-uri-to-path")
    (version "2.0.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/TooTallNate/file-uri-to-path")
             (commit version)))
       (file-name (git-file-name name version))
       (sha256
        (base32 "08l779az44czm12xdhgcrnzpqw34s59hbrlfphs7g9y2k26drqav"))))
    (native-inputs
     (list esbuild))
    (build-system node-build-system)
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("@types/mocha"
                                    "@types/node"
                                    "@typescript-eslint/eslint-plugin"
                                    "@typescript-eslint/parser"
                                    "cpy-cli"
                                    "eslint"
                                    "eslint-config-airbnb"
                                    "eslint-config-prettier"
                                    "eslint-import-resolver-typescript"
                                    "eslint-plugin-import"
                                    "eslint-plugin-jsx-a11y"
                                    "eslint-plugin-react"
                                    "mocha"
                                    "rimraf"
                                    "typescript"))))
         (replace 'build
           (lambda* (#:key inputs native-inputs #:allow-other-keys)
             (copy-recursively "src" "dist")
             (invoke (search-input-file (or native-inputs inputs)
                                        "/bin/esbuild")
                     "dist/index.ts"
                     "--outfile=dist/src/index.js"
                     "--format=cjs"
                     "--sourcemap"
                     "--platform=node"))))
       #:tests? #f))
    (home-page "https://github.com/TooTallNate/file-uri-to-path")
    (synopsis "Convert a @code{file:} URI to a file path")
    (description "This package provides a function to convert a @code{file:}
URI to a file path.  It accepts a @code{file:} URI and returns a file path
suitable for use with the @code{fs} module functions.")
    (license license:expat)))

(define-public node-global-gradle-clean
  (package
    (name "node-global-gradle-clean")
    (version "1.0.1")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/VarunBarad/global-gradle-clean")
                    (commit version)))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1fhm4jimnf7bl5drgwg39mjh8x4rns15hl0fz3bnxi9ikc6dm02y"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f)) ;No tests.
    (home-page "https://github.com/VarunBarad/global-gradle-clean")
    (synopsis "Global Gradle Clean")
    (description
     "Global Gradle Clean is a Node.js package used to clean all gradle
projects under a given directory.  It uses the gradle wrapper to execute the
clean task of each project.")
    (license license:expat)))

(define-public node-ieee754
  (package
    (name "node-ieee754")
    (version "1.2.1")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/feross/ieee754")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "19rlg59lavnwsvbblhvrqwinz2wzqlxhddqpwrc3cyqkscjgza7i"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("airtap" "standard" "tape")))))))
    (home-page "https://github.com/feross/ieee754")
    (synopsis "Read/write IEEE754 floating point numbers in Javascript")
    (description "This package can read and write IEEE754 floating point
numbers from/to a Buffer or array-like object in Javascript.")
    (license license:bsd-3)))

(define-public node-inherits
  (package
    (name "node-inherits")
    (version "2.0.4")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/isaacs/inherits")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32
         "0cpsr5yqwkxpbbbbl0rwk4mcby6zbx841k2zb4c3gb1579i5wq9p"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies '("tap")))))
       ;; FIXME: Tests depend on node-tap
       #:tests? #f))
    (home-page "https://github.com/isaacs/inherits")
    (synopsis "Browser-friendly object inheritance")
    (description "This package provides an alternative implementation of
Node's @code{inherits} constructor that can be used in browsers, while
defaulting to Node's implementation otherwise.")
    (license license:isc)))

(define-public node-irc
  (package
    (name "node-irc")
    (version "0.5.2")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/martynsmith/node-irc")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1ln4qfx20jbwg4cp8lp0vf27m5281z2sz16d15xd6150n26cbi4x"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies
              `("ansi-color" "faucet" "jscs" "tape")))))
       #:tests? #f))
    (inputs
     (list node-irc-colors))
    (home-page "https://github.com/martynsmith/node-irc")
    (synopsis "IRC client library for Node.js")
    (description "@code{node-irc} is an IRC client library for Node.js.
It has functions for joining, parting, talking, and many other IRC commands.")
    (license license:gpl3+)))

(define-public node-irc-colors
  (package
    (name "node-irc-colors")
    (version "1.5.0")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/fent/irc-colors.js")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "0q3y34rbnlc55jcakmdxkicwazyvyph9r6gaf6hi8k7wj2nfwfli"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("istanbul" "vows")))))
       #:tests? #f))
    (home-page "https://github.com/fent/irc-colors.js")
    (synopsis "Node.js module providing color and formatting for IRC")
    (description "@code{node-irc-colors} is a Node.js module that
allows you to easily use colored output and formatting in IRC bots.
It contains functions for colours as well as more complex formatting
such as rainbows.")
    (license license:expat)))

(define-public node-long-stack-traces
  (package
    (name "node-long-stack-traces")
    (version "0.1.2")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/tlrobinson/long-stack-traces")
               (commit (string-append "v" version))))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "0famwsyc6xawi30v25zi65d8fhbvlvh976bqydf1dqn5gz200cl3"))))
    (build-system node-build-system)
    (arguments '(#:tests? #f)) ; No tests.
    (home-page "https://github.com/tlrobinson/long-stack-traces")
    (synopsis "Long stacktraces implemented in user-land JavaScript")
    (description "This package provides long stacktraces for V8 implemented in
user-land JavaScript.")
    (license license:expat))) ; in README

(define-public node-mersenne
  (package
    (name "node-mersenne")
    (version "0.0.4")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/jwatte/node-mersenne")
               ;; The actual release lacks a git tag.
               (commit "f9fa01694ee49d6ae6ff9d90cfda594bddd3ccef")))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "034iaiq2pdqn342p2404cpz364g282d2hkp9375hysnh9i968wbb"))))
    (build-system node-build-system)
    (arguments '(#:tests? #f)) ; No tests.
    (home-page "https://www.enchantedage.com/node-mersenne")
    (synopsis "Node.js module for generating Mersenne Twister random numbers")
    (description "This package provides a node.js port of the Mersenne Twister
random number generator.")
    (license license:bsd-3)))

(define-public node-minimist
  (package
    (name "node-minimist")
    (version "1.2.6")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/substack/minimist")
                    (commit version)))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "0mxj40mygbiy530wskc8l28wxb6fv3f8vrhpwjgprymhpgbaac7d"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("covert" "tap" "tape")))))))
    (home-page "https://github.com/substack/minimist")
    (synopsis "Parse CLI arguments in Javascript")
    (description "This package can scan for CLI flags and arguments in
Javascript.")
    (license license:expat)))

(define-public node-ms
  (package
    (name "node-ms")
    (version "2.1.3")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/vercel/ms")
             (commit version)))
       (file-name (git-file-name name version))
       (sha256
        (base32 "1l74kmmwffmzdz38lli0v5mdb9p9jmsjxpb48ncknqw2n74cgf08"))))
    (build-system node-build-system)
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("eslint"
                                    "expect.js"
                                    "husky"
                                    "lint-staged"
                                    "mocha"
                                    "prettier")))))
       #:tests? #f))
    (home-page "https://github.com/vercel/ms")
    (synopsis "Convert time to milliseconds")
    (description "Use this package to easily convert various time formats to
milliseconds.  A number supplied as integer or string is returned as-is, while
a string consisting of a number and a time unit is converted to milliseconds.")
    (license license:expat)))

(define-public node-nan
  (package
    (name "node-nan")
    (version "2.22.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/nodejs/nan")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "02gqm23x26glffvyxrnk610hy3hg0kwh2v58dhnb032l0jhjzqvp"))))
    (build-system node-build-system)
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies
              '("bindings"
                "commander"
                "glob"
                "request"
                "node-gyp" ;; would be needed for tests
                "tap"
                "xtend")))))
       ;; tests need tap and other dependencies
       #:tests? #f))
    (inputs
     (list node-readable-stream))
    (home-page "https://github.com/nodejs/nan")
    (synopsis "Native Abstractions for Node.js")
    (description "Native Abstractions for Node.js (``NaN'') provides a header
file filled with macros and utilities for making add-on development for Node.js
easier across versions.  The goal is to provide all logic necessary to develop
native Node.js addons without having to inspect @code{NODE_MODULE_VERSION}.")
    (license license:expat)))

(define-public node-normalize-path
  (package
    (name "node-normalize-path")
    (version "3.0.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/jonschlinkert/normalize-path")
             (commit version)))
       (file-name (git-file-name name version))
       (sha256
        (base32 "1l079szbgw2b9i5zx6zbwvxiivssa55a4pwfy4m7n6rdkcmsxf7f"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("gulp-format-md" "mocha")))))))
    (native-inputs (list node-minimist))
    (home-page "https://github.com/jonschlinkert/normalize-path")
    (synopsis "Normalize slashes in a file path")
    (description
     "Normalize slashes in a file path to be POSIX/Unix-like forward slashes.
Can also condense repeated slashes to a single slash and remove trailing
slashes, unless disabled.")
    (license license:expat)))

(define-public node-once
  (package
    (name "node-once")
    (version "1.4.0")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/isaacs/once")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1z8dcbf28dqdcp4wb0c53wrs90a07nkrax2c9kk26dsk1dhrnxav"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies '("tap")))))
       ;; FIXME: Tests depend on node-tap
       #:tests? #f))
    (inputs
     (list node-wrappy))
    (home-page "https://github.com/isaacs/once")
    (synopsis "Node.js module to call a function only once")
    (description
     "@code{once} is a Node.js module to call a function exactly one time.
Subsequent calls will either return the cached previous value or throw an error
if desired.")
    (license license:isc)))

(define-public node-oop
  ;; No releases, last commit was February 2013.
  (let ((commit "f9d87cda0958886955c14a0a716e57021ed295dc")
        (revision "1"))
    (package
      (name "node-oop")
      (version (git-version "0.0.0" revision commit))
      (source
        (origin
          (method git-fetch)
          (uri (git-reference
                 (url "https://github.com/felixge/node-oop")
                 (commit commit)))
          (file-name (git-file-name name version))
          (sha256
           (base32
            "0mqrcf0xi2jbwffwkk00cljpqfsri1jk8s6kz8jny45apn7zjds1"))))
      (build-system node-build-system)
      (arguments '(#:tests? #f)) ; Tests run during build phase.
      (home-page "https://github.com/felixge/node-oop")
      (synopsis "Simple, light-weight oop module for Node")
      (description "This library tries to bring basic oop features to JavaScript
while being as light-weight and simple as possible.")
      (license license:expat))))

(define-public node-path-key
  (package
    (name "node-path-key")
    (version "4.0.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/sindresorhus/path-key")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "09f4rf70qhq234fcc3pw9nrqic8cb75pk2b6wfnpr96v0r1h8d8g"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("@types/node" "ava" "tsd" "xo")))))))
    (home-page "https://github.com/sindresorhus/path-key")
    (synopsis "Cross-platform utility to compute the PATH environment variable key")
    (description "@code{path-key} provides an implementation to compute the
particular cross-platform spellings of the PATH environment variable key.")
    (license license:expat)))

(define-public node-pbf
  (package
    (name "node-pbf")
    (version "3.2.1")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/mapbox/pbf")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1r8xs787ix79yr0vrwrizdml9h7cmxjrzhvnhkj784ac5f8nv5j7"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies
                       '("benchmark"
                         "browserify"
                         "eslint"
                         "eslint-config-mourner"
                         "mkdirp"
                         "protobufjs"
                         "protocol-buffers"
                         "tap"
                         "tile-stats-runner"
                         "uglify-js")))))))
    (inputs (list node-ieee754 node-resolve-protobuf-schema))
    (home-page "https://github.com/mapbox/pbf")
    (synopsis "Decode and encode protocol buffers in Javascript")
    (description
     "This package is a low-level, fast and lightweight JavaScript library
for decoding and encoding protocol buffers, a compact binary format for
structured data serialization.  Works both in Node and the browser.
It supports lazy decoding and detailed customization of the reading/writing
code.")
    (license license:bsd-3)))

(define-public node-protocol-buffers-schema
  (package
    (name "node-protocol-buffers-schema")
    (version "3.6.0")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/mafintosh/protocol-buffers-schema")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "0lnckxj14jzsnfxdd5kmlwrac43c214bv8i2g5rdldymlpxzrz1v"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("standard" "tape")))))))
    (home-page "https://github.com/mafintosh/protocol-buffers-schema")
    (synopsis "Protocol buffers schema parser written in Javascript")
    (description "This package provides a protocol buffers schema parser
written in Javascript.")
    (license license:expat)))

(define-public node-readable-stream
  (package
    (name "node-readable-stream")
    (version "3.6.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/nodejs/readable-stream")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32
         "0ybl4cdgsm9c5jq3xq8s01201jk8w0yakh63hlclsfbcdfqhd9ri"))))
    (build-system node-build-system)
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("@babel/cli"
                                    "@babel/core"
                                    "@babel/polyfill"
                                    "@babel/preset-env"
                                    "airtap"
                                    "assert"
                                    "bl"
                                    "deep-strict-equal"
                                    "events.once"
                                    "glob"
                                    "gunzip-maybe"
                                    "hyperquest"
                                    "lolex"
                                    "nyc"
                                    "pump"
                                    "rimraf"
                                    "tap"
                                    "tape"
                                    "tar-fs"
                                    "util-promisify")))))
       #:tests? #f))
    (inputs (list node-util-deprecate node-string-decoder node-inherits))
    (home-page "https://github.com/nodejs/readable-stream")
    (synopsis "Node.js core streams for userland")
    (description
     "@code{readable-stream} provides an implementation of Node.js core streams
that behaves the same across different versions.")
    (license license:expat)))

(define-public node-resolve-protobuf-schema
  (package
    (name "node-resolve-protobuf-schema")
    (version "2.1.0")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/mafintosh/resolve-protobuf-schema")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "0zxavr0b2yz9xzp6zlsg5g09i0a6zqb24j12rdvfgph6wd4mzk40"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("standard" "tape")))))))
    (inputs (list node-protocol-buffers-schema))
    (home-page "https://github.com/mafintosh/resolve-protobuf-schema")
    (synopsis "Resolve protobuf imports")
    (description
     "This package can read a protobuf schema from the disk, parse it and
resolve all imports.")
    (license license:expat)))

(define-public node-safe-buffer
  (package
    (name "node-safe-buffer")
    (version "5.2.1")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/feross/safe-buffer")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32
         "0r26m0nl41h90ihnl2xf0cqs6z9z7jb87dl5j8yqb7887r9jlbpi"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies '("tape" "standard")))))
       #:tests? #f))
    (home-page "https://github.com/feross/safe-buffer")
    (synopsis "Buffer creation with explicit semantics")
    (description "This package provides a drop-in replacement for Node.js
@code{Buffer} API, which provides newer, explicit constructors (such as
@code{Buffer.alloc(SIZE)}) in older versions.")
    (license license:expat)))

(define-public node-safe-stable-stringify
  (package
    (name "node-safe-stable-stringify")
    (version "2.4.3")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/BridgeAR/safe-stable-stringify")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "008adig8j13rn2a21ngnp770y4zz6yq176ix5rkskjbb8g2qwapg"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("benchmark" "clone"
                                             "fast-json-stable-stringify"
                                             "fast-safe-stringify"
                                             "fast-stable-stringify"
                                             "faster-stable-stringify"
                                             "fastest-stable-stringify"
                                             "json-stable-stringify"
                                             "json-stringify-deterministic"
                                             "json-stringify-safe"
                                             "standard"
                                             "tap"
                                             "typescript"
                                             "@types/node"
                                             "@types/json-stable-stringify")))))))
    (home-page "https://github.com/BridgeAR/safe-stable-stringify")
    (synopsis "Serialization of javascript objects")
    (description
     "Safe, deterministic and fast serialization alternative to JSON.stringify.
Gracefully handles circular structures and bigint instead of throwing.
Optional custom circular values, deterministic behavior or strict JSON
compatibility check.")
    (license license:expat)))

(define-public node-segfault-handler
  (package
    (name "node-segfault-handler")
    (version "1.3.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/ddopson/node-segfault-handler")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "07nbw35wvrr18kmh8f388v4k5mpjgyy0260bx0xzjdv795i3xvfv"))))
    (native-inputs
     (list python))
    (inputs
     (list node-bindings node-nan))
    (build-system node-build-system)
    (arguments
     ;; there are no tests
     `(#:tests? #f))
    (home-page "https://github.com/ddopson/node-segfault-handler")
    (synopsis "Catches @code{SIGSEGV} and prints diagnostic information")
    (description "This package is a tool for debugging Node.js C/C++ native
code modules and getting stack traces when things go wrong.  If a
@code{SIGSEGV} signal is raised, the module will print a native stack trace to
both @file{stderr} and to a timestamped file.")
    (license license:bsd-3)))

(define-public node-semver
  (package
    (name "node-semver")
    (version "7.2.1")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/npm/node-semver")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "06biknqb05r9xsmcflm3ygh50pjvdk84x6r79w43kmck4fn3qn5p"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies '("tap")))))
       ;; FIXME: Tests depend on node-tap
       #:tests? #f))
    (home-page "https://github.com/npm/node-semver")
    (synopsis "Parses semantic versions strings")
    (description
     "@code{node-semver} is a JavaScript implementation of the
@uref{https://semver.org/, SemVer.org} specification.")
    (license license:isc)))

(define-public node-serialport
  (package
    (name "node-serialport")
    (version "9.2.7")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/serialport/node-serialport")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "0x7zm59a5ff5yygjyw15xs3r5m3rb8av1yfrh4snn44mrwq87yg8"))))
    (inputs
     (list node-serialport-bindings
           node-serialport-parser-delimiter
           node-serialport-parser-readline
           node-serialport-parser-regex
           node-serialport-parser-ready
           node-serialport-parser-inter-byte-timeout
           node-serialport-parser-cctalk
           node-serialport-parser-byte-length
           node-serialport-stream
           node-debug))
    (build-system node-build-system)
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("@serialport/binding-mock"))))
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/serialport"))))
       #:tests? #f))
    (home-page "https://serialport.io")
    (synopsis "Node.js package to access serial ports")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  This package is the recommended entry point for most
projects.  It combines a high-level Node.js stream interface with a useful
default set of parsers and bindings.")
    (license license:expat)))

(define-public node-serialport-binding-abstract
  (package
    (inherit node-serialport)
    (name "node-serialport-binding-abstract")
    (version "9.2.3")
    (inputs
     (list node-debug))
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/binding-abstract"))))
       #:tests? #f))
    (synopsis "Abstract base class for Node SerialPort bindings")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

This package provides the @code{AbstractBinding} class, the base for all Node
SerialPort bindings.  You wouldn't use this class directly, but instead extend
it to make a new binding for a different platform or underling technology.")))

(define-public node-serialport-bindings
  (package
    (inherit node-serialport)
    (name "node-serialport-bindings")
    (version "9.2.7")
    (native-inputs
     (list python))
    (inputs
     (list node-nan node-bindings node-serialport-binding-abstract
           node-serialport-parser-readline node-debug))
    (arguments
     `(#:modules
       ((guix build node-build-system)
        (srfi srfi-1)
        (ice-9 match)
        (guix build utils))
       #:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/bindings")))
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `("prebuild-install"
                                    ;; devDependencies
                                    "@serialport/binding-mock"
                                    "node-abi"))))
         (add-after 'chdir 'avoid-prebuild-install
           (lambda args
             (with-atomic-json-file-replacement "package.json"
               (match-lambda
                 (('@ . pkg-meta-alist)
                  (cons '@ (map (match-lambda
                                  (("scripts" @ . scripts-alist)
                                   `("scripts" @ ,@(filter (match-lambda
                                                             (("install" . _)
                                                              #f)
                                                             (_
                                                              #t))
                                                           scripts-alist)))
                                  (("gypfile" . _)
                                   '("gypfile" . #f))
                                  (other
                                   other))
                                pkg-meta-alist))))))))
       #:tests? #f))
    (synopsis "Abstract base class for Node SerialPort bindings")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

This package provides the @code{Binding} class, which uses a native addon to
talk to the underlying system.  You never have to use @code{Binding} objects
directly.  There is also a @code{MockBinding} available (but not yet packaged
for Guix) to assist with testing.")))

(define-public node-serialport-parser-byte-length
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-byte-length")
    (version "9.2.4")
    (inputs `())
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-byte-length"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser for fixed-length buffers")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{ByteLength}, a parser that emits data
as a buffer every time a specified number of bytes are received.")))

(define-public node-serialport-parser-cctalk
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-cctalk")
    (version "9.2.4")
    (inputs `())
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-cctalk"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser for the ccTalk protocol")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{CCTalk}, which emits packets for the
ccTalk protocol (an open standard for currency detectors) as they are
received.")))

(define-public node-serialport-parser-delimiter
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-delimiter")
    (version "9.2.4")
    (inputs `())
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-delimiter"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser to split data on a delimiter")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{Delimiter}, a parser that emits data
each time a specified byte sequence is received.")))

(define-public node-serialport-parser-inter-byte-timeout
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-inter-byte-timeout")
    (version "9.2.4")
    (inputs `())
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-inter-byte-timeout"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser to detect pauses in data")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{InterByteTimeout}, a parser that emits
data if there is a pause between packets for the specified amount of time.")))

(define-public node-serialport-parser-readline
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-readline")
    (version "9.2.4")
    (inputs
     (list node-serialport-parser-delimiter))
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-readline"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser to split data on newlines")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{Readline}, a parser that emits data
after a (configurable) newline delimiter is received.")))

(define-public node-serialport-parser-ready
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-ready")
    (version "9.2.4")
    (inputs `())
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-ready"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser to wait for specified byte sequence")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{Ready}, a parser that waits for a
specified sequence of ``ready'' bytes before emitting a ready event and
emitting data events.")))

(define-public node-serialport-parser-regex
  (package
    (inherit node-serialport)
    (name "node-serialport-parser-regex")
    (version "9.2.4")
    (inputs `())
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/parser-regex"))))
       #:tests? #f))
    (synopsis "Node SerialPort parser to split data on a regular expression")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

Parsers are used to take raw binary data and transform them into usable
messages.  This package provides @code{Regex}, a parser that uses a regular
expression to split the incoming text.")))

(define-public node-serialport-stream
  (package
    (inherit node-serialport)
    (name "node-serialport-stream")
    (version "9.2.4")
    (inputs
     (list node-debug))
    (arguments
     `(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies `(;; devDependencies
                                    "@serialport/binding-mock"))))
         (add-after 'unpack 'chdir
           (lambda args
             (chdir "packages/stream"))))
       #:tests? #f))
    (synopsis "Node.js stream interface for Node SerialPort")
    (description "Node SerialPort is a modular suite of Node.js packages for
accessing serial ports.  The Guix package @code{node-serialport} provides the
recommended high-level interface.

This package provides an interface for using Node SerialPort bindings via the
Node.js Stream API.  The stream is a duplex stream, allowing for reading and
writing.  It has additional methods for managing the SerialPort
connection.")))

(define-public node-sqlite3
  (package
    (name "node-sqlite3")
    (version "5.0.2")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/mapbox/node-sqlite3")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "0sbbzzli282nxyfha10zx0k5m8hdp0sf3ipl59khjb7wm449j86h"))
       (snippet
        (with-imported-modules '((guix build utils))
          #~(begin
              (use-modules (guix build utils))
              ;; unbundle sqlite
              (for-each delete-file-recursively
                        (find-files "deps"
                                    (lambda (pth stat)
                                      (gzip-file? pth)))))))))
    (inputs
     (list node-addon-api python sqlite))
    (build-system node-build-system)
    (arguments
     `(#:modules
       ((guix build node-build-system)
        (srfi srfi-1)
        (ice-9 match)
        (guix build utils))
       #:tests? #f ; FIXME: tests depend on node-mocha
       #:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies
              `(;; Normally, this is "built" using @mapbox/node-pre-gyp,
                ;; which publishes or downloads pre-built binaries or
                ;; falls back to building from source.  Here, we patch out
                ;; all of that and just build directly.  It might be
                ;; better to patch a version of @mapbox/node-pre-gyp that
                ;; always builds from source, as Debian does, but there
                ;; are a number of dependencies that need to be packaged
                ;; or removed.
                "@mapbox/node-pre-gyp"
                "node-pre-gyp" ;; deprecated name still used in some places
                "aws-sdk"
                "@mapbox/cloudfriend"
                ;; Confusingly, this is only a dependency because of
                ;; @mapbox/node-pre-gyp: with that removed,
                ;; npm will use its own copy:
                "node-gyp"
                ;; These we'd like, we just don't have them yet:
                "eslint"
                "mocha"))))
         (add-before 'configure 'npm-config-sqlite
           ;; We need this step even if we do replace @mapbox/node-pre-gyp
           ;; because the package expects to build its bundled sqlite
           (lambda* (#:key inputs #:allow-other-keys)
             (setenv "npm_config_sqlite" (assoc-ref inputs "sqlite"))))
         (add-after 'install 'patch-binding-path
           ;; We replace a file that dynamic searches for the addon using
           ;; node-pre-gyp (which we don't have) with a version that
           ;; simply uses the path to the addon we built directly.
           ;; The exact path is supposed to depend on things like the
           ;; architecture and napi_build_version, so, to avoid having
           ;; hard-code the details accurately, we do this after the addon
           ;; has been built so we can just find where it ended up.
           (lambda* (#:key outputs #:allow-other-keys)
             (with-directory-excursion
                 (search-input-directory outputs
                                         "lib/node_modules/sqlite3/lib")
               (match (find-files "binding" "\\.node$")
                 ((rel-path)
                  (with-atomic-file-replacement "sqlite3-binding.js"
                    (lambda (in out)
                      (format out "var binding = require('./~a');\n" rel-path)
                      (display "module.exports = exports = binding;\n"
                               out))))))))
         (add-after 'patch-dependencies 'avoid-node-pre-gyp
           (lambda args
             ;; We need to patch .npmignore before the 'repack phase
             ;; so that the built addon is installed with in the package.
             ;; (Upstream assumes node-pre-gyp will download a pre-built
             ;; version when this package is installed.)
             (substitute* ".npmignore"
               (("lib/binding")
                "#lib/binding # <- patched for Guix"))
             (with-atomic-json-file-replacement "package.json"
               (match-lambda
                 (('@ . pkg-meta-alist)
                  (match (assoc-ref pkg-meta-alist "binary")
                    (('@ . binary-alist)
                     ;; When it builds from source, node-pre-gyp supplies
                     ;; module_name and module_path based on the entries under
                     ;; "binary" from "package.json", so this package's
                     ;; "binding.gyp" doesn't define them. Thus, we also need
                     ;; to supply them. The GYP_DEFINES environment variable
                     ;; turns out to be the easiest way to make sure they are
                     ;; propagated from npm to node-gyp to gyp.
                     (setenv "GYP_DEFINES"
                             (string-append
                              "module_name="
                              (assoc-ref binary-alist "module_name")
                              " "
                              "module_path="
                              (assoc-ref binary-alist "module_path")))))
                  ;; We need to remove the install script from "package.json",
                  ;; as it would try to use node-pre-gyp and would block the
                  ;; automatic building performed by `npm install`.
                  (cons '@ (map (match-lambda
                                  (("scripts" @ . scripts-alist)
                                   `("scripts" @ ,@(filter (match-lambda
                                                             (("install" . _)
                                                              #f)
                                                             (_
                                                              #t))
                                                           scripts-alist)))
                                  (other
                                   other))
                                pkg-meta-alist))))))))))
    (home-page "https://github.com/mapbox/node-sqlite3")
    (synopsis "Node.js bindings for SQLite3")
    (description
     "@code{node-sqlite3} provides a set of a Node.js bindings for interacting
with SQLite3 databases.")
     (license license:bsd-3)))

(define-public node-stack-trace
  ;; There have been improvements since the last release.
  (let ((commit "4fd379ee78965ce7ce8820b436f1b1b590d5dbcf")
        (revision "1"))
    (package
      (name "node-stack-trace")
      (version (git-version "0.0.10" revision commit))
      (source
        (origin
          (method git-fetch)
          (uri (git-reference
                 (url "https://github.com/felixge/node-stack-trace")
                 (commit commit)))
          (file-name (git-file-name name version))
          (sha256
           (base32
            "1pk19wcpy8i95z5jr77fybd57qj7xmzmniap4dy47vjlmpkqia4i"))))
      (build-system node-build-system)
      (arguments
       '(#:phases
         (modify-phases %standard-phases
         (add-before 'check 'skip-intentionally-failing-test
           (lambda _
             (substitute* "test/run.js"
               (("far.include") "far.exclude(/test-parse.js/)\nfar.include"))
             #t)))))
      (native-inputs
       (list node-far node-long-stack-traces))
      (home-page "https://github.com/felixge/node-stack-trace")
      (synopsis "Get v8 stack traces as an array of CallSite objects")
      (description "Get v8 stack traces as an array of CallSite objects.")
      (license license:expat))))

(define-public node-statsd-parser
  (package
    (name "node-statsd-parser")
    (version "0.0.4")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/dscape/statsd-parser")
               (commit version)))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "049rnczsd6pv6bk282q4w72bhqc5cs562djgr7yncy7lk0wzq5j3"))))
    (build-system node-build-system)
    (arguments '(#:tests? #f)) ; No tests.
    (home-page "https://github.com/dscape/statsd-parser")
    (synopsis "Streaming parser for the statsd protocol")
    (description "This package provides a streaming parser for the statsd
protocol used in @code{node-lynx}.")
    (license license:asl2.0)))

(define-public node-string-decoder
  (package
    (name "node-string-decoder")
    (version "1.3.0")
    (source
     (origin
       (method git-fetch)
       (uri (git-reference
             (url "https://github.com/nodejs/string_decoder")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32
         "0xxvyya9fl9rlkqwmxzqzbz4rdr3jgw4vf37hff7cgscxkhg266k"))))
    (build-system node-build-system)
    (arguments
     '(#:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies
              '("tap" "core-util-is" "babel-polyfill")))))
       ;; FIXME: Tests depend on node-tap
       #:tests? #f))
    (inputs (list node-safe-buffer node-inherits))
    (home-page "https://github.com/nodejs/string_decoder")
    (synopsis "Decode buffers while preserving multi-byte sequences")
    (description "This package provides a user-land implementation of
Node-core's @code{string_decoder}, which serves to decode buffers to
strings so that the decoded string does not contain incomplete multibyte
sequences.")
    (license license:expat)))

(define-public node-util-deprecate
  (package
    (name "node-util-deprecate")
    (version "1.0.2")
    (source
      (origin
        (method git-fetch)
        (uri (git-reference
               (url "https://github.com/TooTallNate/util-deprecate")
               (commit version)))
        (file-name (git-file-name name version))
        (sha256
         (base32
          "1rk94nl3qc7znsk8400bnga30v0m7j2mmvz9ldwjinxv1d3n11xc"))))
    (build-system node-build-system)
    (arguments '(#:tests? #f)) ; No test suite.
    (home-page "https://github.com/TooTallNate/util-deprecate")
    (synopsis "Node.js `util.deprecate()` function with browser support")
    (description "This package provides the Node.js @code{util.deprecate()}
function with browser support.")
    (license license:expat)))

(define-public node-wrappy
  (package
    (name "node-wrappy")
    (version "1.0.2")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/npm/wrappy")
                    (commit (string-append "v" version))))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1ymlc61cja6v5438vwb04gq8wg2b784lj39zf0g4i36fvgcw9783"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f ; FIXME: Tests depend on node-tap
       #:phases
       (modify-phases %standard-phases
         (add-after 'patch-dependencies 'delete-dependencies
           (lambda args
             (delete-dependencies '("tap")))))))
    (home-page "https://github.com/npm/wrappy")
    (synopsis "Callback wrapping utility")
    (description "@code{wrappy} is a utility for Node.js to wrap callbacks.")
    (license license:isc)))

(define-public node-yazl
  (package
    (name "node-yazl")
    (version "2.5.1")
    (source (origin
              (method git-fetch)
              (uri (git-reference
                    (url "https://github.com/thejoshwolfe/yazl")
                    (commit version)))
              (file-name (git-file-name name version))
              (sha256
               (base32
                "1lhwqqnvazpi4xw81ldpx0ky0h1j5rcx3br480q2bnzj21cm109n"))))
    (build-system node-build-system)
    (arguments
     '(#:tests? #f
       #:phases (modify-phases %standard-phases
                  (add-after 'patch-dependencies 'delete-dependencies
                    (lambda _
                      (delete-dependencies '("airtap" "bl" "istanbul" "yauzl")))))))
    (inputs (list node-buffer-crc32))
    (home-page "https://github.com/thejoshwolfe/yazl")
    (synopsis "Yet another zip library for node")
    (description
     "This package provides a zip library for Node.  It follows the
following principles:
@enumerate
@item Don't block the JavaScript thread.  Use and provide async APIs.
@item Keep memory usage under control.  Don't attempt to buffer entire
files in RAM at once.
@item Prefer to open input files one at a time than all at once.
@end enumerate")
    (license license:expat)))

;;;
;;; Avoid adding new packages to the end of this file. To reduce the chances
;;; of a merge conflict, place them above in alphabetic order.
;;;
ommit (string-append "v" version)))) (sha256 (base32 "03kp3ms2sjz4gwb94xs404mi63fnv1bq00hyqxyvc9csmicxzawn")) (file-name (git-file-name name version)))) (build-system gnu-build-system) (arguments ;; NOTE: (Sharlatan-20210119T211511+0000) Tests are disabled due to being ;; dependent on Quicklisp, main build target is `pgloader-standalone' which ;; does not require Quicklisp workarounds. There is no `install' target ;; configured in Makefile. (list #:tests? #f #:strip-binaries? #f #:make-flags #~(list "pgloader-standalone" "BUILDAPP_SBCL=buildapp") #:phases #~(modify-phases %standard-phases (delete 'configure) (add-after 'unpack 'set-home (lambda _ (setenv "HOME" "/tmp"))) (add-after 'unpack 'patch-Makefile (lambda _ (substitute* "Makefile" (("--sbcl.*") "--sbcl $(CL) --asdf-path . \\\n")))) (replace 'install (lambda* (#:key outputs #:allow-other-keys) (let ((bin (string-append #$output "/bin"))) (mkdir-p bin) (install-file "build/bin/pgloader" bin))))))) (native-inputs (list buildapp sbcl)) (inputs (list sbcl-alexandria sbcl-cl-abnf sbcl-cl-base64 sbcl-cl-csv sbcl-cl-fad sbcl-cl-log sbcl-cl-markdown sbcl-cl-mustache sbcl-cl-ppcre sbcl-cl-sqlite sbcl-closer-mop sbcl-command-line-arguments sbcl-db3 sbcl-drakma sbcl-esrap sbcl-flexi-streams sbcl-ixf sbcl-local-time sbcl-lparallel sbcl-metabang-bind sbcl-mssql sbcl-postmodern sbcl-py-configparser sbcl-qmynd sbcl-quri sbcl-split-sequence sbcl-trivial-backtrace sbcl-usocket sbcl-uuid sbcl-yason sbcl-zs3)) (home-page "https://pgloader.io/") (synopsis "Tool to migrate data to PostgreSQL") (description "@code{pgloader} is a program that can load data or migrate databases from CSV, DB3, iXF, SQLite, MS-SQL or MySQL to PostgreSQL.") (license (license:x11-style "file://LICENSE")))) (define-public python-pymysql (package (name "python-pymysql") (version "1.1.1") (source (origin (method url-fetch) (uri (pypi-uri "pymysql" version)) (sha256 (base32 "1l2cj0ps96g3bblvhdszgyjv9bi405bxrx0bqq1p8h9bmwd629z1")))) (build-system pyproject-build-system) (native-inputs (list python-setuptools python-wheel)) (propagated-inputs (list python-cryptography python-pynacl)) (arguments `(#:tests? #f)) ; tests expect a running MySQL (home-page "https://github.com/PyMySQL/PyMySQL/") (synopsis "Pure-Python MySQL driver") (description "PyMySQL is a pure-Python MySQL client library, based on PEP 249. Most public APIs are compatible with @command{mysqlclient} and MySQLdb.") (license license:expat))) (define-public qdbm (package (name "qdbm") (version "1.8.78") (source (origin (method url-fetch) (uri (string-append "http://fallabs.com/" name "/" name "-" version ".tar.gz")) (sha256 (base32 "0gmpvhn02pkq280ffmn4da1g4mdr1xxz7l80b7y4n7km1mrzwrml")))) (build-system gnu-build-system) (arguments `(#:configure-flags (list (string-append "LDFLAGS=-Wl,-rpath=" (assoc-ref %outputs "out") "/lib")) #:make-flags (list "CFLAGS=-fPIC"))) (home-page "https://fallabs.com/qdbm/") (synopsis "Key-value database") (description "QDBM is a library of routines for managing a database. The database is a simple data file containing key-value pairs. Every key and value is serial bytes with variable length. Binary data as well as character strings can be used as a key or a value. There is no concept of data tables or data types. Records are organized in a hash table or B+ tree.") (license license:lgpl2.1+))) (define-public recutils (package (name "recutils") (version "1.9") (source (origin (method url-fetch) (uri (string-append "mirror://gnu/recutils/recutils-" version ".tar.gz")) (sha256 (base32 "03kf91f20brn2ffljfjzirxh5xj99m1mvvspcx2lph9000mmj0b3")))) (build-system gnu-build-system) (arguments (list #:configure-flags #~(list "--disable-static" (string-append "--with-bash-headers=" (search-input-directory %build-inputs "include/bash"))) #:phases #~(modify-phases %standard-phases (add-after 'install 'symlink-bash-loadables (lambda* (#:key outputs #:allow-other-keys) (with-directory-excursion (string-append (assoc-ref outputs "out") "/lib") (mkdir "bash") (for-each (compose symlink (lambda (loadable) (values (string-append (getcwd) "/" loadable ".so") (string-append "bash/" loadable)))) '("readrec" "testrec")))))))) (native-inputs (list bc check-0.14 pkg-config)) (inputs ;; TODO: Add more optional inputs. (list bash ; /bin/bash for native compilation `(,bash "include") curl libgcrypt `(,util-linux "lib"))) (synopsis "Manipulate plain text files as databases") (description "GNU Recutils is a set of tools and libraries for creating and manipulating text-based, human-editable databases. Despite being text-based, databases created with Recutils carry all of the expected features such as unique fields, primary keys, time stamps and more. Many different field types are supported, as is encryption.") (license license:gpl3+) (home-page "https://www.gnu.org/software/recutils/"))) (define-public emacs-rec-mode (package (name "emacs-rec-mode") (version "1.9.4") (source (origin (method url-fetch) (uri (string-append "https://elpa.gnu.org/packages/" "rec-mode-" version ".tar")) (sha256 (base32 "0pi483g5qgz6gvyi13a4ldfbkaad3xkad08aqfcnmsdylvc9zzma")) (snippet #~(begin (delete-file "rec-mode.info"))))) (build-system emacs-build-system) (arguments (list #:phases #~(modify-phases %standard-phases (add-after 'unpack 'patch-program-paths (lambda* (#:key inputs #:allow-other-keys) (emacs-substitute-variables "rec-mode.el" ("rec-recfix" (search-input-file inputs "bin/recfix")) ("rec-recinf" (search-input-file inputs "bin/recinf")) ("rec-recsel" (search-input-file inputs "bin/recsel"))))) (add-before 'install 'make-info (lambda _ (invoke "makeinfo" "--no-split" "-o" "rec-mode.info" "rec-mode.texi")))))) (inputs (list recutils)) (native-inputs (list texinfo)) (home-page "https://www.gnu.org/software/recutils/") (synopsis "Emacs mode for working with recutils database files") (description "This package provides an Emacs major mode @code{rec-mode} for working with GNU Recutils text-based, human-editable databases. It supports editing, navigation, and querying of recutils database files including field and record folding.") (license license:gpl3+))) (define-public emacs-recutils (deprecated-package "emacs-recutils" emacs-rec-mode)) (define-public rocksdb (package (name "rocksdb") (version "6.26.1") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/facebook/rocksdb") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0mylma106w93kxhj89g9y1ccdq7m9m94wrmv5nyr17yc1zsk87sg")) (modules '((guix build utils))) (snippet '(begin ;; TODO: unbundle gtest. (delete-file "build_tools/gnu_parallel") (substitute* "Makefile" (("build_tools/gnu_parallel") "parallel")))))) (build-system cmake-build-system) (arguments `(#:configure-flags (list "-DROCKSDB_BUILD_SHARED=1" ;; Ceph requires that RTTI is enabled. "-DUSE_RTTI=1" ;; Prevent the build from passing '-march=native' to the compiler. "-DPORTABLE=1") ;; Many tests fail on 32-bit platforms. There are multiple ;; reports about this upstream, but it's not going to be ;; supported any time soon. What's worse: Release builds don't ;; include tests, and overriding the build system to build ;; tests anyway fails with missing TEST_ symbols. #:tests? #false #:phases (modify-phases %standard-phases (add-after 'unpack 'patch-CMakeLists.txt (lambda _ (substitute* "CMakeLists.txt" ;; build reproducibly (("set\\(BUILD_DATE \"\\$\\{TS\\}\"") "set(BUILD_DATE \"1970-01-01\"")))) (add-after 'unpack 'build-generically (lambda _ (substitute* "CMakeLists.txt" (("if\\(HAVE_SSE42\\)") "if(FALSE)"))))))) (native-inputs (list parallel perl procps python which)) (inputs (list bzip2 gflags jemalloc lz4 snappy zlib)) (home-page "https://rocksdb.org/") (synopsis "Persistent key-value store for fast storage") (description "RocksDB is a library that forms the core building block for a fast key-value server, especially suited for storing data on flash drives. It has a @dfn{Log-Structured-Merge-Database} (LSM) design with flexible tradeoffs between @dfn{Write-Amplification-Factor} (WAF), @dfn{Read-Amplification-Factor} (RAF) and @dfn{Space-Amplification-Factor} (SAF). It has multi-threaded compactions, making it specially suitable for storing multiple terabytes of data in a single database. RocksDB is partially based on @code{LevelDB}.") ;; RocksDB is dual licensed under GPL2 and ASL 2.0. Some header ;; files carry the 3-clause BSD license. (license (list license:gpl2 license:asl2.0 license:bsd-3)))) (define-public sparql-query (package (name "sparql-query") (version "1.1") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/tialaramex/sparql-query") (commit version))) (sha256 (base32 "0a84a89idpjhj9w2y3fmvzv7ldps1cva1kxvfmh897k02kaniwxk")) (file-name (git-file-name name version)))) (build-system gnu-build-system) (inputs (list curl glib libxml2 ncurses readline)) (native-inputs (list pkg-config)) (arguments `(#:make-flags '("CC=gcc") #:phases (modify-phases %standard-phases (delete 'configure) ;; The Makefile uses git to obtain versioning information. This phase ;; substitutes the git invocation with the package version. (add-after 'unpack 'remove-git-dependency (lambda _ (substitute* "Makefile" (("^gitrev :=.*$") (string-append "gitrev = \"v" ,version "\""))) #t)) ;; The install phase of the Makefile assumes $PREFIX/usr/local/bin. ;; This replacement does the same thing, except for using $PREFIX/bin ;; instead. (replace 'install (lambda* (#:key outputs #:allow-other-keys) (let* ((out (assoc-ref outputs "out")) (bin (string-append out "/bin"))) (install-file "sparql-query" bin) (symlink (string-append bin "/sparql-query") (string-append bin "/sparql-update"))) #t)) (replace 'check (lambda* (#:key make-flags #:allow-other-keys) (apply invoke "make" `(,@make-flags "scan-test")) (invoke "./scan-test")))))) (home-page "https://github.com/tialaramex/sparql-query/") (synopsis "Command-line tool for accessing SPARQL endpoints over HTTP") (description "Sparql-query is a command-line tool for accessing SPARQL endpoints over HTTP. It has been intentionally designed to @code{feel} similar to tools for interrogating SQL databases. For example, you can enter a query over several lines, using a semi-colon at the end of a line to indicate the end of your query. It also supports readline so that you can more easily recall and edit previous queries, even across sessions. It can be used non-interactively, for example from a shell script.") ;; Some files (like scan-sparql.c) contain a GPLv3+ license header, while ;; others (like sparql-query.c) contain a GPLv2+ license header. (license (list license:gpl3+)))) (define-public sqitch (package (name "sqitch") (version "1.1.0") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/D/DW/DWHEELER/App-Sqitch-v" version ".tar.gz")) (sha256 (base32 "1ayiwg9kh3w0nbacbcln7h944z94vq5vnnd5diz86033bpbnq57f")))) (build-system perl-build-system) (arguments '(#:phases (modify-phases %standard-phases (add-before 'check 'set-check-environment (lambda _ (setenv "TZ" "UTC") (setenv "HOME" "/tmp"))) (add-after 'install 'wrap-program (lambda* (#:key outputs #:allow-other-keys) (let* ((out (assoc-ref outputs "out")) (path (getenv "PERL5LIB"))) (wrap-program (string-append out "/bin/sqitch") `("PERL5LIB" ":" prefix (,(string-append out "/lib/perl5/site_perl" ":" path)))))))))) (native-inputs (list perl-capture-tiny perl-io-pager perl-module-build perl-module-runtime perl-path-class perl-test-deep perl-test-dir perl-test-exception perl-test-file perl-test-file-contents perl-test-mockmodule perl-test-mockobject perl-test-nowarnings perl-test-warn)) (inputs (list bash-minimal perl-class-xsaccessor perl-clone perl-config-gitlike perl-datetime perl-datetime-timezone perl-dbd-mysql perl-dbd-pg perl-dbd-sqlite perl-dbi perl-devel-stacktrace perl-encode-locale perl-hash-merge perl-ipc-run3 perl-ipc-system-simple perl-libintl-perl perl-list-moreutils perl-moo perl-mysql-config perl-namespace-autoclean perl-path-class perl-perlio-utf8_strict perl-string-formatter perl-string-shellquote perl-sub-exporter perl-template-tiny perl-template-toolkit perl-throwable perl-try-tiny perl-type-tiny perl-type-tiny-xs perl-uri perl-uri-db)) (home-page "https://sqitch.org/") (synopsis "Database change management tool") (description "Sqitch is a standalone change management system for database schemas, which uses SQL to describe changes.") (license license:x11))) (define-public sqlcrush ;; Unfortunately, there is no proper upstream release and may never be. (let ((commit "502a583e97a84efdeb48e59f1bfe403daa9681ee") (revision "2")) (package (name "sqlcrush") (version (git-version "0.1.5" revision commit)) (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/coffeeandscripts/sqlcrush") (commit commit))) (file-name (git-file-name name version)) (sha256 (base32 "0x2q4m9ryw68kifalnm3x4bv9v2xrc2ffsiap8m9wnw6lf1h05la")))) (build-system python-build-system) (inputs (list python-psycopg2 python-pymysql python-sqlalchemy)) (home-page "https://github.com/coffeeandscripts/sqlcrush") (synopsis "Text console-based database viewer and editor") (description "SQLcrush lets you view and edit a database directly from the text console through an ncurses interface. You can explore each table's structure, browse and edit the contents, add and delete entries, all while tracking your changes.") (license license:gpl3+)))) ; no headers, see README.md (define-public tdb (package (name "tdb") (version "1.4.7") (source (origin (method url-fetch) (uri (string-append "https://www.samba.org/ftp/tdb/tdb-" version ".tar.gz")) (sha256 (base32 "03n2hz4sv003gpkyp57hk5kiw4xk9f2dkxq75kzk2gskxy6idyx4")))) (build-system gnu-build-system) (arguments '(#:phases (modify-phases %standard-phases (replace 'configure (lambda* (#:key outputs #:allow-other-keys) (let ((out (assoc-ref outputs "out"))) ;; The 'configure' script is a wrapper for Waf and ;; doesn't recognize things like '--enable-fast-install'. (invoke "./configure" (string-append "--prefix=" out)))))))) (native-inputs (list docbook-xsl libxcrypt libxslt python ;for the Waf build system which)) (home-page "https://tdb.samba.org/") (synopsis "Trivial database") (description "TDB is a Trivial Database. In concept, it is very much like GDBM, and BSD's DB except that it allows multiple simultaneous writers and uses locking internally to keep writers from trampling on each other. TDB is also extremely small.") (license license:lgpl3+))) (define-public perl-dbi (package (name "perl-dbi") (version "1.643") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/T/TI/TIMB/DBI-" version ".tar.gz")) (sha256 (base32 "1yinx39960y241vf2sknxj0dfz82a5m9gvklq5rw78k0nlyrjawa")))) (build-system perl-build-system) (synopsis "Database independent interface for Perl") (description "This package provides a database interface for Perl.") (home-page "https://metacpan.org/release/DBI") (license license:perl-license))) (define-public perl-dbix-class (package (name "perl-dbix-class") (version "0.082843") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/R/RI/RIBASUSHI/" "DBIx-Class-" version ".tar.gz")) (sha256 (base32 "0lgjw7z4y2inf3yyfph1ljdp4f5zdmy9vh56fj8w9n19rdp0n7il")))) (build-system perl-build-system) (native-inputs (list perl-dbd-sqlite perl-module-install perl-package-stash perl-test-deep perl-test-exception perl-test-warn)) (propagated-inputs (list perl-class-accessor-grouped perl-class-c3-componentised perl-class-inspector perl-config-any perl-context-preserve perl-data-dumper-concise perl-data-page perl-dbi perl-devel-globaldestruction perl-hash-merge perl-module-find perl-moo-2 perl-mro-compat perl-namespace-clean perl-path-class perl-scope-guard perl-sql-abstract-classic perl-sub-name perl-try-tiny)) (home-page "https://metacpan.org/release/DBIx-Class") (synopsis "Extensible and flexible object <-> relational mapper") (description "An SQL to OO mapper with an object API inspired by Class::DBI (with a compatibility layer as a springboard for porting) and a resultset API that allows abstract encapsulation of database operations. It aims to make representing queries in your code as perl-ish as possible while still providing access to as many of the capabilities of the database as possible, including retrieving related records from multiple tables in a single query, \"JOIN\", \"LEFT JOIN\", \"COUNT\", \"DISTINCT\", \"GROUP BY\", \"ORDER BY\" and \"HAVING\" support.") (properties ;; This is needed for perl-catalyst-authentication-store-dbix-class `((updater-extra-propagated-inputs . ("perl-data-page")))) (license license:perl-license))) (define-public perl-dbix-class-cursor-cached (package (name "perl-dbix-class-cursor-cached") (version "1.001004") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/A/AR/ARCANEZ/" "DBIx-Class-Cursor-Cached-" version ".tar.gz")) (sha256 (base32 "09b2jahn2x12qm4f7qm1jzsxbz7qn1czp6a3fnl5l2i3l4r5421p")))) (build-system perl-build-system) (native-inputs (list perl-cache-cache perl-dbd-sqlite perl-module-install)) (propagated-inputs (list perl-carp-clan perl-dbix-class)) (home-page "https://metacpan.org/release/DBIx-Class-Cursor-Cached") (synopsis "Cursor with built-in caching support") (description "DBIx::Class::Cursor::Cached provides a cursor class with built-in caching support.") (license license:perl-license))) (define-public perl-dbix-class-introspectablem2m (package (name "perl-dbix-class-introspectablem2m") (version "0.001002") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/I/IL/ILMARI/" "DBIx-Class-IntrospectableM2M-" version ".tar.gz")) (sha256 (base32 "1w47rh2241iy5x3a9bqsyd5kdp9sk43dksr99frzv4qn4jsazfn6")))) (build-system perl-build-system) (native-inputs (list perl-module-install)) (propagated-inputs (list perl-dbix-class)) (home-page "https://metacpan.org/release/DBIx-Class-IntrospectableM2M") (synopsis "Introspect many-to-many relationships") (description "Because the many-to-many relationships are not real relationships, they can not be introspected with DBIx::Class. Many-to-many relationships are actually just a collection of convenience methods installed to bridge two relationships. This DBIx::Class component can be used to store all relevant information about these non-relationships so they can later be introspected and examined.") (license license:perl-license))) (define-public perl-dbix-class-schema-loader (package (name "perl-dbix-class-schema-loader") (version "0.07049") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/I/IL/ILMARI/" "DBIx-Class-Schema-Loader-" version ".tar.gz")) (sha256 (base32 "0r57fv71ypxafb85cpxph1hdqii7ipjwvc19yb6fpkvq2ggcssg8")))) (build-system perl-build-system) (native-inputs (list perl-config-any perl-config-general perl-dbd-sqlite perl-dbix-class-introspectablem2m perl-module-install perl-moose perl-moosex-markasmethods perl-moosex-nonmoose perl-namespace-autoclean perl-test-deep perl-test-differences perl-test-exception perl-test-pod perl-test-warn)) (propagated-inputs (list perl-class-unload perl-class-inspector perl-class-accessor-grouped perl-class-c3-componentised perl-carp-clan perl-data-dump perl-dbix-class perl-hash-merge perl-list-moreutils perl-lingua-en-inflect-phrase perl-lingua-en-inflect-number perl-lingua-en-tagger perl-namespace-clean perl-mro-compat perl-scope-guard perl-string-camelcase perl-string-toidentifier-en perl-sub-name perl-try-tiny)) (arguments `(#:tests? #f)) ;TODO: t/20invocations.t fails (home-page "https://metacpan.org/release/DBIx-Class-Schema-Loader") (synopsis "Create a DBIx::Class::Schema based on a database") (description "DBIx::Class::Schema::Loader automates the definition of a DBIx::Class::Schema by scanning database table definitions and setting up the columns, primary keys, unique constraints and relationships.") (license license:perl-license))) (define-public perl-dbix-class-deploymenthandler (package (name "perl-dbix-class-deploymenthandler") (version "0.002233") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/M/MM/MMCCLIMON/DBIx-Class-DeploymentHandler-" version ".tar.gz")) (sha256 (base32 "1bikp1q3pm1xphfdr8kmsqvzzpk06an3112mhb6gl8vlpg81ch4m")))) (build-system perl-build-system) (native-inputs (list perl-aliased perl-dbd-sqlite perl-dbix-class-schema-loader perl-test-fatal perl-test-most perl-test-requires)) (propagated-inputs (list perl-carp-clan perl-context-preserve perl-dbix-class perl-log-contextual perl-module-runtime perl-moose perl-moosex-role-parameterized perl-namespace-autoclean perl-path-class perl-sql-splitstatement perl-sql-translator perl-sub-exporter-progressive perl-sub-quote perl-text-brew perl-try-tiny perl-yaml)) (home-page "https://metacpan.org/release/DBIx-Class-DeploymentHandler") (synopsis "Extensible DBIx::Class deployment") (description "@code{DBIx::Class::DeploymentHandler} is a tool for deploying and upgrading databases with @code{DBIx::Class}. It is designed to be much more flexible than @code{DBIx::Class::Schema::Versioned}, hence the use of Moose and lots of roles.") (license license:perl-license))) (define-public perl-dbix-simple (package (name "perl-dbix-simple") (version "1.37") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/J/JU/JUERD/DBIx-Simple-" version ".tar.gz")) (sha256 (base32 "1qyaj01zb6xplzcp7pj0b9609fvd89c9c4an3i00g2g05jm13ls6")))) (build-system perl-build-system) (propagated-inputs (list perl-dbi)) (home-page "https://metacpan.org/release/DBIx-Simple") (synopsis "Object-oriented interface to DBI") (description "DBIx::Simple provides a simplified interface to DBI, Perl's powerful database module. This module is aimed at rapid development and easy maintenance. Query preparation and execution are combined in a single method, the result object (which is a wrapper around the statement handle) provides easy row-by-row and slurping methods.") ;; The POD info says: "Pick your favorite OSI-approved license" ;; Use unlicense because it has the least restrictions. (license license:unlicense))) (define-public perl-dbicx-testdatabase (package (name "perl-dbicx-testdatabase") (version "0.05") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/J/JR/JROCKWAY/DBICx-TestDatabase-" version ".tar.gz")) (sha256 (base32 "1kqaiygxiarrqkgqbq1s3xilx77msbdsqrdaqf4628811d9w4fwf")))) (build-system perl-build-system) (native-inputs (list perl-dbix-class perl-module-install)) (propagated-inputs (list perl-dbd-sqlite perl-sql-translator)) (home-page "https://metacpan.org/release/DBICx-TestDatabase") (synopsis "Create a temporary database from a DBIx::Class::Schema") (description "This module creates a temporary SQLite database, deploys a DBIC schema, and then connects to it. This lets you easily test DBIC schema. Since you have a fresh database for every test, you don't have to worry about cleaning up after your tests, ordering of tests affecting failure, etc.") (license license:perl-license))) (define-public perl-dbix-class-dynamicdefault (package (name "perl-dbix-class-dynamicdefault") (version "0.04") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/M/MS/MSTROUT/DBIx-Class-DynamicDefault-" version ".tar.gz")) (sha256 (base32 "1yssda00988hn9v96jl95apbzib74vgbcgf69m5mhhj64amm33r2")))) (build-system perl-build-system) (native-inputs (list perl-dbicx-testdatabase perl-module-install)) (propagated-inputs (list perl-dbix-class)) (home-page "https://metacpan.org/release/DBIx-Class-DynamicDefault") (synopsis "Automatically set and update fields") (description "Automatically set and update fields with values calculated at runtime. Ipdate or create actions will set the specified columns to the value returned by the callback you specified as a method name or code reference.") (license license:perl-license))) (define-public perl-dbix-class-timestamp (package (name "perl-dbix-class-timestamp") (version "0.14") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/R/RI/RIBASUSHI/DBIx-Class-TimeStamp-" version ".tar.gz")) (sha256 (base32 "1zhr4r5ffihqsh2imap7zmps2y0h71piqqhg2nqhcwkjhvlxb958")))) (build-system perl-build-system) (native-inputs (list perl-class-accessor-grouped perl-datetime-format-mysql perl-datetime-format-sqlite perl-dbd-sqlite perl-module-install perl-test-pod perl-time-warp)) (propagated-inputs (list perl-datetime perl-dbix-class perl-dbix-class-dynamicdefault)) (home-page "https://metacpan.org/release/DBIx-Class-TimeStamp") (synopsis "DBIx::Class extension to update and create date and time based fields") (description "This package works in conjunction with @code{InflateColumn::DateTime} to automatically set update and create date and time based fields in a table.") (license license:perl-license))) (define-public perl-dbd-pg (package (name "perl-dbd-pg") (version "3.15.1") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/T/TU/TURNSTEP/" "DBD-Pg-" version ".tar.gz")) (sha256 (base32 "0zn17xb6bmixkmv53p576igzw1jd43cwql35r19m56jwahxm9iqk")))) (build-system perl-build-system) (native-inputs (list perl-dbi)) (propagated-inputs (list perl-dbi postgresql)) (home-page "https://metacpan.org/release/DBD-Pg") (synopsis "DBI PostgreSQL interface") (description "This package provides a PostgreSQL driver for the Perl5 @dfn{Database Interface} (DBI).") (license license:perl-license))) (define-public perl-dbd-mysql (package (name "perl-dbd-mysql") (version "4.050") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/D/DV/DVEEDEN/" "DBD-mysql-" version ".tar.gz")) (sha256 (base32 "0y4djb048i09dk19av7mzfb3khr72vw11p3ayw2p82jsy4gm8j2g")))) (build-system perl-build-system) (arguments `(#:phases (modify-phases %standard-phases (add-before 'configure 'skip-library-detection ;; Avoid depencies on perl-devel-checklib, openssl, and zlib. They ;; are really only needed for the test suite; their absence does not ;; affect the build or the end result. (lambda _ (substitute* "Makefile.PL" (("use Devel::CheckLib;" match) (string-append "# " match)) (("assert_lib") "print")) #t))) ;; Tests require running MySQL server. #:tests? #f)) (propagated-inputs `(("perl-dbi" ,perl-dbi) ("mysql" ,mariadb "lib") ("mysql-dev" ,mariadb "dev"))) (home-page "https://metacpan.org/release/DBD-mysql") (synopsis "DBI MySQL interface") (description "This package provides a MySQL driver for the Perl5 @dfn{Database Interface} (DBI).") (license license:perl-license))) (define-public perl-dbd-sqlite (package (name "perl-dbd-sqlite") (version "1.66") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/I/IS/ISHIGAKI/DBD-SQLite-" version ".tar.gz")) (sha256 (base32 "1zljln5nh61gj3k22a1fv2vhx5l83waizmarwkh77hk6kzzmvrw9")))) (build-system perl-build-system) (inputs (list sqlite)) (propagated-inputs (list perl-dbi)) (synopsis "SQlite interface for Perl") (description "DBD::SQLite is a Perl DBI driver for SQLite, that includes the entire thing in the distribution. So in order to get a fast transaction capable RDBMS working for your Perl project you simply have to install this module, and nothing else.") (license license:perl-license) (home-page "https://metacpan.org/release/DBD-SQLite"))) (define-public perl-mysql-config (package (name "perl-mysql-config") (version "1.04") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/D/DA/DARREN/MySQL-Config-" version ".tar.gz")) (sha256 (base32 "1svn7ccw2gc4cazvc58j84rxhnc9vs01zpird0l8460598j475qr")))) (build-system perl-build-system) (home-page "https://metacpan.org/release/MySQL-Config") (synopsis "Parse and utilize MySQL's /etc/my.cnf and ~/.my.cnf files") (description "@code{MySQL::Config} emulates the @code{load_defaults} function from libmysqlclient. It will fill an array with long options, ready to be parsed by @code{Getopt::Long}.") (license license:perl-license))) (define-public perl-sql-abstract (package (name "perl-sql-abstract") (version "1.87") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/I/IL/ILMARI/" "SQL-Abstract-" version ".tar.gz")) (sha256 (base32 "0jhw91b23wc9bkfwcgvka4x5ddxk58m9bcp5ay7a3vx77nla09p9")))) (build-system perl-build-system) (native-inputs (list perl-module-install perl-test-deep perl-test-exception perl-test-warn)) (propagated-inputs (list perl-hash-merge perl-moo perl-mro-compat perl-text-balanced)) (home-page "https://metacpan.org/release/SQL-Abstract") (synopsis "Generate SQL from Perl data structures") (description "This module was inspired by the excellent DBIx::Abstract. While based on the concepts used by DBIx::Abstract, the concepts used have been modified to make the SQL easier to generate from Perl data structures. The underlying idea is for this module to do what you mean, based on the data structures you provide it, so that you don't have to modify your code every time your data changes.") (license license:perl-license))) (define-public perl-sql-abstract-classic (package (name "perl-sql-abstract-classic") (version "1.91") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/R/RI/RIBASUSHI/" "SQL-Abstract-Classic-" version ".tar.gz")) (sha256 (base32 "0a7g13hs3kdxrjn43sfli09mgsi9d6w0dfw6hlk268av17yisgaf")))) (build-system perl-build-system) (native-inputs (list perl-test-deep perl-test-exception perl-test-warn)) (propagated-inputs (list perl-mro-compat perl-sql-abstract)) (home-page "https://metacpan.org/release/SQL-Abstract-Classic") (synopsis "Generate SQL from Perl data structures") (description "This module is nearly identical to @code{SQL::Abstract} 1.81, and exists to preserve the ability of users to opt into the new way of doing things in later versions according to their own schedules. It is an abstract SQL generation module based on the concepts used by @code{DBIx::Abstract}, with several important differences, especially when it comes to @code{WHERE} clauses. These concepts were modified to make the SQL easier to generate from Perl data structures. The underlying idea is for this module to do what you mean, based on the data structures you provide it. You shouldn't have to modify your code every time your data changes, as this module figures it out.") (license license:perl-license))) (define-public perl-sql-splitstatement (package (name "perl-sql-splitstatement") (version "1.00023") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/V/VE/VEESH/" "SQL-SplitStatement-" version ".tar.gz")) (sha256 (base32 "0ppkx46nydzlnsxf9a8pkyb74wggfrdiiwafab143lrarlh88x0s")))) (build-system perl-build-system) (native-inputs (list perl-test-differences perl-test-exception perl-test-script)) (propagated-inputs (list perl-class-accessor perl-list-moreutils perl-regexp-common perl-sql-tokenizer)) (home-page "https://metacpan.org/release/SQL-SplitStatement") (synopsis "Split SQL code into atomic statements") (description "This module tries to split any SQL code, even including non-standard extensions, into the atomic statements it is composed of.") (license license:perl-license))) (define-public perl-sql-tokenizer (package (name "perl-sql-tokenizer") (version "0.24") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/I/IZ/IZUT/" "SQL-Tokenizer-" version ".tar.gz")) (sha256 (base32 "1qa2dfbzdlr5qqdam9yn78z5w3al5r8577x06qan8wv58ay6ka7s")))) (build-system perl-build-system) (home-page "https://metacpan.org/release/SQL-Tokenizer") (synopsis "SQL tokenizer") (description "SQL::Tokenizer is a tokenizer for SQL queries. It does not claim to be a parser or query verifier. It just creates sane tokens from a valid SQL query.") (license license:perl-license))) (define-public perl-sql-translator (package (name "perl-sql-translator") (version "1.63") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/V/VE/VEESH/SQL-Translator-" version ".tar.gz")) (sha256 (base32 "0cric118ms3dcnb3m2a1jdhdxmai8wwp5jbx34mf72s9jd6b11aq")))) (build-system perl-build-system) (native-inputs (list perl-file-sharedir-install perl-json-maybexs perl-test-differences perl-test-exception perl-test-most perl-xml-writer perl-yaml)) (propagated-inputs (list perl-carp-clan perl-dbi perl-file-sharedir perl-gd perl-graph perl-graphviz perl-moo perl-package-variant perl-parse-recdescent perl-spreadsheet-parseexcel perl-strictures-2 perl-sub-quote perl-template-toolkit perl-text-recordparser perl-try-tiny perl-xml-libxml)) (home-page "https://metacpan.org/release/SQL-Translator") (synopsis "Manipulate structured data definitions (SQL and more)") (description "@code{SQL::Translator} is a group of Perl modules that converts vendor-specific SQL table definitions into other formats, such as other vendor-specific SQL, ER diagrams, documentation (POD and HTML), XML, and @code{Class::DBI} classes. The main focus is SQL, but parsers exist for other structured data formats, including Excel spreadsheets and arbitrarily delimited text files. Through the separation of the code into parsers and producers with an object model in between, it's possible to combine any parser with any producer, to plug in custom parsers or producers, or to manipulate the parsed data via the built-in object model. Presently only the definition parts of SQL are handled (CREATE, ALTER), not the manipulation of data (INSERT, UPDATE, DELETE).") (license license:perl-license))) (define-public perl-test-postgresql (package (name "perl-test-postgresql") (version "1.29") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/T/TJ/TJC/Test-PostgreSQL-" version ".tar.gz")) (sha256 (base32 "17jgiqdyprb8q4855anica2kr0lxdi9rnq27vsfclk6ai7jzgb0q")))) (build-system perl-build-system) (arguments (list #:tests? #f)) ;2/41 fail, require running Postgres server (native-inputs (list perl-module-build-tiny perl-test-sharedfork)) (propagated-inputs (list perl-dbd-pg perl-dbi perl-file-which perl-function-parameters perl-moo perl-tie-hash-method perl-try-tiny perl-type-tiny)) (home-page "https://metacpan.org/release/Test-PostgreSQL") (synopsis "PostgreSQL runner for tests") (description "@code{Test::PostgreSQL} automatically setups a PostgreSQL instance in a temporary directory, and destroys it when the perl script exits.") (license license:artistic2.0))) (define-public unixodbc (package (name "unixodbc") (version "2.3.9") (source (origin (method url-fetch) (uri (string-append "ftp://ftp.unixodbc.org/pub/unixODBC/unixODBC-" version ".tar.gz")) (sha256 (base32 "01xj65d02i3yjy7p9z08y9jakcs5szmz4rask868n7387nn3x0sj")))) (build-system gnu-build-system) (synopsis "Data source abstraction library") (description "Unixodbc is a library providing an API with which to access data sources. Data sources include SQL Servers and any software with an ODBC Driver.") (license license:lgpl2.1+) ;; COPYING contains copy of lgpl2.1 - but copyright notices just say "LGPL" (home-page "https://www.unixodbc.org"))) (define-public nanodbc (package (name "nanodbc") (version "2.14.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/nanodbc/nanodbc") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "1253bnrmchga3ra99jqkd2p29bc5h2ip79xd8afblz6b1v00wmbm")))) (build-system cmake-build-system) (arguments `(#:configure-flags ;; The tests require ODBC backends to be installed. (list "-DNANODBC_DISABLE_TESTS=ON" "-DBUILD_SHARED_LIBS=ON") #:tests? #false)) (inputs (list unixodbc)) (home-page "https://nanodbc.io/") (synopsis "C++ wrapper for the native C ODBC API") (description "The goal for nanodbc is to make developers happy by providing a simpler and less verbose API for working with ODBC. Common tasks should be easy, requiring concise and simple code.") (license license:expat))) (define-public nanodbc-for-irods (package (inherit nanodbc) (arguments `(#:tests? #false #:configure-flags '("-DBUILD_SHARED_LIBS=ON" ;; The tests require ODBC backends to be installed. "-DNANODBC_DISABLE_TESTS=ON" "-DCMAKE_CXX_COMPILER=clang++" "-DCMAKE_CXX_FLAGS=-stdlib=libc++" "-DCMAKE_EXE_LINKER_FLAGS=-lc++abi") #:phases (modify-phases %standard-phases (add-after 'set-paths 'adjust-CPLUS_INCLUDE_PATH (lambda* (#:key inputs #:allow-other-keys) (let ((gcc (assoc-ref inputs "gcc"))) (setenv "CPLUS_INCLUDE_PATH" (string-join (cons (string-append (assoc-ref inputs "libcxx") "/include/c++/v1") ;; Hide GCC's C++ headers so that they do not interfere with ;; the Clang headers. (delete (string-append gcc "/include/c++") (string-split (getenv "CPLUS_INCLUDE_PATH") #\:))) ":")) (format #true "environment variable `CPLUS_INCLUDE_PATH' changed to ~a~%" (getenv "CPLUS_INCLUDE_PATH")))))))) (properties `((hidden? . #true))) (inputs `(("unixodbc" ,unixodbc) ("libcxx" ,libcxx+libcxxabi-6) ("libcxxabi" ,libcxxabi-6) ("clang" ,clang-6))))) (define-public unqlite (package (name "unqlite") (version "1.1.6") (source (origin (method url-fetch) ;; Contains bug fixes against the official release, and has an ;; autotooled build system. (uri (string-append "https://github.com/aidin36/tocc/releases/" "download/v1.0.0/" "unqlite-unofficial-" version ".tar.gz")) (sha256 (base32 "1sbpvhg15gadq0mpcy16q7k3rkg4b4dicpnn5xifpkpn02sqik3s")))) (build-system gnu-build-system) (arguments `(#:tests? #f)) ;No check target (home-page "https://www.unqlite.org") (synopsis "In-memory key/value and document store") (description "UnQLite is an in-process software library which implements a self-contained, serverless, zero-configuration, transactional NoSQL database engine. UnQLite is a document store database similar to Redis, CouchDB, etc., as well as a standard key/value store similar to BerkeleyDB, LevelDB, etc.") (license license:bsd-2))) ;; NOTE: When upgrading redis, make sure that redis is still released ;; under a Free Software license. (define-public redis (package (name "redis") (version "7.2.6") (source (origin (method url-fetch) (uri (string-append "https://download.redis.io/releases/redis-" version".tar.gz")) (sha256 (base32 "03ixkzdc43lr4q3my0yax1f1gqz6sr6hch5qdipmbd725xxdc47v")) (modules '((guix build utils))) (snippet ;; Delete bundled jemalloc, as the package will use the libc one '(begin (delete-file-recursively "deps/jemalloc"))))) (build-system gnu-build-system) (arguments (list #:make-flags #~(list (string-append "CC=" #$(cc-for-target)) "MALLOC=libc" "LDFLAGS=-ldl" (string-append "PREFIX=" #$output)) #:phases #~(modify-phases %standard-phases (delete 'configure) (add-after 'unpack 'patch-paths (lambda _ (substitute* "runtest" (("^TCLSH=.*") (string-append "TCLSH=" (which "tclsh")))) (substitute* "tests/support/server.tcl" (("/usr/bin/env") (which "env"))))) (add-after 'unpack 'adjust-tests (lambda _ ;; Disable failing tests. (substitute* "tests/test_helper.tcl" ;; The AOF tests cause the test suite to hang waiting for a ;; "background AOF rewrite to finish", perhaps because dead ;; processes persist as zombies in the build environment. (("unit/aofrw") "") (("integration/aof([^-]|-multi-part)") "") ;; The OOM score tests try to raise the current OOM score, but ;; our build environment already sets it for all children to ;; the highest possible one (1000). We can't lower it because ;; we don't have CAP_SYS_RESOURCE. (("unit/oom-score-adj") "") (("integration/failover") "") (("integration/replication[^-]") ""))))))) (native-inputs (list pkg-config procps tcl which)) (synopsis "Key-value cache and store") (description "Redis is an advanced key-value cache and store. Redis supports many data structures including strings, hashes, lists, sets, sorted sets, bitmaps and hyperloglogs.") (home-page "https://redis.io/") ;; These two CVEs have long been fixed. (properties `((lint-hidden-cve . ("CVE-2022-3647" "CVE-2022-33105")))) (license license:bsd-3))) (define-public hiredis (package (name "hiredis") (version "1.1.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/redis/hiredis") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "1zld30j3kpzqr9w3vkpd6mm3f1b1yk3dlgp9lp6gpsybjjfr2i6h")))) (build-system cmake-build-system) (native-inputs ;; needed for testing (list redis)) (synopsis "Minimalistic C client library for the Redis database") (description "This package provides a library for sending commands and receiving replies to and from a Redis server. It comes with a synchronous API, asynchronous API and reply parsing API. Only the binary-safe Redis protocol is supported.") (home-page "https://github.com/redis/hiredis") (license license:bsd-3))) (define-public ruby-hiredis (package (name "ruby-hiredis") (version "0.6.3") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/redis/hiredis-rb") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "05y4g7frhym59m9x208zpvg2qvqvfjlgqmygxj8sqgl07n0ww1ks")) (patches (search-patches "ruby-hiredis-use-system-hiredis.patch")))) (build-system ruby-build-system) (arguments (list #:tests? #f ;require native extension #:phases #~(modify-phases %standard-phases (add-after 'unpack 'patch-hiredis-include-directory (lambda* (#:key inputs #:allow-other-keys) (substitute* "ext/hiredis_ext/extconf.rb" ;; Adjust the hiredis include directory. (("\\$CFLAGS << \" -I/usr/include/hiredis\"") (format #f "$CFLAGS << \" -I~a\"" (search-input-directory inputs "include/hiredis")))))) (add-after 'unpack 'disable-building-c-extension (lambda _ ;; FIXME: The produced native extension appears to segfault when ;; run; disable building it until a solution is found (see: ;; https://github.com/redis/hiredis-rb/issues/93). (substitute* "ext/hiredis_ext/extconf.rb" (("build_hiredis = true") "build_hiredis = false")))) ;; FIXME: Un-comment phase after the extension can be made to run ;; without crashing (see above). ;; (add-after 'build 'build-ext ;; (lambda _ ;; (setenv "CC" #$(cc-for-target)) ;; (invoke "rake" "compile"))) (add-before 'check 'start-redis (lambda _ (invoke "redis-server" "--daemonize" "yes"))) (add-after 'install 'delete-mkmf.log (lambda _ ;; This build log captures non-deterministic file names (see: ;; https://github.com/rubygems/rubygems/issues/6259). (for-each delete-file (find-files #$output "^mkmf\\.log$"))))))) (native-inputs (list redis ruby-rake-compiler)) (inputs (list hiredis)) (synopsis "Ruby wrapper for hiredis") (description "@code{hiredis-rb} is a Ruby extension that wraps @code{hiredis}, a minimalist C client for Redis. Both the synchronous connection API and a separate protocol reader are supported. It is primarily intended to speed up parsing multi bulk replies.") (home-page "https://github.com/redis/hiredis-rb") (license license:bsd-3))) (define-public ruby-redis (package (name "ruby-redis") (version "4.2.5") (source (origin (method url-fetch) (uri (rubygems-uri "redis" version)) (sha256 (base32 "15x2sr6h094rjbvg8pkq6m3lcd5abpyx93aifvfdz3wv6x55xa48")))) (build-system ruby-build-system) (arguments `(#:tests? #f)) ; Tests require a running redis server. (synopsis "Ruby client for Redis' API") (description "This package provides a Ruby client that tries to match Redis' API one-to-one, while still providing an idiomatic interface.") (home-page "https://github.com/redis/redis-rb") (license license:expat))) (define-public go-github-com-cupcake-rdb (package (name "go-github-com-cupcake-rdb") (version "0.0.0-20161107195141-43ba34106c76") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/tent/rdb") (commit (go-version->git-ref version)))) (file-name (git-file-name name version)) (sha256 (base32 "1l4bsn5yj8r875crz1rsk6dlvhv0bd8mgazsch5vl4c19v0fs2ib")))) (build-system go-build-system) (arguments '(#:import-path "github.com/cupcake/rdb")) (native-inputs (list go-gopkg-in-check-v1)) (home-page "https://github.com/tent/rdb") (synopsis "Redis RDB parser for Go") (description "Package rdb implements parsing and encoding of the Redis RDB file format.") (license license:expat))) (define-public go-github-com-gomodule-redigo (package (name "go-github-com-gomodule-redigo") (version "1.8.8") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/gomodule/redigo") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0wplaaxg7f6c6c08gdp33l48hygn8gq1rhlnjzr1c9qcggsm07k1")))) (build-system go-build-system) (arguments '(#:unpack-path "github.com/gomodule/redigo" #:import-path "github.com/gomodule/redigo/redis")) (native-inputs (list go-github-com-stretchr-testify redis)) (home-page "https://github.com/gomodule/redigo") (synopsis "Go client for Redis") (description "Redigo is a Go client for the Redis database.") (license license:asl2.0))) (define-public kyotocabinet (package (name "kyotocabinet") (version "1.2.79") (source (origin (method url-fetch) (uri (string-append "https://fallabs.com/kyotocabinet/pkg/" "kyotocabinet-" version ".tar.gz")) (sha256 (base32 "079ymsahlrijswgwfr2la9yw5h57l752cprhp5dz31iamsj1vyv7")))) (build-system gnu-build-system) (arguments `(#:configure-flags (list "--disable-opt" ;"-march=native". XXX this also turns off -O0. (string-append "LDFLAGS=-Wl,-rpath=" (assoc-ref %outputs "out") "/lib")))) (inputs (list zlib)) (home-page "https://fallabs.com/kyotocabinet/") (synopsis "Kyoto Cabinet is a modern implementation of the DBM database") (description "Kyoto Cabinet is a standalone file-based database that supports Hash and B+ Tree data storage models. It is a fast key-value lightweight database and supports many programming languages. It is a NoSQL database.") (license license:gpl3+))) (define-public tokyocabinet (package (name "tokyocabinet") (version "1.4.48") (source (origin (method url-fetch) (uri (string-append "http://fallabs.com/tokyocabinet/" name "-" version ".tar.gz")) (sha256 (base32 "140zvr0n8kvsl0fbn2qn3f2kh3yynfwnizn4dgbj47m975yg80x0")))) (build-system gnu-build-system) (arguments `(#:configure-flags (list "--enable-pthread" "--enable-off64" ,@(if (target-x86?) ;; Enables x86 specific cflags. '("--enable-fastest") '()) (string-append "LDFLAGS=-Wl,-rpath=" (assoc-ref %outputs "out") "/lib")))) (inputs (list zlib)) (home-page "http://fallabs.com/tokyocabinet/") (synopsis "Tokyo Cabinet is a modern implementation of the DBM database") (description "Tokyo Cabinet is a library of routines for managing a database. The database is a simple data file containing records, each is a pair of a key and a value. Every key and value is serial bytes with variable length. Both binary data and character string can be used as a key and a value. There is neither concept of data tables nor data types. Records are organized in hash table, B+ tree, or fixed-length array.") (license license:lgpl2.1+))) (define-public wiredtiger (package (name "wiredtiger") (version "2.9.1") (source (origin (method url-fetch) (uri (string-append "http://source.wiredtiger.com/releases/wiredtiger-" version ".tar.bz2")) (sha256 (base32 "0krwnb2zfbhvjaskwl875qzd3y626s84zcciq2mxr5c5riw3yh6s")))) (build-system gnu-build-system) (arguments '(#:configure-flags '("--enable-lz4" "--with-builtins=snappy,zlib") #:phases (modify-phases %standard-phases (add-before 'check 'disable-test/fops (lambda _ ;; XXX: timed out after 3600 seconds of silence (substitute* "Makefile" (("test/fops") "")) #t))))) (inputs (list lz4 zlib snappy)) (home-page "https://source.wiredtiger.com/") (synopsis "NoSQL data engine") (description "WiredTiger is an extensible platform for data management. It supports row-oriented storage (where all columns of a row are stored together), column-oriented storage (where columns are stored in groups, allowing for more efficient access and storage of column subsets) and log-structured merge trees (LSM), for sustained throughput under random insert workloads.") (license license:gpl3) ; or GPL-2 ;; configure.ac: WiredTiger requires a 64-bit build. (supported-systems (delete "riscv64-linux" %64bit-supported-systems)))) (define-public wiredtiger-3 (package (inherit wiredtiger) (name "wiredtiger") (version "3.1.0") (source (origin (method url-fetch) (uri (string-append "http://source.wiredtiger.com/releases/wiredtiger-" version ".tar.bz2")) (sha256 (base32 "014awypv579ascg4jbx4pndj2wld337m79yyzrzyr7hxrff139jx")))))) (define-public guile-wiredtiger (package (name "guile-wiredtiger") (version "0.7.0") (source (origin (method git-fetch) (uri (git-reference (url "https://framagit.org/a-guile-mind/guile-wiredtiger.git") (commit "340ad4bc2ff4dcc6216a2f5c6f9172ca320ac66b"))) (file-name (string-append name "-" version "-checkout")) (sha256 (base32 "15j36bvxxzil7qpwlmh1rffqpva3ynvrcpqhhqbj2c9208ayz595")))) (build-system gnu-build-system) (arguments '(#:parallel-tests? #f ;; tests can't be run in parallel, yet. #:configure-flags (list (string-append "--with-libwiredtiger-prefix=" (assoc-ref %build-inputs "wiredtiger"))) #:make-flags '("GUILE_AUTO_COMPILE=0"))) (native-inputs (list autoconf automake pkg-config)) (inputs (list wiredtiger-3 guile-2.2)) (propagated-inputs (list guile2.2-bytestructures)) (synopsis "WiredTiger bindings for GNU Guile") (description "This package provides Guile bindings to the WiredTiger ``NoSQL'' database.") (home-page "https://framagit.org/a-guile-mind/guile-wiredtiger") (license license:gpl3+))) (define-public perl-db-file (package (name "perl-db-file") (version "1.858") (source (origin (method url-fetch) (uri (string-append "mirror://cpan/authors/id/P/PM/PMQS/DB_File-" version ".tar.gz")) (sha256 (base32 "1xm7s2ag15498kp7g8r20gxk22ncz3b3hz4b3srqf7ypif3a5dyf")))) (build-system perl-build-system) (arguments (list #:phases #~(modify-phases %standard-phases (add-before 'configure 'modify-config.in (lambda _ (substitute* "config.in" (("/usr/local/BerkeleyDB") #$(this-package-input "bdb")))))))) (inputs (list bdb)) (native-inputs (list perl-test-pod)) (home-page "https://metacpan.org/release/DB_File") (synopsis "Perl5 access to Berkeley DB version 1.x") (description "The DB::File module provides Perl bindings to the Berkeley DB version 1.x.") (license license:perl-license))) (define-public lmdb (package (name "lmdb") (version "0.9.29") (source (origin (method git-fetch) (uri (git-reference (url "https://git.openldap.org/openldap/openldap.git") (commit (string-append "LMDB_" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0airps4cd0d91nbgy7hgvifa801snxwxzwxyr6pdv61plsi7h8l3")))) (build-system gnu-build-system) (arguments `(#:test-target "test" ;; TODO: Make this unconditional on core-updates. ,@(if (%current-target-system) `(#:make-flags `(,(string-append "CC=" ,(cc-for-target)) ,(string-append "AR=" ,(ar-for-target)))) '()) #:phases (modify-phases %standard-phases (replace 'configure (lambda* (#:key outputs #:allow-other-keys) (chdir "libraries/liblmdb") (substitute* "Makefile" (("/usr/local") (assoc-ref outputs "out"))) #t)) (add-after 'install 'create-pkg-config-file (lambda* (#:key outputs #:allow-other-keys) (let ((out (assoc-ref outputs "out"))) (mkdir-p (string-append out "/lib/pkgconfig")) (with-output-to-file (string-append out "/lib/pkgconfig/liblmdb.pc") (lambda _ (format #t "prefix=~a~@ exec_prefix=~a~@ libdir=~a/lib~@ includedir=~a/include~@ ~@ Name: liblmdb~@ Version: ~a~@ Description: Lightning Memory-Mapped Database library~@ Libs: -L${libdir} -llmdb~@ Cflags: -I${includedir}~%" out out out out ,version))) #t)))))) (home-page "https://symas.com/lmdb/") (synopsis "Lightning Memory-Mapped Database library") (description "The @dfn{Lightning Memory-Mapped Database} (LMDB) is a high-performance transactional database. Unlike more complex relational databases, LMDB handles only key-value pairs (stored as arbitrary byte arrays) and relies on the underlying operating system for caching and locking, keeping the code small and simple. The use of ‘zero-copy’ memory-mapped files combines the persistence of classic disk-based databases with high read performance that scales linearly over multiple cores. The size of each database is limited only by the size of the virtual address space — not physical RAM.") (license license:openldap2.8))) (define-public lmdbxx (package (name "lmdbxx") (version "1.0.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/hoytech/lmdbxx") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "12k5rz74d1l0skcks9apry1svkl96g9lf5dcgylgjmh7v1jm0b7c")))) (arguments `(#:make-flags (list (string-append "PREFIX=" (assoc-ref %outputs "out"))) #:phases (modify-phases %standard-phases (delete 'configure)))) (build-system gnu-build-system) (inputs (list lmdb)) (home-page "https://github.com/hoytech/lmdbxx") (synopsis "C++11 wrapper for the LMDB embedded B+ tree database library") (description "@code{lmdbxx} is a comprehensive @code{C++} wrapper for the @code{LMDB} embedded database library, offering both an error-checked procedural interface and an object-oriented resource interface with RAII semantics.") (license license:unlicense))) (define-public libpqxx (package (name "libpqxx") (version "7.7.4") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/jtv/libpqxx") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "1qwpfba8g55jjv0xnsk4hhf2cmhk7mdirxx115cvnjjw97ppy0z0")))) (build-system gnu-build-system) (native-inputs (list gcc-11 python-wrapper)) (inputs (list postgresql)) (arguments '(#:tests? #f)) ;tests require a running PostgreSQL server (synopsis "C++ connector for PostgreSQL") (description "Libpqxx is a C++ library to enable user programs to communicate with the PostgreSQL database back-end. The database back-end can be local or it may be on another machine, accessed via TCP/IP.") (home-page "https://pqxx.org/") (license license:bsd-3))) (define-public python-peewee (package (name "python-peewee") (version "3.14.4") (source (origin (method url-fetch) (uri (pypi-uri "peewee" version)) (sha256 (base32 "18jidir2wid0cp8a61m9vf9mf0pdvm6nzspc8bfwdbifghr6ndcy")))) (build-system python-build-system) (arguments `(#:tests? #f)) ; fails to import test data (inputs (list sqlite)) (native-inputs (list python-cython)) (home-page "https://github.com/coleifer/peewee/") (synopsis "Small object-relational mapping utility") (description "Peewee is a simple and small ORM (object-relation mapping) tool. Peewee handles converting between pythonic values and those used by databases, so you can use Python types in your code without having to worry. It has built-in support for sqlite, mysql and postgresql. If you already have a database, you can autogenerate peewee models using @code{pwiz}, a model generator.") (license license:expat))) (define-public python-pypika-tortoise (package (name "python-pypika-tortoise") (version "0.1.6") (source (origin (method url-fetch) (uri (pypi-uri "pypika-tortoise" version)) (sha256 (base32 "0dmzpsnlqjjz0vm0r9xjk69xfsm235bpnk3jccr8ww4s8y7qc0nq")))) (build-system pyproject-build-system) (native-inputs (list poetry)) (home-page "https://github.com/tortoise/pypika-tortoise") (synopsis "Pypika fork for tortoise-orm") (description "Pypika-tortoise is a fork of pypika which has been streamlined for its use in the context of tortoise-orm. It removes support for many database kinds that tortoise-orm doesn't need, for example.") (license license:asl2.0))) (define-public python-sphinxcontrib-asyncio (package (name "python-sphinxcontrib-asyncio") (version "0.3.0") (source (origin (method url-fetch) (uri (pypi-uri "sphinxcontrib-asyncio" version)) (sha256 (base32 "0bkj010ygsr7m769llf2aq4bbjfhdwqrrabi98j8gpvyzvh2dzcr")))) (build-system python-build-system) (arguments '(#:tests? #f)) ;no test suite (propagated-inputs (list python-sphinx)) (home-page "https://github.com/aio-libs/sphinxcontrib-asyncio") (synopsis "Sphinx extension to support coroutines in markup") (description "This package is a Sphinx extension providing additional coroutine-specific markup.") (license license:asl2.0))) (define-public python-asyncpg (package (name "python-asyncpg") (version "0.25.0") (source (origin (method url-fetch) (uri (pypi-uri "asyncpg" version)) (sha256 (base32 "0h1573lp4607nppflnnjrhn7yrfy6i54cm98gi4qbcikjykfdy33")))) (build-system python-build-system) (propagated-inputs (list python-typing-extensions)) (native-inputs (list postgresql python-cython python-pytest python-uvloop)) (home-page "https://github.com/MagicStack/asyncpg") (synopsis "Fast PostgreSQL database client library for Python") (description "@code{asyncpg} is a database interface library designed specifically for PostgreSQL and Python/asyncio. @code{asyncpg} is an efficient, clean implementation of PostgreSQL server binary protocol for use with Python's asyncio framework.") (license license:asl2.0))) (define-public python-asyncmy (package (name "python-asyncmy") (version "0.2.5") (source (origin (method url-fetch) (uri (pypi-uri "asyncmy" version)) (sha256 (base32 "0i18zxy6xvzv6dk791xifn2sw2q4zvqwpzrzy8qx51d3mp8z6gng")))) (build-system python-build-system) (native-inputs (list python-cython)) (home-page "https://github.com/long2ice/asyncmy") (synopsis "Fast MySQL driver for Python") (description "@code{asyncmy} is a fast @code{asyncio} MySQL driver, which reuses most of @code{pymysql} and @code{aiomysql} but rewrites the core protocol with Cython for performance.") (license license:asl2.0))) (define-public python-aiomysql (package (name "python-aiomysql") (version "0.1.1") (source (origin (method url-fetch) (uri (pypi-uri "aiomysql" version)) (sha256 (base32 "0zhhisf2bz2hv0vcklw45k54yr0f7gx61gnq4lc7vdp6v97nqs0d")))) (build-system pyproject-build-system) (arguments '(#:tests? #f)) ;test suite requires docker (propagated-inputs (list python-pymysql)) (native-inputs (list python-setuptools python-wheel)) (home-page "https://github.com/aio-libs/aiomysql") (synopsis "MySQL driver for Python") (description "@code{aiomysql} is a driver for accessing a MySQL database from the @code{asyncio} Python framework. It depends on and reuses most parts of PyMySQL. @code{aiomysql} tries to preserve the same API as the @code{aiopg} library.") (license license:expat))) (define-public python-tortoise-orm (package (name "python-tortoise-orm") (version "0.20.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/tortoise/tortoise-orm") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "19rgyvs2y9gn27x71y7djdz6rb6bszgvprv55q1hr4266wy6g999")))) (build-system pyproject-build-system) ;; The test suite relies on asynctest, which is abandoned and doesn't ;; support Python >= 3.8. (arguments '(#:tests? #f)) (native-inputs (list poetry)) (propagated-inputs (list python-aiomysql python-aiosqlite-0.17 python-asyncmy python-asyncpg python-ciso8601 python-iso8601 python-pypika-tortoise python-pytz python-rapidjson python-uvloop)) (home-page "https://github.com/tortoise/tortoise-orm") (synopsis "Asynchronous Object Relational Mapper (ORM) for Python") (description "Tortoise ORM is an easy-to-use asyncio ORM (Object Relational Mapper) inspired by Django. Tortoise ORM was built with relations in mind and admiration for the excellent and popular Django ORM. It's engraved in its design that you are working not with just tables, you work with relational data.") (license license:asl2.0))) (define-public aerich (package (name "aerich") (version "0.7.2") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/tortoise/aerich") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0pcy945bg890p12s7cyw0mg7hxwsxyy570j600sbf7kwj2d3lilg")))) (build-system pyproject-build-system) (native-inputs (list poetry python-bandit python-cryptography python-isort python-pydantic python-pytest python-pytest-asyncio python-pytest-mock python-pytest-xdist)) (propagated-inputs (list python-asyncmy python-asyncpg python-click python-ddlparse python-dictdiffer python-tomlkit python-tortoise-orm)) (home-page "https://github.com/tortoise/aerich") (synopsis "Database migrations tool for Tortoise @acronym{ORM, Object Relational Mapper}") (description "This package provides @code{aerich}, a Python database migrations tool for Tortoise @acronym{ORM, Object Relational Mapper}. It can be used both programmatically or as a standalone CLI application.") (license license:asl2.0))) (define-public sqlcipher (package (name "sqlcipher") (version "3.4.2") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/sqlcipher/sqlcipher") (commit (string-append "v" version)))) (sha256 (base32 "168wb6fvyap7y8j86fb3xl5rd4wmhiq0dxvx9wxwi5kwm1j4vn1a")) (file-name (git-file-name name version)))) (build-system gnu-build-system) (inputs `(("libcrypto" ,openssl) ("libtcl8.6" ,tcl))) ; required for running the tests (native-inputs (list tcl)) (arguments '(#:configure-flags '("--enable-tempstore=yes" "CFLAGS=-DSQLITE_HAS_CODEC -DSQLITE_ENABLE_FTS3" "LDFLAGS=-lcrypto -ltcl8.6" "--disable-tcl") ;; tests cannot be run from the Makefile ;; see: <https://github.com/sqlcipher/sqlcipher/issues/172> #:test-target "testfixture" #:phases (modify-phases %standard-phases (add-before 'check 'build-test-runner (assoc-ref %standard-phases 'check)) (replace 'check (lambda _ (invoke "./testfixture" "test/crypto.test")))))) (home-page "https://www.zetetic.net/sqlcipher/") (synopsis "Library providing transparent encryption of SQLite database files") (description "SQLCipher is an implementation of SQLite, extended to provide transparent 256-bit AES encryption of database files. Pages are encrypted before being written to disk and are decrypted when read back. It’s well suited for protecting embedded application databases and for mobile development.") ;; The source files ;; src/{crypto.c,crypto_impl.c,crypto.h,crypto_cc.c,crypto_libtomcrypt.c}, ;; src/{crypto_openssl.c,sqlcipher.h}, tool/crypto-speedtest.tcl, ;; test/crypto.test are licensed under a 3-clause BSD license. All other ;; source files are in the public domain. (license (list license:public-domain license:bsd-3)))) (define-public python-pyodbc-c (package (name "python-pyodbc-c") (version "3.1.5") (source (origin (method git-fetch) (uri (git-reference (url "https://gitlab.com/daym/pyodbc-c/") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "08y60c5sx0k953zfx0s2a155l8py968sb17ap9a9fg8bjnj783k8")))) (build-system python-build-system) (inputs (list unixodbc)) (arguments `(;; The tests require a running SQL server that they don't help set up. #:tests? #f)) (home-page "https://gitlab.com/daym/pyodbc-c") (synopsis "Python ODBC Library written in C") (description "@code{python-pyodbc-c} provides a Python DB-API driver for ODBC, similar to python-pyodbc but written in C. It's designed to stand alone and not have other dependencies on other packages or languages. It uses only Python's built-in data types.") (license (license:x11-style "file://LICENSE.TXT")))) (define-public python-pyodbc (package (name "python-pyodbc") (version "4.0.35") (source (origin (method url-fetch) (uri (pypi-uri "pyodbc" version)) (sha256 (base32 "1j7577acd2f16zifw49ajg0aw7vm0pdg6jxrr1dlaa5rx14azfcj")) (modules '((guix build utils))) (snippet ;; Delete precompiled binaries. The corresponding source is included. #~(for-each delete-file (find-files "." "\\.pyc$"))))) (build-system python-build-system) (inputs (list unixodbc)) (arguments ;; XXX Tests fail with ‘Can't open lib 'SQL Server Native Client 10.0' : ;; file not found (0) (SQLDriverConnect)")’. (list #:tests? #f #:phases #~(modify-phases %standard-phases (replace 'check (lambda* (#:key tests? #:allow-other-keys) (when tests? (invoke "python3" "tests3/test.py"))))))) (home-page "https://github.com/mkleehammer/pyodbc") (synopsis "Python ODBC Library") (description "@code{python-pyodbc} provides a Python DB-API driver for ODBC.") (license (license:x11-style "file:///LICENSE.TXT")))) (define-public mdbtools (package (name "mdbtools") (version "0.7.1") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/brianb/mdbtools") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "0gwcpp9y09xhs21g7my2fs8ncb8i6ahlyixcx8jd3q97jbzj441l")))) (build-system gnu-build-system) (inputs (list glib)) (native-inputs (list autoconf automake libtool pkg-config txt2man which)) (home-page "https://mdbtools.sourceforge.net/") (synopsis "Read Microsoft Access databases") (description "MDB Tools is a set of tools and applications to read the proprietary MDB file format used in Microsoft's Access database package. This includes programs to export schema and data from Microsoft's Access database file format to other databases such as MySQL, Oracle, Sybase, PostgreSQL, etc., and an SQL engine for performing simple SQL queries.") (license (list license:lgpl2.0 license:gpl2+)))) (define-public go-gopkg-in-mgo-v2 (package (name "go-gopkg-in-mgo-v2") (version "2.0.0-20190816093944-a6b53ec6cb22") (source (origin (method git-fetch) (uri (git-reference (url "https://gopkg.in/mgo.v2") (commit (go-version->git-ref version)))) (file-name (git-file-name name version)) (sha256 (base32 "1lgvwxsbmdrf4938qkxl56wbwgbphk2qqnmpf73qdmlv4qsg14na")))) (build-system go-build-system) (arguments '(#:tests? #f ; Tests try to use a running mongodb server. #:import-path "gopkg.in/mgo.v2")) (propagated-inputs (list go-gopkg.in-tomb.v2)) (inputs (list cyrus-sasl)) (native-inputs (list go-gopkg-in-check-v1)) (home-page "https://gopkg.in/mgo.v2") (synopsis "MongoDB driver for Go") (description "This package provides a MongoDB driver for Go.") (license license:bsd-2))) (define-public python-lmdb (package (name "python-lmdb") (version "1.0.0") (source (origin (method url-fetch) (uri (pypi-uri "lmdb" version)) (sha256 (base32 "1di1gj2agbxwqqwrpk4w58dpfah0kl10ha20s63dlqdd1bgzydj1")) (modules '((guix build utils))) (snippet ;; Delete bundled lmdb source files. '(begin (for-each delete-file (list "lib/lmdb.h" "lib/mdb.c" "lib/midl.c" "lib/midl.h")) #t)))) (build-system python-build-system) (inputs (list lmdb)) (arguments `(#:phases (modify-phases %standard-phases (add-before 'build 'use-system-lmdb (lambda* (#:key inputs #:allow-other-keys) (let ((lmdb (assoc-ref inputs "lmdb"))) (setenv "LMDB_PURE" "set") ; don't apply env-copy-txn.patch (setenv "LMDB_FORCE_SYSTEM" "set") (setenv "LMDB_INCLUDEDIR" (string-append lmdb "/include")) (setenv "LMDB_LIBDIR" (string-append lmdb "/lib")) #t)))) ;; Tests fail with: ‘lmdb.tool: Please specify environment (--env)’. #:tests? #f)) (home-page "https://github.com/dw/py-lmdb") (synopsis "Python binding for the ‘Lightning’ database (LMDB)") (description "python-lmdb or py-lmdb is a Python binding for the @dfn{Lightning Memory-Mapped Database} (LMDB), a high-performance key-value store.") (license (list license:openldap2.8 ;; ‘lib/win32/inttypes.h’ and ‘lib/win32-stdint/stdint.h’ are BSD-3, ;; but not actually needed on platforms currently supported by Guix. license:bsd-3)))) (define-public virtuoso-ose (package (name "virtuoso-ose") (version "7.2.11") (source (origin (method url-fetch) (uri (string-append "mirror://sourceforge/virtuoso/virtuoso/" version "/" "virtuoso-opensource-" version ".tar.gz")) (sha256 (base32 "0mk25gr1pafmps4nsydjprwswbzwch8b583nlwh7x2031sz7ald1")) (patches (search-patches "virtuoso-ose-remove-pre-built-jar-files.patch")) (modules '((guix build utils))) ;; This snippet removes pre-built Java archives. (snippet #~(for-each delete-file-recursively (list "binsrc/hibernate" "binsrc/jena" "binsrc/jena2" "binsrc/jena3" "binsrc/jena4" "binsrc/rdf4j" "binsrc/sesame" "binsrc/sesame2" "binsrc/sesame3" "binsrc/sesame4" "libsrc/JDBCDriverType4"))))) (build-system gnu-build-system) (arguments (list #:tests? #f ; tests require a network connection ;; TODO: Removing the libsrc/zlib source directory breaks the build. ;; This indicates that the internal zlib code may still be used. #:configure-flags #~(list "--without-internal-zlib" "--with-readline" "--enable-static=no") #:phases #~(modify-phases %standard-phases (replace 'bootstrap (lambda _ (invoke "sh" "autogen.sh"))) (add-after 'unpack 'avoid-embedding-kernel-and-timestamps ;; For a reproducible build, avoid embedding the kernel version and ;; timestamps. (lambda _ (substitute* (list "bin/makever" "appsrc/ODS-Polls/make_vad.sh" "appsrc/ODS-Blog/make_vad.sh" "appsrc/ODS-Community/make_vad.sh" "appsrc/ODS-Framework/make_vad.sh" "appsrc/ODS-Framework/oauth/make_vad.sh" "appsrc/ODS-WebMail/make_vad.sh" "appsrc/ODS-Calendar/make_vad.sh" "appsrc/ODS-Gallery/make_vad.sh" "appsrc/ODS-Briefcase/make_vad.sh" "appsrc/ODS-FeedManager/make_vad.sh" "appsrc/ODS-Bookmark/make_vad.sh" "appsrc/ODS-Addressbook/make_vad.sh" "binsrc/dbpedia/make_vad.sh" "binsrc/samples/demo/make_vad.sh" "binsrc/samples/demo/mkdoc.sh" "binsrc/samples/sparql_demo/make_vad.sh" "binsrc/bpel/make_vad.sh" "binsrc/fct/make_vad.sh" "binsrc/rdf_mappers/make_vad.sh" "binsrc/isparql/make_vad.sh" "binsrc/conductor/mkvad.sh") (("^UNAME_SYSTEM=.*") "UNAME_SYSTEM=unknown\n") (("^UNAME_RELEASE=.*") "UNAME_RELEASE=unknown\n") (("^PACKDATE=.*") "PACKDATE=2012-04-18\n") (("^DATE=.*") "DATE=2012-04-18\n")))) ;; Even with "--enable-static=no", "libvirtuoso-t.a" is left in ;; the build output. The following phase removes it. (add-after 'install 'remove-static-libs (lambda _ (for-each (lambda (file) (delete-file (string-append #$output "/lib/" file))) '("libvirtuoso-t.a" "libvirtuoso-t.la"))))))) (native-inputs (list autoconf automake bison flex gperf libtool)) (inputs (list openssl net-tools readline which zlib)) (home-page "https://vos.openlinksw.com/owiki/wiki/VOS/") (synopsis "Multi-model database system") (description "Virtuoso is a scalable cross-platform server that combines relational, graph, and document data management with web application server and web services platform functionality.") ;; configure: error: ... can only be build on 64bit platforms (supported-systems %64bit-supported-systems) (license license:gpl2))) (define-public python-ccm (package (name "python-ccm") (version "2.1.6") (source (origin (method url-fetch) (uri (pypi-uri "ccm" version)) (sha256 (base32 "177dfxsmk3k4cih6fh6v8d91bh4nqx7ns6pc07w7m7i3cvdx3c8n")))) (build-system python-build-system) (propagated-inputs (list python-pyyaml ;; Not listed in setup.py, but used in ccmlib/node.py for full ;; functionality python-psutil python-six)) (home-page "https://github.com/pcmanus/ccm") (synopsis "Cassandra Cluster Manager for Apache Cassandra clusters on localhost") (description "Cassandra Cluster Manager is a development tool for testing local Cassandra clusters. It creates, launches and removes Cassandra clusters on localhost.") (license license:asl2.0))) (define-public python-sqlalchemy (package (name "python-sqlalchemy") (version "1.4.42") (source (origin (method url-fetch) (uri (pypi-uri "SQLAlchemy" version)) (sha256 (base32 "0qzkxy47y06fqh1m7a0p7q2r9h48x9k5kl3znzhx2vj79j8l2zhp")))) (build-system pyproject-build-system) (native-inputs (list python-cython ; for C extensions python-pytest python-mock python-pytest-xdist ; for tests python-setuptools python-wheel)) (propagated-inputs (list python-greenlet)) (arguments (list #:test-flags '(list ;; The memory usage tests are very expensive and run in sequence; ;; skip them. "-k" "not test_memusage.py"))) (home-page "https://www.sqlalchemy.org") (synopsis "Database abstraction library") (description "SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that gives application developers the full power and flexibility of SQL. It provides a full suite of well known enterprise-level persistence patterns, designed for efficient and high-performing database access, adapted into a simple and Pythonic domain language.") (license license:x11))) (define-public python-sqlalchemy-2 (package (name "python-sqlalchemy") (version "2.0.36") (source (origin (method url-fetch) (uri (pypi-uri "sqlalchemy" version)) (sha256 (base32 "1i99kgm8hc38iffgp3wdbixpdc5jfjklabh8lyp9h8vd1dl6f9vz")))) (build-system pyproject-build-system) (arguments (list #:test-flags ;; Remove expensive tests. #~(list "--ignore=test/aaa_profiling/test_memusage.py" "--ignore=test/ext/mypy/test_mypy_plugin_py3k.py" "--ignore=test/typing/test_mypy.py" ;; Disable a test that fails randomly. "-k" "test_recycle_pool_no_race"))) (native-inputs (list python-cython python-pytest python-setuptools python-wheel)) (propagated-inputs (list python-greenlet python-typing-extensions)) (home-page "https://www.sqlalchemy.org") (synopsis "SQL toolkit and object relational mapper") (description "SQLAlchemy is the Python SQL toolkit and @acronym{ORM, Object Relational Mapper} that gives application developers the full power and flexibility of SQL. It provides a full suite of well known enterprise-level persistence patterns, designed for efficient and high-performing database access, adapted into a simple and Pythonic domain language.") (license license:expat))) (define-public python-sqlalchemy-stubs (package (name "python-sqlalchemy-stubs") (version "0.4") (source (origin (method url-fetch) (uri (pypi-uri "sqlalchemy-stubs" version)) (sha256 (base32 "1bppjmv7v7m0q8gwg791pgxbx4ay7mna0zq204pn9vw28kfxcrf6")))) (build-system python-build-system) (propagated-inputs (list python-mypy python-typing-extensions)) (home-page "https://github.com/dropbox/sqlalchemy-stubs") (synopsis "SQLAlchemy stubs and mypy plugin") (description "This package contains type stubs and a mypy plugin to provide more precise static types and type inference for SQLAlchemy framework.") (license license:asl2.0))) (define-public python-sqlalchemy-utils (package (name "python-sqlalchemy-utils") (version "0.38.3") (source (origin (method url-fetch) (uri (pypi-uri "SQLAlchemy-Utils" version)) (sha256 (base32 "0k8z0mjhvdv302kn0nhci8b2dgw4cn2akprsf37ma1540ykgp6lz")))) (build-system python-build-system) (arguments '(#:tests? #f)) ; FIXME: Many tests require a running database server. ;; #:phases ;; (modify-phases %standard-phases ;; (replace 'check ;; (lambda _ ;; (zero? (system* "py.test" "sqlalchemy_utils" "tests"))))) (propagated-inputs (list python-six python-sqlalchemy)) (native-inputs (list python-dateutil python-flexmock python-psycopg2 python-pytest python-pytz)) (home-page "https://github.com/kvesteri/sqlalchemy-utils") (synopsis "Various utility functions for SQLAlchemy") (description "SQLAlchemy-utils provides various utility functions and custom data types for SQLAlchemy. SQLAlchemy is an SQL database abstraction library for Python. You might also want to install the following optional dependencies: @enumerate @item @code{python-passlib} @item @code{python-babel} @item @code{python-cryptography} @item @code{python-pytz} @item @code{python-psycopg2} @item @code{python-furl} @item @code{python-flask-babel} @end enumerate ") (license license:bsd-3))) (define-public python-alchemy-mock (package (name "python-alchemy-mock") (version "0.4.3") (home-page "https://github.com/miki725/alchemy-mock") (source (origin (method url-fetch) (uri (pypi-uri "alchemy-mock" version)) (sha256 (base32 "0ylxygl3bcdapzz529n8wgk7vx9gjwb3ism564ypkpd7dbsw653r")) (snippet #~(begin (use-modules (guix build utils)) (substitute* "alchemy_mock/comparison.py" (("collections\\.Mapping") "collections.abc.Mapping")))))) (build-system python-build-system) (arguments '(#:phases (modify-phases %standard-phases (replace 'check (lambda _ ;; Create pytest.ini that adds doctest options to ;; prevent test failure. Taken from tox.ini. (call-with-output-file "pytest.ini" (lambda (port) (format port "[pytest] doctest_optionflags=IGNORE_EXCEPTION_DETAIL "))) (invoke "pytest" "-vv" "--doctest-modules" "alchemy_mock/")))))) (native-inputs (list python-mock python-pytest)) (propagated-inputs (list python-six python-sqlalchemy)) (synopsis "Mock helpers for SQLAlchemy") (description "This package provides mock helpers for SQLAlchemy that makes it easy to mock an SQLAlchemy session while preserving the ability to do asserts. Normally Normally SQLAlchemy's expressions cannot be easily compared as comparison on binary expression produces yet another binary expression, but this library provides functions to facilitate such comparisons.") (license license:expat))) (define-public python-alembic (package (name "python-alembic") (version "1.14.0") (source (origin (method url-fetch) (uri (pypi-uri "alembic" version)) (sha256 (base32 "0jrh9q4h2jv2bafpd6isx2dvc90rpx6j7fpdvfwd0hin7fsr425h")))) (build-system pyproject-build-system) (arguments (list #:test-flags #~(list "--ignore=tests/integration" "-k" (string-join ;; XXX: Tests require fresh python-pytz timezones, remove ;; when updated. (list "not test_custom_tz" "test_custom_tz_lowercase" "test_custom_tz_utc" "test_custom_tzdata_tz") " and not ")))) (native-inputs (list python-mock python-pytest python-setuptools python-wheel)) (propagated-inputs (list python-dateutil python-editor python-mako python-sqlalchemy python-typing-extensions)) (home-page "https://bitbucket.org/zzzeek/alembic") (synopsis "Database migration tool for SQLAlchemy") (description "Alembic is a lightweight database migration tool for usage with the SQLAlchemy Database Toolkit for Python.") (license license:expat))) (define-public python-sqlite-fts4 (package (name "python-sqlite-fts4") (version "1.0.3") (source (origin (method url-fetch) (uri (pypi-uri "sqlite-fts4" version)) (sha256 (base32 "034kx0ac556sywy1p4qcrc36l24w3q0xwswqv2z9s3k8yvm5xc3q")))) (build-system python-build-system) (native-inputs (list python-pytest)) (home-page "https://github.com/simonw/sqlite-fts4") (synopsis "Python functions for working with SQLite FTS4 search") (description "This package provides custom SQLite functions written in Python for ranking documents indexed using the SQLite's FTS4 full text search extension.") (license license:asl2.0))) (define-public python-sqlite-utils (package (name "python-sqlite-utils") (version "3.32.1") (source (origin (method git-fetch) ;for tests (uri (git-reference (url "https://github.com/simonw/sqlite-utils") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "1qf9zwn9gdkx8825klicwkw8zj5wpidd8csdhjxvybq56nkgnrpm")))) (build-system pyproject-build-system) (arguments (list #:phases #~(modify-phases %standard-phases (add-after 'unpack 'relax-requirements (lambda _ (substitute* "setup.py" ;; This is a variant designed to have a binary ;; wheel made available on PyPI, which is not a ;; concern to Guix. (("click-default-group-wheel") "click-default-group"))))))) (propagated-inputs (list python-click python-click-default-group python-dateutil python-sqlite-fts4 python-tabulate)) (native-inputs (list python-pytest python-setuptools python-wheel)) (home-page "https://github.com/simonw/sqlite-utils") (synopsis "CLI tool and Python utility functions for manipulating SQLite databases") (description "This package provides a CLI tool and Python utility functions for manipulating SQLite databases. It's main features are: @itemize @item Pipe JSON (or CSV or TSV) directly into a new SQLite database file, automatically creating a table with the appropriate schema. @item Run in-memory SQL queries, including joins, directly against data in CSV, TSV or JSON files and view the results. @item Configure SQLite full-text search against your database tables and run search queries against them, ordered by relevance. @item Run transformations against your tables to make schema changes that SQLite ALTER TABLE does not directly support, such as changing the type of a column. @item Extract columns into separate tables to better normalize your existing data. @end itemize") (license license:asl2.0))) (define-public python-pickleshare (package (name "python-pickleshare") (version "0.7.5") (source (origin (method url-fetch) (uri (pypi-uri "pickleshare" version)) (sha256 (base32 "1jmghg3c53yp1i8cm6pcrm280ayi8621rwyav9fac7awjr3kss47")))) (build-system pyproject-build-system) (native-inputs (list python-pytest python-setuptools python-wheel)) (home-page "https://github.com/vivainio/pickleshare") (synopsis "Tiny key value database with concurrency support") (description "PickleShare is a small ‘shelve’-like datastore with concurrency support. Like shelve, a PickleShareDB object acts like a normal dictionary. Unlike shelve, many processes can access the database simultaneously. Changing a value in database is immediately visible to other processes accessing the same database. Concurrency is possible because the values are stored in separate files. Hence the “database” is a directory where all files are governed by PickleShare.") (license license:expat))) (define-public python-apsw (package (name "python-apsw") (version "3.46.0.0") ;; The compressed release has fetching functionality disabled. (source (origin (method url-fetch) (uri (string-append "https://github.com/rogerbinns/apsw/releases/download/" version "/apsw-" version ".zip")) (sha256 (base32 "10yfbasi4mq63g0svyl1h49ylwn9znjylq78id16dzxzk9q9ipdx")))) (build-system pyproject-build-system) (native-inputs (list unzip python-setuptools python-wheel)) (inputs (list sqlite-next)) ;SQLite 3.45.1 required. (arguments (list #:phases #~(modify-phases %standard-phases (add-before 'build 'build-extensions (lambda _ (invoke "python" "setup.py" "build" "--enable-all-extensions" "--enable=load_extension"))) (add-after 'build 'build-test-helper (lambda _ (invoke "gcc" "-fPIC" "-shared" "-o" "./testextension.sqlext" "-I." "-Isqlite3" "src/testextension.c")))))) (home-page "https://github.com/rogerbinns/apsw/") (synopsis "Another Python SQLite Wrapper") (description "APSW is a Python wrapper for the SQLite embedded relational database engine. In contrast to other wrappers such as pysqlite it focuses on being a minimal layer over SQLite attempting just to translate the complete SQLite API into Python.") (license license:zlib))) (define-public python-aiosqlite (package (name "python-aiosqlite") (version "0.18.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/omnilib/aiosqlite") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "1a8sggh1wwbpl46k5qcfmp97s9hjysna0x7mwwc53kyfm0m95wf8")))) (build-system pyproject-build-system) (arguments (list #:phases #~(modify-phases %standard-phases (replace 'check (lambda* (#:key tests? #:allow-other-keys) (when tests? (invoke "python" "-m" "coverage" "run" "-m" "aiosqlite.tests") (invoke "python" "-m" "coverage" "report"))))))) (native-inputs (list python-flit-core python-coverage python-mypy)) (home-page "https://github.com/jreese/aiosqlite") (synopsis "Asyncio bridge for sqlite3") (description "The package aiosqlite replicates the standard sqlite3 module, but with async versions of all the standard connection and cursor methods, and context managers for automatically closing connections.") (license license:expat))) (define-public python-aiosqlite-0.17 (package (inherit python-aiosqlite) (version "0.17.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/omnilib/aiosqlite") (commit (string-append "v" version)))) (file-name (git-file-name (package-name python-aiosqlite) version)) (sha256 (base32 "1agh7b9g7rgryvb8flph85i8m80ai1rinpljxzlsrs0s0y616qgg")))) (build-system pyproject-build-system) (arguments '(#:phases (modify-phases %standard-phases (replace 'check (lambda* (#:key tests? #:allow-other-keys) (if tests? (invoke "python" "-m" "unittest" "aiosqlite.tests") (format #t "test suite not run~%"))))))) (propagated-inputs (list python-typing-extensions)) (native-inputs (list python-flit-core python-aiounittest)))) (define-public python-databases (package (name "python-databases") (version "0.7.0") (source (origin (method url-fetch) (uri (pypi-uri "databases" version)) (sha256 (base32 "0x5nqhzgjqimv2ybjbzy5vv0l23g0n1g5f6fnyahbf1f7nfl2bga")))) (build-system python-build-system) (propagated-inputs (list python-aiosqlite python-aiopg python-aiomysql python-asyncpg python-asyncmy python-sqlalchemy)) (home-page "https://github.com/encode/databases") (synopsis "Asynchronous database abstraction library") (description "Databases provides a wrapper around asynchronous database libraries with SQLALchemy.") (license license:bsd-3))) (define-public python-psycopg2 (package (name "python-psycopg2") (version "2.9.6") (source (origin (method url-fetch) (uri (pypi-uri "psycopg2" version)) (sha256 (base32 "04chl9f7v7k1zssa40pmk06jvpyqiss2lpjq50dq69nqix0mhlgi")))) (build-system python-build-system) (arguments ;; Tests would require a postgresql database "psycopg2_test" ;; and a running postgresql database management service. '(#:tests? #f)) ; TODO re-enable after providing a test-db. (inputs (list postgresql)) ; libpq (home-page "https://www.psycopg.org/") (synopsis "Python PostgreSQL adapter") (description "psycopg2 is a thread-safe PostgreSQL adapter that implements DB-API 2.0.") (license license:lgpl3+))) (define-public python-psycopg-pool (package (name "python-psycopg-pool") ;; The connection pooling code is on a different release cadence ;; from the driver code, so fetch the latest PyPI release. (version "3.1.7") (source (origin (method url-fetch) (uri (pypi-uri "psycopg-pool" version)) (sha256 (base32 "1pkx7nj1mhacwpna7ldzqfqxd1xg8826600r0bs9ad1h93f429yh")))) (build-system python-build-system) (arguments (list #:tests? #f ;run for psycopg below #:phases #~(modify-phases %standard-phases ;; This module requires 'psycopg', however psycopg needs this ;; for its tests. Disable sanity check to break the cycle. (delete 'sanity-check)))) (home-page "https://www.psycopg.org/") (synopsis "Connection pooler for psycopg") (description "This module provides connection pool implementations that can be used with the @code{psycopg} PostgreSQL driver.") (license license:lgpl3+))) (define-public python-psycopg (package (name "python-psycopg") (version "3.1.10") (source (origin ;; Fetch from git because PyPI contains only cythonized sources. (method git-fetch) (uri (git-reference (url "https://github.com/psycopg/psycopg") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "0hqk45wlaflz69cy1r0hbv11bwb89p6hjb7zmgqas26gdhg37n0r")))) (build-system python-build-system) (arguments (list #:phases #~(modify-phases %standard-phases (add-before 'build 'change-directory (lambda _ (chdir "psycopg"))) (add-after 'build 'build-c-extensions (lambda _ (with-directory-excursion "../psycopg_c" ((assoc-ref %standard-phases 'build))))) (add-after 'install 'install-c-extensions (lambda* (#:key inputs outputs #:allow-other-keys) ;; For some reason setup.py refuses to install if the ;; installation directory is not on PYTHONPATH. (setenv "PYTHONPATH" (site-packages inputs outputs)) (with-directory-excursion "../psycopg_c" ((assoc-ref %standard-phases 'install) #:inputs inputs #:outputs outputs)))) (add-before 'check 'start-postgresql (lambda _ (let ((dbdir (string-append (getcwd) "/../pgdir"))) (invoke "initdb" "-D" dbdir) (invoke "pg_ctl" "-D" dbdir "-o" (string-append "-k " dbdir) "-l" (string-append dbdir "/db.log") "start") (invoke "psql" "-h" dbdir "-d" "postgres" "-c" "CREATE DATABASE nixbld;")))) (replace 'check (lambda* (#:key inputs tests? #:allow-other-keys) (when tests? (setenv "TZDIR" (search-input-directory inputs "share/zoneinfo")) (with-directory-excursion ".." (invoke "pytest" "-vv" "-o" "asyncio_mode=auto" ;; FIXME: Many of the typing tests are failing, ;; conveniently tagged as slow... "-k" "not slow"))))) ;; The sanity check phase attempts loading the C extension ;; before the Python library, which results in the following: ;; <ImportError: the psycopg package should be imported ;; before psycopg_c>. (delete 'sanity-check)))) (native-inputs (list python-cython-3 python-mypy python-psycopg-pool python-pytest python-pytest-asyncio python-anyio python-tenacity pproxy tzdata-for-tests)) (inputs (list postgresql)) (home-page "https://www.psycopg.org/") (synopsis "PostgreSQL driver for Python") (description "Psycopg 3 is a new implementation of the popular @code{psycopg2} database adapter for Python.") (license license:lgpl3+))) (define-public python-sadisplay (package (name "python-sadisplay") (version "0.4.9") (source (origin (method url-fetch) (uri (pypi-uri "sadisplay" version)) (sha256 (base32 "15jxwgla3q4xsp6rw8inqaiy1kdzc8l2cixj8amqcf0ji47icrxg")))) (build-system python-build-system) (arguments '(#:phases (modify-phases %standard-phases (replace 'check (lambda* (#:key tests? #:allow-other-keys) (if tests? (begin (setenv "PYTHONPATH" (string-append ".:" (or (getenv "PYTHONPATH") ""))) (invoke "pytest" "-vv")) (format #t "test suite not run~%"))))))) (propagated-inputs (list python-sqlalchemy)) (native-inputs ;; For tests. (list python-pytest)) (home-page "https://bitbucket.org/estin/sadisplay") (synopsis "SQLAlchemy schema displayer") (description "This package provides a program to build Entity Relationship diagrams from a SQLAlchemy model (or directly from the database).") (license license:bsd-3))) (define-public yoyo-migrations (package (name "yoyo-migrations") (version "8.2.0") (source (origin ;; We use the upstream repository, as the tests are not included in the ;; PyPI releases. (method hg-fetch) (uri (hg-reference (url "https://hg.sr.ht/~olly/yoyo") (changeset (string-append "v" version "-release")))) (file-name (string-append name "-" version "-checkout")) (sha256 (base32 "1al030ix0w63hr4s3mqry6s0mlqdj8p242pdqks06br7c25nx3yj")))) (build-system python-build-system) (arguments ;; XXX: Tests require a connection to some pgsql database and psycopg ;; fails to connect to it. '(#:tests? #f)) (propagated-inputs (list python-sqlparse python-tabulate python-importlib-metadata)) (home-page "https://ollycope.com/software/yoyo/latest/") (synopsis "Database migrations with SQL") (description "Yoyo is a database schema migration tool. Migrations are written as SQL files or Python scripts that define a list of migration steps.") (license license:asl2.0))) (define-public python-mysqlclient (package (name "python-mysqlclient") (version "2.2.4") (source (origin (method url-fetch) (uri (pypi-uri "mysqlclient" version)) (sha256 (base32 "0hdznfz9095d2qhl7awbp39s7wpqbxn37xzan487qzaf8srrzg1k")))) (build-system pyproject-build-system) (arguments (list #:test-flags #~'("tests/test__mysql.py" ;tests not needing a live db "tests/test_MySQLdb_times.py"))) (native-inputs (list pkg-config python-pytest python-setuptools python-wheel)) (inputs (list mariadb-connector-c)) (home-page "https://github.com/PyMySQL/mysqlclient") (synopsis "MySQLdb is an interface to the popular MySQL database server for Python") (description "MySQLdb is an interface to the popular MySQL database server for Python. The design goals are: @enumerate @item Compliance with Python database API version 2.0 [PEP-0249], @item Thread-safety, @item Thread-friendliness (threads will not block each other). @end enumerate") (license license:gpl2))) (define-public python-hiredis (package (name "python-hiredis") (version "2.2.2") (source (origin (method git-fetch) ;for tests (uri (git-reference (url "https://github.com/redis/hiredis-py") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "066rm5m7aa8skm0a57cf45153bwmbl9yyi4s60an14hb25n947gi")) (patches (search-patches "python-hiredis-fix-header.patch" "python-hiredis-use-system-hiredis.patch")))) (build-system pyproject-build-system) (arguments (list #:phases #~(modify-phases %standard-phases (add-before 'check 'delete-extraneous-__init__.py (lambda _ ;; The fix was forwarded upstream, see: ;; https://github.com/redis/hiredis-py/pull/160. (delete-file "tests/__init__.py")))))) (native-inputs (list python-pytest python-setuptools python-wheel)) (inputs (list hiredis)) (home-page "https://github.com/redis/hiredis-py") (synopsis "Python extension that wraps protocol parsing code in hiredis") (description "Python-hiredis is a python extension that wraps protocol parsing code in hiredis. It primarily speeds up parsing of multi bulk replies.") (license license:bsd-3))) (define-public python-fakeredis (package (name "python-fakeredis") (version "2.26.1") (source (origin (method git-fetch) ;for tests (uri (git-reference (url "https://github.com/cunla/fakeredis-py") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "10f9qwpc9vlcd2411c398n9kwjsk399vk1pjd9dbczlhvsn9s5bq")))) (build-system pyproject-build-system) (arguments (list #:test-flags '(list "-m" "not slow") #:phases #~(modify-phases %standard-phases (add-after 'unpack 'poetry-compatibility (lambda _ ;; Our version of poetry does not understand "to". (substitute* "pyproject.toml" ((", to = \"fakeredis\" ") "")))) (add-after 'unpack 'relax-requirements (lambda _ (substitute* "pyproject.toml" (("sortedcontainers = \"\\^2\\.4\"") "sortedcontainers = \"^2.1\"")))) ;; Tests require a running Redis server. (add-before 'check 'start-redis (lambda* (#:key tests? #:allow-other-keys) (when tests? (invoke "redis-server" "--daemonize" "yes" "--port" "6390"))))))) (native-inputs (list python-poetry-core python-pytest python-pytest-asyncio python-pytest-mock redis)) (propagated-inputs (list python-redis python-sortedcontainers python-typing-extensions)) (home-page "https://github.com/cunla/fakeredis-py") (synopsis "Fake implementation of redis API for testing purposes") (description "Fakeredis is a pure-Python implementation of the redis-py Python client that simulates talking to a redis server. It was created for a single purpose: to write unit tests. Setting up redis is not hard, but one often wants to write unit tests that don't talk to an external server such as redis. This module can be used as a reasonable substitute.") (license license:bsd-3))) (define-public python-redis (package (name "python-redis") (version "5.2.0") (source (origin ;; The PyPI archive lacks some test resources such as the TLS ;; certificates under docker/stunnel/keys. (method git-fetch) (uri (git-reference (url "https://github.com/redis/redis-py") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0f38s704gpm8ra6vdrqhicfq7m77in60kbgcmhvmviq9qj6v3505")))) (build-system pyproject-build-system) (arguments (list #:test-flags #~(list "-m" ;; These tests are disabled in the official CI run (see: ;; https://raw.githubusercontent.com/redis/redis-py/master/ ;; .github/workflows/install_and_test.sh). (string-append "not onlycluster " "and not redismod " "and not ssl " "and not graph") "-k" (string-join (list ;; The autoclaim test fails with "AssertionError: assert ;; [b'0-0', [], []] == [b'0-0', []]". "not test_xautoclaim " ;; These tests cause the following error: "Error 111 ;; connecting to localhost:6380. Connection refused." ;; (see: https://github.com/redis/redis-py/issues/2109). "test_sync" "test_psync" ;; Same with: "Error 111 connecting to ;; localhost:6479. Connection refused." "test_tfcall" "test_tfunction_load_delete" "test_tfunction_list" ;; AssertionError: assert 3 == 2 "test_acl_list") " and not ")) #:phases #~(modify-phases %standard-phases ;; Tests require a running Redis server. (add-before 'check 'start-redis (lambda* (#:key tests? #:allow-other-keys) (when tests? (invoke "redis-server" "--daemonize" "yes" "--enable-debug-command" "yes" "--enable-module-command" "local"))))))) (native-inputs (list python-numpy python-pytest python-pytest-asyncio-0.23 python-pytest-cov python-pytest-timeout python-setuptools python-wheel redis)) (propagated-inputs (list python-async-timeout)) (home-page "https://github.com/redis/redis-py") (synopsis "Redis Python client") (description "This package provides a Python interface to the Redis key-value store.") (license license:expat))) (define-public python-aioredis (deprecated-package "python-aioredis" python-redis)) (define-public python-rq (package (name "python-rq") (version "1.11.1") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/rq/rq") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0dnjm2s036l4j4ypq0h903vh132dp2wiwjrn8jicz1nw829dqpzf")))) (build-system python-build-system) (arguments '(#:phases (modify-phases %standard-phases (add-before 'check 'start-redis (lambda _ (invoke "redis-server" "--daemonize" "yes"))) (replace 'check (lambda* (#:key outputs #:allow-other-keys) (let ((out (assoc-ref outputs "out"))) ;; Drop test that needs the SDK for Sentry.io. (delete-file "tests/test_sentry.py") ;; Ensure 'rq' and 'rqworker' ends up on PATH. (setenv "PATH" (string-append out "/bin:" (getenv "PATH"))) (invoke "pytest" "-vv"))))))) (native-inputs (list python-mock python-psutil python-pytest redis)) (propagated-inputs (list python-click python-redis)) (home-page "https://python-rq.org/") (synopsis "Simple job queues for Python") (description "RQ (Redis Queue) is a simple Python library for queueing jobs and processing them in the background with workers. It is backed by Redis and it is designed to have a low barrier to entry.") (license license:bsd-2))) (define-public python-rq-scheduler (package (name "python-rq-scheduler") (version "0.10.0") (home-page "https://github.com/rq/rq-scheduler") (source (origin (method git-fetch) (uri (git-reference (url home-page) (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0xg6yazqs5kbr2ayvhvljs1h5vgx5k5dds613fmhswln7gglf9hk")))) (build-system python-build-system) (arguments '(#:phases (modify-phases %standard-phases (add-before 'check 'start-redis (lambda _ (invoke "redis-server" "--daemonize" "yes"))) (replace 'check (lambda _ (substitute* "run_tests.py" (("/usr/bin/env") (which "env"))) (invoke "./run_tests.py")))))) (native-inputs (list redis which)) (propagated-inputs (list python-croniter python-rq)) (synopsis "Job scheduling capabilities for RQ (Redis Queue)") (description "This package provides job scheduling capabilities to @code{python-rq} (Redis Queue).") (license license:expat))) (define-public python-sqlparse (package (name "python-sqlparse") (version "0.4.3") (source (origin (method url-fetch) (uri (pypi-uri "sqlparse" version)) (sha256 (base32 "0s3jyllg0ka0n7pgqfng1hzvh39li853dr40qcp4s4dv8r481jk9")))) (build-system python-build-system) (arguments `(#:phases (modify-phases %standard-phases (replace 'check (lambda _ (invoke "py.test"))) ;; XXX: The regular wrap phase ends up storing pytest as a runtime ;; dependency. See <https://bugs.gnu.org/25235>. (replace 'wrap (lambda* (#:key native-inputs inputs outputs #:allow-other-keys) (let* ((out (assoc-ref outputs "out")) (python (assoc-ref (or native-inputs inputs) "python")) (sitedir (string-append "/lib/python" (python-version python) "/site-packages"))) (wrap-program (string-append out "/bin/sqlformat") `("PYTHONPATH" ":" prefix ,(map (lambda (output) (string-append output sitedir)) (list python out)))))))))) (native-inputs (list python-pytest)) (inputs (list bash-minimal)) (home-page "https://github.com/andialbrecht/sqlparse") (synopsis "Non-validating SQL parser") (description "Sqlparse is a non-validating SQL parser for Python. It provides support for parsing, splitting and formatting SQL statements.") (license license:bsd-3) (properties '((cpe-name . "sqlparse"))))) (define-public python-sql (package (name "python-sql") (version "1.3.0") (source (origin (method url-fetch) (uri (pypi-uri "python-sql" version)) (sha256 (base32 "0xnimfzlxj1ddrb5xj3s4gaii278a0gpxrvwmdmrdxgjfdi3lq4x")))) (build-system python-build-system) (home-page "https://python-sql.tryton.org/") (synopsis "Library to write SQL queries in a pythonic way") (description "@code{python-sql} is a library to write SQL queries, that transforms idiomatic python function calls to well-formed SQL queries.") (license license:bsd-3))) (define-public python-pypika (package (name "python-pypika") (version "0.47.6") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/kayak/pypika") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "001pg36sw9a36zdd1kccbymcxndphjcjbbrsy6ri7ng8h4dgz549")))) (build-system python-build-system) (native-inputs (list python-parameterized)) (home-page "https://github.com/kayak/pypika") (synopsis "SQL query builder API for Python") (description "PyPika is a python SQL query builder that exposes the full richness of the SQL language using a syntax that reflects the resulting query.") (license license:asl2.0))) (define-public apache-orc (package (name "apache-orc") (version "2.0.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/apache/orc") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "1fi6d045wakks0x8clplyxgal342kljqjql7vq5gbd6a2qnaz6m2")))) (build-system cmake-build-system) (arguments (list #:build-type "Release" #:configure-flags #~(list "-DBUILD_JAVA=OFF" "-DINSTALL_VENDORED_LIBS=OFF" "-DCMAKE_CXX_FLAGS=-fPIC" (string-append "-DGTEST_HOME=" #$(this-package-native-input "googletest")) (string-append "-DZSTD_HOME=" (assoc-ref %build-inputs "zstd:lib")) (string-append "-DZLIB_HOME=" #$(this-package-input "zlib")) (string-append "-DPROTOBUF_HOME=" #$(this-package-input "protobuf")) (string-append "-DLZ4_HOME=" #$(this-package-input "lz4")) (string-append "-DSNAPPY_HOME=" #$(this-package-input "snappy"))) #:phases #~(modify-phases %standard-phases (add-after 'unpack 'disable-bad-test (lambda _ ;; This one test fails with an obscure error: ;; ;; Expected: (std::string::npos) != (error.find(error_msg)), ;; actual: 18446744073709551615 vs 18446744073709551615 (substitute* "tools/test/TestFileScan.cc" (("findProgram\\(\"tools/src/orc-scan\"\\);" m) (string-append m "return;"))))) (add-after 'unpack 'do-not-download-orc-format (lambda _ (substitute* "cmake_modules/ThirdpartyToolchain.cmake" (("URL \"https://archive.apache.org/dist/orc/orc-format.*") (string-append "URL \"file://" #$(this-package-native-input "orc-format") "\"\n"))))) (add-after 'unpack 'timezone-fallback (lambda _ ;; In the build container we don't have /etc/localtime (substitute* "c++/src/Timezone.cc" (("return getTimezoneByFilename\\(LOCAL_TIMEZONE\\);") "if (!std::filesystem::exists(std::filesystem::path(LOCAL_TIMEZONE))) { return getTimezoneByName(\"UTC\"); } return getTimezoneByFilename(LOCAL_TIMEZONE);")))) (add-before 'check 'pre-check (lambda* (#:key inputs #:allow-other-keys) (setenv "TZDIR" (search-input-directory inputs "share/zoneinfo"))))))) (inputs `(("lz4" ,lz4) ("protobuf" ,protobuf) ("snappy" ,snappy) ("zlib" ,zlib "static") ("zstd" ,zstd) ("zstd:lib" ,zstd "lib"))) (native-inputs `(("googletest" ,googletest) ("orc-format" ,(origin (method url-fetch) (uri "https://archive.apache.org/dist/orc/orc-format-1.0.0/\ orc-format-1.0.0.tar.gz") (sha256 (base32 "1mccbna3mqhhlqs4pw0fa4pgjnq4c41jhxrh84mq27sbz5gsx7vk")))) ("pkg-config" ,pkg-config) ("tzdata" ,tzdata-for-tests))) (home-page "https://orc.apache.org/") (synopsis "Columnar storage for Hadoop workloads") (description "ORC is a self-describing type-aware columnar file format designed for Hadoop workloads. It is optimized for large streaming reads, but with integrated support for finding required rows quickly.") (license license:asl2.0))) ;; There are many wrappers for this in other languages. When touching, please ;; be sure to ensure all dependencies continue to build. (define-public apache-arrow (package (name "apache-arrow") (version "17.0.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/apache/arrow") (commit (string-append "apache-arrow-" version)))) (file-name (git-file-name name version)) (sha256 (base32 "11yzhqdvvcq8k4dhcfnwhc0hl0a2k09gyijln00zbglajk7ihfsk")))) (build-system cmake-build-system) (arguments (list #:tests? #f #:phases #~(modify-phases %standard-phases (add-before 'configure 'enter-source-directory (lambda _ (chdir "cpp"))) (add-after 'unpack 'set-env (lambda* (#:key inputs #:allow-other-keys) (substitute* "cpp/cmake_modules/ThirdpartyToolchain.cmake" (("set\\(xsimd_SOURCE.*") "")) (setenv "BOOST_ROOT" #$(this-package-input "boost")) (setenv "BROTLI_HOME" #$(this-package-input "brotli")) (setenv "FLATBUFFERS_HOME" #$(this-package-input "flatbuffers")) (setenv "RAPIDJSON_HOME" #$(this-package-input "rapidjson"))))) #:build-type "Release" #:configure-flags #~(list "-DARROW_PYTHON=ON" ;; Parquet options "-DARROW_PARQUET=ON" "-DPARQUET_BUILD_EXECUTABLES=ON" ;; The maintainers disallow using system versions of ;; jemalloc: ;; https://issues.apache.org/jira/browse/ARROW-3507. This ;; is unfortunate because jemalloc increases performance: ;; https://arrow.apache.org/blog/2018/07/20/jemalloc/. "-DARROW_JEMALLOC=OFF" ;; The CMake option ARROW_DEPENDENCY_SOURCE is a global ;; option that instructs the build system how to resolve ;; each dependency. SYSTEM = Finding the dependency in ;; system paths using CMake's built-in find_package ;; function, or using pkg-config for packages that do not ;; have this feature "-DARROW_DEPENDENCY_SOURCE=SYSTEM" "-Dxsimd_SOURCE=SYSTEM" "-DARROW_RUNTIME_SIMD_LEVEL=NONE" "-DARROW_SIMD_LEVEL=NONE" "-DARROW_PACKAGE_KIND=Guix" ;; Split output into its component packages. (string-append "-DCMAKE_INSTALL_PREFIX=" #$output:lib) (string-append "-DCMAKE_INSTALL_RPATH=" #$output:lib "/lib") (string-append "-DCMAKE_INSTALL_BINDIR=" #$output "/bin") (string-append "-DCMAKE_INSTALL_INCLUDEDIR=" #$output:include "/share/include") "-DARROW_WITH_SNAPPY=ON" "-DARROW_WITH_ZLIB=ON" "-DARROW_WITH_ZSTD=ON" "-DARROW_WITH_LZ4=ON" "-DARROW_COMPUTE=ON" "-DARROW_CSV=ON" "-DARROW_DATASET=ON" "-DARROW_FILESYSTEM=ON" "-DARROW_HDFS=ON" "-DARROW_JSON=ON" ;; Arrow Python C++ integration library (required for ;; building pyarrow). This library must be built against ;; the same Python version for which you are building ;; pyarrow. NumPy must also be installed. Enabling this ;; option also enables ARROW_COMPUTE, ARROW_CSV, ;; ARROW_DATASET, ARROW_FILESYSTEM, ARROW_HDFS, and ;; ARROW_JSON. "-DARROW_PYTHON=ON" "-DARROW_ORC=ON" "-DORC_SOURCE=SYSTEM" ;; Building the tests forces on all the ;; optional features and the use of static ;; libraries. "-DARROW_BUILD_TESTS=OFF" ;;"-DBENCHMARK_ENABLE_TESTING=OFF" "-DARROW_BUILD_STATIC=OFF"))) (inputs (list apache-orc boost brotli bzip2 double-conversion gflags glog grpc protobuf python python-numpy rapidjson re2 snappy xsimd)) ;; These are all listed under Requires.private in arrow.pc (propagated-inputs (list `(,apache-thrift "lib") lz4 utf8proc zlib `(,zstd "lib"))) (native-inputs (list pkg-config)) (outputs '("out" "lib" "include")) (home-page "https://arrow.apache.org/") (synopsis "Columnar in-memory analytics") (description "Apache Arrow is a columnar in-memory analytics layer designed to accelerate big data. It houses a set of canonical in-memory representations of flat and hierarchical data along with multiple language-bindings for structure manipulation. It also provides IPC and common algorithm implementations.") (license license:asl2.0))) (define-public apache-arrow-for-ceph (package (name "apache-arrow") (version "6.0.1") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/apache/arrow") (commit (string-append "apache-arrow-" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0mcw361akqw4sxnnpnr9c9v1zk4hphk6gcq763pcb19yzljh88ig")))) (build-system cmake-build-system) (arguments `(#:tests? #f #:phases (modify-phases %standard-phases (add-before 'configure 'enter-source-directory (lambda _ (chdir "cpp"))) (add-after 'unpack 'set-env (lambda* (#:key inputs #:allow-other-keys) (substitute* "cpp/src/parquet/parquet.pc.in" (("includedir=\\$\\{prefix\\}/") "includedir=")) (substitute* "cpp/cmake_modules/ThirdpartyToolchain.cmake" (("set\\(xsimd_SOURCE.*") "")) (setenv "BOOST_ROOT" (assoc-ref inputs "boost")) (setenv "BROTLI_HOME" (assoc-ref inputs "brotli")) (setenv "FLATBUFFERS_HOME" (assoc-ref inputs "flatbuffers")) (setenv "RAPIDJSON_HOME" (assoc-ref inputs "rapidjson"))))) #:build-type "Release" #:configure-flags (list "-DARROW_PYTHON=ON" "-DARROW_GLOG=ON" ;; Parquet options "-DARROW_PARQUET=ON" "-DPARQUET_BUILD_EXECUTABLES=ON" ;; The maintainers disallow using system versions of ;; jemalloc: ;; https://issues.apache.org/jira/browse/ARROW-3507. This ;; is unfortunate because jemalloc increases performance: ;; https://arrow.apache.org/blog/2018/07/20/jemalloc/. "-DARROW_JEMALLOC=OFF" ;; The CMake option ARROW_DEPENDENCY_SOURCE is a global ;; option that instructs the build system how to resolve ;; each dependency. SYSTEM = Finding the dependency in ;; system paths using CMake's built-in find_package ;; function, or using pkg-config for packages that do not ;; have this feature "-DARROW_DEPENDENCY_SOURCE=SYSTEM" "-Dxsimd_SOURCE=SYSTEM" "-DARROW_RUNTIME_SIMD_LEVEL=NONE" "-DARROW_SIMD_LEVEL=NONE" "-DARROW_PACKAGE_KIND=Guix" ;; Split output into its component packages. (string-append "-DCMAKE_INSTALL_PREFIX=" (assoc-ref %outputs "lib")) (string-append "-DCMAKE_INSTALL_RPATH=" (assoc-ref %outputs "lib") "/lib") (string-append "-DCMAKE_INSTALL_BINDIR=" (assoc-ref %outputs "out") "/bin") (string-append "-DCMAKE_INSTALL_INCLUDEDIR=" (assoc-ref %outputs "include") "/share/include") "-DARROW_WITH_SNAPPY=ON" "-DARROW_WITH_ZLIB=ON" "-DARROW_WITH_ZSTD=ON" "-DARROW_WITH_LZ4=ON" "-DARROW_COMPUTE=ON" "-DARROW_CSV=ON" "-DARROW_DATASET=ON" "-DARROW_FILESYSTEM=ON" "-DARROW_HDFS=ON" "-DARROW_JSON=ON" ;; Arrow Python C++ integration library (required for ;; building pyarrow). This library must be built against ;; the same Python version for which you are building ;; pyarrow. NumPy must also be installed. Enabling this ;; option also enables ARROW_COMPUTE, ARROW_CSV, ;; ARROW_DATASET, ARROW_FILESYSTEM, ARROW_HDFS, and ;; ARROW_JSON. "-DARROW_PYTHON=ON" ;; Building the tests forces on all the ;; optional features and the use of static ;; libraries. "-DARROW_BUILD_TESTS=OFF" "-DBENCHMARK_ENABLE_GTEST_TESTS=OFF" ;;"-DBENCHMARK_ENABLE_TESTING=OFF" "-DARROW_BUILD_STATIC=OFF"))) (inputs (list boost brotli bzip2 double-conversion gflags glog grpc protobuf python python-numpy rapidjson re2 snappy xsimd)) ;; These are all listed under Requires.private in arrow.pc (propagated-inputs (list (list apache-thrift "lib") lz4 utf8proc zlib (list zstd "lib"))) (native-inputs (list pkg-config)) (outputs '("out" "lib" "include")) (home-page "https://arrow.apache.org/") (synopsis "Columnar in-memory analytics") (description "Apache Arrow is a columnar in-memory analytics layer designed to accelerate big data. It houses a set of canonical in-memory representations of flat and hierarchical data along with multiple language-bindings for structure manipulation. It also provides IPC and common algorithm implementations.") (license license:asl2.0))) (define-public apache-arrow-0.16 (package (name "apache-arrow") (version "0.16.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/apache/arrow") (commit (string-append "apache-arrow-" version)))) (file-name (git-file-name name version)) (sha256 (base32 "15bplqy5708bxy1mynzjkd3d2g8v2wd36z8l0ap8yyyq54l3gdvy")))) (build-system cmake-build-system) (arguments `(#:tests? #f #:phases (modify-phases %standard-phases (add-before 'configure 'enter-source-directory (lambda _ (chdir "cpp") (substitute* "src/parquet/CMakeLists.txt" ((" parquet_constants.cpp") "") (("set\\(THRIFT_OUTPUT_FILES \\$\\{THRIFT_OUTPUT_FILES\\}.*") "") ((".*\"\\$\\{THRIFT_OUTPUT_DIR\\}/parquet_constants.cpp\"\\).*") "")))) (add-after 'unpack 'set-env (lambda _ (setenv "BOOST_ROOT" (assoc-ref %build-inputs "boost")) (setenv "BROTLI_HOME" (assoc-ref %build-inputs "brotli")) (setenv "FLATBUFFERS_HOME" (assoc-ref %build-inputs "flatbuffers")) (setenv "RAPIDJSON_HOME" (assoc-ref %build-inputs "rapidjson"))))) #:build-type "Release" #:configure-flags (list "-DARROW_PYTHON=ON" "-DARROW_GLOG=ON" "-DARROW_SSE42=OFF" "-DARROW_BOOST_USE_SHARED=ON" ;; Parquet options "-DARROW_PARQUET=ON" ;; The maintainers disallow using system versions of ;; jemalloc: ;; https://issues.apache.org/jira/browse/ARROW-3507. This ;; is unfortunate because jemalloc increases performance: ;; https://arrow.apache.org/blog/2018/07/20/jemalloc/. "-DARROW_JEMALLOC=OFF" ;; The CMake option ARROW_DEPENDENCY_SOURCE is a global ;; option that instructs the build system how to resolve ;; each dependency. SYSTEM = Finding the dependency in ;; system paths using CMake's built-in find_package ;; function, or using pkg-config for packages that do not ;; have this feature "-DARROW_DEPENDENCY_SOURCE=SYSTEM" ;; Split output into its component packages. (string-append "-DCMAKE_INSTALL_PREFIX=" (assoc-ref %outputs "out")) (string-append "-DCMAKE_INSTALL_RPATH=" (assoc-ref %outputs "out") "/lib") (string-append "-DCMAKE_INSTALL_BINDIR=" (assoc-ref %outputs "out") "/bin") (string-append "-DCMAKE_INSTALL_INCLUDEDIR=" (assoc-ref %outputs "include") "/share/include") "-DARROW_WITH_SNAPPY=ON" "-DARROW_WITH_ZLIB=ON" "-DARROW_WITH_ZSTD=ON" "-DARROW_WITH_LZ4=ON" "-DARROW_COMPUTE=ON" "-DARROW_CSV=ON" "-DARROW_DATASET=ON" "-DARROW_FILESYSTEM=ON" "-DARROW_HDFS=ON" "-DARROW_JSON=ON" ;; Arrow Python C++ integration library (required for ;; building pyarrow). This library must be built against ;; the same Python version for which you are building ;; pyarrow. NumPy must also be installed. Enabling this ;; option also enables ARROW_COMPUTE, ARROW_CSV, ;; ARROW_DATASET, ARROW_FILESYSTEM, ARROW_HDFS, and ;; ARROW_JSON. "-DARROW_PYTHON=ON" ;; Building the tests forces on all the ;; optional features and the use of static ;; libraries. "-DARROW_BUILD_TESTS=OFF" "-DBENCHMARK_ENABLE_GTEST_TESTS=OFF" ;;"-DBENCHMARK_ENABLE_TESTING=OFF" "-DARROW_BUILD_STATIC=OFF"))) (inputs `(("boost" ,boost) ("brotli" ,brotli) ("double-conversion" ,double-conversion) ("snappy" ,snappy) ("gflags" ,gflags) ("glog" ,glog) ("apache-thrift" ,apache-thrift "lib") ("protobuf" ,protobuf) ("rapidjson" ,rapidjson) ("zlib" ,zlib) ("bzip2" ,bzip2) ("lz4" ,lz4) ("zstd" ,zstd "lib") ("re2" ,re2) ("grpc" ,grpc) ("python-3" ,python) ("python-numpy" ,python-numpy))) (native-inputs (list pkg-config apache-thrift)) (outputs '("out" "include")) (home-page "https://arrow.apache.org/") (synopsis "Columnar in-memory analytics") (description "Apache Arrow is a columnar in-memory analytics layer designed to accelerate big data. It houses a set of canonical in-memory representations of flat and hierarchical data along with multiple language-bindings for structure manipulation. It also provides IPC and common algorithm implementations.") (license license:asl2.0))) (define-public python-pyarrow (package (inherit apache-arrow) (name "python-pyarrow") (build-system python-build-system) (arguments (list ;; XXX: Test data is distributed sepratly in ;; <https://github.com/apache/arrow-testing> 39MiB and requires ;; additional steps to be implemented, see ;; <https://github.com/apache/arrow/blob/main/ci/scripts/python_build.sh>. #:tests? #f #:phases #~(modify-phases %standard-phases (delete 'build) ; XXX the build is performed again during the install phase (add-after 'unpack 'enter-source-directory (lambda _ (chdir "python"))) (add-after 'enter-source-directory 'set-version (lambda _ ;; XXX: This python-setuptools-scm option is available in v8+: ;; TypeError: Configuration.__init__() got an unexpected ;; keyword argument 'version_file' (substitute* "pyproject.toml" (("version_file = .*") "")) ;; Version file generation ad-hoc, remove when a newer version ;; of python-setuptools-scm is packed. (with-output-to-file "pyarrow/_generated_version.py" (let* ((version #$(package-version this-package) ) (version-tuple (string-join (string-split version #\.) ", "))) (lambda () (format #t "__version__ = version = '~a' __version_tuple__ = version_tuple = (~a)~%" version version-tuple)))))) (add-before 'install 'set-pyarrow-build-options (lambda _ (setenv "PYARROW_BUNDLE_ARROW_CPP_HEADERS" "0") (setenv "PYARROW_CMAKE_OPTIONS" (string-append "-DCMAKE_INSTALL_RPATH=" #$output)) (setenv "PYARROW_PARALLEL" (number->string (parallel-job-count))) (setenv "PYARROW_WITH_DATASET" "1") (setenv "PYARROW_WITH_HDFS" "1") (setenv "PYARROW_WITH_ORC" "1") (setenv "PYARROW_WITH_PARQUET" "1")))))) (propagated-inputs (list (list apache-arrow "lib") (list apache-arrow "include") apache-orc python-numpy python-pandas python-six)) (native-inputs (list cmake-minimal pkg-config python-cython python-pytest python-pytest-runner python-setuptools-scm)) (outputs '("out")) (home-page "https://arrow.apache.org/docs/python/") (synopsis "Python bindings for Apache Arrow") (description "This library provides a Pythonic API wrapper for the reference Arrow C++ implementation, along with tools for interoperability with pandas, NumPy, and other traditional Python scientific computing packages.") (license license:asl2.0))) (define-public python-pyarrow-0.16 (package (inherit apache-arrow-0.16) (name "python-pyarrow") (build-system python-build-system) (arguments '(#:tests? #f ; XXX There are no tests in the "python" directory #:phases (modify-phases %standard-phases (delete 'build) ; XXX the build is performed again during the install phase (add-after 'unpack 'enter-source-directory (lambda _ (chdir "python"))) (add-after 'unpack 'make-git-checkout-writable (lambda _ (for-each make-file-writable (find-files ".")))) (add-before 'install 'patch-cmake-variables (lambda* (#:key inputs #:allow-other-keys) ;; Replace cmake locations with hardcoded guix links for the ;; underlying C++ library and headers. This is a pretty awful ;; hack. (substitute* "cmake_modules/FindParquet.cmake" (("# Licensed to the Apache Software Foundation" m) (string-append "set(PARQUET_INCLUDE_DIR \"" (assoc-ref inputs "apache-arrow:include") "/share/include\")\n" m)) (("find_package_handle_standard_args" m) (string-append "set(PARQUET_LIB_DIR \"" (assoc-ref inputs "apache-arrow:lib") "/lib\")\n" m))))) (add-before 'install 'patch-parquet-library (lambda _ (substitute* "CMakeLists.txt" (("parquet_shared") "parquet")))) (add-before 'install 'set-PYARROW_WITH_PARQUET (lambda _ (setenv "PYARROW_WITH_PARQUET" "1")))))) (propagated-inputs `(("apache-arrow:lib" ,apache-arrow-0.16) ("apache-arrow:include" ,apache-arrow-0.16 "include") ("python-numpy" ,python-numpy) ("python-pandas" ,python-pandas) ("python-six" ,python-six))) (native-inputs (list cmake-minimal pkg-config python-cython python-pytest python-pytest-runner python-setuptools-scm)) (outputs '("out")) (home-page "https://arrow.apache.org/docs/python/") (synopsis "Python bindings for Apache Arrow") (description "This library provides a Pythonic API wrapper for the reference Arrow C++ implementation, along with tools for interoperability with pandas, NumPy, and other traditional Python scientific computing packages.") (license license:asl2.0))) (define-public python-fastparquet (package (name "python-fastparquet") (version "2024.2.0") (source (origin ;; Fastparquet uses setuptools-scm to find the current version. This ;; only works when we use the PyPI tarball, which does not contain ;; tests. Instead, we use the git-fetch method and set the version via ;; envar. (method git-fetch) (uri (git-reference (url "https://github.com/dask/fastparquet") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "0f32dj1xvd11l0siznqd33dpjlhg9siylcjcfkcdlqfcy45jfj3v")))) (build-system pyproject-build-system) (arguments (list #:test-flags #~(list "--numprocesses" (number->string (parallel-job-count))) #:phases #~(modify-phases %standard-phases (add-after 'unpack 'relax-requirements (lambda _ (substitute* "setup.py" ;; Remove dependencies on git. (("^.*\"git\", \"status\".*$") "") ;; Guix is only compatible with a single version of numpy ;; at a time. We can safely remove this dependency. (("'oldest-supported-numpy'") "")))) (add-before 'build 'pretend-version ;; The version string is usually derived via setuptools-scm, but ;; without the git metadata available, the version string is set ;; to '0.0.0'. (lambda _ (setenv "SETUPTOOLS_SCM_PRETEND_VERSION" #$version))) (add-before 'check 'build-cython-extensions ;; Cython extensions need to be built for the check phase. (lambda _ (invoke "python" "setup.py" "build_ext" "--inplace")))))) (propagated-inputs (list python-cramjam python-fsspec python-lzo python-numpy python-packaging python-pandas)) (native-inputs (list python-cython python-pytest-runner python-pytest-xdist python-setuptools-scm)) (home-page "https://github.com/dask/fastparquet") (synopsis "Python implementation of the Parquet file format") (description "@code{fastparquet} is a Python implementation of the Parquet file format. @code{fastparquet} is used implicitly by @code{dask}, @code{pandas} and @code{intake-parquet}. It supports the following compression algorithms: @itemize @item Gzip @item Snappy @item Brotli @item LZ4 @item Zstd @item LZO (optionally) @end itemize") (license license:asl2.0))) (define-public python-crate (package (name "python-crate") (version "0.23.2") (source (origin (method url-fetch) (uri (pypi-uri "crate" version)) (sha256 (base32 "0ngmlvi320c5gsxab0s7qgq0ck4jdlcwvb6lbjhnfprafdp56vvx")))) (build-system python-build-system) (propagated-inputs (list python-urllib3)) (home-page "https://github.com/crate/crate-python") (synopsis "CrateDB Python client") (description "This package provides a Python client library for CrateDB. It implements the Python DB API 2.0 specification and includes support for SQLAlchemy.") (license license:asl2.0))) (define-public libdbi (package (name "libdbi") (version "0.9.0") (source (origin (method url-fetch) (uri (string-append "mirror://sourceforge/libdbi/libdbi/libdbi-" version "/libdbi-" version ".tar.gz")) (sha256 (base32 "00s5ra7hdlq25iv23nwf4h1v3kmbiyzx0v9bhggjiii4lpf6ryys")))) (build-system gnu-build-system) (synopsis "Database independent abstraction layer in C") (description "This library implements a database independent abstraction layer in C, similar to the DBI/DBD layer in Perl. Writing one generic set of code, programmers can leverage the power of multiple databases and multiple simultaneous database connections by using this framework.") (home-page "https://libdbi.sourceforge.net/") (license license:lgpl2.1+))) (define-public libdbi-drivers (package (name "libdbi-drivers") (version "0.9.0") (source (origin (method url-fetch) (uri (string-append "mirror://sourceforge/libdbi-drivers/" "libdbi-drivers/libdbi-drivers-" version "/libdbi-drivers-" version ".tar.gz")) (sha256 (base32 "0m680h8cc4428xin4p733azysamzgzcmv4psjvraykrsaz6ymlj3")))) (build-system gnu-build-system) (native-inputs (list ;; For tests. inetutils glibc-locales mariadb)) (inputs `(("libdbi" ,libdbi) ("mariadb:dev" ,mariadb "dev") ("mariadb:lib" ,mariadb "lib") ("postgresql" ,postgresql) ("sqlite" ,sqlite))) (arguments `(#:configure-flags (let ((libdbi (assoc-ref %build-inputs "libdbi")) (mysql:inc (assoc-ref %build-inputs "mariadb:dev")) (mysql:lib (assoc-ref %build-inputs "mariadb:lib")) (postgresql (assoc-ref %build-inputs "postgresql")) (sqlite (assoc-ref %build-inputs "sqlite"))) (list "--disable-docs" (string-append "--with-dbi-incdir=" libdbi "/include") (string-append "--with-dbi-libdir=" libdbi "/lib") "--with-mysql" (string-append "--with-mysql-incdir=" mysql:inc "/include/mysql") (string-append "--with-mysql-libdir=" mysql:lib "/lib") "--with-pgsql" (string-append "--with-pgsql-incdir=" postgresql "/include") (string-append "--with-pgsql-libdir=" postgresql "/lib") "--with-sqlite3" (string-append "--with-sqlite-incdir=" sqlite "/include") (string-append "--with-sqlite-libdir=" sqlite "/lib"))) #:tests? #f ; FIXME: Find why the tests get stuck forever. #:phases (modify-phases %standard-phases (add-after 'unpack 'fix-tests (lambda* (#:key inputs #:allow-other-keys) (substitute* "tests/test_mysql.sh" (("^MYMYSQLD=.*") (string-append "MYMYSQLD=" (assoc-ref inputs "mariadb") "/bin/mysqld"))) #t)) (add-after 'install 'remove-empty-directories (lambda* (#:key outputs #:allow-other-keys) (let ((var (string-append (assoc-ref outputs "out") "/var"))) (delete-file-recursively var)) #t))))) (synopsis "Database drivers for the libdbi framework") (description "The @code{libdbi-drivers} library provides the database specific drivers for the @code{libdbi} framework. The drivers officially supported by @code{libdbi} are: @itemize @item MySQL, @item PostgreSQL, @item SQLite. @end itemize") (home-page "https://libdbi-drivers.sourceforge.net/") (license license:lgpl2.1+))) (define-public soci (package (name "soci") (version "4.0.3") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/SOCI/soci/") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "12aq7pama96l2c1kmfkclb4bvrsxs9a8ppgk5gmzw45w2lg35i0y")))) (build-system cmake-build-system) (propagated-inputs ;; Headers of soci has include-references to headers of these inputs. `(("firebird" ,firebird) ("postgresql" ,postgresql) ("sqlite" ,sqlite) ("odbc" ,unixodbc) ("boost" ,boost) ("mariadb:dev" ,mariadb "dev"))) (arguments `(#:configure-flags ;; C++11 (-DSOCI_CXX11) is OFF by default. hyperledger-iroha needs it. (list "-DCMAKE_CXX_STANDARD=17" "-DSOCI_LIBDIR=lib" ;; This is for relocation when linking statically "-DCMAKE_CXX_FLAGS=-fPIE") #:tests? #f)) ; may require running database management systems (synopsis "C++ Database Access Library") (description "SOCI is an abstraction layer for several database backends, including PostreSQL, SQLite, ODBC and MySQL.") (home-page "https://soci.sourceforge.net/") (license license:boost1.0))) (define-public freetds (package (name "freetds") (version "1.2.20") (source (origin (method url-fetch) (uri (string-append "https://www.freetds.org/files/stable/" "freetds-" version ".tar.gz")) (sha256 (base32 "11fzwcahc1bc8npxbif0448v9cwyf7k04167i7fcspmfw7a0hj0d")))) (build-system gnu-build-system) (arguments ;; NOTE: (Sharlatan-20210110213908+0000) some tests require DB connection, ;; disabled for now. `(#:tests? #f)) (home-page "https://www.freetds.org/") (synopsis "Client libraries for MS SQL and Sybase servers") (description "FreeTDS is an implementation of the Tabular DataStream protocol, used for connecting to MS SQL and Sybase servers over TCP/IP.") (license license:lgpl2.0+))) (define-public python-tinydb (package (name "python-tinydb") (version "4.8.0") (source (origin (method url-fetch) (uri (pypi-uri "tinydb" version)) (sha256 (base32 "0r6mavw0wm03lbmqbgglsyff3vws86ddg3q8h29glpd7qnlqdmkd")))) (build-system pyproject-build-system) (native-inputs (list python-poetry-core python-pytest)) (home-page "https://github.com/msiemens/tinydb") (synopsis "TinyDB is a lightweight document oriented database") (description "TinyDB is a small document oriented database written in pure Python with no external dependencies. The targets are small apps that would be blown away by a SQL-DB or an external database server.") (license license:expat))) (define-public sequeler (package (name "sequeler") (version "0.8.2") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/Alecaddd/sequeler") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0biggmsn8k7j6pdrwk29whl56qlfgvf5d9vjpgz4nyqih56wgh9j")))) (build-system meson-build-system) (arguments '(#:glib-or-gtk? #t #:phases (modify-phases %standard-phases (add-after 'unpack 'skip-gtk-update-icon-cache ;; Don't create 'icon-theme.cache'. (lambda _ (substitute* "build-aux/meson_post_install.py" (("gtk-update-icon-cache") "true") (("update-desktop-database") "true"))))))) (native-inputs `(;("appstream-glib" ,appstream-glib) ; validation fails for lack of network ("gettext-minimal" ,gettext-minimal) ("glib:bin" ,glib "bin") ; for glib-compile-resources ("gtk+" ,gtk+ "bin") ("pkg-config" ,pkg-config) ("vala" ,vala))) (inputs `(("glib" ,glib) ("granite" ,granite) ("gsettings-desktop-schemas" ,gsettings-desktop-schemas) ("gtk+" ,gtk+) ("gtksourceview-3" ,gtksourceview-3) ("libgda" ,libgda) ("libgee" ,libgee) ("libsecret" ,libsecret) ("libssh2" ,libssh2) ("libxml2" ,libxml2))) (synopsis "Friendly SQL Client") (description "Sequeler is a native Linux SQL client built in Vala and Gtk. It allows you to connect to your local and remote databases, write SQL in a handy text editor with language recognition, and visualize SELECT results in a Gtk.Grid Widget.") (home-page "https://github.com/Alecaddd/sequeler") (license license:gpl2+))) (define-public sqlitebrowser (package (name "sqlitebrowser") (version "3.13.0") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/sqlitebrowser/sqlitebrowser") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0v4a59lgqng9hqvbc2k504aclinpwpk8hi6ckirbr6m1pnf26kfr")) (modules '((guix build utils))) (snippet '(begin (delete-file-recursively "libs/qcustomplot-source/") (delete-file-recursively "libs/qhexedit/") (delete-file-recursively "libs/qscintilla"))))) (build-system qt-build-system) (arguments (list #:configure-flags ;; TODO: Unbundle json (nlohmann-json). #~(list (string-append "-DQSCINTILLA_INCLUDE_DIR=" #$(this-package-input "qscintilla") "/include/Qsci") "-DFORCE_INTERNAL_QCUSTOMPLOT=OFF" "-DFORCE_INTERNAL_QHEXEDIT=OFF" "-DENABLE_TESTING=ON"))) (inputs (list qcustomplot qhexedit qscintilla qtbase-5 sqlite)) (native-inputs (list qttools-5)) (home-page "https://sqlitebrowser.org/") (synopsis "Visual database browser and editor for SQLite") (description "Sqlitebrowser lets you create, design, and edit database files compatible with SQLite using a graphical user interface.") (license ;; dual license (list license:gpl3+ license:mpl2.0)))) (define-public sqls (package (name "sqls") ;; TODO: The latest version requires a way more packages to be available ;; in Guix. (version "0.2.18") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/sqls-server/sqls") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "13837v27avdp2nls3vyy7ml12nj7rxragchwf92adn10ffp4aj6c")))) (build-system go-build-system) (arguments (list #:install-source? #f #:import-path "github.com/lighttiger2505/sqls")) (native-inputs (list go-github-com-google-go-cmp go-github-com-go-sql-driver-mysql go-github-com-k0kubun-pp go-github-com-lib-pq go-github-com-mattn-go-runewidth go-github-com-mattn-go-sqlite3 go-github-com-olekukonko-tablewriter go-github-com-pkg-errors go-github-com-sourcegraph-jsonrpc2 go-golang-org-x-crypto go-golang-org-x-xerrors go-gopkg-in-yaml-v2)) (home-page "https://github.com/sqls-server/sqls") (synopsis "SQL language server written in Go") (description "This package implements the @acronym{LSP, Language Server Protocol} for SQL.") (license license:expat))) (define-public python-dogpile.cache (package (name "python-dogpile.cache") (version "1.1.8") (source (origin (method url-fetch) (uri (pypi-uri "dogpile.cache" version)) (sha256 (base32 "0kpx42vxzss4sz5ic6mp01a97zinzm6q76n8li2gbi4ccfxyhi6q")))) (build-system python-build-system) (arguments '(#:phases (modify-phases %standard-phases (replace 'check (lambda* (#:key tests? #:allow-other-keys) (when tests? (invoke "pytest"))))))) (native-inputs (list python-mako python-pytest)) (propagated-inputs (list python-decorator python-stevedore)) (home-page "https://github.com/sqlalchemy/dogpile.cache") (synopsis "Caching front-end based on the Dogpile lock") (description "@code{dogpile.cache} is a caching API which provides a generic interface to caching backends of any variety, and additionally provides API hooks which integrate these cache backends with the locking mechanism of @code{dogpile}.") (license license:expat))) (define-public datasette (package (name "datasette") (version "1.0a7") (source (origin (method git-fetch) ;for tests (uri (git-reference (url "https://github.com/simonw/datasette") (commit version))) (file-name (git-file-name name version)) (sha256 (base32 "1wwdx2xqkxygbww1nzpr6h702ims6zcxpjskh8fldn1kby591qgg")))) (build-system pyproject-build-system) (arguments (list #:test-flags ;; There are multiple unexplained test failures (see: ;; https://github.com/simonw/datasette/issues/2048). #~(list "-k" (string-append "not (test_database_page_for_database_with_dot_in_name" " or test_row_strange_table_name" " or test_database_with_space_in_name" " or test_tilde_encoded_database_names" " or test_weird_database_names" " or test_css_classes_on_body" " or test_templates_considered" " or test_row_html_compound_primary_key" " or test_edit_sql_link_on_canned_queries" " or test_alternate_url_json" " or test_table_with_slashes_in_name" " or test_searchable" " or test_custom_query_with_unicode_characters" " or test_searchmode)") "-n" (number->string (parallel-job-count)) "-m" "not serial") ;cannot run in parallel #:phases #~(modify-phases %standard-phases (add-after 'unpack 'relax-requirements (lambda _ ;; The package needlessly specifies exact versions ;; of dependencies, when it works fine with others. (substitute* "setup.py" (("(black)==[0-9\\.]+" _ package) package) (("click-default-group-wheel") "click-default-group"))))))) (propagated-inputs (list python-aiofiles python-asgi-csrf python-asgiref python-asyncinject python-click python-click-default-group python-httpx python-hupper python-itsdangerous python-janus python-jinja2 python-mergedeep python-pint python-pluggy python-pyyaml python-sqlite-utils python-uvicorn)) (native-inputs (list python-beautifulsoup4 python-black python-cogapp python-pip python-pytest python-pytest-asyncio python-pytest-runner python-pytest-timeout python-pytest-xdist python-setuptools python-trustme python-wheel)) (home-page "https://datasette.io/") (synopsis "Multi-tool for exploring and publishing data") (description "Datasette is a tool for exploring and publishing data. It helps people take data of any shape or size and publish that as an interactive, explorable website and accompanying API.") (license license:asl2.0)))