Mirror of tailscale/tailscale@github.com
Go to file
David Anderson e0e677a8f6 net/dns: split out search domains and match domains in OSConfig.
It seems that all the setups that support split DNS understand
this distinction, and it's an important one when translating
high-level configuration.

Part of #953.

Signed-off-by: David Anderson <danderson@tailscale.com>
2021-04-06 15:27:09 -07:00
.github Switch to Go 1.16. 2021-02-19 13:18:31 -08:00
atomicfile atomicfile: don't Chmod on windows 2020-07-15 12:31:40 -07:00
client/tailscale cmd/tailscale, ipn/localapi: add "tailscale bugreport" subcommand 2021-03-31 15:19:51 -07:00
cmd cmd/tailscale/cli: add debug command to print localapi curl command 2021-04-06 14:05:49 -07:00
control/controlclient cmd/tailscale, ipn/localapi: move IP forwarding check to tailscaled, API 2021-03-31 12:09:16 -07:00
derp derp: return keep-alive message up to callers 2021-03-15 10:43:48 -07:00
disco wgengine/magicsock: send, use endpoints in CallMeMaybe messages 2021-01-20 14:59:41 -08:00
health health: add DNS subsystem and plumb errors in. 2021-04-05 10:55:35 -07:00
internal wgengine: move DNS configuration out of wgengine/router. 2021-04-05 10:55:35 -07:00
ipn ipn/localapi: add API for getting file targets 2021-04-06 11:01:30 -07:00
log log/filelogger: move our Windows disk file writing+rotation package here 2020-10-29 14:59:44 -07:00
logpolicy logpolicy: set log target on windows based on a registry key (#1542) 2021-03-18 13:23:56 -04:00
logtail logtail: use link monitor to determine when to retry after upload failure 2021-03-02 16:30:57 -08:00
metrics metrics: add LabelMap.GetFloat 2020-07-19 12:31:12 -07:00
net net/dns: split out search domains and match domains in OSConfig. 2021-04-06 15:27:09 -07:00
paths ipn/ipnlocal: make peerapi work on iOS again 2021-03-31 14:09:06 -07:00
portlist portlist: collect IPv6 listening sockets on linux. 2021-03-04 13:52:56 -08:00
safesocket client/tailscale, cmd/tailscale/cli: plumb --socket through 2021-03-30 10:09:14 -07:00
scripts Allow 2021 in LICENSE header. 2021-01-08 10:23:32 -08:00
smallzstd smallzstd: new package that constructs zstd small encoders/decoders. 2020-07-02 16:13:06 -07:00
syncs syncs: disable TestWatchMultipleValues on Windows CI builds 2021-03-27 13:25:33 -07:00
tailcfg net/dns: remove PerDomain from Config. 2021-04-01 22:55:44 -07:00
tempfork tempfork/wireguard-windows/firewall: add. 2021-03-01 19:37:22 -08:00
tsconst net/netns: add windows support. 2020-09-14 16:28:49 -07:00
tstest tstest/natlab: use net.ErrClosed 2021-03-24 09:46:36 -07:00
tstime tstime: add RandomDurationBetween helper 2021-01-21 07:54:14 -08:00
tsweb tsweb: add num_goroutines expvar 2021-02-01 14:38:59 -08:00
types types/preftype: don't use iota for consts persisted to disk 2021-04-02 09:02:54 -07:00
util net/dns/resolver: teach the forwarder to do per-domain routing. 2021-04-01 19:42:48 -07:00
version version/distro: look for absolute synology path 2021-04-01 17:21:36 -07:00
wgengine net/dns: add a Primary field to OSConfig. 2021-04-05 13:05:47 -07:00
.gitattributes .gitattributes: add a smudge filter for go.mod. 2020-02-19 20:02:02 -05:00
.gitignore Revert "cmd/tailscaled: split package main into main shim + package" 2021-03-25 09:06:00 -07:00
AUTHORS Move Linux client & common packages into a public repo. 2020-02-09 09:32:57 -08:00
CODE_OF_CONDUCT.md Add a code of conduct. 2020-02-10 22:16:30 -08:00
Dockerfile build_docker.sh, Dockerfile: fix bug with shell quoting 2021-03-05 10:38:32 -08:00
LICENSE LICENSE: Reformat for Github 2021-01-24 16:20:22 -08:00
Makefile wgengine/netstack: fix 32-bit build broken from prior commit 2021-03-01 11:19:31 -08:00
PATENTS Move Linux client & common packages into a public repo. 2020-02-09 09:32:57 -08:00
README.md Switch to Go 1.16. 2021-02-19 13:18:31 -08:00
SECURITY.md Add a SECURITY.md for vulnerability reports. 2020-02-11 10:26:41 -08:00
VERSION.txt VERSION.txt: this is 1.7.0. 2021-03-16 19:04:55 -07:00
api.md api.md: add TOC 2021-01-19 12:35:09 -08:00
build_dist.sh build_dist: fix after version refactor. 2020-11-03 14:40:09 -08:00
build_docker.sh build_docker.sh, Dockerfile: fix bug with shell quoting 2021-03-05 10:38:32 -08:00
go.mod go.mod: update wireguard-go again 2021-04-03 10:35:17 -07:00
go.sum go.mod: update wireguard-go again 2021-04-03 10:35:17 -07:00
shell.nix add nix-shell boilerplate (#1028) 2020-12-29 12:17:03 -05:00

README.md

Tailscale

https://tailscale.com

Private WireGuard® networks made easy

Overview

This repository contains all the open source Tailscale client code and the tailscaled daemon and tailscale CLI tool. The tailscaled daemon runs primarily on Linux; it also works to varying degrees on FreeBSD, OpenBSD, Darwin, and Windows.

The Android app is at https://github.com/tailscale/tailscale-android

Using

We serve packages for a variety of distros 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 that are not open source.

Building

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.

We only guarantee to support the latest Go release and any Go beta or release candidate builds (currently Go 1.16) in module mode. It might work in earlier Go versions or in GOPATH mode, but we're making no effort to keep those working.

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.

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.