package bank
import (
"fmt"
"log"
"strconv"
"strings"
"time"
"wartank/pkg/alias"
"wartank/pkg/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", ош)
}
сам := &Банк{
Секция: section,
сереброБот: сереброБот,
режим1: bankmode.NewBankMode(),
режим2: bankmode.NewBankMode(),
}
сам.сеть, ош = banknet.NewBankNet(сам)
if ош != nil {
return nil, fmt.Errorf("NewBank(): in create NetBank, err=\n\t%w", ош)
}
return сам, nil
}
// Пуск -- запускает банк в работу
func (сам *Банк) Пуск() error {
log.Printf("Банк.Run()\n")
go сам.пуск()
return nil
}
// UpdateLst -- принудительно обновляет состояние банка
func (сам *Банк) UpdateLst() {
if err := сам.сеть.Обновить(); err != nil {
log.Printf("Банк.UpdateLst(): err=\n\t%v\n", err)
}
}
// запускает банк в опрос
func (сам *Банк) пуск() {
log.Printf("Банк.пуск()\n")
fnRun := func() {
defer time.Sleep(time.Minute * 5)
сам.забрать()
if сам.построитьУлучшить() {
time.Sleep(time.Minute * 25)
return
}
if сам.проверитьУскорить() {
time.Sleep(time.Minute * 25)
return
}
if ош := сам.сеть.Обновить(); ош != 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 {
// <-сам.ВремяОпрос().КаналСиг()
fnRun()
}
}
// Проверка на ускорение строительства
func (сам *Банк) проверитьУскорить() bool {
var (
стрСсылка = ""
еслиНайдено = false
)
списБанк, ош := сам.сеть.Клиент().Get("https://wartank.ru/buildings")
if ош != nil {
log.Printf("Банк.проверУскорить(): при получении страницы базы, ош=\n\t%v\n", ош)
return false
}
//
Ускорение
for _, стрСсылка = range списБанк {
if strings.Contains(стрСсылка, `.ILinkListener-buildings-1-building-rootBlock-actionPanel-freeBoostLink`) {
еслиНайдено = true
break
}
}
if !еслиНайдено {
return false
}
_ссылка := strings.TrimPrefix(стрСсылка, ` | Ускорение`)
ссылка := "https://wartank.ru/" + _ссылка
_, ош = сам.сеть.Клиент().Get(ссылка)
if ош != nil {
log.Printf("Банк.проверУскорить(): при выполнении ускорения, ош=\n\t%v\n", ош)
return false
}
return true
}
// Забирает серебро
func (сам *Банк) забрать() {
var (
strOut string
еслиНайдено bool
)
списБанк, ош := сам.сеть.Клиент().Get("https://wartank.ru/buildings")
if ош != nil {
log.Printf("Банк.забрать(): при выполнении GET-запроса 'получить страницу базы', ош=\n\t%v\n", ош)
return
}
// Забрать
for _, strOut = range списБанк {
if strings.Contains(strOut, `.ILinkListener-buildings-1-building-rootBlock-actionPanel-takeProductionLink`) {
еслиНайдено = true
break
}
}
if !еслиНайдено {
return
}
_ссылка := strings.TrimPrefix(strOut, `Забрать`)
// https://wartank.ru/buildings?3-1.ILinkListener-buildings-1-building-rootBlock-actionPanel-takeProductionLink
ссылка := "https://wartank.ru/" + _ссылка
_, ош = сам.сеть.Клиент().Get(ссылка)
if ош != nil {
log.Printf("Банк.забрать(): при выполнении GET-запроса 'забрать серебро', err=\n\t%v\n", ош)
return
}
}
// Проверяет необходимость постройки полигона
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 еслиНайти { // Время полигона вышло
_ссылка := 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
}
}
log.Printf("Банк.построитьПровер(): построен упешно\n")
return true
}
// РежимРаботы2 -- возвращает объект режима2
func (сам *Банк) РежимРаботы2() types.ИБанкРежим {
return сам.режим2
}
// РежимРаботы1 -- возвращает объект режима1
func (сам *Банк) РежимРаботы1() types.ИБанкРежим {
return сам.режим1
}
// СереброБот -- возвращает серебро от бота
func (сам *Банк) СереброБот() types.ИСтатПарам {
return сам.сереброБот
}
// Запускает в производство серебро
func (сам *Банк) сделатьСеребро() (alias.МилСек, error) {
var (
lstBank = сам.СписПолучить()
ind int
strOut string
strLink string
еслиНайдено bool
)
time1 := сам.РежимРаботы1().ВремяСделать()
time2 := сам.РежимРаботы2().ВремяСделать()
if time1 > time2 {
time1 = time2
}
for ind, strOut = range lstBank {
if strings.Contains(strOut, time1) {
ind += 7
strLink = lstBank[ind]
еслиНайдено = true
break
}
}
if еслиНайдено && strings.Contains(strLink, `>Начать производство`) {
lstLink := strings.Split(strLink, `Начать производство`)
strLink = "https://wartank.ru/production/" + lstLink[0]
lstBank, err := сам.сеть.Get(strLink)
if err != nil {
return 0, fmt.Errorf("BankNet.makeProduct(): при выполнении GET-запроса начать производство, err=%w", err)
}
for _, strOut := range lstBank {
if strings.Contains(strOut, `База`) { // Это база, а не банк
return 30, nil
}
}
if err = сам.СтрОбновить(lstBank); err != nil {
return 0, fmt.Errorf("BankNet.makeProduct(): при обновлении lstBank, err=%w", err)
}
if err := сам.Уст(alias.Время(time1)); err != nil {
log.Printf("WARN Банк.makeProduct(): при установке времени производства банка(%v)\n\terr=%v\n", time1, err)
}
}
return сам.ВремяОстат().ПолучМилСек(), nil
}
// Получает все режимы банка
func (сам *Банк) получитьВсеРежимы() error {
var (
lstBank = сам.СписПолучить()
ind int
strMode string
strMode1 string
strMode2 string
)
{ // Получить первый режим
for ind, strMode = range lstBank {
if strings.Contains(strMode, `Кол-во: `) {
strMode1 = strMode
break
}
}
lstMode := strings.Split(strMode1, `Кол-во: `)
strMode1 = lstMode[1]
lstMode = strings.Split(strMode1, ` `)
strMode1 = lstMode[0]
iNum1, err := strconv.Atoi(strMode1)
if err != nil {
return fmt.Errorf("BankNet.getAllMode(): numSilver1(%v) not number, err=\n\t%w", strMode1, err)
}
сам.РежимРаботы1().Серебро().Уст(iNum1)
// Установить время производства
strTime1 := lstBank[ind+2]
сам.РежимРаботы1().ВремяСделатьУст(strTime1)
if iNum1 <= 2 { // Если банк слишком слабый
return nil
}
}
{ // Получить второй режим
for _ind := ind + 2; _ind < len(lstBank); _ind++ {
strMode := lstBank[_ind]
if strings.Contains(strMode, `Кол-во: `) {
strMode2 = strMode
ind = _ind
break
}
}
lstMode := strings.Split(strMode2, `Кол-во: `)
strMode2 = lstMode[1]
lstMode = strings.Split(strMode2, ` `)
strMode2 = lstMode[0]
iNum2, err := strconv.Atoi(strMode2)
if err != nil {
return fmt.Errorf("BankNet.getAllMode(): numSilver2(%v) not number, err=\n\t%w", strMode2, err)
}
сам.РежимРаботы2().Серебро().Уст(iNum2)
// Установить время производства
strTime2 := lstBank[ind+2]
сам.РежимРаботы2().ВремяСделатьУст(strTime2)
}
return nil
}
|