-
Notifications
You must be signed in to change notification settings - Fork 1
/
telstrasms.py
executable file
·57 lines (48 loc) · 1.65 KB
/
telstrasms.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
#!/usr/bin/python
import urllib
import urllib2
import json
import datetime
import sys
if len(sys.argv) < 3:
sys.exit("Usage: telstrasms.py RECIPIENT MESSAGE")
smsrcpt = sys.argv[1]
subject = sys.argv[2]
key="YOURKEYHERE"
secret="YOURSECRETHERE"
url="https://api.telstra.com/v1/oauth/token?client_id="+key+"&client_secret="+secret+"&grant_type=client_credentials&scope=SMS"
now = datetime.datetime.today()
authfile = '/tmp/telstraauth'
def GetAuthToken( url, now, key, secret ):
response = urllib2.urlopen(url)
newtokendict = json.loads(response.read())
newtokendict["datetime"] = str(now)
authtoken = newtokendict["access_token"]
newjsontoken = json.JSONEncoder().encode(newtokendict)
f = open(authfile,'w')
print "new token : "+newjsontoken
f.write(newjsontoken)
f.close()
return authtoken
f = open(authfile,'a+')
filetoken = f.read()
f.close()
try:
dicttoken = json.loads(filetoken)
authtoken = dicttoken["access_token"]
dtobj = datetime.datetime.strptime(dicttoken["datetime"], '%Y-%m-%d %H:%M:%S.%f')
expires = dtobj + datetime.timedelta(0,int(dicttoken["expires_in"]))
if expires < now:
print "expired"
authtoken = GetAuthToken(url, now, key, secret)
else:
print "not expired"
except ValueError:
print "Invalid JSON. Retrieving new token"
authtoken = GetAuthToken(url, now, key, secret)
smsdata = { 'to':smsrcpt, 'body':subject }
headers = { 'Content-type':'application/json','Authorization':'Bearer '+str(authtoken) }
url = "https://api.telstra.com/v1/sms/messages"
req = urllib2.Request(url,headers=headers,data=json.dumps(smsdata))
msg = urllib2.urlopen(req)
print msg.read()