2014-04-12 13:18:18 +08:00
|
|
|
// Beego (http://beego.me/)
|
2014-07-03 23:40:21 +08:00
|
|
|
//
|
2014-04-12 13:18:18 +08:00
|
|
|
// @description beego is an open-source, high-performance web framework for the Go programming language.
|
2014-07-03 23:40:21 +08:00
|
|
|
//
|
2014-04-12 13:18:18 +08:00
|
|
|
// @link http://github.com/astaxie/beego for the canonical source repository
|
2014-07-03 23:40:21 +08:00
|
|
|
//
|
2014-04-12 13:18:18 +08:00
|
|
|
// @license http://github.com/astaxie/beego/blob/master/LICENSE
|
2014-07-03 23:40:21 +08:00
|
|
|
//
|
2014-04-12 13:18:18 +08:00
|
|
|
// @authors astaxie
|
2013-09-10 00:00:11 +08:00
|
|
|
package beego
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
"net/http/fcgi"
|
|
|
|
"time"
|
2013-12-03 21:37:39 +08:00
|
|
|
|
|
|
|
"github.com/astaxie/beego/context"
|
2013-09-10 00:00:11 +08:00
|
|
|
)
|
|
|
|
|
2013-12-20 22:35:16 +08:00
|
|
|
// FilterFunc defines filter function type.
|
2013-09-10 00:00:11 +08:00
|
|
|
type FilterFunc func(*context.Context)
|
|
|
|
|
2013-12-20 19:20:13 +08:00
|
|
|
// App defines beego application with a new PatternServeMux.
|
2013-09-10 00:00:11 +08:00
|
|
|
type App struct {
|
|
|
|
Handlers *ControllerRegistor
|
2014-05-20 17:28:06 +08:00
|
|
|
Server *http.Server
|
2013-09-10 00:00:11 +08:00
|
|
|
}
|
|
|
|
|
2013-12-20 19:20:13 +08:00
|
|
|
// NewApp returns a new beego application.
|
2013-09-10 00:00:11 +08:00
|
|
|
func NewApp() *App {
|
2014-06-10 20:12:57 +08:00
|
|
|
cr := NewControllerRegister()
|
2014-05-20 17:28:06 +08:00
|
|
|
app := &App{Handlers: cr, Server: &http.Server{}}
|
2013-09-10 00:00:11 +08:00
|
|
|
return app
|
|
|
|
}
|
|
|
|
|
2013-12-20 19:20:13 +08:00
|
|
|
// Run beego application.
|
2013-09-10 00:00:11 +08:00
|
|
|
func (app *App) Run() {
|
|
|
|
addr := HttpAddr
|
|
|
|
|
|
|
|
if HttpPort != 0 {
|
|
|
|
addr = fmt.Sprintf("%s:%d", HttpAddr, HttpPort)
|
|
|
|
}
|
2013-11-26 15:30:59 +08:00
|
|
|
|
2013-12-04 22:27:29 -05:00
|
|
|
BeeLogger.Info("Running on %s", addr)
|
2013-11-26 15:30:59 +08:00
|
|
|
|
2013-09-10 00:00:11 +08:00
|
|
|
var (
|
|
|
|
err error
|
|
|
|
l net.Listener
|
|
|
|
)
|
2014-05-20 16:41:39 +08:00
|
|
|
endRunning := make(chan bool, 1)
|
2013-11-26 15:30:59 +08:00
|
|
|
|
2013-09-10 00:00:11 +08:00
|
|
|
if UseFcgi {
|
|
|
|
if HttpPort == 0 {
|
|
|
|
l, err = net.Listen("unix", addr)
|
|
|
|
} else {
|
|
|
|
l, err = net.Listen("tcp", addr)
|
|
|
|
}
|
|
|
|
if err != nil {
|
2013-09-10 00:17:49 +08:00
|
|
|
BeeLogger.Critical("Listen: ", err)
|
2013-09-10 00:00:11 +08:00
|
|
|
}
|
|
|
|
err = fcgi.Serve(l, app.Handlers)
|
|
|
|
} else {
|
2014-05-20 17:28:06 +08:00
|
|
|
app.Server.Addr = addr
|
|
|
|
app.Server.Handler = app.Handlers
|
|
|
|
app.Server.ReadTimeout = time.Duration(HttpServerTimeOut) * time.Second
|
|
|
|
app.Server.WriteTimeout = time.Duration(HttpServerTimeOut) * time.Second
|
|
|
|
|
2014-05-20 16:41:39 +08:00
|
|
|
if EnableHttpTLS {
|
|
|
|
go func() {
|
|
|
|
if HttpsPort != 0 {
|
2014-05-20 17:28:06 +08:00
|
|
|
app.Server.Addr = fmt.Sprintf("%s:%d", HttpAddr, HttpsPort)
|
2014-05-13 17:19:50 +02:00
|
|
|
}
|
2014-05-20 17:28:06 +08:00
|
|
|
err := app.Server.ListenAndServeTLS(HttpCertFile, HttpKeyFile)
|
2014-05-20 16:41:39 +08:00
|
|
|
if err != nil {
|
|
|
|
BeeLogger.Critical("ListenAndServeTLS: ", err)
|
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
2014-05-20 15:30:17 +08:00
|
|
|
|
2014-05-20 16:41:39 +08:00
|
|
|
if EnableHttpListen {
|
|
|
|
go func() {
|
2014-05-20 17:28:06 +08:00
|
|
|
err := app.Server.ListenAndServe()
|
2014-05-20 16:41:39 +08:00
|
|
|
if err != nil {
|
|
|
|
BeeLogger.Critical("ListenAndServe: ", err)
|
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
}
|
|
|
|
}()
|
2013-09-10 00:00:11 +08:00
|
|
|
}
|
|
|
|
}
|
2013-11-26 15:30:59 +08:00
|
|
|
|
2014-05-20 15:30:17 +08:00
|
|
|
<-endRunning
|
2013-09-10 00:00:11 +08:00
|
|
|
}
|