package bank
import (
"fmt"
"log"
"strconv"
"strings"
"time"
"wartank/pkg/alias"
"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"
)
/*
Предоставляет объект банка на базе
*/
// Банк -- объект банка на базе
type Банк struct {
*section.Секция
сеть *banknet.BankNet
сереброБот types.ИСтатПарам
режим1 *bankmode.BankMode // 1 режим работы на выбор
режим2 *bankmode.BankMode // 2 режим работы на выбор
}
// НовБанк -- возвращает новый *Bank
func НовБанк(база types.ИБаза) (*Банк, error) {
section, ош := section.НовСекция(база.Бот(), "Банк", `Серебро
`)
if ош != nil {
return nil, fmt.Errorf("НовБанк(): при создании секции банка, ош=\n\t%w", ош)
}
сереброБот, ош := static_param.НовСтатПарам("silver_bot")
if ош != nil {
return nil, fmt.Errorf("НовБанк(): при создании статы серебра бота, ош=\n\t%w", ош)
}
sf := &Банк{
Секция: section,
сереброБот: сереброБот,
режим1: bankmode.NewBankMode(),
режим2: bankmode.NewBankMode(),
}
sf.сеть, ош = banknet.NewBankNet(sf)
if ош != nil {
return nil, fmt.Errorf("NewBank(): in create NetBank, err=\n\t%w", ош)
}
return sf, nil
}
// Пуск -- запускает банк в работу
func (сам *Банк) Пуск() error {
log.Printf("Банк.Run()\n")
go сам.пуск()
return nil
}
// UpdateLst -- принудительно обновляет состояние банка
func (сам *Банк) UpdateLst() {
if err := сам.сеть.UpdateLst(); err != nil {
log.Printf("Банк.UpdateLst(): err=\n\t%v\n", err)
}
}
// запускает банк в опрос
func (сам *Банк) пуск() {
log.Printf("Банк.пуск()\n")
fnRun := func() {
defer time.Sleep(time.Minute * 2)
сам.проверитьПостроить()
if ош := сам.сеть.UpdateLst(); ош != nil {
// log._rintf("ERRO Банк.пуск(): при обновлении lstBank, err=\n\t%v\n", err)
return
}
if ош := сам.получитьВсеРежимы(); ош != nil {
log.Printf("ERRO Банк.пуск(): при получении списка режимов банка, err=\n\t%v\n", ош)
}
_, ош := сам.сделатьСеребро()
if ош != nil {
log.Printf("ERRO Банк.пуск(): при пуске производства банка, err=\n\t%v\n", ош)
}
}
for {
// <-sf.ВремяОпрос().КаналСиг()
fnRun()
}
}
// Проверяет необходимость постройки полигона
func (сам *Банк) проверитьПостроить() {
фнПостроить := func() bool {
var (
списБанк []string
ош error
)
{ // Зайти на страницу постройки
// https://wartank.ru/building-upgrade/Bank
списБанк, ош = сам.сеть.Клиент().Get("https://wartank.ru/building-upgrade/Bank")
if ош != nil {
log.Printf("Банк.построитьПровер(): при чтении страницы строительства банка, ош=\n\t%v\n", ош)
return false
}
стрСсылка := ""
еслиНайти := false
//
for _, стрСсылка = range списБанк {
if strings.Contains(стрСсылка, `href="Bank?`) {
еслиНайти = true
break
}
}
if !еслиНайти { // Время полигона вышло
return false
}
_ссылка := strings.TrimPrefix(стрСсылка, ``)
ссылка := "https://wartank.ru/building-upgrade/" + _ссылка
// https://wartank.ru/building-upgrade/Bank?162-1.ILinkListener-upgradeLink-link
списБанк, ош = сам.сеть.Клиент().Get(ссылка)
if ош != nil {
log.Printf("Банк.построитьПровер(): при выполнении запроса на строительство, ош=\n\t%v\n", ош)
return false
}
}
{ // Заказать постройку
// https://wartank.ru/building-upgrade/Bank
стрСсылка := ""
еслиНайти := false
//
for _, стрСсылка = range списБанк {
if strings.Contains(стрСсылка, `href="Bank?`) {
еслиНайти = true
break
}
}
if !еслиНайти { // Время полигона вышло
return false
}
_ссылка := strings.TrimPrefix(стрСсылка, ``)
ссылка := "https://wartank.ru/building-upgrade/" + _ссылка
// https://wartank.ru/building-upgrade/Bank?162-1.ILinkListener-upgradeLink-link
списБанк, ош = сам.сеть.Клиент().Get(ссылка)
if ош != nil {
log.Printf("Банк.построитьПровер(): при выполнении запроса на строительство, ош=\n\t%v\n", ош)
return false
}
}
{ // подтверждение постройки
// да, подтверждаю
стрСсылка := ""
еслиНайти := false
for _, стрСсылка = range списБанк {
if strings.Contains(стрСсылка, `.ILinkListener-confirmLink`) {
еслиНайти = true
break
}
}
if !еслиНайти { // Время полигона вышло
return false
}
_ссылка := strings.TrimPrefix(стрСсылка, `да, подтверждаю")
ссылка := "https://wartank.ru/" + _ссылка
// https://wartank.ru/wicket/page?135-1.ILinkListener-confirmLink
_, ош = сам.сеть.Клиент().Get(ссылка)
if ош != nil {
log.Printf("Банк.построитьПровер(): при выполнении запроса на строительство, ош=\n\t%v\n", ош)
return false
}
}
return true
}
фнПостроить()
log.Printf("Банк.построитьПровер(): построен упешно\n")
}
// РежимРаботы2 -- возвращает объект режима2
func (sf *Банк) РежимРаботы2() types.ИБанкРежим {
return sf.режим2
}
// РежимРаботы1 -- возвращает объект режима1
func (sf *Банк) РежимРаботы1() types.ИБанкРежим {
return sf.режим1
}
// СереброБот -- возвращает серебро от бота
func (sf *Банк) СереброБот() types.ИСтатПарам {
return sf.сереброБот
}
// Запускает в производство серебро
func (sf *Банк) сделатьСеребро() (alias.МилСек, 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 = "https://wartank.ru/production/" + lstLink[0]
lstBank, err := sf.сеть.Get(strLink)
if err != nil {
return 0, fmt.Errorf("BankNet.makeProduct(): при выполнении GET-запроса начать производство, err=%w", err)
}
for _, strOut := range lstBank {
if strings.Contains(strOut, `