Subversion Repositories SmartDukaan

Rev

Rev 22768 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
12691 manish.sha 1
from shop2020.clients.HelperClient import HelperClient
2
from shop2020.clients.TransactionClient import TransactionClient
3
from shop2020.thriftpy.utils.ttypes import UserSms, UserSmsInfo
4
from shop2020.thriftpy.utils.ttypes import SmsStatus, SmsType, SmsDeliveryStatus
5
from shop2020.utils.daemon import Daemon
6
import optparse
7
import sched
8
import sys
9
import time
10
import os
11
import urllib
12
import urllib2
12933 manish.sha 13
import datetime
12691 manish.sha 14
 
15
class SmsSender(Daemon):
16
    def __init__(self, logfile='/var/log/utils/smssender/smssender.log', pidfile='/var/run/sms-sender.pid', count = 0):
17
        Daemon.__init__(self, pidfile, stdout=logfile, stderr=logfile)
12933 manish.sha 18
        print 'SmsSender initiated at', datetime.datetime.now()
12691 manish.sha 19
        self.sms_schedular = sched.scheduler(time.time, time.sleep)
12967 manish.sha 20
        self.time_to_sleep = 60
12691 manish.sha 21
        self.count = count
22
        self.exceptionCount = {}
23
 
24
    def sendSms(self, userSmsList):
25
        listSmsSentToOperator = []
26
        for sms in userSmsList:
27
            try:
28
                mobileNo = sms.mobileNumber
29
                smsText = sms.smsText
30
                #'This is a test sms, please ignore the same.'
22759 amit.gupta 31
                #url_params = { 'ani' : '91'+str(mobileNo),  'uname' : 'srlsaholic', 'passwd' : 'sr18mar' , 'cli' : 'SAHOLC', 'message' : smsText }
23356 amit.gupta 32
                url_params = { 'Mobile' : '91'+mobileNo,  'Username' : 'srlsaholic', 'Password' : 'sr18mar' , 'MessageType' : 'txt', 'SenderID' : 'SMTDKN', 'Message' : smsText }
12691 manish.sha 33
                encoded_url_params = urllib.urlencode(url_params)
22759 amit.gupta 34
                url = 'http://103.15.179.45:8085/MessagingGateway/SendTransSMS?' + encoded_url_params
12691 manish.sha 35
                print url
36
                req = urllib2.Request(url)
37
                response = urllib2.urlopen(req)
38
                response_str = response.read()
39
                print response_str
22768 amit.gupta 40
                if "SMS Sent successfully to " in response_str:
12691 manish.sha 41
                    response_str_vals = response_str.split('#')
42
                    userSms = UserSms()
12900 manish.sha 43
                    userSms.id= sms.id
44
                    userSms.user_id = sms.user_id
45
                    userSms.mobileNumber = sms.mobileNumber
46
                    userSms.attempts = sms.attempts
47
                    userSms.createdTimestamp = sms.createdTimestamp
48
                    userSms.smsText = sms.smsText
49
                    userSms.status = sms.status
50
                    userSms.type = sms.type
12885 manish.sha 51
                    userSms.responseId = response_str_vals[0]
52
                    userSms.responseText = response_str_vals[1]
12691 manish.sha 53
                    userSms.deliveryStatus = SmsDeliveryStatus.SENT_TO_OPERATOR
54
                    listSmsSentToOperator.append(userSms)
13100 manish.sha 55
 
56
                if "Please use valid 10 digit mobile number" in response_str:
57
                    userSms = UserSms()
58
                    userSms.id= sms.id
59
                    userSms.user_id = sms.user_id
60
                    userSms.mobileNumber = sms.mobileNumber
61
                    userSms.attempts = sms.attempts
62
                    userSms.createdTimestamp = sms.createdTimestamp
63
                    userSms.smsText = sms.smsText
64
                    userSms.status = SmsStatus.INVALID_NUMBER
65
                    userSms.type = sms.type
66
                    userSms.responseId = "No_Response"
67
                    userSms.responseText = response_str
68
                    userSms.deliveryStatus = SmsDeliveryStatus.SENT_TO_OPERATOR
69
                    listSmsSentToOperator.append(userSms)
70
 
13105 manish.sha 71
                if "Invalid Mobile number" in response_str:
13106 manish.sha 72
                    userSms = UserSms()
13105 manish.sha 73
                    userSms.id= sms.id
74
                    userSms.user_id = sms.user_id
75
                    userSms.mobileNumber = sms.mobileNumber
76
                    userSms.attempts = sms.attempts
77
                    userSms.createdTimestamp = sms.createdTimestamp
78
                    userSms.smsText = sms.smsText
79
                    userSms.status = SmsStatus.INVALID_NUMBER
80
                    userSms.type = sms.type
81
                    userSms.responseId = "No_Response"
82
                    userSms.responseText = response_str
83
                    userSms.deliveryStatus = SmsDeliveryStatus.SENT_TO_OPERATOR
84
                    listSmsSentToOperator.append(userSms)
85
 
12691 manish.sha 86
            except Exception as e:
87
                print sys.exc_info()[0]
88
                print e
89
                print 'Error occurred sending sms with id - ' + str(sms.id)
90
                if self.exceptionCount.has_key(sms.id) :
91
                    self.exceptionCount[sms.id] = self.exceptionCount[sms.id] + 1
92
                else :
93
                    self.exceptionCount[sms.id] = 1
94
                continue
95
 
96
        helperServiceClient = HelperClient()
97
        helper_client = helperServiceClient.get_client()
22395 amit.gupta 98
        print "listSmsSentToOperator {0}".format(listSmsSentToOperator)
12691 manish.sha 99
        marked = helper_client.markMessagesAsSentToOperator(listSmsSentToOperator)
100
 
101
        if marked:
102
            print 'Messages sent successfully to Operator'
103
            return "success"
104
        else:
105
            return "error"
106
 
107
    def send(self):
108
 
13171 kshitij.so 109
        if self.count > 100:
12691 manish.sha 110
            print str(self.count)
13171 kshitij.so 111
            print "Number of failed attempts is more than 100. Exiting"
13202 manish.sha 112
            #sys.exit()
12691 manish.sha 113
 
114
        for smsId in self.exceptionCount.keys() :
13171 kshitij.so 115
            if self.exceptionCount[smsId] > 100:
12691 manish.sha 116
                print "Number of exceptions for sms id : " + str(smsId) + " is : " + str(self.exceptionCount[smsId]) + ". Exiting"
13202 manish.sha 117
                #sys.exit()
12691 manish.sha 118
 
12933 manish.sha 119
        print "Despatch stared at ", datetime.datetime.now()
12691 manish.sha 120
        helperServiceClient = HelperClient()
121
        helper_client = helperServiceClient.get_client()
122
 
123
        listSmsToGetDeliveryInfo = helper_client.listSmsToGetDeliveryInfo()
124
 
125
        listSmsMarkedAsSubmittedToSmsc = []
126
        listSmsMarkedAsSent = []
127
        listSmsMarkedAsRetry = []
128
 
129
        for userSms in listSmsToGetDeliveryInfo:
13100 manish.sha 130
            if userSms.responseId == "No_Response":
131
                sms = UserSms()
132
                sms.id= userSms.id
133
                sms.user_id = userSms.user_id
134
                sms.mobileNumber = userSms.mobileNumber
135
                sms.attempts = userSms.attempts
136
                sms.createdTimestamp = userSms.createdTimestamp
137
                sms.smsText = userSms.smsText
138
                sms.status = SmsStatus.INVALID_NUMBER
139
                sms.type = userSms.type
140
                sms.responseId = "No_Response"
141
                sms.responseText = userSms.responseText
142
                sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
143
                listSmsMarkedAsSent.append(sms)
144
                continue
145
 
12691 manish.sha 146
            del_det_params = {'uname' : 'srlsaholic', 'passwd' : 'sr18mar' , 'messageid' : userSms.responseId}
147
            encoded_del_det_params = urllib.urlencode(del_det_params)
148
            del_det_url = 'http://103.15.179.45:8085/SMSGateway/getApiReport?' + encoded_del_det_params
13119 manish.sha 149
            print "Delivery Report Url-",del_det_url
13121 manish.sha 150
            try:
151
                del_req = urllib2.Request(del_det_url)
152
                del_response = urllib2.urlopen(del_req)
153
                del_response_str = del_response.read()
154
            except Exception as e:
155
                continue
12691 manish.sha 156
 
12886 manish.sha 157
            print del_response_str
12691 manish.sha 158
            del_response_vals = del_response_str.split(' ')
159
 
160
            if "Submitted to SMSC" in del_response_str:
161
                sms = UserSms()
162
                sms.id= userSms.id
163
                sms.user_id = userSms.user_id
164
                sms.mobileNumber = userSms.mobileNumber
165
                sms.attempts = userSms.attempts
12884 manish.sha 166
                sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 167
                sms.smsText = userSms.smsText
168
                sms.status = userSms.status
169
                sms.type = userSms.type
170
                sms.responseId = del_response_vals[1]
171
                sms.responseText = del_response_vals[2]
172
                sms.deliveryStatus = SmsDeliveryStatus.SUBMITTED_TO_SMSC
173
                listSmsMarkedAsSubmittedToSmsc.append(sms)
174
 
175
            elif len(del_response_vals) == 8:
12900 manish.sha 176
                if del_response_vals[7][:-2] == '0' :
12691 manish.sha 177
                    sms = UserSms()
178
                    sms.id= userSms.id
179
                    sms.user_id = userSms.user_id
180
                    sms.mobileNumber = userSms.mobileNumber
181
                    sms.attempts = userSms.attempts
12884 manish.sha 182
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 183
                    sms.smsText = userSms.smsText
184
                    sms.status = SmsStatus.DELIVERED
185
                    sms.type = userSms.type
186
                    sms.responseId = del_response_vals[1]
12900 manish.sha 187
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 188
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
189
                    listSmsMarkedAsSent.append(sms)
190
 
12900 manish.sha 191
                elif del_response_vals[7][:-2] in ('4', '6', '100' ):
12691 manish.sha 192
                    sms = UserSms()
193
                    sms.id= userSms.id
194
                    sms.user_id = userSms.user_id
195
                    sms.mobileNumber = userSms.mobileNumber
196
                    sms.attempts = userSms.attempts
12884 manish.sha 197
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 198
                    sms.smsText = userSms.smsText
199
                    sms.status = SmsStatus.UNDELIVERED
200
                    sms.type = userSms.type
201
                    sms.responseId = del_response_vals[1]
12900 manish.sha 202
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 203
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
204
                    listSmsMarkedAsSent.append(sms)
205
 
12900 manish.sha 206
                elif del_response_vals[7][:-2] in ('1', '7'):
12691 manish.sha 207
                    sms = UserSms()
208
                    sms.id= userSms.id
209
                    sms.user_id = userSms.user_id
210
                    sms.mobileNumber = userSms.mobileNumber
211
                    sms.attempts = userSms.attempts
12884 manish.sha 212
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 213
                    sms.smsText = userSms.smsText
214
                    sms.status = SmsStatus.INVALID_NUMBER
215
                    sms.type = userSms.type
216
                    sms.responseId = del_response_vals[1]
12900 manish.sha 217
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 218
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
219
                    listSmsMarkedAsSent.append(sms)
220
 
12900 manish.sha 221
                elif del_response_vals[7][:-2] == '2':
12691 manish.sha 222
                    sms = UserSms()
223
                    sms.id= userSms.id
224
                    sms.user_id = userSms.user_id
225
                    sms.mobileNumber = userSms.mobileNumber
12914 manish.sha 226
                    sms.attempts = userSms.attempts+1
12884 manish.sha 227
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 228
                    sms.smsText = userSms.smsText
229
                    sms.status = SmsStatus.USER_ABSENT
230
                    sms.type = userSms.type
231
                    sms.responseId = del_response_vals[1]
12900 manish.sha 232
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 233
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
234
                    listSmsMarkedAsRetry.append(sms)
235
 
12900 manish.sha 236
                elif del_response_vals[7][:-2] == '3':
12691 manish.sha 237
                    sms = UserSms()
238
                    sms.id= userSms.id
239
                    sms.user_id = userSms.user_id
240
                    sms.mobileNumber = userSms.mobileNumber
12914 manish.sha 241
                    sms.attempts = userSms.attempts+1
12884 manish.sha 242
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 243
                    sms.smsText = userSms.smsText
244
                    sms.status = SmsStatus.MEMORY_FULL
245
                    sms.type = userSms.type
246
                    sms.responseId = del_response_vals[1]
247
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
248
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
249
                    listSmsMarkedAsRetry.append(sms)
250
 
12900 manish.sha 251
                elif del_response_vals[7][:-2] == '5':
12691 manish.sha 252
                    sms = UserSms()
253
                    sms.id= userSms.id
254
                    sms.user_id = userSms.user_id
255
                    sms.mobileNumber = userSms.mobileNumber
12914 manish.sha 256
                    sms.attempts = userSms.attempts+1
12884 manish.sha 257
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 258
                    sms.smsText = userSms.smsText
259
                    sms.status = SmsStatus.SERVICE_ERROR
260
                    sms.type = userSms.type
261
                    sms.responseId = del_response_vals[1]
12900 manish.sha 262
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 263
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
264
                    listSmsMarkedAsRetry.append(sms)
265
 
12900 manish.sha 266
                elif del_response_vals[7][:-2] == '9':
12691 manish.sha 267
                    sms = UserSms()
268
                    sms.id= userSms.id
269
                    sms.user_id = userSms.user_id
270
                    sms.mobileNumber = userSms.mobileNumber
271
                    sms.attempts = userSms.attempts
12884 manish.sha 272
                    sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 273
                    sms.smsText = userSms.smsText
274
                    sms.status = SmsStatus.NDLC_FAIL
275
                    sms.type = userSms.type
276
                    sms.responseId = del_response_vals[1]
12900 manish.sha 277
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 278
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
279
                    listSmsMarkedAsSent.append(sms)
12927 manish.sha 280
 
12939 manish.sha 281
                elif del_response_vals[7][:-2] in ('549', '550'):
12927 manish.sha 282
                    sms = UserSms()
283
                    sms.id= userSms.id
284
                    sms.user_id = userSms.user_id
285
                    sms.mobileNumber = userSms.mobileNumber
286
                    sms.attempts = userSms.attempts
287
                    sms.createdTimestamp = userSms.createdTimestamp
288
                    sms.smsText = userSms.smsText
289
                    sms.status = SmsStatus.UNDELIVERED
290
                    sms.type = userSms.type
291
                    sms.responseId = del_response_vals[1]
292
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
293
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
294
                    listSmsMarkedAsSent.append(sms)
12930 manish.sha 295
 
296
                elif del_response_vals[7][:-2] == '155':
297
                    sms = UserSms()
298
                    sms.id= userSms.id
299
                    sms.user_id = userSms.user_id
300
                    sms.mobileNumber = userSms.mobileNumber
301
                    sms.attempts = userSms.attempts
302
                    sms.createdTimestamp = userSms.createdTimestamp
303
                    sms.smsText = userSms.smsText
304
                    sms.status = SmsStatus.UNDELIVERED
305
                    sms.type = userSms.type
306
                    sms.responseId = del_response_vals[1]
307
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
308
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
309
                    listSmsMarkedAsSent.append(sms)
12942 manish.sha 310
 
311
                else:
312
                    sms = UserSms()
313
                    sms.id= userSms.id
314
                    sms.user_id = userSms.user_id
315
                    sms.mobileNumber = userSms.mobileNumber
316
                    sms.attempts = userSms.attempts
317
                    sms.createdTimestamp = userSms.createdTimestamp
318
                    sms.smsText = userSms.smsText
319
                    sms.status = SmsStatus.UNDELIVERED
320
                    sms.type = userSms.type
321
                    sms.responseId = del_response_vals[1]
322
                    sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
323
                    sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
324
                    listSmsMarkedAsSent.append(sms)
12691 manish.sha 325
 
326
            elif "No message submitted with MessageID" in del_response_str:
327
                sms = UserSms()
328
                sms.id= userSms.id
329
                sms.user_id = userSms.user_id
330
                sms.mobileNumber = userSms.mobileNumber
331
                sms.attempts = userSms.attempts
12884 manish.sha 332
                sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 333
                sms.smsText = userSms.smsText
334
                sms.status = SmsStatus.UNDELIVERED
335
                sms.type = userSms.type
12915 manish.sha 336
                sms.responseId = userSms.responseId
337
                sms.responseText = del_response_str
12691 manish.sha 338
                sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
339
                listSmsMarkedAsSent.append(sms)
340
 
341
            else:
342
                sms = UserSms()
343
                sms.id= userSms.id
344
                sms.user_id = userSms.user_id
345
                sms.mobileNumber = userSms.mobileNumber
346
                sms.attempts = userSms.attempts
12884 manish.sha 347
                sms.createdTimestamp = userSms.createdTimestamp
12691 manish.sha 348
                sms.smsText = userSms.smsText
349
                sms.status = SmsStatus.UNDELIVERED
350
                sms.type = userSms.type
351
                sms.responseId = del_response_vals[1]
12900 manish.sha 352
                sms.responseText = "Status Code: " +del_response_vals[7][:-2]+" Status: "+ del_response_vals[5]
12691 manish.sha 353
                sms.deliveryStatus = SmsDeliveryStatus.GOT_STATUS_CODE
354
                listSmsMarkedAsSent.append(sms)
355
 
356
        if len(listSmsMarkedAsSubmittedToSmsc) > 0:
357
            if not helper_client.isAlive() :
358
                helper_client = helperServiceClient.get_client()
359
 
360
            markedSmsc =helper_client.markMessagesAsSubmittedToSmsc(listSmsMarkedAsSubmittedToSmsc)
361
            if markedSmsc:
362
                print 'Sms marked submitted to SMSC successfully'
363
            else:
364
                print 'Sms marked submitted to SMSC failed'
365
 
366
        time.sleep(5)
367
 
368
        if len(listSmsMarkedAsSent) > 0:
369
            if not helper_client.isAlive() :
370
                helper_client = helperServiceClient.get_client()
371
 
372
            markedSent = helper_client.markMessagesAsSent(listSmsMarkedAsSent)
373
 
374
            if markedSent:
375
                print 'Sms marked Sent successfully'
376
            else:
377
                print 'Sms marked Sent failed'
378
 
379
        time.sleep(5)
380
 
381
        if len(listSmsMarkedAsRetry) > 0:
382
            if not helper_client.isAlive() :
383
                helper_client = helperServiceClient.get_client()
384
 
385
            markedRetry = helper_client.markMessagesAsRetry(listSmsMarkedAsRetry)
386
            if markedRetry:
387
                print 'Sms marked Retry successfully'
388
            else:
389
                print 'Sms marked Retry failed'
390
 
391
        time.sleep(5)
392
 
393
        if not helper_client.isAlive() :
394
            helper_client = helperServiceClient.get_client()
395
 
396
        sms_to_be_dispatched = helper_client.getSmsToBeSent()        
397
 
398
        print len(sms_to_be_dispatched)
399
        send_result = "error"
400
        try:
401
            send_result = self.sendSms(sms_to_be_dispatched)
402
        except Exception as e:
403
            if send_result in ("error" ) :
404
                print 'Marked Sms sent to Operator Failed '
405
                self.count = self.count + 1
406
            pass
407
        self.sms_schedular.enter(self.time_to_sleep, 1, self.send, ())
408
 
409
 
410
 
411
    def run(self):
412
        self.sms_schedular.enter(self.time_to_sleep, 1, self.send, ())
413
        self.sms_schedular.run()
414
 
415
if __name__ == "__main__":
416
    parser = optparse.OptionParser()
417
    parser.add_option("-l", "--logfile", dest="logfile",
418
                      type="string",
419
                      help="Log all output to LOG_FILE",
420
                      )
421
    parser.add_option("-i", "--pidfile", dest="pidfile",
422
                      type="string",
423
                      help="Write the PID to pidfile")
424
    (options, args) = parser.parse_args()
425
    daemon = SmsSender(options.logfile, options.pidfile, 0)
426
    if len(args) == 0:
427
        daemon.run()
428
    elif len(args) == 1:
429
        if 'start' == args[0]:
430
            daemon.start()
431
        elif 'stop' == args[0]:
432
            daemon.stop()
433
        elif 'restart' == args[0]:
434
            daemon.restart()
435
        else:
436
            print "Unknown command"
437
            sys.exit(2)
438
        sys.exit(0)
439
    else:
440
        print "usage: %s start|stop|restart" % sys.argv[0]
441
        sys.exit(2)      
442
 
443