2019-01-04 08:41:01 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2019-01-18 13:50:59 +01:00
|
|
|
"fmt"
|
2019-01-18 08:47:38 +01:00
|
|
|
"mapserver/app"
|
2019-01-23 13:22:47 +01:00
|
|
|
"mapserver/mapobject"
|
2019-01-18 08:47:38 +01:00
|
|
|
"mapserver/params"
|
2019-01-24 07:52:25 +01:00
|
|
|
"mapserver/tilerendererjob"
|
2019-01-18 13:50:59 +01:00
|
|
|
"mapserver/web"
|
2019-01-23 09:11:55 +01:00
|
|
|
"runtime"
|
2019-02-02 16:21:20 +01:00
|
|
|
|
|
|
|
"github.com/sirupsen/logrus"
|
2019-01-04 08:41:01 +01:00
|
|
|
)
|
|
|
|
|
2019-02-13 14:42:53 +01:00
|
|
|
//go:generate sh -c "go run github.com/mjibson/esc -o vfs/static.go -prefix='static/' -pkg vfs static"
|
|
|
|
|
2019-01-04 11:00:49 +01:00
|
|
|
func main() {
|
2019-01-18 08:47:38 +01:00
|
|
|
//Parse command line
|
2019-01-13 16:32:54 +01:00
|
|
|
|
2019-01-18 09:13:37 +01:00
|
|
|
p := params.Parse()
|
2019-01-13 16:32:54 +01:00
|
|
|
|
2019-01-18 14:23:33 +01:00
|
|
|
if p.Debug {
|
|
|
|
logrus.SetLevel(logrus.DebugLevel)
|
|
|
|
} else {
|
|
|
|
logrus.SetLevel(logrus.InfoLevel)
|
|
|
|
}
|
|
|
|
|
2019-01-18 09:13:37 +01:00
|
|
|
if p.Help {
|
|
|
|
params.PrintHelp()
|
|
|
|
return
|
|
|
|
}
|
2019-01-13 16:32:54 +01:00
|
|
|
|
2019-01-18 09:13:37 +01:00
|
|
|
if p.Version {
|
|
|
|
fmt.Print("Mapserver version: ")
|
2019-01-24 14:08:44 +01:00
|
|
|
fmt.Println(app.Version)
|
|
|
|
fmt.Print("OS: ")
|
|
|
|
fmt.Println(runtime.GOOS)
|
|
|
|
fmt.Print("Architecture: ")
|
2019-01-23 09:11:55 +01:00
|
|
|
fmt.Println(runtime.GOARCH)
|
2019-01-18 09:13:37 +01:00
|
|
|
return
|
|
|
|
}
|
2019-01-13 16:32:54 +01:00
|
|
|
|
2019-01-18 09:03:57 +01:00
|
|
|
//parse Config
|
2019-01-21 10:53:58 +01:00
|
|
|
cfg, err := app.ParseConfig(app.ConfigFile)
|
2019-01-18 09:03:57 +01:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2019-01-21 10:53:58 +01:00
|
|
|
//write back config with all values
|
|
|
|
err = cfg.Save()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
2019-01-18 09:11:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//setup app context
|
2019-02-01 11:26:57 +01:00
|
|
|
ctx := app.Setup(p, cfg)
|
2019-01-09 08:56:39 +01:00
|
|
|
|
2019-01-23 13:22:47 +01:00
|
|
|
//Set up mapobject events
|
|
|
|
mapobject.Setup(ctx)
|
|
|
|
|
2019-01-18 08:47:38 +01:00
|
|
|
//run initial rendering
|
2019-01-24 07:52:25 +01:00
|
|
|
if ctx.Config.EnableRendering {
|
|
|
|
go tilerendererjob.Job(ctx)
|
2019-01-18 13:07:01 +01:00
|
|
|
}
|
|
|
|
|
2019-01-18 09:30:51 +01:00
|
|
|
//Start http server
|
2019-01-23 13:22:47 +01:00
|
|
|
//TODO: defer, may cause race condition
|
2019-01-18 09:30:51 +01:00
|
|
|
web.Serve(ctx)
|
|
|
|
|
2019-01-04 11:00:49 +01:00
|
|
|
}
|