File operator-sdk.spec of Package operator-sdk

#
# spec file for package operator-sdk
#
# Copyright (c) 2025 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:           operator-sdk
Version:        1.40.0
Release:        0
Summary:        CLI for installing the Operator Lifecycle Manager
License:        Apache-2.0
URL:            https://github.com/operator-framework/operator-sdk
Source:         operator-sdk-%{version}.tar.gz
Source1:        vendor.tar.gz
BuildRequires:  bash-completion
BuildRequires:  fish
BuildRequires:  go >= 1.19
BuildRequires:  zsh
BuildRequires:  pkgconfig(gpgme)

%description
This project is a component of the Operator Framework, an open source toolkit
to manage Kubernetes native applications, called Operators, in an effective,
automated, and scalable way. Read more in the introduction blog post.

Operators make it easy to manage complex stateful applications on top of
Kubernetes. However writing an Operator today can be difficult because of
challenges such as using low level APIs, writing boilerplate, and a lack of
modularity which leads to duplication.

The Operator SDK is a framework that uses the controller-runtime library to
make writing operators easier by providing:

* High level APIs and abstractions to write the operational logic more
  intuitively
* Tools for scaffolding and code generation to bootstrap a new project fast
* Extensions to cover common Operator use cases

%package -n %{name}-bash-completion
Summary:        Bash Completion for %{name}
Group:          System/Shells
Requires:       %{name} = %{version}
Requires:       bash-completion
Supplements:    (%{name} and bash-completion)
BuildArch:      noarch

%description -n %{name}-bash-completion
Bash command line completion support for %{name}.

%package -n %{name}-fish-completion
Summary:        Fish Completion for %{name}
Group:          System/Shells
Requires:       %{name} = %{version}
Supplements:    (%{name} and fish)
BuildArch:      noarch

%description -n %{name}-fish-completion
Fish command line completion support for %{name}.

%package -n %{name}-zsh-completion
Summary:        Zsh Completion for %{name}
Group:          System/Shells
Requires:       %{name} = %{version}
Supplements:    (%{name} and zsh)
BuildArch:      noarch

%description -n %{name}-zsh-completion
zsh command line completion support for %{name}.

%prep
%autosetup -p 1 -a 1

%build
export K8S_VERSION=$(awk '/^export K8S_VERSION/ {print $4}' Makefile)
go build \
   -mod=vendor \
   -buildmode=pie \
   -ldflags="-X github.com/operator-framework/operator-sdk/internal/version.Version=%{version} \
   -X github.com/operator-framework/operator-sdk/internal/version.GitVersion=v%{version} \
   -X github.com/operator-framework/operator-sdk/internal/version.GitCommit=v%{version} \
   -X github.com/operator-framework/operator-sdk/internal/version.ImageVersion=v%{version} \
   -X github.com/operator-framework/operator-sdk/internal/version.KubernetesVersion=v${K8S_VERSION}" \
   -o bin/operator-sdk ./cmd/operator-sdk

%install
# Install the binary.
install -D -m 0755 bin/%{name} "%{buildroot}/%{_bindir}/%{name}"

# create the bash completion file
mkdir -p %{buildroot}%{_datarootdir}/bash-completion/completions/
%{buildroot}/%{_bindir}/%{name} completion bash > %{buildroot}%{_datarootdir}/bash-completion/completions/%{name}

# create the fish completion file
mkdir -p %{buildroot}%{_datarootdir}/fish/vendor_completions.d/
%{buildroot}/%{_bindir}/%{name} completion fish > %{buildroot}%{_datarootdir}/fish/vendor_completions.d/%{name}.fish

# create the zsh completion file
mkdir -p %{buildroot}%{_datarootdir}/zsh/site-functions/
%{buildroot}/%{_bindir}/%{name} completion zsh > %{buildroot}%{_datarootdir}/zsh/site-functions/_%{name}

%files
%doc README.md
%license LICENSE
%{_bindir}/%{name}

%files -n %{name}-bash-completion
%{_datarootdir}/bash-completion/completions/%{name}

%files -n %{name}-fish-completion
%{_datarootdir}/fish/vendor_completions.d/%{name}.fish

%files -n %{name}-zsh-completion
%{_datarootdir}/zsh/site-functions/_%{name}

%changelog
openSUSE Build Service is sponsored by