scponly: init at 4.8
Co-authored-by: Sandro <sandro.jaeckel@gmail.com>
This commit is contained in:
parent
17631db07c
commit
cd0fa5ae48
3 changed files with 62 additions and 0 deletions
pkgs
39
pkgs/shells/scponly/default.nix
Normal file
39
pkgs/shells/scponly/default.nix
Normal file
|
@ -0,0 +1,39 @@
|
|||
{ stdenv, lib, fetchFromGitHub, openssh, debugLevel ? 0 }:
|
||||
|
||||
stdenv.mkDerivation {
|
||||
pname = "scponly";
|
||||
version = "4.8";
|
||||
|
||||
src = fetchFromGitHub {
|
||||
owner = "scponly";
|
||||
repo = "scponly";
|
||||
rev = "d8ca58257b9905186aa5706f35813d5f80ea07c1";
|
||||
sha256 = "U0K7lOp18ytNjh3KVFmc6vL+/tG4ETnwLEPQEhM4lXE=";
|
||||
};
|
||||
|
||||
patches = [ ./scponly-fix-make.patch ];
|
||||
|
||||
buildInputs = [ openssh ];
|
||||
|
||||
# Add path to sftp-server so configure finds it
|
||||
preConfigure = "export PATH=$PATH:${openssh}/libexec";
|
||||
|
||||
# chroot doesn't seem to work, so not enabling
|
||||
# rsync could also be optionally enabled
|
||||
configureFlags = [ "--enable-winscp-compat" ];
|
||||
|
||||
postInstall = lib.optionalString (debugLevel > 0) ''
|
||||
mkdir -p $out/etc/scponly && echo ${
|
||||
toString debugLevel
|
||||
} > $out/etc/scponly/debuglevel
|
||||
'';
|
||||
|
||||
passthru.shellPath = "/bin/scponly";
|
||||
|
||||
meta = with lib; {
|
||||
description = "A shell that only permits scp and sftp-server";
|
||||
homepage = "https://github.com/scponly/scponly";
|
||||
license = with licenses; [ bsd2 ];
|
||||
maintainers = with maintainers; [ wmertens ];
|
||||
};
|
||||
}
|
21
pkgs/shells/scponly/scponly-fix-make.patch
Normal file
21
pkgs/shells/scponly/scponly-fix-make.patch
Normal file
|
@ -0,0 +1,21 @@
|
|||
--- a/Makefile.in
|
||||
+++ b/Makefile.in
|
||||
@@ -41,14 +41,14 @@
|
||||
${INSTALL} -d ${DESTDIR}${bindir}
|
||||
${INSTALL} -d ${DESTDIR}${mandir}/man8
|
||||
${INSTALL} -d ${DESTDIR}${CONFDIR}
|
||||
- ${INSTALL} -o 0 -g 0 scponly ${DESTDIR}${bindir}/scponly
|
||||
- ${INSTALL} -o 0 -g 0 -m 0644 scponly.8 ${DESTDIR}${mandir}/man8/scponly.8
|
||||
- ${INSTALL} -o 0 -g 0 -m 0644 debuglevel ${DESTDIR}${DEBUGFILE}
|
||||
+ ${INSTALL} scponly ${DESTDIR}${bindir}/scponly
|
||||
+ ${INSTALL} -m 0644 scponly.8 ${DESTDIR}${mandir}/man8/scponly.8
|
||||
+ ${INSTALL} -m 0644 debuglevel ${DESTDIR}${DEBUGFILE}
|
||||
if test "x${CHROOTED_NAME}" != "x"; then \
|
||||
${INSTALL} -d ${DESTDIR}${sbindir}; \
|
||||
rm -f ${DESTDIR}${sbindir}/${CHROOTED_NAME}; \
|
||||
cp scponly ${CHROOTED_NAME}; \
|
||||
- ${INSTALL} -o 0 -g 0 -m 4755 ${CHROOTED_NAME} ${DESTDIR}${sbindir}/${CHROOTED_NAME}; \
|
||||
+ ${INSTALL} ${CHROOTED_NAME} ${DESTDIR}${sbindir}/${CHROOTED_NAME}; \
|
||||
fi
|
||||
|
||||
debuglevel:
|
|
@ -9168,6 +9168,8 @@ in
|
|||
|
||||
pash = callPackage ../shells/pash { };
|
||||
|
||||
scponly = callPackage ../shells/scponly { };
|
||||
|
||||
tcsh = callPackage ../shells/tcsh { };
|
||||
|
||||
rush = callPackage ../shells/rush { };
|
||||
|
|
Loading…
Reference in a new issue