nixpkgs/pkgs/tools/admin/aws-google-auth/default.nix
stuebinm ff1a94e523 treewide: add meta.mainProgram to packages with a single binary
The nixpkgs-unstable channel's programs.sqlite was used to identify
packages producing exactly one binary, and these automatically added
to their package definitions wherever possible.
2024-03-19 03:14:51 +01:00

85 lines
1.6 KiB
Nix

{ lib
, buildPythonApplication
, fetchFromGitHub
, beautifulsoup4
, boto3
, configparser
, filelock
, keyring
, keyrings-alt
, lxml
, pillow
, requests
, six
, tabulate
, tzlocal
, nose
, mock
, setuptools
, aws-google-auth
, testers
, withU2F ? false, python-u2flib-host
}:
buildPythonApplication rec {
pname = "aws-google-auth";
version = "0.0.38";
pyproject = true;
# Pypi doesn't ship the tests, so we fetch directly from GitHub
# https://github.com/cevoaustralia/aws-google-auth/issues/120
src = fetchFromGitHub {
owner = "cevoaustralia";
repo = "aws-google-auth";
rev = "refs/tags/${version}";
sha256 = "sha256-/Xe4RDA9sBEsBBV1VP91VX0VfO8alK8L70m9WrB7qu4=";
};
nativeBuildInputs = [
setuptools
];
propagatedBuildInputs = [
beautifulsoup4
boto3
configparser
filelock
keyring
keyrings-alt
lxml
pillow
requests
six
tabulate
tzlocal
] ++ lib.optional withU2F python-u2flib-host;
nativeCheckInputs = [
mock
nose
];
preCheck = ''
export HOME=$TMPDIR
'';
# with pyproject the tests aren't attempted
# without pyproject the tests try to access internet
doCheck = false;
pythonImportsCheck = [ "aws_google_auth" ];
passthru.tests.version = testers.testVersion {
package = aws-google-auth;
};
meta = with lib; {
description = "Acquire AWS STS (temporary) credentials via Google Apps SAML Single Sign On";
mainProgram = "aws-google-auth";
homepage = "https://github.com/cevoaustralia/aws-google-auth";
maintainers = [ maintainers.marsam ];
license = licenses.mit;
};
}