-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathworker.py
128 lines (109 loc) · 4.21 KB
/
worker.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
128
import logging
from utilities import *
from threading import Timer
try:
import pync
except Exception:
pync = None
class NotificationData:
def __init__(self):
self.isOnline = False
self.notifyTimer = None
# ['action', {'add': 'relay'}, [{u'status': u'ERROR', u'message': {u'conversation': u'Test'}, u'key': {u'remoteJid': u'3456345@s.whatsapp.net', u'fromMe': False, u'id': u'62EC04FB60FFBD8A284C28E823EE2D5E'}, u'messageTimestamp': u'1560598969'}]]
class Worker:
wa = None
subscribeListFile = None
presenceFile = None
notificationFile = None
notificationList = {}
subscriberList = {}
subscriberId = None
isSubscribed = False
onlineNotificationDurationSecs = 180
def __init__(self, subscribeListFile, presenceFile, notificationFile):
self.subscribeListFile = subscribeListFile
self.presenceFile = presenceFile
self.notificationFile = notificationFile
def subscribe(self):
logging.info("Subscribe list file: %s" % self.subscribeListFile)
try:
with open(self.subscribeListFile) as f:
lineList = f.readlines()
for line in lineList:
line = line.strip()
info = line.split(",")
number = info[0]
id = info[1]
self.addToSubscriberList(number, id)
self.sendSubscribe(str.strip(number))
except:
logging.info("Subscribe list not present")
raise
try:
with open(self.notificationFile) as f:
lineList = f.readlines()
for line in lineList:
line = line.strip()
self.notificationList[line] = NotificationData()
except:
logging.info("Notification list not present")
def addToSubscriberList(self, number, id):
self.subscriberId = id
self.subscriberList[number] = self.subscriberId
logging.info("Subscriberid for %s is %s" % (number, self.subscriberList[number]))
def addNewSubscribe(self, jid):
number = self.getUserIdIfUser(jid)
if number in self.subscriberList:
logging.info("Subscriber already has presence")
return False
with open(self.subscribeListFile, "a+") as pFile:
pFile.write('%s\n' % number)
self.addToSubscriberList(number)
self.sendSubscribe(number)
logging.info("Added the new subscriber")
return True
def sendSubscribe(self, userId):
logging.info('Subsrcibing for %s' % userId)
messageTag = str(getTimestampMs())
message = ('%s,,["action", "presence", "subscribe", "%s@c.us"]' % (messageTag, userId))
logging.info(message)
self.wa.ws.send(message)
def notifyLongOnline(self, userId):
if pync:
pync.Notifier.notify("{} is online for {}s".format(userId, self.onlineNotificationDurationSecs), sound='Bell',
title='Online')
def handleNotification(self, userId, pType):
if userId not in self.notificationList:
return
if pType == "available":
if self.notificationList[userId].isOnline:
return
notifyTimer = Timer(self.onlineNotificationDurationSecs, lambda: self.notifyLongOnline(userId))
notifyTimer.start()
self.notificationList[userId].notifyTimer = notifyTimer
self.notificationList[userId].isOnline = True
else:
if not self.notificationList[userId].isOnline:
return
self.notificationList[userId].isOnline = False
self.notificationList[userId].notifyTimer.cancel()
def writePresenceToFilefromJson(self, presenceInfo):
userId = self.getUserIdIfUser(presenceInfo["id"])
presencetype = presenceInfo["type"]
presenceTime = getTimeString('Asia/Kolkata')
self.writePresenceToFile(userId, presencetype, presenceTime)
self.handleNotification(userId, presencetype)
def writePresenceToFile(self, userId, pType, pTime):
with open(self.presenceFile, "a+") as pFile:
if userId in self.subscriberList:
pFile.write('%s,%s,%s,%s\n' % (userId, pType, str(pTime), self.subscriberList[userId]))
else:
pFile.write('%s,%s,%s,%s\n' % (userId, pType, str(pTime), "None"))
def getUserIdIfUser(self, sender):
jid = sender.split('@')[0]
logging.debug("Jid: %s" % jid)
splitList = jid.split('-')
if len(splitList) > 1:
logging.info("Seems message from group: %s" % sender)
raise ValueError("Sender seems a group")
return splitList[0]