mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 22:27:26 +01:00
restore NaN history entries (@djuretic thanks!)
This commit is contained in:
45
migrations/20131221_restore_NaN_history.js
Normal file
45
migrations/20131221_restore_NaN_history.js
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
// node .migrations/20131221_restore_NaN_history.js
|
||||||
|
|
||||||
|
/**
|
||||||
|
* After the classes migration, users lost some history entries
|
||||||
|
*/
|
||||||
|
var mongo = require('mongoskin');
|
||||||
|
var _ = require('lodash');
|
||||||
|
|
||||||
|
var backupUsers = mongo.db('localhost:27017/habitrpg_old?auto_reconnect').collection('users');
|
||||||
|
var liveUsers = mongo.db('localhost:27017/habitrpg?auto_reconnect').collection('users');
|
||||||
|
|
||||||
|
function filterNaNs(h) {
|
||||||
|
return h && _.isNumber(+h.value) && !_.isNaN(+h.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
var fields = {history:1,habits:1,dailys:1,migration:1};
|
||||||
|
var count = 0;
|
||||||
|
liveUsers.findEach({migration: {$ne:'20131221_restore_NaN_history'}}, fields, {batchSize:500}, function(err, after){
|
||||||
|
if (!after) err = '!after';
|
||||||
|
if (err) {count++;return console.error(err);}
|
||||||
|
|
||||||
|
backupUsers.findById(after._id, fields, function(err, before){
|
||||||
|
if (err) {count++;return console.error(err);}
|
||||||
|
|
||||||
|
_.each(['todos','exp'],function(type){
|
||||||
|
if (!_.isEmpty(after.history[type]))
|
||||||
|
after.history[type] = _.filter(after.history[type], filterNaNs);
|
||||||
|
if (before && !_.isEmpty(before.history[type]))
|
||||||
|
after.history[type] = before.history[type].concat(after.history[type]);
|
||||||
|
})
|
||||||
|
|
||||||
|
_.each(['habits','dailys'], function(type){
|
||||||
|
_.each(after[type], function(t){
|
||||||
|
t.history = _.filter(t.history, filterNaNs);
|
||||||
|
var found = before && _.find(before[type],{id:t.id});
|
||||||
|
if (found && found.history) t.history = found.history.concat(t.history);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
liveUsers.update({_id:after._id}, {$set:{history:after.history, dailys:after.dailys, habits:after.habits, migration:'20131221_restore_NaN_history'}, $inc:{_v:1}});
|
||||||
|
//if (--count <= 0) console.log("DONE! " + after._id);
|
||||||
|
if (++count%1000 == 0) console.log(count);
|
||||||
|
if (after._id == '9') console.log('lefnire processed');
|
||||||
|
})
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user