serv_web.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. // package serv_web -- веб-сервер для графики
  2. package serv_web
  3. import (
  4. "fmt"
  5. "log"
  6. "os"
  7. "time"
  8. "github.com/gofiber/fiber/v2"
  9. // "github.com/gofiber/fiber/v2/middleware/compress"
  10. // "github.com/gofiber/template/html/v2"
  11. "wartank/pkg/types"
  12. )
  13. type СервВеб struct {
  14. серв types.ИСервер
  15. роутер fiber.App
  16. порт string
  17. }
  18. // НовСервВеб -- возвращает новый веб-сервер
  19. func НовСервВеб(серв types.ИСервер) (*СервВеб, error) {
  20. if серв == nil {
  21. return nil, fmt.Errorf("НовСерВеб(): ИСервер==nil")
  22. }
  23. стенд := os.Getenv("STAGE")
  24. порт := "18061" // dev
  25. if стенд == "prod" {
  26. порт = "18060"
  27. }
  28. // engine := html.New("./web/tmpl", ".tmpl.html")
  29. конф := fiber.Config{
  30. // Prefork: false,
  31. ServerHeader: "WarTank",
  32. //StrictRouting: false,
  33. //CaseSensitive: false,
  34. //Immutable: false,
  35. //UnescapePath: false,
  36. //ETag: false,
  37. BodyLimit: 10_000_000,
  38. Concurrency: 50,
  39. // Views: engine,
  40. //ViewsLayout: "",
  41. //PassLocalsToViews: false,
  42. ReadTimeout: 15 * time.Second,
  43. WriteTimeout: 15 * time.Second,
  44. IdleTimeout: 15 * time.Second,
  45. ReadBufferSize: 4096,
  46. WriteBufferSize: 4096,
  47. //CompressedFileSuffix: "",
  48. //ProxyHeader: "",
  49. //GETOnly: false,
  50. //ErrorHandler: func(*fiber.Ctx, error) error { panic("not implemented") },
  51. //DisableKeepalive: false,
  52. //DisableDefaultDate: false,
  53. //DisableDefaultContentType: false,
  54. //DisableHeaderNormalizing: false,
  55. //DisableStartupMessage: false,
  56. AppName: "WarTank.App",
  57. // StreamRequestBody: false,
  58. // DisablePreParseMultipartForm: false,
  59. // ReduceMemoryUsage: false,
  60. // JSONEncoder: func(interface{}) ([]byte, error) { panic("not implemented") },
  61. // JSONDecoder: func([]byte, interface{}) error { panic("not implemented") },
  62. // XMLEncoder: func(interface{}) ([]byte, error) { panic("not implemented") },
  63. Network: "tcp4",
  64. // EnableTrustedProxyCheck: false,
  65. // TrustedProxies: []string{},
  66. // EnableIPValidation: false,
  67. // EnablePrintRoutes: false,
  68. // ColorScheme: fiber.Colors{
  69. // Black: "",
  70. // Red: "",
  71. // Green: "",
  72. // Yellow: "",
  73. // Blue: "",
  74. // Magenta: "",
  75. // Cyan: "",
  76. // White: "",
  77. // Reset: "",
  78. // },
  79. // RequestMethods: []string{},
  80. // EnableSplittingOnParsers: false,
  81. }
  82. сам := &СервВеб{
  83. серв: серв,
  84. роутер: *fiber.New(конф),
  85. порт: порт,
  86. }
  87. // compresConfig := compress.Config{
  88. // Level: compress.LevelBestCompression,
  89. // }
  90. // сам.роутер.Use(compress.New(compresConfig))
  91. // сам.роутер.Static("/static", "./web/static", fiber.Static{
  92. // Compress: true,
  93. // ByteRange: true,
  94. // Browse: true,
  95. // Index: "index.html",
  96. // CacheDuration: 30 * time.Second,
  97. // MaxAge: 3600,
  98. // })
  99. сам.роутер.Get("/list_bot/get", сам.гетСписБот)
  100. сам.роутер.Post("/list_bot/add", сам.постБотНов)
  101. сам.роутер.Post("bot/stat", сам.постБотСтат)
  102. return сам, nil
  103. }
  104. // Пуск -- запускае веб-сервер в работу
  105. func (сам *СервВеб) Пуск() {
  106. фнПуск := func() {
  107. ош := сам.роутер.Listen(":" + сам.порт)
  108. if ош != nil {
  109. log.Printf("СервВеб.Пуск(): при работе веб-сервера, ош=\n\t%v\n", ош)
  110. сам.серв.CancelApp()
  111. }
  112. }
  113. go фнПуск()
  114. }
  115. type ПостБотСтат struct {
  116. Логин string `form:"name"`
  117. }
  118. // постБотСтат -- возвращает статистику бота
  119. func (сам *СервВеб) постБотСтат(кнт *fiber.Ctx) error {
  120. ботСт := &ПостБотСтат{}
  121. if err := кнт.BodyParser(ботСт); err != nil {
  122. return кнт.JSON(fiber.Map{
  123. "error": "СервВеб.постБотСтат(): при парсинге тела запроса, ош=\n\t%" + err.Error(),
  124. })
  125. }
  126. if ботСт.Логин == "" {
  127. return кнт.JSON(fiber.Map{
  128. "error": "СервВеб.постБотСтат(): пустой логин",
  129. })
  130. }
  131. имя := ботСт.Логин
  132. if имя == "" {
  133. return кнт.JSON(fiber.Map{
  134. "error": "СервВеб.постБотСтат(): пустое имя бота",
  135. })
  136. }
  137. ботоФерма := сам.серв.ServBots()
  138. бот := ботоФерма.Get(имя)
  139. if бот == nil {
  140. return кнт.JSON(fiber.Map{
  141. "error": fmt.Sprintf("СервВеб.постБотСтат(): бот c имнем %q не существует", имя),
  142. })
  143. }
  144. диктБот := map[string]string{}
  145. диктБот["isAuto"] = fmt.Sprint(бот.АвтоИграЕсли())
  146. диктБот["isWork"] = fmt.Sprint(бот.ЕслиПуск())
  147. топливо := бот.Ангар().Топливо().Получ()
  148. if топливо == 0 {
  149. бот.Ангар().Обновить()
  150. топливо = бот.Ангар().Топливо().Получ()
  151. }
  152. диктБот["топливо"] = fmt.Sprint(топливо)
  153. диктБот["золото"] = fmt.Sprint(бот.Ангар().Золото().Получ())
  154. диктБот["серебро"] = fmt.Sprint(бот.Ангар().СереброВсего().Получ())
  155. слава := бот.Ангар().Конвой().Слава().Получ()
  156. if слава == 0 {
  157. бот.Ангар().Обновить()
  158. слава = бот.Ангар().Конвой().Слава().Получ()
  159. }
  160. диктБот["слава"] = fmt.Sprint(слава)
  161. диктБот["прогресс"] = fmt.Sprintf("%v%%", бот.Ангар().Прогресс().Получ())
  162. диктБот["уровень"] = fmt.Sprintf("%v", бот.Ангар().Уровень().Получ())
  163. диктБот["атака"] = fmt.Sprintf("%v", бот.Танк().ТанкСтат().Атака().Получ())
  164. диктБот["броня"] = fmt.Sprintf("%v", бот.Танк().ТанкСтат().Броня().Получ())
  165. диктБот["точность"] = fmt.Sprintf("%v", бот.Танк().ТанкСтат().Точность().Получ())
  166. диктБот["прочность"] = fmt.Sprintf("%v", бот.Танк().ТанкСтат().Прочность().Получ())
  167. диктБот["мощь"] = fmt.Sprintf("%v", бот.Танк().ТанкСтат().Мощь().Получ())
  168. диктБот["шахта_уровень"] = fmt.Sprintf("%v", бот.Ангар().База().Шахта().Уровень().Получ())
  169. диктБот["шахта_режим"] = fmt.Sprintf("%v", бот.Ангар().База().Шахта().РежимТекущ().Получ())
  170. диктБот["шахта_сделать_кол"] = fmt.Sprintf("%v", бот.Ангар().База().Шахта().ПродуктКолСейчас())
  171. диктБот["шахта_сделать_назв"] = бот.Ангар().База().Шахта().ПродуктИмяСейчас()
  172. диктБот["шахта_сделать_время"] = бот.Ангар().База().Шахта().ПродуктВремяСейчас()
  173. диктБот["полигон_уровень"] = fmt.Sprintf("%v", бот.Ангар().База().Полигон().Уровень().Получ())
  174. диктБот["полигон_режим"] = fmt.Sprintf("%v", бот.Ангар().База().Полигон().РежимТекущ().Получ())
  175. диктБот["полигон_сделать_кол"] = fmt.Sprintf("%v", бот.Ангар().База().Полигон().ПродуктКолСейчас())
  176. диктБот["полигон_сделать_назв"] = бот.Ангар().База().Полигон().ПродуктИмяСейчас()
  177. диктБот["полигон_сделать_время"] = бот.Ангар().База().Полигон().ПродуктВремяСейчас()
  178. return кнт.JSON(диктБот)
  179. }
  180. type ПостБотНов struct {
  181. Логин string `form:"login"`
  182. Пароль string `form:"pass"`
  183. ЕслиАвто string `form:"is_auto"`
  184. }
  185. // постБотНов -- добавляет бота на бото-ферму
  186. func (сам *СервВеб) постБотНов(кнт *fiber.Ctx) error {
  187. бот := &ПостБотНов{}
  188. if err := кнт.BodyParser(бот); err != nil {
  189. return кнт.JSON(fiber.Map{
  190. "error": "СервВеб.постБотНов(): при парсинге тела запроса, ош=\n\t%" + err.Error(),
  191. })
  192. }
  193. if бот.Логин == "" {
  194. return кнт.JSON(fiber.Map{
  195. "error": "СервВеб.постБотНов(): пустой логин",
  196. })
  197. }
  198. if бот.Пароль == "" {
  199. return кнт.JSON(fiber.Map{
  200. "error": "СервВеб.постБотНов(): пустой пароль",
  201. })
  202. }
  203. if бот.ЕслиАвто == "" {
  204. return кнт.JSON(fiber.Map{
  205. "error": "СервВеб.постБотНов(): пустой еслиАвто",
  206. })
  207. }
  208. var еслиАвто bool
  209. if бот.ЕслиАвто == "true" {
  210. еслиАвто = true
  211. }
  212. ботоФерма := сам.серв.ServBots()
  213. ош := ботоФерма.НовБот(бот.Логин, бот.Пароль, еслиАвто)
  214. if ош != nil {
  215. return кнт.JSON(fiber.Map{
  216. "error": "СервВеб.постБотНов(): при создании бота %q, ош=\n\t%" + ош.Error(),
  217. })
  218. }
  219. return nil
  220. }
  221. // гетСписБот -- возвращает список ботов
  222. func (сам *СервВеб) гетСписБот(кнт *fiber.Ctx) error {
  223. списБот := сам.серв.ServBots().ListBot()
  224. рез := make([]map[string]string, 0)
  225. for _, бот := range списБот {
  226. _бот := map[string]string{}
  227. _бот["name"] = бот.Имя()
  228. _бот["isAuto"] = fmt.Sprint(бот.АвтоИграЕсли())
  229. _бот["isWork"] = fmt.Sprint(бот.ЕслиПуск())
  230. _бот["gold"] = fmt.Sprint(бот.Ангар().Золото().Получ())
  231. _бот["fuel"] = fmt.Sprint(бот.Ангар().Топливо().Получ())
  232. рез = append(рез, _бот)
  233. }
  234. return кнт.JSON(рез)
  235. }