first commit
This commit is contained in:
commit
23b7266db6
8
.env
Normal file
8
.env
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
POSTGRES_HOST=127.0.0.1
|
||||||
|
POSTGRES_PORT=5432
|
||||||
|
POSTGRES_USER=postgres
|
||||||
|
POSTGRES_PASSWORD=postgres
|
||||||
|
POSTGRES_DATABASE=remedify-users-local
|
||||||
|
PORT=3000
|
||||||
|
MODE=DEV
|
||||||
|
RUN_MIGRATIONS=false
|
||||||
24
.eslintrc.js
Normal file
24
.eslintrc.js
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
module.exports = {
|
||||||
|
parser: '@typescript-eslint/parser',
|
||||||
|
parserOptions: {
|
||||||
|
project: 'tsconfig.json',
|
||||||
|
tsconfigRootDir: __dirname,
|
||||||
|
sourceType: 'module',
|
||||||
|
},
|
||||||
|
plugins: ['@typescript-eslint/eslint-plugin'],
|
||||||
|
extends: [
|
||||||
|
'plugin:@typescript-eslint/recommended',
|
||||||
|
],
|
||||||
|
root: true,
|
||||||
|
env: {
|
||||||
|
node: true,
|
||||||
|
jest: true,
|
||||||
|
},
|
||||||
|
ignorePatterns: ['.eslintrc.js'],
|
||||||
|
rules: {
|
||||||
|
'@typescript-eslint/interface-name-prefix': 'off',
|
||||||
|
'@typescript-eslint/explicit-function-return-type': 'off',
|
||||||
|
'@typescript-eslint/explicit-module-boundary-types': 'off',
|
||||||
|
'@typescript-eslint/no-explicit-any': 'off',
|
||||||
|
},
|
||||||
|
};
|
||||||
36
.gitignore
vendored
Normal file
36
.gitignore
vendored
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
# compiled output
|
||||||
|
/dist
|
||||||
|
/node_modules
|
||||||
|
/uploads/*
|
||||||
|
|
||||||
|
# Logs
|
||||||
|
logs
|
||||||
|
*.log
|
||||||
|
npm-debug.log*
|
||||||
|
pnpm-debug.log*
|
||||||
|
yarn-debug.log*
|
||||||
|
yarn-error.log*
|
||||||
|
lerna-debug.log*
|
||||||
|
|
||||||
|
# OS
|
||||||
|
.DS_Store
|
||||||
|
|
||||||
|
# Tests
|
||||||
|
/coverage
|
||||||
|
/.nyc_output
|
||||||
|
|
||||||
|
# IDEs and editors
|
||||||
|
/.idea
|
||||||
|
.project
|
||||||
|
.classpath
|
||||||
|
.c9/
|
||||||
|
*.launch
|
||||||
|
.settings/
|
||||||
|
*.sublime-workspace
|
||||||
|
|
||||||
|
# IDE - VSCode
|
||||||
|
.vscode/*
|
||||||
|
!.vscode/settings.json
|
||||||
|
!.vscode/tasks.json
|
||||||
|
!.vscode/launch.json
|
||||||
|
!.vscode/extensions.json
|
||||||
1
Insomnia_2024-01-21.json
Normal file
1
Insomnia_2024-01-21.json
Normal file
File diff suppressed because one or more lines are too long
73
README.md
Normal file
73
README.md
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
<p align="center">
|
||||||
|
<a href="http://nestjs.com/" target="blank"><img src="https://nestjs.com/img/logo-small.svg" width="200" alt="Nest Logo" /></a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
[circleci-image]: https://img.shields.io/circleci/build/github/nestjs/nest/master?token=abc123def456
|
||||||
|
[circleci-url]: https://circleci.com/gh/nestjs/nest
|
||||||
|
|
||||||
|
<p align="center">A progressive <a href="http://nodejs.org" target="_blank">Node.js</a> framework for building efficient and scalable server-side applications.</p>
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://www.npmjs.com/~nestjscore" target="_blank"><img src="https://img.shields.io/npm/v/@nestjs/core.svg" alt="NPM Version" /></a>
|
||||||
|
<a href="https://www.npmjs.com/~nestjscore" target="_blank"><img src="https://img.shields.io/npm/l/@nestjs/core.svg" alt="Package License" /></a>
|
||||||
|
<a href="https://www.npmjs.com/~nestjscore" target="_blank"><img src="https://img.shields.io/npm/dm/@nestjs/common.svg" alt="NPM Downloads" /></a>
|
||||||
|
<a href="https://circleci.com/gh/nestjs/nest" target="_blank"><img src="https://img.shields.io/circleci/build/github/nestjs/nest/master" alt="CircleCI" /></a>
|
||||||
|
<a href="https://coveralls.io/github/nestjs/nest?branch=master" target="_blank"><img src="https://coveralls.io/repos/github/nestjs/nest/badge.svg?branch=master#9" alt="Coverage" /></a>
|
||||||
|
<a href="https://discord.gg/G7Qnnhy" target="_blank"><img src="https://img.shields.io/badge/discord-online-brightgreen.svg" alt="Discord"/></a>
|
||||||
|
<a href="https://opencollective.com/nest#backer" target="_blank"><img src="https://opencollective.com/nest/backers/badge.svg" alt="Backers on Open Collective" /></a>
|
||||||
|
<a href="https://opencollective.com/nest#sponsor" target="_blank"><img src="https://opencollective.com/nest/sponsors/badge.svg" alt="Sponsors on Open Collective" /></a>
|
||||||
|
<a href="https://paypal.me/kamilmysliwiec" target="_blank"><img src="https://img.shields.io/badge/Donate-PayPal-ff3f59.svg"/></a>
|
||||||
|
<a href="https://opencollective.com/nest#sponsor" target="_blank"><img src="https://img.shields.io/badge/Support%20us-Open%20Collective-41B883.svg" alt="Support us"></a>
|
||||||
|
<a href="https://twitter.com/nestframework" target="_blank"><img src="https://img.shields.io/twitter/follow/nestframework.svg?style=social&label=Follow"></a>
|
||||||
|
</p>
|
||||||
|
<!--[](https://opencollective.com/nest#backer)
|
||||||
|
[](https://opencollective.com/nest#sponsor)-->
|
||||||
|
|
||||||
|
## Description
|
||||||
|
|
||||||
|
[Nest](https://github.com/nestjs/nest) framework TypeScript starter repository.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
## Running the app
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# development
|
||||||
|
$ npm run start
|
||||||
|
|
||||||
|
# watch mode
|
||||||
|
$ npm run start:dev
|
||||||
|
|
||||||
|
# production mode
|
||||||
|
$ npm run start:prod
|
||||||
|
```
|
||||||
|
|
||||||
|
## Test
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# unit tests
|
||||||
|
$ npm run test
|
||||||
|
|
||||||
|
# e2e tests
|
||||||
|
$ npm run test:e2e
|
||||||
|
|
||||||
|
# test coverage
|
||||||
|
$ npm run test:cov
|
||||||
|
```
|
||||||
|
|
||||||
|
## Support
|
||||||
|
|
||||||
|
Nest is an MIT-licensed open source project. It can grow thanks to the sponsors and support by the amazing backers. If you'd like to join them, please [read more here](https://docs.nestjs.com/support).
|
||||||
|
|
||||||
|
## Stay in touch
|
||||||
|
|
||||||
|
- Author - [Kamil Myśliwiec](https://kamilmysliwiec.com)
|
||||||
|
- Website - [https://nestjs.com](https://nestjs.com/)
|
||||||
|
- Twitter - [@nestframework](https://twitter.com/nestframework)
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
Nest is [MIT licensed](LICENSE).
|
||||||
1
config/system.config.json
Normal file
1
config/system.config.json
Normal file
File diff suppressed because one or more lines are too long
98
create table queries.sql
Normal file
98
create table queries.sql
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
CREATE TABLE "users" (
|
||||||
|
"id" BIGSERIAL PRIMARY KEY,
|
||||||
|
"email" TEXT,
|
||||||
|
"phoneNumber" TEXT,
|
||||||
|
"password" TEXT,
|
||||||
|
"name" TEXT,
|
||||||
|
"userTypeCode" TEXT,
|
||||||
|
"primaryRole" TEXT,
|
||||||
|
"instituteCode" TEXT,
|
||||||
|
"status" TEXT,
|
||||||
|
"validFrom" DATE,
|
||||||
|
"validTill" DATE,
|
||||||
|
"createdAt" DATE,
|
||||||
|
"updatedAt" DATE,
|
||||||
|
"createBy" TEXT,
|
||||||
|
"modifiedBy" TEXT,
|
||||||
|
"deletedAt" DATE,
|
||||||
|
"version" NUMERIC
|
||||||
|
);
|
||||||
|
CREATE TABLE "user_type" (
|
||||||
|
"id" BIGSERIAL PRIMARY KEY,
|
||||||
|
"userTypeCode" TEXT,
|
||||||
|
"userTypeName" TEXT,
|
||||||
|
"userTypeDesc" TEXT,
|
||||||
|
"status" TEXT,
|
||||||
|
"validFrom" DATE,
|
||||||
|
"validTill" DATE,
|
||||||
|
"createdAt" DATE,
|
||||||
|
"updatedAt" DATE,
|
||||||
|
"createBy" TEXT,
|
||||||
|
"modifiedBy" TEXT,
|
||||||
|
"deletedAt" DATE,
|
||||||
|
"version" NUMERIC
|
||||||
|
);
|
||||||
|
CREATE TABLE "user_additional_details" (
|
||||||
|
"id" BIGSERIAL PRIMARY KEY,
|
||||||
|
"userId" BIGINT,
|
||||||
|
"addlDataType" TEXT,
|
||||||
|
"addlDataName" TEXT,
|
||||||
|
"status" TEXT,
|
||||||
|
"validFrom" DATE,
|
||||||
|
"validTill" DATE,
|
||||||
|
"createdAt" DATE,
|
||||||
|
"updatedAt" DATE,
|
||||||
|
"createBy" TEXT,
|
||||||
|
"modifiedBy" TEXT,
|
||||||
|
"deletedAt" DATE,
|
||||||
|
"version" NUMERIC,
|
||||||
|
);
|
||||||
|
CREATE TABLE "roles_ref" (
|
||||||
|
"id" BIGSERIAL PRIMARY KEY,
|
||||||
|
"appCode" TEXT,
|
||||||
|
"roleCode" TEXT,
|
||||||
|
"roleName" TEXT,
|
||||||
|
"status" TEXT,
|
||||||
|
"validFrom" DATE,
|
||||||
|
"validTill" DATE,
|
||||||
|
"createdAt" DATE,
|
||||||
|
"updatedAt" DATE,
|
||||||
|
"createBy" TEXT,
|
||||||
|
"modifiedBy" TEXT,
|
||||||
|
"deletedAt" DATE,
|
||||||
|
"version" NUMERIC
|
||||||
|
);
|
||||||
|
CREATE TABLE "institute" (
|
||||||
|
"id" BIGSERIAL PRIMARY KEY,
|
||||||
|
"instituteCode" TEXT,
|
||||||
|
"instituteName" TEXT,
|
||||||
|
"address" TEXT,
|
||||||
|
"lat" NUMERIC,
|
||||||
|
"lng" NUMERIC,
|
||||||
|
"status" TEXT,
|
||||||
|
"validFrom" DATE,
|
||||||
|
"validTill" DATE,
|
||||||
|
"createdAt" DATE,
|
||||||
|
"updatedAt" DATE,
|
||||||
|
"createBy" TEXT,
|
||||||
|
"modifiedBy" TEXT,
|
||||||
|
"deletedAt" DATE,
|
||||||
|
"version" NUMERIC
|
||||||
|
);
|
||||||
|
CREATE TABLE "subscription" (
|
||||||
|
"id" BIGSERIAL PRIMARY KEY,
|
||||||
|
"user_id" BIGINT,
|
||||||
|
"plan_type" TEXT,
|
||||||
|
"start_date" DATE,
|
||||||
|
"end_date" DATE,
|
||||||
|
"is_active" BOOLEAN,
|
||||||
|
"status" TEXT,
|
||||||
|
"validFrom" DATE,
|
||||||
|
"validTill" DATE,
|
||||||
|
"createdAt" DATE,
|
||||||
|
"updatedAt" DATE,
|
||||||
|
"createBy" TEXT,
|
||||||
|
"modifiedBy" TEXT,
|
||||||
|
"deletedAt" DATE,
|
||||||
|
"version" NUMERIC,
|
||||||
|
);
|
||||||
283
dump-wastecare-202401222136.sql
Normal file
283
dump-wastecare-202401222136.sql
Normal file
@ -0,0 +1,283 @@
|
|||||||
|
CREATE TABLE public.actions_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"appCode" text,
|
||||||
|
"actionCode" text,
|
||||||
|
"actionName" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE public.apps_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"appCode" text,
|
||||||
|
"appName" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.companies (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"companyCode" text,
|
||||||
|
"companyName" text,
|
||||||
|
address text,
|
||||||
|
gst text,
|
||||||
|
status text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.company_details (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"companyId" numeric,
|
||||||
|
"companyCode" text,
|
||||||
|
"addlDataType" text,
|
||||||
|
"addlDataName" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE public.crud_config_info (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"endPtNm" text,
|
||||||
|
"opsTypeName" text,
|
||||||
|
"sqlQueryText" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE public.item_category_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"categoryName" text,
|
||||||
|
"categoryCode" text,
|
||||||
|
"categoryDescription" text,
|
||||||
|
"parentCode" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.items_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"itemCode" text,
|
||||||
|
"itemName" text,
|
||||||
|
"itemCategoryCode" text,
|
||||||
|
"itemDesc" text,
|
||||||
|
"parentCode" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.policies_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"appCode" text,
|
||||||
|
"roleCode" text,
|
||||||
|
"resourceCode" text,
|
||||||
|
"actionCode" text,
|
||||||
|
"canAllow" boolean,
|
||||||
|
priority boolean,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.resources_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"appCode" text,
|
||||||
|
"resourceCode" text,
|
||||||
|
"resourceName" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.roles_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"appCode" text,
|
||||||
|
"roleCode" text,
|
||||||
|
"roleName" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE public.user_additional_details (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"userId" numeric,
|
||||||
|
"addlDataType" text,
|
||||||
|
"addlDataName" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.users (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
email text,
|
||||||
|
password text,
|
||||||
|
name text,
|
||||||
|
"userTypeCode" text,
|
||||||
|
"primaryRole" text,
|
||||||
|
"companyCode" text,
|
||||||
|
status text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.master_config_category_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"categoryName" text,
|
||||||
|
"categoryCode" text,
|
||||||
|
"categoryDescription" text,
|
||||||
|
"categoryType" text,
|
||||||
|
"parentCode" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.master_config_ref (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"configCode" text,
|
||||||
|
"configName" text,
|
||||||
|
"configCategoryCode" text,
|
||||||
|
"configDesc" text,
|
||||||
|
"parentCode" text,
|
||||||
|
"configType" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.master_config_mapping (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"configCode" text,
|
||||||
|
"companyCode" text,
|
||||||
|
"status" text,
|
||||||
|
"dispSerialNumber" text,
|
||||||
|
"defaultValue" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE public.config_transcations (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"configCode" text,
|
||||||
|
"companyCode" text,
|
||||||
|
"itemCategoryCode" text,
|
||||||
|
"itemCode" text,
|
||||||
|
"status" text,
|
||||||
|
"value" text,
|
||||||
|
"fileUrl" text,
|
||||||
|
"weight" numeric,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE TABLE public.config_logs (
|
||||||
|
id bigserial NOT NULL,
|
||||||
|
"tableName" text,
|
||||||
|
"prevValue" text,
|
||||||
|
"currValue" text,
|
||||||
|
"validFrom" date,
|
||||||
|
"validTill" date,
|
||||||
|
"createdAt" date,
|
||||||
|
"updatedAt" date,
|
||||||
|
"createBy" text,
|
||||||
|
"modifiedBy" text,
|
||||||
|
"deletedAt" date,
|
||||||
|
version numeric
|
||||||
|
)
|
||||||
10
nest-cli.json
Normal file
10
nest-cli.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://json.schemastore.org/nest-cli",
|
||||||
|
"collection": "@nestjs/schematics",
|
||||||
|
"sourceRoot": "src",
|
||||||
|
"compilerOptions": {
|
||||||
|
"deleteOutDir": true,
|
||||||
|
"assets": ["mail/templates/**/*"],
|
||||||
|
"watchAssets": true
|
||||||
|
}
|
||||||
|
}
|
||||||
11
nodemon.json
Normal file
11
nodemon.json
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"watch": [
|
||||||
|
"src"
|
||||||
|
],
|
||||||
|
"ext": "ts",
|
||||||
|
"ignore": [
|
||||||
|
"src/**/*.spec.ts"
|
||||||
|
],
|
||||||
|
"exec": "node --inspect=127.0.0.1:9223 -r ts-node/register -- src/main.ts",
|
||||||
|
"env": {}
|
||||||
|
}
|
||||||
23924
package-lock.json
generated
Normal file
23924
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
89
package.json
Normal file
89
package.json
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
{
|
||||||
|
"name": "epr-be",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"description": "",
|
||||||
|
"author": "",
|
||||||
|
"private": true,
|
||||||
|
"license": "UNLICENSED",
|
||||||
|
"scripts": {
|
||||||
|
"build": "node script-util.js config.local.json config.json && nest build",
|
||||||
|
"format": "prettier --write \"src/**/*.ts\" \"test/**/*.ts\"",
|
||||||
|
"start": "node script-util.js config.local.json config.json && nest start",
|
||||||
|
"start:local": "node script-util.js config.local.json config.json && nest start --watch",
|
||||||
|
"start:debug": "node script-util.js config.local.json config.json && nest start --debug --watch",
|
||||||
|
"start:prod": "node dist/main",
|
||||||
|
"build:dev": "node script-util.js config.dev.json config.json && nest build && cp package.json dist/package.json && cp -r config dist/",
|
||||||
|
"build:prod": "node script-util.js config.prod.json config.json && nest build && cp package.json dist/package.json && cp -r config dist/",
|
||||||
|
"build:test": "node script-util.js config.test.json config.json && nest build && cp package.json dist/package.json && cp -r config dist/",
|
||||||
|
"lint": "eslint \"{src,apps,libs,test}/**/*.ts\" --fix",
|
||||||
|
"test": "jest",
|
||||||
|
"test:watch": "jest --watch",
|
||||||
|
"test:cov": "jest --coverage",
|
||||||
|
"test:debug": "node --inspect-brk -r tsconfig-paths/register -r ts-node/register node_modules/.bin/jest --runInBand",
|
||||||
|
"test:e2e": "jest --config ./test/jest-e2e.json"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@nestjs-modules/mailer": "^1.10.3",
|
||||||
|
"@nestjs/common": "^10.0.0",
|
||||||
|
"@nestjs/config": "^3.1.1",
|
||||||
|
"@nestjs/core": "^10.0.0",
|
||||||
|
"@nestjs/platform-express": "^10.0.0",
|
||||||
|
"@nestjs/typeorm": "^10.0.1",
|
||||||
|
"dotenv": "^16.3.1",
|
||||||
|
"handlebars": "^4.7.8",
|
||||||
|
"moment": "^2.30.1",
|
||||||
|
"nexe": "^4.0.0-rc.6",
|
||||||
|
"nodemailer": "^6.9.9",
|
||||||
|
"otp-generator": "^4.0.1",
|
||||||
|
"pg": "^8.11.3",
|
||||||
|
"reflect-metadata": "^0.1.14",
|
||||||
|
"rxjs": "^7.8.1",
|
||||||
|
"sequelize": "^6.35.2",
|
||||||
|
"sequelize-typescript": "^2.1.6",
|
||||||
|
"typeorm": "^0.3.17"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@nestjs/cli": "^10.0.0",
|
||||||
|
"@nestjs/schematics": "^10.0.0",
|
||||||
|
"@nestjs/testing": "^10.0.0",
|
||||||
|
"@types/express": "^4.17.17",
|
||||||
|
"@types/jest": "^29.5.2",
|
||||||
|
"@types/multer": "^1.4.11",
|
||||||
|
"@types/node": "^20.10.6",
|
||||||
|
"@types/nodemailer": "^6.4.14",
|
||||||
|
"@types/supertest": "^2.0.12",
|
||||||
|
"@types/validator": "^13.11.7",
|
||||||
|
"@typescript-eslint/eslint-plugin": "^6.0.0",
|
||||||
|
"@typescript-eslint/parser": "^6.0.0",
|
||||||
|
"eslint": "^8.42.0",
|
||||||
|
"eslint-config-prettier": "^9.0.0",
|
||||||
|
"eslint-plugin-prettier": "^5.0.0",
|
||||||
|
"jest": "^29.5.0",
|
||||||
|
"nodemon": "^3.0.2",
|
||||||
|
"prettier": "^3.0.0",
|
||||||
|
"source-map-support": "^0.5.21",
|
||||||
|
"supertest": "^6.3.3",
|
||||||
|
"ts-jest": "^29.1.0",
|
||||||
|
"ts-loader": "^9.4.3",
|
||||||
|
"ts-node": "^10.9.2",
|
||||||
|
"tsconfig-paths": "^4.2.0",
|
||||||
|
"typescript": "^5.1.3"
|
||||||
|
},
|
||||||
|
"jest": {
|
||||||
|
"moduleFileExtensions": [
|
||||||
|
"js",
|
||||||
|
"json",
|
||||||
|
"ts"
|
||||||
|
],
|
||||||
|
"rootDir": "src",
|
||||||
|
"testRegex": ".*\\.spec\\.ts$",
|
||||||
|
"transform": {
|
||||||
|
"^.+\\.(t|j)s$": "ts-jest"
|
||||||
|
},
|
||||||
|
"collectCoverageFrom": [
|
||||||
|
"**/*.(t|j)s"
|
||||||
|
],
|
||||||
|
"coverageDirectory": "../coverage",
|
||||||
|
"testEnvironment": "node"
|
||||||
|
}
|
||||||
|
}
|
||||||
11
script-util.js
Normal file
11
script-util.js
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
/* eslint-disable @typescript-eslint/no-var-requires */
|
||||||
|
|
||||||
|
// Import the required modules
|
||||||
|
const fs = require('fs');
|
||||||
|
|
||||||
|
// Get the source and destination file paths from the command-line arguments
|
||||||
|
const sourcePath = `src/app-config/${process.argv[2]}`;
|
||||||
|
const destinationPath = `src/app-config/${process.argv[3]}`;
|
||||||
|
|
||||||
|
// Read the source file
|
||||||
|
fs.writeFileSync(destinationPath, fs.readFileSync(sourcePath));
|
||||||
18
src/app-config/app-config.controller.spec.ts
Normal file
18
src/app-config/app-config.controller.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { AppConfigController } from './app-config.controller';
|
||||||
|
|
||||||
|
describe('AppConfigController', () => {
|
||||||
|
let controller: AppConfigController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [AppConfigController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<AppConfigController>(AppConfigController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
41
src/app-config/app-config.controller.ts
Normal file
41
src/app-config/app-config.controller.ts
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
import { Controller, Get, Post, Query, Req, Res } from '@nestjs/common';
|
||||||
|
import { getFile, updateFile } from './file.util';
|
||||||
|
import { Request, Response } from 'express';
|
||||||
|
import { Utility } from 'src/common/Utility';
|
||||||
|
@Controller('app-config')
|
||||||
|
export class AppConfigController {
|
||||||
|
@Get('/')
|
||||||
|
async get(@Req() req: Request, @Query() query, @Res() res: Response) {
|
||||||
|
console.log('Inside Config Controller GET', query);
|
||||||
|
const filePath = (query.path) ? `${Utility.fileConfig.configPath}/${query.path}` : `${Utility.fileConfig.configPath}`;
|
||||||
|
const response = await getFile(filePath, 'UTF-8');
|
||||||
|
return res.status(200).send(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/')
|
||||||
|
async post(@Req() req: Request, @Res() res: Response) {
|
||||||
|
const filePath = `${Utility.fileConfig.configPath}`;
|
||||||
|
const fileName = (req.body && req.body.fileName) ? req.body.fileName : null;
|
||||||
|
let data = (req.body && req.body.data) ? req.body.data : null;
|
||||||
|
let resultSet = {};
|
||||||
|
console.log('Inside Config Controller Post');
|
||||||
|
console.log(`File Path ${filePath}`);
|
||||||
|
console.log(`File Name ${fileName}`);
|
||||||
|
console.log(`File Data ${data}`);
|
||||||
|
|
||||||
|
if (!filePath || !fileName || !data) {
|
||||||
|
resultSet = {
|
||||||
|
exception: true,
|
||||||
|
exceptionMessage: 'Invalid Params',
|
||||||
|
exceptionSeverity: 'high'
|
||||||
|
}
|
||||||
|
return res.status(400).send(resultSet);
|
||||||
|
}
|
||||||
|
if(typeof data === 'object') {
|
||||||
|
data = JSON.stringify(data);
|
||||||
|
}
|
||||||
|
const response = await updateFile(filePath,fileName,data);
|
||||||
|
resultSet['result'] = response;
|
||||||
|
return res.status(200).send(resultSet);
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/app-config/app-config.service.spec.ts
Normal file
18
src/app-config/app-config.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { AppConfigService } from './app-config.service';
|
||||||
|
|
||||||
|
describe('AppConfigService', () => {
|
||||||
|
let service: AppConfigService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [AppConfigService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<AppConfigService>(AppConfigService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
44
src/app-config/app-config.service.ts
Normal file
44
src/app-config/app-config.service.ts
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import * as configMaster from './config.json';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class AppConfigService {
|
||||||
|
defaultEnv = 'local';
|
||||||
|
constructor() {
|
||||||
|
}
|
||||||
|
|
||||||
|
private getValue(key: string, throwOnMissing = true): any {
|
||||||
|
const value = configMaster[this.defaultEnv].dbConfig[key];
|
||||||
|
if (!value && throwOnMissing) {
|
||||||
|
throw new Error(`config error - missing env.${key}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ensureValues(keys: string[]) {
|
||||||
|
keys.forEach(k => this.getValue(k, true));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public getPort() {
|
||||||
|
return this.getValue('PORT', true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public isProduction() {
|
||||||
|
const mode = this.getValue('MODE', false);
|
||||||
|
return mode != 'DEV';
|
||||||
|
}
|
||||||
|
|
||||||
|
getDbConfig() {
|
||||||
|
return configMaster[this.defaultEnv].dbConfig;
|
||||||
|
}
|
||||||
|
|
||||||
|
initializeFileSystem() {
|
||||||
|
return configMaster[this.defaultEnv].fileConfig;
|
||||||
|
}
|
||||||
|
|
||||||
|
getMailConfig() {
|
||||||
|
return configMaster[this.defaultEnv].mailConfig;
|
||||||
|
}
|
||||||
|
}
|
||||||
34
src/app-config/config.dev.json
Normal file
34
src/app-config/config.dev.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"local": {
|
||||||
|
"appConfig": {
|
||||||
|
"port": 3003
|
||||||
|
},
|
||||||
|
"dbConfig": {
|
||||||
|
"host": "localhost",
|
||||||
|
"port": 5432,
|
||||||
|
"user": "postgres",
|
||||||
|
"password": "postgres",
|
||||||
|
"database": "epr",
|
||||||
|
"MODE": "DEV",
|
||||||
|
"loggerEnabled": true
|
||||||
|
},
|
||||||
|
"fileConfig": {
|
||||||
|
"storagePath": "/opt/www/wastecare-uploads/dev",
|
||||||
|
"configPath": "/opt/wastecare/config/dev"
|
||||||
|
},
|
||||||
|
"mailConfig": {
|
||||||
|
"transport": {
|
||||||
|
"host": "smtppro.zoho.in",
|
||||||
|
"secure": true,
|
||||||
|
"port": 465,
|
||||||
|
"auth": {
|
||||||
|
"user": "admin@wct.co.in",
|
||||||
|
"pass": "Wastecare@123"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaults": {
|
||||||
|
"from": "\"No Reply\" <admin@wct.co.in>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
34
src/app-config/config.json
Normal file
34
src/app-config/config.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"local": {
|
||||||
|
"appConfig": {
|
||||||
|
"port": 3000
|
||||||
|
},
|
||||||
|
"dbConfig": {
|
||||||
|
"host": "localhost",
|
||||||
|
"port": 5432,
|
||||||
|
"user": "postgres",
|
||||||
|
"password": "postgres",
|
||||||
|
"database": "remedify-users-local",
|
||||||
|
"MODE": "DEV",
|
||||||
|
"loggerEnabled": true
|
||||||
|
},
|
||||||
|
"fileConfig": {
|
||||||
|
"storagePath": "./uploads",
|
||||||
|
"configPath": "./config"
|
||||||
|
},
|
||||||
|
"mailConfig": {
|
||||||
|
"transport": {
|
||||||
|
"host": "smtppro.zoho.in",
|
||||||
|
"secure": true,
|
||||||
|
"port": 465,
|
||||||
|
"auth": {
|
||||||
|
"user": "admin@wct.co.in",
|
||||||
|
"pass": "Wastecare@123"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaults": {
|
||||||
|
"from": "\"No Reply\" <admin@wct.co.in>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
34
src/app-config/config.local.json
Normal file
34
src/app-config/config.local.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"local": {
|
||||||
|
"appConfig": {
|
||||||
|
"port": 3000
|
||||||
|
},
|
||||||
|
"dbConfig": {
|
||||||
|
"host": "localhost",
|
||||||
|
"port": 5432,
|
||||||
|
"user": "postgres",
|
||||||
|
"password": "postgres",
|
||||||
|
"database": "remedify-users-local",
|
||||||
|
"MODE": "DEV",
|
||||||
|
"loggerEnabled": true
|
||||||
|
},
|
||||||
|
"fileConfig": {
|
||||||
|
"storagePath": "./uploads",
|
||||||
|
"configPath": "./config"
|
||||||
|
},
|
||||||
|
"mailConfig": {
|
||||||
|
"transport": {
|
||||||
|
"host": "smtppro.zoho.in",
|
||||||
|
"secure": true,
|
||||||
|
"port": 465,
|
||||||
|
"auth": {
|
||||||
|
"user": "admin@wct.co.in",
|
||||||
|
"pass": "Wastecare@123"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaults": {
|
||||||
|
"from": "\"No Reply\" <admin@wct.co.in>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
34
src/app-config/config.prod.json
Normal file
34
src/app-config/config.prod.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"local": {
|
||||||
|
"appConfig": {
|
||||||
|
"port": 3003
|
||||||
|
},
|
||||||
|
"dbConfig": {
|
||||||
|
"host": "127.0.0.1",
|
||||||
|
"port": 5432,
|
||||||
|
"user": "postgres",
|
||||||
|
"password": "postgres",
|
||||||
|
"database": "epr",
|
||||||
|
"MODE": "PROD",
|
||||||
|
"loggerEnabled": true
|
||||||
|
},
|
||||||
|
"fileConfig": {
|
||||||
|
"storagePath": "/opt/www/wastecare-uploads/prod",
|
||||||
|
"configPath": "/opt/wastecare/config/prod"
|
||||||
|
},
|
||||||
|
"mailConfig": {
|
||||||
|
"transport": {
|
||||||
|
"host": "smtppro.zoho.in",
|
||||||
|
"secure": true,
|
||||||
|
"port": 465,
|
||||||
|
"auth": {
|
||||||
|
"user": "admin@wct.co.in",
|
||||||
|
"pass": "Wastecare@123"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaults": {
|
||||||
|
"from": "\"No Reply\" <admin@wct.co.in>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
34
src/app-config/config.test.json
Normal file
34
src/app-config/config.test.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"local": {
|
||||||
|
"appConfig": {
|
||||||
|
"port": 3003
|
||||||
|
},
|
||||||
|
"dbConfig": {
|
||||||
|
"host": "127.0.0.1",
|
||||||
|
"port": 5432,
|
||||||
|
"user": "postgres",
|
||||||
|
"password": "postgres",
|
||||||
|
"database": "epr",
|
||||||
|
"MODE": "TEST",
|
||||||
|
"loggerEnabled": true
|
||||||
|
},
|
||||||
|
"fileConfig": {
|
||||||
|
"storagePath": "/opt/www/wastecare-uploads/test",
|
||||||
|
"configPath": "/opt/wastecare/config/test"
|
||||||
|
},
|
||||||
|
"mailConfig": {
|
||||||
|
"transport": {
|
||||||
|
"host": "smtppro.zoho.in",
|
||||||
|
"secure": true,
|
||||||
|
"port": 465,
|
||||||
|
"auth": {
|
||||||
|
"user": "admin@wct.co.in",
|
||||||
|
"pass": "Wastecare@123"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaults": {
|
||||||
|
"from": "\"No Reply\" <admin@wct.co.in>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
82
src/app-config/file.util.ts
Normal file
82
src/app-config/file.util.ts
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
// This file should exist in `src/common/helpers`
|
||||||
|
import * as fs from 'fs';
|
||||||
|
import { promisify } from 'util';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a file exists at a given path.
|
||||||
|
*
|
||||||
|
* @param {string} path
|
||||||
|
*
|
||||||
|
* @returns {boolean}
|
||||||
|
*/
|
||||||
|
export const checkIfFileOrDirectoryExists = (path: string): boolean => {
|
||||||
|
return fs.existsSync(path);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets file data from a given path via a promise interface.
|
||||||
|
*
|
||||||
|
* @param {string} path
|
||||||
|
* @param {string} encoding
|
||||||
|
*
|
||||||
|
* @returns {Promise<Buffer>}
|
||||||
|
*/
|
||||||
|
export const getFile = async (
|
||||||
|
path: string,
|
||||||
|
encoding: string,
|
||||||
|
): Promise<string | Buffer> => {
|
||||||
|
const readFile = promisify(fs.readFile);
|
||||||
|
|
||||||
|
return encoding ? readFile(path) : readFile(path, {});
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a file at a given path via a promise interface.
|
||||||
|
*
|
||||||
|
* @param {string} path
|
||||||
|
* @param {string} fileName
|
||||||
|
* @param {string} data
|
||||||
|
*
|
||||||
|
* @return {Promise<void>}
|
||||||
|
*/
|
||||||
|
export const createFile = async (
|
||||||
|
path: string,
|
||||||
|
fileName: string,
|
||||||
|
data: string,
|
||||||
|
): Promise<void> => {
|
||||||
|
if (!checkIfFileOrDirectoryExists(path)) {
|
||||||
|
fs.mkdirSync(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
const writeFile = promisify(fs.writeFile);
|
||||||
|
|
||||||
|
return await writeFile(`${path}/${fileName}`, data, 'utf8');
|
||||||
|
};
|
||||||
|
|
||||||
|
export const updateFile = async (
|
||||||
|
path: string,
|
||||||
|
fileName: string,
|
||||||
|
data: string,
|
||||||
|
): Promise<void> => {
|
||||||
|
const fqdn = `${path}/${fileName}`
|
||||||
|
if (!checkIfFileOrDirectoryExists(path)) {
|
||||||
|
fs.mkdirSync(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
// const writeFile = promisify(fs.writeFile);
|
||||||
|
|
||||||
|
return fs.writeFileSync(`${fqdn}`, data);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete file at the given path via a promise interface
|
||||||
|
*
|
||||||
|
* @param {string} path
|
||||||
|
*
|
||||||
|
* @returns {Promise<void>}
|
||||||
|
*/
|
||||||
|
export const deleteFile = async (path: string): Promise<void> => {
|
||||||
|
const unlink = promisify(fs.unlink);
|
||||||
|
|
||||||
|
return await unlink(path);
|
||||||
|
};
|
||||||
22
src/app.controller.spec.ts
Normal file
22
src/app.controller.spec.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { AppController } from './app.controller';
|
||||||
|
import { AppService } from './app.service';
|
||||||
|
|
||||||
|
describe('AppController', () => {
|
||||||
|
let appController: AppController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const app: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [AppController],
|
||||||
|
providers: [AppService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
appController = app.get<AppController>(AppController);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('root', () => {
|
||||||
|
it('should return "Hello World!"', () => {
|
||||||
|
expect(appController.getHello()).toBe('Hello World!');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
14
src/app.controller.ts
Normal file
14
src/app.controller.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { Controller, Get } from '@nestjs/common';
|
||||||
|
import { AppService } from './app.service';
|
||||||
|
|
||||||
|
@Controller()
|
||||||
|
export class AppController {
|
||||||
|
constructor(private readonly appService: AppService) {
|
||||||
|
this.appService.initializeSequelize();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get()
|
||||||
|
getHello(): string {
|
||||||
|
return this.appService.getHello();
|
||||||
|
}
|
||||||
|
}
|
||||||
29
src/app.module.ts
Normal file
29
src/app.module.ts
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { AppController } from './app.controller';
|
||||||
|
import { AppService } from './app.service';
|
||||||
|
import { UserModule } from './user/user.module';
|
||||||
|
import { CommonService } from './common/common.service';
|
||||||
|
import { AppConfigService } from './app-config/app-config.service';
|
||||||
|
import { DataModule } from './data/data.module';
|
||||||
|
import { MailModule } from './mail/mail.module';
|
||||||
|
import { AppConfigController } from './app-config/app-config.controller';
|
||||||
|
import { ItemsModule } from './items/item.module';
|
||||||
|
import { MasterConfigModule } from './master-config/master-config.module';
|
||||||
|
import { ConfigModule } from './config/config.module';
|
||||||
|
import { SubscriptionsModule } from './subscription/subscription.module';
|
||||||
|
import { InstituteModule } from './institute/institute.module';
|
||||||
|
@Module({
|
||||||
|
imports: [
|
||||||
|
UserModule,
|
||||||
|
InstituteModule,
|
||||||
|
DataModule,
|
||||||
|
MailModule,
|
||||||
|
ItemsModule,
|
||||||
|
SubscriptionsModule,
|
||||||
|
MasterConfigModule,
|
||||||
|
ConfigModule
|
||||||
|
],
|
||||||
|
controllers: [AppController, AppConfigController],
|
||||||
|
providers: [CommonService, AppConfigService, AppService],
|
||||||
|
})
|
||||||
|
export class AppModule {}
|
||||||
76
src/app.service.ts
Normal file
76
src/app.service.ts
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import { CommonService } from './common/common.service';
|
||||||
|
import * as fs from 'fs';
|
||||||
|
import * as path from 'path';
|
||||||
|
import { Sequelize } from 'sequelize-typescript';
|
||||||
|
import { AppConfigService } from './app-config/app-config.service';
|
||||||
|
import { Utility } from './common/Utility';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class AppService {
|
||||||
|
|
||||||
|
modelFilePaths: string[] = [] as string[];
|
||||||
|
|
||||||
|
|
||||||
|
constructor(private commonService: CommonService, private configService: AppConfigService) { }
|
||||||
|
|
||||||
|
getHello(): string {
|
||||||
|
return 'Hello World!';
|
||||||
|
}
|
||||||
|
|
||||||
|
initializeSequelize() {
|
||||||
|
this.getModels();
|
||||||
|
const dbConfig = this.configService.getDbConfig();
|
||||||
|
if (this.modelFilePaths.length > 0) {
|
||||||
|
this.commonService.sequelize = new Sequelize({
|
||||||
|
database: dbConfig.database,
|
||||||
|
dialect: 'postgres',
|
||||||
|
username: dbConfig.user,
|
||||||
|
password: dbConfig.password,
|
||||||
|
models: this.modelFilePaths,
|
||||||
|
modelMatch: (filename, member) => {
|
||||||
|
return filename.substring(0, filename.indexOf('.entity')) === member.toLowerCase();
|
||||||
|
},
|
||||||
|
});
|
||||||
|
Utility.sequelize = this.commonService.sequelize;
|
||||||
|
}
|
||||||
|
const fileConfig = this.configService.initializeFileSystem();
|
||||||
|
this.commonService.fileConfig = fileConfig;
|
||||||
|
Utility.fileConfig = fileConfig;
|
||||||
|
|
||||||
|
const emailConfig = this.configService.getMailConfig();
|
||||||
|
this.commonService.mailConfig = emailConfig;
|
||||||
|
Utility.mailConfig = emailConfig;
|
||||||
|
}
|
||||||
|
|
||||||
|
getModels() {
|
||||||
|
this.fromDir(__dirname, '.entity', ['.js', '.ts']);
|
||||||
|
if (this.modelFilePaths.length > 0) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
fromDir(startPath, filter, extensions) {
|
||||||
|
if (!fs.existsSync(startPath) || !extensions || extensions.length === 0) {
|
||||||
|
console.log("no dir ", startPath);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const files = fs.readdirSync(startPath);
|
||||||
|
for (let i = 0; i < files.length; i++) {
|
||||||
|
const filename = path.join(startPath, files[i]);
|
||||||
|
const stat = fs.lstatSync(filename);
|
||||||
|
if (stat.isDirectory()) {
|
||||||
|
this.fromDir(filename, filter, extensions); //recurse
|
||||||
|
} else if (filename.includes(filter)) {
|
||||||
|
extensions.map((extension) => {
|
||||||
|
if (filename.endsWith(`${filter}${extension}`)) {
|
||||||
|
this.modelFilePaths.push(filename);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
18
src/common/Exception.model.ts
Normal file
18
src/common/Exception.model.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
export class Exception {
|
||||||
|
public exception: boolean;
|
||||||
|
public exceptionSeverity: 'HIGH' | 'MEDIUM' | 'LOW';
|
||||||
|
public exceptionMessage: string;
|
||||||
|
public stackTrace: any;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
exception,
|
||||||
|
exceptionSeverity,
|
||||||
|
exceptionMessage,
|
||||||
|
stackTrace = null,
|
||||||
|
) {
|
||||||
|
this.exception = exception;
|
||||||
|
this.exceptionSeverity = exceptionSeverity;
|
||||||
|
this.exceptionMessage = exceptionMessage;
|
||||||
|
this.stackTrace = stackTrace;
|
||||||
|
}
|
||||||
|
}
|
||||||
14
src/common/GenericResponse.model.ts
Normal file
14
src/common/GenericResponse.model.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { Exception } from "./Exception.model";
|
||||||
|
|
||||||
|
export class GenericResponse {
|
||||||
|
public notification: Exception;
|
||||||
|
data: any
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
exception: Exception,
|
||||||
|
data
|
||||||
|
) {
|
||||||
|
this.notification = exception;
|
||||||
|
this.data = data;
|
||||||
|
}
|
||||||
|
}
|
||||||
22
src/common/Utility.ts
Normal file
22
src/common/Utility.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import { Sequelize } from "sequelize";
|
||||||
|
|
||||||
|
export class Utility {
|
||||||
|
static sequelize: Sequelize;
|
||||||
|
static appPort: number = 3000;
|
||||||
|
static models: any;
|
||||||
|
static fileConfig: any = {"storagePath": "./uploads"};
|
||||||
|
static mailConfig: any = {
|
||||||
|
"transport": {
|
||||||
|
"host": "smtppro.zoho.in",
|
||||||
|
"secure": true,
|
||||||
|
"port": 465,
|
||||||
|
"auth": {
|
||||||
|
"user": "admin@wct.co.in",
|
||||||
|
"pass": "Wastecare@123"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaults": {
|
||||||
|
"from": "\"No Reply\" <admin@wct.co.in>"
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
13
src/common/common.service.ts
Normal file
13
src/common/common.service.ts
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import {Sequelize} from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class CommonService {
|
||||||
|
sequelize: Sequelize;
|
||||||
|
models: any;
|
||||||
|
fileConfig: any;
|
||||||
|
mailConfig: any;
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/config/config-logs/config-logs.controller.spec.ts
Normal file
18
src/config/config-logs/config-logs.controller.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { ConfigLogsController } from './config-logs.controller';
|
||||||
|
|
||||||
|
describe('ConfigLogsController', () => {
|
||||||
|
let controller: ConfigLogsController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [ConfigLogsController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<ConfigLogsController>(ConfigLogsController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
103
src/config/config-logs/config-logs.controller.ts
Normal file
103
src/config/config-logs/config-logs.controller.ts
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { ConfigLogsService } from './config-logs.service';
|
||||||
|
import ConfigLog from './config-logs.entity';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
|
||||||
|
@Controller('config/logs')
|
||||||
|
export class ConfigLogsController {
|
||||||
|
constructor(private configService: ConfigLogsService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.configService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() config: ConfigLog, @Res() res: Response) {
|
||||||
|
if(!config) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.filter(config) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() config: ConfigLog, @Res() res: Response) {
|
||||||
|
if(!config) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete config.id;
|
||||||
|
const response = await this.configService.upsert(config, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() config: ConfigLog, @Res() res: Response) {
|
||||||
|
if(!config || !config.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.upsert(config, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
29
src/config/config-logs/config-logs.entity.ts
Normal file
29
src/config/config-logs/config-logs.entity.ts
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({tableName: 'config_logs'})
|
||||||
|
export default class ConfigLog extends Model {
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
tableName: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
prevValue: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
currValue: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
}
|
||||||
18
src/config/config-logs/config-logs.service.spec.ts
Normal file
18
src/config/config-logs/config-logs.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { ConfigLogsService } from './config-logs.service';
|
||||||
|
|
||||||
|
describe('ConfigLogsService', () => {
|
||||||
|
let service: ConfigLogsService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [ConfigLogsService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<ConfigLogsService>(ConfigLogsService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
37
src/config/config-logs/config-logs.service.ts
Normal file
37
src/config/config-logs/config-logs.service.ts
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import ConfigLog from './config-logs.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ConfigLogsService {
|
||||||
|
async findAll(): Promise<{rows: ConfigLog[], count: number}> {
|
||||||
|
return ConfigLog.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<ConfigLog> {
|
||||||
|
return ConfigLog.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(config: ConfigLog) : Promise<ConfigLog[]> {
|
||||||
|
return ConfigLog.findAll({where: config as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(config: ConfigLog): Promise<ConfigLog> {
|
||||||
|
return ConfigLog.findOne({where: config as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return ConfigLog.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(config: ConfigLog, insertIfNotFound: boolean): Promise<ConfigLog | [affectedCount: number]> {
|
||||||
|
if(config.id) {
|
||||||
|
const existingUser = await this.findByPk(config.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return ConfigLog.update(config, {where: {id: config.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return ConfigLog.create(config as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/config/config.controller.spec.ts
Normal file
18
src/config/config.controller.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { ConfigController } from './config.controller';
|
||||||
|
|
||||||
|
describe('ConfigController', () => {
|
||||||
|
let controller: ConfigController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [ConfigController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<ConfigController>(ConfigController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
104
src/config/config.controller.ts
Normal file
104
src/config/config.controller.ts
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { ConfigService } from './config.service';
|
||||||
|
import Config from './config.entity';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
|
||||||
|
@Controller('config')
|
||||||
|
export class ConfigController {
|
||||||
|
|
||||||
|
constructor(private configService: ConfigService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.configService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() config: Config, @Res() res: Response) {
|
||||||
|
if(!config) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.filter(config) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() config: Config, @Res() res: Response) {
|
||||||
|
if(!config) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete config.id;
|
||||||
|
const response = await this.configService.upsert(config, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() config: Config, @Res() res: Response) {
|
||||||
|
if(!config || !config.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.upsert(config, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.configService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
44
src/config/config.entity.ts
Normal file
44
src/config/config.entity.ts
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({tableName: 'config_transcations'})
|
||||||
|
export default class Config extends Model {
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
companyCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
itemCategoryCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
itemCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
value: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
fileUrl: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.NUMBER})
|
||||||
|
weight: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
}
|
||||||
11
src/config/config.module.ts
Normal file
11
src/config/config.module.ts
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { ConfigController } from './config.controller';
|
||||||
|
import { ConfigService } from './config.service';
|
||||||
|
import { ConfigLogsController } from './config-logs/config-logs.controller';
|
||||||
|
import { ConfigLogsService } from './config-logs/config-logs.service';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
controllers: [ConfigController, ConfigLogsController],
|
||||||
|
providers: [ConfigService, ConfigLogsService]
|
||||||
|
})
|
||||||
|
export class ConfigModule {}
|
||||||
18
src/config/config.service.spec.ts
Normal file
18
src/config/config.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { ConfigService } from './config.service';
|
||||||
|
|
||||||
|
describe('ConfigService', () => {
|
||||||
|
let service: ConfigService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [ConfigService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<ConfigService>(ConfigService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
37
src/config/config.service.ts
Normal file
37
src/config/config.service.ts
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import Config from './config.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ConfigService {
|
||||||
|
async findAll(): Promise<{rows: Config[], count: number}> {
|
||||||
|
return Config.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<Config> {
|
||||||
|
return Config.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(config: Config) : Promise<Config[]> {
|
||||||
|
return Config.findAll({where: config as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(config: Config): Promise<Config> {
|
||||||
|
return Config.findOne({where: config as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return Config.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(config: Config, insertIfNotFound: boolean): Promise<Config | [affectedCount: number]> {
|
||||||
|
if(config.id) {
|
||||||
|
const existingUser = await this.findByPk(config.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return Config.update(config, {where: {id: config.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return Config.create(config as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/data/data.controller.spec.ts
Normal file
18
src/data/data.controller.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { DataController } from './data.controller';
|
||||||
|
|
||||||
|
describe('DataController', () => {
|
||||||
|
let controller: DataController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [DataController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<DataController>(DataController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
132
src/data/data.controller.ts
Normal file
132
src/data/data.controller.ts
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import DataModel from './data.entity';
|
||||||
|
import { DataService } from './data.service';
|
||||||
|
import { Response } from 'express';
|
||||||
|
|
||||||
|
@Controller('data')
|
||||||
|
export class DataController {
|
||||||
|
|
||||||
|
constructor(private dataService: DataService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAllUsers(@Res() res: Response) {
|
||||||
|
const response: any = await this.dataService.findAll() || [];
|
||||||
|
res.send((response && response.rows) ? response.rows : []);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.dataService.findByPk(id) || {};
|
||||||
|
res.send(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Post('/:endPtNm/:opType')
|
||||||
|
async performOperation(@Param('endPtNm') endPtNm: string, @Param('opType') opType: string, @Body() body, @Res() res: Response) {
|
||||||
|
if(!opType || !endPtNm) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response: DataModel = await this.dataService.findOne({endPtNm: endPtNm, opsTypeName: opType.toUpperCase()} as any);
|
||||||
|
if(response && response.sqlQueryText) {
|
||||||
|
if(body) {
|
||||||
|
for(const key in body) {
|
||||||
|
response.sqlQueryText = response.sqlQueryText.replaceAll(`:${key}`, (typeof body[key] === 'string') ? `'${body[key]}'` : body[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let dataResponse = await this.dataService.executeQuery(response.sqlQueryText);
|
||||||
|
if(dataResponse && dataResponse.length && Array.isArray(dataResponse[0])) {
|
||||||
|
dataResponse = dataResponse[0];
|
||||||
|
}
|
||||||
|
res.send(dataResponse);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
return new GenericResponse(null, []);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() quote: DataModel, @Res() res: Response) {
|
||||||
|
if(!quote) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.dataService.filter(quote) || [];
|
||||||
|
res.send(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() quote: DataModel, @Res() res: Response) {
|
||||||
|
if(!quote) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete quote.id;
|
||||||
|
const response = await this.dataService.upsert(quote, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() quote: DataModel, @Res() res: Response) {
|
||||||
|
if(!quote || !quote.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.dataService.upsert(quote, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.dataService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
29
src/data/data.entity.ts
Normal file
29
src/data/data.entity.ts
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({tableName: 'crud_config_info'})
|
||||||
|
export default class DataModel extends Model {
|
||||||
|
|
||||||
|
@Column({type: DataType.NUMBER})
|
||||||
|
endPtNm: number;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
sqlQueryText: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
opsTypeName: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
}
|
||||||
9
src/data/data.module.ts
Normal file
9
src/data/data.module.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { DataService } from './data.service';
|
||||||
|
import { DataController } from './data.controller';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
providers: [DataService],
|
||||||
|
controllers: [DataController]
|
||||||
|
})
|
||||||
|
export class DataModule {}
|
||||||
18
src/data/data.service.spec.ts
Normal file
18
src/data/data.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { DataService } from './data.service';
|
||||||
|
|
||||||
|
describe('DataService', () => {
|
||||||
|
let service: DataService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [DataService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<DataService>(DataService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
44
src/data/data.service.ts
Normal file
44
src/data/data.service.ts
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import DataModel from './data.entity';
|
||||||
|
import { Utility } from 'src/common/Utility';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class DataService {
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: DataModel[], count: number}> {
|
||||||
|
return DataModel.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<DataModel> {
|
||||||
|
return DataModel.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(dataDetail: DataModel): Promise<DataModel> {
|
||||||
|
return DataModel.findOne({where: dataDetail as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(dataDetail: DataModel) : Promise<DataModel[]> {
|
||||||
|
return DataModel.findAll({where: dataDetail as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return DataModel.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(dataDetail: DataModel, insertIfNotFound: boolean): Promise<DataModel | [affectedCount: number]> {
|
||||||
|
if(dataDetail.id) {
|
||||||
|
const existingUser = await this.findByPk(dataDetail.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return DataModel.update(dataDetail, {where: {id: dataDetail.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return DataModel.create(dataDetail as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
executeQuery(sqlQueryText: string): Promise<any> {
|
||||||
|
return Utility.sequelize.query(sqlQueryText);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { CompanyAdditionalDetailsController } from './company-additional-details.controller';
|
||||||
|
|
||||||
|
describe('CompanyAdditionalDetailsController', () => {
|
||||||
|
let controller: CompanyAdditionalDetailsController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [CompanyAdditionalDetailsController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<CompanyAdditionalDetailsController>(CompanyAdditionalDetailsController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { InstituteAdditionalDetailsService } from './institute-additional-details.service';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import InstituteAdditionalDetail from './institute-additional-details.entity';
|
||||||
|
|
||||||
|
@Controller('institute/addlDetail')
|
||||||
|
export class InstituteAdditionalDetailsController {
|
||||||
|
constructor(private instituteDetailService: InstituteAdditionalDetailsService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAllInstitutes(@Res() res: Response) {
|
||||||
|
const response = await this.instituteDetailService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteDetailService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() institute: InstituteAdditionalDetail, @Res() res: Response) {
|
||||||
|
if(!institute) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteDetailService.findOne(institute) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() institute: InstituteAdditionalDetail, @Res() res: Response) {
|
||||||
|
if(!institute) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete institute.id;
|
||||||
|
const response = await this.instituteDetailService.upsert(institute, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() institute: InstituteAdditionalDetail, @Res() res: Response) {
|
||||||
|
if(!institute || !institute.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteDetailService.upsert(institute, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteDetailService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,33 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, ForeignKey } from 'sequelize-typescript';
|
||||||
|
import Institute from '../institute.entity';
|
||||||
|
|
||||||
|
@Table({tableName: 'institute_details'})
|
||||||
|
export default class InstituteAdditionalDetail extends Model {
|
||||||
|
|
||||||
|
@ForeignKey(() => Institute)
|
||||||
|
@Column({type: DataType.NUMBER})
|
||||||
|
instituteId: number;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
instituteCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
addlDataType: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
addlDataName: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
}
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { CompanyAdditionalDetailsService } from './company-additional-details.service';
|
||||||
|
|
||||||
|
describe('CompanyAdditionalDetailsService', () => {
|
||||||
|
let service: CompanyAdditionalDetailsService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [CompanyAdditionalDetailsService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<CompanyAdditionalDetailsService>(CompanyAdditionalDetailsService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
@ -0,0 +1,33 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import InstituteAdditionalDetail from './institute-additional-details.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class InstituteAdditionalDetailsService {
|
||||||
|
async findAll(): Promise<{rows: InstituteAdditionalDetail[], count: number}> {
|
||||||
|
return InstituteAdditionalDetail.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<InstituteAdditionalDetail> {
|
||||||
|
return InstituteAdditionalDetail.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(institute: InstituteAdditionalDetail): Promise<InstituteAdditionalDetail> {
|
||||||
|
return InstituteAdditionalDetail.findOne({where: institute as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return InstituteAdditionalDetail.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(institute: InstituteAdditionalDetail, insertIfNotFound: boolean): Promise<InstituteAdditionalDetail | [affectedCount: number]> {
|
||||||
|
if(institute.id) {
|
||||||
|
const existingUser = await this.findByPk(institute.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return InstituteAdditionalDetail.update(institute, {where: {id: institute.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return InstituteAdditionalDetail.create(institute as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/institute/institute.controller.spec.ts
Normal file
18
src/institute/institute.controller.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { CompanyController } from './company.controller';
|
||||||
|
|
||||||
|
describe('CompanyController', () => {
|
||||||
|
let controller: CompanyController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [CompanyController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<CompanyController>(CompanyController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
103
src/institute/institute.controller.ts
Normal file
103
src/institute/institute.controller.ts
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { InstituteService } from './institute.service';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import Institute from './institute.entity';
|
||||||
|
|
||||||
|
@Controller('institute')
|
||||||
|
export class InstituteController {
|
||||||
|
constructor(private instituteService: InstituteService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAllInstitutes(@Res() res: Response) {
|
||||||
|
const response = await this.instituteService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() institute: Institute, @Res() res: Response) {
|
||||||
|
if(!institute) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteService.filter(institute) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() institute: Institute, @Res() res: Response) {
|
||||||
|
if(!institute) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete institute.id;
|
||||||
|
const response = await this.instituteService.upsert(institute, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() institute: Institute, @Res() res: Response) {
|
||||||
|
if(!Institute || !institute.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteService.upsert(institute, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.instituteService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
36
src/institute/institute.entity.ts
Normal file
36
src/institute/institute.entity.ts
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, HasMany, Unique } from 'sequelize-typescript';
|
||||||
|
import InstituteAdditionalDetail from './institute-additional-details/institute-additional-details.entity';
|
||||||
|
|
||||||
|
@Table({ tableName: 'institute' })
|
||||||
|
export default class Institute extends Model {
|
||||||
|
|
||||||
|
@Unique(true)
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
instituteCode: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
instituteName: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
address: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DECIMAL })
|
||||||
|
lat: number;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DECIMAL })
|
||||||
|
lng: number;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
// @HasMany(() => InstituteAdditionalDetail)
|
||||||
|
// additionalDetails: InstituteAdditionalDetail[];
|
||||||
|
}
|
||||||
12
src/institute/institute.module.ts
Normal file
12
src/institute/institute.module.ts
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { InstituteController } from './institute.controller';
|
||||||
|
import { InstituteService } from './institute.service';
|
||||||
|
import { InstituteAdditionalDetailsController } from './institute-additional-details/institute-additional-details.controller';
|
||||||
|
import { InstituteAdditionalDetailsService } from './institute-additional-details/institute-additional-details.service';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
imports: [],
|
||||||
|
providers: [InstituteService, InstituteAdditionalDetailsService],
|
||||||
|
controllers: [InstituteController, InstituteAdditionalDetailsController]
|
||||||
|
})
|
||||||
|
export class InstituteModule {}
|
||||||
18
src/institute/institute.service.spec.ts
Normal file
18
src/institute/institute.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { CompanyService } from './company.service';
|
||||||
|
|
||||||
|
describe('CompanyService', () => {
|
||||||
|
let service: CompanyService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [CompanyService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<CompanyService>(CompanyService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
39
src/institute/institute.service.ts
Normal file
39
src/institute/institute.service.ts
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import Institute from './institute.entity';
|
||||||
|
import InstituteAdditionalDetail from './institute-additional-details/institute-additional-details.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class InstituteService {
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: Institute[], count: number}> {
|
||||||
|
return Institute.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<Institute> {
|
||||||
|
return Institute.findByPk(id, {include: {model: InstituteAdditionalDetail} })
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(institute: Institute) : Promise<Institute[]> {
|
||||||
|
return Institute.findAll({where: institute as any, include: InstituteAdditionalDetail})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(institute: Institute): Promise<Institute> {
|
||||||
|
return Institute.findOne({where: institute as any, include: InstituteAdditionalDetail})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return Institute.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(institute: Institute, insertIfNotFound: boolean): Promise<Institute | [affectedCount: number]> {
|
||||||
|
if(institute.id) {
|
||||||
|
const existingUser = await this.findByPk(institute.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return Institute.update(institute, {where: {id: institute.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return Institute.create(institute as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
103
src/items/item-category/item-category.controller.ts
Normal file
103
src/items/item-category/item-category.controller.ts
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import { ItemCategoryService } from './item-category.service';
|
||||||
|
import ItemCategory from './item-category.entity';
|
||||||
|
|
||||||
|
@Controller('items/category')
|
||||||
|
export class ItemCategoryController {
|
||||||
|
constructor(private itemsService: ItemCategoryService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.itemsService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() item: ItemCategory, @Res() res: Response) {
|
||||||
|
if(!item) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.filter(item) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() item: ItemCategory, @Res() res: Response) {
|
||||||
|
if(!item) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete item.id;
|
||||||
|
const response = await this.itemsService.upsert(item, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() item: ItemCategory, @Res() res: Response) {
|
||||||
|
if(!item || !item.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.upsert(item, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
36
src/items/item-category/item-category.entity.ts
Normal file
36
src/items/item-category/item-category.entity.ts
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, Unique, HasMany } from 'sequelize-typescript';
|
||||||
|
import Item from '../item.entity';
|
||||||
|
|
||||||
|
@Table({tableName: 'item_category_ref'})
|
||||||
|
export default class ItemCategory extends Model {
|
||||||
|
|
||||||
|
@Unique(true)
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryName: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryDescription: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
parentCode: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
@HasMany(() => Item)
|
||||||
|
items: Item[];
|
||||||
|
}
|
||||||
37
src/items/item-category/item-category.service.ts
Normal file
37
src/items/item-category/item-category.service.ts
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import ItemCategory from './item-category.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ItemCategoryService {
|
||||||
|
async findAll(): Promise<{rows: ItemCategory[], count: number}> {
|
||||||
|
return ItemCategory.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<ItemCategory> {
|
||||||
|
return ItemCategory.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(itemCategory: ItemCategory): Promise<ItemCategory> {
|
||||||
|
return ItemCategory.findOne({where: itemCategory as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return ItemCategory.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(item: ItemCategory) : Promise<ItemCategory[]> {
|
||||||
|
return ItemCategory.findAll({where: item as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(itemCategory: ItemCategory, insertIfNotFound: boolean): Promise<ItemCategory | [affectedCount: number]> {
|
||||||
|
if(itemCategory.id) {
|
||||||
|
const existingUser = await this.findByPk(itemCategory.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return ItemCategory.update(itemCategory, {where: {id: itemCategory.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return ItemCategory.create(itemCategory as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
103
src/items/item.controller.ts
Normal file
103
src/items/item.controller.ts
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import { ItemService } from './item.service';
|
||||||
|
import Item from './item.entity';
|
||||||
|
|
||||||
|
@Controller('items')
|
||||||
|
export class ItemController {
|
||||||
|
constructor(private itemsService: ItemService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.itemsService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() item: Item, @Res() res: Response) {
|
||||||
|
if(!item) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.filter(item) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() item: Item, @Res() res: Response) {
|
||||||
|
if(!item) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete item.id;
|
||||||
|
const response = await this.itemsService.upsert(item, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() item: Item, @Res() res: Response) {
|
||||||
|
if(!item || !item.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.upsert(item, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.itemsService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
38
src/items/item.entity.ts
Normal file
38
src/items/item.entity.ts
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, Unique, ForeignKey } from 'sequelize-typescript';
|
||||||
|
import ItemCategory from './item-category/item-category.entity';
|
||||||
|
|
||||||
|
@Table({tableName: 'items_ref'})
|
||||||
|
export default class Item extends Model {
|
||||||
|
|
||||||
|
@Unique(true)
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
itemCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
itemName: string;
|
||||||
|
|
||||||
|
@ForeignKey(() => ItemCategory)
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
itemCategoryCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
itemDesc: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
parentCode: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
}
|
||||||
12
src/items/item.module.ts
Normal file
12
src/items/item.module.ts
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { ItemService } from './item.service';
|
||||||
|
import { ItemCategoryService } from './item-category/item-category.service';
|
||||||
|
import { ItemController } from './item.controller';
|
||||||
|
import { ItemCategoryController } from './item-category/item-category.controller';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
imports: [],
|
||||||
|
providers: [ItemService, ItemCategoryService],
|
||||||
|
controllers: [ItemController, ItemCategoryController]
|
||||||
|
})
|
||||||
|
export class ItemsModule {}
|
||||||
38
src/items/item.service.ts
Normal file
38
src/items/item.service.ts
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import Item from './item.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ItemService {
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: Item[], count: number}> {
|
||||||
|
return Item.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<Item> {
|
||||||
|
return Item.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(item: Item) : Promise<Item[]> {
|
||||||
|
return Item.findAll({where: item as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(item: Item): Promise<Item> {
|
||||||
|
return Item.findOne({where: item as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return Item.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(item: Item, insertIfNotFound: boolean): Promise<Item | [affectedCount: number]> {
|
||||||
|
if(item.id) {
|
||||||
|
const existingUser = await this.findByPk(item.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return Item.update(item, {where: {id: item.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return Item.create(item as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
27
src/mail/mail.module.ts
Normal file
27
src/mail/mail.module.ts
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
import { MailerModule } from '@nestjs-modules/mailer';
|
||||||
|
import { HandlebarsAdapter } from '@nestjs-modules/mailer/dist/adapters/handlebars.adapter';
|
||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { MailService } from './mail.service';
|
||||||
|
import { join } from 'path';
|
||||||
|
import { Utility } from 'src/common/Utility';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
imports: [
|
||||||
|
MailerModule.forRoot({
|
||||||
|
// transport: 'smtps://user@example.com:topsecret@smtp.example.com',
|
||||||
|
// or
|
||||||
|
transport: Utility.mailConfig.transport,
|
||||||
|
defaults: Utility.mailConfig.defaults,
|
||||||
|
template: {
|
||||||
|
dir: join(__dirname, 'templates'),
|
||||||
|
adapter: new HandlebarsAdapter(), // or new PugAdapter() or new EjsAdapter()
|
||||||
|
options: {
|
||||||
|
strict: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
providers: [MailService],
|
||||||
|
exports: [MailService], // 👈 export for DI
|
||||||
|
})
|
||||||
|
export class MailModule {}
|
||||||
18
src/mail/mail.service.spec.ts
Normal file
18
src/mail/mail.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { MailService } from './mail.service';
|
||||||
|
|
||||||
|
describe('MailService', () => {
|
||||||
|
let service: MailService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [MailService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<MailService>(MailService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
19
src/mail/mail.service.ts
Normal file
19
src/mail/mail.service.ts
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
import { MailerService } from '@nestjs-modules/mailer';
|
||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class MailService {
|
||||||
|
constructor(private mailerService: MailerService) { }
|
||||||
|
|
||||||
|
|
||||||
|
async sendEmail(templateName: string, subject: string, context: any, toEmail: string, ccEmails?: string[], bccEmails?: string[]) {
|
||||||
|
await this.mailerService.sendMail({
|
||||||
|
to: toEmail,
|
||||||
|
cc: ccEmails,
|
||||||
|
bcc: bccEmails,
|
||||||
|
subject: subject,
|
||||||
|
template: templateName, // `.hbs` extension is appended automatically
|
||||||
|
context,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
82
src/mail/templates/confirmation.hbs
Normal file
82
src/mail/templates/confirmation.hbs
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
<head>
|
||||||
|
<style>
|
||||||
|
* {
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.gjs-row {
|
||||||
|
display: flex;
|
||||||
|
justify-content: flex-start;
|
||||||
|
align-items: stretch;
|
||||||
|
flex-wrap: nowrap;
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.gjs-cell {
|
||||||
|
min-height: 75px;
|
||||||
|
flex-grow: 1;
|
||||||
|
flex-basis: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#im43 {
|
||||||
|
background-repeat: repeat;
|
||||||
|
background-position: left top;
|
||||||
|
background-attachment: scroll;
|
||||||
|
background-size: auto;
|
||||||
|
background-image: linear-gradient(#39960c 0%, #39960c 100%);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ij93 {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ilfj {
|
||||||
|
color: #ffffff;
|
||||||
|
text-align: left;
|
||||||
|
font-weight: 900;
|
||||||
|
font-size: 3rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ihfp {
|
||||||
|
height: 577px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#i23r {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.gjs-row {
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body id="iohk">
|
||||||
|
<div class="gjs-row" id="iir1">
|
||||||
|
<div class="gjs-cell" id="im43">
|
||||||
|
<div id="ij93">
|
||||||
|
<span id="ilfj">Waste Care Technologies</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="gjs-row" id="ihfp">
|
||||||
|
<div class="gjs-cell">
|
||||||
|
<div id="i23r">Dear {{ name }},
|
||||||
|
<br />
|
||||||
|
<br />Welcome to Waste Care Technologies.
|
||||||
|
<br />
|
||||||
|
<br />Use Password {{ password }} to login to your account.
|
||||||
|
<br />
|
||||||
|
<br />Contact our Support if you need any queries.
|
||||||
|
<br />
|
||||||
|
<br />Thank you for choosing us
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
79
src/mail/templates/quoteCreated.hbs
Normal file
79
src/mail/templates/quoteCreated.hbs
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
<head>
|
||||||
|
<style>
|
||||||
|
* {
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.gjs-row {
|
||||||
|
display: flex;
|
||||||
|
justify-content: flex-start;
|
||||||
|
align-items: stretch;
|
||||||
|
flex-wrap: nowrap;
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.gjs-cell {
|
||||||
|
min-height: 75px;
|
||||||
|
flex-grow: 1;
|
||||||
|
flex-basis: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#im43 {
|
||||||
|
background-repeat: repeat;
|
||||||
|
background-position: left top;
|
||||||
|
background-attachment: scroll;
|
||||||
|
background-size: auto;
|
||||||
|
background-image: linear-gradient(#39960c 0%, #39960c 100%);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ij93 {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ilfj {
|
||||||
|
color: #ffffff;
|
||||||
|
text-align: left;
|
||||||
|
font-weight: 900;
|
||||||
|
font-size: 3rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ihfp {
|
||||||
|
height: 577px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#i23r {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.gjs-row {
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body id="iohk">
|
||||||
|
<div class="gjs-row" id="iir1">
|
||||||
|
<div class="gjs-cell" id="im43">
|
||||||
|
<div id="ij93">
|
||||||
|
<span id="ilfj">Waste Care Technologies</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="gjs-row" id="ihfp">
|
||||||
|
<div class="gjs-cell" id="ihbs">
|
||||||
|
<div id="i23r">Dear {{ email }},
|
||||||
|
<br/>
|
||||||
|
<br/>A Quote with {{ quoteID }} is created by you.
|
||||||
|
<br/>
|
||||||
|
<br/>Current Quote is in {{ status }} status.
|
||||||
|
<br/>
|
||||||
|
<br/>Thank you for choosing us
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
16
src/main.ts
Normal file
16
src/main.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import { NestFactory } from '@nestjs/core';
|
||||||
|
import { AppModule } from './app.module';
|
||||||
|
import * as bodyParser from 'body-parser';
|
||||||
|
import * as configMaster from './app-config/config.json';
|
||||||
|
import { Utility } from './common/Utility';
|
||||||
|
|
||||||
|
async function bootstrap() {
|
||||||
|
Utility.appPort = configMaster.local.appConfig.port;
|
||||||
|
Utility.mailConfig = configMaster.local.mailConfig;
|
||||||
|
Utility.fileConfig = configMaster.local.fileConfig;
|
||||||
|
const app = await NestFactory.create(AppModule, { cors: true });
|
||||||
|
app.use(bodyParser.json({limit: '50mb'}));
|
||||||
|
app.use(bodyParser.urlencoded({limit: '50mb', extended: true}));
|
||||||
|
await app.listen(Utility.appPort);
|
||||||
|
}
|
||||||
|
bootstrap();
|
||||||
@ -0,0 +1,104 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import MasterConfigCategory from './master-config-category.entity';
|
||||||
|
import { MasterConfigCategoryService } from './master-config-category.service';
|
||||||
|
|
||||||
|
@Controller('master-config/category')
|
||||||
|
export class MasterConfigCategoryController {
|
||||||
|
constructor(private masterConfigService: MasterConfigCategoryService) { }
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.masterConfigService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if (!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_IN_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() masterConfig: MasterConfigCategory, @Res() res: Response) {
|
||||||
|
if (!masterConfig) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.filter(masterConfig) || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() masterConfig: MasterConfigCategory, @Res() res: Response) {
|
||||||
|
if (!masterConfig) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete masterConfig.id;
|
||||||
|
const response = await this.masterConfigService.upsert(masterConfig, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() masterConfig: MasterConfigCategory, @Res() res: Response) {
|
||||||
|
if (!masterConfig || !masterConfig.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.upsert(masterConfig, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if (!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,34 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({tableName: 'master_config_category_ref'})
|
||||||
|
export default class MasterConfigCategory extends Model {
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryName: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryCode: number;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryDescription: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
categoryType: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
parentCode: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
}
|
||||||
@ -0,0 +1,37 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import MasterConfigCategory from './master-config-category.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class MasterConfigCategoryService {
|
||||||
|
async findAll(): Promise<{rows: MasterConfigCategory[], count: number}> {
|
||||||
|
return MasterConfigCategory.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<MasterConfigCategory> {
|
||||||
|
return MasterConfigCategory.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(masterConfig: MasterConfigCategory) : Promise<MasterConfigCategory[]> {
|
||||||
|
return MasterConfigCategory.findAll({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(masterConfig: MasterConfigCategory): Promise<MasterConfigCategory> {
|
||||||
|
return MasterConfigCategory.findOne({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return MasterConfigCategory.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(masterConfig: MasterConfigCategory, insertIfNotFound: boolean): Promise<MasterConfigCategory | [affectedCount: number]> {
|
||||||
|
if(masterConfig.id) {
|
||||||
|
const existingmasterConfig = await this.findByPk(masterConfig.id);
|
||||||
|
if(existingmasterConfig) {
|
||||||
|
return MasterConfigCategory.update(masterConfig, {where: {id: masterConfig.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return MasterConfigCategory.create(masterConfig as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,105 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import { MasterConfigMappingService } from './master-config-mapping.service';
|
||||||
|
import MasterConfigMapping from './master-config-mapping.entity';
|
||||||
|
|
||||||
|
@Controller('master-config/mapping')
|
||||||
|
export class MasterConfigMappingController {
|
||||||
|
|
||||||
|
constructor(private masterConfigService: MasterConfigMappingService) {
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.masterConfigService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_IN_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() masterConfig: MasterConfigMapping, @Res() res: Response) {
|
||||||
|
if(!masterConfig) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.filter(masterConfig) || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() masterConfig: MasterConfigMapping, @Res() res: Response) {
|
||||||
|
if(!masterConfig) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete masterConfig.id;
|
||||||
|
const response = await this.masterConfigService.upsert(masterConfig, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() masterConfig: MasterConfigMapping, @Res() res: Response) {
|
||||||
|
if(!masterConfig || !masterConfig.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.upsert(masterConfig, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,34 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({tableName: 'master_config_mapping'})
|
||||||
|
export default class MasterConfigMapping extends Model {
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
companyCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
dispSerialNumber: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
defaultValue: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
}
|
||||||
@ -0,0 +1,39 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import MasterConfigMapping from './master-config-mapping.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class MasterConfigMappingService {
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: MasterConfigMapping[], count: number}> {
|
||||||
|
return MasterConfigMapping.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<MasterConfigMapping> {
|
||||||
|
return MasterConfigMapping.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
filter(masterConfig: MasterConfigMapping) : Promise<MasterConfigMapping[]> {
|
||||||
|
return MasterConfigMapping.findAll({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(masterConfig: MasterConfigMapping): Promise<MasterConfigMapping> {
|
||||||
|
return MasterConfigMapping.findOne({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return MasterConfigMapping.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(masterConfig: MasterConfigMapping, insertIfNotFound: boolean): Promise<MasterConfigMapping | [affectedCount: number]> {
|
||||||
|
if(masterConfig.id) {
|
||||||
|
const existingUser = await this.findByPk(masterConfig.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return MasterConfigMapping.update(masterConfig, {where: {id: masterConfig.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return MasterConfigMapping.create(masterConfig as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
102
src/master-config/master-config.controller.ts
Normal file
102
src/master-config/master-config.controller.ts
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { MasterConfigService } from './master-config.service';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from '../common/GenericResponse.model';
|
||||||
|
import MasterConfig from './master-config.entity';
|
||||||
|
|
||||||
|
@Controller('master-config')
|
||||||
|
export class MasterConfigController {
|
||||||
|
constructor(private masterConfigService: MasterConfigService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.masterConfigService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() masterConfig: MasterConfig, @Res() res: Response) {
|
||||||
|
if(!masterConfig) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.filter(masterConfig) || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.status(200).send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() masterConfig: MasterConfig, @Res() res: Response) {
|
||||||
|
if(!masterConfig) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.upsert(masterConfig, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() masterConfig: MasterConfig, @Res() res: Response) {
|
||||||
|
if(!masterConfig || !masterConfig.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.upsert(masterConfig, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.masterConfigService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
38
src/master-config/master-config.entity.ts
Normal file
38
src/master-config/master-config.entity.ts
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, Unique } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({tableName: 'master_config_ref'})
|
||||||
|
export default class MasterConfig extends Model {
|
||||||
|
|
||||||
|
@Unique(true)
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configName: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configCategoryCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configDesc: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
parentCode: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
configType: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
}
|
||||||
14
src/master-config/master-config.module.ts
Normal file
14
src/master-config/master-config.module.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { MasterConfigMappingController } from './master-config-mapping/master-config-mapping.controller';
|
||||||
|
import { MasterConfigCategoryController } from './master-config-category/master-config-category.controller';
|
||||||
|
import { MasterConfigController } from './master-config.controller';
|
||||||
|
import { MasterConfigService } from './master-config.service';
|
||||||
|
import { MasterConfigMappingService } from './master-config-mapping/master-config-mapping.service';
|
||||||
|
import { MasterConfigCategoryService } from './master-config-category/master-config-category.service';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
controllers: [MasterConfigController, MasterConfigMappingController, MasterConfigCategoryController],
|
||||||
|
providers: [MasterConfigService, MasterConfigMappingService, MasterConfigCategoryService],
|
||||||
|
imports: []
|
||||||
|
})
|
||||||
|
export class MasterConfigModule { }
|
||||||
43
src/master-config/master-config.service.ts
Normal file
43
src/master-config/master-config.service.ts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import MasterConfig from './master-config.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class MasterConfigService {
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: MasterConfig[], count: number}> {
|
||||||
|
return MasterConfig.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<MasterConfig> {
|
||||||
|
return MasterConfig.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(masterConfig: MasterConfig): Promise<MasterConfig> {
|
||||||
|
return MasterConfig.findOne({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(masterConfig: MasterConfig) : Promise<MasterConfig[]> {
|
||||||
|
return MasterConfig.findAll({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return MasterConfig.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(masterConfig: MasterConfig, insertIfNotFound: boolean): Promise<MasterConfig | [affectedCount: number]> {
|
||||||
|
if(masterConfig.id) {
|
||||||
|
const existingUser = await this.findByPk(masterConfig.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return MasterConfig.update(masterConfig, {where: {id: masterConfig.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return MasterConfig.create(masterConfig as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async login(masterConfig: MasterConfig): Promise<MasterConfig> {
|
||||||
|
return MasterConfig.findOne({where: masterConfig as any})
|
||||||
|
}
|
||||||
|
}
|
||||||
103
src/subscription/subscription.controller.ts
Normal file
103
src/subscription/subscription.controller.ts
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import { SubscriptionService } from './subscription.service';
|
||||||
|
import Subscription from './subscription.entity';
|
||||||
|
|
||||||
|
@Controller('subscriptions')
|
||||||
|
export class SubscriptionController {
|
||||||
|
constructor(private subscriptionsService: SubscriptionService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAll(@Res() res: Response) {
|
||||||
|
const response = await this.subscriptionsService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.subscriptionsService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() subscription: Subscription, @Res() res: Response) {
|
||||||
|
if(!subscription) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.subscriptionsService.filter(subscription) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() subscription: Subscription, @Res() res: Response) {
|
||||||
|
if(!subscription) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete subscription.id;
|
||||||
|
const response = await this.subscriptionsService.upsert(subscription, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() subscription: Subscription, @Res() res: Response) {
|
||||||
|
if(!subscription || !subscription.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.subscriptionsService.upsert(subscription, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.subscriptionsService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
55
src/subscription/subscription.entity.ts
Normal file
55
src/subscription/subscription.entity.ts
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, ForeignKey } from 'sequelize-typescript';
|
||||||
|
import { User } from 'src/user/user.entity';
|
||||||
|
|
||||||
|
@Table({ tableName: 'subscription', timestamps: true })
|
||||||
|
export default class Subscription extends Model {
|
||||||
|
|
||||||
|
@Column({ type: DataType.BIGINT, primaryKey: true, autoIncrement: true })
|
||||||
|
id: number;
|
||||||
|
|
||||||
|
@ForeignKey(() => User)
|
||||||
|
@Column({ type: DataType.BIGINT })
|
||||||
|
user_id: number;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
plan_type: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
start_date: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
end_date: Date;
|
||||||
|
|
||||||
|
@Default(true)
|
||||||
|
@Column({ type: DataType.BOOLEAN })
|
||||||
|
is_active: boolean;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
createdAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
updatedAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
deletedAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.INTEGER })
|
||||||
|
version: number;
|
||||||
|
}
|
||||||
12
src/subscription/subscription.module.ts
Normal file
12
src/subscription/subscription.module.ts
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { SubscriptionService } from './subscription.service';
|
||||||
|
// import { SubscriptionCategoryService } from './subscription-category/subscription-category.service';
|
||||||
|
import { SubscriptionController } from './subscription.controller';
|
||||||
|
// import { SubscriptionCategoryController } from './subscription-category/subscription-category.controller';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
imports: [],
|
||||||
|
providers: [SubscriptionService, ],
|
||||||
|
controllers: [SubscriptionController,]
|
||||||
|
})
|
||||||
|
export class SubscriptionsModule {}
|
||||||
38
src/subscription/subscription.service.ts
Normal file
38
src/subscription/subscription.service.ts
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import Subscription from './subscription.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class SubscriptionService {
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: Subscription[], count: number}> {
|
||||||
|
return Subscription.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<Subscription> {
|
||||||
|
return Subscription.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(subscription: Subscription) : Promise<Subscription[]> {
|
||||||
|
return Subscription.findAll({where: subscription as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(subscription: Subscription): Promise<Subscription> {
|
||||||
|
return Subscription.findOne({where: subscription as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return Subscription.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(subscription: Subscription, insertIfNotFound: boolean): Promise<Subscription | [affectedCount: number]> {
|
||||||
|
if(subscription.id) {
|
||||||
|
const existingUser = await this.findByPk(subscription.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return Subscription.update(subscription, {where: {id: subscription.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return Subscription.create(subscription as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { UserAdditionalDetailsController } from './user-additional-details.controller';
|
||||||
|
|
||||||
|
describe('UserAdditionalDetailsController', () => {
|
||||||
|
let controller: UserAdditionalDetailsController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [UserAdditionalDetailsController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<UserAdditionalDetailsController>(UserAdditionalDetailsController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
@ -0,0 +1,103 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { UserAdditionalDetailsService } from './user-additional-details.service';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import UserAdditionalDetail from './user-additional-details.entity';
|
||||||
|
|
||||||
|
@Controller('users/addl/')
|
||||||
|
export class UserAdditionalDetailsController {
|
||||||
|
constructor(private userAdditionalDetailsService: UserAdditionalDetailsService) { }
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async userTypegetAll(@Res() res: Response) {
|
||||||
|
const response = await this.userAdditionalDetailsService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async userTypeFindById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if (!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_IN_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userAdditionalDetailsService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async userTypeFilter(@Body() user: UserAdditionalDetail, @Res() res: Response) {
|
||||||
|
if (!user) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userAdditionalDetailsService.filter(user) || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async userTypeInsert(@Body() user: UserAdditionalDetail, @Res() res: Response) {
|
||||||
|
if (!user) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete user.id;
|
||||||
|
const response = await this.userAdditionalDetailsService.upsert(user, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async userTypeUpdate(@Body() user: UserAdditionalDetail, @Res() res: Response) {
|
||||||
|
if (!user || !user.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userAdditionalDetailsService.upsert(user, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async userTypeDeleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if (!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userAdditionalDetailsService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,31 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, ForeignKey, BelongsTo } from 'sequelize-typescript';
|
||||||
|
import { User } from '../user.entity';
|
||||||
|
|
||||||
|
@Table({tableName: 'user_additional_details'})
|
||||||
|
export default class UserAdditionalDetail extends Model {
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
addlDataType: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.NUMBER})
|
||||||
|
@ForeignKey(() => User)
|
||||||
|
userId: number;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
addlDataName: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({type: DataType.DATEONLY})
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({type: DataType.TEXT})
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
}
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { UserAdditionalDetailsService } from './user-additional-details.service';
|
||||||
|
|
||||||
|
describe('UserAdditionalDetailsService', () => {
|
||||||
|
let service: UserAdditionalDetailsService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [UserAdditionalDetailsService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<UserAdditionalDetailsService>(UserAdditionalDetailsService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
@ -0,0 +1,37 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import UserAdditionalDetail from './user-additional-details.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class UserAdditionalDetailsService {
|
||||||
|
async findAll(): Promise<{rows: UserAdditionalDetail[], count: number}> {
|
||||||
|
return UserAdditionalDetail.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<UserAdditionalDetail> {
|
||||||
|
return UserAdditionalDetail.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
filter(userAdditionalDetail: UserAdditionalDetail) : Promise<UserAdditionalDetail[]> {
|
||||||
|
return UserAdditionalDetail.findAll({where: userAdditionalDetail as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(user: UserAdditionalDetail): Promise<UserAdditionalDetail> {
|
||||||
|
return UserAdditionalDetail.findOne({where: user as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return UserAdditionalDetail.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(userDetail: UserAdditionalDetail, insertIfNotFound: boolean): Promise<UserAdditionalDetail | [affectedCount: number]> {
|
||||||
|
if(userDetail.id) {
|
||||||
|
const existingUser = await this.findByPk(userDetail.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return UserAdditionalDetail.update(userDetail, {where: {id: userDetail.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return UserAdditionalDetail.create(userDetail as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
108
src/user/user-types/user-type.controller.ts
Normal file
108
src/user/user-types/user-type.controller.ts
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from 'src/common/GenericResponse.model';
|
||||||
|
import UserType from './user-type.entity';
|
||||||
|
import { UserTypesService } from './user-types.service';
|
||||||
|
|
||||||
|
@Controller('users/types')
|
||||||
|
export class UserTypesController {
|
||||||
|
|
||||||
|
constructor(private userTypeService?: UserTypesService) {
|
||||||
|
if(!userTypeService) {
|
||||||
|
userTypeService = new UserTypesService();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async userTypegetAll(@Res() res: Response) {
|
||||||
|
const response = await this.userTypeService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async userTypeFindById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_IN_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userTypeService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async userTypeFilter(@Body() user: UserType, @Res() res: Response) {
|
||||||
|
if(!user) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userTypeService.filter(user) || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async userTypeInsert(@Body() user: UserType, @Res() res: Response) {
|
||||||
|
if(!user) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete user.id;
|
||||||
|
const response = await this.userTypeService.upsert(user, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async userTypeUpdate(@Body() user: UserType, @Res() res: Response) {
|
||||||
|
if(!user || !user.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userTypeService.upsert(user, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async userTypeDeleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userTypeService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
}
|
||||||
44
src/user/user-types/user-type.entity.ts
Normal file
44
src/user/user-types/user-type.entity.ts
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, Unique } from 'sequelize-typescript';
|
||||||
|
|
||||||
|
@Table({ tableName: 'user_type' })
|
||||||
|
export default class UserType extends Model {
|
||||||
|
|
||||||
|
@Unique(true)
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
userTypeCode: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
userTypeName: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
userTypeDesc: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
createdAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
updatedAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
deletedAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.NUMBER })
|
||||||
|
version: number;
|
||||||
|
}
|
||||||
18
src/user/user-types/user-types.service.spec.ts
Normal file
18
src/user/user-types/user-types.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { UserTypesService } from './user-types.service';
|
||||||
|
|
||||||
|
describe('UserTypesService', () => {
|
||||||
|
let service: UserTypesService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [UserTypesService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<UserTypesService>(UserTypesService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
39
src/user/user-types/user-types.service.ts
Normal file
39
src/user/user-types/user-types.service.ts
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import UserType from './user-type.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class UserTypesService {
|
||||||
|
|
||||||
|
async findAll(): Promise<{rows: UserType[], count: number}> {
|
||||||
|
return UserType.findAndCountAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
findByPk(id: number): Promise<UserType> {
|
||||||
|
return UserType.findByPk(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
filter(userType: UserType) : Promise<UserType[]> {
|
||||||
|
return UserType.findAll({where: userType as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
findOne(user: UserType): Promise<UserType> {
|
||||||
|
return UserType.findOne({where: user as any})
|
||||||
|
}
|
||||||
|
|
||||||
|
async remove(id: number): Promise<number> {
|
||||||
|
return UserType.destroy({where: {id: id}});
|
||||||
|
}
|
||||||
|
|
||||||
|
async upsert(userDetail: UserType, insertIfNotFound: boolean): Promise<UserType | [affectedCount: number]> {
|
||||||
|
if(userDetail.id) {
|
||||||
|
const existingUser = await this.findByPk(userDetail.id);
|
||||||
|
if(existingUser) {
|
||||||
|
return UserType.update(userDetail, {where: {id: userDetail.id}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(insertIfNotFound) {
|
||||||
|
return UserType.create(userDetail as any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/user/user.controller.spec.ts
Normal file
18
src/user/user.controller.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { UserController } from './user.controller';
|
||||||
|
|
||||||
|
describe('UserController', () => {
|
||||||
|
let controller: UserController;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
controllers: [UserController],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
controller = module.get<UserController>(UserController);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(controller).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
136
src/user/user.controller.ts
Normal file
136
src/user/user.controller.ts
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
import { Body, Controller, Delete, Get, Param, Post, Put, Res } from '@nestjs/common';
|
||||||
|
import { UserService } from './user.service';
|
||||||
|
import { Response } from 'express';
|
||||||
|
import { GenericResponse } from '../common/GenericResponse.model';
|
||||||
|
import { User } from './user.entity';
|
||||||
|
|
||||||
|
@Controller('users')
|
||||||
|
export class UserController {
|
||||||
|
constructor(private userService: UserService) {}
|
||||||
|
|
||||||
|
@Get("/all")
|
||||||
|
async getAllUsers(@Res() res: Response) {
|
||||||
|
const response = await this.userService.findAll() || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get(':id')
|
||||||
|
async findById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userService.findByPk(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/filter')
|
||||||
|
async filter(@Body() user: User, @Res() res: Response) {
|
||||||
|
if(!user) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userService.filter(user) || [];
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.status(200).send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post()
|
||||||
|
async insert(@Body() user: User, @Res() res: Response) {
|
||||||
|
if(!user) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delete user.id;
|
||||||
|
if(user.password) {
|
||||||
|
user.password = this.encryptPassword(user.password);
|
||||||
|
}
|
||||||
|
const response = await this.userService.upsert(user, true);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Put()
|
||||||
|
async update(@Body() user: User, @Res() res: Response) {
|
||||||
|
if(!user || !user.id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(user.password) {
|
||||||
|
user.password = this.encryptPassword(user.password);
|
||||||
|
}
|
||||||
|
const response = await this.userService.upsert(user, false);
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Delete(':id')
|
||||||
|
async deleteById(@Param('id') id: number, @Res() res: Response) {
|
||||||
|
if(!id) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await this.userService.remove(id) || {};
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/login')
|
||||||
|
async login(@Body() user: User, @Res() res: Response) {
|
||||||
|
if(!user || !user.email || !user.password) {
|
||||||
|
const response = new GenericResponse({
|
||||||
|
exception: true,
|
||||||
|
exceptionSeverity: 'HIGH',
|
||||||
|
exceptionMessage: 'ERR.NO_ID_REQ',
|
||||||
|
stackTrace: 'Request'
|
||||||
|
}, null);
|
||||||
|
res.status(401).send(response);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
user.password = this.encryptPassword(user.password);
|
||||||
|
user.status = 'active';
|
||||||
|
const response = {user: {} as User, token: ''};
|
||||||
|
response.user = await this.userService.login(user) || {} as User;
|
||||||
|
if(response.user && response.user.id) {
|
||||||
|
response.token = await this.encryptPassword(response.user.email);
|
||||||
|
}
|
||||||
|
const httpResponse = new GenericResponse(null, response)
|
||||||
|
res.status(200).send(httpResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
encryptPassword(password: string) {
|
||||||
|
return Buffer.from(password).toString('base64');
|
||||||
|
}
|
||||||
|
}
|
||||||
59
src/user/user.entity.ts
Normal file
59
src/user/user.entity.ts
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
import { Table, Column, Model, Default, DataType, HasMany, Unique, ForeignKey } from 'sequelize-typescript';
|
||||||
|
import UserAdditionalDetail from './user-additional-details/user-additional-details.entity';
|
||||||
|
import UserType from './user-types/user-type.entity';
|
||||||
|
|
||||||
|
@Table({ tableName: 'users' })
|
||||||
|
export class User extends Model {
|
||||||
|
|
||||||
|
@Unique(true)
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
email: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
name: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
password: string;
|
||||||
|
|
||||||
|
@ForeignKey(() => UserType)
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
userTypeCode: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
primaryRole: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
instituteCode: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Default(new Date())
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validFrom: Date;
|
||||||
|
|
||||||
|
@Default(new Date("2070-12-31"))
|
||||||
|
@Column({ type: DataType.DATEONLY })
|
||||||
|
validTill: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
createBy: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.TEXT })
|
||||||
|
modifiedBy: string;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
createdAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
updatedAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.DATE })
|
||||||
|
deletedAt: Date;
|
||||||
|
|
||||||
|
@Column({ type: DataType.NUMBER })
|
||||||
|
version: number;
|
||||||
|
|
||||||
|
@HasMany(() => UserAdditionalDetail)
|
||||||
|
additionalDetails: UserAdditionalDetail[];
|
||||||
|
}
|
||||||
14
src/user/user.module.ts
Normal file
14
src/user/user.module.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { UserController } from './user.controller';
|
||||||
|
import { UserService } from './user.service';
|
||||||
|
import { UserTypesService } from './user-types/user-types.service';
|
||||||
|
import { UserTypesController } from './user-types/user-type.controller';
|
||||||
|
import { UserAdditionalDetailsController } from './user-additional-details/user-additional-details.controller';
|
||||||
|
import { UserAdditionalDetailsService } from './user-additional-details/user-additional-details.service';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
controllers: [UserController, UserTypesController, UserAdditionalDetailsController],
|
||||||
|
providers: [UserService, UserTypesService, UserAdditionalDetailsService],
|
||||||
|
imports: []
|
||||||
|
})
|
||||||
|
export class UserModule { }
|
||||||
18
src/user/user.service.spec.ts
Normal file
18
src/user/user.service.spec.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { UserService } from './user.service';
|
||||||
|
|
||||||
|
describe('UserService', () => {
|
||||||
|
let service: UserService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [UserService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<UserService>(UserService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user