You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
Irbe Krumina ba517ab388
cmd/k8s-operator,ssh/tailssh,tsnet: optionally record 'kubectl exec' sessions via Kubernetes operator's API server proxy (#12274)
cmd/k8s-operator,ssh/tailssh,tsnet: optionally record kubectl exec sessions

The Kubernetes operator's API server proxy, when it receives a request
for 'kubectl exec' session now reads 'RecorderAddrs', 'EnforceRecorder'
fields from tailcfg.KubernetesCapRule.
If 'RecorderAddrs' is set to one or more addresses (of a tsrecorder instance(s)),
it attempts to connect to those and sends the session contents
to the recorder before forwarding the request to the kube API
server. If connection cannot be established or fails midway,
it is only allowed if 'EnforceRecorder' is not true (fail open).

Updates tailscale/corp#19821

Signed-off-by: Irbe Krumina <irbe@tailscale.com>
Co-authored-by: Maisem Ali <maisem@tailscale.com>
5 months ago
.bencher
.github scripts: don't refresh the pacman repository on Arch (#12194) 5 months ago
appc
atomicfile
chirp
client
clientupdate
cmd cmd/k8s-operator,ssh/tailssh,tsnet: optionally record 'kubectl exec' sessions via Kubernetes operator's API server proxy (#12274) 5 months ago
control control/controlknobs,tailcfg,wgengine/magicsock: remove DRPO shutoff switch 5 months ago
derp derp/xdp: retain the link so that the fd is not closed 5 months ago
disco
docs
doctor
drive
envknob
gokrazy
health health: send ImpactsConnectivity value over LocalAPI (#12700) 5 months ago
hostinfo
internal
ipn ipn/ipnlocal: handle auto value for ExitNodeID syspolicy (#12512) 5 months ago
jsondb
k8s-operator
kube
licenses licenses: update license notices 5 months ago
log
logpolicy
logtail
metrics
net net/dns: fix broken dns benchmark tests (#12686) 5 months ago
omit
packages/deb
paths
portlist
posture
prober
proxymap
publicapi
release
safesocket
safeweb
scripts scripts: don't refresh the pacman repository on Arch (#12194) 5 months ago
smallzstd
ssh/tailssh cmd/k8s-operator,ssh/tailssh,tsnet: optionally record 'kubectl exec' sessions via Kubernetes operator's API server proxy (#12274) 5 months ago
syncs
tailcfg wgengine/magicsock: add debug envknob for injecting an endpoint 5 months ago
taildrop
tempfork
tka ipn/ipnlocal: allow multiple signature chains from the same SigCredential 5 months ago
tool tool/gocross: fix regression detecting when gocross needs rebuild 5 months ago
tsconst
tsd
tsnet tsnet: do not log an error on shutdown 5 months ago
tstest
tstime
tsweb
types
util util/winutil/s4u: fix some doc comments in the s4u package 5 months ago
version version/mkversion: allow env config of oss git cache dir 5 months ago
wf
wgengine wgengine/magicsock: add debug envknob for injecting an endpoint 5 months ago
words
.gitattributes
.gitignore
.golangci.yml
ALPINE.txt
AUTHORS
CODEOWNERS
CODE_OF_CONDUCT.md
Dockerfile
Dockerfile.base
LICENSE
Makefile cmd/k8s-operator: add depaware.txt 5 months ago
PATENTS
README.md
SECURITY.md
VERSION.txt
api.md
build_dist.sh
build_docker.sh
flake.lock
flake.nix go.mod.sri: update SRI hash for go.mod changes 5 months ago
go.mod go.mod: bump github.com/tailscale/wireguard-go 5 months ago
go.mod.sri go.mod.sri: update SRI hash for go.mod changes 5 months ago
go.sum go.mod: bump github.com/tailscale/wireguard-go 5 months ago
go.toolchain.branch
go.toolchain.rev go.toolchain.rev: update to Go 1.22.5 (#12690) 5 months ago
gomod_test.go
header.txt
pull-toolchain.sh
shell.nix go.mod.sri: update SRI hash for go.mod changes 5 months ago
staticcheck.conf
update-flake.sh
version-embed.go
version_test.go

README.md

Tailscale

https://tailscale.com

Private WireGuard® networks made easy

Overview

This repository contains the majority of Tailscale's open source code. Notably, it includes the tailscaled daemon and the tailscale CLI tool. The tailscaled daemon runs on Linux, Windows, macOS, and to varying degrees on FreeBSD and OpenBSD. The Tailscale iOS and Android apps use this repo's code, but this repo doesn't contain the mobile GUI code.

Other Tailscale repos of note:

For background on which parts of Tailscale are open source and why, see https://tailscale.com/opensource/.

Using

We serve packages for a variety of distros and platforms at https://pkgs.tailscale.com.

Other clients

The macOS, iOS, and Windows clients use the code in this repository but additionally include small GUI wrappers. The GUI wrappers on non-open source platforms are themselves not open source.

Building

We always require the latest Go release, currently Go 1.22. (While we build releases with our Go fork, its use is not required.)

go install tailscale.com/cmd/tailscale{,d}

If you're packaging Tailscale for distribution, use build_dist.sh instead, to burn commit IDs and version info into the binaries:

./build_dist.sh tailscale.com/cmd/tailscale
./build_dist.sh tailscale.com/cmd/tailscaled

If your distro has conventions that preclude the use of build_dist.sh, please do the equivalent of what it does in your distro's way, so that bug reports contain useful version information.

Bugs

Please file any issues about this code or the hosted service on the issue tracker.

Contributing

PRs welcome! But please file bugs. Commit messages should reference bugs.

We require Developer Certificate of Origin Signed-off-by lines in commits.

See git log for our commit message style. It's basically the same as Go's style.

About Us

Tailscale is primarily developed by the people at https://github.com/orgs/tailscale/people. For other contributors, see:

WireGuard is a registered trademark of Jason A. Donenfeld.