mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2025-04-27 14:33:59 -04:00
More refactoring, added message loop example
This commit is contained in:
parent
ccd94f0f1f
commit
d9b2a36875
1 changed files with 33 additions and 31 deletions
|
@ -16,7 +16,7 @@ module.exports.setupRoutes = (app) ->
|
|||
|
||||
generateQueueInstance = ->
|
||||
if config.isProduction
|
||||
return new RemoteQueue()
|
||||
return new RemoteQueue(config.queue.simulationQueueName)
|
||||
else
|
||||
return new LocalQueue()
|
||||
|
||||
|
@ -36,45 +36,54 @@ class AbstractQueue
|
|||
|
||||
|
||||
class RemoteQueue extends AbstractQueue
|
||||
constructor: ->
|
||||
constructor: (queueName) ->
|
||||
@configure()
|
||||
@sqs = @generateSQSInstance()
|
||||
@createSimulationQueueAndSetUrl (err, data) =>
|
||||
@sendMessage "This is a new test message",5, =>
|
||||
winston.info "Sent test message!"
|
||||
setTimeout @receiveMessage.bind(this, (err, data) =>
|
||||
if err?
|
||||
winston.error "Error receiving message, reason: #{JSON.stringify err}"
|
||||
else
|
||||
winston.info "Received message, content: #{JSON.stringify data}"
|
||||
winston.info "Deleting message..."
|
||||
@deleteMessage data.Messages?[0].ReceiptHandle, ->
|
||||
winston.info "Deleted message!"
|
||||
), 5000
|
||||
@createSimulationQueueAndSetUrl queueName, (err, data) =>
|
||||
@sendMessage "This is a new test message",5, (error,data) ->
|
||||
if err?
|
||||
winston.error "#{JSON.stringify error}"
|
||||
@enterReceieveMessageForeverLoop()
|
||||
|
||||
|
||||
|
||||
|
||||
configure: ->
|
||||
aws.config.update @generateAWSConfigurationObject()
|
||||
|
||||
enterReceieveMessageForeverLoop: ->
|
||||
async.forever (asyncCallback) =>
|
||||
@receiveMessage (err, data) =>
|
||||
if err?
|
||||
winston.error "Error receiving message, reason: #{JSON.stringify err}"
|
||||
else
|
||||
if data.Messages?
|
||||
winston.info "Received message, content: #{JSON.stringify data.Messages[0].Body}"
|
||||
winston.info "Deleting message..."
|
||||
@deleteMessage data.Messages?[0].ReceiptHandle, ->
|
||||
winston.info "Deleted message!"
|
||||
else
|
||||
winston.info "No messages to receieve"
|
||||
asyncCallback(null)
|
||||
|
||||
createSimulationQueueAndSetUrl: (callback) ->
|
||||
@sqs.createQueue {QueueName: config.queue.simulationQueueName}, (err, data) =>
|
||||
createSimulationQueueAndSetUrl: (queueName, callback) ->
|
||||
@sqs.createQueue {QueueName: queueName}, (err, data) =>
|
||||
if err?
|
||||
winston.error "Failed to create simulation queue!"
|
||||
throw new Error "Failed to create simulation queue."
|
||||
throw new Error "Failed to create queue \"#{queueName}\""
|
||||
else
|
||||
winston.info "Created simulation queue, URL is #{data.QueueUrl}"
|
||||
@simulationQueueUrl = data.QueueUrl
|
||||
callback?(null,data)
|
||||
winston.info "Created queue, URL is #{data.QueueUrl}"
|
||||
@queueUrl = data.QueueUrl
|
||||
callback?(err,data)
|
||||
|
||||
|
||||
receiveMessage: (callback) ->
|
||||
@sqs.receiveMessage {QueueUrl: @simulationQueueUrl, WaitTimeSeconds: 20}, callback
|
||||
@sqs.receiveMessage {QueueUrl: @queueUrl, WaitTimeSeconds: 20}, callback
|
||||
|
||||
deleteMessage: (receiptHandle, callback) ->
|
||||
@sqs.deleteMessage {QueueUrl: @simulationQueueUrl, ReceiptHandle: receiptHandle}, callback
|
||||
@sqs.deleteMessage {QueueUrl: @queueUrl, ReceiptHandle: receiptHandle}, callback
|
||||
|
||||
sendMessage: (messageBody, delaySeconds, callback) ->
|
||||
@sqs.sendMessage {QueueUrl: @simulationQueueUrl, MessageBody: messageBody, DelaySeconds: delaySeconds}, callback
|
||||
@sqs.sendMessage {QueueUrl: @queueUrl, MessageBody: messageBody, DelaySeconds: delaySeconds}, callback
|
||||
|
||||
|
||||
generateAWSConfigurationObject: ->
|
||||
|
@ -87,13 +96,6 @@ class RemoteQueue extends AbstractQueue
|
|||
generateSQSInstance: ->
|
||||
new aws.SQS()
|
||||
|
||||
testConnection: ->
|
||||
@sqs.listQueues {}, (err, data) ->
|
||||
if err?
|
||||
winston.error "Error connecting to SQS, reason: #{err}"
|
||||
throw new Error("Couldn't connect to SQS.")
|
||||
else
|
||||
winston.info "Connected to SQS!"
|
||||
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue