mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-20 23:00:34 +00:00
feat(server): remove the phone number from users service
This commit is contained in:
@@ -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({
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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) => {});
|
||||||
|
};
|
||||||
@@ -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;
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user