diff --git a/migrations/20170811_pinned_items.js b/migrations/20170811_pinned_items.js new file mode 100644 index 0000000000..3c12a01531 --- /dev/null +++ b/migrations/20170811_pinned_items.js @@ -0,0 +1,108 @@ +var updateStore = require('../website/common/script/libs/updateStore'); +var getItemInfo = require('../website/common/script/libs/getItemInfo'); + +var migrationName = '20170811_pinned_items.js'; +var authorName = 'paglias'; // in case script author needs to know when their ... +var authorUuid = 'ed4c688c-6652-4a92-9d03-a5a79844174a'; //... own data is done + +/* + * Migrate existing in app rewards lists to pinned items + */ + +var monk = require('monk'); +var connectionString = 'mongodb://localhost:27017/habitrpg?auto_reconnect=true'; // FOR TEST DATABASE +var dbUsers = monk(connectionString).get('users', { castIds: false }); + +function processUsers(lastId) { + // specify a query to limit the affected users (empty for all users): + var query = { + 'migration':{$ne:migrationName}, + }; + + if (lastId) { + query._id = { + $gt: lastId + } + } + + return dbUsers.find(query, { + sort: {_id: 1}, + limit: 250, + }) + .then(updateUsers) + .catch(function (err) { + console.log(err); + return exiting(1, 'ERROR! ' + err); + }); +} + +var progressCount = 1000; +var count = 0; + +function updateUsers (users) { + if (!users || users.length === 0) { + console.warn('All appropriate users found and modified.'); + displayData(); + return; + } + + var userPromises = users.map(updateUser); + var lastUser = users[users.length - 1]; + + return Promise.all(userPromises) + .then(function () { + processUsers(lastUser._id); + }); +} + +function updateUser (user) { + count++; + + var set = {'migration': migrationName}; + + var oldRewardsList = updateStore(user); + var newPinnedItems = [ + { + type: 'armoire', + path: 'armoire', + }, + { + type: 'potion', + path: 'potion', + }, + ]; + + oldRewardsList.forEach(item => { + var type = 'marketGear'; + + var itemInfo = getItemInfo(user, 'marketGear', item); + newPinnedItems.push({ + type, + path: itemInfo.path, + }) + }); + + set.pinnedItems = newPinnedItems; + + if (count % progressCount == 0) console.warn(count + ' ' + user._id); + if (user._id == authorUuid) console.warn(authorName + ' processed'); + + return dbUsers.update({_id: user._id}, {$set:set}); +} + +function displayData() { + console.warn('\n' + count + ' users processed\n'); + return exiting(0); +} + +function exiting(code, msg) { + code = code || 0; // 0 = success + if (code && !msg) { msg = 'ERROR!'; } + if (msg) { + if (code) { console.error(msg); } + else { console.log( msg); } + } + process.exit(code); +} + +module.exports = processUsers; diff --git a/test/common/ops/buyArmoire.js b/test/common/ops/buyArmoire.js index 22dcc8a442..facf87132c 100644 --- a/test/common/ops/buyArmoire.js +++ b/test/common/ops/buyArmoire.js @@ -68,23 +68,6 @@ describe('shared.ops.buyArmoire', () => { done(); } }); - - it('does not open without Ultimate Gear achievement', (done) => { - user.achievements.ultimateGearSets = {healer: false, wizard: false, rogue: false, warrior: false}; - - try { - buyArmoire(user); - } catch (err) { - expect(err).to.be.an.instanceof(NotAuthorized); - expect(err.message).to.equal(i18n.t('cannotBuyItem')); - expect(user.items.gear.owned).to.eql({ - weapon_warrior_0: true, - }); - expect(user.items.food).to.be.empty; - expect(user.stats.exp).to.eql(0); - done(); - } - }); }); context('non-gear awards', () => { diff --git a/website/client/components/inventory/equipment/attributesPopover.vue b/website/client/components/inventory/equipment/attributesPopover.vue index 1beca9046c..a65347bd65 100644 --- a/website/client/components/inventory/equipment/attributesPopover.vue +++ b/website/client/components/inventory/equipment/attributesPopover.vue @@ -1,7 +1,7 @@