mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 14:47:53 +01:00
fix(achievement): Make Costume Contest repeatable
This commit is contained in:
@@ -69,8 +69,9 @@
|
|||||||
"habiticaDayPluralText": "Celebrated <%= number %> Naming Days! Thanks for being a fantastic user.",
|
"habiticaDayPluralText": "Celebrated <%= number %> Naming Days! Thanks for being a fantastic user.",
|
||||||
"achievementDilatory": "Savior of Dilatory",
|
"achievementDilatory": "Savior of Dilatory",
|
||||||
"achievementDilatoryText": "Helped defeat the Dread Drag'on of Dilatory during the 2014 Summer Splash Event!",
|
"achievementDilatoryText": "Helped defeat the Dread Drag'on of Dilatory during the 2014 Summer Splash Event!",
|
||||||
"costumeContest": "2014 Costume Contest",
|
"costumeContest": "Costume Contest",
|
||||||
"costumeContestText": "Participated in the 2014 Halloween Costume Contest. See some of the entries at blog.habitica.com/tagged/cosplay!",
|
"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",
|
"memberSince": "- Member since",
|
||||||
"lastLoggedIn": "- Last logged in",
|
"lastLoggedIn": "- Last logged in",
|
||||||
"notPorted": "This feature is not yet ported from the original site.",
|
"notPorted": "This feature is not yet ported from the original site.",
|
||||||
|
|||||||
@@ -73,9 +73,11 @@ dbUsers.findEach(query, fields, {batchSize:250}, function(err, user) {
|
|||||||
count++;
|
count++;
|
||||||
|
|
||||||
// specify user data to change:
|
// 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}, {$set:set});
|
||||||
|
dbUsers.update({_id:user._id}, {$inc:inc});
|
||||||
|
|
||||||
if (count%progressCount == 0) console.warn(count + ' ' + user._id);
|
if (count%progressCount == 0) console.warn(count + ' ' + user._id);
|
||||||
if (user._id == authorUuid) console.warn(authorName + ' processed');
|
if (user._id == authorUuid) console.warn(authorName + ' processed');
|
||||||
64
migrations/20151116_costume_contest_to_number.js
Normal file
64
migrations/20151116_costume_contest_to_number.js
Normal file
@@ -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:password@ds031379-a0.mongolab.com: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);
|
||||||
|
}
|
||||||
|
|
||||||
@@ -53,11 +53,12 @@ var UserSchema = new Schema({
|
|||||||
perfect: Number,
|
perfect: Number,
|
||||||
habitBirthdays: Number,
|
habitBirthdays: Number,
|
||||||
valentine: Number,
|
valentine: Number,
|
||||||
costumeContest: Boolean,
|
costumeContest: Boolean, // Superseded by costumeContests
|
||||||
nye: Number,
|
nye: Number,
|
||||||
habiticaDays: Number,
|
habiticaDays: Number,
|
||||||
greeting: Number,
|
greeting: Number,
|
||||||
thankyou: Number
|
thankyou: Number,
|
||||||
|
costumeContests: Number
|
||||||
},
|
},
|
||||||
auth: {
|
auth: {
|
||||||
blocked: Boolean,
|
blocked: Boolean,
|
||||||
|
|||||||
@@ -229,11 +229,13 @@ div(ng-if='::profile.achievements.quests.burnout')
|
|||||||
=env.t('achievementBurnoutText')
|
=env.t('achievementBurnoutText')
|
||||||
hr
|
hr
|
||||||
|
|
||||||
div(ng-if='::profile.achievements.costumeContest')
|
div(ng-if='::profile.achievements.costumeContests')
|
||||||
.achievement.achievement-costumeContest
|
.achievement.achievement-costumeContest
|
||||||
h5=env.t('costumeContest')
|
h5=env.t('costumeContest')
|
||||||
small
|
small(ng-if='::profile.achievements.costumeContests === 1')
|
||||||
=env.t('costumeContestText')
|
!=env.t('costumeContestText')
|
||||||
|
small(ng-if='::profile.achievements.costumeContests > 1')
|
||||||
|
!=env.t('costumeContestPluralText', {number: "{{::profile.achievements.costumeContests}}"})
|
||||||
hr
|
hr
|
||||||
|
|
||||||
each card in ['greeting', 'thankyou', 'nye', 'valentine']
|
each card in ['greeting', 'thankyou', 'nye', 'valentine']
|
||||||
|
|||||||
Reference in New Issue
Block a user