nixpkgs/pkgs/development/tools/database/sqlcl/default.nix
2022-11-28 21:08:30 -03:00

70 lines
2.3 KiB
Nix

{ lib, stdenv, makeWrapper, requireFile, unzip, jdk }:
let
version = "22.3.1";
fileVersion = "1032109-01";
in
stdenv.mkDerivation {
inherit version;
pname = "sqlcl";
src = requireFile rec {
url = "https://www.oracle.com/database/sqldeveloper/technologies/sqlcl/download/";
name = "V${fileVersion}.zip";
message = ''
This Nix expression requires that ${name} already be part of the store. To
obtain it you need to
- navigate to ${url}
- make sure that it says "Version ${version}" above the list of downloads
- if it does not, click on the "Previous Version" link below the
download and repeat until the version is correct. This is necessary
because as the time of this writing there exists no permanent link
for the current version yet.
Also consider updating this package yourself (you probably just need
to change the `version` variable and update the sha256 to the one of
the new file) or opening an issue at the nixpkgs repo.
- click "Download"
- sign in or create an oracle account if neccessary
- on the next page, click the "${name}" link
and then add the file to the Nix store using either:
nix-store --add-fixed sha256 ${name}
or
nix-prefetch-url --type sha256 file:///path/to/${name}
'';
sha256 = "0yqj8m2zwl8m7zxrzjnbl2rqnl2imn5h1bfpnmklp03nkakbzjbn";
};
nativeBuildInputs = [ makeWrapper unzip ];
unpackCmd = "unzip $curSrc";
installPhase = ''
mkdir -p $out/libexec
mv * $out/libexec/
makeWrapper $out/libexec/bin/sql $out/bin/sqlcl \
--set JAVA_HOME ${jdk.home} \
--chdir "$out/libexec/bin"
'';
meta = with lib; {
description = "Oracle's Oracle DB CLI client";
longDescription = ''
Oracle SQL Developer Command Line (SQLcl) is a free command line
interface for Oracle Database. It allows you to interactively or batch
execute SQL and PL/SQL. SQLcl provides in-line editing, statement
completion, and command recall for a feature-rich experience, all while
also supporting your previously written SQL*Plus scripts.
'';
homepage = "https://www.oracle.com/database/sqldeveloper/technologies/sqlcl/";
license = licenses.unfree;
platforms = [ "x86_64-linux" ];
maintainers = with maintainers; [ misterio77 ];
};
}