update for ticket-plus.

master
Max 2023-12-13 18:26:22 +08:00 committed by GitHub
parent e9f1ae4931
commit f4b3a26ed1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 52 additions and 26 deletions

View File

@ -55,7 +55,7 @@ import webbrowser
import chromedriver_autoinstaller import chromedriver_autoinstaller
CONST_APP_VERSION = "MaxBot (2023.12.05)" CONST_APP_VERSION = "MaxBot (2023.12.06)"
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"
@ -400,6 +400,8 @@ def get_chrome_options(webdriver_path, config_dict):
if browser=="safari": if browser=="safari":
chrome_options = webdriver.SafariOptions() chrome_options = webdriver.SafariOptions()
chrome_options.set_capability("goog:loggingPrefs",{"performance": "ALL"})
# some windows cause: timed out receiving message from renderer # some windows cause: timed out receiving message from renderer
if config_dict["advanced"]["adblock_plus_enable"]: if config_dict["advanced"]["adblock_plus_enable"]:
# PS: this is ocx version. # PS: this is ocx version.
@ -550,9 +552,10 @@ def get_uc_options(uc, config_dict, webdriver_path):
options.page_load_strategy = 'eager' options.page_load_strategy = 'eager'
#options.page_load_strategy = 'none' #options.page_load_strategy = 'none'
options.unhandled_prompt_behavior = "accept" options.unhandled_prompt_behavior = "accept"
#print("strategy", options.page_load_strategy) #print("strategy", options.page_load_strategy)
options.set_capability("goog:loggingPrefs",{"performance": "ALL"})
if config_dict["advanced"]["adblock_plus_enable"]: if config_dict["advanced"]["adblock_plus_enable"]:
load_extension_path = "" load_extension_path = ""
extension_list = get_favoriate_extension_path(webdriver_path) extension_list = get_favoriate_extension_path(webdriver_path)
@ -836,7 +839,7 @@ def get_driver_by_config(config_dict):
,'*syndication.twitter.com/*' ,'*syndication.twitter.com/*'
,'*youtube.com/*' ,'*youtube.com/*'
,'*player.youku.*' ,'*player.youku.*'
,'*h.clarity.ms/*' ,'*.clarity.ms/*'
,'*img.uniicreative.com/*' ,'*img.uniicreative.com/*'
,'*e2elog.fetnet.net*'] ,'*e2elog.fetnet.net*']
@ -850,7 +853,9 @@ def get_driver_by_config(config_dict):
NETWORK_BLOCKED_URLS.append('*static.tixcraft.com/images/activity/*') NETWORK_BLOCKED_URLS.append('*static.tixcraft.com/images/activity/*')
NETWORK_BLOCKED_URLS.append('*static.ticketmaster.sg/images/activity/*') NETWORK_BLOCKED_URLS.append('*static.ticketmaster.sg/images/activity/*')
NETWORK_BLOCKED_URLS.append('*static.ticketmaster.com/images/activity/*') NETWORK_BLOCKED_URLS.append('*static.ticketmaster.com/images/activity/*')
NETWORK_BLOCKED_URLS.append('*azureedge.net/QWARE_TICKET//images/*') NETWORK_BLOCKED_URLS.append('*ticketimg2.azureedge.net/image/ActivityImage/ActivityImage_*')
NETWORK_BLOCKED_URLS.append('*.azureedge.net/QWARE_TICKET//images/*')
NETWORK_BLOCKED_URLS.append('*static.ticketplus.com.tw/event/*')
if config_dict["advanced"]["block_facebook_network"]: if config_dict["advanced"]["block_facebook_network"]:
NETWORK_BLOCKED_URLS.append('*facebook.com/*') NETWORK_BLOCKED_URLS.append('*facebook.com/*')
@ -11310,22 +11315,50 @@ def ticketplus_order_exclusive_code(driver, config_dict, fail_list):
return is_answer_sent, fail_list, is_question_popup return is_answer_sent, fail_list, is_question_popup
def ticketplus_order_check_coming_soon(driver): def ticketplus_order_auto_reload_coming_soon(driver):
is_onsale=True is_vue_ready = False
current_layout_style = 0
try: try:
my_css_selector = "div.order-content" getSeatsByTicketAreaIdUrl = ""
div_element = driver.find_element(By.CSS_SELECTOR, my_css_selector) #r = driver.execute_script("return window.performance.getEntries();")
if not div_element is None: logs = driver.get_log("performance")
div_html = div_element.get_attribute('innerHTML') url_list = []
#print("div_html:", div_html) for log in logs:
if '<div class="text-nine">開賣時間</div>' in div_html: network_log = json.loads(log["message"])["message"]
is_onsale=False if ("Network.response" in network_log["method"]
except Exception as exc: or "Network.request" in network_log["method"]
print(exc) or "Network.webSocket" in network_log["method"]):
if 'request' in network_log["params"]:
if 'url' in network_log["params"]["request"]:
if 'apis.ticketplus.com.tw/config/api/' in network_log["params"]["request"]["url"]:
print("url:", network_log["params"]["request"]["url"])
if 'get?ticketAreaId=' in network_log["params"]["request"]["url"]:
getSeatsByTicketAreaIdUrl = network_log["params"]["request"]["url"]
is_vue_ready = True
break
if is_vue_ready:
js = """var t = JSON.parse(Cookies.get("user")) ? JSON.parse(Cookies.get("user")).access_token : "";
fetch("%s",{headers: {
authorization: "Bearer ".concat(t)
}}).then(function (response) {
return response.json();
}).then(function (data) {
console.log(data);
if(data.result.product.length>0)
if(data.result.product[0].status=="pending") {
location.reload();
}
}).catch(function (err){
console.log(err);
});
""" % getSeatsByTicketAreaIdUrl
driver.set_script_timeout(0.1)
driver.execute_async_script(js)
except Exception as exc:
#print(exc)
pass
return is_onsale
def ticketplus_order(driver, config_dict, ocr, Captcha_Browser, ticketplus_dict): def ticketplus_order(driver, config_dict, ocr, Captcha_Browser, ticketplus_dict):
show_debug_message = True # debug. show_debug_message = True # debug.
@ -11872,15 +11905,8 @@ def ticketplus_main(driver, url, config_dict, ocr, Captcha_Browser, ticketplus_d
is_button_pressed = ticketplus_accept_realname_card(driver) is_button_pressed = ticketplus_accept_realname_card(driver)
is_button_pressed = ticketplus_accept_order_fail(driver) is_button_pressed = ticketplus_accept_order_fail(driver)
is_onsale = ticketplus_order_check_coming_soon(driver) ticketplus_order_auto_reload_coming_soon(driver)
#print("is_onsale:", is_onsale)
if is_onsale:
is_captcha_sent, ticketplus_dict = ticketplus_order(driver, config_dict, ocr, Captcha_Browser, ticketplus_dict) is_captcha_sent, ticketplus_dict = ticketplus_order(driver, config_dict, ocr, Captcha_Browser, ticketplus_dict)
else:
try:
driver.refresh()
except Exception as exc:
print(exc)
else: else:
ticketplus_dict["fail_list"]=[] ticketplus_dict["fail_list"]=[]