package bank
import (
"fmt"
"log"
"strconv"
"strings"
"time"
"wartank/pkg/components/section"
"wartank/pkg/types"
"wartank/server/serv_bots/warbot/angar/base/bank/bankmode"
"wartank/server/serv_bots/warbot/angar/base/bank/banknet"
"wartank/server/serv_bots/warbot/tank/tankstat/static_param"
)
/*
Предоставляет объект банка на базе
*/
// Bank -- объект банка на базе
type Bank struct {
*section.Section
net *banknet.BankNet
сереброБот types.ИСтатПарам
mode1 *bankmode.BankMode // 1 режим работы на выбор
mode2 *bankmode.BankMode // 2 режим работы на выбор
}
// НовБанк -- возвращает новый *Bank
func НовБанк(base types.ИБаза) (*Bank, error) {
section, ош := section.NewSection(base.Бот(), "Банк", `Серебро
`)
if ош != nil {
return nil, fmt.Errorf("НовБанк(): при создании секции банка, ош=\n\t%w", ош)
}
сереброБот, ош := static_param.НовСтатПарам("silver_bot")
if ош != nil {
return nil, fmt.Errorf("НовБанк(): при создании статы серебра бота, ош=\n\t%w", ош)
}
sf := &Bank{
Section: section,
сереброБот: сереброБот,
mode1: bankmode.NewBankMode(),
mode2: bankmode.NewBankMode(),
}
sf.net, ош = banknet.NewBankNet(sf)
if ош != nil {
return nil, fmt.Errorf("NewBank(): in create NetBank, err=\n\t%w", ош)
}
return sf, nil
}
// Run -- запускает банк в работу
func (sf *Bank) Run() error {
log.Printf("Bank.Run()\n")
go sf.run()
return nil
}
// UpdateLst -- принудительно обновляет состояние банка
func (sf *Bank) UpdateLst() {
if err := sf.net.UpdateLst(); err != nil {
log.Printf("Bank.UpdateLst(): err=\n\t%v\n", err)
}
}
// запускает банк в опрос
func (sf *Bank) run() {
log.Printf("Bank.run()\n")
sf.SetCountDown(5)
for {
<-sf.ВремяОпрос().КаналСиг()
if err := sf.net.UpdateLst(); err != nil {
// log._rintf("ERRO Bank.Run(): при обновлении lstBank, err=\n\t%v\n", err)
continue
}
if err := sf.getAllMode(); err != nil {
// log._rintf("ERRO Bank.Run(): при получении списка режимов банка, err=\n\t%v\n", err)
continue
}
iTime, err := sf.makeProduct()
if err != nil {
log.Printf("ERRO Bank.Run(): при пуске производства банка, err=\n\t%v\n", err)
continue
}
sf.Section.SetCountDown(iTime)
time.Sleep(time.Second * 10)
}
}
// РежимРаботы2 -- возвращает объект режима2
func (sf *Bank) РежимРаботы2() types.ИБанкРежим {
return sf.mode2
}
// РежимРаботы1 -- возвращает объект режима1
func (sf *Bank) РежимРаботы1() types.ИБанкРежим {
return sf.mode1
}
// СереброБот -- возвращает серебро от бота
func (sf *Bank) СереброБот() types.ИСтатПарам {
return sf.сереброБот
}
// Запускает в производство серебро
func (sf *Bank) makeProduct() (int, error) {
var (
lstBank = sf.СписПолучить()
ind int
strOut string
strLink string
isFind bool
)
time1 := sf.РежимРаботы1().ВремяСделать()
time2 := sf.РежимРаботы2().ВремяСделать()
if time1 > time2 {
time1 = time2
}
for ind, strOut = range lstBank {
if strings.Contains(strOut, time1) {
ind += 7
strLink = lstBank[ind]
isFind = true
break
}
}
if isFind && strings.Contains(strLink, `>Начать производство`) {
lstLink := strings.Split(strLink, `Начать производство`)
strLink = "http://wartank.ru/production/" + lstLink[0]
lstBank, err := sf.net.Get(strLink)
if err != nil {
return -1, fmt.Errorf("BankNet.makeProduct(): при выполнении GET-запроса начать производство, err=%w", err)
}
for _, strOut := range lstBank {
if strings.Contains(strOut, `