mirror of
https://github.com/tailscale/tailscale.git
synced 2024-12-13 11:44:36 +00:00
1a093ef482
`src/` is broken up into several subdirectories: - `lib/` and `types`/ for shared code and type definitions (more code will be moved here) - `app/` for the existing Preact-app - `pkg/` for the new NPM package A new `build-pkg` esbuild-based command is added to generate the files for the NPM package. To generate type definitions (something that esbuild does not do), we set up `dts-bundle-generator`. Includes additional cleanups to the Wasm type definitions (we switch to string literals for enums, since exported const enums are hard to use via packages). Also allows the control URL to be set a runtime (in addition to the current build option), so that we don't have to rebuild the package for dev vs. prod use. Updates #5415 Signed-off-by: Mihai Parparita <mihai@tailscale.com>
68 lines
2.2 KiB
Go
68 lines
2.2 KiB
Go
// Copyright (c) 2022 Tailscale Inc & AUTHORS All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// 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.")
|
|
)
|
|
|
|
func main() {
|
|
flag.Usage = usage
|
|
flag.Parse()
|
|
if len(flag.Args()) != 1 {
|
|
flag.Usage()
|
|
}
|
|
|
|
switch flag.Arg(0) {
|
|
case "dev":
|
|
runDev()
|
|
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)
|
|
}
|