Browse Source

Changed hard-coded values to config options

master
Gisle Aune 7 years ago
parent
commit
a83c372c9f
  1. 7
      aitestory.json
  2. BIN
      debug
  3. 2
      main.go
  4. 11
      server/config.go
  5. 29
      view/renderer.go

7
aitestory.json

@ -12,7 +12,7 @@
"server": {
"host": "0.0.0.0",
"port": 8000,
"ui": "./ui/"
"debug": true
},
"wiki": {
@ -21,6 +21,11 @@
"password": ""
},
"directories": {
"ui": "./ui/",
"templates": "./view/templates"
},
"test": {
"enabled": true,
"username": "AiteBot@AiteStory",

BIN
debug

2
main.go

@ -11,7 +11,7 @@ func main() {
router.Mount("/user", &controllers.UserController)
router.Mount("/", &controllers.ListController)
router.Static("/ui/", server.Main.Config.Server.UI)
router.Static("/ui/", server.Main.Config.Directories.UI)
server.Main.Start()
}

11
server/config.go

@ -20,11 +20,16 @@ type Config struct {
} `json:"db"`
Server struct {
Host string `json:"host"`
Port int `json:"port"`
UI string `json:"ui"`
Host string `json:"host"`
Port int `json:"port"`
Debug bool `json:"debug"`
} `json:"server"`
Directories struct {
UI string `json:"ui"`
Templates string `json:"templates"`
} `json:"directories"`
Wiki struct {
URL string `json:"url"`
Username string `json:"username"`

29
view/renderer.go

@ -9,17 +9,19 @@ import (
"os"
"path"
"git.aiterp.net/AiteRP/aitestory/server"
"git.aiterp.net/gisle/wrouter/response"
)
var wd, _ = os.Getwd()
var rootPath = path.Join(wd, "./view/templates/")
var cache = make(map[string]*template.Template)
var argsCache = make(map[string][]string)
// Register registers a template and compiles it for rendering. This should be done
// in the beginning since an error will terminate the server
func Register(name string, base string, fragments ...string) {
rootPath := server.Main.Config.Directories.Templates
for i, fragment := range fragments {
fragments[i] = path.Join(rootPath, fragment+".tmpl")
}
@ -38,16 +40,23 @@ func Register(name string, base string, fragments ...string) {
// view model. The view model is expected to be the correct model from the viewmodel
// package
func Render(w http.ResponseWriter, name string, status int, viewModel interface{}) {
tmpl, ok := cache[name]
if !ok {
response.Text(w, 500, "Template not found: "+name)
return
}
var tmpl *template.Template
var err error
tmpl, err := template.New(name).ParseFiles(argsCache[name]...)
if err != nil {
response.Text(w, 500, "Failed to run template "+name+": "+err.Error())
return
if server.Main.Config.Server.Debug {
tmpl, err = template.New(name).ParseFiles(argsCache[name]...)
if err != nil {
response.Text(w, 500, "Failed to run template "+name+": "+err.Error())
return
}
} else {
var ok bool
tmpl, ok = cache[name]
if !ok {
response.Text(w, 500, "Template not found: "+name)
return
}
}
w.WriteHeader(status)

Loading…
Cancel
Save