feat(server): remove the phone number from users service

This commit is contained in:
a.bouhuolia
2023-04-06 03:08:06 +02:00
parent 85b24c7a4f
commit e4a647376c
6 changed files with 31 additions and 75 deletions

View File

@@ -11,10 +11,10 @@ import AcceptInviteUserService from '@/services/InviteUsers/AcceptInviteUser';
@Service() @Service()
export default class InviteUsersController extends BaseController { export default class InviteUsersController extends BaseController {
@Inject() @Inject()
inviteUsersService: InviteTenantUserService; private inviteUsersService: InviteTenantUserService;
@Inject() @Inject()
acceptInviteService: AcceptInviteUserService; private acceptInviteService: AcceptInviteUserService;
/** /**
* Routes that require authentication. * Routes that require authentication.
@@ -68,13 +68,13 @@ export default class InviteUsersController extends BaseController {
/** /**
* Invite DTO schema validation. * Invite DTO schema validation.
* @returns {ValidationChain[]}
*/ */
get inviteUserDTO() { private get inviteUserDTO() {
return [ return [
check('first_name').exists().trim().escape(), check('first_name').exists().trim().escape(),
check('last_name').exists().trim().escape(), check('last_name').exists().trim().escape(),
check('phone_number').exists().trim().escape(), check('password').exists().trim().escape().isLength({ min: 5 }),
check('password').exists().trim().escape(),
param('token').exists().trim().escape(), param('token').exists().trim().escape(),
]; ];
} }
@@ -85,17 +85,13 @@ export default class InviteUsersController extends BaseController {
* @param {Response} res - Response object. * @param {Response} res - Response object.
* @param {NextFunction} next - Next function. * @param {NextFunction} next - Next function.
*/ */
async sendInvite(req: Request, res: Response, next: Function) { private async sendInvite(req: Request, res: Response, next: Function) {
const sendInviteDTO = this.matchedBodyData(req); const sendInviteDTO = this.matchedBodyData(req);
const { tenantId } = req; const { tenantId } = req;
const { user } = req; const { user } = req;
try { try {
const { invite } = await this.inviteUsersService.sendInvite( await this.inviteUsersService.sendInvite(tenantId, sendInviteDTO, user);
tenantId,
sendInviteDTO,
user
);
return res.status(200).send({ return res.status(200).send({
type: 'success', type: 'success',
code: 'INVITE.SENT.SUCCESSFULLY', code: 'INVITE.SENT.SUCCESSFULLY',
@@ -112,7 +108,7 @@ export default class InviteUsersController extends BaseController {
* @param {Response} res - Response object. * @param {Response} res - Response object.
* @param {NextFunction} next - Next function. * @param {NextFunction} next - Next function.
*/ */
async resendInvite(req: Request, res: Response, next: NextFunction) { private async resendInvite(req: Request, res: Response, next: NextFunction) {
const { tenantId, user } = req; const { tenantId, user } = req;
const { userId } = req.params; const { userId } = req.params;
@@ -135,7 +131,7 @@ export default class InviteUsersController extends BaseController {
* @param {Response} res - * @param {Response} res -
* @param {NextFunction} next - * @param {NextFunction} next -
*/ */
async accept(req: Request, res: Response, next: Function) { private async accept(req: Request, res: Response, next: Function) {
const inviteUserInput: IInviteUserInput = this.matchedBodyData(req, { const inviteUserInput: IInviteUserInput = this.matchedBodyData(req, {
locations: ['body'], locations: ['body'],
includeOptionals: true, includeOptionals: true,
@@ -161,7 +157,7 @@ export default class InviteUsersController extends BaseController {
* @param {Response} res - * @param {Response} res -
* @param {NextFunction} next - * @param {NextFunction} next -
*/ */
async invited(req: Request, res: Response, next: Function) { private async invited(req: Request, res: Response, next: Function) {
const { token } = req.params; const { token } = req.params;
try { try {
@@ -181,7 +177,12 @@ export default class InviteUsersController extends BaseController {
/** /**
* Handles the service error. * Handles the service error.
*/ */
handleServicesError(error, req: Request, res: Response, next: Function) { private handleServicesError(
error,
req: Request,
res: Response,
next: Function
) {
if (error instanceof ServiceError) { if (error instanceof ServiceError) {
if (error.errorType === 'EMAIL_EXISTS') { if (error.errorType === 'EMAIL_EXISTS') {
return res.status(400).send({ return res.status(400).send({

View File

@@ -47,7 +47,6 @@ export default class UsersController extends BaseController {
check('first_name').exists(), check('first_name').exists(),
check('last_name').exists(), check('last_name').exists(),
check('email').exists().isEmail(), check('email').exists().isEmail(),
check('phone_number').optional().isMobilePhone(),
check('role_id').exists().isNumeric().toInt(), check('role_id').exists().isNumeric().toInt(),
], ],
this.validationResult, this.validationResult,

View File

@@ -0,0 +1,9 @@
exports.up = function (knex) {
return knex.schema.table('users', (table) => {
table.dropColumn('phone_number');
});
};
exports.down = function (knex) {
return knex.schema.table('users', (table) => {});
};

View File

@@ -9,7 +9,6 @@ export interface ISystemUser extends Model {
active: boolean; active: boolean;
password: string; password: string;
email: string; email: string;
phoneNumber: string;
roleId: number; roleId: number;
tenantId: number; tenantId: number;
@@ -26,7 +25,6 @@ export interface ISystemUserDTO {
firstName: string; firstName: string;
lastName: string; lastName: string;
password: string; password: string;
phoneNumber: string;
active: boolean; active: boolean;
email: string; email: string;
roleId?: number; roleId?: number;
@@ -35,7 +33,6 @@ export interface ISystemUserDTO {
export interface IEditUserDTO { export interface IEditUserDTO {
firstName: string; firstName: string;
lastName: string; lastName: string;
phoneNumber: string;
active: boolean; active: boolean;
email: string; email: string;
roleId: number; roleId: number;
@@ -44,7 +41,6 @@ export interface IEditUserDTO {
export interface IInviteUserInput { export interface IInviteUserInput {
firstName: string; firstName: string;
lastName: string; lastName: string;
phoneNumber: string;
password: string; password: string;
} }
export interface IUserInvite { export interface IUserInvite {
@@ -111,7 +107,6 @@ export interface ITenantUser {
id?: number; id?: number;
firstName: string; firstName: string;
lastName: string; lastName: string;
phoneNumber: string;
active: boolean; active: boolean;
email: string; email: string;
roleId?: number; roleId?: number;

View File

@@ -3,8 +3,6 @@ import moment from 'moment';
import { ServiceError } from '@/exceptions'; import { ServiceError } from '@/exceptions';
import { Invite, SystemUser, Tenant } from '@/system/models'; import { Invite, SystemUser, Tenant } from '@/system/models';
import { hashPassword } from 'utils'; import { hashPassword } from 'utils';
import TenancyService from '@/services/Tenancy/TenancyService';
import InviteUsersMailMessages from '@/services/InviteUsers/InviteUsersMailMessages';
import events from '@/subscribers/events'; import events from '@/subscribers/events';
import { import {
IAcceptInviteEventPayload, IAcceptInviteEventPayload,
@@ -12,29 +10,13 @@ import {
ICheckInviteEventPayload, ICheckInviteEventPayload,
IUserInvite, IUserInvite,
} from '@/interfaces'; } from '@/interfaces';
import TenantsManagerService from '@/services/Tenancy/TenantsManager';
import { ERRORS } from './constants'; import { ERRORS } from './constants';
import { EventPublisher } from '@/lib/EventPublisher/EventPublisher'; import { EventPublisher } from '@/lib/EventPublisher/EventPublisher';
@Service() @Service()
export default class AcceptInviteUserService { export default class AcceptInviteUserService {
@Inject() @Inject()
eventPublisher: EventPublisher; private eventPublisher: EventPublisher;
@Inject()
tenancy: TenancyService;
@Inject('logger')
logger: any;
@Inject()
mailMessages: InviteUsersMailMessages;
@Inject('repositories')
sysRepositories: any;
@Inject()
tenantsManager: TenantsManagerService;
/** /**
* Accept the received invite. * Accept the received invite.
@@ -50,9 +32,6 @@ export default class AcceptInviteUserService {
// Retrieve the invite token or throw not found error. // Retrieve the invite token or throw not found error.
const inviteToken = await this.getInviteTokenOrThrowError(token); const inviteToken = await this.getInviteTokenOrThrowError(token);
// Validates the user phone number.
await this.validateUserPhoneNumberNotExists(inviteUserDTO.phoneNumber);
// Hash the given password. // Hash the given password.
const hashedPassword = await hashPassword(inviteUserDTO.password); const hashedPassword = await hashPassword(inviteUserDTO.password);

View File

@@ -17,20 +17,17 @@ import { EventPublisher } from '@/lib/EventPublisher/EventPublisher';
@Service() @Service()
export default class UsersService { export default class UsersService {
@Inject('logger')
logger: any;
@Inject('repositories') @Inject('repositories')
repositories: any; private repositories: any;
@Inject() @Inject()
rolesService: RolesService; private rolesService: RolesService;
@Inject() @Inject()
tenancy: HasTenancyService; private tenancy: HasTenancyService;
@Inject() @Inject()
eventPublisher: EventPublisher; private eventPublisher: EventPublisher;
/** /**
* Creates a new user. * Creates a new user.
@@ -46,7 +43,7 @@ export default class UsersService {
authorizedUser: ISystemUser authorizedUser: ISystemUser
): Promise<any> { ): Promise<any> {
const { User } = this.tenancy.models(tenantId); const { User } = this.tenancy.models(tenantId);
const { email, phoneNumber } = editUserDTO; const { email } = editUserDTO;
// Retrieve the tenant user or throw not found service error. // Retrieve the tenant user or throw not found service error.
const oldTenantUser = await this.getTenantUserOrThrowError( const oldTenantUser = await this.getTenantUserOrThrowError(
@@ -62,9 +59,6 @@ export default class UsersService {
// Validate user email should be unique. // Validate user email should be unique.
await this.validateUserEmailUniquiness(tenantId, email, userId); await this.validateUserEmailUniquiness(tenantId, email, userId);
// Validate user phone number should be unique.
await this.validateUserPhoneNumberUniqiness(tenantId, phoneNumber, userId);
// Retrieve the given role or throw not found service error. // Retrieve the given role or throw not found service error.
const role = await this.rolesService.getRoleOrThrowError( const role = await this.rolesService.getRoleOrThrowError(
tenantId, tenantId,
@@ -295,27 +289,6 @@ export default class UsersService {
} }
}; };
/**
* Validate user phone number should be unique.
* @param {string} phoneNumber -
* @param {number} userId -
*/
private validateUserPhoneNumberUniqiness = async (
tenantId: number,
phoneNumber: string,
userId: number
) => {
const { User } = this.tenancy.models(tenantId);
const userByPhoneNumber = await User.query()
.findOne('phone_number', phoneNumber)
.whereNot('id', userId);
if (userByPhoneNumber) {
throw new ServiceError(ERRORS.PHONE_NUMBER_ALREADY_EXIST);
}
};
/** /**
* Validate the authorized user cannot mutate its role. * Validate the authorized user cannot mutate its role.
* @param {ITenantUser} oldTenantUser * @param {ITenantUser} oldTenantUser