代码拉取完成,页面将自动刷新
// Pipe - A small and beautiful blogging platform written in golang.
// Copyright (C) 2017-present, b3log.org
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package main
import (
"io"
"io/ioutil"
"math/rand"
"net/http"
"os"
"os/signal"
"path/filepath"
"strings"
"syscall"
"time"
"github.com/b3log/gulu"
"github.com/b3log/pipe/controller"
"github.com/b3log/pipe/cron"
"github.com/b3log/pipe/i18n"
"github.com/b3log/pipe/model"
"github.com/b3log/pipe/service"
"github.com/b3log/pipe/theme"
"github.com/gin-gonic/gin"
)
// Logger
var logger *gulu.Logger
// The only one init function in pipe.
func init() {
rand.Seed(time.Now().UTC().UnixNano())
gulu.Log.SetLevel("warn")
logger = gulu.Log.NewLogger(os.Stdout)
model.LoadConf()
i18n.Load()
theme.Load()
replaceServerConf()
if "dev" == model.Conf.RuntimeMode {
gin.SetMode(gin.DebugMode)
} else {
gin.SetMode(gin.ReleaseMode)
}
gin.DefaultWriter = io.MultiWriter(os.Stdout)
}
// Entry point.
func main() {
service.ConnectDB()
service.Upgrade.Perform()
cron.Start()
router := controller.MapRoutes()
server := &http.Server{
Addr: "0.0.0.0:" + model.Conf.Port,
Handler: router,
}
handleSignal(server)
logger.Infof("Pipe (v%s) is running [%s]", model.Version, model.Conf.Server)
if err := server.ListenAndServe(); nil != err {
logger.Fatalf("listen and serve failed: " + err.Error())
}
}
// handleSignal handles system signal for graceful shutdown.
func handleSignal(server *http.Server) {
c := make(chan os.Signal)
signal.Notify(c, syscall.SIGINT, syscall.SIGQUIT, syscall.SIGTERM)
go func() {
s := <-c
logger.Infof("got signal [%s], exiting pipe now", s)
if err := server.Close(); nil != err {
logger.Errorf("server close failed: " + err.Error())
}
service.DisconnectDB()
logger.Infof("Pipe exited")
os.Exit(0)
}()
}
func replaceServerConf() {
path := "theme/sw.min.js.tpl"
if gulu.File.IsExist(path) {
data, err := ioutil.ReadFile(path)
if nil != err {
logger.Fatal("read file [" + path + "] failed: " + err.Error())
}
content := string(data)
content = strings.Replace(content, "http://server.tpl.json", model.Conf.Server, -1)
content = strings.Replace(content, "http://staticserver.tpl.json", model.Conf.StaticServer, -1)
content = strings.Replace(content, "${StaticResourceVersion}", model.Conf.StaticResourceVersion, -1)
writePath := strings.TrimSuffix(path, ".tpl")
if err = ioutil.WriteFile(writePath, []byte(content), 0644); nil != err {
logger.Fatal("replace sw.min.js in [" + path + "] failed: " + err.Error())
}
}
if gulu.File.IsExist("console/dist/") {
err := filepath.Walk("console/dist/", func(path string, f os.FileInfo, err error) error {
if strings.HasSuffix(path, ".tpl") {
data, err := ioutil.ReadFile(path)
if nil != err {
logger.Fatal("read file [" + path + "] failed: " + err.Error())
}
content := string(data)
content = strings.Replace(content, "http://server.tpl.json", model.Conf.Server, -1)
content = strings.Replace(content, "http://staticserver.tpl.json", model.Conf.StaticServer, -1)
writePath := strings.TrimSuffix(path, ".tpl")
if err = ioutil.WriteFile(writePath, []byte(content), 0644); nil != err {
logger.Fatal("replace server conf in [" + writePath + "] failed: " + err.Error())
}
}
return err
})
if nil != err {
logger.Fatal("replace server conf in [theme] failed: " + err.Error())
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。