summaryrefslogtreecommitdiff
path: root/main.go
blob: 3ea9e93e90240eeb27e866860f2bc68701935dde (plain)
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
package main

import (
	"embed"
	"fmt"
	"net/http"
	"time"

	"go.wit.com/lib/gui/prep"
	"go.wit.com/lib/protobuf/forgepb"
	"go.wit.com/log"
)

// are sent via -ldflags at buildtime
var VERSION string
var BUILDTIME string
var ARGNAME string = "forged"

//go:embed resources/*
var resources embed.FS

var HOSTNAME string = "forge.wit.com"

func main() {
	me = new(mainType)
	me.myGui = prep.Gui()      // prepares the GUI package for go-args
	me.auto = prep.Bash(&argv) // this line should be:  prep.Bash(&argv)

	me.forge = forgepb.InitByAppname(ARGNAME)
	me.forge.Config.DumpENV()

	if err := me.forge.InitPatchsets(); err != nil {
		log.Info("patches failed to open", err)
		badExit(err)
	}

	if argv.Patch != nil {
		if err := doPatches(); err != nil {
			badExit(err)
		}
		okExit("")
	}

	if argv.Repos != nil {
		if err := doRepos(); err != nil {
			badExit(err)
		}
		okExit("")
	}

	if argv.Daemon == true {
		if argv.Gui != nil {
			me.myGui.Start() // loads the GUI toolkit
			doGui()          // start making our forge GUI
			debug()          // sits here forever
		}
		mux := http.NewServeMux()
		okHandlerFunc := http.HandlerFunc(okHandler)

		// Set a limit of 50 kilobytes for requests to this handler.
		// Adjust this value to your needs.
		const maxUploadSize = 1025 * 1024 // 1 MB
		mux.Handle("/", http.MaxBytesHandler(okHandlerFunc, maxUploadSize))

		p := fmt.Sprintf(":%d", argv.Port)
		log.Printf("Server starting on port %s...\n", p)
		log.Printf("Test with: curl -d 'hello world' http://localhost:%s/\n", p)

		server := &http.Server{
			Addr:         p,
			Handler:      mux,
			ReadTimeout:  5 * time.Minute,
			WriteTimeout: 10 * time.Second,
			IdleTimeout:  120 * time.Second,
		}

		log.Printf("Server starting on port %s with a 1 MB request body limit...\n", p)
		if err := server.ListenAndServe(); err != nil {
			log.Fatal("Could not start server: %s\n", err)
		}
		okExit("")
	}

	log.Info("--daemon was not set. Just list the patches.")
	// doList()
}