| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- // Copyright 2014 Unknwon
- // Copyright 2014 Torkel Ödegaard
- package cmd
- import (
- "fmt"
- "net/http"
- "path"
- "github.com/Unknwon/macaron"
- "github.com/codegangsta/cli"
- "github.com/macaron-contrib/session"
- "github.com/torkelo/grafana-pro/pkg/api"
- "github.com/torkelo/grafana-pro/pkg/log"
- "github.com/torkelo/grafana-pro/pkg/middleware"
- "github.com/torkelo/grafana-pro/pkg/setting"
- "github.com/torkelo/grafana-pro/pkg/social"
- "github.com/torkelo/grafana-pro/pkg/stores/sqlstore"
- )
- var CmdWeb = cli.Command{
- Name: "web",
- Usage: "Start Grafana Pro web server",
- Description: `Start Grafana Pro server`,
- Action: runWeb,
- Flags: []cli.Flag{},
- }
- func newMacaron() *macaron.Macaron {
- m := macaron.New()
- m.Use(middleware.Logger())
- m.Use(macaron.Recovery())
- mapStatic(m, "public", "public")
- mapStatic(m, "public/app", "app")
- mapStatic(m, "public/img", "img")
- m.Use(session.Sessioner(session.Options{
- Provider: setting.SessionProvider,
- Config: *setting.SessionConfig,
- }))
- m.Use(macaron.Renderer(macaron.RenderOptions{
- Directory: path.Join(setting.StaticRootPath, "views"),
- IndentJSON: macaron.Env != macaron.PROD,
- Delims: macaron.Delims{Left: "[[", Right: "]]"},
- }))
- m.Use(middleware.GetContextHandler())
- return m
- }
- func mapStatic(m *macaron.Macaron, dir string, prefix string) {
- m.Use(macaron.Static(
- path.Join(setting.StaticRootPath, dir),
- macaron.StaticOptions{
- SkipLogging: true,
- Prefix: prefix,
- },
- ))
- }
- func runWeb(*cli.Context) {
- log.Info("Starting Grafana-Pro v.2-alpha")
- setting.NewConfigContext()
- setting.InitServices()
- social.NewOAuthService()
- sqlstore.Init()
- // init database
- sqlstore.LoadModelsConfig()
- if err := sqlstore.NewEngine(); err != nil {
- log.Fatal(4, "fail to initialize orm engine: %v", err)
- }
- m := newMacaron()
- api.Register(m)
- var err error
- listenAddr := fmt.Sprintf("%s:%s", setting.HttpAddr, setting.HttpPort)
- log.Info("Listen: %v://%s%s", setting.Protocol, listenAddr, setting.AppSubUrl)
- switch setting.Protocol {
- case setting.HTTP:
- err = http.ListenAndServe(listenAddr, m)
- case setting.HTTPS:
- err = http.ListenAndServeTLS(listenAddr, setting.CertFile, setting.KeyFile, m)
- default:
- log.Fatal(4, "Invalid protocol: %s", setting.Protocol)
- }
- if err != nil {
- log.Fatal(4, "Fail to start server: %v", err)
- }
- }
|