forked from alex-quiterio/ts_creep
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathticketswap.py
102 lines (83 loc) · 3.23 KB
/
ticketswap.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
"""Checks for a ticket on ticketswap."""
import sys
import logging
import sched
import time
from random import randrange
import numpy as np
from bs4 import BeautifulSoup
import messenger
import scrapper
import ticket
LOGGER = logging.getLogger(__name__)
handler = logging.StreamHandler()
formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
LOGGER.setLevel(logging.INFO)
LOGGER.addHandler(handler)
class TicketSwapTrigger(object):
def __init__(self, main_url, t_min=5, t_max=10):
self.main_url = main_url
self.t_min = t_min
self.t_max = t_max
self.messenger = messenger.Message()
self.scapper = scrapper.TicketSwapScrapper(self.main_url)
self.content = None
self.refresh_count = 0
def send_message(self, message):
self.messenger.send_message(message)
def send_url_message(self):
self.send_message(self.main_url)
def get_web_content(self):
return self.scapper.get_content()
def get_pretty_content(self):
return BeautifulSoup(self.get_web_content(), "lxml")
def get_content_values(self):
try:
self.content = self.get_pretty_content()
except:
self.send_message('Connection died')
self.run_task()
def get_ticket_values(self):
self.get_content_values()
tickets = self.content.find_all("div", class_="counter-value")
ticket_count = {}
try:
ticket_count['offered'] = int(tickets[0].get_text())
ticket_count['sold'] = int(tickets[1].get_text())
ticket_count['wanted'] = int(tickets[2].get_text())
except IndexError:
ticket_count['offered'] = np.nan
ticket_count['sold'] = np.nan
ticket_count['wanted'] = np.nan
return ticket_count
def refresh_content(self, s):
self.refresh_count += 1
LOGGER.info('Resfresh count: %s', self.refresh_count)
ticket_count = self.get_ticket_values()
LOGGER.info('Tickets available: %s', ticket_count['offered'])
LOGGER.info('Tickets sold: %s', ticket_count['sold'])
if ticket_count['offered'] > 0:
ticket.add_ticket(url=self.main_url)
self.send_message('There is a ticket available')
for i in range(50):
LOGGER.info('+++++++++++++++++++++++++++++++++++++++++++++')
else:
time_delay = randrange(self.t_min, self.t_max)
LOGGER.info('Time delay: %s', time_delay)
LOGGER.info('=====================')
if ticket_count['offered'] is not np.nan:
s.enter(time_delay, 1, self.refresh_content, (s,))
else:
self.send_message('You are a robot, increase the time')
LOGGER.criticl('You are a robot')
def run_task(self):
s = sched.scheduler(time.time, time.sleep)
s.enter(1, 1, self.refresh_content, (s,))
s.run()
if __name__ == '__main__':
url = 'https://www.ticketswap.com/event/mastodon-melkweg-amsterdam/81389dda-908c-4f73-b7f7-047c5a1ea0e9'
concert = TicketSwapTrigger(main_url=url, t_min=1, t_max=2)
concert.run_task()
input("Press Enter to continue...")