ToolJet/server/src/controllers/organizations.controller.ts
vjaris42 e50fa984ee
[Feature] :: Allow users to be filtered via status (#4908)
* add: user filter via status

* fix: typo in options name

* refactor: add All options to status filters
2022-12-19 12:36:08 +05:30

118 lines
4.4 KiB
TypeScript

import { Body, Controller, Get, NotFoundException, Param, Patch, Post, UseGuards, Query } from '@nestjs/common';
import { OrganizationsService } from '@services/organizations.service';
import { decamelizeKeys } from 'humps';
import { User } from 'src/decorators/user.decorator';
import { JwtAuthGuard } from '../../src/modules/auth/jwt-auth.guard';
import { AuthService } from '@services/auth.service';
import { AppAbility } from 'src/modules/casl/casl-ability.factory';
import { CheckPolicies } from 'src/modules/casl/check_policies.decorator';
import { PoliciesGuard } from 'src/modules/casl/policies.guard';
import { User as UserEntity } from 'src/entities/user.entity';
import { ConfigService } from '@nestjs/config';
import { MultiOrganizationGuard } from 'src/modules/auth/multi-organization.guard';
import { OrganizationCreateDto } from '@dto/organization-create.dto';
@Controller('organizations')
export class OrganizationsController {
constructor(
private organizationsService: OrganizationsService,
private authService: AuthService,
private readonly configService: ConfigService
) {}
@UseGuards(JwtAuthGuard, PoliciesGuard)
@CheckPolicies((ability: AppAbility) => ability.can('viewAllUsers', UserEntity))
@Get('users')
async getUsers(@User() user, @Query() query) {
const { page, email, firstName, lastName, status } = query;
const filterOptions = {
...(email && { email }),
...(firstName && { firstName }),
...(lastName && { lastName }),
...(status && { status }),
};
const usersCount = await this.organizationsService.usersCount(user, filterOptions);
let users = [];
if (usersCount > 0) users = await this.organizationsService.fetchUsers(user, page, filterOptions);
const meta = {
total_pages: Math.ceil(usersCount / 10),
total_count: usersCount,
current_page: parseInt(page || 1),
};
const response = {
meta,
users,
};
return decamelizeKeys(response);
}
@UseGuards(JwtAuthGuard)
@Get('users/suggest')
async getUserSuggestions(@User() user, @Query('input') searchInput) {
const users = await this.organizationsService.fetchUsersByValue(user, searchInput);
const response = {
users,
};
return decamelizeKeys(response);
}
@UseGuards(JwtAuthGuard)
@Get()
async get(@User() user) {
const result = await this.organizationsService.fetchOrganizations(user);
return decamelizeKeys({ organizations: result });
}
@UseGuards(JwtAuthGuard, MultiOrganizationGuard)
@Post()
async create(@User() user, @Body() organizationCreateDto: OrganizationCreateDto) {
const result = await this.organizationsService.create(organizationCreateDto.name, user);
if (!result) {
throw new Error();
}
return await this.authService.switchOrganization(result.id, user, true);
}
@Get(['/:organizationId/public-configs', '/public-configs'])
async getOrganizationDetails(@Param('organizationId') organizationId: string) {
if (!organizationId && this.configService.get<string>('DISABLE_MULTI_WORKSPACE') === 'true') {
// Request from single organization login page - find one from organization and setting
organizationId = (await this.organizationsService.getSingleOrganization())?.id;
}
if (!organizationId) {
throw new NotFoundException();
}
const result = await this.organizationsService.fetchOrganizationDetails(organizationId, [true], true, true);
return decamelizeKeys({ ssoConfigs: result });
}
@UseGuards(JwtAuthGuard, PoliciesGuard)
@CheckPolicies((ability: AppAbility) => ability.can('updateOrganizations', UserEntity))
@Get('/configs')
async getConfigs(@User() user) {
const result = await this.organizationsService.fetchOrganizationDetails(user.organizationId);
return decamelizeKeys({ organizationDetails: result });
}
@UseGuards(JwtAuthGuard, PoliciesGuard)
@CheckPolicies((ability: AppAbility) => ability.can('updateOrganizations', UserEntity))
@Patch()
async update(@Body() body, @User() user) {
await this.organizationsService.updateOrganization(user.organizationId, body);
return {};
}
@UseGuards(JwtAuthGuard, PoliciesGuard)
@CheckPolicies((ability: AppAbility) => ability.can('updateOrganizations', UserEntity))
@Patch('/configs')
async updateConfigs(@Body() body, @User() user) {
const result: any = await this.organizationsService.updateOrganizationConfigs(user.organizationId, body);
return decamelizeKeys({ id: result.id });
}
}