Create & Init Project...

This commit is contained in:
2019-04-22 18:49:16 +08:00
commit fc4fa37393
25440 changed files with 4054998 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_library",
)
go_library(
name = "go_default_library",
srcs = [
"doc.go",
"http.go",
],
importpath = "go-common/app/interface/main/kvo/http",
tags = ["automanaged"],
visibility = ["//visibility:public"],
deps = [
"//app/interface/main/kvo/conf:go_default_library",
"//app/interface/main/kvo/service:go_default_library",
"//library/ecode:go_default_library",
"//library/log:go_default_library",
"//library/net/http/blademaster:go_default_library",
"//library/net/http/blademaster/middleware/auth:go_default_library",
],
)
filegroup(
name = "package-srcs",
srcs = glob(["**"]),
tags = ["automanaged"],
visibility = ["//visibility:private"],
)
filegroup(
name = "all-srcs",
srcs = [":package-srcs"],
tags = ["automanaged"],
visibility = ["//visibility:public"],
)

View File

@@ -0,0 +1,77 @@
package http
import (
"strconv"
"time"
"go-common/library/ecode"
"go-common/library/log"
bm "go-common/library/net/http/blademaster"
)
// doc get document
func doc(c *bm.Context) {
params := c.Request.Form
tsStr := params.Get("timestamp")
moduleKey := params.Get("module_key")
checkSumStr := params.Get("check_sum")
// check login
midIf, _ := c.Get("mid")
mid := midIf.(int64)
ts, err := strconv.ParseInt(tsStr, 10, 64)
if err != nil {
log.Error("strconv.ParseInt64(%v) error(%v)", tsStr, err)
c.JSON(nil, ecode.RequestErr)
return
}
checkSum, err := strconv.ParseInt(checkSumStr, 10, 64)
if err != nil {
log.Error("strconv.ParseInt64(%v) error(%v)", checkSumStr, err)
c.JSON(nil, ecode.RequestErr)
return
}
// doc
data, err := kvoSvr.Document(c, mid, moduleKey, ts, checkSum)
if err != nil {
if ecode.Cause(err) != ecode.NotModified {
log.Error("kvoSvr.Document(%v,%v) error(%v)", mid, moduleKey, err)
}
c.JSON(nil, err)
return
}
c.JSON(data, nil)
}
// addDoc add document
func addDoc(c *bm.Context) {
params := c.Request.Form
data := params.Get("data")
tsStr := params.Get("timestamp")
checkSumStr := params.Get("check_sum")
moduleKey := params.Get("module_key")
// check login
midIf, _ := c.Get("mid")
mid := midIf.(int64)
ts, err := strconv.ParseInt(tsStr, 10, 64)
if err != nil {
log.Error("strconv.ParseInt64(%v) error(%v)", tsStr, err)
c.JSON(nil, ecode.RequestErr)
return
}
checkSum, err := strconv.ParseInt(checkSumStr, 10, 64)
if err != nil {
log.Error("strconv.ParseInt64(%v) error(%v)", checkSumStr, err)
c.JSON(nil, ecode.RequestErr)
return
}
// add doc
resp, err := kvoSvr.AddDocument(c, mid, moduleKey, data, ts, checkSum, time.Now())
if err != nil {
if ecode.Cause(err) != ecode.NotModified {
log.Error("kvoSvr.AddDocument(%v,%v,%v,%v,%v) error(%v)", mid, moduleKey, data, ts, checkSum, err)
}
c.JSON(nil, err)
return
}
c.JSON(resp, nil)
}

View File

@@ -0,0 +1,49 @@
package http
import (
"net/http"
"go-common/app/interface/main/kvo/conf"
"go-common/app/interface/main/kvo/service"
"go-common/library/log"
bm "go-common/library/net/http/blademaster"
"go-common/library/net/http/blademaster/middleware/auth"
)
var (
kvoSvr *service.Service
authSvr *auth.Auth
)
// Init init http
func Init(c *conf.Config) {
kvoSvr = service.New(c)
authSvr = auth.New(c.Auth)
// init outer router
engineOut := bm.DefaultServer(c.BM)
outerRouter(engineOut)
if err := engineOut.Start(); err != nil {
log.Error("engineOut.Start error(%v)", err)
panic(err)
}
}
func outerRouter(e *bm.Engine) {
e.Ping(ping)
group := e.Group("/x/kvo", bm.CORS())
{
group.GET("/web/doc/get", authSvr.UserWeb, doc)
group.POST("/web/doc/add", authSvr.UserWeb, addDoc)
group.GET("/app/doc/get", authSvr.UserMobile, doc)
group.POST("/app/doc/add", authSvr.UserMobile, addDoc)
}
}
// ping check server ok.
func ping(c *bm.Context) {
var err error
if err = kvoSvr.Ping(c); err != nil {
log.Error("kvo service ping error(%v)", err)
c.AbortWithStatus(http.StatusServiceUnavailable)
}
}