2020-11-03 09:16:41 +01:00
|
|
|
#
|
|
|
|
# spec file for package parsec
|
|
|
|
#
|
2021-04-01 15:00:44 +02:00
|
|
|
# Copyright (c) 2021 SUSE LLC
|
2020-11-03 09:16:41 +01:00
|
|
|
#
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
|
|
# upon. The license for this file, and modifications and additions to the
|
|
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
|
|
# license for the pristine package is not an Open Source License, in which
|
|
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
|
|
# published by the Open Source Initiative.
|
|
|
|
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
|
|
#
|
|
|
|
|
2021-04-01 15:00:44 +02:00
|
|
|
|
2020-11-03 09:16:41 +01:00
|
|
|
%global rustflags '-Clink-arg=-Wl,-z,relro,-z,now'
|
2021-04-14 17:57:17 +02:00
|
|
|
# Features available:
|
|
|
|
# all-providers = ["tpm-provider", "pkcs11-provider", "mbed-crypto-provider", "cryptoauthlib-provider"]
|
|
|
|
# all-authenticators = ["direct-authenticator", "unix-peer-credentials-authenticator"]
|
|
|
|
%define features "all-authenticators,all-providers"
|
2020-11-03 09:16:41 +01:00
|
|
|
%{?systemd_ordering}
|
|
|
|
Name: parsec
|
2021-04-01 15:00:44 +02:00
|
|
|
Version: 0.7.2
|
2020-11-03 09:16:41 +01:00
|
|
|
Release: 0
|
|
|
|
Summary: Platform AbstRaction for SECurity
|
|
|
|
License: Apache-2.0
|
|
|
|
URL: https://parallaxsecond.github.io/parsec-book
|
|
|
|
Source0: https://github.com/parallaxsecond/parsec/archive/%{version}.tar.gz#/parsec-%{version}.tar.gz
|
|
|
|
Source1: vendor.tar.xz
|
|
|
|
Source2: cargo_config
|
|
|
|
Source3: parsec.service
|
|
|
|
Source4: config.toml
|
|
|
|
Source5: parsec.conf
|
|
|
|
Source6: system-user-parsec.conf
|
|
|
|
BuildRequires: cargo
|
|
|
|
BuildRequires: clang-devel
|
|
|
|
BuildRequires: cmake
|
|
|
|
BuildRequires: llvm-devel
|
|
|
|
BuildRequires: pkgconfig
|
2021-04-01 15:00:44 +02:00
|
|
|
BuildRequires: protobuf-devel
|
2020-11-03 09:16:41 +01:00
|
|
|
BuildRequires: python3
|
|
|
|
BuildRequires: rust-packaging
|
|
|
|
BuildRequires: sysuser-tools
|
2021-04-01 15:00:44 +02:00
|
|
|
BuildRequires: pkgconfig(tss2-esys) >= 2.3.3
|
|
|
|
# opensc is used to initialize HSM keys (PKCS#11 backend)
|
|
|
|
Recommends: opensc
|
2020-11-03 09:16:41 +01:00
|
|
|
%sysusers_requires
|
2021-04-01 15:00:44 +02:00
|
|
|
# /dev/tpm* are owned by tss user
|
|
|
|
Requires(pre): system-user-tss
|
2021-04-14 17:57:17 +02:00
|
|
|
# tpm2-0-tss holds the udev rule to make /dev/tpm* owned by tss user
|
|
|
|
Requires: tpm2-0-tss
|
|
|
|
# Without libtss2-tcti-device0 parsec fails to start TPM properly
|
|
|
|
Requires: libtss2-tcti-device0
|
2020-11-03 09:16:41 +01:00
|
|
|
ExcludeArch: armv6l armv6hl
|
|
|
|
|
|
|
|
%description
|
|
|
|
PARSEC is the Platform AbstRaction for SECurity, an open-source initiative to provide
|
|
|
|
a common API to hardware security and cryptographic services in a platform-agnostic way.
|
2021-04-01 15:00:44 +02:00
|
|
|
This abstraction layer keeps workloads decoupled from physical platform details,
|
2020-11-03 09:16:41 +01:00
|
|
|
enabling cloud-native delivery flows within the data center and at the edge.
|
|
|
|
|
|
|
|
%prep
|
2021-04-14 17:57:17 +02:00
|
|
|
%autosetup -p1 -a1
|
2021-04-01 15:00:44 +02:00
|
|
|
rm -rf .cargo && mkdir .cargo
|
2020-11-03 09:16:41 +01:00
|
|
|
cp %{SOURCE2} .cargo/config
|
2021-04-01 15:00:44 +02:00
|
|
|
# Enable all providers
|
|
|
|
sed -i -e 's#default = \["unix-peer-credentials-authenticator"\]##' Cargo.toml
|
2021-04-14 17:57:17 +02:00
|
|
|
echo 'default = ["all-authenticators", "all-providers"]' >> Cargo.toml
|
2020-11-03 09:16:41 +01:00
|
|
|
|
|
|
|
%build
|
|
|
|
export PROTOC=%{_bindir}/protoc
|
|
|
|
export PROTOC_INCLUDE=%{_includedir}
|
|
|
|
%cargo_build -- --features=%features
|
|
|
|
%sysusers_generate_pre %{SOURCE6} parsec
|
|
|
|
|
|
|
|
%install
|
|
|
|
export PROTOC=%{_bindir}/protoc
|
|
|
|
export PROTOC_INCLUDE=%{_includedir}
|
|
|
|
%cargo_install
|
|
|
|
mkdir -p %{buildroot}%{_sysusersdir}
|
|
|
|
install -m 0644 %{SOURCE6} %{buildroot}%{_sysusersdir}/
|
|
|
|
install -D -p -m0644 %{SOURCE3} %{buildroot}%{_unitdir}/parsec.service
|
|
|
|
install -D -p -m0644 %{SOURCE4} %{buildroot}%{_sysconfdir}/parsec/config.toml
|
|
|
|
install -D -p -m0644 %{SOURCE5} %{buildroot}%{_tmpfilesdir}/parsec.conf
|
|
|
|
install -d -m0755 %{buildroot}%{_localstatedir}/lib/parsec
|
|
|
|
# Move parsec to _libexecdir
|
|
|
|
mkdir -p %{buildroot}%{_libexecdir}
|
|
|
|
mv target/release/parsec %{buildroot}%{_libexecdir}
|
|
|
|
# Clean-up
|
|
|
|
find %{buildroot} -name .crates2.json -delete
|
|
|
|
rm -rf %{buildroot}%{_datadir}/cargo/registry
|
|
|
|
|
|
|
|
%check
|
|
|
|
export PROTOC=%{_bindir}/protoc
|
|
|
|
export PROTOC_INCLUDE=%{_includedir}
|
|
|
|
%cargo_test -- --lib --features=%features
|
|
|
|
|
|
|
|
%pre -f parsec.pre
|
|
|
|
%service_add_pre parsec.service
|
|
|
|
|
|
|
|
%post
|
|
|
|
%service_add_post parsec.service
|
|
|
|
%tmpfiles_create %_tmpfilesdir/parsec.conf
|
|
|
|
|
|
|
|
%preun
|
|
|
|
%service_del_preun parsec.service
|
|
|
|
|
|
|
|
%postun
|
|
|
|
%service_del_postun parsec.service
|
|
|
|
|
|
|
|
%files
|
|
|
|
%license LICENSE
|
|
|
|
%doc README.md config.toml
|
|
|
|
%attr(0750,parsec,parsec) %dir %{_sysconfdir}/parsec/
|
|
|
|
%attr(0750,parsec,parsec) %dir %{_localstatedir}/lib/parsec/
|
|
|
|
%attr(0644,parsec,parsec) %config(noreplace) %{_sysconfdir}/parsec/config.toml
|
|
|
|
%{_libexecdir}/parsec
|
|
|
|
%{_tmpfilesdir}/parsec.conf
|
|
|
|
%{_unitdir}/parsec.service
|
|
|
|
%{_sysusersdir}/system-user-parsec.conf
|
|
|
|
|
|
|
|
%changelog
|