mirror of
https://github.com/tailscale/tailscale.git
synced 2024-11-27 03:55:36 +00:00
02582083d5
#7339 changed the root directory logic to find the ancestor of the cwd with a go.mod file. This works when running the the binary from this repo directly, but breaks when we're a dependency in another repo. Allow the directory to be passed in via a -rootdir flag (the repo that depends on it can then use `go list -m -f '{{.Dir}}' tailscale.com` or similar to pass in the value). Updates tailscale/corp#10165 Signed-off-by: Mihai Parparita <mihai@tailscale.com>
70 lines
2.2 KiB
Go
70 lines
2.2 KiB
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
// The tsconnect command builds and serves the static site that is generated for
|
|
// the Tailscale Connect JS/WASM client. Can be run in 3 modes:
|
|
// - dev: builds the site and serves it. JS and CSS changes can be picked up
|
|
// with a reload.
|
|
// - build: builds the site and writes it to dist/
|
|
// - serve: serves the site from dist/ (embedded in the binary)
|
|
package main // import "tailscale.com/cmd/tsconnect"
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
"os"
|
|
)
|
|
|
|
var (
|
|
addr = flag.String("addr", ":9090", "address to listen on")
|
|
distDir = flag.String("distdir", "./dist", "path of directory to place build output in")
|
|
pkgDir = flag.String("pkgdir", "./pkg", "path of directory to place NPM package build output in")
|
|
yarnPath = flag.String("yarnpath", "../../tool/yarn", "path yarn executable used to install JavaScript dependencies")
|
|
fastCompression = flag.Bool("fast-compression", false, "Use faster compression when building, to speed up build time. Meant to iterative/debugging use only.")
|
|
devControl = flag.String("dev-control", "", "URL of a development control server to be used with dev. If provided without specifying dev, an error will be returned.")
|
|
rootDir = flag.String("rootdir", "", "Root directory of repo. If not specified, will be inferred from the cwd.")
|
|
)
|
|
|
|
func main() {
|
|
flag.Usage = usage
|
|
flag.Parse()
|
|
if len(flag.Args()) != 1 {
|
|
flag.Usage()
|
|
}
|
|
|
|
switch flag.Arg(0) {
|
|
case "dev":
|
|
runDev()
|
|
case "dev-pkg":
|
|
runDevPkg()
|
|
case "build":
|
|
runBuild()
|
|
case "build-pkg":
|
|
runBuildPkg()
|
|
case "serve":
|
|
runServe()
|
|
default:
|
|
log.Printf("Unknown command: %s", flag.Arg(0))
|
|
flag.Usage()
|
|
}
|
|
}
|
|
|
|
func usage() {
|
|
fmt.Fprintf(os.Stderr, `
|
|
usage: tsconnect {dev|build|serve}
|
|
`[1:])
|
|
|
|
flag.PrintDefaults()
|
|
fmt.Fprintf(os.Stderr, `
|
|
|
|
tsconnect implements development/build/serving workflows for Tailscale Connect.
|
|
It can be invoked with one of three subcommands:
|
|
|
|
- dev: Run in development mode, allowing JS and CSS changes to be picked up without a rebuilt or restart.
|
|
- build: Run in production build mode (generating static assets)
|
|
- serve: Run in production serve mode (serving static assets)
|
|
`[1:])
|
|
os.Exit(2)
|
|
}
|