2016-06-29 11:57:56 +00:00
|
|
|
RedisManager = require "./app/coffee/RedisManager"
|
|
|
|
UpdateManager = require "./app/coffee/UpdateManager"
|
|
|
|
LockManager = require "./app/coffee/LockManager"
|
|
|
|
|
2016-07-07 15:29:01 +00:00
|
|
|
async = require "async"
|
|
|
|
|
2016-06-29 11:57:56 +00:00
|
|
|
handleErrorInsideLock = (doc_id, lockValue, original_error, callback = (error) ->) ->
|
|
|
|
LockManager.releaseLock doc_id, lockValue, (lock_error) ->
|
|
|
|
callback(original_error)
|
|
|
|
|
|
|
|
migrateDoc = (doc_id, callback = (error) ->) ->
|
|
|
|
LockManager.getLock doc_id, (error, lockValue) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
RedisManager.getAndSetDoc doc_id, (error, project_id) ->
|
|
|
|
return handleErrorInsideLock(doc_id, lockValue, error, callback) if error?
|
|
|
|
RedisManager.getAndSetProject project_id, (error) ->
|
|
|
|
return handleErrorInsideLock(doc_id, lockValue, error, callback) if error?
|
|
|
|
LockManager.releaseLock doc_id, lockValue, (error) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
UpdateManager.continueProcessingUpdatesWithLock project_id, doc_id, callback
|
|
|
|
|
2016-07-07 15:29:01 +00:00
|
|
|
doc_ids = process.argv.slice(2)
|
|
|
|
if doc_ids.length == 0
|
|
|
|
console.log "Usage: coffee migrate.coffee DOC_ID [DOC_ID ...]"
|
2016-06-29 11:57:56 +00:00
|
|
|
process.exit(1)
|
|
|
|
|
2016-07-07 15:29:01 +00:00
|
|
|
jobs = []
|
|
|
|
for doc_id in doc_ids
|
|
|
|
do (doc_id) ->
|
|
|
|
jobs.push (cb) ->
|
|
|
|
console.log "MIGRATING #{doc_id}"
|
|
|
|
migrateDoc doc_id, cb
|
|
|
|
|
|
|
|
async.series jobs, (error) ->
|
2016-06-29 11:57:56 +00:00
|
|
|
throw error if error?
|
2016-07-07 15:29:01 +00:00
|
|
|
process.exit(0)
|