controller.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. package abango
  2. import (
  3. "encoding/json"
  4. "io/ioutil"
  5. "strings"
  6. "time"
  7. e "github.com/dabory/abango-rest/etc"
  8. "github.com/go-xorm/xorm"
  9. "gopkg.in/yaml.v2"
  10. )
  11. func (c *Controller) Init() (int, string) {
  12. // status, msg := c.GetYDB()
  13. // return status, msg
  14. var gtb GateTokenBase
  15. var gtbStr string
  16. var err error
  17. if XConfig["IsYDBFixed"] == "Yes" {
  18. data, err := ioutil.ReadFile("models/custom.yml")
  19. if err != nil {
  20. return 507, e.LogStr("ASDFQEWFA", "Can NOT Read custom.yml")
  21. }
  22. var config Config
  23. if err := yaml.Unmarshal(data, &config); err == nil {
  24. c.Gtb = config.Source
  25. c.Gtb.ConnString = config.Source.ConnStr // custom.yml의 Variable name 이 서로 달라서 복사해줌.
  26. } else {
  27. return 507, e.LogStr("ASDWEWFA", "connString in custom.yml format mismatch ")
  28. }
  29. } else {
  30. if c.GateToken == "" {
  31. return 505, e.LogStr("QWCAFVD", "GateToken is Empty: ")
  32. }
  33. if gtbStr, err = MdbView(c.GateToken); err != nil {
  34. return 505, e.LogStr("QWFAECD", "GateToken Not Found in MemoryDB: "+c.GateToken)
  35. }
  36. if err := json.Unmarshal([]byte(gtbStr), &gtb); err == nil {
  37. c.Gtb = gtb
  38. } else {
  39. return 505, e.LogStr("QWFAEC1AFVDS", "AfterBase64Content Format mismatch: "+c.GateToken)
  40. }
  41. }
  42. if c.Db, err = xorm.NewEngine(XConfig["DbType"], c.Gtb.ConnString); err != nil {
  43. return 600, e.LogStr("ADASEF", "DBEngine Open Error")
  44. }
  45. if status, msg := c.AttachDB(); status != 200 { // DB 까지 붙여야 memory error 가 안난다.
  46. return status, e.LogStr("PBUYJM-", msg)
  47. }
  48. return 200, ""
  49. }
  50. type Config struct {
  51. Source GateTokenBase
  52. }
  53. type Target struct {
  54. Type string `yaml:"type"`
  55. Language string `yaml:"language"`
  56. OutputDir string `yaml:"output_dir"`
  57. }
  58. func (c *Controller) AttachDB() (int, string) {
  59. var err error
  60. if c.Db, err = xorm.NewEngine(XConfig["DbType"], c.Gtb.ConnString); err != nil {
  61. return 600, e.LogStr("ADASEF", "DBEngine Open Error")
  62. }
  63. var connHint string
  64. strArr := strings.Split(c.Gtb.ConnString, "@tcp")
  65. if len(strArr) == 2 {
  66. connHint = strArr[1]
  67. } else {
  68. return 507, e.LogStr("ASDFQEWFA", "connString format mismatch: "+strArr[1])
  69. }
  70. c.Db.ShowSQL(false)
  71. c.Db.SetMaxOpenConns(100)
  72. c.Db.SetMaxIdleConns(20)
  73. c.Db.SetConnMaxLifetime(60 * time.Second)
  74. if _, err := c.Db.IsTableExist("aaa"); err == nil {
  75. return 200, e.LogStr("ASDFASFQFE", "YDB connection in "+connHint)
  76. } else {
  77. return 600, e.LogStr("PMUHIUYBUYJM-", "YDB connection Fail in "+connHint)
  78. }
  79. return 200, ""
  80. }
  81. // func (c *Controller) Init(ask AbangoAsk) {
  82. // c.ServerVars = make(map[string]string) // 반드시 할당해줘야 함.
  83. // c.Data = make(map[interface{}]interface{})
  84. // c.Ctx.Ask = ask
  85. // c.ConnString = XConfig["KafkaConnect"]
  86. // c.Ctx.ReturnTopic = c.Ctx.Ask.UniqueId
  87. // for _, p := range c.Ctx.Ask.ServerParams {
  88. // c.ServerVars[p.Key] = p.Value
  89. // }
  90. // c.GetAbangoAccessAndDb()
  91. // }
  92. // func (c *Controller) InitNormal() {
  93. // c.ServerVars = make(map[string]string) // 반드시 할당해줘야 함.
  94. // c.Data = make(map[interface{}]interface{})
  95. // //c.Ctx.ReturnTopic = "ljsldjfalsdfja" // 여기서 메모리 할당이 한됨'
  96. // c.GetAbangoAccessAndDb()
  97. // }
  98. // func (c *Controller) KafkaAnswer(body string) {
  99. // // c.Ctx.Answer.Body = []byte(body) // 쓸데없는 것 같은데 나중에 지
  100. // // e.Tp("ReturnTopic=" + c.Ctx.ReturnTopic)
  101. // if _, _, err := KafkaProducer(body,
  102. // c.Ctx.ReturnTopic, c.ConnString, XConfig["api_method"]); err != nil {
  103. // e.MyErr("WERRWEEWQRFDFHQW", err, false)
  104. // }
  105. // }
  106. func (c *Controller) AnswerJson() {
  107. // var ret []byte
  108. // if c.Data["json"] == nil {
  109. // msg := " QVCZEFAQWERQ " + c.Ctx.Ask.AskName + "[\"" + c.Ctx.Ask.ApiType + "\"] Data[json] is empty !"
  110. // e.MyErr(msg, errors.New(""), true)
  111. // return
  112. // }
  113. // if c.ServerVars["indent_answer"] == "yes" {
  114. // ret, _ = json.MarshalIndent(c.Data["json"], "", " ")
  115. // } else {
  116. // ret, _ = json.Marshal(c.Data["json"])
  117. // }
  118. // // e.Tp(string(ret))
  119. // if c.Ctx.Ask.ApiType == "Kafka" {
  120. // c.KafkaAnswer(string(ret))
  121. // } else if c.Ctx.Ask.ApiType == "gRpc" {
  122. // // 점진적으로 채워나가자.
  123. // } else if c.Ctx.Ask.ApiType == "Rest" {
  124. // // 점진적으로 채워나가자.
  125. // }
  126. }
  127. func (c *Controller) GetAbangoAccessAndDb() error {
  128. // if err := c.GetAccessAuth(); err == nil {
  129. // var err2 error
  130. // if c.Db, err2 = xorm.NewEngine(c.Access.DbType, c.Access.DbConnStr); err2 == nil {
  131. // // db, err := xorm.NewEngine(XEnc.DbType, "root:root@tcp(127.0.0.1:3306)/kangan?charset=utf8&parseTime=True")
  132. // strArr := strings.Split(c.Access.DbConnStr, "@tcp")
  133. // if len(strArr) == 2 {
  134. // e.OkLog(strArr[1])
  135. // } else {
  136. // e.MyErr(strArr[1], err2, true)
  137. // return err2
  138. // }
  139. // c.Db.ShowSQL(false)
  140. // c.Db.SetMaxOpenConns(100)
  141. // c.Db.SetMaxIdleConns(20)
  142. // c.Db.SetConnMaxLifetime(60 * time.Second)
  143. // if _, err := c.Db.IsTableExist("admin_menu"); err != nil {
  144. // e.MyErr("DB DISconnected in "+strArr[1], err, true)
  145. // } else {
  146. // e.OkLog("DB connect in " + strArr[1])
  147. // }
  148. // } else {
  149. // e.MyErr("xorm.NewEngine", err, true)
  150. // }
  151. // } else {
  152. // e.MyErr("GetAccessAuth", err, true)
  153. // }
  154. return nil
  155. }
  156. func (c *Controller) GetAccessAuth() error {
  157. return nil
  158. }