/
queueSample.js
281 lines (249 loc) · 12.3 KB
/
queueSample.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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
//----------------------------------------------------------------------------------
// Microsoft Developer & Platform Evangelism
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// THIS CODE AND INFORMATION ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
// EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES
// OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.
//----------------------------------------------------------------------------------
// The example companies, organizations, products, domain names,
// e-mail addresses, logos, people, places, and events depicted
// herein are fictitious. No association with any real company,
// organization, product, domain name, email address, logo, person,
// places, or events is intended or should be inferred.
//----------------------------------------------------------------------------------
/**
* Azure Storage Queue Sample in Node.JS
* This samples demonstrates how to use the Queue Storage service.
* Queue storage provides a reliable messaging solution for asynchronous communication
* Queues can be accessed from anywhere in the world via HTTP or HTTPS.
*
* Documentation References:
* - What is a Storage Account - http://azure.microsoft.com/en-us/documentation/articles/storage-whatis-account/
* - Getting Started with Queues - https://azure.microsoft.com/en-us/documentation/articles/storage-nodejs-how-to-use-queues
* - Queue Service Concepts - https://msdn.microsoft.com/en-us/library/azure/dd179353.aspx
* - Queue Service REST API - https://msdn.microsoft.com/en-us/library/azure/dd179363.aspx
* - Queue Service Node API - http://azure.github.io/azure-storage-node/QueueService.html
* - Delegating Access with Shared Access Signatures - http://azure.microsoft.com/en-us/documentation/articles/storage-dotnet-shared-access-signature-part-1/
* - Storage Emulator - https://azure.microsoft.com/en-us/documentation/articles/storage-use-emulator/
*/
var fs = require('fs');
var util = require('util');
var storage = require('azure-storage');
var queueNamePrefix = "storagesampleforqueue";
var queueService;
console.log('Azure Storage Queue Samples in Node.JS');
RunQueueSamples();
function RunQueueSamples() {
/**
* Instructions: This sample can be run using either the Azure Storage Emulator (https://go.microsoft.com/fwlink/?linkid=717179&clcid=0x409)
* or by updating the app.config file with your account name and key.
*
* To run the sample using the Storage Emulator (default option, on Windows only)
* Start the Azure Storage Emulator (once only) by pressing the Start button or the Windows key and searching for it
* by typing "Azure Storage Emulator". Select it from the list of applications to start it.
*
* To run the sample using the Storage Service
* Open the app.config file and comment out the setting for the emulator ("useDevelopmentStorage":true),
* uncomment the "accountName" and "accountKey" for the storage service and set the account credential.
*/
var config = GetConfigSettings();
// Create a queue service client for interacting with the Queue service from account name and account key or the connection string.
// You can either connect to an Azure storage account with account name and account key specified OR use the storage emulator for development.
// How to create a storage connection string - http://msdn.microsoft.com/en-us/library/azure/ee758697.aspx
if (config.connectionString) {
queueService = storage.createQueueService(config.connectionString);
} else {
queueService = storage.createQueueService(config.accountName, config.accountKey);
}
var current = 0;
var scenarios = [
{
scenario: QueueOperations,
message: 'Basic Operations on Queue Completed\n'
},
{
scenario: QueueMessageOperations,
message: 'Basic Operations on Queue Messages Completed\n'
},
{
scenario: QueueDeleteOperation,
message: 'Delete Queue Operation Completed\n'
}];
var callback = function (error) {
if (error) {
if (error.code === "ECONNREFUSED") {
console.log("Connection refused. Please check if the connection parameters are correct. If you are using the Emulator, please make sure it is running");
} else {
throw error;
}
} else {
console.log(scenarios[current].message);
current++;
if (current < scenarios.length) {
scenarios[current].scenario(callback);
}
}
};
scenarios[current].scenario(callback);
}
// Read configuration file to retrieve credentials such as account name and account key
function GetConfigSettings() {
var config = JSON.parse(fs.readFileSync('app.config', 'utf8'));
if (config.useDevelopmentStorage) {
// use the Storage Emulator if this option is specified
// note that the Storage Emulator must be running for the sample to succeed
config.connectionString = storage.generateDevelopmentStorageCredentials();
}
return config;
}
function QueueOperations(callback) {
var id = 1;
// define an array to return the list of queues
var queues = [];
// Create several queues.
// Use createQueueIfNotExists to create a queue only if it does not already exist.
var queueName = queueNamePrefix + (id++);
queueService.createQueueIfNotExists(queueName, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log('QueueOperations: Queue ' + queueName + ' successfully created');
queueName = queueNamePrefix + (id++);
queueService.createQueueIfNotExists(queueName, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log('QueueOperations: Queue ' + queueName + ' successfully created');
queueName = queueNamePrefix + (id++);
queueService.createQueueIfNotExists(queueName, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log('QueueOperations: Queue ' + queueName + ' successfully created');
// List all queues for a storage account.
// Specify null for the continuationToken and options. For more on this, please check https://msdn.microsoft.com/en-us/library/azure/dd179363.aspx
var continuationToken = null;
var option = { maxResults: 2, include: 'metadata' };
listQueues(queueService, queueNamePrefix, continuationToken, option, function (error, result) {
for (var i = 0; i < result.length; i++) {
console.log(util.format('QueueOperations: Retrieved - %s'), result[i].name);
}
queueService.deleteQueue(queueName, function (error) {
callback(error);
})
});
}
});
}
});
}
});
function listQueues(queueService, prefix, token, options, callback) {
// return results by page and recursively invoke
queueService.listQueuesSegmentedWithPrefix(prefix, token, options, function (error, result) {
queues.push.apply(queues, result.entries);
token = result.continuationToken;
if (token) {
console.log('QueueOperations: Received a page of results. There are ' + result.entries.length + ' queues on this page.');
listQueues(queueService, prefix, token, options, callback);
} else {
console.log('QueueOperations: Completed listing. There are ' + queues.length + ' queues.');
callback(null, queues);
}
});
}
}
function QueueMessageOperations(callback) {
var queueName = queueNamePrefix + "myqueueformessages";
var message = "Hello world";
var nextMessage = 'Hello world again';
// Create a queue.
// Use createQueueIfNotExists to create a queue only if it does not already exist.
queueService.createQueueIfNotExists(queueName, function (error) {
if (error) {
callback(error);
} else {
console.log('QueueMessageOperations: Queue "' + queueName + '" successfully created');
// Add a message to a queue.
queueService.createMessage(queueName, message, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log('QueueMessageOperations: Message "' + message + '" was added to queue successfully');
queueService.createMessage(queueName, nextMessage, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log('QueueMessageOperations: Message "' + nextMessage + '" was added to queue successfully');
// Dequeue the next message. First retrieve the message, this makes the message invisible...
// By default, a single message is retrieved from the queue with this operation.
// Please refer to http://azure.github.io/azure-storage-node/QueueService.html#getMessages for more options.
queueService.getMessages(queueName, function (error, messages) {
// The messages will be invisible for further dequeueing for 30 seconds (by default)
// The message text is available in messages[0].messagetext
console.log('QueueMessageOperations: Message "' + messages[0].messageText + '" has been dequeued');
// then delete it
queueService.deleteMessage(queueName, messages[0].messageId, messages[0].popReceipt, function (error) {
if (error) {
callback(error);
}
console.log('QueueMessageOperations: Message "%s" deleted successfully', messages[0].messageId);
// Find the next message in a queue, without changing the message visibility.
queueService.peekMessages(queueName, function (error, result) {
if (error) {
callback(error);
} else {
console.log('QueueMessageOperations: The next message in the queue is "%s"', result[0].messageText);
// Change contents of a message, first retrieve...
// Retrieve a message from the front of the queue and make it invisible to other consumers.
// Please note the difference with queueService.getMessages that the return is a message instead of a message array.
queueService.getMessage(queueName, function (error, result, response) {
if (error) {
callback(error);
} else {
// then update the contents and set the new visibility timeout
var message = result;
queueService.updateMessage(queueName, message.messageId, message.popReceipt, 10, { messageText: 'new text' }, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log("QueueMessageOperations: Contents of message changed");
queueService.deleteQueue(queueName, function(){
callback(error);
});
}
});
}
});
}
});
});
});
}
});
}
});
}
});
}
function QueueDeleteOperation(callback) {
var queueName = queueNamePrefix + "myqueuedelete";
///Create a queue.
///Use createQueueIfNotExists to create a queue only if it does not already exist.
queueService.createQueueIfNotExists(queueName, function (error, result, response) {
if (error) {
callback(error);
} else {
console.log('QueueDeleteOperation: Queue ' + queueName + ' successfully created');
//delete queue
queueService.deleteQueueIfExists(queueName, function (error, result) {
if (!error) {
console.log('QueueDeleteOperation: Queue ' + queueName + ' successfully deleted');
}
callback(error);
});
}
});
}