193 lines
5.6 KiB
RPMSpec
193 lines
5.6 KiB
RPMSpec
#
|
|
# spec file for package teleport
|
|
#
|
|
# 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 __arch_install_post export NO_BRP_STRIP_DEBUG=true
|
|
|
|
Name: teleport
|
|
Version: 16.3.0
|
|
Release: 0
|
|
Summary: Identity-aware, multi-protocol access proxy
|
|
License: AGPL-3.0-only
|
|
URL: https://github.com/gravitational/teleport
|
|
Source: %{name}-%{version}.tar.gz
|
|
# go vendoring
|
|
Source1: vendor.tar.gz
|
|
Source2: webassets.tar.gz
|
|
Source3: teleport.service
|
|
Source4: teleport.yaml
|
|
Source5: tbot.yaml
|
|
# Rust vendoring
|
|
Source6: vendor.tar.zst
|
|
BuildRequires: cargo >= 1.69
|
|
BuildRequires: cargo-packaging
|
|
BuildRequires: git-core
|
|
BuildRequires: go1.22 >= 1.22.6
|
|
BuildRequires: pam-devel
|
|
BuildRequires: systemd-rpm-macros
|
|
Requires: teleport-tctl
|
|
|
|
%description
|
|
Teleport is the easiest, most secure way to access all your infrastructure. Teleport is an identity-aware, multi-protocol access proxy which understands SSH, HTTPS, RDP, Kubernetes API, MySQL, MongoDB and PostgreSQL wire protocols.
|
|
|
|
On the server-side, Teleport is a single binary which enables convenient secure access to behind-NAT resources such as:
|
|
* SSH nodes - SSH works in browsers too!
|
|
* Kubernetes clusters
|
|
* PostgreSQL, MongoDB, CockroachDB and MySQL databases
|
|
* Internal Web apps
|
|
* Windows Hosts
|
|
* Networked servers
|
|
|
|
%package -n teleport-tctl
|
|
Summary: CLI tool for managing a teleport server
|
|
License: Apache-2.0
|
|
|
|
%description -n teleport-tctl
|
|
An administrative tool that can configure Teleport Auth Service.
|
|
|
|
%package -n teleport-tsh
|
|
Summary: CLI tool for logging into nodes via Teleport SSH
|
|
License: Apache-2.0
|
|
|
|
%description -n teleport-tsh
|
|
A tool that lets end users interact with Teleport nodes. This replaces ssh.
|
|
|
|
%package -n teleport-tbot
|
|
Summary: CLI tool for Machine ID
|
|
License: Apache-2.0
|
|
|
|
%description -n teleport-tbot
|
|
Machine ID is a service that programmatically issues and renews short-lived certificates to any service account (e.g., a CI/CD server) by retrieving credentials from the Teleport Auth Service. This enables fine-grained role-based access controls and audit.
|
|
tbot is the executable belonging to the Machine ID service.
|
|
|
|
%package -n teleport-fdpass-teleport
|
|
Summary: Significantly reduce resource consumption by large numbers of SSH connections
|
|
License: Apache-2.0
|
|
|
|
%description -n teleport-fdpass-teleport
|
|
fdpass-teleport can be optionally used by Machine ID to significantly reduce resource consumption in use-cases that create large numbers of SSH connections (e.g. Ansible).
|
|
|
|
%prep
|
|
%setup -q
|
|
%setup -q -T -D -a 1
|
|
%setup -q -T -D -a 2
|
|
tar xvf %{SOURCE6} -C tool/fdpass-teleport
|
|
|
|
%build
|
|
|
|
mkdir -p lib/web/build/webassets
|
|
cp -r webassets/teleport/* lib/web/build/webassets
|
|
|
|
go build \
|
|
-tags "pam webassets_embed" \
|
|
-mod=vendor \
|
|
-buildmode=pie \
|
|
-ldflags="-w -s -X main.VERSION=%{version}" \
|
|
-o teleport ./tool/teleport
|
|
go build \
|
|
-tags "pam" \
|
|
-mod=vendor \
|
|
-buildmode=pie \
|
|
-ldflags="-w -s -X main.VERSION=%{version}" \
|
|
-o tsh ./tool/tsh
|
|
go build \
|
|
-tags "pam" \
|
|
-mod=vendor \
|
|
-buildmode=pie \
|
|
-ldflags="-w -s -X main.VERSION=%{version}" \
|
|
-o tbot ./tool/tbot
|
|
go build \
|
|
-tags "pam" \
|
|
-mod=vendor \
|
|
-buildmode=pie \
|
|
-ldflags="-w -s -X main.VERSION=%{version}" \
|
|
-o tctl ./tool/tctl
|
|
|
|
cd tool/fdpass-teleport
|
|
%{cargo_build}
|
|
|
|
%install
|
|
# Install the binary.
|
|
install -D -m 0755 tsh "%{buildroot}/%{_bindir}/tsh"
|
|
install -D -m 0755 tctl "%{buildroot}/%{_bindir}/tctl"
|
|
install -D -m 0755 tbot "%{buildroot}/%{_bindir}/tbot"
|
|
install -D -m 0755 tool/fdpass-teleport/target/release/fdpass-teleport "%{buildroot}/%{_bindir}/fdpass-teleport"
|
|
install -D -m 0755 teleport "%{buildroot}/%{_sbindir}/teleport"
|
|
install -D -m 644 %{SOURCE3} %{buildroot}%{_unitdir}/teleport.service
|
|
install -D -m 644 %{SOURCE4} %{buildroot}%{_sysconfdir}/teleport.yaml
|
|
install -D -m 644 examples/systemd/machine-id/machine-id.service %{buildroot}%{_unitdir}/
|
|
install -D -m 644 %{SOURCE5} %{buildroot}%{_sysconfdir}/tbot.yaml
|
|
|
|
# teleport service
|
|
|
|
%pre -n teleport
|
|
%service_add_pre teleport.service
|
|
|
|
%post -n teleport
|
|
%service_add_post teleport.service
|
|
|
|
%preun -n teleport
|
|
%service_del_preun teleport.service
|
|
|
|
%postun -n teleport
|
|
%service_del_postun teleport.service
|
|
|
|
# machine-id service
|
|
|
|
%pre -n teleport-tbot
|
|
%service_add_pre machine-id.service
|
|
|
|
%post -n teleport-tbot
|
|
%service_add_post machine-id.service
|
|
|
|
%preun -n teleport-tbot
|
|
%service_del_preun machine-id.service
|
|
|
|
%postun -n teleport-tbot
|
|
%service_del_postun machine-id.service
|
|
|
|
%files -n teleport
|
|
%doc README.md
|
|
%license LICENSE
|
|
%{_sbindir}/teleport
|
|
%{_unitdir}/teleport.service
|
|
%config(noreplace) %{_sysconfdir}/teleport.yaml
|
|
|
|
%files -n teleport-tsh
|
|
%doc README.md
|
|
%license LICENSE
|
|
%{_bindir}/tsh
|
|
|
|
%files -n teleport-tctl
|
|
%doc README.md
|
|
%license LICENSE
|
|
%{_bindir}/tctl
|
|
|
|
%files -n teleport-tbot
|
|
%doc README.md
|
|
%license LICENSE
|
|
%{_bindir}/tbot
|
|
%{_unitdir}/machine-id.service
|
|
%config(noreplace) %{_sysconfdir}/tbot.yaml
|
|
|
|
%files -n teleport-fdpass-teleport
|
|
%doc README.md
|
|
%license LICENSE
|
|
%{_bindir}/fdpass-teleport
|
|
|
|
%changelog
|