mirror of
https://git.freesoftwareextremist.com/bloat
synced 2024-11-09 16:14:11 +00:00
60392e61c7
Access logs aren't really useful during normal operation. Add a new flag -v to enable the verbose logging mode, which is still useful during the development. Also remove the log_file config because it's no longer useful.
66 lines
1.3 KiB
Go
66 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"errors"
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
|
|
"bloat/config"
|
|
"bloat/renderer"
|
|
"bloat/service"
|
|
)
|
|
|
|
var (
|
|
configFiles = []string{"bloat.conf", "/etc/bloat.conf"}
|
|
)
|
|
|
|
func errExit(err error) {
|
|
fmt.Fprintln(os.Stderr, err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
func main() {
|
|
configFile := flag.String("f", "", "config file")
|
|
verbose := flag.Bool("v", false, "verbose mode")
|
|
flag.Parse()
|
|
|
|
if len(*configFile) > 0 {
|
|
configFiles = []string{*configFile}
|
|
}
|
|
config, err := config.ParseFiles(configFiles)
|
|
if err != nil {
|
|
errExit(err)
|
|
}
|
|
|
|
if !config.IsValid() {
|
|
errExit(errors.New("invalid config"))
|
|
}
|
|
|
|
templatesGlobPattern := filepath.Join(config.TemplatesPath, "*")
|
|
renderer, err := renderer.NewRenderer(templatesGlobPattern)
|
|
if err != nil {
|
|
errExit(err)
|
|
}
|
|
|
|
customCSS := config.CustomCSS
|
|
if len(customCSS) > 0 && !strings.HasPrefix(customCSS, "http://") &&
|
|
!strings.HasPrefix(customCSS, "https://") {
|
|
customCSS = "/static/" + customCSS
|
|
}
|
|
|
|
s := service.NewService(config.ClientName, config.ClientScope,
|
|
config.ClientWebsite, customCSS, config.SingleInstance,
|
|
config.PostFormats, renderer)
|
|
handler := service.NewHandler(s, *verbose, config.StaticDirectory)
|
|
|
|
log.Println("listening on", config.ListenAddress)
|
|
err = http.ListenAndServe(config.ListenAddress, handler)
|
|
if err != nil {
|
|
errExit(err)
|
|
}
|
|
}
|