fake-toss-payments-server
Version:
Fake toss-payments server for testing
95 lines (83 loc) • 2.15 kB
text/typescript
import core from "@nestia/core";
import {
ConflictException,
InternalServerErrorException,
NotFoundException,
UnprocessableEntityException,
} from "@nestjs/common";
import { DomainError, InvalidArgument, OutOfRange } from "tstl";
/* eslint-disable */
const EXTENSION = __filename.substring(__filename.length - 2);
if (EXTENSION === "js") require("source-map-support").install();
/**
* Fake 토스 페이먼츠 서버의 설정 정보.
*
* @author Samchon
*/
export namespace FakeTossConfiguration {
/**
* @internal
*/
export const ASSETS = __dirname + "/../assets";
/**
* 임시 저장소의 레코드 만료 기한.
*/
export const EXPIRATION: IExpiration = {
time: 3 * 60 * 1000,
capacity: 1000,
};
/**
* 서버가 사용할 포트 번호.
*/
export let API_PORT: number = 30771;
/**
* Webhook 이벤트를 수신할 URL 주소.
*/
export let WEBHOOK_URL: string = `http://127.0.0.1:${API_PORT}/internal/webhook`;
/**
* 토큰 인증 함수.
*
* 클라이언트가 전송한 Basic 토큰값이 제대로 된 것인지 판별한다.
*
* @param token 토큰값
*/
export let authorize: (token: string) => boolean = (token) => {
return token === "test_ak_ZORzdMaqN3wQd5k6ygr5AkYXQGwy";
};
/**
* 임시 저장소의 레코드 만료 기한.
*/
export interface IExpiration {
/**
* 만료 시간.
*/
time: number;
/**
* 최대 수용량.
*/
capacity: number;
}
}
// CUSTOM EXCEPTIION CONVERSION
core.ExceptionManager.insert(
OutOfRange,
(exp) => new NotFoundException(exp.message),
);
core.ExceptionManager.insert(
InvalidArgument,
(exp) => new ConflictException(exp.message),
);
core.ExceptionManager.insert(
DomainError,
(exp) => new UnprocessableEntityException(exp.message),
);
// TRACE EXACT SERVER INTERNAL ERROR
core.ExceptionManager.insert(
Error,
(exp) =>
new InternalServerErrorException({
message: exp.message,
name: exp.name,
stack: exp.stack,
}),
);