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,35 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_library",
)
go_library(
name = "go_default_library",
srcs = ["rpc.go"],
importpath = "go-common/app/service/main/rank/server/gorpc",
tags = ["automanaged"],
visibility = ["//visibility:public"],
deps = [
"//app/service/main/rank/conf:go_default_library",
"//app/service/main/rank/model:go_default_library",
"//app/service/main/rank/service:go_default_library",
"//library/net/rpc:go_default_library",
"//library/net/rpc/context: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,60 @@
package rpc
import (
"go-common/app/service/main/rank/conf"
"go-common/app/service/main/rank/model"
"go-common/app/service/main/rank/service"
"go-common/library/net/rpc"
"go-common/library/net/rpc/context"
)
// RPC favorite rpc.
type RPC struct {
c *conf.Config
s *service.Service
}
// New init rpc.
func New(c *conf.Config, s *service.Service) (svr *rpc.Server) {
r := &RPC{
c: c,
s: s,
}
svr = rpc.NewServer(c.RPCServer)
if err := svr.Register(r); err != nil {
panic(err)
}
return
}
// Ping check connection success.
func (r *RPC) Ping(c context.Context, arg *struct{}, res *struct{}) (err error) {
return
}
// Mget .
func (r *RPC) Mget(c context.Context, a *model.MgetReq, res *model.MgetResp) (err error) {
var v *model.MgetResp
if v, err = r.s.Mget(c, a); err == nil {
*res = *v
}
return
}
// Sort .
func (r *RPC) Sort(c context.Context, a *model.SortReq, res *model.SortResp) (err error) {
var v *model.SortResp
if v, err = r.s.Sort(c, a); err == nil {
*res = *v
}
return
}
// Group .
func (r *RPC) Group(c context.Context, a *model.GroupReq, res *model.GroupResp) (err error) {
var v *model.GroupResp
if v, err = r.s.Group(c, a); err == nil {
*res = *v
}
return
}

View File

@@ -0,0 +1,28 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_library",
)
go_library(
name = "go_default_library",
srcs = ["server.go"],
importpath = "go-common/app/service/main/rank/server/grpc",
tags = ["automanaged"],
visibility = ["//visibility:public"],
)
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,3 @@
package grpc
// TODO

View File

@@ -0,0 +1,36 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_library",
)
go_library(
name = "go_default_library",
srcs = ["http.go"],
importpath = "go-common/app/service/main/rank/server/http",
tags = ["automanaged"],
visibility = ["//visibility:public"],
deps = [
"//app/service/main/rank/conf:go_default_library",
"//app/service/main/rank/model:go_default_library",
"//app/service/main/rank/service:go_default_library",
"//library/log:go_default_library",
"//library/net/http/blademaster:go_default_library",
"//library/net/http/blademaster/middleware/verify: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,108 @@
package http
import (
"net/http"
"strings"
"go-common/app/service/main/rank/conf"
"go-common/app/service/main/rank/model"
"go-common/app/service/main/rank/service"
"go-common/library/log"
bm "go-common/library/net/http/blademaster"
"go-common/library/net/http/blademaster/middleware/verify"
)
var (
srv *service.Service
vfy *verify.Verify
)
// Init init
func Init(c *conf.Config, s *service.Service) {
srv = s
vfy = verify.New(c.Verify)
engine := bm.DefaultServer(c.BM)
router(engine)
if err := engine.Start(); err != nil {
log.Error("engine.Start() error(%v)", err)
panic(err)
}
}
func router(e *bm.Engine) {
e.Ping(ping)
e.Register(register)
g := e.Group("/x/internal/rank")
{
g.GET("/do", do)
g.GET("/mget", mget)
g.GET("/sort", sort)
g.GET("/group", vfy.Verify, group)
}
}
func ping(c *bm.Context) {
if err := srv.Ping(c); err != nil {
log.Error("ping error(%v)", err)
c.AbortWithStatus(http.StatusServiceUnavailable)
}
}
func register(c *bm.Context) {
c.JSON(map[string]interface{}{}, nil)
}
func do(c *bm.Context) {
arg := new(model.DoReq)
if err := c.Bind(arg); err != nil {
return
}
c.JSON(srv.Do(c, arg), nil)
}
func mget(c *bm.Context) {
arg := new(model.MgetReq)
if err := c.Bind(arg); err != nil {
return
}
c.JSON(srv.Mget(c, arg))
}
func sort(c *bm.Context) {
arg := new(struct {
Business string `form:"business" validate:"required"`
Field string `form:"field" validate:"required"`
Order string `form:"order" validate:"required"`
Filters []string `form:"filters,split"`
Oids []int64 `form:"oids,split" validate:"required"`
Pn int `form:"pn"`
Ps int `form:"ps"`
})
if err := c.Bind(arg); err != nil {
return
}
filterMap := make(map[string]string)
for _, v := range arg.Filters {
strs := strings.Split(v, "|")
if len(strs) == 2 {
filterMap[strs[0]] = strs[1]
}
}
a := new(model.SortReq)
a.Business = arg.Business
a.Field = arg.Field
a.Order = arg.Order
a.Filters = filterMap
a.Oids = arg.Oids
a.Pn = arg.Pn
a.Ps = arg.Ps
c.JSON(srv.Sort(c, a))
}
func group(c *bm.Context) {
arg := new(model.GroupReq)
if err := c.Bind(arg); err != nil {
return
}
c.JSON(srv.Group(c, arg))
}