mirror of
https://github.com/tailscale/tailscale.git
synced 2025-10-24 01:31:55 +00:00

This adds a new `UserLogf` field to the `Server` struct. When set this any logs generated by Server are logged using `UserLogf` and all spammy backend logs are logged to `Logf`. If it `UserLogf` is unset, we default to `log.Printf` and if `Logf` is unset we discard all the spammy logs. Fixes #12094 Signed-off-by: Maisem Ali <maisem@tailscale.com>
42 lines
843 B
Go
42 lines
843 B
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
// The tsnet-funnel server demonstrates how to use tsnet with Funnel.
|
|
//
|
|
// To use it, generate an auth key from the Tailscale admin panel and
|
|
// run the demo with the key:
|
|
//
|
|
// TS_AUTHKEY=<yourkey> go run tsnet-funnel.go
|
|
package main
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
"net/http"
|
|
|
|
"tailscale.com/tsnet"
|
|
)
|
|
|
|
func main() {
|
|
flag.Parse()
|
|
s := &tsnet.Server{
|
|
Dir: "./funnel-demo-config",
|
|
Hostname: "fun",
|
|
}
|
|
defer s.Close()
|
|
|
|
ln, err := s.ListenFunnel("tcp", ":443")
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
defer ln.Close()
|
|
|
|
fmt.Printf("Listening on https://%v\n", s.CertDomains()[0])
|
|
|
|
err = http.Serve(ln, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
fmt.Fprintln(w, "<html><body><h1>Hello, internet!</h1>")
|
|
}))
|
|
log.Fatal(err)
|
|
}
|