diff options
author | Zac Medico <zmedico@gentoo.org> | 2016-10-19 23:36:18 -0700 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2016-10-19 23:39:58 -0700 |
commit | dd89c09adc169f8881589f6c6a060ae6148c7fe8 (patch) | |
tree | 51b6b2d1c46cae19c13ff2fe6b43bc00a5069989 /app-admin/vault/vault-0.6.2.ebuild | |
parent | dev-ruby/origin: add 2.2.1 (diff) | |
download | gentoo-dd89c09adc169f8881589f6c6a060ae6148c7fe8.tar.gz gentoo-dd89c09adc169f8881589f6c6a060ae6148c7fe8.tar.bz2 gentoo-dd89c09adc169f8881589f6c6a060ae6148c7fe8.zip |
app-admin/vault: version bump to 0.6.2
Package-Manager: portage-2.3.2
Diffstat (limited to 'app-admin/vault/vault-0.6.2.ebuild')
-rw-r--r-- | app-admin/vault/vault-0.6.2.ebuild | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/app-admin/vault/vault-0.6.2.ebuild b/app-admin/vault/vault-0.6.2.ebuild new file mode 100644 index 000000000000..ade0af0668cd --- /dev/null +++ b/app-admin/vault/vault-0.6.2.ebuild @@ -0,0 +1,119 @@ +# Copyright 1999-2016 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Id$ + +EAPI=6 + +inherit fcaps golang-base systemd user + +EGO_PN="github.com/hashicorp/${PN}/..." +DESCRIPTION="A tool for managing secrets" +HOMEPAGE="https://vaultproject.io/" +SRC_URI="https://${EGO_PN%/*}/archive/v${PV}.tar.gz -> ${P}.tar.gz + https://github.com/mitchellh/gox/archive/c9740af9c6574448fd48eb30a71f964014c7a837.tar.gz -> gox-c9740af9c6574448fd48eb30a71f964014c7a837.tar.gz + https://github.com/mitchellh/iochan/archive/87b45ffd0e9581375c491fef3d32130bb15c5bd7.tar.gz -> iochan-87b45ffd0e9581375c491fef3d32130bb15c5bd7.tar.gz +" +SLOT="0" +LICENSE="MPL-2.0" +KEYWORDS="~amd64" +IUSE="" + +RESTRICT="test" + +DEPEND=">=dev-lang/go-1.6:=" +RDEPEND="" + +STRIP_MASK="*.a" + +FILECAPS=( + -m 755 'cap_ipc_lock=+ep' usr/bin/${PN} +) + +get_archive_go_package() { + local archive=${1} uri x + for x in ${SRC_URI}; do + if [[ ${x} == http* ]]; then + uri=${x} + elif [[ ${x} == ${archive} ]]; then + break + fi + done + uri=${uri#https://} + echo ${uri%/archive/*} +} + +unpack_go_packages() { + local go_package x + # Unpack packages to appropriate locations for GOPATH + for x in ${A}; do + unpack ${x} + if [[ ${x} == *.tar.gz ]]; then + go_package=$(get_archive_go_package ${x}) + mkdir -p src/${go_package%/*} + mv ${go_package##*/}-* src/${go_package} || die + fi + done +} + +src_unpack() { + mkdir "${S}" && cd "${S}" || die + unpack_go_packages +} + +src_prepare() { + eapply_user + # Avoid the need to have a git checkout + sed -e 's:^GIT.*::' -i src/${EGO_PN%/*}/scripts/build.sh || die +} + +pkg_setup() { + enewgroup ${PN} + enewuser ${PN} -1 -1 -1 ${PN} +} + +src_compile() { + export GOPATH=${S} + go install -v -work -x ${EGO_BUILD_FLAGS} "github.com/mitchellh/gox/..." || die + go install -v -work -x ${EGO_BUILD_FLAGS} "${EGO_PN}" + # the previous command returns 2 on success... + [[ -d ${S}/pkg/$(go env GOOS)_$(go env GOARCH)/${EGO_PN%/*} ]] || die + cd "${S}"/src/${EGO_PN%/*} || die + PATH=${PATH}:${S}/bin \ + XC_ARCH=$(go env GOARCH) \ + XC_OS=$(go env GOOS) \ + XC_OSARCH=$(go env GOOS)/$(go env GOARCH) \ + emake +} + +src_install() { + local x + + dodoc "${S}"/src/${EGO_PN%/*}/{CHANGELOG.md,CONTRIBUTING.md,README.md} + newinitd "${FILESDIR}/${PN}.initd" "${PN}" + newconfd "${FILESDIR}/${PN}.confd" "${PN}" + systemd_dounit "${FILESDIR}/${PN}.service" + + keepdir /etc/${PN}.d + insinto /etc/${PN}.d + doins "${FILESDIR}/"*.json.example + + keepdir /var/log/${PN} + fowners ${PN}:${PN} /var/log/${PN} + + dobin "${S}/bin/${PN}" + + rm -rf "${S}"/{src,pkg/$(go env GOOS)_$(go env GOARCH)}/${EGO_PN%/*}/vendor + find "${S}"/src/${EGO_PN%/*} -mindepth 1 -maxdepth 1 -type f -delete || die + + while read -r -d '' x; do + x=${x#${S}/src} + [[ -d ${S}/pkg/$(go env GOOS)_$(go env GOARCH)/${x} || + -f ${S}/pkg/$(go env GOOS)_$(go env GOARCH)/${x}.a ]] && continue + rm -rf "${S}"/src/${x} + done < <(find "${S}"/src/${EGO_PN%/*} -mindepth 1 -maxdepth 1 -type d -print0) + insopts -m0644 -p # preserve timestamps for bug 551486 + insinto $(dirname "$(get_golibdir)/pkg/$(go env GOOS)_$(go env GOARCH)/${EGO_PN%/*}") + doins -r "${S}"/pkg/$(go env GOOS)_$(go env GOARCH)/${EGO_PN%/*} + insinto $(dirname "$(get_golibdir)/src/${EGO_PN%/*}") + doins -r "${S}"/src/${EGO_PN%/*} +} |