# # spec file for package glasskube-cli # # Copyright (c) 2024 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/ # %define executable_name glasskube Name: glasskube-cli Version: 0.26.0 Release: 0 Summary: The next generation Package Manager for Kubernetes License: Apache-2.0 URL: https://github.com/glasskube/glasskube Source: %{name}-%{version}.tar.gz Source1: vendor.tar.gz BuildRequires: bash-completion BuildRequires: fish BuildRequires: go >= 1.20 BuildRequires: zsh Provides: glasskube = %{version} %description Glasskube is an Open Source package manager for Kubernetes. It makes deploying, updating, and configuring packages on Kubernetes 20 times faster than tools like Helm or Kustomize. Inspired by the simplicity of Homebrew and npm. You can decide if you want to use the Glasskube UI, CLI, or directly deploy packages via GitOps. %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 # hash will be shortened by COMMIT_HASH:0:8 later COMMIT_HASH="$(sed -n 's/commit: \(.*\)/\1/p' %_sourcedir/%{name}.obsinfo)" DATE_FMT="+%%Y-%%m-%%dT%%H:%%M:%%SZ" BUILD_DATE=$(date -u -d "@${SOURCE_DATE_EPOCH}" "${DATE_FMT}" 2>/dev/null || date -u -r "${SOURCE_DATE_EPOCH}" "${DATE_FMT}" 2>/dev/null || date -u "${DATE_FMT}") go build \ -mod=vendor \ -buildmode=pie \ -ldflags=" \ -X github.com/glasskube/glasskube/internal/config.Version=v%{version} \ -X github.com/glasskube/glasskube/internal/config.Commit=${COMMIT_HASH:0:8} \ -X github.com/glasskube/glasskube/internal/config.Date=${BUILD_DATE}" \ -o bin/%{executable_name} ./cmd/glasskube %install # Install the binary. install -D -m 0755 bin/%{executable_name} %{buildroot}/%{_bindir}/%{executable_name} # create the bash completion file mkdir -p %{buildroot}%{_datarootdir}/bash-completion/completions/ %{buildroot}/%{_bindir}/%{executable_name} completion bash > %{buildroot}%{_datarootdir}/bash-completion/completions/%{executable_name} # create the fish completion file mkdir -p %{buildroot}%{_datarootdir}/fish/vendor_completions.d/ %{buildroot}/%{_bindir}/%{executable_name} completion fish > %{buildroot}%{_datarootdir}/fish/vendor_completions.d/%{executable_name}.fish # create the zsh completion file mkdir -p %{buildroot}%{_datarootdir}/zsh/site-functions/ %{buildroot}/%{_bindir}/%{executable_name} completion zsh > %{buildroot}%{_datarootdir}/zsh/site-functions/_%{executable_name} %files %doc README.md %license LICENSE %{_bindir}/%{executable_name} %files -n %{name}-bash-completion %{_datarootdir}/bash-completion/completions/%{executable_name} %files -n %{name}-fish-completion %{_datarootdir}/fish/vendor_completions.d/%{executable_name}.fish %files -n %{name}-zsh-completion %{_datarootdir}/zsh/site-functions/_%{executable_name} %changelog