forked from 46elks/samples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathex03_sms_forwarding_groups.js
executable file
·137 lines (112 loc) · 4.83 KB
/
ex03_sms_forwarding_groups.js
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
129
130
131
132
133
134
135
136
137
#!/usr/bin/env node
/* jshint node: true */
/*
* 46elks samples: Forwarding text messages in groups
* ===
*
* This example blends the previous two examples - sending custom text messages and receiving
* text messages. Received text messages are matches against rules and appropriately forwarded
* to the members of the group. The scenario is that you can message a single number and the
* message is then delivered to everyone in that group which allows an easy group chat regardless
* of what devices everyone involved is using.
*
* Setup
* ---
*
* Allocate phone numbers either via the web dashboard or by using the /Numbers API endpoint.
* For the allocated numbers you are going to use, set the `sms_url` value as the endpoint
* provided by this example (http://example.com/callback/newsms).
* Modify the group objects as described in the code, setting your allocated numbers and the
* numbers of all the members of the groups.
* Provide your own API username and API password (see the sendSms() function).
*/
var core = require(__dirname + '/_core.js');
var https = require('https');
var querystring = require('querystring');
// We have to define the phone numbers we will be working with.
var groups = {
'+46761070124': { // This is the number which you have been allocated.
'name': 'The development team', // This is here just for logging purposes.
'members': { // These are... well, the members of the group.
'+46707808449': 'sirmike', // Each member is ID'd by his/her number and a name.
'+46761239871': 'sl0wcoder',
'+46739338123': 'jlundberg'
}
},
'+46761070125': {
'name': 'Family',
'members': {
'+46735207657': 'Anders',
'+46707224755': 'Marie',
'+46709194878': 'Kicki',
'+46703738061': 'Carina'
}
}
};
function sendSms(from, to, message) {
// Do URL-encoding on the data and prepare the request details.
var postData = querystring.stringify({ from: from, to: to, message: message });
var options = {
hostname: 'api.46elks.com',
path: '/a1/SMS',
method: 'POST',
headers: {
'User-Agent': 'samples/1.0.0',
'Content-Length': postData.length,
'Content-Type': 'application/x-www-form-urlencoded',
// Add basic access authentication. Real simple.
'Authorization': 'Basic ' +
new Buffer(core.username + ':' + core.password, 'utf8').toString('base64')
}
};
// Start the web request.
var request = https.request(options, function (response) {
// Log all data we receive from the server. We need to consume these 'data' events anyway.
response.on('data', function (data) { console.log(data.toString('utf8')); });
});
// Send the real data away to the server.
request.write(postData, 'utf8');
// Finish sending the request.
request.end();
// Log any errors, in case something goes wrong.
request.on('error', function (err) { console.error(err); });
}
core.listen('/callback/newsms', function listener(page) {
// Make sure the POST data looks sane before starting anything.
var fields = [ 'from', 'to', 'message' ];
for (var i = 0; i < fields.length; i++) {
var field = fields[i];
if (typeof page.post[field] === 'undefined') {
console.error('No "' + field + '" key in the POST data.');
return;
}
}
// Group keys are our allocated numbers which makes group lookup rather simple.
var group = groups[page.post.to];
// If there is no group matched, just log that and return.
if (typeof group === 'undefined') {
console.error('No group for number "' + page.post.to + '". (from: "' + page.post.from + '")');
return;
}
// People's names are nicely organized as well where the keys are their representative numbers.
var author = group.members[page.post.from];
// The sender does not seem to be a member of the group he is sending for.
if (typeof author === 'undefined') {
// If you want to allow this, you could use something like `author = page.post.from`.
console.error('Broadcast for "' + page.post.from + '" rejected in "' + group.name + '".');
return;
}
// After all this validation, send out messages to everyone in the group!
for (var memberNumber in group.members) {
// This is a bit of a weird quirk with JS. Got to have this to avoid weird numbers popping up.
if (!group.members.hasOwnProperty(memberNumber)) continue;
// The original sender is probably not interested in an echo.
if (memberNumber === page.post.from) continue;
// This is what we end up sending off:
// from = page.post.to // This is the number we received the text on.
// to = memberNumber // This is the number of the current member we are looking at.
// message = "<author>: <original message>" // This is the message being sent away. Simple.
// Message ahoy!
sendSms(page.post.to, memberNumber, author + ': ' + page.post.message);
}
});