-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathmain.go
65 lines (54 loc) · 1.45 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package main
import (
"log"
"net"
"net/http"
"strings"
)
var (
version = "master"
revision = "dev"
)
func main() {
log.SetFlags(log.Flags() | log.LUTC)
if len(revision) > 8 {
revision = revision[:8]
}
log.Printf("Cloud IAP Auth & Proxy Server (build: %s.%s)\n", version, revision)
if err := initConfig(); err != nil {
log.Fatal(err)
}
log.Printf("Matching audiences: %s\n", cfg.MatchAudiences)
if len(cfg.MatchDomains) > 0 {
log.Printf("Matching domains: %s\n", strings.Join(parsedDomains, ", "))
}
http.HandleFunc("/auth", authHandler)
http.HandleFunc("/healthz", healthzHandler)
if backend != nil && *backend != "" {
proxy, err := newProxy(*backend, *emailHeader)
if err != nil {
log.Fatal(err)
}
log.Printf("Proxying authenticated requests to backend %s", *backend)
http.HandleFunc("/", proxy.handler)
}
addr := net.JoinHostPort(*listenAddr, *listenPort)
if len(*tlsCertPath) != 0 || len(*tlsKeyPath) != 0 {
listenAndServeHTTPS(addr)
} else {
listenAndServeHTTP(addr)
}
}
func listenAndServeHTTP(addr string) {
log.Printf("Listening on http://%s\n", addr)
if err := http.ListenAndServe(addr, nil); err != nil {
log.Fatalf("Failed to listen on http://%s (%v)\n", addr, err)
}
}
func listenAndServeHTTPS(addr string) {
log.Printf("Listening on https://%s\n", addr)
err := http.ListenAndServeTLS(addr, *tlsCertPath, *tlsKeyPath, nil)
if err != nil {
log.Fatalf("Failed to listen on https://%s (%v)\n", addr, err)
}
}