Skip to content

Commit

Permalink
📜 feat: Add script to set balance for user (danny-avila#4506)
Browse files Browse the repository at this point in the history
* feat: Add script to set balance for user

* Show current balance before updating
  • Loading branch information
dennis531 authored and olivierhub committed Dec 5, 2024
1 parent 7a7df89 commit c0c165b
Show file tree
Hide file tree
Showing 2 changed files with 125 additions and 0 deletions.
124 changes: 124 additions & 0 deletions config/set-balance.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
const path = require('path');
require('module-alias')({ base: path.resolve(__dirname, '..', 'api') });
const { askQuestion, silentExit } = require('./helpers');
const { isEnabled } = require('~/server/utils/handleText');
const User = require('~/models/User');
const connect = require('./connect');
const Balance = require('~/models/Balance');

(async () => {
await connect();

/**
* Show the welcome / help menu
*/
console.purple('--------------------------');
console.purple('Set balance to a user account!');
console.purple('--------------------------');
/**
* Set up the variables we need and get the arguments if they were passed in
*/
let email = '';
let amount = '';
// If we have the right number of arguments, lets use them
if (process.argv.length >= 3) {
email = process.argv[2];
amount = process.argv[3];
} else {
console.orange('Usage: npm run set-balance <email> <amount>');
console.orange('Note: if you do not pass in the arguments, you will be prompted for them.');
console.purple('--------------------------');
// console.purple(`[DEBUG] Args Length: ${process.argv.length}`);
}

if (!process.env.CHECK_BALANCE) {
console.red(
'Error: CHECK_BALANCE environment variable is not set! Configure it to use it: `CHECK_BALANCE=true`',
);
silentExit(1);
}
if (isEnabled(process.env.CHECK_BALANCE) === false) {
console.red(
'Error: CHECK_BALANCE environment variable is set to `false`! Please configure: `CHECK_BALANCE=true`',
);
silentExit(1);
}

/**
* If we don't have the right number of arguments, lets prompt the user for them
*/
if (!email) {
email = await askQuestion('Email:');
}
// Validate the email
if (!email.includes('@')) {
console.red('Error: Invalid email address!');
silentExit(1);
}

// Validate the user
const user = await User.findOne({ email }).lean();
if (!user) {
console.red('Error: No user with that email was found!');
silentExit(1);
} else {
console.purple(`Found user: ${user.email}`);
}

let balance = await Balance.findOne({ user: user._id }).lean();
if (!balance) {
console.purple('User has no balance!');
} else {
console.purple(`Current Balance: ${balance.tokenCredits}`);
}

if (!amount) {
amount = await askQuestion('amount:');
}
// Validate the amount
if (!amount) {
console.red('Error: Please specify an amount!');
silentExit(1);
}

/**
* Now that we have all the variables we need, lets set the balance
*/
let result;
try {
result = await Balance.findOneAndUpdate(
{ user: user._id },
{ tokenCredits: amount },
{ upsert: true, new: true },
).lean();
} catch (error) {
console.red('Error: ' + error.message);
console.error(error);
silentExit(1);
}

// Check the result
if (!result?.tokenCredits) {
console.red('Error: Something went wrong while updating the balance!');
console.error(result);
silentExit(1);
}

// Done!
console.green('Balance set successfully!');
console.purple(`New Balance: ${result.tokenCredits}`);
silentExit(0);
})();

process.on('uncaughtException', (err) => {
if (!err.message.includes('fetch failed')) {
console.error('There was an uncaught error:');
console.error(err);
}

if (err.message.includes('fetch failed')) {
return;
} else {
process.exit(1);
}
});
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
"scripts": {
"update": "node config/update.js",
"add-balance": "node config/add-balance.js",
"set-balance": "node config/set-balance.js",
"list-balances": "node config/list-balances.js",
"user-stats": "node config/user-stats.js",
"rebuild:package-lock": "node config/packages",
Expand Down

0 comments on commit c0c165b

Please sign in to comment.