Skip to content

Commit

Permalink
Noobaa Account: Remove password hashing
Browse files Browse the repository at this point in the history
Signed-off-by: Ashish Pandey <[email protected]>
  • Loading branch information
aspandey committed Aug 6, 2024
1 parent 7b46193 commit 9180e77
Show file tree
Hide file tree
Showing 6 changed files with 70 additions and 55 deletions.
1 change: 0 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,6 @@
"@smithy/node-http-handler": "3.1.2",
"ajv": "8.17.1",
"aws-sdk": "2.1659.0",
"bcrypt": "5.1.1",
"big-integer": "1.6.52",
"bindings": "1.5.0",
"bufferutil": "4.0.8",
Expand Down
14 changes: 12 additions & 2 deletions src/server/common_services/auth_server.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
'use strict';

const _ = require('lodash');
const bcrypt = require('bcrypt');
const ip_module = require('ip');

const P = require('../../util/promise');
Expand All @@ -20,7 +19,18 @@ const jwt_utils = require('../../util/jwt_utils');
const config = require('../../../config');
const s3_bucket_policy_utils = require('../../endpoint/s3/s3_bucket_policy_utils');

function verify_password(password, target_account) {

if (!password || !target_account.password) {
return true;
}

if (password.unwrap() === target_account.password.unwrap()) {
return true;
} else {
return false;
}
}
/**
*
* CREATE_AUTH
Expand Down Expand Up @@ -66,7 +76,7 @@ function create_auth(req) {
if (!password) return;

return P.resolve()
.then(() => bcrypt.compare(password.unwrap(), target_account.password.unwrap()))
.then(() => verify_password(password, target_account))
.then(match => {
if (!match) {
dbg.log0('password mismatch', email, system_name);
Expand Down
63 changes: 27 additions & 36 deletions src/server/system_services/account_server.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ const _ = require('lodash');
const net = require('net');
const chance = require('chance')();
const GoogleStorage = require('../../util/google_storage_wrap');
const bcrypt = require('bcrypt');
const server_rpc = require('../server_rpc');

const config = require('../../../config');
Expand Down Expand Up @@ -42,6 +41,7 @@ const check_new_azure_connection_timeout = 20 * 1000;
*
*/
async function create_account(req) {

const account = {
_id: (
req.rpc_params.new_system_parameters ?
Expand Down Expand Up @@ -77,10 +77,12 @@ async function create_account(req) {
system_store.parse_system_store_id(req.rpc_params.new_system_parameters.new_system_id) :
req.system._id;

if (req.rpc_params.has_login) {
account.password = req.rpc_params.password;
const password_hash = await bcrypt_password(account.password.unwrap());
account.password = password_hash;
if (req.rpc_params.has_login && req.rpc_params.password) {
if (account.email.unwrap() === '[email protected]') {
account.password = req.rpc_params.password;
} else {
throw new RpcError('Invalid account configuration - Password should not be set');
}
}

if (req.rpc_params.s3_access) {
Expand Down Expand Up @@ -574,7 +576,7 @@ async function reset_password(req) {

const params = req.rpc_params;

const password = await bcrypt_password(params.password.unwrap());
const password = params.password.unwrap();

const changes = {
password: new SensitiveString(password),
Expand Down Expand Up @@ -1334,35 +1336,25 @@ function ensure_support_account() {
}

console.log('CREATING SUPPORT ACCOUNT...');
return bcrypt_password(system_store.get_server_secret())
.then(password => {
const support_account = {
_id: system_store.new_system_store_id(),
name: new SensitiveString('Support'),
email: new SensitiveString('[email protected]'),
password: new SensitiveString(password),
has_login: true,
is_support: true,
};

return system_store.make_changes({
insert: {
accounts: [support_account]
}
});
})
.then(() => console.log('SUPPORT ACCOUNT CREATED'));
const support_account = {
_id: system_store.new_system_store_id(),
name: new SensitiveString('Support'),
email: new SensitiveString('[email protected]'),
has_login: true,
is_support: true,
};

return system_store.make_changes({
insert: {
accounts: [support_account]
}
});
})
.catch(function(err) {
console.error('FAILED CREATE SUPPORT ACCOUNT', err);
});
}

function bcrypt_password(password) {
return P.resolve()
.then(() => password && bcrypt.hash(password, 10));
}

function is_support_or_admin_or_me(system, account, target_account) {
return account.is_support ||
(target_account && String(target_account._id) === String(account._id)) ||
Expand Down Expand Up @@ -1426,10 +1418,6 @@ function validate_create_account_params(req) {
}

if (req.rpc_params.has_login) {
if (!req.rpc_params.password) {
throw new RpcError('BAD_REQUEST', 'Password is missing');
}

// Verify that account with login access have full s3 access permissions.
const { default_resource } = req.rpc_params.new_system_parameters || req.rpc_params;
const allow_bucket_creation = req.rpc_params.new_system_parameters ?
Expand All @@ -1444,17 +1432,20 @@ function validate_create_account_params(req) {
throw new RpcError('BAD_REQUEST', 'Accounts with login access must have full s3 access permissions');
}

} else if (req.rpc_params.password) {
throw new RpcError('BAD_REQUEST', 'Password should not be sent');
}
if (req.rpc_params.password) {
dbg.warn('Password should not be sent; password/has_login', req.rpc_params.password, req.rpc_params.has_login);
}
}

async function verify_authorized_account(req) {
//operator connects by token and doesn't have the password property.

if (req.role === 'operator') {
return true;
}
return bcrypt.compare(req.rpc_params.verification_password.unwrap(), req.account.password.unwrap());

return (req.rpc_params.verification_password.unwrap() === req.account.password.unwrap());
}

function _list_connection_usage(account, credentials) {
Expand Down
2 changes: 1 addition & 1 deletion src/server/system_services/schemas/account_schema.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ module.exports = {

// password login
has_login: { type: 'boolean' },
password: { wrapper: SensitiveString }, // bcrypted password
password: { wrapper: SensitiveString }, // password
next_password_change: { date: true },

// default policy for new buckets
Expand Down
15 changes: 0 additions & 15 deletions src/tools/bcrypt_cli.js

This file was deleted.

30 changes: 30 additions & 0 deletions src/upgrade/upgrade_scripts/5.18.0/remove_account_password.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
/* Copyright (C) 2024 NooBaa */
"use strict";

async function run({ dbg, system_store }) {
try {
dbg.log0('starting upgrade accounts...');
const accounts = system_store.data.accounts
.map(a => a.password && ({
_id: a._id,
$unset: { password: true }
}))
.filter(Boolean);
if (accounts.length > 0) {
dbg.log0(`deleting "passwords" from accounts: ${accounts.map(b => b._id).join(', ')}`);
await system_store.make_changes({ update: { accounts } });
} else {
dbg.log0('upgrade accounts: no upgrade needed...');
}
} catch (err) {
dbg.error('got error while upgrading accounts:', err);
throw err;
}
}


module.exports = {
run,
description: 'Update accounts to remove "password" field'
};

0 comments on commit 9180e77

Please sign in to comment.