typescript-express-starter 8.0.2 → 8.1.2

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 (148) hide show
  1. package/lib/default/.env.development.local +13 -0
  2. package/lib/default/.env.production.local +13 -0
  3. package/lib/default/.env.test.local +13 -0
  4. package/lib/default/.swcrc +1 -0
  5. package/lib/default/package.json +0 -2
  6. package/lib/default/src/app.ts +6 -7
  7. package/lib/default/src/config/index.ts +5 -0
  8. package/lib/default/src/middlewares/auth.middleware.ts +2 -2
  9. package/lib/default/src/server.ts +0 -2
  10. package/lib/default/src/services/auth.service.ts +2 -2
  11. package/lib/default/src/utils/logger.ts +2 -2
  12. package/lib/default/tsconfig.json +1 -0
  13. package/lib/graphql/.env.development.local +20 -0
  14. package/lib/graphql/.env.production.local +20 -0
  15. package/lib/graphql/.env.test.local +20 -0
  16. package/lib/graphql/.swcrc +1 -0
  17. package/lib/graphql/package.json +0 -2
  18. package/lib/graphql/src/app.ts +7 -8
  19. package/lib/graphql/src/config/index.ts +5 -0
  20. package/lib/graphql/src/databases/index.ts +6 -8
  21. package/lib/graphql/src/middlewares/auth.middleware.ts +2 -2
  22. package/lib/graphql/src/repositories/auth.repository.ts +2 -2
  23. package/lib/graphql/src/server.ts +0 -3
  24. package/lib/graphql/src/utils/logger.ts +2 -2
  25. package/lib/graphql/tsconfig.json +1 -0
  26. package/lib/knex/.env.development.local +20 -0
  27. package/lib/knex/.env.production.local +20 -0
  28. package/lib/knex/.env.test.local +20 -0
  29. package/lib/knex/.swcrc +1 -0
  30. package/lib/knex/knexfile.ts +6 -10
  31. package/lib/knex/package.json +0 -2
  32. package/lib/knex/src/app.ts +6 -7
  33. package/lib/knex/src/config/index.ts +5 -0
  34. package/lib/knex/src/databases/index.ts +6 -8
  35. package/lib/knex/src/middlewares/auth.middleware.ts +2 -2
  36. package/lib/knex/src/server.ts +0 -2
  37. package/lib/knex/src/services/auth.service.ts +2 -2
  38. package/lib/knex/src/utils/logger.ts +2 -2
  39. package/lib/knex/tsconfig.json +1 -0
  40. package/lib/mongoose/.env.development.local +18 -0
  41. package/lib/mongoose/.env.production.local +18 -0
  42. package/lib/mongoose/.env.test.local +18 -0
  43. package/lib/mongoose/.swcrc +1 -0
  44. package/lib/mongoose/package.json +0 -2
  45. package/lib/mongoose/src/app.ts +6 -7
  46. package/lib/mongoose/src/config/index.ts +5 -0
  47. package/lib/mongoose/src/databases/index.ts +2 -5
  48. package/lib/mongoose/src/middlewares/auth.middleware.ts +2 -2
  49. package/lib/mongoose/src/server.ts +0 -2
  50. package/lib/mongoose/src/services/auth.service.ts +2 -2
  51. package/lib/mongoose/src/utils/logger.ts +2 -2
  52. package/lib/mongoose/tsconfig.json +1 -0
  53. package/lib/prisma/.env.development.local +16 -0
  54. package/lib/prisma/.env.production.local +16 -0
  55. package/lib/prisma/.env.test.local +16 -0
  56. package/lib/prisma/.swcrc +1 -0
  57. package/lib/prisma/package.json +0 -2
  58. package/lib/prisma/src/app.ts +6 -7
  59. package/lib/prisma/src/config/index.ts +5 -0
  60. package/lib/prisma/src/middlewares/auth.middleware.ts +2 -2
  61. package/lib/prisma/src/server.ts +0 -2
  62. package/lib/prisma/src/services/auth.service.ts +2 -2
  63. package/lib/prisma/src/utils/logger.ts +2 -2
  64. package/lib/prisma/tsconfig.json +1 -0
  65. package/lib/routing-controllers/.env.development.local +13 -0
  66. package/lib/routing-controllers/.env.production.local +13 -0
  67. package/lib/routing-controllers/.env.test.local +13 -0
  68. package/lib/routing-controllers/.swcrc +1 -0
  69. package/lib/routing-controllers/package.json +0 -2
  70. package/lib/routing-controllers/src/app.ts +7 -8
  71. package/lib/routing-controllers/src/config/index.ts +5 -0
  72. package/lib/routing-controllers/src/middlewares/auth.middleware.ts +2 -2
  73. package/lib/routing-controllers/src/server.ts +0 -2
  74. package/lib/routing-controllers/src/services/auth.service.ts +2 -2
  75. package/lib/routing-controllers/src/utils/logger.ts +2 -2
  76. package/lib/routing-controllers/tsconfig.json +1 -0
  77. package/lib/sequelize/.env.development.local +20 -0
  78. package/lib/sequelize/.env.production.local +20 -0
  79. package/lib/sequelize/.env.test.local +20 -0
  80. package/lib/sequelize/.swcrc +1 -0
  81. package/lib/sequelize/package.json +0 -2
  82. package/lib/sequelize/src/app.ts +6 -7
  83. package/lib/sequelize/src/config/index.ts +5 -0
  84. package/lib/sequelize/src/databases/index.ts +7 -8
  85. package/lib/sequelize/src/middlewares/auth.middleware.ts +2 -2
  86. package/lib/sequelize/src/server.ts +0 -2
  87. package/lib/sequelize/src/services/auth.service.ts +2 -2
  88. package/lib/sequelize/src/utils/logger.ts +2 -2
  89. package/lib/sequelize/tsconfig.json +1 -0
  90. package/lib/typeorm/.env.development.local +20 -0
  91. package/lib/typeorm/.env.production.local +20 -0
  92. package/lib/typeorm/.env.test.local +20 -0
  93. package/lib/typeorm/.swcrc +1 -0
  94. package/lib/typeorm/package.json +0 -2
  95. package/lib/typeorm/src/app.ts +6 -7
  96. package/lib/typeorm/src/config/index.ts +5 -0
  97. package/lib/typeorm/src/databases/index.ts +6 -8
  98. package/lib/typeorm/src/middlewares/auth.middleware.ts +2 -2
  99. package/lib/typeorm/src/server.ts +0 -2
  100. package/lib/typeorm/src/services/auth.service.ts +2 -2
  101. package/lib/typeorm/src/utils/logger.ts +2 -2
  102. package/lib/typeorm/tsconfig.json +1 -0
  103. package/package.json +1 -1
  104. package/lib/default/.env +0 -1
  105. package/lib/default/src/configs/development.json +0 -12
  106. package/lib/default/src/configs/production.json +0 -12
  107. package/lib/default/src/configs/test.json +0 -12
  108. package/lib/default/src/index.ts +0 -1
  109. package/lib/graphql/.env +0 -1
  110. package/lib/graphql/src/configs/development.json +0 -19
  111. package/lib/graphql/src/configs/production.json +0 -19
  112. package/lib/graphql/src/configs/test.json +0 -19
  113. package/lib/graphql/src/index.ts +0 -1
  114. package/lib/graphql/src/interfaces/db.interface.ts +0 -7
  115. package/lib/knex/.env +0 -1
  116. package/lib/knex/src/configs/development.json +0 -19
  117. package/lib/knex/src/configs/production.json +0 -19
  118. package/lib/knex/src/configs/test.json +0 -19
  119. package/lib/knex/src/index.ts +0 -1
  120. package/lib/knex/src/interfaces/db.interface.ts +0 -7
  121. package/lib/mongoose/.env +0 -1
  122. package/lib/mongoose/src/configs/development.json +0 -17
  123. package/lib/mongoose/src/configs/production.json +0 -17
  124. package/lib/mongoose/src/configs/test.json +0 -17
  125. package/lib/mongoose/src/index.ts +0 -1
  126. package/lib/mongoose/src/interfaces/db.interface.ts +0 -5
  127. package/lib/prisma/.env +0 -10
  128. package/lib/prisma/src/configs/development.json +0 -12
  129. package/lib/prisma/src/configs/production.json +0 -12
  130. package/lib/prisma/src/configs/test.json +0 -12
  131. package/lib/prisma/src/index.ts +0 -1
  132. package/lib/routing-controllers/.env +0 -1
  133. package/lib/routing-controllers/src/configs/development.json +0 -12
  134. package/lib/routing-controllers/src/configs/production.json +0 -12
  135. package/lib/routing-controllers/src/configs/test.json +0 -12
  136. package/lib/routing-controllers/src/index.ts +0 -1
  137. package/lib/sequelize/.env +0 -1
  138. package/lib/sequelize/src/configs/development.json +0 -22
  139. package/lib/sequelize/src/configs/production.json +0 -22
  140. package/lib/sequelize/src/configs/test.json +0 -22
  141. package/lib/sequelize/src/index.ts +0 -1
  142. package/lib/sequelize/src/interfaces/db.interface.ts +0 -10
  143. package/lib/typeorm/.env +0 -1
  144. package/lib/typeorm/src/configs/development.json +0 -18
  145. package/lib/typeorm/src/configs/production.json +0 -18
  146. package/lib/typeorm/src/configs/test.json +0 -18
  147. package/lib/typeorm/src/index.ts +0 -1
  148. package/lib/typeorm/src/interfaces/db.interface.ts +0 -6
@@ -0,0 +1,20 @@
1
+ # PORT
2
+ PORT = 3000
3
+
4
+ # DATABASE
5
+ DB_HOST = localhost
6
+ DB_PORT = 3306
7
+ DB_USER = root
8
+ DB_PASSWORD = password
9
+ DB_DATABASE = test
10
+
11
+ # TOKEN
12
+ SECRET_KEY = secretKey
13
+
14
+ # LOG
15
+ LOG_FORMAT = dev
16
+ LOG_DIR = ../logs
17
+
18
+ # CORS
19
+ ORIGIN = *
20
+ CREDENTIALS = true
@@ -0,0 +1,20 @@
1
+ # PORT
2
+ PORT = 3000
3
+
4
+ # DATABASE
5
+ DB_HOST = localhost
6
+ DB_PORT = 3306
7
+ DB_USER = root
8
+ DB_PASSWORD = password
9
+ DB_DATABASE = test
10
+
11
+ # TOKEN
12
+ SECRET_KEY = secretKey
13
+
14
+ # LOG
15
+ LOG_FORMAT = combined
16
+ LOG_DIR = ../logs
17
+
18
+ # CORS
19
+ ORIGIN = your.domain.com
20
+ CREDENTIALS = true
@@ -0,0 +1,20 @@
1
+ # PORT
2
+ PORT = 3000
3
+
4
+ # DATABASE
5
+ DB_HOST = localhost
6
+ DB_PORT = 3306
7
+ DB_USER = root
8
+ DB_PASSWORD = password
9
+ DB_DATABASE = test
10
+
11
+ # TOKEN
12
+ SECRET_KEY = secretKey
13
+
14
+ # LOG
15
+ LOG_FORMAT = dev
16
+ LOG_DIR = ../logs
17
+
18
+ # CORS
19
+ ORIGIN = *
20
+ CREDENTIALS = true
@@ -21,6 +21,7 @@
21
21
  "baseUrl": "src",
22
22
  "paths": {
23
23
  "@/*": ["*"],
24
+ "@config": ["config"],
24
25
  "@controllers/*": ["controllers/*"],
25
26
  "@databases": ["databases"],
26
27
  "@dtos/*": ["dtos/*"],
@@ -20,7 +20,6 @@
20
20
  "class-transformer": "^0.4.0",
21
21
  "class-validator": "^0.13.1",
22
22
  "compression": "^1.7.4",
23
- "config": "^3.3.6",
24
23
  "cookie-parser": "^1.4.5",
25
24
  "cors": "^2.8.5",
26
25
  "dotenv": "^10.0.0",
@@ -42,7 +41,6 @@
42
41
  "@swc/core": "^1.2.108",
43
42
  "@types/bcrypt": "^5.0.0",
44
43
  "@types/compression": "^1.7.1",
45
- "@types/config": "^0.0.39",
46
44
  "@types/cookie-parser": "^1.4.2",
47
45
  "@types/cors": "^2.8.11",
48
46
  "@types/dotenv": "^8.2.0",
@@ -1,14 +1,13 @@
1
- import '@/index';
2
1
  import compression from 'compression';
3
2
  import cookieParser from 'cookie-parser';
4
3
  import cors from 'cors';
5
- import config from 'config';
6
4
  import express from 'express';
7
5
  import helmet from 'helmet';
8
6
  import hpp from 'hpp';
9
7
  import morgan from 'morgan';
10
8
  import swaggerJSDoc from 'swagger-jsdoc';
11
9
  import swaggerUi from 'swagger-ui-express';
10
+ import { NODE_ENV, PORT, LOG_FORMAT, ORIGIN, CREDENTIALS } from '@config';
12
11
  import DB from '@databases';
13
12
  import { Routes } from '@interfaces/routes.interface';
14
13
  import errorMiddleware from '@middlewares/error.middleware';
@@ -16,13 +15,13 @@ import { logger, stream } from '@utils/logger';
16
15
 
17
16
  class App {
18
17
  public app: express.Application;
19
- public port: string | number;
20
18
  public env: string;
19
+ public port: string | number;
21
20
 
22
21
  constructor(routes: Routes[]) {
23
22
  this.app = express();
24
- this.port = process.env.PORT || 3000;
25
- this.env = process.env.NODE_ENV || 'development';
23
+ this.env = NODE_ENV || 'development';
24
+ this.port = PORT || 3000;
26
25
 
27
26
  this.connectToDatabase();
28
27
  this.initializeMiddlewares();
@@ -49,8 +48,8 @@ class App {
49
48
  }
50
49
 
51
50
  private initializeMiddlewares() {
52
- this.app.use(morgan(config.get('log.format'), { stream }));
53
- this.app.use(cors({ origin: config.get('cors.origin'), credentials: config.get('cors.credentials') }));
51
+ this.app.use(morgan(LOG_FORMAT, { stream }));
52
+ this.app.use(cors({ origin: ORIGIN, credentials: CREDENTIALS }));
54
53
  this.app.use(hpp());
55
54
  this.app.use(helmet());
56
55
  this.app.use(compression());
@@ -0,0 +1,5 @@
1
+ import { config } from 'dotenv';
2
+ config({ path: `.env.${process.env.NODE_ENV || 'development'}.local` });
3
+
4
+ export const CREDENTIALS = process.env.CREDENTIALS === 'true';
5
+ export const { NODE_ENV, PORT, DB_HOST, DB_PORT, DB_USER, DB_PASSWORD, DB_DATABASE, SECRET_KEY, LOG_FORMAT, LOG_DIR, ORIGIN } = process.env;
@@ -1,13 +1,12 @@
1
- import config from 'config';
2
1
  import Sequelize from 'sequelize';
3
- import { dbConfig } from '@interfaces/db.interface';
2
+ import { NODE_ENV, DB_HOST, DB_PORT, DB_USER, DB_PASSWORD, DB_DATABASE } from '@config';
4
3
  import UserModel from '@models/users.model';
5
4
  import { logger } from '@utils/logger';
6
5
 
7
- const { host, user, password, database, pool }: dbConfig = config.get('dbConfig');
8
- const sequelize = new Sequelize.Sequelize(database, user, password, {
9
- host: host,
6
+ const sequelize = new Sequelize.Sequelize(DB_DATABASE, DB_USER, DB_PASSWORD, {
10
7
  dialect: 'mysql',
8
+ host: DB_HOST,
9
+ port: DB_PORT,
11
10
  timezone: '+09:00',
12
11
  define: {
13
12
  charset: 'utf8mb4',
@@ -16,10 +15,10 @@ const sequelize = new Sequelize.Sequelize(database, user, password, {
16
15
  freezeTableName: true,
17
16
  },
18
17
  pool: {
19
- min: pool.min,
20
- max: pool.max,
18
+ min: 0,
19
+ max: 5,
21
20
  },
22
- logQueryParameters: process.env.NODE_ENV === 'development',
21
+ logQueryParameters: NODE_ENV === 'development',
23
22
  logging: (query, time) => {
24
23
  logger.info(time + 'ms' + ' ' + query);
25
24
  },
@@ -1,6 +1,6 @@
1
- import config from 'config';
2
1
  import { NextFunction, Response } from 'express';
3
2
  import { verify } from 'jsonwebtoken';
3
+ import { SECRET_KEY } from '@config';
4
4
  import DB from '@databases';
5
5
  import { HttpException } from '@exceptions/HttpException';
6
6
  import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
@@ -10,7 +10,7 @@ const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFun
10
10
  const Authorization = req.cookies['Authorization'] || (req.header('Authorization') ? req.header('Authorization').split('Bearer ')[1] : null);
11
11
 
12
12
  if (Authorization) {
13
- const secretKey: string = config.get('secretKey');
13
+ const secretKey: string = SECRET_KEY;
14
14
  const verificationResponse = verify(Authorization, secretKey) as DataStoredInToken;
15
15
  const userId = verificationResponse.id;
16
16
  const findUser = await DB.Users.findByPk(userId);
@@ -1,5 +1,3 @@
1
- import 'dotenv/config';
2
- import '@/index';
3
1
  import App from '@/app';
4
2
  import AuthRoute from '@routes/auth.route';
5
3
  import IndexRoute from '@routes/index.route';
@@ -1,6 +1,6 @@
1
1
  import { compare, hash } from 'bcrypt';
2
- import config from 'config';
3
2
  import { sign } from 'jsonwebtoken';
3
+ import { SECRET_KEY } from '@config';
4
4
  import DB from '@databases';
5
5
  import { CreateUserDto } from '@dtos/users.dto';
6
6
  import { HttpException } from '@exceptions/HttpException';
@@ -49,7 +49,7 @@ class AuthService {
49
49
 
50
50
  public createToken(user: User): TokenData {
51
51
  const dataStoredInToken: DataStoredInToken = { id: user.id };
52
- const secretKey: string = config.get('secretKey');
52
+ const secretKey: string = SECRET_KEY;
53
53
  const expiresIn: number = 60 * 60;
54
54
 
55
55
  return { expiresIn, token: sign(dataStoredInToken, secretKey, { expiresIn }) };
@@ -1,11 +1,11 @@
1
- import config from 'config';
2
1
  import { existsSync, mkdirSync } from 'fs';
3
2
  import { join } from 'path';
4
3
  import winston from 'winston';
5
4
  import winstonDaily from 'winston-daily-rotate-file';
5
+ import { LOG_DIR } from '@config';
6
6
 
7
7
  // logs dir
8
- const logDir: string = join(__dirname, config.get('log.dir'));
8
+ const logDir: string = join(__dirname, LOG_DIR);
9
9
 
10
10
  if (!existsSync(logDir)) {
11
11
  mkdirSync(logDir);
@@ -22,6 +22,7 @@
22
22
  "baseUrl": "src",
23
23
  "paths": {
24
24
  "@/*": ["*"],
25
+ "@config": ["config"],
25
26
  "@controllers/*": ["controllers/*"],
26
27
  "@databases": ["databases"],
27
28
  "@dtos/*": ["dtos/*"],
@@ -0,0 +1,20 @@
1
+ # PORT
2
+ PORT = 3000
3
+
4
+ # DATABASE
5
+ DB_HOST = localhost
6
+ DB_PORT = 5432
7
+ DB_USER = root
8
+ DB_PASSWORD = password
9
+ DB_DATABASE = test
10
+
11
+ # TOKEN
12
+ SECRET_KEY = secretKey
13
+
14
+ # LOG
15
+ LOG_FORMAT = dev
16
+ LOG_DIR = ../logs
17
+
18
+ # CORS
19
+ ORIGIN = *
20
+ CREDENTIALS = true
@@ -0,0 +1,20 @@
1
+ # PORT
2
+ PORT = 3000
3
+
4
+ # DATABASE
5
+ DB_HOST = localhost
6
+ DB_PORT = 5432
7
+ DB_USER = root
8
+ DB_PASSWORD = password
9
+ DB_DATABASE = test
10
+
11
+ # TOKEN
12
+ SECRET_KEY = secretKey
13
+
14
+ # LOG
15
+ LOG_FORMAT = combined
16
+ LOG_DIR = ../logs
17
+
18
+ # CORS
19
+ ORIGIN = your.domain.com
20
+ CREDENTIALS = true
@@ -0,0 +1,20 @@
1
+ # PORT
2
+ PORT = 3000
3
+
4
+ # DATABASE
5
+ DB_HOST = localhost
6
+ DB_PORT = 5432
7
+ DB_USER = root
8
+ DB_PASSWORD = password
9
+ DB_DATABASE = test
10
+
11
+ # TOKEN
12
+ SECRET_KEY = secretKey
13
+
14
+ # LOG
15
+ LOG_FORMAT = dev
16
+ LOG_DIR = ../logs
17
+
18
+ # CORS
19
+ ORIGIN = *
20
+ CREDENTIALS = true
@@ -21,6 +21,7 @@
21
21
  "baseUrl": "src",
22
22
  "paths": {
23
23
  "@/*": ["*"],
24
+ "@config": ["config"],
24
25
  "@controllers/*": ["controllers/*"],
25
26
  "@databases": ["databases"],
26
27
  "@dtos/*": ["dtos/*"],
@@ -20,7 +20,6 @@
20
20
  "class-transformer": "^0.4.0",
21
21
  "class-validator": "^0.13.1",
22
22
  "compression": "^1.7.4",
23
- "config": "^3.3.6",
24
23
  "cookie-parser": "^1.4.5",
25
24
  "cors": "^2.8.5",
26
25
  "dotenv": "^10.0.0",
@@ -43,7 +42,6 @@
43
42
  "@swc/core": "^1.2.108",
44
43
  "@types/bcrypt": "^5.0.0",
45
44
  "@types/compression": "^1.7.1",
46
- "@types/config": "^0.0.39",
47
45
  "@types/cookie-parser": "^1.4.2",
48
46
  "@types/cors": "^2.8.11",
49
47
  "@types/dotenv": "^8.2.0",
@@ -1,8 +1,6 @@
1
1
  import 'reflect-metadata';
2
- import '@/index';
3
2
  import cookieParser from 'cookie-parser';
4
3
  import cors from 'cors';
5
- import config from 'config';
6
4
  import express from 'express';
7
5
  import helmet from 'helmet';
8
6
  import hpp from 'hpp';
@@ -11,6 +9,7 @@ import compression from 'compression';
11
9
  import swaggerUi from 'swagger-ui-express';
12
10
  import swaggerJSDoc from 'swagger-jsdoc';
13
11
  import { createConnection } from 'typeorm';
12
+ import { NODE_ENV, PORT, LOG_FORMAT, ORIGIN, CREDENTIALS } from '@config';
14
13
  import { dbConnection } from '@databases';
15
14
  import { Routes } from '@interfaces/routes.interface';
16
15
  import errorMiddleware from '@middlewares/error.middleware';
@@ -18,13 +17,13 @@ import { logger, stream } from '@utils/logger';
18
17
 
19
18
  class App {
20
19
  public app: express.Application;
21
- public port: string | number;
22
20
  public env: string;
21
+ public port: string | number;
23
22
 
24
23
  constructor(routes: Routes[]) {
25
24
  this.app = express();
26
- this.port = process.env.PORT || 3000;
27
- this.env = process.env.NODE_ENV || 'development';
25
+ this.env = NODE_ENV || 'development';
26
+ this.port = PORT || 3000;
28
27
 
29
28
  this.env !== 'test' && this.connectToDatabase();
30
29
  this.initializeMiddlewares();
@@ -51,8 +50,8 @@ class App {
51
50
  }
52
51
 
53
52
  private initializeMiddlewares() {
54
- this.app.use(morgan(config.get('log.format'), { stream }));
55
- this.app.use(cors({ origin: config.get('cors.origin'), credentials: config.get('cors.credentials') }));
53
+ this.app.use(morgan(LOG_FORMAT, { stream }));
54
+ this.app.use(cors({ origin: ORIGIN, credentials: CREDENTIALS }));
56
55
  this.app.use(hpp());
57
56
  this.app.use(helmet());
58
57
  this.app.use(compression());
@@ -0,0 +1,5 @@
1
+ import { config } from 'dotenv';
2
+ config({ path: `.env.${process.env.NODE_ENV || 'development'}.local` });
3
+
4
+ export const CREDENTIALS = process.env.CREDENTIALS === 'true';
5
+ export const { NODE_ENV, PORT, DB_HOST, DB_PORT, DB_USER, DB_PASSWORD, DB_DATABASE, SECRET_KEY, LOG_FORMAT, LOG_DIR, ORIGIN } = process.env;
@@ -1,16 +1,14 @@
1
- import config from 'config';
2
1
  import { join } from 'path';
3
2
  import { ConnectionOptions } from 'typeorm';
4
- import { dbConfig } from '@interfaces/db.interface';
3
+ import { DB_HOST, DB_PORT, DB_USER, DB_PASSWORD, DB_DATABASE } from '@config';
5
4
 
6
- const { host, user, password, database }: dbConfig = config.get('dbConfig');
7
5
  export const dbConnection: ConnectionOptions = {
8
6
  type: 'postgres',
9
- host: host,
10
- port: 5432,
11
- username: user,
12
- password: password,
13
- database: database,
7
+ host: DB_HOST,
8
+ port: DB_PORT,
9
+ username: DB_USER,
10
+ password: DB_PASSWORD,
11
+ database: DB_DATABASE,
14
12
  synchronize: true,
15
13
  logging: false,
16
14
  entities: [join(__dirname, '../**/*.entity{.ts,.js}')],
@@ -1,6 +1,6 @@
1
- import config from 'config';
2
1
  import { NextFunction, Response } from 'express';
3
2
  import { verify } from 'jsonwebtoken';
3
+ import { SECRET_KEY } from '@config';
4
4
  import { UserEntity } from '@entities/users.entity';
5
5
  import { HttpException } from '@exceptions/HttpException';
6
6
  import { DataStoredInToken, RequestWithUser } from '@interfaces/auth.interface';
@@ -10,7 +10,7 @@ const authMiddleware = async (req: RequestWithUser, res: Response, next: NextFun
10
10
  const Authorization = req.cookies['Authorization'] || (req.header('Authorization') ? req.header('Authorization').split('Bearer ')[1] : null);
11
11
 
12
12
  if (Authorization) {
13
- const secretKey: string = config.get('secretKey');
13
+ const secretKey: string = SECRET_KEY;
14
14
  const { id } = (await verify(Authorization, secretKey)) as DataStoredInToken;
15
15
  const findUser = await UserEntity.findOne(id, { select: ['id', 'email', 'password'] });
16
16
 
@@ -1,5 +1,3 @@
1
- import 'dotenv/config';
2
- import '@/index';
3
1
  import App from '@/app';
4
2
  import AuthRoute from '@routes/auth.route';
5
3
  import IndexRoute from '@routes/index.route';
@@ -1,7 +1,7 @@
1
1
  import { compare, hash } from 'bcrypt';
2
- import config from 'config';
3
2
  import { sign } from 'jsonwebtoken';
4
3
  import { EntityRepository, Repository } from 'typeorm';
4
+ import { SECRET_KEY } from '@config';
5
5
  import { CreateUserDto } from '@dtos/users.dto';
6
6
  import { UserEntity } from '@entities/users.entity';
7
7
  import { HttpException } from '@exceptions/HttpException';
@@ -48,7 +48,7 @@ class AuthService extends Repository<UserEntity> {
48
48
 
49
49
  public createToken(user: User): TokenData {
50
50
  const dataStoredInToken: DataStoredInToken = { id: user.id };
51
- const secretKey: string = config.get('secretKey');
51
+ const secretKey: string = SECRET_KEY;
52
52
  const expiresIn: number = 60 * 60;
53
53
 
54
54
  return { expiresIn, token: sign(dataStoredInToken, secretKey, { expiresIn }) };
@@ -1,11 +1,11 @@
1
- import config from 'config';
2
1
  import { existsSync, mkdirSync } from 'fs';
3
2
  import { join } from 'path';
4
3
  import winston from 'winston';
5
4
  import winstonDaily from 'winston-daily-rotate-file';
5
+ import { LOG_DIR } from '@config';
6
6
 
7
7
  // logs dir
8
- const logDir: string = join(__dirname, config.get('log.dir'));
8
+ const logDir: string = join(__dirname, LOG_DIR);
9
9
 
10
10
  if (!existsSync(logDir)) {
11
11
  mkdirSync(logDir);
@@ -22,6 +22,7 @@
22
22
  "baseUrl": "src",
23
23
  "paths": {
24
24
  "@/*": ["*"],
25
+ "@config": ["config"],
25
26
  "@controllers/*": ["controllers/*"],
26
27
  "@databases": ["databases"],
27
28
  "@dtos/*": ["dtos/*"],
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "typescript-express-starter",
3
- "version": "8.0.2",
3
+ "version": "8.1.2",
4
4
  "description": "Quick and Easy TypeScript Express Starter",
5
5
  "author": "AGUMON <ljlm0402@gmail.com>",
6
6
  "license": "MIT",
package/lib/default/.env DELETED
@@ -1 +0,0 @@
1
- PORT=3000
@@ -1,12 +0,0 @@
1
- {
2
- "env": "development",
3
- "secretKey": "secretKey",
4
- "log": {
5
- "format": "dev",
6
- "dir": "../logs"
7
- },
8
- "cors": {
9
- "origin": true,
10
- "credentials": true
11
- }
12
- }
@@ -1,12 +0,0 @@
1
- {
2
- "env": "production",
3
- "secretKey": "secretKey",
4
- "log": {
5
- "format": "combined",
6
- "dir": "../logs"
7
- },
8
- "cors": {
9
- "origin": "your.domain.com",
10
- "credentials": true
11
- }
12
- }
@@ -1,12 +0,0 @@
1
- {
2
- "env": "test",
3
- "secretKey": "secretKey",
4
- "log": {
5
- "format": "dev",
6
- "dir": "../logs"
7
- },
8
- "cors": {
9
- "origin": true,
10
- "credentials": true
11
- }
12
- }
@@ -1 +0,0 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
package/lib/graphql/.env DELETED
@@ -1 +0,0 @@
1
- PORT=3000
@@ -1,19 +0,0 @@
1
- {
2
- "env": "development",
3
- "dbConfig": {
4
- "host": "localhost",
5
- "user": "root",
6
- "port": 5432,
7
- "password": "password",
8
- "database": "test"
9
- },
10
- "secretKey": "secretKey",
11
- "log": {
12
- "format": "dev",
13
- "dir": "../logs"
14
- },
15
- "cors": {
16
- "origin": true,
17
- "credentials": true
18
- }
19
- }
@@ -1,19 +0,0 @@
1
- {
2
- "env": "production",
3
- "dbConfig": {
4
- "host": "localhost",
5
- "user": "root",
6
- "port": 5432,
7
- "password": "password",
8
- "database": "test"
9
- },
10
- "secretKey": "secretKey",
11
- "log": {
12
- "format": "combined",
13
- "dir": "../logs"
14
- },
15
- "cors": {
16
- "origin": "your.domain.com",
17
- "credentials": true
18
- }
19
- }
@@ -1,19 +0,0 @@
1
- {
2
- "env": "test",
3
- "dbConfig": {
4
- "host": "localhost",
5
- "user": "root",
6
- "port": 5432,
7
- "password": "password",
8
- "database": "test"
9
- },
10
- "secretKey": "secretKey",
11
- "log": {
12
- "format": "dev",
13
- "dir": "../logs"
14
- },
15
- "cors": {
16
- "origin": true,
17
- "credentials": true
18
- }
19
- }
@@ -1 +0,0 @@
1
- process.env['NODE_CONFIG_DIR'] = __dirname + '/configs';
@@ -1,7 +0,0 @@
1
- export interface dbConfig {
2
- host: string;
3
- user: string;
4
- port: number;
5
- password: string;
6
- database: string;
7
- }
package/lib/knex/.env DELETED
@@ -1 +0,0 @@
1
- PORT=3000
@@ -1,19 +0,0 @@
1
- {
2
- "env": "development",
3
- "dbConfig": {
4
- "host": "localhost",
5
- "user": "root",
6
- "password": "password",
7
- "database": "test",
8
- "port": 3306
9
- },
10
- "secretKey": "secretKey",
11
- "log": {
12
- "format": "dev",
13
- "dir": "../logs"
14
- },
15
- "cors": {
16
- "origin": true,
17
- "credentials": true
18
- }
19
- }
@@ -1,19 +0,0 @@
1
- {
2
- "env": "production",
3
- "dbConfig": {
4
- "host": "localhost",
5
- "user": "root",
6
- "password": "password",
7
- "database": "test",
8
- "port": 3306
9
- },
10
- "secretKey": "secretKey",
11
- "log": {
12
- "format": "combined",
13
- "dir": "../logs"
14
- },
15
- "cors": {
16
- "origin": "your.domain.com",
17
- "credentials": true
18
- }
19
- }