extension add heart beat, allow auto reload for non-chrome browser on kktix.
parent
fcd6ca1beb
commit
9f8b92f232
|
@ -54,7 +54,7 @@ import webbrowser
|
||||||
|
|
||||||
import chromedriver_autoinstaller
|
import chromedriver_autoinstaller
|
||||||
|
|
||||||
CONST_APP_VERSION = "MaxBot (2023.12.21)"
|
CONST_APP_VERSION = "MaxBot (2023.12.22)"
|
||||||
|
|
||||||
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"
|
||||||
|
@ -2657,7 +2657,7 @@ def tixcraft_ticket_agree(driver, config_dict):
|
||||||
|
|
||||||
return is_finish_checkbox_click
|
return is_finish_checkbox_click
|
||||||
|
|
||||||
def tixcraft_ticket_number_auto_fill(driver, select_obj, ticket_number):
|
def ticket_number_select_fill(driver, select_obj, ticket_number):
|
||||||
is_ticket_number_assigned = False
|
is_ticket_number_assigned = False
|
||||||
if not select_obj is None:
|
if not select_obj is None:
|
||||||
try:
|
try:
|
||||||
|
@ -3387,20 +3387,23 @@ def tixcraft_assign_ticket_number(driver, config_dict):
|
||||||
if row_text.isnumeric():
|
if row_text.isnumeric():
|
||||||
# ticket assign.
|
# ticket assign.
|
||||||
is_ticket_number_assigned = True
|
is_ticket_number_assigned = True
|
||||||
return is_ticket_number_assigned
|
|
||||||
|
return is_ticket_number_assigned, select_obj
|
||||||
|
|
||||||
|
|
||||||
def tixcraft_ticket_main(driver, config_dict, ocr, Captcha_Browser, domain_name):
|
def tixcraft_ticket_main(driver, config_dict, ocr, Captcha_Browser, domain_name):
|
||||||
# use extension instead of selenium.
|
# use extension instead of selenium.
|
||||||
#tixcraft_ticket_main_agree(driver, config_dict)
|
#tixcraft_ticket_main_agree(driver, config_dict)
|
||||||
|
|
||||||
|
is_ticket_number_assigned = False
|
||||||
|
|
||||||
is_ticket_number_assigned = tixcraft_assign_ticket_number(driver, config_dict)
|
# PS: some events on tixcraft have multi <select>.
|
||||||
|
is_ticket_number_assigned, select_obj = tixcraft_assign_ticket_number(driver, config_dict)
|
||||||
|
|
||||||
if not is_ticket_number_assigned:
|
if not is_ticket_number_assigned:
|
||||||
# should not enter this block, due to extension done.
|
# should not enter this block, due to extension done.
|
||||||
ticket_number = str(config_dict["ticket_number"])
|
ticket_number = str(config_dict["ticket_number"])
|
||||||
is_ticket_number_assigned = tixcraft_ticket_number_auto_fill(driver, select_obj, ticket_number)
|
is_ticket_number_assigned = ticket_number_select_fill(driver, select_obj, ticket_number)
|
||||||
|
|
||||||
# must wait ticket number assign to focus captcha.
|
# must wait ticket number assign to focus captcha.
|
||||||
if is_ticket_number_assigned:
|
if is_ticket_number_assigned:
|
||||||
|
@ -4598,11 +4601,114 @@ def kktix_reg_new_main(driver, config_dict, fail_list, captcha_sound_played, is_
|
||||||
|
|
||||||
return fail_list, captcha_sound_played
|
return fail_list, captcha_sound_played
|
||||||
|
|
||||||
|
def kktix_get_registerStatus(driver, event_code):
|
||||||
|
html_result = None
|
||||||
|
|
||||||
|
url = "https://kktix.com/g/events/%s/register_info" % (event_code)
|
||||||
|
#print('event_code:',event_code)
|
||||||
|
#print("url:", url)
|
||||||
|
|
||||||
|
headers = {"Accept-Language": "zh-TW,zh;q=0.5", 'User-Agent': USER_AGENT}
|
||||||
|
try:
|
||||||
|
html_result = requests.get(url , headers=headers, timeout=0.7, allow_redirects=False)
|
||||||
|
except Exception as exc:
|
||||||
|
html_result = None
|
||||||
|
print("send reg_info request fail:")
|
||||||
|
print(exc)
|
||||||
|
|
||||||
|
registerStatus = None
|
||||||
|
if not html_result is None:
|
||||||
|
status_code = html_result.status_code
|
||||||
|
#print("status_code:",status_code)
|
||||||
|
if status_code == 200:
|
||||||
|
html_text = html_result.text
|
||||||
|
#print("html_text:", html_text)
|
||||||
|
try:
|
||||||
|
jsLoads = json.loads(html_text)
|
||||||
|
if 'inventory' in jsLoads:
|
||||||
|
if 'registerStatus' in jsLoads['inventory']:
|
||||||
|
registerStatus = jsLoads['inventory']['registerStatus']
|
||||||
|
except Exception as exc:
|
||||||
|
print("load reg_info json fail:")
|
||||||
|
print(exc)
|
||||||
|
pass
|
||||||
|
|
||||||
|
#print("registerStatus:", registerStatus)
|
||||||
|
return registerStatus
|
||||||
|
|
||||||
|
def kktix_check_register_status(driver, url):
|
||||||
|
#ex: https://xxx.kktix.cc/events/xxx
|
||||||
|
prefix_list = ['.com/events/','.cc/events/']
|
||||||
|
postfix = '/registrations/new'
|
||||||
|
|
||||||
|
is_match_event_code = False
|
||||||
|
event_code = ""
|
||||||
|
for prefix in prefix_list:
|
||||||
|
event_code = find_between(url,prefix,postfix)
|
||||||
|
if len(event_code) > 0:
|
||||||
|
is_match_event_code = True
|
||||||
|
#print('event_code:',event_code)
|
||||||
|
break
|
||||||
|
|
||||||
|
if is_match_event_code:
|
||||||
|
js = '''
|
||||||
|
function load_kktix_register_code(){
|
||||||
|
let api_url = "https://kktix.com/g/events/%s/register_info";
|
||||||
|
fetch(api_url).then(function (response)
|
||||||
|
{
|
||||||
|
return response.json();
|
||||||
|
}
|
||||||
|
).then(function (data)
|
||||||
|
{
|
||||||
|
let reload=false;
|
||||||
|
console.log(data.inventory.registerStatus);
|
||||||
|
if(data.inventory.registerStatus=='OUT_OF_STOCK') {reload=true;}
|
||||||
|
if(data.inventory.registerStatus=='COMING_SOON') {reload=true;}
|
||||||
|
console.log(reload);
|
||||||
|
if(reload) {location.reload();}
|
||||||
|
}
|
||||||
|
).catch(function (err)
|
||||||
|
{
|
||||||
|
console.log(err);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (!$.kkUser) {
|
||||||
|
$.kkUser = {};
|
||||||
|
}
|
||||||
|
if (typeof $.kkUser.checked_status_register_code === 'undefined') {
|
||||||
|
$.kkUser.checked_status_register_code = true;
|
||||||
|
load_kktix_register_code();
|
||||||
|
}
|
||||||
|
''' % (event_code)
|
||||||
|
try:
|
||||||
|
driver.execute_script(js)
|
||||||
|
except Exception as exc:
|
||||||
|
pass
|
||||||
|
|
||||||
|
# use javascritp version only.
|
||||||
|
is_match_event_code = False
|
||||||
|
|
||||||
|
registerStatus = None
|
||||||
|
if is_match_event_code:
|
||||||
|
registerStatus = kktix_get_registerStatus(driver, event_code)
|
||||||
|
return registerStatus
|
||||||
|
|
||||||
def kktix_reg_auto_reload(driver, url, config_dict, kktix_register_status_last):
|
def kktix_reg_auto_reload(driver, url, config_dict, kktix_register_status_last):
|
||||||
registerStatus = kktix_register_status_last
|
registerStatus = kktix_register_status_last
|
||||||
|
|
||||||
# auto reload javascrit code at extension.
|
# auto reload javascrit code at chrome extension.
|
||||||
is_need_refresh = False
|
is_need_refresh = False
|
||||||
|
if config_dict["browser"] in ["firefox", "edge", "safari"]:
|
||||||
|
if not is_need_refresh:
|
||||||
|
if registerStatus is None:
|
||||||
|
# current version, change refresh event from selenium to javascript.
|
||||||
|
registerStatus = kktix_check_register_status(driver, url)
|
||||||
|
# for request solution, refresh on selenium.
|
||||||
|
if not registerStatus is None:
|
||||||
|
print("registerStatus:", registerStatus)
|
||||||
|
# OUT_OF_STOCK
|
||||||
|
if registerStatus != 'IN_STOCK':
|
||||||
|
is_need_refresh = True
|
||||||
|
|
||||||
is_finish_checkbox_click = False
|
is_finish_checkbox_click = False
|
||||||
if not is_need_refresh:
|
if not is_need_refresh:
|
||||||
|
@ -6210,7 +6316,7 @@ def assign_ticket_number_by_select(driver, config_dict, by_method, selector_stri
|
||||||
is_ticket_number_assigned = True
|
is_ticket_number_assigned = True
|
||||||
|
|
||||||
if not is_ticket_number_assigned:
|
if not is_ticket_number_assigned:
|
||||||
is_ticket_number_assigned = tixcraft_ticket_number_auto_fill(driver, select_obj, ticket_number)
|
is_ticket_number_assigned = ticket_number_select_fill(driver, select_obj, ticket_number)
|
||||||
else:
|
else:
|
||||||
if show_debug_message:
|
if show_debug_message:
|
||||||
print("ticket_number assigned by previous action.")
|
print("ticket_number assigned by previous action.")
|
||||||
|
@ -7443,7 +7549,7 @@ def ticketmaster_assign_ticket_number(driver, config_dict):
|
||||||
# must wait select object ready to assign ticket number.
|
# must wait select object ready to assign ticket number.
|
||||||
if not is_ticket_number_assigned:
|
if not is_ticket_number_assigned:
|
||||||
ticket_number = str(config_dict["ticket_number"])
|
ticket_number = str(config_dict["ticket_number"])
|
||||||
is_ticket_number_assigned = tixcraft_ticket_number_auto_fill(driver, select_obj, ticket_number)
|
is_ticket_number_assigned = ticket_number_select_fill(driver, select_obj, ticket_number)
|
||||||
|
|
||||||
# must wait ticket number assign to focus captcha.
|
# must wait ticket number assign to focus captcha.
|
||||||
if is_ticket_number_assigned:
|
if is_ticket_number_assigned:
|
||||||
|
|
|
@ -22,7 +22,7 @@ import sys
|
||||||
import threading
|
import threading
|
||||||
import webbrowser
|
import webbrowser
|
||||||
|
|
||||||
CONST_APP_VERSION = "MaxBot (2023.12.21)"
|
CONST_APP_VERSION = "MaxBot (2023.12.22)"
|
||||||
|
|
||||||
CONST_MAXBOT_LAUNCHER_FILE = "config_launcher.json"
|
CONST_MAXBOT_LAUNCHER_FILE = "config_launcher.json"
|
||||||
CONST_MAXBOT_CONFIG_FILE = "settings.json"
|
CONST_MAXBOT_CONFIG_FILE = "settings.json"
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
{"homepage": "https://tixcraft.com", "browser": "chrome", "language": "\u7e41\u9ad4\u4e2d\u6587", "ticket_number": 2, "ocr_captcha": {"enable": true, "beta": true, "force_submit": true, "image_source": "canvas"}, "webdriver_type": "undetected_chromedriver", "kktix": {"auto_press_next_step_button": true, "auto_fill_ticket_number": true}, "tixcraft": {"date_auto_select": {"enable": true, "date_keyword": "", "mode": "random"}, "pass_date_is_sold_out": true, "auto_reload_coming_soon_page": true}, "area_auto_select": {"enable": true, "mode": "random", "area_keyword": ""}, "keyword_exclude": "\"\u8f2a\u6905\",\"\u8eab\u969c\",\"\u8eab\u5fc3 \u969c\u7919\",\"Restricted View\",\"\u71c8\u67f1\u906e\u853d\",\"\u8996\u7dda\u4e0d\u5b8c\u6574\"", "advanced": {"play_captcha_sound": {"enable": true, "filename": "ding-dong.wav"}, "tixcraft_sid": "", "ibonqware": "", "facebook_account": "", "kktix_account": "", "fami_account": "", "cityline_account": "", "urbtix_account": "", "hkticketing_account": "", "kham_account": "", "ticket_account": "", "udn_account": "", "ticketplus_account": "", "facebook_password": "", "kktix_password": "", "fami_password": "", "urbtix_password": "", "cityline_password": "", "hkticketing_password": "", "kham_password": "", "ticket_password": "", "udn_password": "", "ticketplus_password": "", "adblock_plus_enable": false, "disable_adjacent_seat": false, "hide_some_image": true, "block_facebook_network": false, "headless": false, "verbose": true, "auto_guess_options": true, "user_guess_string": "", "online_dictionary_url": "", "auto_reload_page_interval": 1.0, "auto_reload_random_delay": false, "proxy_server_port": ""}}
|
{"homepage": "https://tixcraft.com", "browser": "chrome", "language": "\u7e41\u9ad4\u4e2d\u6587", "ticket_number": 2, "ocr_captcha": {"enable": true, "beta": true, "force_submit": true, "image_source": "canvas"}, "webdriver_type": "undetected_chromedriver", "kktix": {"auto_press_next_step_button": true, "auto_fill_ticket_number": true}, "tixcraft": {"date_auto_select": {"enable": true, "date_keyword": "", "mode": "random"}, "pass_date_is_sold_out": true, "auto_reload_coming_soon_page": true}, "area_auto_select": {"enable": true, "mode": "random", "area_keyword": ""}, "keyword_exclude": "\"\u8f2a\u6905\",\"\u8eab\u969c\",\"\u8eab\u5fc3 \u969c\u7919\",\"Restricted View\",\"\u71c8\u67f1\u906e\u853d\",\"\u8996\u7dda\u4e0d\u5b8c\u6574\"", "advanced": {"play_captcha_sound": {"enable": true, "filename": "ding-dong.wav"}, "tixcraft_sid": "", "ibonqware": "", "facebook_account": "", "kktix_account": "", "fami_account": "", "cityline_account": "", "urbtix_account": "", "hkticketing_account": "", "kham_account": "", "ticket_account": "", "udn_account": "", "ticketplus_account": "", "facebook_password": "", "kktix_password": "", "fami_password": "", "urbtix_password": "", "cityline_password": "", "hkticketing_password": "", "kham_password": "", "ticket_password": "", "udn_password": "", "ticketplus_password": "", "adblock_plus_enable": false, "disable_adjacent_seat": false, "hide_some_image": true, "block_facebook_network": false, "headless": false, "verbose": false, "auto_guess_options": true, "user_guess_string": "", "online_dictionary_url": "", "auto_reload_page_interval": 1.0, "auto_reload_random_delay": false, "proxy_server_port": ""}}
|
|
@ -34,7 +34,7 @@ import ssl
|
||||||
|
|
||||||
ssl._create_default_https_context = ssl._create_unverified_context
|
ssl._create_default_https_context = ssl._create_unverified_context
|
||||||
|
|
||||||
CONST_APP_VERSION = "MaxBot (2023.12.21)"
|
CONST_APP_VERSION = "MaxBot (2023.12.22)"
|
||||||
|
|
||||||
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"
|
||||||
|
|
|
@ -27,7 +27,7 @@ import pyperclip
|
||||||
import tornado
|
import tornado
|
||||||
from tornado.web import Application
|
from tornado.web import Application
|
||||||
|
|
||||||
CONST_APP_VERSION = "MaxBot (2023.12.21)"
|
CONST_APP_VERSION = "MaxBot (2023.12.22)"
|
||||||
|
|
||||||
CONST_MAXBOT_QUESTION_FILE = "MAXBOT_QUESTION.txt"
|
CONST_MAXBOT_QUESTION_FILE = "MAXBOT_QUESTION.txt"
|
||||||
|
|
||||||
|
|
|
@ -6,29 +6,32 @@
|
||||||
|
|
||||||
const storage = chrome.storage.local;
|
const storage = chrome.storage.local;
|
||||||
|
|
||||||
chrome.declarativeNetRequest.onRuleMatchedDebug.addListener((e) => {
|
|
||||||
const msg = `Navigation blocked to ${e.request.url} on tab ${e.request.tabId}.`;
|
|
||||||
//console.log(msg);
|
|
||||||
});
|
|
||||||
|
|
||||||
chrome.runtime.onInstalled.addListener(function(){
|
chrome.runtime.onInstalled.addListener(function(){
|
||||||
|
console.log("onInstalled");
|
||||||
|
|
||||||
|
let default_status='ON';
|
||||||
|
chrome.action.setBadgeText({
|
||||||
|
text: default_status
|
||||||
|
});
|
||||||
|
|
||||||
fetch("data/settings.json")
|
fetch("data/settings.json")
|
||||||
.then((resp) => resp.json())
|
.then((resp) => resp.json())
|
||||||
.then((settings) =>
|
.then((settings) =>
|
||||||
{
|
{
|
||||||
chrome.storage.local.set(
|
chrome.storage.local.set(
|
||||||
{
|
{
|
||||||
settings: settings
|
settings: settings,
|
||||||
|
status: default_status
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
console.log("dump settings.json to storage");
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
});
|
||||||
|
|
||||||
let default_status='ON';
|
chrome.declarativeNetRequest.onRuleMatchedDebug.addListener((e) => {
|
||||||
chrome.action.setBadgeText({
|
const msg = `Navigation blocked to ${e.request.url} on tab ${e.request.tabId}.`;
|
||||||
text: default_status
|
//console.log(msg);
|
||||||
});
|
|
||||||
storage.set({status: default_status});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
chrome.action.onClicked.addListener(async (tab) => {
|
chrome.action.onClicked.addListener(async (tab) => {
|
||||||
|
@ -43,3 +46,38 @@ chrome.action.onClicked.addListener(async (tab) => {
|
||||||
text: nextState
|
text: nextState
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
import heartbeatconnect from './modules/heartbeatconnect.js';
|
||||||
|
|
||||||
|
let heartbeatInterval;
|
||||||
|
|
||||||
|
async function runHeartbeat()
|
||||||
|
{
|
||||||
|
//console.log("runHeartbeat");
|
||||||
|
storage.get('status', function (items)
|
||||||
|
{
|
||||||
|
console.log(items);
|
||||||
|
if (items.status && items.status=='ON')
|
||||||
|
{
|
||||||
|
heartbeatconnect.start();
|
||||||
|
} else {
|
||||||
|
console.log('no status found');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async function startHeartbeat()
|
||||||
|
{
|
||||||
|
runHeartbeat().then(() =>
|
||||||
|
{
|
||||||
|
heartbeatInterval = setInterval(runHeartbeat, 1 * 1000);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
async function stopHeartbeat()
|
||||||
|
{
|
||||||
|
clearInterval(heartbeatInterval);
|
||||||
|
}
|
||||||
|
|
||||||
|
startHeartbeat();
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
{"homepage": "https://tixcraft.com", "browser": "chrome", "language": "\u7e41\u9ad4\u4e2d\u6587", "ticket_number": 2, "ocr_captcha": {"enable": true, "beta": true, "force_submit": true, "image_source": "canvas"}, "webdriver_type": "undetected_chromedriver", "kktix": {"auto_press_next_step_button": true, "auto_fill_ticket_number": true}, "tixcraft": {"date_auto_select": {"enable": true, "date_keyword": "", "mode": "random"}, "pass_date_is_sold_out": true, "auto_reload_coming_soon_page": true}, "area_auto_select": {"enable": true, "mode": "random", "area_keyword": ""}, "keyword_exclude": "\"\u8f2a\u6905\",\"\u8eab\u969c\",\"\u8eab\u5fc3 \u969c\u7919\",\"Restricted View\",\"\u71c8\u67f1\u906e\u853d\",\"\u8996\u7dda\u4e0d\u5b8c\u6574\"", "advanced": {"play_captcha_sound": {"enable": true, "filename": "ding-dong.wav"}, "tixcraft_sid": "", "ibonqware": "", "facebook_account": "", "kktix_account": "", "fami_account": "", "cityline_account": "", "urbtix_account": "", "hkticketing_account": "", "kham_account": "", "ticket_account": "", "udn_account": "", "ticketplus_account": "", "facebook_password": "", "kktix_password": "", "fami_password": "", "urbtix_password": "", "cityline_password": "", "hkticketing_password": "", "kham_password": "", "ticket_password": "", "udn_password": "", "ticketplus_password": "", "adblock_plus_enable": false, "disable_adjacent_seat": false, "hide_some_image": true, "block_facebook_network": false, "headless": false, "verbose": true, "auto_guess_options": true, "user_guess_string": "", "online_dictionary_url": "", "auto_reload_page_interval": 1.0, "auto_reload_random_delay": false, "proxy_server_port": ""}}
|
{"homepage": "https://kktix.com", "browser": "chrome", "language": "\u7e41\u9ad4\u4e2d\u6587", "ticket_number": 2, "ocr_captcha": {"enable": true, "beta": true, "force_submit": true, "image_source": "canvas"}, "webdriver_type": "undetected_chromedriver", "kktix": {"auto_press_next_step_button": true, "auto_fill_ticket_number": true}, "tixcraft": {"date_auto_select": {"enable": true, "date_keyword": "", "mode": "random"}, "pass_date_is_sold_out": true, "auto_reload_coming_soon_page": true}, "area_auto_select": {"enable": true, "mode": "random", "area_keyword": ""}, "keyword_exclude": "\"\u8f2a\u6905\",\"\u8eab\u969c\",\"\u8eab\u5fc3 \u969c\u7919\",\"Restricted View\",\"\u71c8\u67f1\u906e\u853d\",\"\u8996\u7dda\u4e0d\u5b8c\u6574\"", "advanced": {"play_captcha_sound": {"enable": true, "filename": "ding-dong.wav"}, "tixcraft_sid": "", "ibonqware": "", "facebook_account": "", "kktix_account": "", "fami_account": "", "cityline_account": "", "urbtix_account": "", "hkticketing_account": "", "kham_account": "", "ticket_account": "", "udn_account": "", "ticketplus_account": "", "facebook_password": "", "kktix_password": "", "fami_password": "", "urbtix_password": "", "cityline_password": "", "hkticketing_password": "", "kham_password": "", "ticket_password": "", "udn_password": "", "ticketplus_password": "", "adblock_plus_enable": false, "disable_adjacent_seat": false, "hide_some_image": true, "block_facebook_network": false, "headless": false, "verbose": true, "auto_guess_options": true, "user_guess_string": "", "online_dictionary_url": "", "auto_reload_page_interval": 1.0, "auto_reload_random_delay": false, "proxy_server_port": ""}}
|
|
@ -11,7 +11,8 @@
|
||||||
},
|
},
|
||||||
"manifest_version": 3,
|
"manifest_version": 3,
|
||||||
"background": {
|
"background": {
|
||||||
"service_worker": "background.js"
|
"service_worker": "background.js",
|
||||||
|
"type": "module"
|
||||||
},
|
},
|
||||||
"declarative_net_request": {
|
"declarative_net_request": {
|
||||||
"rule_resources": [
|
"rule_resources": [
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
const storage = chrome.storage.local;
|
||||||
|
var settings=null;
|
||||||
|
const https_url="https://";
|
||||||
|
const http_url="https://";
|
||||||
|
|
||||||
|
class HeartBeatConnector
|
||||||
|
{
|
||||||
|
constructor() {}
|
||||||
|
|
||||||
|
start() {
|
||||||
|
//console.log("start heart beat connector");
|
||||||
|
//load_font.loadFont();
|
||||||
|
|
||||||
|
// Query the active tab before injecting the content script
|
||||||
|
chrome.tabs.query(
|
||||||
|
{
|
||||||
|
active: true,
|
||||||
|
status: "complete",
|
||||||
|
currentWindow: true
|
||||||
|
}, (tabs) =>
|
||||||
|
{
|
||||||
|
if(tabs && tabs.length) {
|
||||||
|
//console.log(tabs);
|
||||||
|
//console.log(tabs[0]);
|
||||||
|
if (tabs[0].url.startsWith(https_url) || tabs[0].url.startsWith(http_url)) {
|
||||||
|
// Use the Scripting API to execute a script
|
||||||
|
chrome.scripting.executeScript(
|
||||||
|
{
|
||||||
|
target:
|
||||||
|
{
|
||||||
|
tabId: tabs[0].id
|
||||||
|
},
|
||||||
|
func: ack
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function ack() {
|
||||||
|
//console.log("act");
|
||||||
|
}
|
||||||
|
|
||||||
|
export default new HeartBeatConnector();
|
Loading…
Reference in New Issue