2023-07-04, fix for ticketmaster.sg get ticket without map info.
parent
31ce6a7ed6
commit
c78ee22316
|
@ -53,7 +53,7 @@ import webbrowser
|
||||||
import argparse
|
import argparse
|
||||||
import itertools
|
import itertools
|
||||||
|
|
||||||
CONST_APP_VERSION = "MaxBot (2023.07.03)"
|
CONST_APP_VERSION = "MaxBot (2023.07.04)"
|
||||||
|
|
||||||
CONST_MAXBOT_CONFIG_FILE = "settings.json"
|
CONST_MAXBOT_CONFIG_FILE = "settings.json"
|
||||||
CONST_MAXBOT_LAST_URL_FILE = "MAXBOT_LAST_URL.txt"
|
CONST_MAXBOT_LAST_URL_FILE = "MAXBOT_LAST_URL.txt"
|
||||||
|
@ -2696,7 +2696,7 @@ def tixcraft_keyin_captcha_code(driver, answer = "", auto_submit = False):
|
||||||
form_verifyCode.click()
|
form_verifyCode.click()
|
||||||
is_verifyCode_editing = True
|
is_verifyCode_editing = True
|
||||||
except Exception as exc:
|
except Exception as exc:
|
||||||
print("click form_verifyCode fail, tring to use javascript.")
|
print("click form_verifyCode fail, trying to use javascript.")
|
||||||
# plan B
|
# plan B
|
||||||
try:
|
try:
|
||||||
driver.execute_script("document.getElementById(\"TicketForm_verifyCode\").focus();")
|
driver.execute_script("document.getElementById(\"TicketForm_verifyCode\").focus();")
|
||||||
|
@ -2767,7 +2767,7 @@ def tixcraft_get_ocr_answer(driver, ocr, ocr_captcha_image_source, Captcha_Brows
|
||||||
#image_id = 'TicketForm_verifyCode-image'
|
#image_id = 'TicketForm_verifyCode-image'
|
||||||
pass
|
pass
|
||||||
try:
|
try:
|
||||||
driver.set_script_timeout(3)
|
driver.set_script_timeout(1)
|
||||||
form_verifyCode_base64 = driver.execute_async_script("""
|
form_verifyCode_base64 = driver.execute_async_script("""
|
||||||
var canvas = document.createElement('canvas');
|
var canvas = document.createElement('canvas');
|
||||||
var context = canvas.getContext('2d');
|
var context = canvas.getContext('2d');
|
||||||
|
@ -2790,6 +2790,7 @@ def tixcraft_get_ocr_answer(driver, ocr, ocr_captcha_image_source, Captcha_Brows
|
||||||
if show_debug_message:
|
if show_debug_message:
|
||||||
print("canvas exception:", str(exc))
|
print("canvas exception:", str(exc))
|
||||||
pass
|
pass
|
||||||
|
|
||||||
if not img_base64 is None:
|
if not img_base64 is None:
|
||||||
try:
|
try:
|
||||||
ocr_answer = ocr.classification(img_base64)
|
ocr_answer = ocr.classification(img_base64)
|
||||||
|
@ -2797,6 +2798,7 @@ def tixcraft_get_ocr_answer(driver, ocr, ocr_captcha_image_source, Captcha_Brows
|
||||||
pass
|
pass
|
||||||
|
|
||||||
return ocr_answer
|
return ocr_answer
|
||||||
|
|
||||||
#PS: credit to LinShihJhang's share
|
#PS: credit to LinShihJhang's share
|
||||||
def tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, domain_name):
|
def tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, domain_name):
|
||||||
show_debug_message = True # debug.
|
show_debug_message = True # debug.
|
||||||
|
@ -2806,7 +2808,18 @@ def tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, C
|
||||||
is_need_redo_ocr = False
|
is_need_redo_ocr = False
|
||||||
is_form_sumbited = False
|
is_form_sumbited = False
|
||||||
|
|
||||||
|
is_input_box_exist = False
|
||||||
if not ocr is None:
|
if not ocr is None:
|
||||||
|
form_verifyCode = None
|
||||||
|
try:
|
||||||
|
form_verifyCode = driver.find_element(By.ID, 'TicketForm_verifyCode')
|
||||||
|
is_input_box_exist = True
|
||||||
|
except Exception as exc:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
print("ddddocr component is not able to use, you may running in arm environment.")
|
||||||
|
|
||||||
|
if is_input_box_exist:
|
||||||
if show_debug_message:
|
if show_debug_message:
|
||||||
print("away_from_keyboard_enable:", away_from_keyboard_enable)
|
print("away_from_keyboard_enable:", away_from_keyboard_enable)
|
||||||
print("previous_answer:", previous_answer)
|
print("previous_answer:", previous_answer)
|
||||||
|
@ -2853,7 +2866,7 @@ def tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, C
|
||||||
if new_captcha_url != "":
|
if new_captcha_url != "":
|
||||||
tixcraft_change_captcha(driver, new_captcha_url) #更改CAPTCHA圖
|
tixcraft_change_captcha(driver, new_captcha_url) #更改CAPTCHA圖
|
||||||
else:
|
else:
|
||||||
print("ddddocr component is not able to use, you may running in arm environment.")
|
print("input box not exist, quit ocr...")
|
||||||
|
|
||||||
return is_need_redo_ocr, previous_answer, is_form_sumbited
|
return is_need_redo_ocr, previous_answer, is_form_sumbited
|
||||||
|
|
||||||
|
@ -3089,6 +3102,7 @@ def tixcraft_ticket_main_ocr(driver, config_dict, ocr, Captcha_Browser, domain_n
|
||||||
tixcraft_keyin_captcha_code(driver)
|
tixcraft_keyin_captcha_code(driver)
|
||||||
else:
|
else:
|
||||||
previous_answer = None
|
previous_answer = None
|
||||||
|
last_url, is_quit_bot = get_current_url(driver)
|
||||||
for redo_ocr in range(999):
|
for redo_ocr in range(999):
|
||||||
is_need_redo_ocr, previous_answer, is_form_sumbited = tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, domain_name)
|
is_need_redo_ocr, previous_answer, is_form_sumbited = tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, domain_name)
|
||||||
if is_form_sumbited:
|
if is_form_sumbited:
|
||||||
|
@ -3101,6 +3115,10 @@ def tixcraft_ticket_main_ocr(driver, config_dict, ocr, Captcha_Browser, domain_n
|
||||||
if not is_need_redo_ocr:
|
if not is_need_redo_ocr:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
current_url, is_quit_bot = get_current_url(driver)
|
||||||
|
if current_url != last_url:
|
||||||
|
break
|
||||||
|
|
||||||
def kktix_confirm_order_button(driver):
|
def kktix_confirm_order_button(driver):
|
||||||
ret = False
|
ret = False
|
||||||
|
|
||||||
|
@ -6820,6 +6838,52 @@ def ticketmaster_parse_zone_info(driver, config_dict):
|
||||||
if show_debug_message:
|
if show_debug_message:
|
||||||
print(exc)
|
print(exc)
|
||||||
|
|
||||||
|
def ticketmaster_get_ticketPriceList(driver, config_dict):
|
||||||
|
show_debug_message = True # debug.
|
||||||
|
show_debug_message = False # online
|
||||||
|
|
||||||
|
if config_dict["advanced"]["verbose"]:
|
||||||
|
show_debug_message = True
|
||||||
|
|
||||||
|
div_mapContainer = None
|
||||||
|
try:
|
||||||
|
my_css_selector = '#mapContainer'
|
||||||
|
div_mapContainer = driver.find_element(By.CSS_SELECTOR, my_css_selector)
|
||||||
|
except Exception as exc:
|
||||||
|
if show_debug_message:
|
||||||
|
print('fail to find my_css_selector:', my_css_selector)
|
||||||
|
#print("find table#ticketPriceList fail", exc)
|
||||||
|
|
||||||
|
table_select = None
|
||||||
|
if not div_mapContainer is None:
|
||||||
|
is_loading = False
|
||||||
|
|
||||||
|
# check is loading.
|
||||||
|
div_loadingmap = None
|
||||||
|
try:
|
||||||
|
my_css_selector = '#loadingmap'
|
||||||
|
div_loadingmap = driver.find_element(By.CSS_SELECTOR, my_css_selector)
|
||||||
|
if not div_loadingmap is None:
|
||||||
|
is_loading = True
|
||||||
|
except Exception as exc:
|
||||||
|
if show_debug_message:
|
||||||
|
print('fail to find my_css_selector:', my_css_selector)
|
||||||
|
#print("find table#ticketPriceList fail", exc)
|
||||||
|
|
||||||
|
if not is_loading:
|
||||||
|
try:
|
||||||
|
my_css_selector = '#ticketPriceList'
|
||||||
|
table_select = driver.find_element(By.CSS_SELECTOR, my_css_selector)
|
||||||
|
except Exception as exc:
|
||||||
|
if show_debug_message:
|
||||||
|
print('fail to find my_css_selector:', my_css_selector)
|
||||||
|
#print("find table#ticketPriceList fail", exc)
|
||||||
|
|
||||||
|
if table_select is None:
|
||||||
|
ticketmaster_parse_zone_info(driver, config_dict)
|
||||||
|
|
||||||
|
return table_select
|
||||||
|
|
||||||
def ticketmaster_assign_ticket_number(driver, config_dict):
|
def ticketmaster_assign_ticket_number(driver, config_dict):
|
||||||
show_debug_message = True # debug.
|
show_debug_message = True # debug.
|
||||||
show_debug_message = False # online
|
show_debug_message = False # online
|
||||||
|
@ -6827,21 +6891,13 @@ def ticketmaster_assign_ticket_number(driver, config_dict):
|
||||||
if config_dict["advanced"]["verbose"]:
|
if config_dict["advanced"]["verbose"]:
|
||||||
show_debug_message = True
|
show_debug_message = True
|
||||||
|
|
||||||
table_select = None
|
table_select = ticketmaster_get_ticketPriceList(driver, config_dict)
|
||||||
try:
|
|
||||||
my_css_selector = 'table#ticketPriceList'
|
|
||||||
table_select = driver.find_element(By.CSS_SELECTOR, my_css_selector)
|
|
||||||
except Exception as exc:
|
|
||||||
if show_debug_message:
|
|
||||||
print('fail to find my_css_selector:', my_css_selector)
|
|
||||||
#print("find table#ticketPriceList fail", exc)
|
|
||||||
ticketmaster_parse_zone_info(driver, config_dict)
|
|
||||||
|
|
||||||
form_select = None
|
select_obj = None
|
||||||
if not table_select is None:
|
if not table_select is None:
|
||||||
|
form_select = None
|
||||||
if show_debug_message:
|
if show_debug_message:
|
||||||
print('found table, start find select')
|
print('found table#ticketPriceList, start find select')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
my_css_selector = 'select'
|
my_css_selector = 'select'
|
||||||
form_select = table_select.find_element(By.CSS_SELECTOR, my_css_selector)
|
form_select = table_select.find_element(By.CSS_SELECTOR, my_css_selector)
|
||||||
|
@ -6851,10 +6907,9 @@ def ticketmaster_assign_ticket_number(driver, config_dict):
|
||||||
print("find form-select fail", exc)
|
print("find form-select fail", exc)
|
||||||
pass
|
pass
|
||||||
|
|
||||||
select_obj = None
|
|
||||||
if form_select is not None:
|
if form_select is not None:
|
||||||
if show_debug_message:
|
if show_debug_message:
|
||||||
print('found select.')
|
print('found ticket number select.')
|
||||||
|
|
||||||
is_visible = False
|
is_visible = False
|
||||||
try:
|
try:
|
||||||
|
@ -6920,6 +6975,7 @@ def ticketmaster_captcha(driver, config_dict, ocr, Captcha_Browser, domain_name)
|
||||||
tixcraft_keyin_captcha_code(driver)
|
tixcraft_keyin_captcha_code(driver)
|
||||||
else:
|
else:
|
||||||
previous_answer = None
|
previous_answer = None
|
||||||
|
last_url, is_quit_bot = get_current_url(driver)
|
||||||
for redo_ocr in range(999):
|
for redo_ocr in range(999):
|
||||||
is_need_redo_ocr, previous_answer, is_form_sumbited = tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, domain_name)
|
is_need_redo_ocr, previous_answer, is_form_sumbited = tixcraft_auto_ocr(driver, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, domain_name)
|
||||||
if is_form_sumbited:
|
if is_form_sumbited:
|
||||||
|
@ -6932,6 +6988,10 @@ def ticketmaster_captcha(driver, config_dict, ocr, Captcha_Browser, domain_name)
|
||||||
if not is_need_redo_ocr:
|
if not is_need_redo_ocr:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
current_url, is_quit_bot = get_current_url(driver)
|
||||||
|
if current_url != last_url:
|
||||||
|
break
|
||||||
|
|
||||||
|
|
||||||
def tixcraft_main(driver, url, config_dict, tixcraft_dict, ocr, Captcha_Browser):
|
def tixcraft_main(driver, url, config_dict, tixcraft_dict, ocr, Captcha_Browser):
|
||||||
tixcraft_home_close_window(driver)
|
tixcraft_home_close_window(driver)
|
||||||
|
@ -7784,7 +7844,7 @@ def ibon_auto_ocr(driver, config_dict, ocr, away_from_keyboard_enable, previous_
|
||||||
|
|
||||||
if not image_element is None:
|
if not image_element is None:
|
||||||
try:
|
try:
|
||||||
driver.set_script_timeout(3)
|
driver.set_script_timeout(1)
|
||||||
form_verifyCode_base64 = driver.execute_async_script("""
|
form_verifyCode_base64 = driver.execute_async_script("""
|
||||||
var canvas = document.createElement('canvas');
|
var canvas = document.createElement('canvas');
|
||||||
var context = canvas.getContext('2d');
|
var context = canvas.getContext('2d');
|
||||||
|
@ -7865,6 +7925,7 @@ def ibon_captcha(driver, config_dict, ocr, Captcha_Browser, model_name):
|
||||||
|
|
||||||
is_cpatcha_sent = False
|
is_cpatcha_sent = False
|
||||||
previous_answer = None
|
previous_answer = None
|
||||||
|
last_url, is_quit_bot = get_current_url(driver)
|
||||||
for redo_ocr in range(999):
|
for redo_ocr in range(999):
|
||||||
is_need_redo_ocr, previous_answer, is_form_sumbited = ibon_auto_ocr(driver, config_dict, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, model_name)
|
is_need_redo_ocr, previous_answer, is_form_sumbited = ibon_auto_ocr(driver, config_dict, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, model_name)
|
||||||
|
|
||||||
|
@ -7881,6 +7942,10 @@ def ibon_captcha(driver, config_dict, ocr, Captcha_Browser, model_name):
|
||||||
if not is_need_redo_ocr:
|
if not is_need_redo_ocr:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
current_url, is_quit_bot = get_current_url(driver)
|
||||||
|
if current_url != last_url:
|
||||||
|
break
|
||||||
|
|
||||||
return is_cpatcha_sent
|
return is_cpatcha_sent
|
||||||
|
|
||||||
def ibon_main(driver, url, config_dict, ibon_dict, ocr, Captcha_Browser):
|
def ibon_main(driver, url, config_dict, ibon_dict, ocr, Captcha_Browser):
|
||||||
|
@ -9786,7 +9851,7 @@ def kham_auto_ocr(driver, config_dict, ocr, away_from_keyboard_enable, previous_
|
||||||
|
|
||||||
if not image_element is None:
|
if not image_element is None:
|
||||||
try:
|
try:
|
||||||
driver.set_script_timeout(3)
|
driver.set_script_timeout(1)
|
||||||
form_verifyCode_base64 = driver.execute_async_script("""
|
form_verifyCode_base64 = driver.execute_async_script("""
|
||||||
var canvas = document.createElement('canvas');
|
var canvas = document.createElement('canvas');
|
||||||
var context = canvas.getContext('2d');
|
var context = canvas.getContext('2d');
|
||||||
|
@ -9867,6 +9932,7 @@ def kham_captcha(driver, config_dict, ocr, Captcha_Browser, model_name):
|
||||||
|
|
||||||
is_cpatcha_sent = False
|
is_cpatcha_sent = False
|
||||||
previous_answer = None
|
previous_answer = None
|
||||||
|
last_url, is_quit_bot = get_current_url(driver)
|
||||||
for redo_ocr in range(999):
|
for redo_ocr in range(999):
|
||||||
is_need_redo_ocr, previous_answer, is_form_sumbited = kham_auto_ocr(driver, config_dict, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, model_name)
|
is_need_redo_ocr, previous_answer, is_form_sumbited = kham_auto_ocr(driver, config_dict, ocr, away_from_keyboard_enable, previous_answer, Captcha_Browser, ocr_captcha_image_source, model_name)
|
||||||
|
|
||||||
|
@ -9882,6 +9948,10 @@ def kham_captcha(driver, config_dict, ocr, Captcha_Browser, model_name):
|
||||||
if not is_need_redo_ocr:
|
if not is_need_redo_ocr:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
current_url, is_quit_bot = get_current_url(driver)
|
||||||
|
if current_url != last_url:
|
||||||
|
break
|
||||||
|
|
||||||
return is_cpatcha_sent
|
return is_cpatcha_sent
|
||||||
|
|
||||||
def kham_check_captcha_text_error(driver, config_dict):
|
def kham_check_captcha_text_error(driver, config_dict):
|
||||||
|
@ -10616,6 +10686,7 @@ def ticketplus_order_ocr(driver, config_dict, ocr, Captcha_Browser):
|
||||||
|
|
||||||
is_cpatcha_sent = False
|
is_cpatcha_sent = False
|
||||||
previous_answer = None
|
previous_answer = None
|
||||||
|
last_url, is_quit_bot = get_current_url(driver)
|
||||||
for redo_ocr in range(999):
|
for redo_ocr in range(999):
|
||||||
is_need_redo_ocr, previous_answer, is_form_sumbited = ticketplus_auto_ocr(driver, config_dict, ocr, previous_answer, Captcha_Browser)
|
is_need_redo_ocr, previous_answer, is_form_sumbited = ticketplus_auto_ocr(driver, config_dict, ocr, previous_answer, Captcha_Browser)
|
||||||
|
|
||||||
|
@ -10645,6 +10716,10 @@ def ticketplus_order_ocr(driver, config_dict, ocr, Captcha_Browser):
|
||||||
if not is_need_redo_ocr:
|
if not is_need_redo_ocr:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
current_url, is_quit_bot = get_current_url(driver)
|
||||||
|
if current_url != last_url:
|
||||||
|
break
|
||||||
|
|
||||||
def ticketplus_auto_ocr(driver, config_dict, ocr, previous_answer, Captcha_Browser):
|
def ticketplus_auto_ocr(driver, config_dict, ocr, previous_answer, Captcha_Browser):
|
||||||
show_debug_message = True # debug.
|
show_debug_message = True # debug.
|
||||||
show_debug_message = False # online
|
show_debug_message = False # online
|
||||||
|
@ -10695,7 +10770,7 @@ def ticketplus_auto_ocr(driver, config_dict, ocr, previous_answer, Captcha_Brows
|
||||||
|
|
||||||
if not image_element is None:
|
if not image_element is None:
|
||||||
try:
|
try:
|
||||||
driver.set_script_timeout(3)
|
driver.set_script_timeout(1)
|
||||||
form_verifyCode_base64 = driver.execute_async_script("""
|
form_verifyCode_base64 = driver.execute_async_script("""
|
||||||
function svgToPng(svg, callback) {
|
function svgToPng(svg, callback) {
|
||||||
const url = getSvgUrl(svg);
|
const url = getSvgUrl(svg);
|
||||||
|
@ -11029,79 +11104,12 @@ def ticketplus_main(driver, url, config_dict, ocr, Captcha_Browser):
|
||||||
if is_event_page:
|
if is_event_page:
|
||||||
ticketplus_order(driver, config_dict, ocr, Captcha_Browser)
|
ticketplus_order(driver, config_dict, ocr, Captcha_Browser)
|
||||||
|
|
||||||
|
def get_current_url(driver):
|
||||||
def main(args):
|
|
||||||
config_dict = get_config_dict(args)
|
|
||||||
|
|
||||||
driver = None
|
|
||||||
if not config_dict is None:
|
|
||||||
for i in range(3):
|
|
||||||
driver = get_driver_by_config(config_dict)
|
|
||||||
if not driver is None:
|
|
||||||
break
|
|
||||||
else:
|
|
||||||
time.sleep(0.05)
|
|
||||||
else:
|
|
||||||
print("Load config error!")
|
|
||||||
|
|
||||||
# internal variable. 說明:這是一個內部變數,請略過。
|
|
||||||
url = ""
|
|
||||||
last_url = ""
|
|
||||||
|
|
||||||
# for tixcraft
|
|
||||||
tixcraft_dict = {}
|
|
||||||
tixcraft_dict["fail_list"]=[]
|
|
||||||
tixcraft_dict["fail_promo_list"]=[]
|
|
||||||
tixcraft_dict["is_popup_checkout"] = False
|
|
||||||
|
|
||||||
# for kktix
|
|
||||||
kktix_dict = {}
|
|
||||||
kktix_dict["fail_list"]=[]
|
|
||||||
kktix_dict["captcha_sound_played"] = False
|
|
||||||
kktix_dict["kktix_register_status_last"] = None
|
|
||||||
kktix_dict["is_popup_checkout"] = False
|
|
||||||
|
|
||||||
ibon_dict = {}
|
|
||||||
ibon_dict["fail_list"]=[]
|
|
||||||
|
|
||||||
hkticketing_dict = {}
|
|
||||||
hkticketing_dict["is_date_submiting"] = False
|
|
||||||
hkticketing_dict["fail_list"]=[]
|
|
||||||
|
|
||||||
|
|
||||||
ocr = None
|
|
||||||
Captcha_Browser = None
|
|
||||||
try:
|
|
||||||
if config_dict["ocr_captcha"]["enable"]:
|
|
||||||
ocr = ddddocr.DdddOcr(show_ad=False, beta=config_dict["ocr_captcha"]["beta"])
|
|
||||||
Captcha_Browser = NonBrowser()
|
|
||||||
|
|
||||||
if len(config_dict["advanced"]["tixcraft_sid"]) > 1:
|
|
||||||
set_non_browser_cookies(driver, config_dict["homepage"], Captcha_Browser)
|
|
||||||
except Exception as exc:
|
|
||||||
print(exc)
|
|
||||||
pass
|
|
||||||
|
|
||||||
DISCONNECTED_MSG = ': target window already closed'
|
DISCONNECTED_MSG = ': target window already closed'
|
||||||
|
|
||||||
while True:
|
|
||||||
time.sleep(0.05)
|
|
||||||
|
|
||||||
is_alert_popup = False
|
|
||||||
|
|
||||||
# pass if driver not loaded.
|
|
||||||
if driver is None:
|
|
||||||
print("web driver not accessible!")
|
|
||||||
break
|
|
||||||
|
|
||||||
#is_alert_popup = check_pop_alert(driver)
|
|
||||||
|
|
||||||
#MUST "do nothing: if alert popup.
|
|
||||||
#print("is_alert_popup:", is_alert_popup)
|
|
||||||
if is_alert_popup:
|
|
||||||
continue
|
|
||||||
|
|
||||||
url = ""
|
url = ""
|
||||||
|
is_quit_bot = False
|
||||||
|
|
||||||
try:
|
try:
|
||||||
url = driver.current_url
|
url = driver.current_url
|
||||||
except NoSuchWindowException:
|
except NoSuchWindowException:
|
||||||
|
@ -11125,17 +11133,17 @@ def main(args):
|
||||||
print("get_log:", driver_log)
|
print("get_log:", driver_log)
|
||||||
if DISCONNECTED_MSG in driver_log:
|
if DISCONNECTED_MSG in driver_log:
|
||||||
print('quit bot by NoSuchWindowException')
|
print('quit bot by NoSuchWindowException')
|
||||||
|
is_quit_bot = True
|
||||||
driver.quit()
|
driver.quit()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
break
|
|
||||||
except Exception as excGetDriverMessageFail:
|
except Exception as excGetDriverMessageFail:
|
||||||
#print("excGetDriverMessageFail:", excGetDriverMessageFail)
|
#print("excGetDriverMessageFail:", excGetDriverMessageFail)
|
||||||
except_string = str(excGetDriverMessageFail)
|
except_string = str(excGetDriverMessageFail)
|
||||||
if 'HTTP method not allowed' in except_string:
|
if 'HTTP method not allowed' in except_string:
|
||||||
print('quit bot by close browser')
|
print('quit bot by close browser')
|
||||||
|
is_quit_bot = True
|
||||||
driver.quit()
|
driver.quit()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
break
|
|
||||||
|
|
||||||
except UnexpectedAlertPresentException as exc1:
|
except UnexpectedAlertPresentException as exc1:
|
||||||
print('UnexpectedAlertPresentException at this url:', url )
|
print('UnexpectedAlertPresentException at this url:', url )
|
||||||
|
@ -11180,14 +11188,88 @@ def main(args):
|
||||||
if isinstance(str_exc, str):
|
if isinstance(str_exc, str):
|
||||||
if each_error_string in str_exc:
|
if each_error_string in str_exc:
|
||||||
print('quit bot by error:', each_error_string)
|
print('quit bot by error:', each_error_string)
|
||||||
|
is_quit_bot = True
|
||||||
driver.quit()
|
driver.quit()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
break
|
|
||||||
|
|
||||||
# not is above case, print exception.
|
# not is above case, print exception.
|
||||||
print("Exception:", str_exc)
|
print("Exception:", str_exc)
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
return url, is_quit_bot
|
||||||
|
|
||||||
|
def main(args):
|
||||||
|
config_dict = get_config_dict(args)
|
||||||
|
|
||||||
|
driver = None
|
||||||
|
if not config_dict is None:
|
||||||
|
for i in range(3):
|
||||||
|
driver = get_driver_by_config(config_dict)
|
||||||
|
if not driver is None:
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
time.sleep(0.05)
|
||||||
|
else:
|
||||||
|
print("Load config error!")
|
||||||
|
|
||||||
|
# internal variable. 說明:這是一個內部變數,請略過。
|
||||||
|
url = ""
|
||||||
|
last_url = ""
|
||||||
|
|
||||||
|
# for tixcraft
|
||||||
|
tixcraft_dict = {}
|
||||||
|
tixcraft_dict["fail_list"]=[]
|
||||||
|
tixcraft_dict["fail_promo_list"]=[]
|
||||||
|
tixcraft_dict["is_popup_checkout"] = False
|
||||||
|
|
||||||
|
# for kktix
|
||||||
|
kktix_dict = {}
|
||||||
|
kktix_dict["fail_list"]=[]
|
||||||
|
kktix_dict["captcha_sound_played"] = False
|
||||||
|
kktix_dict["kktix_register_status_last"] = None
|
||||||
|
kktix_dict["is_popup_checkout"] = False
|
||||||
|
|
||||||
|
ibon_dict = {}
|
||||||
|
ibon_dict["fail_list"]=[]
|
||||||
|
|
||||||
|
hkticketing_dict = {}
|
||||||
|
hkticketing_dict["is_date_submiting"] = False
|
||||||
|
hkticketing_dict["fail_list"]=[]
|
||||||
|
|
||||||
|
ocr = None
|
||||||
|
Captcha_Browser = None
|
||||||
|
try:
|
||||||
|
if config_dict["ocr_captcha"]["enable"]:
|
||||||
|
ocr = ddddocr.DdddOcr(show_ad=False, beta=config_dict["ocr_captcha"]["beta"])
|
||||||
|
Captcha_Browser = NonBrowser()
|
||||||
|
|
||||||
|
if len(config_dict["advanced"]["tixcraft_sid"]) > 1:
|
||||||
|
set_non_browser_cookies(driver, config_dict["homepage"], Captcha_Browser)
|
||||||
|
except Exception as exc:
|
||||||
|
print(exc)
|
||||||
|
pass
|
||||||
|
|
||||||
|
while True:
|
||||||
|
time.sleep(0.05)
|
||||||
|
|
||||||
|
is_alert_popup = False
|
||||||
|
|
||||||
|
# pass if driver not loaded.
|
||||||
|
if driver is None:
|
||||||
|
print("web driver not accessible!")
|
||||||
|
break
|
||||||
|
|
||||||
|
#is_alert_popup = check_pop_alert(driver)
|
||||||
|
|
||||||
|
#MUST "do nothing: if alert popup.
|
||||||
|
#print("is_alert_popup:", is_alert_popup)
|
||||||
|
if is_alert_popup:
|
||||||
|
continue
|
||||||
|
|
||||||
|
url, is_quit_bot = get_current_url(driver)
|
||||||
|
if is_quit_bot:
|
||||||
|
break
|
||||||
|
|
||||||
if url is None:
|
if url is None:
|
||||||
continue
|
continue
|
||||||
else:
|
else:
|
||||||
|
|
Loading…
Reference in New Issue