diff options
author | Ed Marshall <esm@logic.net> | 2017-03-07 00:11:26 -0800 |
---|---|---|
committer | Ed Marshall <esm@logic.net> | 2017-03-07 00:11:26 -0800 |
commit | 60bc16e457c3caae9e3e5a20e49d5077e87aed5a (patch) | |
tree | 28e899d10fd773513a6efa8d7ef62d548d3ec457 | |
download | vault-ssh-helper-60bc16e457c3caae9e3e5a20e49d5077e87aed5a.tar.gz vault-ssh-helper-60bc16e457c3caae9e3e5a20e49d5077e87aed5a.tar.xz vault-ssh-helper-60bc16e457c3caae9e3e5a20e49d5077e87aed5a.zip |
Initial import
l--------- | vault-ssh-helper-bfed514.tar.gz | 1 | ||||
-rw-r--r-- | vault-ssh-helper.spec | 225 |
2 files changed, 226 insertions, 0 deletions
diff --git a/vault-ssh-helper-bfed514.tar.gz b/vault-ssh-helper-bfed514.tar.gz new file mode 120000 index 0000000..f6f5d0c --- /dev/null +++ b/vault-ssh-helper-bfed514.tar.gz @@ -0,0 +1 @@ +.git/annex/objects/MJ/23/SHA256E-s80200--61020274f5756c73e9309c02cd1c0d1e1e6217b206261cdf6ffa5cacd8541705.tar.gz/SHA256E-s80200--61020274f5756c73e9309c02cd1c0d1e1e6217b206261cdf6ffa5cacd8541705.tar.gz
\ No newline at end of file diff --git a/vault-ssh-helper.spec b/vault-ssh-helper.spec new file mode 100644 index 0000000..dc72ee2 --- /dev/null +++ b/vault-ssh-helper.spec @@ -0,0 +1,225 @@ +# If any of the following macros should be set otherwise, +# you can wrap any of them with the following conditions: +# - %%if 0%%{centos} == 7 +# - %%if 0%%{?rhel} == 7 +# - %%if 0%%{?fedora} == 23 +# Or just test for particular distribution: +# - %%if 0%%{centos} +# - %%if 0%%{?rhel} +# - %%if 0%%{?fedora} +# +# Be aware, on centos, both %%rhel and %%centos are set. If you want to test +# rhel specific macros, you can use %%if 0%%{?rhel} && 0%%{?centos} == 0 condition. +# (Don't forget to replace double percentage symbol with single one in order to apply a condition) + +# Generate devel rpm +%global with_devel 1 +# Build project from bundled dependencies +%global with_bundled 0 +# Build with debug info rpm +%global with_debug 1 +# Run tests in check section +%global with_check 1 +# Generate unit-test rpm +%global with_unit_test 0 + +%if 0%{?with_debug} +%global _dwz_low_mem_die_limit 0 +%else +%global debug_package %{nil} +%endif + +%if ! 0%{?gobuild:1} +%define gobuild(o:) go build -ldflags "${LDFLAGS:-} -B 0x$(head -c20 /dev/urandom|od -An -tx1|tr -d ' \\n')" -a -v -x %{?**}; +%endif + +%global provider github +%global provider_tld com +%global project hashicorp +%global repo vault-ssh-helper +# https://github.com/hashicorp/vault-ssh-helper +%global provider_prefix %{provider}.%{provider_tld}/%{project}/%{repo} +%global import_path %{provider_prefix} +%global commit bfed514a06af7fe17d66ea32c2b3626d01c02c7b +%global shortcommit %(c=%{commit}; echo ${c:0:7}) + +Name: %{repo} +Version: 0.1.1 +Release: 1%{?dist} +Summary: vault-ssh-helper is used to enable one-time keys and passwords +# Detected licences +# - *No copyright* MPL (v2.0) at 'LICENSE' +License: MPLv2.0 +URL: https://%{provider_prefix} +Source0: https://%{provider_prefix}/archive/%{commit}/%{repo}-%{shortcommit}.tar.gz +Source1: vault-ssh-helper-config.hcl + +# e.g. el6 has ppc64 arch without gcc-go, so EA tag is required +ExclusiveArch: %{?go_arches:%{go_arches}}%{!?go_arches:%{ix86} x86_64 aarch64 %{arm}} +# If go_compiler is not set to 1, there is no virtual provide. Use golang instead. +BuildRequires: %{?go_compiler:compiler(go-compiler)}%{!?go_compiler:golang} + +%if ! 0%{?with_bundled} +# main.go +BuildRequires: golang(github.com/hashicorp/vault/api) + +# Remaining dependencies not included in main packages +%endif + +%description +vault-ssh-helper is a counterpart to Vault's SSH backend. It enables creation +of one-time passwords (OTP) by Vault servers. OTPs will be used as client +authentication credentials while establishing SSH connections with remote +hosts. + +%if 0%{?with_devel} +%package devel +Summary: %{summary} +BuildArch: noarch + +%if 0%{?with_check} && ! 0%{?with_bundled} +BuildRequires: golang(github.com/hashicorp/vault/api) +%endif + +Requires: golang(github.com/hashicorp/vault/api) + +Provides: golang(%{import_path}/helper) = %{version}-%{release} + +%description devel +%{summary} + +This package contains library source intended for +building other packages which use import path with +%{import_path} prefix. +%endif + +%if 0%{?with_unit_test} && 0%{?with_devel} +%package unit-test-devel +Summary: Unit tests for %{name} package +%if 0%{?with_check} +#Here comes all BuildRequires: PACKAGE the unit tests +#in %%check section need for running +%endif + +# test subpackage tests code from devel subpackage +Requires: %{name}-devel = %{version}-%{release} + +%if 0%{?with_check} && ! 0%{?with_bundled} +%endif + + +%description unit-test-devel +%{summary} + +This package contains unit tests for project +providing packages with %{import_path} prefix. +%endif + +%prep +%setup -q -n %{repo}-%{commit} + +%build +mkdir -p src/%{provider}.%{provider_tld}/%{project} +ln -s ../../../ src/%{import_path} + +%if ! 0%{?with_bundled} +export GOPATH=$(pwd):%{gopath} +%else +# No dependency directories so far +export GOPATH=$(pwd):%{gopath} +%endif + +%gobuild -o bin/%{name} %{import_path} + +%install +install -d -p %{buildroot}%{_bindir} +install -p -m 0755 bin/%{name} %{buildroot}%{_bindir} +install -D -p %{SOURCE1} %{buildroot}%{_sysconfdir}/%{name}.d/config.hcl + +# source codes for building projects +%if 0%{?with_devel} +install -d -p %{buildroot}/%{gopath}/src/%{import_path}/ +echo "%%dir %%{gopath}/src/%%{import_path}/." >> devel.file-list +# find all *.go but no *_test.go files and generate devel.file-list +for file in $(find . \( -iname "*.go" -or -iname "*.s" \) \! -iname "*_test.go" | grep -v "vendor") ; do + dirprefix=$(dirname $file) + install -d -p %{buildroot}/%{gopath}/src/%{import_path}/$dirprefix + cp -pav $file %{buildroot}/%{gopath}/src/%{import_path}/$file + echo "%%{gopath}/src/%%{import_path}/$file" >> devel.file-list + + while [ "$dirprefix" != "." ]; do + echo "%%dir %%{gopath}/src/%%{import_path}/$dirprefix" >> devel.file-list + dirprefix=$(dirname $dirprefix) + done +done +%endif + +# testing files for this project +%if 0%{?with_unit_test} && 0%{?with_devel} +install -d -p %{buildroot}/%{gopath}/src/%{import_path}/ +# find all *_test.go files and generate unit-test-devel.file-list +for file in $(find . -iname "*_test.go" | grep -v "vendor") ; do + dirprefix=$(dirname $file) + install -d -p %{buildroot}/%{gopath}/src/%{import_path}/$dirprefix + cp -pav $file %{buildroot}/%{gopath}/src/%{import_path}/$file + echo "%%{gopath}/src/%%{import_path}/$file" >> unit-test-devel.file-list + + while [ "$dirprefix" != "." ]; do + echo "%%dir %%{gopath}/src/%%{import_path}/$dirprefix" >> devel.file-list + dirprefix=$(dirname $dirprefix) + done +done +%endif + +%if 0%{?with_devel} +sort -u -o devel.file-list devel.file-list +%endif + +%check +%if 0%{?with_check} && 0%{?with_unit_test} && 0%{?with_devel} +%if ! 0%{?with_bundled} +export GOPATH=%{buildroot}/%{gopath}:%{gopath} +%else +# Since we aren't packaging up the vendor directory we need to link +# back to it somehow. Hack it up so that we can add the vendor +# directory from BUILD dir as a gopath to be searched when executing +# tests from the BUILDROOT dir. +ln -s ./ ./vendor/src # ./vendor/src -> ./vendor + +export GOPATH=%{buildroot}/%{gopath}:$(pwd)/vendor:%{gopath} +%endif + +%if ! 0%{?gotest:1} +%global gotest go test +%endif + +%endif + +#define license tag if not already defined +%{!?_licensedir:%global license %doc} + +%files +%license LICENSE +%doc README.md +%config(noreplace) %{_sysconfdir}/%{name}.d/config.hcl +%{_bindir}/%{name} + +%if 0%{?with_devel} +%files devel -f devel.file-list +%license LICENSE +%doc README.md +%dir %{gopath}/src/%{provider}.%{provider_tld}/%{project} +%endif + +%if 0%{?with_unit_test} && 0%{?with_devel} +%files unit-test-devel -f unit-test-devel.file-list +%license LICENSE +%doc README.md +%endif + +%changelog +* Sun Mar 05 2017 Ed Marshall <esm@logic.net> - 0.1.1-1 +- Update to 0.1.1 + +* Wed Dec 23 2015 Ed Marshall <esm@logic.net> - 0.1.0-1 +- First package for Fedora |