aboutsummaryrefslogtreecommitdiff
path: root/main.go
blob: 14358267395e0e85d659f22407ebbc66070c911e (plain) (blame)
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package main

import (
	"fmt"
	"html/template"
	"log"
	"net"
	"net/http"
	"net/http/fcgi"

	"gorm.io/driver/sqlite"
	"gorm.io/gorm"
)

var db *gorm.DB
var tmpl *template.Template

func handle_index(w http.ResponseWriter, req *http.Request) {
	tmpl.ExecuteTemplate(w, "index", nil)
}

func handle_login(w http.ResponseWriter, req *http.Request) {
	/* TODO: Invalidate current session */
	openid_authorization_url := generate_authorization_url()
	http.Redirect(w, req, openid_authorization_url, 303)
}

func main() {
	/*
	 * This seems necessary because in the following sections I need to
	 * assign to global variables like db and tmpl. If I use = there, and
	 * don't declare err here, then err is undeclared; but if I use :=
	 * there, my global variables are treated as local variables.
	 */
	var err error

	fbfp_get_config("fbfp.scfg")

	log.Printf("Opening database\n")
	switch config.Db.Type {
	case "sqlite":
		db, err = gorm.Open(sqlite.Open(config.Db.Conn), &gorm.Config{})
		e(err)
	default:
		e(fmt.Errorf("Database type \"%s\" unsupported", config.Db.Type))
	}

	log.Printf("Setting up templates\n")
	tmpl, err = template.ParseGlob("tmpl/*")
	e(err)

	if config.Static {
		log.Printf("Registering static handle\n")
		fs := http.FileServer(http.Dir("./static"))
		http.Handle("/static/", http.StripPrefix("/static/", fs))
	}

	log.Printf("Registering handlers\n")
	http.HandleFunc("/{$}", handle_index)
	http.HandleFunc("/login", handle_login)
	http.HandleFunc("/oidc", handle_oidc)

	log.Printf(
		"Establishing listener for net \"%s\", addr \"%s\"\n",
		config.Listen.Net,
		config.Listen.Addr,
	)
	l, err := net.Listen(config.Listen.Net, config.Listen.Addr)
	e(err)

	log.Printf("Fetching OpenID Connect configuration\n")
	get_openid_config(config.Openid.Endpoint)

	if config.Listen.Proto == "http" {
		log.Printf("Serving http\n")
		err = http.Serve(l, nil)
	} else if config.Listen.Proto == "fcgi" {
		log.Printf("Serving fcgi\n")
		err = fcgi.Serve(l, nil)
	}
	e(err)
}