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
Brad Fitzpatrick 515866d7c6 ipn, ipnserver, cmd/tailscale: add "server mode" support on Windows
This partially (but not yet fully) migrates Windows to tailscaled's
StateStore storage system.

This adds a new bool Pref, ForceDaemon, defined as:

// ForceDaemon specifies whether a platform that normally
// operates in "client mode" (that is, requires an active user
// logged in with the GUI app running) should keep running after the
// GUI ends and/or the user logs out.
//
// The only current applicable platform is Windows. This
// forced Windows to go into "server mode" where Tailscale is
// running even with no users logged in. This might also be
// used for macOS in the future. This setting has no effect
// for Linux/etc, which always operate in daemon mode.

Then, when ForceDaemon becomes true, we now write use the StateStore
to track which user started it in server mode, and store their prefs
under that key.

The ipnserver validates the connections/identities and informs that
LocalBackend which userid is currently in charge.

The GUI can then enable/disable server mode at runtime, without using
the CLI.

But the "tailscale up" CLI was also fixed, so Windows users can use
authkeys or ACL tags, etc.

Updates #275
4 years ago
.github Add depaware.txt files and GitHub checks. (#745) 4 years ago
atomicfile atomicfile: don't Chmod on windows 4 years ago
cmd ipn, ipnserver, cmd/tailscale: add "server mode" support on Windows 4 years ago
control/controlclient controlclient: print http errors if result code != 200. 4 years ago
derp tshttp, derphttp: send Proxy-Authorization, not Authorization, to proxies 4 years ago
disco wgengine/magicsock: run test DERP in mode where only disco packets allowed 4 years ago
internal Add tooldeps package to keep depaware pinned in go.mod. 4 years ago
ipn ipn, ipnserver, cmd/tailscale: add "server mode" support on Windows 4 years ago
log/logheap log/logheap: properly document LogHeap as performing HTTP upload (#741) 4 years ago
logpolicy all: use IsZero methods 4 years ago
logtail all: use testing.T.TempDir 4 years ago
metrics metrics: add LabelMap.GetFloat 4 years ago
net ipn, wgengine, magicsock, tsdns: be quieter and less aggressive when offline 4 years ago
paths paths, cmd/tailscaled: on Windows, don't try to migrate from legacy relay.conf 4 years ago
portlist portlist: reduce log spam on macOS 4 years ago
safesocket safesocket: gofmt 4 years ago
scripts scripts: don't descend into .git for license header check 4 years ago
smallzstd smallzstd: new package that constructs zstd small encoders/decoders. 4 years ago
syncs syncs: add Watch, for monitoring mutex contention 4 years ago
tailcfg tailcfg: restore Roles field to UserProfile 4 years ago
tempfork all: use testing.T.TempDir 4 years ago
tsconst net/netns: add windows support. 4 years ago
tstest tstest: skip resource check when test has failed 4 years ago
tstime tstime: hand-implement parseInt for specific needs of rfc3339 parsing. 4 years ago
tsweb tsweb: when unwrapping HTTPError, record the user-facing message also in the log 4 years ago
types cmd/tailscaled: use the standard flag page instead of getopt 4 years ago
util util/uniq: add new package 4 years ago
version version: add Windows MAJOR,MINOR,BUILD,REVISON value 4 years ago
wgengine wgengine/monitor: fix copy/paste-o to actually monitor route changes 4 years ago
.gitattributes .gitattributes: add a smudge filter for go.mod. 4 years ago
.gitignore cmd/relaynode: drop local --acl-file in favour of central packet filter. 4 years ago
AUTHORS Move Linux client & common packages into a public repo. 4 years ago
CODE_OF_CONDUCT.md Add a code of conduct. 4 years ago
Dockerfile Dockerfile: install iproute2 in the container image. 4 years ago
LICENSE Move Linux client & common packages into a public repo. 4 years ago
Makefile Makefile: remove tsshd from depaware 4 years ago
PATENTS Move Linux client & common packages into a public repo. 4 years ago
README.md Switch to Go 1.15. 4 years ago
SECURITY.md Add a SECURITY.md for vulnerability reports. 4 years ago
go.mod go.mod: bump wireguard-go for x/sys/unix symbol loss 4 years ago
go.sum controlclient: print http errors if result code != 200. 4 years ago

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}

We only guarantee to support the latest Go release and any Go beta or release candidate builds (currently Go 1.15) 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

We are apenwarr, bradfitz, crawshaw, danderson, dfcarney, josharian from Tailscale Inc. You can learn more about us from our website.

WireGuard is a registered trademark of Jason A. Donenfeld.