mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 22:57:21 +01:00
feat(usernames): Veteran Pet ladder award for affected users
This commit is contained in:
91
migrations/users/20181019_veteran_pet_ladder.js
Normal file
91
migrations/users/20181019_veteran_pet_ladder.js
Normal file
@@ -0,0 +1,91 @@
|
|||||||
|
/* eslint-disable no-console */
|
||||||
|
import { model as User } from '../website/server/models/user';
|
||||||
|
|
||||||
|
function processUsers (lastId) {
|
||||||
|
let query = {
|
||||||
|
'flags.verifiedUsername': true,
|
||||||
|
};
|
||||||
|
|
||||||
|
let fields = {
|
||||||
|
'items.pets': 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (lastId) {
|
||||||
|
query._id = {
|
||||||
|
$gt: lastId,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return User.find(query)
|
||||||
|
.limit(250)
|
||||||
|
.sort({_id: 1})
|
||||||
|
.select(fields)
|
||||||
|
.then(updateUsers)
|
||||||
|
.catch((err) => {
|
||||||
|
console.log(err);
|
||||||
|
return exiting(1, `ERROR! ${err}`);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
let progressCount = 1000;
|
||||||
|
let count = 0;
|
||||||
|
|
||||||
|
function updateUsers (users) {
|
||||||
|
if (!users || users.length === 0) {
|
||||||
|
console.warn('All appropriate users found and modified.');
|
||||||
|
displayData();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let userPromises = users.map(updateUser);
|
||||||
|
let lastUser = users[users.length - 1];
|
||||||
|
|
||||||
|
return Promise.all(userPromises)
|
||||||
|
.then(() => {
|
||||||
|
processUsers(lastUser._id);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateUser (user) {
|
||||||
|
count++;
|
||||||
|
|
||||||
|
let set = {};
|
||||||
|
|
||||||
|
if (user.items.pets['Bear-Veteran']) {
|
||||||
|
set['items.pets.Fox-Veteran'] = 5;
|
||||||
|
} else if (user.items.pets['Lion-Veteran']) {
|
||||||
|
set['items.pets.Bear-Veteran'] = 5;
|
||||||
|
} else if (user.items.pets['Tiger-Veteran']) {
|
||||||
|
set['items.pets.Lion-Veteran'] = 5;
|
||||||
|
} else if (user.items.pets['Wolf-Veteran']) {
|
||||||
|
set['items.pets.Tiger-Veteran'] = 5;
|
||||||
|
} else {
|
||||||
|
set['items.pets.Wolf-Veteran'] = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count % progressCount === 0) console.warn(`${count} ${user._id}`);
|
||||||
|
|
||||||
|
return User.update({_id: user._id}, {$set: set}).exec();
|
||||||
|
}
|
||||||
|
|
||||||
|
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;
|
||||||
@@ -19,6 +19,7 @@
|
|||||||
"veteranTiger": "Veteran Tiger",
|
"veteranTiger": "Veteran Tiger",
|
||||||
"veteranLion": "Veteran Lion",
|
"veteranLion": "Veteran Lion",
|
||||||
"veteranBear": "Veteran Bear",
|
"veteranBear": "Veteran Bear",
|
||||||
|
"veteranFox": "Veteran Fox",
|
||||||
"cerberusPup": "Cerberus Pup",
|
"cerberusPup": "Cerberus Pup",
|
||||||
"hydra": "Hydra",
|
"hydra": "Hydra",
|
||||||
"mantisShrimp": "Mantis Shrimp",
|
"mantisShrimp": "Mantis Shrimp",
|
||||||
|
|||||||
@@ -71,6 +71,7 @@ let specialPets = {
|
|||||||
'Orca-Base': 'orca',
|
'Orca-Base': 'orca',
|
||||||
'Bear-Veteran': 'veteranBear',
|
'Bear-Veteran': 'veteranBear',
|
||||||
'Hippogriff-Hopeful': 'hopefulHippogriffPet',
|
'Hippogriff-Hopeful': 'hopefulHippogriffPet',
|
||||||
|
'Fox-Veteran': 'veteranFox',
|
||||||
};
|
};
|
||||||
|
|
||||||
let specialMounts = {
|
let specialMounts = {
|
||||||
|
|||||||
BIN
website/raw_sprites/spritesmith/stable/pets/Pet-Fox-Veteran.png
Normal file
BIN
website/raw_sprites/spritesmith/stable/pets/Pet-Fox-Veteran.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 3.8 KiB |
BIN
website/raw_sprites/spritesmith_large/promo_veteran_pets.png
Normal file
BIN
website/raw_sprites/spritesmith_large/promo_veteran_pets.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 19 KiB |
@@ -62,7 +62,20 @@ api.updateUsername = {
|
|||||||
// save username
|
// save username
|
||||||
user.auth.local.lowerCaseUsername = newUsername.toLowerCase();
|
user.auth.local.lowerCaseUsername = newUsername.toLowerCase();
|
||||||
user.auth.local.username = newUsername;
|
user.auth.local.username = newUsername;
|
||||||
|
if (!user.flags.verifiedUsername) {
|
||||||
user.flags.verifiedUsername = true;
|
user.flags.verifiedUsername = true;
|
||||||
|
if (user.items.pets['Bear-Veteran']) {
|
||||||
|
user.items.pets['Fox-Veteran'] = 5;
|
||||||
|
} else if (user.items.pets['Lion-Veteran']) {
|
||||||
|
user.items.pets['Bear-Veteran'] = 5;
|
||||||
|
} else if (user.items.pets['Tiger-Veteran']) {
|
||||||
|
user.items.pets['Lion-Veteran'] = 5;
|
||||||
|
} else if (user.items.pets['Wolf-Veteran']) {
|
||||||
|
user.items.pets['Tiger-Veteran'] = 5;
|
||||||
|
} else {
|
||||||
|
user.items.pets['Wolf-Veteran'] = 5;
|
||||||
|
}
|
||||||
|
}
|
||||||
await user.save();
|
await user.save();
|
||||||
|
|
||||||
res.respond(200, { username: req.body.username });
|
res.respond(200, { username: req.body.username });
|
||||||
|
|||||||
@@ -125,6 +125,7 @@ function _setUpNewUser (user) {
|
|||||||
let iterableFlags = user.flags.toObject();
|
let iterableFlags = user.flags.toObject();
|
||||||
|
|
||||||
user.items.quests.dustbunnies = 1;
|
user.items.quests.dustbunnies = 1;
|
||||||
|
user.items.pets['Wolf-Veteran'] = 5; // Thank-you for users joining during username upheaval
|
||||||
user.purchased.background.violet = true;
|
user.purchased.background.violet = true;
|
||||||
user.preferences.background = 'violet';
|
user.preferences.background = 'violet';
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user