package bank
import (
"fmt"
"log"
"strconv"
"strings"
"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
silverBot types.IStatParam
mode1 *bankmode.BankMode
mode2 *bankmode.BankMode
}
// NewBank -- возвращает новый *Bank
func NewBank(base types.IBase) (*Bank, error) {
section, err := section.NewSection(base.Bot(), `Серебро
`)
if err != nil {
return nil, fmt.Errorf("NewBank(): in create *Section, err=\n\t%w", err)
}
sf := &Bank{
Section: section,
silverBot: static_param.NewStaticParam("silver_bot"),
mode1: bankmode.NewBankMode(),
mode2: bankmode.NewBankMode(),
}
sf.net, err = banknet.NewBankNet(sf)
if err != nil {
return nil, fmt.Errorf("NewBank(): in create NetBank, err=\n\t%w", err)
}
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.CountDown().Set(5)
for range sf.CountDown().ChanSig() {
// time.Sleep(time.Second * 30)
count := sf.CountDown().Get()
log.Printf("Bank countDown=%d\n", count)
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
}
if err := sf.makeProduct(); err != nil {
log.Printf("ERRO Bank.Run(): при пуске производства банка, err=\n\t%v\n", err)
}
}
}
// Mode2 -- возвращает объект режима2
func (sf *Bank) Mode2() types.IBankMode {
return sf.mode2
}
// Mode1 -- возвращает объект режима1
func (sf *Bank) Mode1() types.IBankMode {
return sf.mode1
}
// SilverBot -- возвращает серебро от бота
func (sf *Bank) SilverBot() types.IStatParam {
return sf.silverBot
}
// Запускает в производство серебро
func (sf *Bank) makeProduct() error {
var (
lstBank = sf.GetLst()
ind int
strOut string
strLink string
isFind bool
)
time1 := sf.Mode1().Time()
time2 := sf.Mode2().Time()
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 fmt.Errorf("BankNet.makeProduct(): при выполнении GET-запроса начать производство, err=%w", err)
}
for _, strOut := range lstBank {
if strings.Contains(strOut, `