feat: default values, general item excludes, images, queueManager to manage multi worker messaging to telegram to prevent too many connections
Signed-off-by: Omar Sánchez Pizarro <omar.sanchez@pistacero.net>
This commit is contained in:
@@ -1,9 +1,10 @@
|
||||
|
||||
class ItemMonitor:
|
||||
def __init__(self, search_query, latitude, longitude, max_distance,
|
||||
def __init__(self, name,search_query, latitude, longitude, max_distance,
|
||||
condition, min_price, max_price, title_exclude,
|
||||
description_exclude, title_must_include, description_must_include,
|
||||
title_first_word_exclude):
|
||||
title_first_word_exclude, check_every):
|
||||
self._name = name
|
||||
self._search_query = search_query
|
||||
self._latitude = latitude
|
||||
self._longitude = longitude
|
||||
@@ -16,24 +17,33 @@ class ItemMonitor:
|
||||
self._title_must_include = title_must_include
|
||||
self._description_must_include = description_must_include
|
||||
self._title_first_word_exclude = title_first_word_exclude
|
||||
|
||||
self._check_every = check_every
|
||||
@classmethod
|
||||
def load_from_json(cls, json_data):
|
||||
# search_query is mandatory
|
||||
if 'search_query' not in json_data:
|
||||
raise ValueError("Missing mandatory field: search_query")
|
||||
|
||||
return cls(
|
||||
json_data['name'],
|
||||
json_data['search_query'],
|
||||
json_data['latitude'],
|
||||
json_data['longitude'],
|
||||
json_data['max_distance'],
|
||||
json_data['condition'],
|
||||
json_data['min_price'],
|
||||
json_data['max_price'],
|
||||
json_data['title_exclude'],
|
||||
json_data['description_exclude'],
|
||||
json_data['title_must_include'],
|
||||
json_data['description_must_include'],
|
||||
json_data['title_first_word_exclude']
|
||||
json_data.get('latitude', 0),
|
||||
json_data.get('longitude', 0),
|
||||
json_data.get('max_distance', 0),
|
||||
json_data.get('condition', 'all'),
|
||||
json_data.get('min_price', 0),
|
||||
json_data.get('max_price', 0),
|
||||
json_data.get('title_exclude', []),
|
||||
json_data.get('description_exclude', []),
|
||||
json_data.get('title_must_include', []),
|
||||
json_data.get('description_must_include', []),
|
||||
json_data.get('title_first_word_exclude', []),
|
||||
json_data.get('check_every', 30)
|
||||
)
|
||||
|
||||
def get_name(self):
|
||||
return self._name
|
||||
|
||||
def get_search_query(self):
|
||||
return self._search_query
|
||||
|
||||
@@ -68,4 +78,7 @@ class ItemMonitor:
|
||||
return self._description_must_include
|
||||
|
||||
def get_title_first_word_exclude(self):
|
||||
return self._title_first_word_exclude
|
||||
return self._title_first_word_exclude
|
||||
|
||||
def get_check_every(self):
|
||||
return self._check_every
|
||||
Reference in New Issue
Block a user