typescript-express-starter 6.2.1 → 6.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (122) hide show
  1. package/README.kr.md +35 -12
  2. package/README.md +36 -13
  3. package/bin/cli.js +4 -3
  4. package/lib/default/.swcrc +41 -0
  5. package/lib/default/nodemon.json +2 -2
  6. package/lib/default/package.json +12 -8
  7. package/lib/default/src/app.ts +1 -2
  8. package/lib/default/src/http/auth.http +12 -15
  9. package/lib/default/src/http/users.http +12 -16
  10. package/lib/default/src/index.ts +1 -0
  11. package/lib/default/src/middlewares/auth.middleware.ts +3 -3
  12. package/lib/default/src/models/users.model.ts +5 -5
  13. package/lib/default/src/server.ts +1 -2
  14. package/lib/default/src/services/auth.service.ts +5 -5
  15. package/lib/default/src/services/users.service.ts +3 -3
  16. package/lib/default/src/tests/auth.test.ts +4 -4
  17. package/lib/default/src/tests/users.test.ts +4 -4
  18. package/lib/default/src/utils/logger.ts +5 -5
  19. package/lib/default/tsconfig.json +2 -2
  20. package/lib/knex/.swcrc +39 -0
  21. package/lib/knex/knexfile.ts +6 -6
  22. package/lib/knex/nodemon.json +2 -2
  23. package/lib/knex/package.json +11 -8
  24. package/lib/knex/src/app.ts +2 -3
  25. package/lib/knex/src/databases/index.ts +6 -6
  26. package/lib/knex/src/http/auth.http +12 -15
  27. package/lib/knex/src/http/users.http +12 -16
  28. package/lib/knex/src/index.ts +1 -0
  29. package/lib/knex/src/middlewares/auth.middleware.ts +4 -4
  30. package/lib/knex/src/server.ts +1 -2
  31. package/lib/knex/src/services/auth.service.ts +5 -5
  32. package/lib/knex/src/services/users.service.ts +3 -3
  33. package/lib/knex/src/tests/auth.test.ts +2 -2
  34. package/lib/knex/src/tests/index.test.ts +1 -1
  35. package/lib/knex/src/tests/users.test.ts +2 -2
  36. package/lib/knex/src/utils/logger.ts +5 -5
  37. package/lib/knex/tsconfig.json +2 -2
  38. package/lib/mongoose/.swcrc +39 -0
  39. package/lib/mongoose/docker-compose.yml +0 -4
  40. package/lib/mongoose/nodemon.json +2 -2
  41. package/lib/mongoose/package.json +12 -8
  42. package/lib/mongoose/src/app.ts +2 -3
  43. package/lib/mongoose/src/configs/development.json +1 -1
  44. package/lib/mongoose/src/configs/production.json +1 -1
  45. package/lib/mongoose/src/configs/test.json +1 -1
  46. package/lib/mongoose/src/http/auth.http +32 -0
  47. package/lib/mongoose/src/http/users.http +34 -0
  48. package/lib/mongoose/src/index.ts +1 -0
  49. package/lib/mongoose/src/middlewares/auth.middleware.ts +3 -3
  50. package/lib/mongoose/src/server.ts +1 -2
  51. package/lib/mongoose/src/services/auth.service.ts +5 -5
  52. package/lib/mongoose/src/services/users.service.ts +3 -3
  53. package/lib/mongoose/src/utils/logger.ts +5 -5
  54. package/lib/mongoose/tsconfig.json +2 -2
  55. package/lib/prisma/.env +1 -1
  56. package/lib/prisma/.swcrc +37 -0
  57. package/lib/prisma/docker-compose.yml +1 -6
  58. package/lib/prisma/nodemon.json +2 -2
  59. package/lib/prisma/package.json +14 -10
  60. package/lib/prisma/src/app.ts +2 -3
  61. package/lib/prisma/src/http/auth.http +12 -15
  62. package/lib/prisma/src/http/users.http +12 -16
  63. package/lib/prisma/src/index.ts +1 -0
  64. package/lib/prisma/src/middlewares/auth.middleware.ts +4 -4
  65. package/lib/prisma/src/server.ts +1 -2
  66. package/lib/prisma/src/services/auth.service.ts +5 -5
  67. package/lib/prisma/src/services/users.service.ts +3 -3
  68. package/lib/prisma/src/utils/logger.ts +5 -5
  69. package/lib/prisma/tsconfig.json +2 -2
  70. package/lib/routing-controllers/.swcrc +37 -0
  71. package/lib/routing-controllers/nodemon.json +2 -2
  72. package/lib/routing-controllers/package.json +12 -9
  73. package/lib/routing-controllers/src/app.ts +3 -4
  74. package/lib/routing-controllers/src/http/auth.http +12 -15
  75. package/lib/routing-controllers/src/http/users.http +12 -16
  76. package/lib/routing-controllers/src/index.ts +1 -0
  77. package/lib/routing-controllers/src/middlewares/auth.middleware.ts +3 -3
  78. package/lib/routing-controllers/src/middlewares/validation.middleware.ts +10 -2
  79. package/lib/routing-controllers/src/models/users.model.ts +5 -5
  80. package/lib/routing-controllers/src/server.ts +1 -3
  81. package/lib/routing-controllers/src/services/auth.service.ts +5 -5
  82. package/lib/routing-controllers/src/services/users.service.ts +3 -3
  83. package/lib/routing-controllers/src/utils/logger.ts +5 -5
  84. package/lib/routing-controllers/tsconfig.json +2 -2
  85. package/lib/sequelize/.swcrc +39 -0
  86. package/lib/sequelize/docker-compose.yml +1 -6
  87. package/lib/sequelize/nodemon.json +2 -2
  88. package/lib/sequelize/package.json +12 -8
  89. package/lib/sequelize/src/app.ts +1 -2
  90. package/lib/sequelize/src/configs/development.json +2 -2
  91. package/lib/sequelize/src/configs/production.json +1 -1
  92. package/lib/sequelize/src/configs/test.json +1 -1
  93. package/lib/sequelize/src/http/auth.http +32 -0
  94. package/lib/sequelize/src/http/users.http +34 -0
  95. package/lib/sequelize/src/index.ts +1 -0
  96. package/lib/sequelize/src/middlewares/auth.middleware.ts +4 -4
  97. package/lib/sequelize/src/server.ts +1 -2
  98. package/lib/sequelize/src/services/auth.service.ts +5 -5
  99. package/lib/sequelize/src/services/users.service.ts +3 -3
  100. package/lib/sequelize/src/utils/logger.ts +5 -5
  101. package/lib/sequelize/tsconfig.json +2 -2
  102. package/lib/starter.js +4 -6
  103. package/lib/typeorm/.swcrc +39 -0
  104. package/lib/typeorm/docker-compose.yml +1 -1
  105. package/lib/typeorm/nodemon.json +2 -2
  106. package/lib/typeorm/package.json +12 -8
  107. package/lib/typeorm/src/app.ts +1 -2
  108. package/lib/typeorm/src/configs/development.json +1 -1
  109. package/lib/typeorm/src/configs/production.json +1 -1
  110. package/lib/typeorm/src/configs/test.json +1 -1
  111. package/lib/typeorm/src/databases/index.ts +5 -5
  112. package/lib/typeorm/src/{entity → entities}/users.entity.ts +3 -3
  113. package/lib/typeorm/src/http/auth.http +12 -15
  114. package/lib/typeorm/src/http/users.http +12 -16
  115. package/lib/typeorm/src/index.ts +1 -0
  116. package/lib/typeorm/src/middlewares/auth.middleware.ts +5 -9
  117. package/lib/typeorm/src/server.ts +1 -2
  118. package/lib/typeorm/src/services/auth.service.ts +13 -17
  119. package/lib/typeorm/src/services/users.service.ts +16 -22
  120. package/lib/typeorm/src/utils/logger.ts +5 -5
  121. package/lib/typeorm/tsconfig.json +3 -3
  122. package/package.json +11 -4
@@ -1,14 +1,14 @@
1
1
  import config from 'config';
2
- import fs from 'fs';
3
- import path from 'path';
2
+ import { existsSync, mkdirSync } from 'fs';
3
+ import { join } from 'path';
4
4
  import winston from 'winston';
5
5
  import winstonDaily from 'winston-daily-rotate-file';
6
6
 
7
7
  // logs dir
8
- const logDir: string = path.join(__dirname, config.get('log.dir'));
8
+ const logDir: string = join(__dirname, config.get('log.dir'));
9
9
 
10
- if (!fs.existsSync(logDir)) {
11
- fs.mkdirSync(logDir);
10
+ if (!existsSync(logDir)) {
11
+ mkdirSync(logDir);
12
12
  }
13
13
 
14
14
  // Define log format
@@ -13,7 +13,7 @@
13
13
  "pretty": true,
14
14
  "sourceMap": true,
15
15
  "declaration": true,
16
- "outDir": "./dist",
16
+ "outDir": "dist",
17
17
  "allowJs": true,
18
18
  "noEmit": false,
19
19
  "esModuleInterop": true,
@@ -35,5 +35,5 @@
35
35
  }
36
36
  },
37
37
  "include": ["src/**/*.ts", "src/**/*.json", ".env"],
38
- "exclude": ["node_modules"]
38
+ "exclude": ["node_modules", "src/http", "src/logs", "src/tests"]
39
39
  }
package/lib/starter.js CHANGED
@@ -1,7 +1,8 @@
1
1
  /*****************************************************************
2
- * Create new typescript-express-starter project.
3
- * By AGUMON <ljlm0402@gmail.com>
4
- * December 18, 2019.
2
+ * Create Typescript Express Starter
3
+ * 2019.12.18 ~ 🎮
4
+ * Made By AGUMON 🦖
5
+ * https://github.com/ljlm0402/typescript-express-starter
5
6
  *****************************************************************/
6
7
 
7
8
  const chalk = require("chalk");
@@ -44,14 +45,11 @@ const createProject = async (projectName) => {
44
45
  spinner = ora();
45
46
  spinner.start();
46
47
 
47
- // manage node_modules
48
48
  await installNodeModules(projectName, spinner);
49
49
  isUpdated && (await updateNodeModules(projectName, spinner));
50
50
  isDeduped && (await dedupeNodeModules(projectName, spinner));
51
-
52
51
  await postInstallScripts(projectName, template, spinner);
53
52
 
54
- // set gitignore
55
53
  await createGitignore(projectName, spinner);
56
54
  await initGit(projectName);
57
55
 
@@ -0,0 +1,39 @@
1
+ {
2
+ "jsc": {
3
+ "parser": {
4
+ "syntax": "typescript",
5
+ "tsx": false,
6
+ "dynamicImport": true,
7
+ "decorators": true
8
+ },
9
+ "transform": {
10
+ "legacyDecorator": true,
11
+ "decoratorMetadata": true
12
+ },
13
+ "target": "es2017",
14
+ "externalHelpers": false,
15
+ "keepClassNames": true,
16
+ "loose": false,
17
+ "minify": {
18
+ "compress": false,
19
+ "mangle": false
20
+ },
21
+ "baseUrl": "src",
22
+ "paths": {
23
+ "@/*": ["*"],
24
+ "@controllers/*": ["controllers/*"],
25
+ "@databases": ["databases"],
26
+ "@dtos/*": ["dtos/*"],
27
+ "@entities/*": ["entities/*"],
28
+ "@exceptions/*": ["exceptions/*"],
29
+ "@interfaces/*": ["interfaces/*"],
30
+ "@middlewares/*": ["middlewares/*"],
31
+ "@routes/*": ["routes/*"],
32
+ "@services/*": ["services/*"],
33
+ "@utils/*": ["utils/*"]
34
+ }
35
+ },
36
+ "module": {
37
+ "type": "commonjs"
38
+ }
39
+ }
@@ -35,7 +35,7 @@ services:
35
35
  environment:
36
36
  POSTGRESQL_USERNAME: root
37
37
  POSTGRESQL_PASSWORD: password
38
- POSTGRESQL_DATABASE: typeorm
38
+ POSTGRESQL_DATABASE: test
39
39
  ports:
40
40
  - '5432:5432'
41
41
  networks:
@@ -5,8 +5,8 @@
5
5
  ],
6
6
  "ext": "js,ts,json",
7
7
  "ignore": [
8
- "src/**/*.spec.ts",
9
- "src/**/*.test.ts"
8
+ "src/logs/*",
9
+ "src/**/*.{spec,test}.ts"
10
10
  ],
11
11
  "exec": "ts-node -r tsconfig-paths/register --transpile-only src/server.ts"
12
12
  }
@@ -7,7 +7,8 @@
7
7
  "scripts": {
8
8
  "start": "npm run build && cross-env NODE_ENV=production node dist/server.js",
9
9
  "dev": "cross-env NODE_ENV=development nodemon",
10
- "build": "tsc && npx tsc-alias",
10
+ "build": "swc src -d dist --source-maps --copy-files",
11
+ "build:tsc": "tsc && tsc-alias",
11
12
  "test": "jest --forceExit --detectOpenHandles",
12
13
  "lint": "eslint --ignore-path .gitignore --ext .ts src/",
13
14
  "lint:fix": "npm run lint -- --fix",
@@ -22,28 +23,24 @@
22
23
  "config": "^3.3.6",
23
24
  "cookie-parser": "^1.4.5",
24
25
  "cors": "^2.8.5",
25
- "cross-env": "^7.0.3",
26
26
  "dotenv": "^10.0.0",
27
27
  "envalid": "^7.1.0",
28
28
  "express": "^4.17.1",
29
29
  "helmet": "^4.6.0",
30
30
  "hpp": "^0.2.3",
31
- "jest": "^27.0.6",
32
31
  "jsonwebtoken": "^8.5.1",
33
32
  "morgan": "^1.10.0",
34
- "pm2": "^5.1.0",
35
33
  "pg": "^8.6.0",
36
34
  "reflect-metadata": "^0.1.13",
37
35
  "swagger-jsdoc": "^6.0.0",
38
36
  "swagger-ui-express": "^4.1.6",
39
- "ts-jest": "^27.0.3",
40
- "ts-node": "^10.0.0",
41
37
  "typeorm": "^0.2.34",
42
- "typescript": "^4.3.5",
43
38
  "winston": "^3.3.3",
44
39
  "winston-daily-rotate-file": "^4.5.5"
45
40
  },
46
41
  "devDependencies": {
42
+ "@swc/cli": "^0.1.51",
43
+ "@swc/core": "^1.2.108",
47
44
  "@types/bcrypt": "^5.0.0",
48
45
  "@types/compression": "^1.7.1",
49
46
  "@types/config": "^0.0.39",
@@ -63,16 +60,23 @@
63
60
  "@types/winston": "^2.4.4",
64
61
  "@typescript-eslint/eslint-plugin": "^4.28.2",
65
62
  "@typescript-eslint/parser": "^4.28.2",
63
+ "cross-env": "^7.0.3",
66
64
  "eslint": "^7.30.0",
67
65
  "eslint-config-prettier": "^8.3.0",
68
66
  "eslint-plugin-prettier": "^3.4.0",
69
67
  "husky": "^7.0.1",
68
+ "jest": "^27.0.6",
70
69
  "lint-staged": "^11.0.0",
71
70
  "node-config": "^0.0.2",
72
71
  "node-gyp": "^8.1.0",
73
72
  "nodemon": "^2.0.9",
73
+ "pm2": "^5.1.0",
74
74
  "prettier": "^2.3.2",
75
75
  "supertest": "^6.1.3",
76
- "tsconfig-paths": "^3.10.1"
76
+ "ts-jest": "^27.0.7",
77
+ "ts-node": "^10.4.0",
78
+ "tsc-alias": "^1.4.1",
79
+ "tsconfig-paths": "^3.10.1",
80
+ "typescript": "^4.5.2"
77
81
  }
78
82
  }
@@ -1,6 +1,5 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
2
-
3
1
  import 'reflect-metadata';
2
+ import '@/index';
4
3
  import cookieParser from 'cookie-parser';
5
4
  import cors from 'cors';
6
5
  import config from 'config';
@@ -4,7 +4,7 @@
4
4
  "host": "localhost",
5
5
  "user": "root",
6
6
  "password": "password",
7
- "database": "typeorm"
7
+ "database": "test"
8
8
  },
9
9
  "secretKey": "secretKey",
10
10
  "log": {
@@ -4,7 +4,7 @@
4
4
  "host": "localhost",
5
5
  "user": "root",
6
6
  "password": "password",
7
- "database": "typeorm"
7
+ "database": "test"
8
8
  },
9
9
  "secretKey": "secretKey",
10
10
  "log": {
@@ -4,7 +4,7 @@
4
4
  "host": "localhost",
5
5
  "user": "root",
6
6
  "password": "password",
7
- "database": "typeorm"
7
+ "database": "test"
8
8
  },
9
9
  "secretKey": "secretKey",
10
10
  "log": {
@@ -1,5 +1,5 @@
1
1
  import config from 'config';
2
- import path from 'path';
2
+ import { join } from 'path';
3
3
  import { ConnectionOptions } from 'typeorm';
4
4
  import { dbConfig } from '@interfaces/db.interface';
5
5
 
@@ -13,11 +13,11 @@ export const dbConnection: ConnectionOptions = {
13
13
  database: database,
14
14
  synchronize: true,
15
15
  logging: false,
16
- entities: [path.join(__dirname, '../**/*.entity{.ts,.js}')],
17
- migrations: [path.join(__dirname, '../**/*.migration{.ts,.js}')],
18
- subscribers: [path.join(__dirname, '../**/*.subscriber{.ts,.js}')],
16
+ entities: [join(__dirname, '../**/*.entity{.ts,.js}')],
17
+ migrations: [join(__dirname, '../**/*.migration{.ts,.js}')],
18
+ subscribers: [join(__dirname, '../**/*.subscriber{.ts,.js}')],
19
19
  cli: {
20
- entitiesDir: 'src/entity',
20
+ entitiesDir: 'src/entities',
21
21
  migrationsDir: 'src/migration',
22
22
  subscribersDir: 'src/subscriber',
23
23
  },
@@ -1,15 +1,15 @@
1
1
  import { IsNotEmpty } from 'class-validator';
2
- import { Entity, PrimaryGeneratedColumn, Column, Unique, CreateDateColumn, UpdateDateColumn } from 'typeorm';
2
+ import { BaseEntity, Entity, PrimaryGeneratedColumn, Column, Unique, CreateDateColumn, UpdateDateColumn } from 'typeorm';
3
3
  import { User } from '@interfaces/users.interface';
4
4
 
5
5
  @Entity()
6
- @Unique(['email'])
7
- export class UserEntity implements User {
6
+ export class UserEntity extends BaseEntity implements User {
8
7
  @PrimaryGeneratedColumn()
9
8
  id: number;
10
9
 
11
10
  @Column()
12
11
  @IsNotEmpty()
12
+ @Unique(['email'])
13
13
  email: string;
14
14
 
15
15
  @Column()
@@ -1,35 +1,32 @@
1
- # auth API
2
-
3
- ###
4
1
  # baseURL
5
2
  @baseURL = http://localhost:3000
6
3
 
7
4
  ###
8
- # signup
9
- POST {{baseURL}}/signup
5
+ # User Signup
6
+ POST {{ baseURL }}/signup
10
7
  Content-Type: application/json
11
8
 
12
9
  {
13
- "email": "example@gmail.com",
14
- "password": "qwer1234"
10
+ "email": "example@email.com",
11
+ "password": "password"
15
12
  }
16
13
 
17
14
  ###
18
- # Login
19
- POST {{baseURL}}/login
15
+ # User Login
16
+ POST {{ baseURL }}/login
20
17
  Content-Type: application/json
21
18
 
22
19
  {
23
- "email": "lim@gmail.com",
24
- "password": "q1w2e3r4"
20
+ "email": "example@email.com",
21
+ "password": "password"
25
22
  }
26
23
 
27
24
  ###
28
- # Logout
29
- POST {{baseURL}}/logout
25
+ # User Logout
26
+ POST {{ baseURL }}/logout
30
27
  Content-Type: application/json
31
28
 
32
29
  {
33
- "email": "lim@gmail.com",
34
- "password": "q1w2e3r4"
30
+ "email": "example@email.com",
31
+ "password": "password"
35
32
  }
@@ -1,38 +1,34 @@
1
- # users API
2
-
3
- ###
4
1
  # baseURL
5
2
  @baseURL = http://localhost:3000
6
3
 
7
4
  ###
8
5
  # Find All Users
9
- GET {{baseURL}}/users
6
+ GET {{ baseURL }}/users
10
7
 
11
8
  ###
12
9
  # Find User By Id
13
- GET {{baseURL}}/users/1
14
-
10
+ GET {{ baseURL }}/users/1
15
11
 
16
12
  ###
17
- # Add User
18
- POST {{baseURL}}/users
13
+ # Create User
14
+ POST {{ baseURL }}/users
19
15
  Content-Type: application/json
20
16
 
21
17
  {
22
- "email": "example@gmail.com",
23
- "password": "qwer1234"
18
+ "email": "example@email.com",
19
+ "password": "password"
24
20
  }
25
21
 
26
22
  ###
27
- # Edit User By Id
28
- PUT {{baseURL}}/users/1
23
+ # Modify User By Id
24
+ PUT {{ baseURL }}/users/1
29
25
  Content-Type: application/json
30
26
 
31
27
  {
32
- "email": "example@gmail.com",
33
- "password": "qwer1234"
28
+ "email": "example@email.com",
29
+ "password": "password"
34
30
  }
35
31
 
36
32
  ###
37
- # Del User By Id
38
- DELETE {{baseURL}}/users/1
33
+ # Delete User By Id
34
+ DELETE {{ baseURL }}/users/1
@@ -0,0 +1 @@
1
+ process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
@@ -1,22 +1,18 @@
1
1
  import config from 'config';
2
2
  import { NextFunction, Response } from 'express';
3
- import jwt from 'jsonwebtoken';
4
- import { getRepository } from 'typeorm';
5
- import { UserEntity } from '@entity/users.entity';
3
+ import { verify } from 'jsonwebtoken';
4
+ import { UserEntity } from '@entities/users.entity';
6
5
  import { HttpException } from '@exceptions/HttpException';
7
6
  import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
8
7
 
9
8
  const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFunction) => {
10
9
  try {
11
- const Authorization = req.cookies['Authorization'] || req.header('Authorization').split('Bearer ')[1] || null;
10
+ const Authorization = req.cookies['Authorization'] || (req.header('Authorization') ? req.header('Authorization').split('Bearer ')[1] : null);
12
11
 
13
12
  if (Authorization) {
14
13
  const secretKey: string = config.get('secretKey');
15
- const verificationResponse = (await jwt.verify(Authorization, secretKey)) as DataStoredInToken;
16
- const userId = verificationResponse.id;
17
-
18
- const userRepository = getRepository(UserEntity);
19
- const findUser = await userRepository.findOne(userId, { select: ['id', 'email', 'password'] });
14
+ const { id } = (await verify(Authorization, secretKey)) as DataStoredInToken;
15
+ const findUser = await UserEntity.findOne(id, { select: ['id', 'email', 'password'] });
20
16
 
21
17
  if (findUser) {
22
18
  req.user = findUser;
@@ -1,6 +1,5 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
2
-
3
1
  import 'dotenv/config';
2
+ import '@/index';
4
3
  import App from '@/app';
5
4
  import AuthRoute from '@routes/auth.route';
6
5
  import IndexRoute from '@routes/index.route';
@@ -1,37 +1,34 @@
1
- import bcrypt from 'bcrypt';
1
+ import { compare, hash } from 'bcrypt';
2
2
  import config from 'config';
3
- import jwt from 'jsonwebtoken';
4
- import { getRepository } from 'typeorm';
3
+ import { sign } from 'jsonwebtoken';
4
+ import { EntityRepository, Repository } from 'typeorm';
5
5
  import { CreateUserDto } from '@dtos/users.dto';
6
- import { UserEntity } from '@entity/users.entity';
6
+ import { UserEntity } from '@entities/users.entity';
7
7
  import { HttpException } from '@exceptions/HttpException';
8
8
  import { DataStoredInToken, TokenData } from '@interfaces/auth.interface';
9
9
  import { User } from '@interfaces/users.interface';
10
10
  import { isEmpty } from '@utils/util';
11
11
 
12
- class AuthService {
13
- public users = UserEntity;
14
-
12
+ @EntityRepository()
13
+ class AuthService extends Repository<UserEntity> {
15
14
  public async signup(userData: CreateUserDto): Promise<User> {
16
15
  if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
17
16
 
18
- const userRepository = getRepository(this.users);
19
- const findUser: User = await userRepository.findOne({ where: { email: userData.email } });
17
+ const findUser: User = await UserEntity.findOne({ where: { email: userData.email } });
20
18
  if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
21
19
 
22
- const hashedPassword = await bcrypt.hash(userData.password, 10);
23
- const createUserData: User = await userRepository.save({ ...userData, password: hashedPassword });
20
+ const hashedPassword = await hash(userData.password, 10);
21
+ const createUserData: User = await UserEntity.create({ ...userData, password: hashedPassword }).save();
24
22
  return createUserData;
25
23
  }
26
24
 
27
25
  public async login(userData: CreateUserDto): Promise<{ cookie: string; findUser: User }> {
28
26
  if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
29
27
 
30
- const userRepository = getRepository(this.users);
31
- const findUser: User = await userRepository.findOne({ where: { email: userData.email } });
28
+ const findUser: User = await UserEntity.findOne({ where: { email: userData.email } });
32
29
  if (!findUser) throw new HttpException(409, `You're email ${userData.email} not found`);
33
30
 
34
- const isPasswordMatching: boolean = await bcrypt.compare(userData.password, findUser.password);
31
+ const isPasswordMatching: boolean = await compare(userData.password, findUser.password);
35
32
  if (!isPasswordMatching) throw new HttpException(409, "You're password not matching");
36
33
 
37
34
  const tokenData = this.createToken(findUser);
@@ -43,8 +40,7 @@ class AuthService {
43
40
  public async logout(userData: User): Promise<User> {
44
41
  if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
45
42
 
46
- const userRepository = getRepository(this.users);
47
- const findUser: User = await userRepository.findOne({ where: { email: userData.email, password: userData.password } });
43
+ const findUser: User = await UserEntity.findOne({ where: { email: userData.email, password: userData.password } });
48
44
  if (!findUser) throw new HttpException(409, "You're not user");
49
45
 
50
46
  return findUser;
@@ -55,7 +51,7 @@ class AuthService {
55
51
  const secretKey: string = config.get('secretKey');
56
52
  const expiresIn: number = 60 * 60;
57
53
 
58
- return { expiresIn, token: jwt.sign(dataStoredInToken, secretKey, { expiresIn }) };
54
+ return { expiresIn, token: sign(dataStoredInToken, secretKey, { expiresIn }) };
59
55
  }
60
56
 
61
57
  public createCookie(tokenData: TokenData): string {
@@ -1,25 +1,22 @@
1
- import bcrypt from 'bcrypt';
2
- import { getRepository } from 'typeorm';
1
+ import { hash } from 'bcrypt';
2
+ import { EntityRepository, Repository } from 'typeorm';
3
3
  import { CreateUserDto } from '@dtos/users.dto';
4
- import { UserEntity } from '@entity/users.entity';
4
+ import { UserEntity } from '@entities/users.entity';
5
5
  import { HttpException } from '@exceptions/HttpException';
6
6
  import { User } from '@interfaces/users.interface';
7
7
  import { isEmpty } from '@utils/util';
8
8
 
9
- class UserService {
10
- public users = UserEntity;
11
-
9
+ @EntityRepository()
10
+ class UserService extends Repository<UserEntity> {
12
11
  public async findAllUser(): Promise<User[]> {
13
- const userRepository = getRepository(this.users);
14
- const users: User[] = await userRepository.find();
12
+ const users: User[] = await UserEntity.find();
15
13
  return users;
16
14
  }
17
15
 
18
16
  public async findUserById(userId: number): Promise<User> {
19
17
  if (isEmpty(userId)) throw new HttpException(400, "You're not userId");
20
18
 
21
- const userRepository = getRepository(this.users);
22
- const findUser: User = await userRepository.findOne({ where: { id: userId } });
19
+ const findUser: User = await UserEntity.findOne({ where: { id: userId } });
23
20
  if (!findUser) throw new HttpException(409, "You're not user");
24
21
 
25
22
  return findUser;
@@ -28,12 +25,11 @@ class UserService {
28
25
  public async createUser(userData: CreateUserDto): Promise<User> {
29
26
  if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
30
27
 
31
- const userRepository = getRepository(this.users);
32
- const findUser: User = await userRepository.findOne({ where: { email: userData.email } });
28
+ const findUser: User = await UserEntity.findOne({ where: { email: userData.email } });
33
29
  if (findUser) throw new HttpException(409, `You're email ${userData.email} already exists`);
34
30
 
35
- const hashedPassword = await bcrypt.hash(userData.password, 10);
36
- const createUserData: User = await userRepository.save({ ...userData, password: hashedPassword });
31
+ const hashedPassword = await hash(userData.password, 10);
32
+ const createUserData: User = await UserEntity.create({ ...userData, password: hashedPassword }).save();
37
33
 
38
34
  return createUserData;
39
35
  }
@@ -41,25 +37,23 @@ class UserService {
41
37
  public async updateUser(userId: number, userData: CreateUserDto): Promise<User> {
42
38
  if (isEmpty(userData)) throw new HttpException(400, "You're not userData");
43
39
 
44
- const userRepository = getRepository(this.users);
45
- const findUser: User = await userRepository.findOne({ where: { id: userId } });
40
+ const findUser: User = await UserEntity.findOne({ where: { id: userId } });
46
41
  if (!findUser) throw new HttpException(409, "You're not user");
47
42
 
48
- const hashedPassword = await bcrypt.hash(userData.password, 10);
49
- await userRepository.update(userId, { ...userData, password: hashedPassword });
43
+ const hashedPassword = await hash(userData.password, 10);
44
+ await UserEntity.update(userId, { ...userData, password: hashedPassword });
50
45
 
51
- const updateUser: User = await userRepository.findOne({ where: { id: userId } });
46
+ const updateUser: User = await UserEntity.findOne({ where: { id: userId } });
52
47
  return updateUser;
53
48
  }
54
49
 
55
50
  public async deleteUser(userId: number): Promise<User> {
56
51
  if (isEmpty(userId)) throw new HttpException(400, "You're not userId");
57
52
 
58
- const userRepository = getRepository(this.users);
59
- const findUser: User = await userRepository.findOne({ where: { id: userId } });
53
+ const findUser: User = await UserEntity.findOne({ where: { id: userId } });
60
54
  if (!findUser) throw new HttpException(409, "You're not user");
61
55
 
62
- await userRepository.delete({ id: userId });
56
+ await UserEntity.delete({ id: userId });
63
57
  return findUser;
64
58
  }
65
59
  }
@@ -1,14 +1,14 @@
1
1
  import config from 'config';
2
- import fs from 'fs';
3
- import path from 'path';
2
+ import { existsSync, mkdirSync } from 'fs';
3
+ import { join } from 'path';
4
4
  import winston from 'winston';
5
5
  import winstonDaily from 'winston-daily-rotate-file';
6
6
 
7
7
  // logs dir
8
- const logDir: string = path.join(__dirname, config.get('log.dir'));
8
+ const logDir: string = join(__dirname, config.get('log.dir'));
9
9
 
10
- if (!fs.existsSync(logDir)) {
11
- fs.mkdirSync(logDir);
10
+ if (!existsSync(logDir)) {
11
+ mkdirSync(logDir);
12
12
  }
13
13
 
14
14
  // Define log format
@@ -13,7 +13,7 @@
13
13
  "pretty": true,
14
14
  "sourceMap": true,
15
15
  "declaration": true,
16
- "outDir": "./dist",
16
+ "outDir": "dist",
17
17
  "allowJs": true,
18
18
  "noEmit": false,
19
19
  "esModuleInterop": true,
@@ -25,7 +25,7 @@
25
25
  "@controllers/*": ["controllers/*"],
26
26
  "@databases": ["databases"],
27
27
  "@dtos/*": ["dtos/*"],
28
- "@entity/*": ["entity/*"],
28
+ "@entities/*": ["entities/*"],
29
29
  "@exceptions/*": ["exceptions/*"],
30
30
  "@interfaces/*": ["interfaces/*"],
31
31
  "@middlewares/*": ["middlewares/*"],
@@ -35,5 +35,5 @@
35
35
  }
36
36
  },
37
37
  "include": ["src/**/*.ts", "src/**/*.json", ".env"],
38
- "exclude": ["node_modules"]
38
+ "exclude": ["node_modules", "src/http", "src/logs", "src/tests"]
39
39
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "typescript-express-starter",
3
- "version": "6.2.1",
3
+ "version": "6.3.0",
4
4
  "description": "Quick and Easy TypeScript Express Starter",
5
5
  "author": "AGUMON <ljlm0402@gmail.com>",
6
6
  "license": "MIT",
@@ -14,7 +14,6 @@
14
14
  "typeorm",
15
15
  "knex",
16
16
  "prisma",
17
- "querybuilder",
18
17
  "jest",
19
18
  "nodemon",
20
19
  "jsonwebtoken",
@@ -32,7 +31,8 @@
32
31
  "mysql",
33
32
  "mariadb",
34
33
  "mongodb",
35
- "postgresql"
34
+ "postgresql",
35
+ "swc"
36
36
  ],
37
37
  "main": "bin/cli.js",
38
38
  "bin": {
@@ -50,6 +50,13 @@
50
50
  "ora": "^4.0.3"
51
51
  },
52
52
  "devDependencies": {},
53
+ "publishConfig": {
54
+ "access": "public"
55
+ },
56
+ "engines": {
57
+ "node": ">= 10.13.0",
58
+ "npm": ">= 6.11.0"
59
+ },
53
60
  "repository": {
54
61
  "type": "git",
55
62
  "url": "git+https://github.com/ljlm0402/typescript-express-starter.git"
@@ -58,4 +65,4 @@
58
65
  "url": "https://github.com/ljlm0402/typescript-express-starter/issues"
59
66
  },
60
67
  "homepage": "https://github.com/ljlm0402/typescript-express-starter#readme"
61
- }
68
+ }