From 071be4c6cc7d4d231c4864d2dedc17c95e2eedcb Mon Sep 17 00:00:00 2001 From: richard483 Date: Mon, 4 Dec 2023 12:52:00 +0700 Subject: [PATCH 1/2] added dockerFile --- Dockerfile | 26 ++++++++++++++++++++++++++ src/contract/contract.helper.ts | 2 ++ 2 files changed, 28 insertions(+) create mode 100644 Dockerfile diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..b54cfda --- /dev/null +++ b/Dockerfile @@ -0,0 +1,26 @@ +FROM node:lts-alpine + +WORKDIR /usr/src/app + +RUN apk update && apk add --no-cache nmap && \ + echo @edge https://dl-cdn.alpinelinux.org/alpine/edge/community >> /etc/apk/repositories && \ + echo @edge https://dl-cdn.alpinelinux.org/alpine/edge/main >> /etc/apk/repositories && \ + apk update && \ + apk add --no-cache \ + chromium \ + harfbuzz \ + "freetype>2.8" \ + ttf-freefont \ + nss + +ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true + +COPY . /usr/src/app + +RUN npm run build + +RUN npm ci + +EXPOSE 3000 + +CMD [ "node", "dist/src/main" ] \ No newline at end of file diff --git a/src/contract/contract.helper.ts b/src/contract/contract.helper.ts index 0580b3e..046932d 100644 --- a/src/contract/contract.helper.ts +++ b/src/contract/contract.helper.ts @@ -23,6 +23,8 @@ export class ContractHelper { const browser = await launch({ args: ['--no-sandbox'], + // comment the below line for running locally + executablePath: '/usr/bin/chromium', headless: true, }); const page = await browser.newPage(); From d7777e99d6f03bc93a6f9ae6338880105a28f7eb Mon Sep 17 00:00:00 2001 From: richard483 Date: Fri, 8 Dec 2023 18:31:33 +0700 Subject: [PATCH 2/2] updated dockerfile & response interceptor --- Dockerfile | 8 +++++--- src/interceptors/response.interceptor.ts | 24 +++++++++++++++++------- 2 files changed, 22 insertions(+), 10 deletions(-) diff --git a/Dockerfile b/Dockerfile index b54cfda..09b2bd0 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,6 @@ -FROM node:lts-alpine +ARG NODE_VERSION=18.17.1 + +FROM node:${NODE_VERSION}-alpine WORKDIR /usr/src/app @@ -17,10 +19,10 @@ ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true COPY . /usr/src/app -RUN npm run build - RUN npm ci +RUN npm run build + EXPOSE 3000 CMD [ "node", "dist/src/main" ] \ No newline at end of file diff --git a/src/interceptors/response.interceptor.ts b/src/interceptors/response.interceptor.ts index 409d883..48a8e93 100644 --- a/src/interceptors/response.interceptor.ts +++ b/src/interceptors/response.interceptor.ts @@ -45,13 +45,7 @@ export class ResponseInterceptor implements NestInterceptor { response.status(status).json({ status: false, statusCode: status, - message: - exception.getResponse() instanceof Object - ? Object(exception.getResponse()).reduce( - (acc, obj) => ({ ...Object(acc), ...Object(obj) }), - {}, - ) - : exception.getResponse(), + message: this.extractErrorMessages(exception), error: this.htttpCodeParser(status), }); } @@ -71,6 +65,22 @@ export class ResponseInterceptor implements NestInterceptor { }); } + private extractErrorMessages(exception: any) { + try { + return Object(exception.getResponse()).reduce( + (acc, obj) => ({ ...Object(acc), ...Object(obj) }), + {}, + ); + } catch (e) { + console.log( + '#Failed to restructure exception for this response: ', + exception.getResponse(), + " would return it's original response instead.", + ); + return exception.getResponse(); + } + } + private htttpCodeParser(statusCode: number) { switch (statusCode) { case 200: