@ahhaohho/response-dto 1.0.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.
- package/README.md +76 -0
- package/ResponseDTO.js +133 -0
- package/index.js +3 -0
- package/package.json +21 -0
package/README.md
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
# ResponseDTO
|
|
2
|
+
|
|
3
|
+
AhhaOhho API 응답을 위한 DTO(Data Transfer Object) 클래스입니다.
|
|
4
|
+
|
|
5
|
+
## 소개
|
|
6
|
+
|
|
7
|
+
이 패키지는 AhhaOhho API 응답을 표준화하고 일관성 있게 만들기 위한 ResponseDTO 클래스를 제공합니다. 성공 응답, 클라이언트 오류, 시스템 오류 등 다양한 API 응답 상황을 처리할 수 있습니다.
|
|
8
|
+
|
|
9
|
+
## 설치
|
|
10
|
+
|
|
11
|
+
npm을 사용하여 패키지를 설치할 수 있습니다:
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
npm install @ahhaohho/response-dto
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
## 사용 방법
|
|
18
|
+
|
|
19
|
+
ResponseDTO 클래스를 import하여 사용할 수 있습니다:
|
|
20
|
+
|
|
21
|
+
```javascript
|
|
22
|
+
const ResponseDTO = require('@ahhaohho/response-dto');
|
|
23
|
+
|
|
24
|
+
// 성공 응답 예시
|
|
25
|
+
const successResponse = ResponseDTO.success({ user: { id: 1, name: '아하오호' } });
|
|
26
|
+
|
|
27
|
+
// 클라이언트 오류 응답 예시
|
|
28
|
+
const clientErrorResponse = ResponseDTO.badRequest('잘못된 요청입니다.');
|
|
29
|
+
|
|
30
|
+
// 시스템 오류 응답 예시
|
|
31
|
+
const systemErrorResponse = ResponseDTO.systemError('서버 오류가 발생했습니다.');
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
## 주요 기능
|
|
35
|
+
|
|
36
|
+
- `success(data)`: 성공 응답 (상태 코드 200)
|
|
37
|
+
- `created(data)`: 리소스 생성 성공 응답 (상태 코드 201)
|
|
38
|
+
- `noContent()`: 콘텐츠 없는 성공 응답 (상태 코드 204)
|
|
39
|
+
- `badRequest(message)`: 잘못된 요청 오류 (상태 코드 400)
|
|
40
|
+
- `unauthorized(message)`: 인증 실패 오류 (상태 코드 401)
|
|
41
|
+
- `forbidden(message)`: 접근 권한 없음 오류 (상태 코드 403)
|
|
42
|
+
- `notFound(message)`: 리소스를 찾을 수 없음 오류 (상태 코드 404)
|
|
43
|
+
- `conflict(message)`: 충돌 오류 (상태 코드 409)
|
|
44
|
+
- `validationError(message)`: 유효성 검사 오류 (상태 코드 422)
|
|
45
|
+
- `systemError(message)`: 시스템 오류 (상태 코드 500)
|
|
46
|
+
- `serviceUnavailable(message)`: 서비스 사용 불가 오류 (상태 코드 503)
|
|
47
|
+
|
|
48
|
+
## 예제
|
|
49
|
+
|
|
50
|
+
Express.js와 함께 사용하는 예제:
|
|
51
|
+
|
|
52
|
+
```javascript
|
|
53
|
+
const express = require('express');
|
|
54
|
+
const ResponseDTO = require('@ahhaohho/response-dto');
|
|
55
|
+
|
|
56
|
+
const app = express();
|
|
57
|
+
|
|
58
|
+
app.get('/api/users/:id', (req, res) => {
|
|
59
|
+
try {
|
|
60
|
+
const user = { id: req.params.id, name: '홍길동' };
|
|
61
|
+
res.json(ResponseDTO.success(user));
|
|
62
|
+
} catch (error) {
|
|
63
|
+
res.status(500).json(ResponseDTO.systemError('사용자 정보를 가져오는 데 실패했습니다.'));
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
app.listen(3000, () => console.log('서버가 3000번 포트에서 실행 중입니다.'));
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
## 작성자
|
|
71
|
+
|
|
72
|
+
정두수 (dsoojung@smilegate.com)
|
|
73
|
+
|
|
74
|
+
---
|
|
75
|
+
|
|
76
|
+
이 README는 프로젝트의 기본적인 정보를 제공합니다. 필요에 따라 내용을 수정하거나 확장할 수 있습니다.
|
package/ResponseDTO.js
ADDED
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ResponseDTO 클래스
|
|
3
|
+
* API 응답을 표준화하기 위한 클래스입니다.
|
|
4
|
+
* 성공 응답, 클라이언트 오류, 시스템 오류 등 모든 API 응답에 대해 일관된 구조를 제공합니다.
|
|
5
|
+
*/
|
|
6
|
+
class ResponseDTO {
|
|
7
|
+
/**
|
|
8
|
+
* ResponseDTO 생성자
|
|
9
|
+
* @param {string} type - 응답 유형 ('success', 'client', 또는 'system')
|
|
10
|
+
* @param {number} status - HTTP 상태 코드
|
|
11
|
+
* @param {object|null} data - 응답 데이터 (선택적)
|
|
12
|
+
* @param {string|null} message - 추가 메시지 (주로 오류에 사용)
|
|
13
|
+
*/
|
|
14
|
+
constructor(type, status, data = null, message = null) {
|
|
15
|
+
this.type = type;
|
|
16
|
+
this.status = status;
|
|
17
|
+
if (data) this.data = data;
|
|
18
|
+
if (message) this.message = message;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* 상태 코드 200의 성공 응답을 생성합니다.
|
|
23
|
+
* @param {object} data - 응답에 포함될 데이터
|
|
24
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
25
|
+
*/
|
|
26
|
+
static success(data) {
|
|
27
|
+
return new ResponseDTO('success', 200, data);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* 리소스 생성 성공을 나타내는 상태 코드 201의 응답을 생성합니다.
|
|
32
|
+
* @param {object} data - 생성된 리소스의 데이터
|
|
33
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
34
|
+
*/
|
|
35
|
+
static created(data) {
|
|
36
|
+
return new ResponseDTO('success', 201, data);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* 콘텐츠가 없는 성공 응답 (상태 코드 204)을 생성합니다.
|
|
41
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
42
|
+
*/
|
|
43
|
+
static noContent() {
|
|
44
|
+
return new ResponseDTO('success', 204);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* 잘못된 요청에 대한 클라이언트 오류 응답 (상태 코드 400)을 생성합니다.
|
|
49
|
+
* @param {string} message - 오류 메시지
|
|
50
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
51
|
+
*/
|
|
52
|
+
static badRequest(message) {
|
|
53
|
+
return new ResponseDTO('client', 400, null, message);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* 인증되지 않은 접근에 대한 클라이언트 오류 응답 (상태 코드 401)을 생성합니다.
|
|
58
|
+
* @param {string} message - 오류 메시지
|
|
59
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
60
|
+
*/
|
|
61
|
+
static unauthorized(message) {
|
|
62
|
+
return new ResponseDTO('client', 401, null, message);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* 금지된 접근에 대한 클라이언트 오류 응답 (상태 코드 403)을 생성합니다.
|
|
67
|
+
* @param {string} message - 오류 메시지
|
|
68
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
69
|
+
*/
|
|
70
|
+
static forbidden(message) {
|
|
71
|
+
return new ResponseDTO('client', 403, null, message);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* 리소스를 찾을 수 없는 경우의 클라이언트 오류 응답 (상태 코드 404)을 생성합니다.
|
|
76
|
+
* @param {string} message - 오류 메시지
|
|
77
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
78
|
+
*/
|
|
79
|
+
static notFound(message) {
|
|
80
|
+
return new ResponseDTO('client', 404, null, message);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* 충돌 상황에 대한 클라이언트 오류 응답 (상태 코드 409)을 생성합니다.
|
|
85
|
+
* @param {string} message - 오류 메시지
|
|
86
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
87
|
+
*/
|
|
88
|
+
static conflict(message) {
|
|
89
|
+
return new ResponseDTO('client', 409, null, message);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* 유효성 검사 오류에 대한 클라이언트 오류 응답 (상태 코드 422)을 생성합니다.
|
|
94
|
+
* @param {string} message - 오류 메시지
|
|
95
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
96
|
+
*/
|
|
97
|
+
static validationError(message) {
|
|
98
|
+
return new ResponseDTO('client', 422, null, message);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* 시스템 오류 응답 (상태 코드 500)을 생성합니다.
|
|
103
|
+
* @param {string} message - 오류 메시지
|
|
104
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
105
|
+
*/
|
|
106
|
+
static systemError(message) {
|
|
107
|
+
return new ResponseDTO('system', 500, null, message);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* 서비스 이용 불가 상황에 대한 시스템 오류 응답 (상태 코드 503)을 생성합니다.
|
|
112
|
+
* @param {string} message - 오류 메시지
|
|
113
|
+
* @returns {ResponseDTO} 새로운 ResponseDTO 인스턴스
|
|
114
|
+
*/
|
|
115
|
+
static serviceUnavailable(message) {
|
|
116
|
+
return new ResponseDTO('system', 503, null, message);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* ResponseDTO 인스턴스를 일반 JavaScript 객체로 변환합니다.
|
|
121
|
+
* @returns {object} ResponseDTO의 일반 JavaScript 객체 표현
|
|
122
|
+
*/
|
|
123
|
+
toJSON() {
|
|
124
|
+
return {
|
|
125
|
+
type: this.type,
|
|
126
|
+
status: this.status,
|
|
127
|
+
...(this.data && { data: this.data }),
|
|
128
|
+
...(this.message && { message: this.message })
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
module.exports = ResponseDTO;
|
package/index.js
ADDED
package/package.json
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@ahhaohho/response-dto",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "한국어 주석이 포함된 API 응답을 위한 DTO 클래스",
|
|
5
|
+
"main": "index.js",
|
|
6
|
+
"scripts": {
|
|
7
|
+
"test": "echo \"Error: no test specified\" && exit 1"
|
|
8
|
+
},
|
|
9
|
+
"keywords": ["api", "response", "dto"],
|
|
10
|
+
"author": "doooosoooo",
|
|
11
|
+
"repository": {
|
|
12
|
+
"type": "git",
|
|
13
|
+
"url": "git@github.com:Future-Lab-META/npm-responseDto.git"
|
|
14
|
+
},
|
|
15
|
+
"license": "ISC",
|
|
16
|
+
"bugs": {
|
|
17
|
+
"url": "https://github.com/Future-Lab-META/npm-responseDto/issues"
|
|
18
|
+
},
|
|
19
|
+
"homepage": "https://github.com/Future-Lab-META/npm-responseDto#readme"
|
|
20
|
+
}
|
|
21
|
+
|