Dirk Mueller
2da922fc4b
- Set default reg_path='registry.opensuse.org/kubevirt' - Add _constraints file with disk requirements - Drop CDI_VERSION env var since its not used during the build OBS-URL: https://build.opensuse.org/request/show/889151 OBS-URL: https://build.opensuse.org/package/show/Virtualization/containerized-data-importer?expand=0&rev=15
227 lines
6.6 KiB
RPMSpec
227 lines
6.6 KiB
RPMSpec
#
|
|
# spec file for package containerized-data-importer
|
|
#
|
|
# Copyright (c) 2021 SUSE LLC
|
|
#
|
|
# 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/
|
|
#
|
|
|
|
|
|
Name: containerized-data-importer
|
|
Version: 1.30.0
|
|
Release: 0
|
|
Summary: Container native virtualization
|
|
License: Apache-2.0
|
|
Group: System/Packages
|
|
URL: https://github.com/kubevirt/containerized-data-importer
|
|
Source0: %{name}-%{version}.tar.gz
|
|
BuildRequires: golang-packaging
|
|
BuildRequires: libnbd-devel
|
|
BuildRequires: pkgconfig
|
|
BuildRequires: rsync
|
|
BuildRequires: sed
|
|
BuildRequires: golang(API) = 1.14
|
|
ExclusiveArch: x86_64
|
|
|
|
%description
|
|
Containerized-Data-Importer (CDI) is a persistent storage management add-on for Kubernetes
|
|
|
|
%package api
|
|
Summary: CDI API server
|
|
Group: System/Packages
|
|
|
|
%description api
|
|
The containerized-data-importer-api package provides the kubernetes API extension for CDI
|
|
|
|
%package cloner
|
|
Summary: Cloner for host assisted cloning
|
|
Group: System/Packages
|
|
|
|
%description cloner
|
|
Source and Target cloner image for host assisted cloning
|
|
|
|
%package controller
|
|
Summary: Controller for the data fetching service
|
|
Group: System/Packages
|
|
|
|
%description controller
|
|
Controller for the data fetching service for VM container images
|
|
|
|
%package importer
|
|
Summary: Data fetching service
|
|
Group: System/Packages
|
|
|
|
%description importer
|
|
Data fetching service for VM container imagess
|
|
|
|
%package operator
|
|
Summary: Operator for the data fetching service
|
|
Group: System/Packages
|
|
|
|
%description operator
|
|
Operator for the data fetching service for VM container images
|
|
|
|
%package uploadproxy
|
|
Summary: Upload proxy for the data fetching service
|
|
Group: System/Packages
|
|
|
|
%description uploadproxy
|
|
Upload proxy for the data fetching service for VM container images
|
|
|
|
%package uploadserver
|
|
Summary: Upload server for the data fetching service
|
|
Group: System/Packages
|
|
|
|
%description uploadserver
|
|
Upload server for the data fetching service for VM container images
|
|
|
|
%package manifests
|
|
Summary: YAML manifests used to install CDI
|
|
Group: System/Packages
|
|
|
|
%description manifests
|
|
This contains the built YAML manifests used to install CDI into a
|
|
kubernetes installation with kubectl apply.
|
|
|
|
%prep
|
|
# Unpack the sources respecting the GOPATH directory structure expected by the
|
|
# go imports resolver. I.e. if DIR is in GOPATH then DIR/src/foo/bar can be
|
|
# imported as "foo/bar". The same 'visibility' rules apply to the local copies
|
|
# of external dependencies placed in 'vendor' directory when imported from the
|
|
# 'parent' package.
|
|
#
|
|
# Note: having bar symlink'ed to DIR/src/foo/bar does not seem to work. Looks
|
|
# like symlinks in go path are not resolved correctly. Hence the sources need
|
|
# to be 'physically' placed into the proper location.
|
|
%setup -n go/src/kubevirt.io/%{name} -c -T
|
|
tar --strip-components=1 -xf %{S:0}
|
|
|
|
%build
|
|
# Hackery to determine which registry path to use in cdi-operator.yaml
|
|
# when building the manifests
|
|
#
|
|
# The 'registry_path' macro can be used to define an explicit path in the
|
|
# project config, e.g.
|
|
#
|
|
# Macros:
|
|
# %registry_path registry.opensuse.org/Virtualization/container
|
|
# :Macros
|
|
#
|
|
# 'registry_path' can also be defined when building locally, e.g.
|
|
#
|
|
# osc build --define='registry_path registry.opensuse.org/foo/bar/baz' ...
|
|
#
|
|
# If 'registry_path' is not specified, the standard publish location for SLE and
|
|
# openSUSE-based containers is used.
|
|
#
|
|
# TODO:
|
|
# 1. Determine "standard publish location" for SLE and openSUSE variants
|
|
# 2. Support Leap when 1 is done
|
|
#
|
|
%if "%{?registry_path}" == ""
|
|
distro='%{?sle_version}:%{is_opensuse}'
|
|
case "${distro}" in
|
|
150200:0)
|
|
reg_path='registry.suse.de/suse/containers/sle-server/15/containers/suse/sles/15.2' ;;
|
|
150300:0)
|
|
reg_path='registry.suse.de/suse/containers/sle-server/15/containers/suse/sles/15.3' ;;
|
|
*)
|
|
reg_path='registry.opensuse.org/kubevirt' ;;
|
|
esac
|
|
%else
|
|
reg_path='%{registry_path}'
|
|
%endif
|
|
|
|
export GOPATH=%{_builddir}/go
|
|
export GOFLAGS="-buildmode=pie -mod=vendor"
|
|
env \
|
|
CDI_SOURCE_DATE_EPOCH="$(date -r LICENSE +%s)" \
|
|
CDI_GIT_COMMIT='v%{version}' \
|
|
CDI_GIT_VERSION='v%{version}' \
|
|
CDI_GIT_TREE_STATE="clean" \
|
|
./hack/build/build-go.sh build \
|
|
cmd/cdi-apiserver \
|
|
cmd/cdi-cloner \
|
|
cmd/cdi-controller \
|
|
cmd/cdi-importer \
|
|
cmd/cdi-uploadproxy \
|
|
cmd/cdi-uploadserver \
|
|
cmd/cdi-operator \
|
|
%{nil}
|
|
|
|
env DOCKER_PREFIX=$reg_path DOCKER_TAG=%{version} ./hack/build/build-manifests.sh
|
|
|
|
%install
|
|
mkdir -p %{buildroot}%{_bindir}
|
|
|
|
install -p -m 0755 _out/cmd/cdi-apiserver/cdi-apiserver %{buildroot}%{_bindir}/virt-cdi-apiserver
|
|
|
|
install -p -m 0755 cmd/cdi-cloner/cloner_startup.sh %{buildroot}%{_bindir}/
|
|
install -p -m 0755 _out/cmd/cdi-cloner/cdi-cloner %{buildroot}%{_bindir}/
|
|
|
|
install -p -m 0755 _out/cmd/cdi-controller/cdi-controller %{buildroot}%{_bindir}/virt-cdi-controller
|
|
|
|
install -p -m 0755 _out/cmd/cdi-importer/cdi-importer %{buildroot}%{_bindir}/virt-cdi-importer
|
|
|
|
install -p -m 0755 _out/cmd/cdi-operator/cdi-operator %{buildroot}%{_bindir}/virt-cdi-operator
|
|
|
|
install -p -m 0755 _out/cmd/cdi-uploadproxy/cdi-uploadproxy %{buildroot}%{_bindir}/virt-cdi-uploadproxy
|
|
|
|
install -p -m 0755 _out/cmd/cdi-uploadserver/cdi-uploadserver %{buildroot}%{_bindir}/virt-cdi-uploadserver
|
|
|
|
mkdir -p %{buildroot}%{_datadir}/cdi
|
|
cp -r _out/manifests %{buildroot}%{_datadir}/cdi/
|
|
|
|
%files api
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/virt-cdi-apiserver
|
|
|
|
%files cloner
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/cloner_startup.sh
|
|
%{_bindir}/cdi-cloner
|
|
|
|
%files controller
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/virt-cdi-controller
|
|
|
|
%files importer
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/virt-cdi-importer
|
|
|
|
%files operator
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/virt-cdi-operator
|
|
|
|
%files uploadproxy
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/virt-cdi-uploadproxy
|
|
|
|
%files uploadserver
|
|
%license LICENSE
|
|
%doc README.md
|
|
%{_bindir}/virt-cdi-uploadserver
|
|
|
|
%files manifests
|
|
%license LICENSE
|
|
%doc README.md
|
|
%dir %{_datadir}/cdi
|
|
%{_datadir}/cdi/manifests
|
|
|
|
%changelog
|