use mongodb to retreive all the reserve objects
This commit is contained in:
+30
-18
@@ -19,10 +19,13 @@ SORRY_SENTENCE_EN = "we are extremely sorry that we were not able to fulfill"
|
||||
NOT_AVAILABLE_CONTENT = "For more than 130 years, our House has offered its full expertise to satisfy"
|
||||
PENDING_SENTENCE = "Ce soir, entre 20:00 et 20:30, vous obtiendrez une réponse par e-mail."
|
||||
PENDING_SENTENCE_EN = "This evening between 20:00 and 20:30 you will receive a response by email."
|
||||
# URLs to ignore during checking results
|
||||
BLANK_URL = "about:blank"
|
||||
WELCOME_URL = "https://rendezvousparis.hermes.com/client/welcome"
|
||||
|
||||
mailer = Mailer()
|
||||
|
||||
|
||||
class TlsPlaywright(threading.local):
|
||||
def __init__(self) -> None:
|
||||
self.playwright = sync_playwright().start()
|
||||
@@ -58,11 +61,9 @@ class ResultChecker:
|
||||
print(error)
|
||||
return None
|
||||
|
||||
def run(self, reserve_pojo: ReserveResultPojo, collection):
|
||||
def run(self, reserve_pojo: ReserveResultPojo, firestore_collection, need_send_email=False):
|
||||
print("Launched worker in ", threading.current_thread().name)
|
||||
url = reserve_pojo.url
|
||||
# url_to_check = url.replace("register/", "")
|
||||
# url_to_check = url + "?lang=fr"
|
||||
print("url is " + url)
|
||||
content = None
|
||||
proxy = params.get_proxy(ProxyType.NETNUT)
|
||||
@@ -90,32 +91,43 @@ class ResultChecker:
|
||||
else:
|
||||
print("status is ACCEPTED")
|
||||
status = ResultEnum.ACCEPTED
|
||||
# send email
|
||||
try:
|
||||
mailer.send_email(get_accepted_result_from(reserve_pojo))
|
||||
except Exception as err:
|
||||
print(err)
|
||||
collection.document(reserve_pojo.id).update({u'accepted': status.name})
|
||||
if need_send_email:
|
||||
# send email
|
||||
try:
|
||||
mailer.send_email(get_accepted_result_from(reserve_pojo))
|
||||
except Exception as err:
|
||||
print(err)
|
||||
firestore_collection.document(reserve_pojo.id).update({u'accepted': status.name})
|
||||
|
||||
|
||||
def check_results():
|
||||
# get the list
|
||||
params.oracle_log_sender.send_log(msg="开始检查约会结果", subject=LOG_SUBJECT_EVENT, type=TYPE_EVENT_CHECK_RESULTS)
|
||||
db_manager = params.firebase_store_manager
|
||||
# collection = db_manager.get_successful_item_for_day_by_status("2022-05-17", ResultEnum.ACCEPTED)
|
||||
collection = db_manager.get_all_successful_items()
|
||||
count = 0
|
||||
result_list = []
|
||||
for appointment in collection.stream():
|
||||
reserve_pojo = ReserveResultPojo.from_firestore_dict(appointment.to_dict())
|
||||
result_list.append(reserve_pojo)
|
||||
firestore_collection = db_manager.get_all_successful_items()
|
||||
reserve_list = params.mongo_store_manager.get_all_successful_items_for_day()
|
||||
print("size is " + str(len(reserve_list)))
|
||||
for result in reserve_list:
|
||||
print(result)
|
||||
# result_list = []
|
||||
# for appointment in collection.stream():
|
||||
# reserve_pojo = ReserveResultPojo.from_firestore_dict(appointment.to_dict())
|
||||
# result_list.append(reserve_pojo)
|
||||
|
||||
start_check(reserve_list, firestore_collection, False)
|
||||
start_check(reserve_list, firestore_collection, True)
|
||||
|
||||
|
||||
def start_check(reserve_list, firestore_collection, need_send_email: bool):
|
||||
count = 0
|
||||
with ThreadPoolExecutor(max_workers=15) as executor:
|
||||
for reserve in result_list:
|
||||
for reserve in reserve_list:
|
||||
count = count + 1
|
||||
if reserve.accepted is None or ResultEnum.ACCEPTED.value == reserve.accepted:
|
||||
if reserve.url != BLANK_URL:
|
||||
executor.submit(ResultChecker().run, reserve, collection)
|
||||
if reserve.url != WELCOME_URL:
|
||||
executor.submit(ResultChecker().run, reserve, firestore_collection,
|
||||
need_send_email)
|
||||
else:
|
||||
print("status is " + reserve.accepted)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user