|
|
@ -6,6 +6,8 @@
|
|
|
|
package main
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
import (
|
|
|
|
|
|
|
|
"crypto/tls"
|
|
|
|
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
"fmt"
|
|
|
|
"html"
|
|
|
|
"html"
|
|
|
|
"log"
|
|
|
|
"log"
|
|
|
@ -16,12 +18,22 @@ import (
|
|
|
|
"tailscale.com/tsnet"
|
|
|
|
"tailscale.com/tsnet"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var (
|
|
|
|
|
|
|
|
addr = flag.String("addr", ":80", "address to listen on")
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
func main() {
|
|
|
|
|
|
|
|
flag.Parse()
|
|
|
|
s := new(tsnet.Server)
|
|
|
|
s := new(tsnet.Server)
|
|
|
|
ln, err := s.Listen("tcp", ":80")
|
|
|
|
ln, err := s.Listen("tcp", *addr)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if *addr == ":443" {
|
|
|
|
|
|
|
|
ln = tls.NewListener(ln, &tls.Config{
|
|
|
|
|
|
|
|
GetCertificate: tailscale.GetCertificate,
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
log.Fatal(http.Serve(ln, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
log.Fatal(http.Serve(ln, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
who, err := tailscale.WhoIs(r.Context(), r.RemoteAddr)
|
|
|
|
who, err := tailscale.WhoIs(r.Context(), r.RemoteAddr)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|