mirror of
https://github.com/cheveguerra/whaticket-community.git
synced 2026-04-20 20:59:16 +00:00
Remove browserless and add chrome in docker image
This commit is contained in:
@@ -1,4 +1,25 @@
|
|||||||
FROM node:14-alpine as build-deps
|
FROM node:14 as build-deps
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y wget
|
||||||
|
|
||||||
|
ENV DOCKERIZE_VERSION v0.6.1
|
||||||
|
RUN wget https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
|
||||||
|
&& tar -C /usr/local/bin -xzvf dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
|
||||||
|
&& rm dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz
|
||||||
|
|
||||||
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y wget gnupg \
|
||||||
|
&& wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add - \
|
||||||
|
&& sh -c 'echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google.list' \
|
||||||
|
&& apt-get update \
|
||||||
|
&& apt-get install -y google-chrome-stable fonts-ipafont-gothic fonts-wqy-zenhei fonts-thai-tlwg fonts-kacst fonts-freefont-ttf libxss1 \
|
||||||
|
--no-install-recommends \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
ADD https://github.com/Yelp/dumb-init/releases/download/v1.2.1/dumb-init_1.2.1_amd64 /usr/local/bin/dumb-init
|
||||||
|
RUN chmod +x /usr/local/bin/dumb-init
|
||||||
|
|
||||||
|
ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD true
|
||||||
|
|
||||||
WORKDIR /usr/src/app
|
WORKDIR /usr/src/app
|
||||||
COPY package*.json ./
|
COPY package*.json ./
|
||||||
@@ -7,25 +28,13 @@ RUN npm install
|
|||||||
COPY . .
|
COPY . .
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
FROM node:14-alpine
|
|
||||||
|
|
||||||
RUN apk add --no-cache openssl
|
|
||||||
|
|
||||||
ENV DOCKERIZE_VERSION v0.6.1
|
|
||||||
RUN wget https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-alpine-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
|
|
||||||
&& tar -C /usr/local/bin -xzvf dockerize-alpine-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
|
|
||||||
&& rm dockerize-alpine-linux-amd64-$DOCKERIZE_VERSION.tar.gz
|
|
||||||
|
|
||||||
WORKDIR /usr/src/app
|
|
||||||
COPY --from=build-deps /usr/src/app/node_modules/ ./node_modules/
|
|
||||||
COPY --from=build-deps /usr/src/app/dist/ ./dist/
|
|
||||||
COPY .sequelizerc .
|
|
||||||
|
|
||||||
ENV NODE_ENV=production
|
ENV NODE_ENV=production
|
||||||
ENV PORT=3000
|
ENV PORT=3000
|
||||||
|
ENV CHROME_BIN=google-chrome-stable
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
|
|
||||||
ENTRYPOINT dockerize -wait tcp://${DB_HOST}:3306 \
|
ENTRYPOINT ["dumb-init", "--"]
|
||||||
|
CMD dockerize -wait tcp://${DB_HOST}:3306 \
|
||||||
&& npx sequelize db:migrate \
|
&& npx sequelize db:migrate \
|
||||||
&& node dist/server.js
|
&& node dist/server.js
|
||||||
@@ -43,12 +43,15 @@ export const initWbot = async (whatsapp: Whatsapp): Promise<Session> => {
|
|||||||
sessionCfg = JSON.parse(whatsapp.session);
|
sessionCfg = JSON.parse(whatsapp.session);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const args:String = process.env.CHROME_ARGS || "";
|
||||||
|
|
||||||
const wbot: Session = new Client({
|
const wbot: Session = new Client({
|
||||||
session: sessionCfg,
|
session: sessionCfg,
|
||||||
puppeteer: {
|
puppeteer: {
|
||||||
executablePath: process.env.CHROME_BIN || undefined,
|
executablePath: process.env.CHROME_BIN || undefined,
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
browserWSEndpoint: process.env.CHROME_WS || undefined
|
browserWSEndpoint: process.env.CHROME_WS || undefined,
|
||||||
|
args: args.split(' ')
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
17
docker-compose-browserless.yaml
Normal file
17
docker-compose-browserless.yaml
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
version: '3'
|
||||||
|
|
||||||
|
networks:
|
||||||
|
whaticket:
|
||||||
|
|
||||||
|
services:
|
||||||
|
|
||||||
|
backend:
|
||||||
|
environment:
|
||||||
|
- CHROME_WS=ws://chrome:3000
|
||||||
|
|
||||||
|
chrome:
|
||||||
|
image: browserless/chrome:latest
|
||||||
|
environment:
|
||||||
|
- MAX_CONCURRENT_SESSIONS=${MAX_CONCURRENT_SESSIONS:-1}
|
||||||
|
networks:
|
||||||
|
- whaticket
|
||||||
@@ -16,7 +16,9 @@ services:
|
|||||||
- DB_NAME=${MYSQL_DATABASE:-whaticket}
|
- DB_NAME=${MYSQL_DATABASE:-whaticket}
|
||||||
- JWT_SECRET=${JWT_SECRET:-3123123213123}
|
- JWT_SECRET=${JWT_SECRET:-3123123213123}
|
||||||
- JWT_REFRESH_SECRET=${JWT_REFRESH_SECRET:-75756756756}
|
- JWT_REFRESH_SECRET=${JWT_REFRESH_SECRET:-75756756756}
|
||||||
- CHROME_WS=ws://chrome:3000
|
- BACKEND_URL=${BACKEND_URL:-http://localhost:3000/api}
|
||||||
|
- FRONTEND_URL=${BACKEND_URL:-http://localhost:3000}
|
||||||
|
- CHROME_ARGS=--no-sandbox --disable-setuid-sandbox
|
||||||
networks:
|
networks:
|
||||||
- whaticket
|
- whaticket
|
||||||
|
|
||||||
@@ -45,10 +47,3 @@ services:
|
|||||||
restart: always
|
restart: always
|
||||||
networks:
|
networks:
|
||||||
- whaticket
|
- whaticket
|
||||||
|
|
||||||
chrome:
|
|
||||||
image: browserless/chrome:latest
|
|
||||||
environment:
|
|
||||||
- MAX_CONCURRENT_SESSIONS=${MAX_CONCURRENT_SESSIONS:-1}
|
|
||||||
networks:
|
|
||||||
- whaticket
|
|
||||||
Reference in New Issue
Block a user