d3ade9
Name:           custodia
d3ade9
Version:        0.6.0
d3ade9
Release:        3%{?dist}
d3ade9
Summary:        A service to manage, retrieve and store secrets for other processes
d3ade9
d3ade9
License:        GPLv3+
d3ade9
URL:            https://github.com/latchset/%{name}
d3ade9
Source0:        https://github.com/latchset/%{name}/releases/download/v%{version}/%{name}-%{version}.tar.gz
d3ade9
Source2:        custodia.conf
d3ade9
Source3:        custodia@.service
d3ade9
Source4:        custodia@.socket
d3ade9
Source5:        custodia.tmpfiles.conf
d3ade9
d3ade9
Patch1:	        nonfatal_deprecation.patch
d3ade9
d3ade9
BuildArch:      noarch
d3ade9
d3ade9
BuildRequires:      systemd
d3ade9
d3ade9
BuildRequires:      python%{python3_pkgversion}-devel
d3ade9
BuildRequires:      python%{python3_pkgversion}-jwcrypto >= 0.4.2
d3ade9
BuildRequires:      python%{python3_pkgversion}-requests
d3ade9
BuildRequires:      python%{python3_pkgversion}-setuptools > 18
d3ade9
BuildRequires:      python%{python3_pkgversion}-coverage
d3ade9
BuildRequires:      python%{python3_pkgversion}-pytest
d3ade9
BuildRequires:      python%{python3_pkgversion}-docutils
d3ade9
BuildRequires:      python%{python3_pkgversion}-systemd
d3ade9
d3ade9
Requires:           python%{python3_pkgversion}-custodia = %{version}-%{release}
d3ade9
d3ade9
Requires(preun):    systemd-units
d3ade9
Requires(postun):   systemd-units
d3ade9
Requires(post):     systemd-units
d3ade9
d3ade9
d3ade9
%global overview                                                           \
d3ade9
Custodia is a Secrets Service Provider, it stores or proxies access to     \
d3ade9
keys, password, and secret material in general. Custodia is built to       \
d3ade9
use the HTTP protocol and a RESTful API as an IPC mechanism over a local   \
d3ade9
Unix Socket. It can also be exposed to a network via a Reverse Proxy       \
d3ade9
service assuming proper authentication and header validation is            \
d3ade9
implemented in the Proxy.                                                  \
d3ade9
                                                                           \
d3ade9
Custodia is modular, the configuration file controls how authentication,   \
d3ade9
authorization, storage and API plugins are combined and exposed.
d3ade9
d3ade9
d3ade9
%description
d3ade9
A service to manage, retrieve and store secrets for other processes
d3ade9
d3ade9
%{overview}
d3ade9
d3ade9
%package -n python%{python3_pkgversion}-custodia
d3ade9
Summary:    Sub-package with python3 custodia modules
d3ade9
%{?python_provide:%python_provide python3-%{name}}
d3ade9
Requires:   python%{python3_pkgversion}-jwcrypto >= 0.4.2
d3ade9
Requires:   python%{python3_pkgversion}-requests
d3ade9
Requires:   python%{python3_pkgversion}-systemd
d3ade9
%if 0%{?rhel} && 0%{?rhel} >= 8
d3ade9
Requires:   platform-python-setuptools
d3ade9
%else
d3ade9
Requires:   python%{python3_pkgversion}-setuptools
d3ade9
%endif
d3ade9
Conflicts:  python%{python3_pkgversion}-custodia-extra < %{version}
d3ade9
Obsoletes:  python%{python3_pkgversion}-custodia-extra < %{version}
d3ade9
d3ade9
%description -n python%{python3_pkgversion}-custodia
d3ade9
Sub-package with python custodia modules
d3ade9
d3ade9
%{overview}
d3ade9
d3ade9
d3ade9
%prep
d3ade9
%autosetup -p1
d3ade9
d3ade9
d3ade9
%build
d3ade9
%py3_build
d3ade9
d3ade9
d3ade9
%check
d3ade9
# don't download packages
d3ade9
export PIP_INDEX_URL=http://host.invalid./
d3ade9
# Don't try to download dnspython3. The package is provided by python%{python3_pkgversion}-dns
d3ade9
export PIP_NO_DEPS=yes
d3ade9
# Ignore all install packages to enforce installation of sdist. Otherwise tox
d3ade9
# may pick up this package from global site-packages instead of source dist.
d3ade9
export PIP_IGNORE_INSTALLED=yes
d3ade9
d3ade9
# Test custodia in a virtual environment
d3ade9
%{__python3} -m venv --system-site-packages testenv
d3ade9
testenv/bin/pip install .
d3ade9
testenv/bin/python -m pytest --capture=no --strict --skip-servertests
d3ade9
d3ade9
d3ade9
%install
d3ade9
mkdir -p %{buildroot}/%{_sbindir}
d3ade9
mkdir -p %{buildroot}/%{_mandir}/man7
d3ade9
mkdir -p %{buildroot}/%{_defaultdocdir}/custodia
d3ade9
mkdir -p %{buildroot}/%{_defaultdocdir}/custodia/examples
d3ade9
mkdir -p %{buildroot}/%{_sysconfdir}/custodia
d3ade9
mkdir -p %{buildroot}/%{_unitdir}
d3ade9
mkdir -p %{buildroot}/%{_tmpfilesdir}
d3ade9
mkdir -p %{buildroot}/%{_localstatedir}/lib/custodia
d3ade9
mkdir -p %{buildroot}/%{_localstatedir}/log/custodia
d3ade9
mkdir -p %{buildroot}/%{_localstatedir}/run/custodia
d3ade9
d3ade9
install -m 644 -t "%{buildroot}/%{_mandir}/man7" man/custodia.7
d3ade9
install -m 644 -t "%{buildroot}/%{_defaultdocdir}/custodia" README API.md
d3ade9
install -m 644 -t "%{buildroot}/%{_defaultdocdir}/custodia/examples" custodia.conf
d3ade9
install -m 600 %{SOURCE2} %{buildroot}%{_sysconfdir}/custodia
d3ade9
install -m 644 %{SOURCE3} %{buildroot}%{_unitdir}
d3ade9
install -m 644 %{SOURCE4} %{buildroot}%{_unitdir}
d3ade9
install -m 644 %{SOURCE5} %{buildroot}%{_tmpfilesdir}/custodia.conf
d3ade9
d3ade9
%py3_install
d3ade9
mv %{buildroot}/%{_bindir}/custodia %{buildroot}/%{_sbindir}/custodia
d3ade9
cp %{buildroot}/%{_sbindir}/custodia %{buildroot}/%{_sbindir}/custodia-3
d3ade9
cp %{buildroot}/%{_bindir}/custodia-cli %{buildroot}/%{_bindir}/custodia-cli-3
d3ade9
d3ade9
d3ade9
%pre
d3ade9
getent group custodia >/dev/null || groupadd -r custodia
d3ade9
getent passwd custodia >/dev/null || \
d3ade9
    useradd -r -g custodia -d / -s /sbin/nologin \
d3ade9
    -c "User for custodia" custodia
d3ade9
exit 0
d3ade9
d3ade9
d3ade9
%post
d3ade9
%systemd_post custodia@\*.socket
d3ade9
%systemd_post custodia@\*.service
d3ade9
d3ade9
d3ade9
%preun
d3ade9
%systemd_preun custodia@\*.socket
d3ade9
%systemd_preun custodia@\*.service
d3ade9
d3ade9
d3ade9
%postun
d3ade9
%systemd_postun custodia@\*.socket
d3ade9
%systemd_postun custodia@\*.service
d3ade9
d3ade9
d3ade9
%files
d3ade9
%doc README API.md
d3ade9
%doc %{_defaultdocdir}/custodia/examples/custodia.conf
d3ade9
%license LICENSE
d3ade9
%{_mandir}/man7/custodia*
d3ade9
%{_sbindir}/custodia
d3ade9
%{_bindir}/custodia-cli
d3ade9
%dir %attr(0700,custodia,custodia) %{_sysconfdir}/custodia
d3ade9
%config(noreplace) %attr(600,custodia,custodia) %{_sysconfdir}/custodia/custodia.conf
d3ade9
%attr(644,root,root)  %{_unitdir}/custodia@.socket
d3ade9
%attr(644,root,root)  %{_unitdir}/custodia@.service
d3ade9
%dir %attr(0700,custodia,custodia) %{_localstatedir}/lib/custodia
d3ade9
%dir %attr(0700,custodia,custodia) %{_localstatedir}/log/custodia
d3ade9
%dir %attr(0755,custodia,custodia) %{_localstatedir}/run/custodia
d3ade9
%{_tmpfilesdir}/custodia.conf
d3ade9
d3ade9
%files -n python%{python3_pkgversion}-custodia
d3ade9
%license LICENSE
d3ade9
%{python3_sitelib}/%{name}
d3ade9
%{python3_sitelib}/%{name}-%{version}-py%{python3_version}.egg-info
d3ade9
%{python3_sitelib}/%{name}-%{version}-py%{python3_version}-nspkg.pth
d3ade9
%{_sbindir}/custodia-3
d3ade9
%{_bindir}/custodia-cli-3
d3ade9
d3ade9
d3ade9
%changelog
d3ade9
* Fri Nov 16 2018 Lumír Balhar <lbalhar@redhat.com> - 0.6.0-3
d3ade9
- Require platform-python-setuptools instead of python3-setuptools
d3ade9
- Resolves: rhbz#1650508
d3ade9
d3ade9
* Fri Jun 29 2018 Christian Heimes <cheimes@redhat.com> - 0.6.0-2
d3ade9
- Don't turn deprecation warnings into fatal errors
d3ade9
d3ade9
* Mon Jun 25 2018 Christian Heimes <cheimes@redhat.com> - 0.6.0-1
d3ade9
- New upstream release Custodia 0.6.0
d3ade9
- Run all tests again
d3ade9
- Remove etcd support and python3-custodia-extra
d3ade9
- Remove unnecesary conflict with old FreeIPA
d3ade9
d3ade9
* Wed Jun 20 2018 Petr Viktorin <pviktori@redhat.com> - 0.5.0-12
d3ade9
- Remove the Python 2 subpackage
d3ade9
- Skip a test that fails on a different logging/error message
d3ade9
- In %%check, use pytest directly rather than tox
d3ade9
d3ade9
* Fri Feb 09 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 0.5.0-11
d3ade9
- Escape macros in %%changelog
d3ade9
d3ade9
* Wed Feb 07 2018 Fedora Release Engineering <releng@fedoraproject.org> - 0.5.0-10
d3ade9
- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild
d3ade9
d3ade9
* Mon Aug 07 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-9
d3ade9
- freeipa 4.4.4-2.fc26 and newer are compatible with custodia 0.5
d3ade9
- Fix dependency to python2-jwcrypto >= 0.4.2
d3ade9
d3ade9
* Wed Aug 02 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-8
d3ade9
- Add PIP_IGNORE_INSTALLED
d3ade9
d3ade9
* Tue Aug 01 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-7
d3ade9
- Modernize spec
d3ade9
d3ade9
* Tue Aug 01 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-6
d3ade9
- Require latest python-jwcrypto with Python 3 fix
d3ade9
- Use python2 prefix for all Python 2 dependencies
d3ade9
d3ade9
* Tue Aug 01 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-5
d3ade9
- Add custodia user and named systemd instances
d3ade9
d3ade9
* Wed Jul 26 2017 Fedora Release Engineering <releng@fedoraproject.org> - 0.5.0-4
d3ade9
- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild
d3ade9
d3ade9
* Tue Jun 20 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-3
d3ade9
- Add systemd build requirement for tmpfilesdir and unitdir macros
d3ade9
d3ade9
* Mon Jun 19 2017 Christian Heimes <cheimes@redhat.com> - 0.5.0-2
d3ade9
- Skip etcd store on PPC64
d3ade9
- Add missing pre/post install hooks for systemd service
d3ade9
- Custodia 0.5 is compatible with FreeIPA 4.4.5 and newer
d3ade9
- Drop custodia user from tmpfiles.d conf
d3ade9
d3ade9
* Tue May 16 2017 Simo Sorce <simo@redhat.com> - 0.5.0-1
d3ade9
- New Custodia version
d3ade9
- Drop checks on sha512sum, these checks are already done by dist-git
d3ade9
d3ade9
* Tue Apr 11 2017 Christian Heimes <cheimes@redhat.com> - 0.3.1-3
d3ade9
- Run Python 3 tests with correct Python version
d3ade9
d3ade9
* Fri Apr 07 2017 Christian Heimes <cheimes@redhat.com> - 0.3.1-2
d3ade9
- Add conflict with FreeIPA < 4.5
d3ade9
d3ade9
* Mon Mar 27 2017 Christian Heimes <cheimes@redhat.com> - 0.3.1-1
d3ade9
- Upstream release 0.3.1
d3ade9
d3ade9
* Thu Mar 16 2017 Christian Heimes <cheimes@redhat.com> - 0.3.0-3
d3ade9
- Provide custodia-2 and custodia-3 scripts
d3ade9
d3ade9
* Thu Mar 02 2017 Christian Heimes <cheimes@redhat.com> - 0.3.0-2
d3ade9
- Run Custodia daemon with Python 3
d3ade9
- Resolves: Bug 1426737 - custodia: Provide a Python 3 subpackage
d3ade9
d3ade9
* Wed Mar 01 2017 Christian Heimes <cheimes@redhat.com> - 0.3.0-1
d3ade9
- Update to custodia 0.3.0
d3ade9
- Run tests with global site packages
d3ade9
- Add tmpfiles.d config for /run/custodia
d3ade9
d3ade9
* Wed Feb 22 2017 Christian Heimes <cheimes@redhat.com> - 0.2.0-4
d3ade9
- Add missing runtime requirement on python[23]-systemd.
d3ade9
- Drop unnecesary build dependency on python%%{python3_pkgversion}-configparser.
d3ade9
- Fix tests, don't try to download dnspython3.
d3ade9
d3ade9
* Fri Feb 10 2017 Fedora Release Engineering <releng@fedoraproject.org> - 0.2.0-3
d3ade9
- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild
d3ade9
d3ade9
* Thu Dec 22 2016 Miro Hrončok <mhroncok@redhat.com> - 0.2.0-2
d3ade9
- Rebuild for Python 3.6
d3ade9