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,54 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_test",
"go_library",
)
go_test(
name = "go_default_test",
srcs = [
"dao_test.go",
"task_test.go",
],
embed = [":go_default_library"],
rundir = ".",
tags = ["automanaged"],
deps = [
"//app/admin/main/aegis/conf:go_default_library",
"//app/admin/main/aegis/model/common:go_default_library",
"//vendor/github.com/smartystreets/goconvey/convey:go_default_library",
],
)
go_library(
name = "go_default_library",
srcs = [
"dao.go",
"task.go",
],
importpath = "go-common/app/admin/main/aegis/dao/mc",
tags = ["automanaged"],
visibility = ["//visibility:public"],
deps = [
"//app/admin/main/aegis/conf:go_default_library",
"//app/admin/main/aegis/model/common:go_default_library",
"//library/cache/memcache:go_default_library",
"//library/log: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,36 @@
package mc
import (
"context"
"go-common/app/admin/main/aegis/conf"
"go-common/library/cache/memcache"
)
// Dao dao
type Dao struct {
c *conf.Config
mc *memcache.Pool
}
// New init mysql db
func New(c *conf.Config) (dao *Dao) {
dao = &Dao{
c: c,
mc: memcache.NewPool(c.Memcache),
}
return
}
// Close close the resource.
func (d *Dao) Close() {
d.mc.Close()
}
// Ping dao ping
func (d *Dao) Ping(c context.Context) error {
return nil
}

View File

@@ -0,0 +1,39 @@
package mc
import (
"context"
"flag"
"fmt"
"os"
"testing"
"go-common/app/admin/main/aegis/conf"
)
var (
d *Dao
ctx context.Context
)
func TestMain(m *testing.M) {
if os.Getenv("DEPLOY_ENV") != "" {
flag.Set("app_id", "main.archive.aegis-admin")
flag.Set("conf_token", "cad913269be022e1eb8c45a8d5408d78")
flag.Set("tree_id", "60977")
flag.Set("conf_version", "1")
flag.Set("deploy_env", "uat")
flag.Set("conf_host", "config.bilibili.co")
flag.Set("conf_path", "/tmp")
flag.Set("region", "sh")
flag.Set("zone", "sh001")
} else {
flag.Set("conf", "../../cmd/aegis-admin.toml")
}
flag.Parse()
if err := conf.Init(); err != nil {
panic(fmt.Sprintf("conf.Init() error(%v)", err))
}
d = New(conf.Conf)
ctx = context.TODO()
os.Exit(m.Run())
}

View File

@@ -0,0 +1,135 @@
package mc
import (
"context"
"encoding/json"
"fmt"
"go-common/app/admin/main/aegis/model/common"
gmc "go-common/library/cache/memcache"
"go-common/library/log"
)
// ConsumerOn 登入
func (d *Dao) ConsumerOn(c context.Context, opt *common.BaseOptions) (err error) {
conn := d.mc.Get(c)
defer conn.Close()
key := mcKey(opt)
if err = conn.Set(&gmc.Item{Key: key, Value: []byte{1}, Expiration: d.c.Consumer.OnExp}); err != nil {
log.Error("conn.Set error(%v)", err)
}
return
}
// ConsumerOff .
func (d *Dao) ConsumerOff(c context.Context, opt *common.BaseOptions) (err error) {
conn := d.mc.Get(c)
defer conn.Close()
key := mcKey(opt)
if err = conn.Delete(key); err != nil {
if err != gmc.ErrNotFound {
log.Error("conn.Delete error(%v)", err)
}
err = nil
}
return
}
// IsConsumerOn .
func (d *Dao) IsConsumerOn(c context.Context, opt *common.BaseOptions) (isOn bool, err error) {
conn := d.mc.Get(c)
defer conn.Close()
key := mcKey(opt)
if _, err = conn.Get(key); err != nil {
if err == gmc.ErrNotFound {
err = nil
} else {
log.Error("IsConsumerOn error(%v)", err)
}
return
}
isOn = true
if err = conn.Set(&gmc.Item{Key: key, Value: []byte{1}, Expiration: d.c.Consumer.OnExp}); err != nil {
log.Error("conn.Set error(%v)", err)
}
return
}
func mcKey(opt *common.BaseOptions) string {
return fmt.Sprintf("aegis%d_%d_%d", opt.BusinessID, opt.FlowID, opt.UID)
}
func roleKey(opt *common.BaseOptions) string {
return fmt.Sprintf("aegis_role%d_%d_%d", opt.BusinessID, opt.FlowID, opt.UID)
}
// Role .
type Role struct {
Role int8 `json:"role"`
Uname string `json:"uname"`
}
// GetRole TODO 目前缓存组长组员,以后扩展到存管理员
func (d *Dao) GetRole(c context.Context, opt *common.BaseOptions) (role int8, uname string, err error) {
conn := d.mc.Get(c)
defer conn.Close()
key := roleKey(opt)
var item *gmc.Item
if item, err = conn.Get(key); err != nil {
if err == gmc.ErrNotFound {
log.Info("GetRole opt(%+v) miss", opt)
err = nil
} else {
log.Error("GetRole opt(%+v) error(%v)", opt, err)
}
return
}
rt := new(Role)
if err = json.Unmarshal(item.Value, rt); err != nil {
log.Error("GetRole value(%s) error(%v)", string(item.Value), err)
return
}
role = rt.Role
uname = rt.Uname
return
}
// SetRole .
func (d *Dao) SetRole(c context.Context, opt *common.BaseOptions, role int8) (err error) {
conn := d.mc.Get(c)
defer conn.Close()
key := roleKey(opt)
val := &Role{
Role: role,
Uname: opt.Uname,
}
var roleb []byte
if roleb, err = json.Marshal(val); err != nil {
log.Error("SetRole error(%v)", err)
return
}
if err = conn.Set(&gmc.Item{Key: key, Value: roleb, Expiration: d.c.Consumer.RoleExp}); err != nil {
log.Error("conn.Set error(%v)", err)
}
return
}
//DelRole .
func (d *Dao) DelRole(c context.Context, bizid, flowid int64, uids []int64) (err error) {
conn := d.mc.Get(c)
defer conn.Close()
for _, uid := range uids {
key := roleKey(&common.BaseOptions{
BusinessID: bizid,
FlowID: flowid,
UID: uid})
conn.Delete(key)
}
return
}

View File

@@ -0,0 +1,110 @@
package mc
import (
"context"
"testing"
"go-common/app/admin/main/aegis/model/common"
"github.com/smartystreets/goconvey/convey"
)
func TestMcConsumerOn(t *testing.T) {
convey.Convey("ConsumerOn", t, func(ctx convey.C) {
var (
opt = &common.BaseOptions{}
)
ctx.Convey("When everything goes positive", func(ctx convey.C) {
err := d.ConsumerOn(context.TODO(), opt)
ctx.Convey("Then err should be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
})
}
func TestMcConsumerOff(t *testing.T) {
convey.Convey("ConsumerOff", t, func(ctx convey.C) {
var (
opt = &common.BaseOptions{}
)
ctx.Convey("When everything goes positive", func(ctx convey.C) {
err := d.ConsumerOff(context.TODO(), opt)
ctx.Convey("Then err should be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
})
}
func TestMcIsConsumerOn(t *testing.T) {
convey.Convey("IsConsumerOn", t, func(ctx convey.C) {
var (
opt = &common.BaseOptions{}
)
ctx.Convey("When everything goes positive", func(ctx convey.C) {
_, err := d.IsConsumerOn(context.TODO(), opt)
ctx.Convey("Then err should be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
})
}
func TestMcmcKey(t *testing.T) {
convey.Convey("mcKey", t, func(ctx convey.C) {
var (
opt = &common.BaseOptions{}
)
ctx.Convey("When everything goes positive", func(ctx convey.C) {
p1 := mcKey(opt)
ctx.Convey("Then p1 should not be nil.", func(ctx convey.C) {
ctx.So(p1, convey.ShouldNotBeNil)
})
})
})
}
func TestMcroleKey(t *testing.T) {
convey.Convey("roleKey", t, func(ctx convey.C) {
var (
opt = &common.BaseOptions{}
)
ctx.Convey("When everything goes positive", func(ctx convey.C) {
p1 := roleKey(opt)
ctx.Convey("Then p1 should not be nil.", func(ctx convey.C) {
ctx.So(p1, convey.ShouldNotBeNil)
})
})
})
}
func TestMcSetRole(t *testing.T) {
convey.Convey("SetRole", t, func(ctx convey.C) {
var (
c = context.TODO()
opt = &common.BaseOptions{}
)
ctx.Convey("When everything gose positive", func(ctx convey.C) {
err := d.SetRole(c, opt, 0)
ctx.Convey("Then p1 should not be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
})
}
func TestMcGetRole(t *testing.T) {
convey.Convey("GetRole", t, func(ctx convey.C) {
var (
c = context.TODO()
opt = &common.BaseOptions{}
)
ctx.Convey("When everything gose positive", func(ctx convey.C) {
_, _, err := d.GetRole(c, opt)
ctx.Convey("Then p1 should not be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
})
}