Skip to content

Commit

Permalink
fix(achievement): Make Costume Contest repeatable
Browse files Browse the repository at this point in the history
  • Loading branch information
SabreCat committed Nov 16, 2015
1 parent bf0f363 commit e73c7be
Show file tree
Hide file tree
Showing 5 changed files with 78 additions and 8 deletions.
5 changes: 3 additions & 2 deletions common/locales/en/generic.json
Original file line number Diff line number Diff line change
Expand Up @@ -69,8 +69,9 @@
"habiticaDayPluralText": "Celebrated <%= number %> Naming Days! Thanks for being a fantastic user.",
"achievementDilatory": "Savior of Dilatory",
"achievementDilatoryText": "Helped defeat the Dread Drag'on of Dilatory during the 2014 Summer Splash Event!",
"costumeContest": "2014 Costume Contest",
"costumeContestText": "Participated in the 2014 Halloween Costume Contest. See some of the entries at blog.habitica.com/tagged/cosplay!",
"costumeContest": "Costume Contest",
"costumeContestText": "Participated in the Habitoween Costume Contest. See some of the entries <a href='http://blog.habitrpg.com/tagged/cosplay' target='_blank'>on the Habitica blog</a>!",
"costumeContestPluralText": "Participated in <%= number %> Habitoween Costume Contests. See some of the entries <a href='http://blog.habitrpg.com/tagged/cosplay' target='_blank'>on the Habitica blog</a>!",
"memberSince": "- Member since",
"lastLoggedIn": "- Last logged in",
"notPorted": "This feature is not yet ported from the original site.",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,9 +73,11 @@ dbUsers.findEach(query, fields, {batchSize:250}, function(err, user) {
count++;

// specify user data to change:
var set = {'migration':migrationName, 'achievements.costumeContest':true};
var set = {'migration':migrationName};
var inc = {'achievements.costumeContests':1};

dbUsers.update({_id:user._id}, {$set:set});
dbUsers.update({_id:user._id}, {$inc:inc});

if (count%progressCount == 0) console.warn(count + ' ' + user._id);
if (user._id == authorUuid) console.warn(authorName + ' processed');
Expand Down
64 changes: 64 additions & 0 deletions migrations/20151116_costume_contest_to_number.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
var migrationName = '20151116_costume_contest_to_number.js';
var authorName = 'Sabe'; // in case script author needs to know when their ...
var authorUuid = '7f14ed62-5408-4e1b-be83-ada62d504931'; //... own data is done

/*
* Change Costume Contest achievement from Boolean to Number, so people can win repeatedly
*/

var dbserver = 'localhost:27017'; // FOR TEST DATABASE
// var dbserver = 'username:[email protected]:31379'; // FOR PRODUCTION DATABASE
var dbname = 'habitrpg';

var mongo = require('mongoskin');
var _ = require('lodash');

var dbUsers = mongo.db(dbserver + '/' + dbname + '?auto_reconnect').collection('users');

// specify a query to limit the affected users (empty for all users):
var query = {
'achievements.costumeContest':true
};

// specify fields we are interested in to limit retrieved data (empty if we're not reading data):
var fields = {
'achievements.costumeContest':1
};

console.warn('Updating users...');
var progressCount = 1000;
var count = 0;
dbUsers.findEach(query, fields, {batchSize:250}, function(err, user) {
if (err) { return exiting(1, 'ERROR! ' + err); }
if (!user) {
console.warn('All appropriate users found and modified.');
return displayData();
}
count++;

// specify user data to change:
var set = {'achievements.costumeContests':1};

dbUsers.update({_id:user._id}, {$set:set});

if (count%progressCount == 0) console.warn(count + ' ' + user._id);
if (user._id == authorUuid) console.warn(authorName + ' processed');
});


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);
}

5 changes: 3 additions & 2 deletions website/src/models/user.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,12 @@ var UserSchema = new Schema({
perfect: Number,
habitBirthdays: Number,
valentine: Number,
costumeContest: Boolean,
costumeContest: Boolean, // Superseded by costumeContests
nye: Number,
habiticaDays: Number,
greeting: Number,
thankyou: Number
thankyou: Number,
costumeContests: Number
},
auth: {
blocked: Boolean,
Expand Down
8 changes: 5 additions & 3 deletions website/views/shared/profiles/achievements.jade
Original file line number Diff line number Diff line change
Expand Up @@ -229,11 +229,13 @@ div(ng-if='::profile.achievements.quests.burnout')
=env.t('achievementBurnoutText')
hr

div(ng-if='::profile.achievements.costumeContest')
div(ng-if='::profile.achievements.costumeContests')
.achievement.achievement-costumeContest
h5=env.t('costumeContest')
small
=env.t('costumeContestText')
small(ng-if='::profile.achievements.costumeContests === 1')
!=env.t('costumeContestText')
small(ng-if='::profile.achievements.costumeContests > 1')
!=env.t('costumeContestPluralText', {number: "{{::profile.achievements.costumeContests}}"})
hr

each card in ['greeting', 'thankyou', 'nye', 'valentine']
Expand Down

0 comments on commit e73c7be

Please sign in to comment.