add source package
This commit is contained in:
parent
f3253a912d
commit
0a3cb6ee7f
124
rust-zincati.spec
Normal file
124
rust-zincati.spec
Normal file
@ -0,0 +1,124 @@
|
||||
%bcond_without check
|
||||
%global __cargo_skip_build 0
|
||||
%define debug_package %{nil}
|
||||
%global crate zincati
|
||||
|
||||
Name: rust-%{crate}
|
||||
Version: 0.0.18
|
||||
Release: 1
|
||||
Summary: Update agent for NestOS
|
||||
License: ASL 2.0
|
||||
URL: https://crates.io/crates/%{crate}
|
||||
Source0: %{crate}-%{version}.crate
|
||||
Source1: https://github.com/coreos/%{crate}/releases/download/v%{version}/%{crate}-%{version}-vendor.tar.gz
|
||||
Patch0: zincati-fix-metadata.diff
|
||||
|
||||
BuildRequires: rust-packaging
|
||||
BuildRequires: systemd openssl-devel
|
||||
|
||||
Requires: polkit
|
||||
|
||||
%global _description %{expand:
|
||||
Update agent for NestOS.}
|
||||
|
||||
%description %{_description}
|
||||
|
||||
%package -n %{crate}
|
||||
Summary: %{summary}
|
||||
License: ASL 2.0 and BSD and MIT and MPLv2.0 and zlib
|
||||
|
||||
%description -n %{crate} %{_description}
|
||||
|
||||
%files -n %{crate}
|
||||
%{_libexecdir}/zincati
|
||||
%doc README.md
|
||||
%license COPYRIGHT LICENSE
|
||||
%dir %{_prefix}/lib/%{crate}
|
||||
%dir %{_prefix}/lib/%{crate}/config.d
|
||||
%{_prefix}/lib/%{crate}/config.d/*.toml
|
||||
%attr(0775, zincati, zincati) %dir /run/%{crate}
|
||||
%attr(0775, zincati, zincati) %dir /run/%{crate}/config.d
|
||||
%attr(0770, zincati, zincati) %dir /run/%{crate}/private
|
||||
%attr(0775, zincati, zincati) %dir /run/%{crate}/public
|
||||
%verify(not size mtime md5) /run/%{crate}/public/metrics.promsock
|
||||
%verify(not size mtime md5) /run/%{crate}/private/metrics.promsock
|
||||
%dir %{_sysconfdir}/%{crate}
|
||||
%dir %{_sysconfdir}/%{crate}/config.d
|
||||
%{_unitdir}/zincati.service
|
||||
%{_sysusersdir}/50-zincati.conf
|
||||
%{_tmpfilesdir}/zincati.conf
|
||||
%{_datadir}/polkit-1/rules.d/zincati.rules
|
||||
%{_datadir}/polkit-1/actions/org.coreos.zincati.*
|
||||
|
||||
%post -n %{crate}
|
||||
%systemd_post zincati.service
|
||||
|
||||
%preun -n %{crate}
|
||||
%systemd_preun zincati.service
|
||||
|
||||
%postun -n %{crate}
|
||||
%systemd_postun_with_restart zincati.service
|
||||
|
||||
%prep
|
||||
%autosetup -n %{crate}-%{version} -p1
|
||||
%patch0 -R -p1
|
||||
%cargo_prep
|
||||
tar xvf %{SOURCE1}
|
||||
mv $RPM_BUILD_DIR/zincati-0.0.18/target/vendor $RPM_BUILD_DIR/zincati-0.0.18
|
||||
mkdir -p .cargo
|
||||
cat >.cargo/config << EOF
|
||||
|
||||
[build]
|
||||
rustc = "%{__rustc}"
|
||||
rustdoc = "%{__rustdoc}"
|
||||
rustflags = %{__global_rustflags_toml}
|
||||
|
||||
[install]
|
||||
root = "%{buildroot}%{_prefix}"
|
||||
|
||||
[term]
|
||||
verbose = true
|
||||
|
||||
[source.crates-io]
|
||||
replace-with = "vendored-sources"
|
||||
|
||||
[source.vendored-sources]
|
||||
directory = "vendor"
|
||||
EOF
|
||||
|
||||
%build
|
||||
%cargo_build
|
||||
|
||||
%install
|
||||
%cargo_install
|
||||
# `zincati` should not be executed directly by users, so we move the binary
|
||||
# out of `/usr/bin`. See: https://github.com/coreos/fedora-coreos-tracker/issues/244
|
||||
mkdir -p %{buildroot}%{_libexecdir}
|
||||
mv %{buildroot}%{_bindir}/zincati %{buildroot}%{_libexecdir}/zincati
|
||||
install -Dpm0644 -t %{buildroot}%{_prefix}/lib/%{crate}/config.d \
|
||||
dist/config.d/*.toml
|
||||
mkdir -p %{buildroot}/run/%{crate}/config.d
|
||||
mkdir -p %{buildroot}/run/%{crate}/private
|
||||
mkdir -p %{buildroot}/run/%{crate}/public
|
||||
touch %{buildroot}/run/%{crate}/public/metrics.promsock
|
||||
mkdir -p %{buildroot}%{_sysconfdir}/%{crate}/config.d
|
||||
install -Dpm0644 -t %{buildroot}%{_unitdir} \
|
||||
dist/systemd/system/*.service
|
||||
install -Dpm0644 -t %{buildroot}%{_sysusersdir} \
|
||||
dist/sysusers.d/*.conf
|
||||
install -Dpm0644 -t %{buildroot}%{_tmpfilesdir} \
|
||||
dist/tmpfiles.d/*.conf
|
||||
install -Dpm0644 -t %{buildroot}%{_datadir}/polkit-1/rules.d \
|
||||
dist/polkit-1/rules.d/*.rules
|
||||
install -Dpm0644 -t %{buildroot}%{_datadir}/polkit-1/actions \
|
||||
dist/polkit-1/actions/org.coreos.zincati.*
|
||||
ln -snf /run/%{crate}/public/metrics.promsock %{buildroot}/run/%{crate}/private/metrics.promsock
|
||||
|
||||
%if %{with check}
|
||||
%check
|
||||
%cargo_test
|
||||
%endif
|
||||
|
||||
%changelog
|
||||
* Mon Dec 27 2021 duyiwei <duyiwei@kylinos.cn> - 0.0.18-1
|
||||
- Package init
|
||||
BIN
zincati-0.0.18-vendor.tar.gz
Normal file
BIN
zincati-0.0.18-vendor.tar.gz
Normal file
Binary file not shown.
BIN
zincati-0.0.18.crate
Normal file
BIN
zincati-0.0.18.crate
Normal file
Binary file not shown.
25
zincati-fix-metadata.diff
Normal file
25
zincati-fix-metadata.diff
Normal file
@ -0,0 +1,25 @@
|
||||
|
||||
--- zincati-0.0.18/Cargo.toml
|
||||
+++ zincati-0.0.18/Cargo.toml
|
||||
@@ -89,7 +89,7 @@ version = "2.1"
|
||||
features = ["serde"]
|
||||
|
||||
[dependencies.prometheus]
|
||||
-version = "0.11"
|
||||
+version = "0.10"
|
||||
default-features = false
|
||||
|
||||
[dependencies.rand]
|
||||
@@ -128,10 +128,10 @@ features = ["serde"]
|
||||
version = "0.2"
|
||||
|
||||
[dev-dependencies.mockito]
|
||||
-version = "0.29"
|
||||
+version = "0.28"
|
||||
|
||||
[dev-dependencies.proptest]
|
||||
-version = "1.0"
|
||||
+version = "0.10"
|
||||
|
||||
[features]
|
||||
failpoints = ["fail/failpoints"]
|
||||
Loading…
x
Reference in New Issue
Block a user