codecombat/scripts/mongodb/queries/patches.js

39 lines
1.7 KiB
JavaScript

// Finds all patches and denorms their target names and creators.
var patches = db.patches.find({status:'pending'}).toArray();
for(var i in patches) {
var patch = patches[i];
var collection = null;
if(patch.target.collection === 'level') collection = db.levels;
if(patch.target.collection === 'level_component') collection = db.level.components;
if(patch.target.collection === 'level_system') collection = db.level.systems;
if(patch.target.collection === 'thang_type') collection = db.thang.types;
if(patch.target.collection === 'achievement') collection = db.achievements;
if(patch.target.collection === 'article') collection = db.articles;
if(patch.target.collection === 'campaign') collection = db.campaigns;
if(patch.target.collection === 'poll') collection = db.polls;
if(collection === null) {
print('could not find collection', patch.target.collection);
continue;
}
var target = collection.findOne({original:patch.target.original, name:{$exists:true}});
if(target === null)
target = collection.findOne({_id:ObjectId(patch.target.original), name:{$exists:true}});
var creator = db.users.findOne({_id:patch.creator});
if(target === null) {
print('No target for patch from', patch.target.collection);
continue;
}
if(creator === null) {
print(target.name, 'made by unknown person...');
continue;
}
var editor = patch.target.collection + '/';
if(editor === 'level_component/' || editor === 'level_system/')
editor = 'level/items?' + patch.target.collection + '=';
if(editor === 'thang_type/')
editor = 'thang/';
var url = 'http://localhost:3000/editor/' + editor + target.slug;
print(url + '\t' + creator.name + '\t' + target.name);
}