123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500 |
- package http
- import (
- "encoding/json"
- "net/http"
- "strconv"
- "strings"
- "time"
- "go-common/app/infra/config/model"
- "go-common/library/ecode"
- "go-common/library/log"
- bm "go-common/library/net/http/blademaster"
- )
- // push config update
- func push(c *bm.Context) {
- var (
- err error
- svr string
- buildVer string
- ver int64
- env string
- )
- query := c.Request.Form
- verStr := query.Get("version")
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if buildVer = query.Get("build_ver"); buildVer == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if ver, err = strconv.ParseInt(verStr, 10, 64); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- service := &model.Service{Name: svr, BuildVersion: buildVer, Version: ver, Env: env}
- // update & write cache
- c.JSON(nil, confSvc.Push(c, service))
- }
- // hosts client hosts
- func hosts(c *bm.Context) {
- var (
- err error
- svr string
- data []*model.Host
- env string
- )
- query := c.Request.URL.Query()
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if data, err = confSvc.Hosts(c, svr, env); err != nil {
- c.JSON(nil, err)
- return
- }
- c.JSON(data, nil)
- }
- // versions client versions which the configuration is complete
- func versions(c *bm.Context) {
- var (
- err error
- svr string
- data *model.Versions
- env string
- bver string
- )
- query := c.Request.URL.Query()
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if bver = query.Get("build"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if data, err = confSvc.VersionSuccess(c, svr, env, bver); err != nil {
- c.JSON(nil, err)
- return
- }
- c.JSON(data, nil)
- }
- // versions client versions which the configuration is complete
- func versionIng(c *bm.Context) {
- var (
- err error
- svr string
- data []int64
- env string
- )
- query := c.Request.URL.Query()
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if data, err = confSvc.VersionIng(c, svr, env); err != nil {
- c.JSON(nil, err)
- return
- }
- c.JSON(data, nil)
- }
- // config get config file
- func config(c *bm.Context) {
- var (
- err error
- svr string
- host string
- buildVer string
- version int64
- env string
- token string
- )
- query := c.Request.URL.Query()
- verStr := query.Get("version")
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if token = query.Get("token"); token == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if host = query.Get("hostname"); host == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if buildVer = query.Get("build"); buildVer == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if version, err = strconv.ParseInt(verStr, 10, 64); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- service := &model.Service{Name: svr, BuildVersion: buildVer, Env: env, Token: token, Version: version, Host: host}
- data, err := confSvc.Config(c, service)
- if err != nil {
- c.JSON(nil, err)
- return
- }
- c.JSON(data, nil)
- }
- // file get one file value
- func file(c *bm.Context) {
- var (
- err error
- svr string
- buildVer string
- env string
- token string
- file string
- ver int64
- data string
- )
- query := c.Request.URL.Query()
- // params
- if buildVer = query.Get("build"); buildVer == "" {
- data = "build is null"
- }
- if !strings.HasPrefix(buildVer, "shsb") && !strings.HasPrefix(buildVer, "shylf") &&
- query.Get("zone") != "" && query.Get("env") != "" && query.Get("treeid") != "" {
- file2(c)
- return
- }
- if verStr := query.Get("version"); verStr == "" {
- ver = model.UnknownVersion
- } else {
- if ver, err = strconv.ParseInt(verStr, 10, 64); err != nil {
- data = "version must be num"
- }
- }
- if svr = query.Get("service"); svr == "" {
- data = "service is null"
- }
- if env = query.Get("environment"); env == "" {
- data = "environment is null"
- }
- if token = query.Get("token"); token == "" {
- data = "token is null"
- }
- if file = query.Get("fileName"); file == "" {
- data = "fileName is null"
- }
- service := &model.Service{Name: svr, BuildVersion: buildVer, Env: env, File: file, Token: token, Version: ver}
- if data == "" {
- if data, err = confSvc.File(c, service); err != nil {
- data = err.Error()
- c.AbortWithStatus(http.StatusInternalServerError)
- }
- } else {
- c.AbortWithStatus(http.StatusBadRequest)
- }
- if _, err = c.Writer.Write([]byte(data)); err != nil {
- log.Error("Response().Write(%v) error(%v)", data, err)
- }
- }
- // check check config version
- func check(c *bm.Context) {
- var (
- err error
- svr string
- host string
- buildVer string
- ip string
- ver int64
- env string
- token string
- appoint int64
- query = c.Request.URL.Query()
- )
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if token = query.Get("token"); token == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if ip = query.Get("ip"); ip == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if host = query.Get("hostname"); host == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if buildVer = query.Get("build"); buildVer == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if ver, err = strconv.ParseInt(query.Get("version"), 10, 64); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- appoint, _ = strconv.ParseInt(query.Get("appoint"), 10, 64)
- // check config version
- rhost := &model.Host{Service: svr, Name: host, BuildVersion: buildVer, IP: ip, ConfigVersion: ver, Appoint: appoint, Customize: query.Get("customize")}
- evt, err := confSvc.CheckVersion(c, rhost, env, token)
- if err != nil {
- c.JSON(nil, err)
- return
- }
- // wait for version change
- select {
- case e := <-evt:
- c.JSON(e, nil)
- case <-time.After(time.Duration(cnf.PollTimeout)):
- c.JSON(nil, ecode.NotModified)
- case <-c.Writer.(http.CloseNotifier).CloseNotify():
- c.JSON(nil, ecode.NotModified)
- }
- confSvc.Unsub(svr, host, env)
- }
- //clear host in redis
- func clearhost(c *bm.Context) {
- var (
- svr string
- env string
- )
- query := c.Request.Form
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- c.JSON(nil, confSvc.ClearHost(c, svr, env))
- }
- // versions client versions which the configuration is complete
- func builds(c *bm.Context) {
- var (
- svr string
- bs, bs2 []string
- env string
- )
- query := c.Request.URL.Query()
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- bs, _ = confSvc.Builds(c, svr, env)
- bs2, _ = confSvc2.TmpBuilds(svr, env)
- bs = append(bs, bs2...)
- if len(bs) == 0 {
- c.JSON(nil, ecode.NothingFound)
- return
- }
- c.JSON(bs, nil)
- }
- func addConfigs(c *bm.Context) {
- var (
- svr string
- env string
- token string
- user string
- data map[string]string
- err error
- values = c.Request.PostForm
- )
- // params
- if svr = values.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = values.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if token = values.Get("token"); token == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if user = values.Get("user"); user == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if err = json.Unmarshal([]byte(values.Get("data")), &data); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- c.JSON(nil, confSvc.AddConfigs(c, svr, env, token, user, data))
- }
- func copyConfigs(c *bm.Context) {
- var (
- svr string
- env string
- token string
- build string
- user string
- err error
- ver int64
- values = c.Request.PostForm
- )
- // params
- if svr = values.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = values.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if token = values.Get("token"); token == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if user = values.Get("user"); user == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if build = values.Get("build"); build == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if ver, err = confSvc.CopyConfigs(c, svr, env, token, user, build); err != nil {
- c.JSON(nil, err)
- return
- }
- c.JSON(ver, nil)
- }
- func updateConfigs(c *bm.Context) {
- var (
- svr string
- env string
- token string
- ver int64
- user string
- data map[string]string
- err error
- values = c.Request.PostForm
- )
- // params
- if svr = values.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = values.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if ver, err = strconv.ParseInt(values.Get("version"), 10, 64); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if token = values.Get("token"); token == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if user = values.Get("user"); user == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if err = json.Unmarshal([]byte(values.Get("data")), &data); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- c.JSON(nil, confSvc.UpdateConfigs(c, svr, env, token, user, ver, data))
- }
- // configN get config namespace file
- func configN(c *bm.Context) {
- var (
- err error
- svr string
- host string
- buildVer string
- version int64
- env string
- token string
- )
- query := c.Request.URL.Query()
- verStr := query.Get("version")
- // params
- if svr = query.Get("service"); svr == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if env = query.Get("environment"); env == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if token = query.Get("token"); token == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if host = query.Get("hostname"); host == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if buildVer = query.Get("build"); buildVer == "" {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- if version, err = strconv.ParseInt(verStr, 10, 64); err != nil {
- c.JSON(nil, ecode.RequestErr)
- return
- }
- service := &model.Service{Name: svr, BuildVersion: buildVer, Env: env, Token: token, Version: version, Host: host}
- data, err := confSvc.Config2(c, service)
- if err != nil {
- c.JSON(nil, err)
- return
- }
- c.JSON(data, nil)
- }
|