forked from wvlover15/wv_downloader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqueue_chrome_request.py
127 lines (110 loc) · 4.65 KB
/
queue_chrome_request.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# -*- coding: utf-8 -*-
#########################################################
# python
import os, sys, traceback, re, json, threading, time, shutil
from datetime import datetime
# third-party
import requests
# third-party
from flask import request, render_template, jsonify, redirect
# sjva 공용
from framework import db, scheduler, path_data, socketio, SystemModelSetting, app, celery, Util, py_queue, py_urllib
# 패키지
from .plugin import P
logger = P.logger
package_name = P.package_name
ModelSetting = P.ModelSetting
from .model import ModelWVDItem
#########################################################
# 서버에 요청하는 큐
class QueueChromeRequest(object):
def __init__(self, module):
self.module = module
self.queue = py_queue.Queue()
self.queue_wait_thread = threading.Thread(target=self.queue_wait_thread_function, args=())
self.queue_wait_thread.daemon = True
self.queue_wait_thread.start()
self.enqueue_thread = None
def queue_wait_thread_function(self):
while True:
try:
logger.debug('!!!!!!!!!!!!!!!!!!!!!!!!QueueChromeRequest wait..')
db_id = self.queue.get()
self.process_chrome_request(db_id)
time.sleep(2)
self.queue.task_done()
time.sleep(60)
except Exception as e:
logger.error('Exception:%s', e)
logger.error(traceback.format_exc())
def process_chrome_request(self, db_id):
db_item = ModelWVDItem.get_by_id(db_id)
#logger.debug('process_chrome_request : %s', db_item)
ret = self.send_url(db_item.site, db_item.url, db_item.code)
logger.warning(f"send url ret : {ret}")
if ret['ret'] == 'success':
db_item.status = 'send_url_success'
db_item.save()
else:
self.queue.put(db_item.id)
# 테스트로 호출 될 수 있음.
def send_url(self, site, url, code):
logger.warning('QueueChromeRequest %s', url)
for i in range(5):
try:
server_url = f"{ModelSetting.get('client_server_ddns')}/{package_name}/api/server/start"
logger.debug(server_url)
data={'apikey':ModelSetting.get('client_server_apikey'), 'url':url, 'client_ddns':SystemModelSetting.get('ddns'), 'site':site, 'code':code}
return requests.post(server_url, data=data).json()
except Exception as e:
P.logger.error('Exception:%s', e)
P.logger.error(traceback.format_exc())
ret = {'ret':'warning', 'msg': str(e)}
time.sleep(10)
return ret
def enqueue(self):
queue_list = list(self.queue.queue)
for db_item in ModelWVDItem.get_items_by_status('ready'):
already_exist = False
for queue_id in queue_list:
if queue_id == db_item.id:
already_exist = True
break
if already_exist == False:
self.queue.put(db_item.id)
def enqueue_one(self,):
queue_list = list(self.queue.queue)
for db_item in ModelWVDItem.get_items_by_status('ready'):
already_exist = False
for queue_id in queue_list:
if queue_id == db_item.id:
already_exist = True
break
if already_exist == False:
self.queue.put(db_item.id)
def add_request_url(self, url, memo):
db_item = ModelWVDItem()
db_item.url = url
db_item.memo = memo
for site in self.module.queue_download.site_list:
logger.debug(url)
logger.debug(site.url_regex)
match = site.url_regex.search(url)
if match:
db_item.site = site.name
db_item.code = match.group('code')
logger.warning(site)
db_item.url = site.get_request_url(url)
break
logger.warning('site:[%s] code:[%s]', db_item.site, db_item.code)
if db_item.site is not None:
tmp = ModelWVDItem.get_item_by_site_and_code(db_item.site, db_item.code)
if tmp is None:
db_item.save()
ret = {'ret':'success', 'msg':u'URL을 추가하였습니다.'}
self.queue.put(db_item.id)
else:
ret = {'ret':'warning', 'msg':u'이미 같은 코드가 목록에 있습니다.', 'db':'exist', 'status':tmp.status}
else:
ret = {'ret':'warning', 'msg':u'처리할 수 없는 URL입니다.'}
return ret