aboutsummaryrefslogtreecommitdiff
path: root/cmd/web/main.go
blob: ec0704d47f0b5b1956c41a3cd4e21dea12ca7ea3 (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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
package main

import (
	"flag"
	"fmt"
	"log"
	"math/rand"
	"net/http"
	"os"
	"sync"
	"time"

	"github.com/gorilla/mux"
	"riedstra.dev/mitch/steam-export/steam"
)

var (
	Version = "Development"
	Logger = log.New(os.Stderr, "", log.LstdFlags)
	Listen = ":8899"

	libMu = &sync.RWMutex{}
	Lib   *steam.Library
)

func reloadLib() {
	Logger.Println("Starting library reload")
	libMu.Lock()
	defer libMu.Unlock()
	var err error
	l2, err := steam.NewLibrary(DefaultLib)
	if err != nil {
		Logger.Printf("Error reopening library: %s", err)
		return
	}
	Lib = l2
	Logger.Println("Done reloading library")
}

func setLibHandler(w http.ResponseWriter, r *http.Request) {
	err := r.ParseForm()
	if err != nil {
		Logger.Printf("Setlib: While parsing form: %s", err)
		http.Error(w, fmt.Sprintf("Invalid form: %s", err), 400)
		return
	}

	DefaultLib = r.Form.Get("path")
	reloadLib()
	http.Redirect(w, r, "/", 302)
}

func quitHandler(w http.ResponseWriter, r *http.Request) {
	Logger.Println("Quit was called, exiting")
	w.Header().Add("Content-type", "text/plain")
	w.Write([]byte("Shutting down..."))
	go func() {
		time.Sleep(time.Second*2)
		os.Exit(0)
	}()
	return
}

func main() {
	fl := flag.NewFlagSet("steam-export", flag.ExitOnError)
	debug := fl.Bool("d", false, "Print line numbers in log")
	fl.StringVar(&Listen, "l", Listen, "What address do we listen on?")
	fl.StringVar(&DefaultLib, "L", DefaultLib, "Full path to default library")
	fl.Parse(os.Args[1:])

	if *debug {
		Logger.SetFlags(log.LstdFlags | log.Llongfile)
	}

	var err error
	Lib, err = steam.NewLibrary(DefaultLib)
	if err != nil {
		Logger.Fatalf("While opening library path: %s", err)
	}

	go installer(getPath)

	r := mux.NewRouter()

	r.HandleFunc("/quit", quitHandler)
	r.HandleFunc("/setLib", setLibHandler)
	r.HandleFunc("/delete", gameDelete)
	r.HandleFunc("/install", gameInstaller)
	r.HandleFunc("/download/{game}", gameDownloader)
	r.HandleFunc("/style.css", cssHandler)
	r.HandleFunc("/", index)

	s := http.Server{
		Handler: r,
		Addr:    Listen,
	}

	go startBrowser()

	for i := 0; i < 5; i++ {
		err = s.ListenAndServe()
		if err != nil {
			Logger.Printf("Encountered: %s", err)
			rand.Seed(time.Now().UnixNano())
			Listen = fmt.Sprintf(":%d", rand.Intn(63000)+1024)
			Logger.Printf("Trying: %s", Listen)
			s.Addr = Listen
		}

	}
}