// package angar_attack -- объект боя на топливе package angar_attack import ( "fmt" "log" "os" "strings" "time" "wartank/pkg/components/sectionnet" "wartank/pkg/cons" "wartank/pkg/types" ) // ТопливоБой -- объект боя на топливе type ТопливоБой struct { *sectionnet.SectionNet ангар types.ИАнгар } // НовТопливоБой -- возвращает новый *AngarAttackNet func НовТопливоБой(angar types.ИАнгар) (*ТопливоБой, error) { sectionNet, err := sectionnet.NewSectionNet(angar, "http://wartank.ru/battle") if err != nil { return nil, fmt.Errorf("NewAngarAttack(): in create SectionNet, err=\n\t%w", err) } sf := &ТопливоБой{ SectionNet: sectionNet, ангар: angar, } return sf, nil } func (sf *ТопливоБой) Пуск() error { go sf.пуск() return nil } func (sf *ТопливоБой) пуск() { for { time.Sleep(time.Second * 30) // Минимальный интервал ожттдания прибавки топлива топливо := sf.ангар.Топливо().Получ() if топливо < cons.ТопливоМин { // Минимальная ёмкость бака -- 315 continue } log.Printf("Fuel.Run: val=%v\n", топливо) списСтрБой, err := sf.начатьБой() if err != nil { // log._rintf("ERRO AngarAttack.findFuel(): in get page battle, err=\n\t%v\n", err) continue } списВыстрел1, err := sf.выбратьБойСлабый(списСтрБой) if err != nil { // log._rintf("ERRO AngarAttack.findFuel(): in get page shooting, err=\n\t%v\n", err) continue } if err := sf.сделатьВыстрелы(списВыстрел1); err != nil { log.Printf("ERRO AngarAttack.findFuel(): in make shooting, err=\n\t%v\n", err) } } } // Идёт в атаку, если топлива больше cons.ТопливоМин func (sf *ТопливоБой) начатьБой() (спискСтрБой []string, err error) { // Получить ссылку на атаку // _mt.Println("\t AngarAttack.makeAtack()") lstAngar := sf.ангар.СписПолучить() var стрАнализ string for _, стрАтак := range lstAngar { if strings.Contains(стрАтак, `В бой!`) { стрАнализ = стрАтак break } } // Вырезать ссылку на атаку lstAngar = strings.Split(стрАнализ, `В бой!`) бойСсылка = "http://wartank.ru/" + lstAngar[0] спискСтрБой, err = sf.Get(бойСсылка) if err != nil { return nil, fmt.Errorf("AngarAttack.makeAtack(): in make GET-request to battle, err=\n\t%w", err) } return спискСтрБой, nil } // Выбирает первого более слабого противника и делает первый выстрел func (sf *ТопливоБой) выбратьБойСлабый(списСтрБой []string) (списСтрВыстрел1 []string, err error) { // _mt.Println("\tAngarNet.makeSelectBattle()") var стрАнализ string defer func() { if паника := recover(); паника != nil { msg := time.Now().Local().Format("2006-01-02 15:04:05.000 ") + "fnShoot1\n" msg += "\tNetClient.makeSelectBattle().fnShoot1()\n" msg0 := fmt.Sprintf("%v\n", паника) msg1 := "" for _, _msg := range strings.Split(msg0, "\n") { if _msg == "" { continue } msg1 += "\t" + _msg + "\n" } msg += msg1 // _mt.Println(msg) err = fmt.Errorf("%v", msg) msg1 = "" // Сброс накопленной ошибки for _, _msg := range списСтрБой { if _msg == "" { continue } msg1 += "\t" + _msg + "\n" } msg += msg1 // Выкинуть ошибку в файл _ = os.MkdirAll("./errors", 0700) err = os.WriteFile("./errors/attack_shoot1.html", []byte(msg), 0600) } }() // Выдернуть строку с первой ссылкой на противника for _, стрБой_ := range списСтрБой { if strings.Contains(стрБой_, `opponents-opponents-0`) { стрАнализ = стрБой_ break } } var ссылкаБой string switch стрАнализ == "" { case true: // Такая ситуация возможна, если уже были какие-то выстрелы return списСтрБой, nil default: // Успешный выстрел // Вырезать ссылку из строки списСтрБой = strings.Split(стрАнализ, `tankДобить`) { strOut = strShoot break } } var linkShoot2 string switch strOut == "" { case true: // Первый выстрел был неудачным for _, strShoot := range lstShoot2 { if strings.Contains(strShoot, `Взять реванш`) { strOut = strShoot break } } if strOut == "" { // Это ситуация для третьего выстрела списВыстрел3 = lstShoot2 return nil } // Вырезать ссылку из строки lstShoot2 = strings.Split(strOut, `Взять реванш`) linkShoot2 = "http://wartank.ru/" + lstShoot2[0] default: // Первый выстрел был удачным // Вырезать ссылку из строки lstShoot2 = strings.Split(strOut, `Добить`) linkShoot2 = "http://wartank.ru/" + lstShoot2[0] } списВыстрел3, err = sf.Get(linkShoot2) if err != nil { return fmt.Errorf("AngarAttack.makeShooting(): in Get-response shoot2, err=\n\t%w", err) } fuel := sf.ангар.Топливо().Получ() fuel -= 30 sf.ангар.Топливо().Уст(fuel) return nil } if err := фнВыстрел2(); err != nil { return err } фнВыстрел3 := func() (err error) { // Третий выстрел // _mt.Println("\tAngarNet.makeShooting().fnShoot3()") defer func() { if _panic := recover(); _panic != nil { msg := time.Now().Local().Format("2006-01-02 15:04:05.000 fnShoot3\n") msg += "\tNetClient.makeShooting().fnShoot3()\n" msg0 := fmt.Sprintf("%v\n", _panic) msg1 := "" for _, _msg := range strings.Split(msg0, "\n") { if _msg == "" { continue } msg1 += "\t" + _msg + "\n" } msg += msg1 // _mt.Println(msg) err = fmt.Errorf("%v", msg) msg1 = "" // Сброс накопленной ошибки for _, _msg := range списВыстрел3 { if _msg == "" { continue } msg1 += "\t" + _msg + "\n" } msg += msg1 // Выкинуть ошибку в файл _ = os.MkdirAll("./errors", 0700) err = os.WriteFile("./errors/attack_shoot3.html", []byte(msg), 0600) } }() // Получить ссылку на третий выстрел var strOut string for _, strShoot3 := range списВыстрел3 { if strings.Contains(strShoot3, `Уничтожить`) { strOut = strShoot3 break } } linkShoot3 := "" switch strOut == "" { case true: // Если не найдена ссылка -- значит было поражение в выстреле if strOut == "" { for _, strShoot3 := range списВыстрел3 { if strings.Contains(strShoot3, `Взять реванш`) { strOut = strShoot3 break } } } // Вырезать ссылку из строки списВыстрел3 = strings.Split(strOut, `Взять реванш`) linkShoot3 = "http://wartank.ru/" + списВыстрел3[0] default: // Успешный выстрел // Вырезать ссылку из строки списВыстрел3 = strings.Split(strOut, `Уничтожить`) linkShoot3 = "http://wartank.ru/" + списВыстрел3[0] } if _, err = sf.Get(linkShoot3); err != nil { return fmt.Errorf("AngarAttack.makeShooting(): in Get-response shoot3, err=\n\t%w", err) } fuel := sf.ангар.Топливо().Получ() fuel -= 30 sf.ангар.Топливо().Уст(fuel) return nil } if err := фнВыстрел3(); err != nil { return err } return nil }