@builderbot/cli 1.0.29-alpha.0 → 1.0.30-alpha.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.
Files changed (201) hide show
  1. package/dist/starters/apps/base-js-baileys-json/Dockerfile +24 -15
  2. package/dist/starters/apps/base-js-baileys-json/README.md +1 -1
  3. package/dist/starters/apps/base-js-baileys-json/package.json +2 -3
  4. package/dist/starters/apps/base-js-baileys-json/src/app.js +6 -5
  5. package/dist/starters/apps/base-js-baileys-memory/Dockerfile +24 -15
  6. package/dist/starters/apps/base-js-baileys-memory/README.md +1 -1
  7. package/dist/starters/apps/base-js-baileys-memory/package.json +2 -3
  8. package/dist/starters/apps/base-js-baileys-memory/src/app.js +5 -4
  9. package/dist/starters/apps/base-js-baileys-mongo/Dockerfile +24 -15
  10. package/dist/starters/apps/base-js-baileys-mongo/README.md +1 -1
  11. package/dist/starters/apps/base-js-baileys-mongo/package.json +2 -3
  12. package/dist/starters/apps/base-js-baileys-mongo/src/app.js +8 -7
  13. package/dist/starters/apps/base-js-baileys-mysql/Dockerfile +24 -15
  14. package/dist/starters/apps/base-js-baileys-mysql/README.md +1 -1
  15. package/dist/starters/apps/base-js-baileys-mysql/package.json +2 -3
  16. package/dist/starters/apps/base-js-baileys-mysql/src/app.js +10 -9
  17. package/dist/starters/apps/base-js-baileys-postgres/Dockerfile +24 -15
  18. package/dist/starters/apps/base-js-baileys-postgres/README.md +1 -1
  19. package/dist/starters/apps/base-js-baileys-postgres/package.json +2 -3
  20. package/dist/starters/apps/base-js-baileys-postgres/src/app.js +11 -10
  21. package/dist/starters/apps/base-js-meta-json/Dockerfile +24 -15
  22. package/dist/starters/apps/base-js-meta-json/README.md +1 -1
  23. package/dist/starters/apps/base-js-meta-json/package.json +2 -3
  24. package/dist/starters/apps/base-js-meta-json/src/app.js +10 -9
  25. package/dist/starters/apps/base-js-meta-memory/Dockerfile +24 -15
  26. package/dist/starters/apps/base-js-meta-memory/README.md +1 -1
  27. package/dist/starters/apps/base-js-meta-memory/package.json +2 -3
  28. package/dist/starters/apps/base-js-meta-memory/src/app.js +9 -8
  29. package/dist/starters/apps/base-js-meta-mongo/Dockerfile +24 -15
  30. package/dist/starters/apps/base-js-meta-mongo/README.md +1 -1
  31. package/dist/starters/apps/base-js-meta-mongo/package.json +2 -3
  32. package/dist/starters/apps/base-js-meta-mongo/src/app.js +12 -11
  33. package/dist/starters/apps/base-js-meta-mysql/Dockerfile +24 -15
  34. package/dist/starters/apps/base-js-meta-mysql/README.md +1 -1
  35. package/dist/starters/apps/base-js-meta-mysql/package.json +2 -3
  36. package/dist/starters/apps/base-js-meta-mysql/src/app.js +14 -13
  37. package/dist/starters/apps/base-js-meta-postgres/Dockerfile +24 -15
  38. package/dist/starters/apps/base-js-meta-postgres/README.md +1 -1
  39. package/dist/starters/apps/base-js-meta-postgres/package.json +2 -3
  40. package/dist/starters/apps/base-js-meta-postgres/src/app.js +15 -14
  41. package/dist/starters/apps/base-js-twilio-json/Dockerfile +24 -15
  42. package/dist/starters/apps/base-js-twilio-json/README.md +1 -1
  43. package/dist/starters/apps/base-js-twilio-json/package.json +2 -3
  44. package/dist/starters/apps/base-js-twilio-json/src/app.js +9 -8
  45. package/dist/starters/apps/base-js-twilio-memory/Dockerfile +24 -15
  46. package/dist/starters/apps/base-js-twilio-memory/README.md +1 -1
  47. package/dist/starters/apps/base-js-twilio-memory/package.json +2 -3
  48. package/dist/starters/apps/base-js-twilio-memory/src/app.js +8 -7
  49. package/dist/starters/apps/base-js-twilio-mongo/Dockerfile +24 -15
  50. package/dist/starters/apps/base-js-twilio-mongo/README.md +1 -1
  51. package/dist/starters/apps/base-js-twilio-mongo/package.json +2 -3
  52. package/dist/starters/apps/base-js-twilio-mongo/src/app.js +11 -10
  53. package/dist/starters/apps/base-js-twilio-mysql/Dockerfile +24 -15
  54. package/dist/starters/apps/base-js-twilio-mysql/README.md +1 -1
  55. package/dist/starters/apps/base-js-twilio-mysql/package.json +2 -3
  56. package/dist/starters/apps/base-js-twilio-mysql/src/app.js +13 -12
  57. package/dist/starters/apps/base-js-twilio-postgres/Dockerfile +24 -15
  58. package/dist/starters/apps/base-js-twilio-postgres/README.md +1 -1
  59. package/dist/starters/apps/base-js-twilio-postgres/package.json +2 -3
  60. package/dist/starters/apps/base-js-twilio-postgres/src/app.js +14 -13
  61. package/dist/starters/apps/base-js-venom-json/Dockerfile +24 -15
  62. package/dist/starters/apps/base-js-venom-json/README.md +1 -1
  63. package/dist/starters/apps/base-js-venom-json/package.json +2 -3
  64. package/dist/starters/apps/base-js-venom-json/src/app.js +6 -5
  65. package/dist/starters/apps/base-js-venom-memory/Dockerfile +24 -15
  66. package/dist/starters/apps/base-js-venom-memory/README.md +1 -1
  67. package/dist/starters/apps/base-js-venom-memory/package.json +2 -3
  68. package/dist/starters/apps/base-js-venom-memory/src/app.js +5 -4
  69. package/dist/starters/apps/base-js-venom-mongo/Dockerfile +24 -15
  70. package/dist/starters/apps/base-js-venom-mongo/README.md +1 -1
  71. package/dist/starters/apps/base-js-venom-mongo/package.json +2 -3
  72. package/dist/starters/apps/base-js-venom-mongo/src/app.js +8 -7
  73. package/dist/starters/apps/base-js-venom-mysql/Dockerfile +24 -15
  74. package/dist/starters/apps/base-js-venom-mysql/README.md +1 -1
  75. package/dist/starters/apps/base-js-venom-mysql/package.json +2 -3
  76. package/dist/starters/apps/base-js-venom-mysql/src/app.js +10 -9
  77. package/dist/starters/apps/base-js-venom-postgres/Dockerfile +24 -15
  78. package/dist/starters/apps/base-js-venom-postgres/README.md +1 -1
  79. package/dist/starters/apps/base-js-venom-postgres/package.json +2 -3
  80. package/dist/starters/apps/base-js-venom-postgres/src/app.js +11 -10
  81. package/dist/starters/apps/base-js-wppconnect-json/Dockerfile +24 -15
  82. package/dist/starters/apps/base-js-wppconnect-json/README.md +1 -1
  83. package/dist/starters/apps/base-js-wppconnect-json/package.json +2 -3
  84. package/dist/starters/apps/base-js-wppconnect-json/src/app.js +6 -5
  85. package/dist/starters/apps/base-js-wppconnect-memory/Dockerfile +24 -15
  86. package/dist/starters/apps/base-js-wppconnect-memory/README.md +1 -1
  87. package/dist/starters/apps/base-js-wppconnect-memory/package.json +2 -3
  88. package/dist/starters/apps/base-js-wppconnect-memory/src/app.js +5 -4
  89. package/dist/starters/apps/base-js-wppconnect-mongo/Dockerfile +24 -15
  90. package/dist/starters/apps/base-js-wppconnect-mongo/README.md +1 -1
  91. package/dist/starters/apps/base-js-wppconnect-mongo/package.json +2 -3
  92. package/dist/starters/apps/base-js-wppconnect-mongo/src/app.js +8 -7
  93. package/dist/starters/apps/base-js-wppconnect-mysql/Dockerfile +24 -15
  94. package/dist/starters/apps/base-js-wppconnect-mysql/README.md +1 -1
  95. package/dist/starters/apps/base-js-wppconnect-mysql/package.json +2 -3
  96. package/dist/starters/apps/base-js-wppconnect-mysql/src/app.js +10 -9
  97. package/dist/starters/apps/base-js-wppconnect-postgres/Dockerfile +24 -15
  98. package/dist/starters/apps/base-js-wppconnect-postgres/README.md +1 -1
  99. package/dist/starters/apps/base-js-wppconnect-postgres/package.json +2 -3
  100. package/dist/starters/apps/base-js-wppconnect-postgres/src/app.js +11 -10
  101. package/dist/starters/apps/base-ts-baileys-json/Dockerfile +26 -15
  102. package/dist/starters/apps/base-ts-baileys-json/README.md +1 -1
  103. package/dist/starters/apps/base-ts-baileys-json/package.json +29 -29
  104. package/dist/starters/apps/base-ts-baileys-json/src/app.ts +5 -5
  105. package/dist/starters/apps/base-ts-baileys-memory/Dockerfile +26 -15
  106. package/dist/starters/apps/base-ts-baileys-memory/README.md +1 -1
  107. package/dist/starters/apps/base-ts-baileys-memory/package.json +28 -28
  108. package/dist/starters/apps/base-ts-baileys-memory/src/app.ts +4 -4
  109. package/dist/starters/apps/base-ts-baileys-mongo/Dockerfile +26 -15
  110. package/dist/starters/apps/base-ts-baileys-mongo/README.md +1 -1
  111. package/dist/starters/apps/base-ts-baileys-mongo/package.json +29 -29
  112. package/dist/starters/apps/base-ts-baileys-mongo/src/app.ts +7 -7
  113. package/dist/starters/apps/base-ts-baileys-mysql/Dockerfile +26 -15
  114. package/dist/starters/apps/base-ts-baileys-mysql/README.md +1 -1
  115. package/dist/starters/apps/base-ts-baileys-mysql/package.json +29 -29
  116. package/dist/starters/apps/base-ts-baileys-mysql/src/app.ts +9 -9
  117. package/dist/starters/apps/base-ts-baileys-postgres/Dockerfile +26 -15
  118. package/dist/starters/apps/base-ts-baileys-postgres/README.md +1 -1
  119. package/dist/starters/apps/base-ts-baileys-postgres/package.json +29 -29
  120. package/dist/starters/apps/base-ts-baileys-postgres/src/app.ts +10 -10
  121. package/dist/starters/apps/base-ts-meta-json/Dockerfile +26 -15
  122. package/dist/starters/apps/base-ts-meta-json/README.md +1 -1
  123. package/dist/starters/apps/base-ts-meta-json/package.json +29 -29
  124. package/dist/starters/apps/base-ts-meta-json/src/app.ts +9 -9
  125. package/dist/starters/apps/base-ts-meta-memory/Dockerfile +26 -15
  126. package/dist/starters/apps/base-ts-meta-memory/README.md +1 -1
  127. package/dist/starters/apps/base-ts-meta-memory/package.json +28 -28
  128. package/dist/starters/apps/base-ts-meta-memory/src/app.ts +8 -8
  129. package/dist/starters/apps/base-ts-meta-mongo/Dockerfile +26 -15
  130. package/dist/starters/apps/base-ts-meta-mongo/README.md +1 -1
  131. package/dist/starters/apps/base-ts-meta-mongo/package.json +29 -29
  132. package/dist/starters/apps/base-ts-meta-mongo/src/app.ts +11 -11
  133. package/dist/starters/apps/base-ts-meta-mysql/Dockerfile +26 -15
  134. package/dist/starters/apps/base-ts-meta-mysql/README.md +1 -1
  135. package/dist/starters/apps/base-ts-meta-mysql/package.json +29 -29
  136. package/dist/starters/apps/base-ts-meta-mysql/src/app.ts +13 -13
  137. package/dist/starters/apps/base-ts-meta-postgres/Dockerfile +26 -15
  138. package/dist/starters/apps/base-ts-meta-postgres/README.md +1 -1
  139. package/dist/starters/apps/base-ts-meta-postgres/package.json +29 -29
  140. package/dist/starters/apps/base-ts-meta-postgres/src/app.ts +14 -14
  141. package/dist/starters/apps/base-ts-twilio-json/Dockerfile +26 -15
  142. package/dist/starters/apps/base-ts-twilio-json/README.md +1 -1
  143. package/dist/starters/apps/base-ts-twilio-json/package.json +29 -29
  144. package/dist/starters/apps/base-ts-twilio-json/src/app.ts +8 -8
  145. package/dist/starters/apps/base-ts-twilio-memory/Dockerfile +26 -15
  146. package/dist/starters/apps/base-ts-twilio-memory/README.md +1 -1
  147. package/dist/starters/apps/base-ts-twilio-memory/package.json +28 -28
  148. package/dist/starters/apps/base-ts-twilio-memory/src/app.ts +7 -7
  149. package/dist/starters/apps/base-ts-twilio-mongo/Dockerfile +26 -15
  150. package/dist/starters/apps/base-ts-twilio-mongo/README.md +1 -1
  151. package/dist/starters/apps/base-ts-twilio-mongo/package.json +29 -29
  152. package/dist/starters/apps/base-ts-twilio-mongo/src/app.ts +10 -10
  153. package/dist/starters/apps/base-ts-twilio-mysql/Dockerfile +26 -15
  154. package/dist/starters/apps/base-ts-twilio-mysql/README.md +1 -1
  155. package/dist/starters/apps/base-ts-twilio-mysql/package.json +29 -29
  156. package/dist/starters/apps/base-ts-twilio-mysql/src/app.ts +12 -12
  157. package/dist/starters/apps/base-ts-twilio-postgres/Dockerfile +26 -15
  158. package/dist/starters/apps/base-ts-twilio-postgres/README.md +1 -1
  159. package/dist/starters/apps/base-ts-twilio-postgres/package.json +29 -29
  160. package/dist/starters/apps/base-ts-twilio-postgres/src/app.ts +13 -13
  161. package/dist/starters/apps/base-ts-venom-json/Dockerfile +26 -15
  162. package/dist/starters/apps/base-ts-venom-json/README.md +1 -1
  163. package/dist/starters/apps/base-ts-venom-json/package.json +29 -29
  164. package/dist/starters/apps/base-ts-venom-json/src/app.ts +5 -5
  165. package/dist/starters/apps/base-ts-venom-memory/Dockerfile +26 -15
  166. package/dist/starters/apps/base-ts-venom-memory/README.md +1 -1
  167. package/dist/starters/apps/base-ts-venom-memory/package.json +28 -28
  168. package/dist/starters/apps/base-ts-venom-memory/src/app.ts +4 -4
  169. package/dist/starters/apps/base-ts-venom-mongo/Dockerfile +26 -15
  170. package/dist/starters/apps/base-ts-venom-mongo/README.md +1 -1
  171. package/dist/starters/apps/base-ts-venom-mongo/package.json +29 -29
  172. package/dist/starters/apps/base-ts-venom-mongo/src/app.ts +7 -7
  173. package/dist/starters/apps/base-ts-venom-mysql/Dockerfile +26 -15
  174. package/dist/starters/apps/base-ts-venom-mysql/README.md +1 -1
  175. package/dist/starters/apps/base-ts-venom-mysql/package.json +29 -29
  176. package/dist/starters/apps/base-ts-venom-mysql/src/app.ts +9 -9
  177. package/dist/starters/apps/base-ts-venom-postgres/Dockerfile +26 -15
  178. package/dist/starters/apps/base-ts-venom-postgres/README.md +1 -1
  179. package/dist/starters/apps/base-ts-venom-postgres/package.json +29 -29
  180. package/dist/starters/apps/base-ts-venom-postgres/src/app.ts +10 -10
  181. package/dist/starters/apps/base-ts-wppconnect-json/Dockerfile +26 -15
  182. package/dist/starters/apps/base-ts-wppconnect-json/README.md +1 -1
  183. package/dist/starters/apps/base-ts-wppconnect-json/package.json +29 -29
  184. package/dist/starters/apps/base-ts-wppconnect-json/src/app.ts +5 -5
  185. package/dist/starters/apps/base-ts-wppconnect-memory/Dockerfile +26 -15
  186. package/dist/starters/apps/base-ts-wppconnect-memory/README.md +1 -1
  187. package/dist/starters/apps/base-ts-wppconnect-memory/package.json +28 -28
  188. package/dist/starters/apps/base-ts-wppconnect-memory/src/app.ts +4 -4
  189. package/dist/starters/apps/base-ts-wppconnect-mongo/Dockerfile +26 -15
  190. package/dist/starters/apps/base-ts-wppconnect-mongo/README.md +1 -1
  191. package/dist/starters/apps/base-ts-wppconnect-mongo/package.json +29 -29
  192. package/dist/starters/apps/base-ts-wppconnect-mongo/src/app.ts +7 -7
  193. package/dist/starters/apps/base-ts-wppconnect-mysql/Dockerfile +26 -15
  194. package/dist/starters/apps/base-ts-wppconnect-mysql/README.md +1 -1
  195. package/dist/starters/apps/base-ts-wppconnect-mysql/package.json +29 -29
  196. package/dist/starters/apps/base-ts-wppconnect-mysql/src/app.ts +9 -9
  197. package/dist/starters/apps/base-ts-wppconnect-postgres/Dockerfile +26 -15
  198. package/dist/starters/apps/base-ts-wppconnect-postgres/README.md +1 -1
  199. package/dist/starters/apps/base-ts-wppconnect-postgres/package.json +29 -29
  200. package/dist/starters/apps/base-ts-wppconnect-postgres/src/app.ts +10 -10
  201. package/package.json +2 -2
@@ -6,7 +6,7 @@
6
6
  "type": "module",
7
7
  "scripts": {
8
8
  "lint": "eslint . --no-ignore",
9
- "dev": "npm run lint && nodemon ./src/app.js",
9
+ "dev": "node --no-warnings --watch-path=./src ./src/app.js",
10
10
  "start": "node ./src/app.js"
11
11
  },
12
12
  "keywords": [],
@@ -16,8 +16,7 @@
16
16
  },
17
17
  "devDependencies": {
18
18
  "eslint-plugin-builderbot": "latest",
19
- "eslint": "^8.57.0",
20
- "nodemon": "^3.1.0"
19
+ "eslint": "^8.57.0"
21
20
  },
22
21
  "author": "",
23
22
  "license": "ISC"
@@ -1,6 +1,7 @@
1
+ import { join } from 'path'
1
2
  import { createBot, createProvider, createFlow, addKeyword, utils } from '@builderbot/bot'
2
- import { MemoryDB as Database } from '@builderbot/bot'
3
- import { VenomProvider as Provider } from '@builderbot/provider-venom'
3
+ import { MemoryDB as Database } from '@builderbot/bot'
4
+ import { VenomProvider as Provider } from '@builderbot/provider-venom'
4
5
 
5
6
  const PORT = process.env.PORT ?? 3008
6
7
 
@@ -59,9 +60,9 @@ const fullSamplesFlow = addKeyword(['samples', utils.setEvent('SAMPLES')])
59
60
 
60
61
  const main = async () => {
61
62
  const adapterFlow = createFlow([welcomeFlow, registerFlow, fullSamplesFlow])
62
-
63
+
63
64
  const adapterProvider = createProvider(Provider)
64
- const adapterDB = new Database()
65
+ const adapterDB = new Database()
65
66
 
66
67
  const { handleCtx, httpServer } = await createBot({
67
68
  flow: adapterFlow,
@@ -1,28 +1,37 @@
1
+ # Image size ~ 330MB
1
2
  FROM node:21-alpine3.18 as builder
2
3
 
4
+ WORKDIR /app
5
+
3
6
  RUN corepack enable && corepack prepare pnpm@latest --activate
4
7
  ENV PNPM_HOME=/usr/local/bin
5
8
 
6
- WORKDIR /app
7
-
8
- COPY package*.json pnpm-lock.yaml ./
9
+ COPY . .
9
10
 
10
- RUN apk add --no-cache \
11
- git
11
+ COPY package*.json *-lock.yaml ./
12
12
 
13
- # RUN pnpm install pm2 -g
13
+ RUN apk add --no-cache --virtual .gyp \
14
+ python3 \
15
+ make \
16
+ g++ \
17
+ && apk add --no-cache git \
18
+ && pnpm install \
19
+ && apk del .gyp
14
20
 
15
- COPY . .
16
- RUN pnpm i
21
+ FROM node:21-alpine3.18 as deploy
17
22
 
18
- FROM builder as deploy
23
+ WORKDIR /app
19
24
 
20
- ARG RAILWAY_STATIC_URL
21
- ARG PUBLIC_URL
22
25
  ARG PORT
23
- COPY --from=builder /app/src ./src
24
- COPY --from=builder /app/package.json /app/pnpm-lock.yaml ./
26
+ ENV PORT $PORT
27
+ EXPOSE $PORT
28
+
29
+ COPY --from=builder /app .
30
+
31
+ RUN corepack enable && corepack prepare pnpm@latest --activate
32
+ ENV PNPM_HOME=/usr/local/bin
33
+
34
+ RUN npm cache clean --force && pnpm install --frozen-lockfile --production --ignore-scripts \
35
+ && rm -rf $PNPM_HOME/.npm $PNPM_HOME/.node-gyp
25
36
 
26
- RUN pnpm install --frozen-lockfile --production
27
- # CMD ["pm2-runtime", "start", "./src/app.js", "--cron", "0 */12 * * *"]
28
37
  CMD ["npm", "start"]
@@ -1,7 +1,7 @@
1
1
  <p align="center">
2
2
  <a href="https://builderbot.vercel.app/">
3
3
  <picture>
4
- <img src="https://i.imgur.com/OPl026Z.png" height="80">
4
+ <img src="https://builderbot.vercel.app/assets/thumbnail-vector.png" height="80">
5
5
  </picture>
6
6
  <h2 align="center">BuilderBot</h2>
7
7
  </a>
@@ -6,7 +6,7 @@
6
6
  "type": "module",
7
7
  "scripts": {
8
8
  "lint": "eslint . --no-ignore",
9
- "dev": "npm run lint && nodemon ./src/app.js",
9
+ "dev": "node --no-warnings --watch-path=./src ./src/app.js",
10
10
  "start": "node ./src/app.js"
11
11
  },
12
12
  "keywords": [],
@@ -17,8 +17,7 @@
17
17
  },
18
18
  "devDependencies": {
19
19
  "eslint-plugin-builderbot": "latest",
20
- "eslint": "^8.57.0",
21
- "nodemon": "^3.1.0"
20
+ "eslint": "^8.57.0"
22
21
  },
23
22
  "author": "",
24
23
  "license": "ISC"
@@ -1,6 +1,7 @@
1
+ import { join } from 'path'
1
2
  import { createBot, createProvider, createFlow, addKeyword, utils } from '@builderbot/bot'
2
- import { MongoAdapter as Database } from '@builderbot/database-mongo'
3
- import { VenomProvider as Provider } from '@builderbot/provider-venom'
3
+ import { MongoAdapter as Database } from '@builderbot/database-mongo'
4
+ import { VenomProvider as Provider } from '@builderbot/provider-venom'
4
5
 
5
6
  const PORT = process.env.PORT ?? 3008
6
7
 
@@ -59,12 +60,12 @@ const fullSamplesFlow = addKeyword(['samples', utils.setEvent('SAMPLES')])
59
60
 
60
61
  const main = async () => {
61
62
  const adapterFlow = createFlow([welcomeFlow, registerFlow, fullSamplesFlow])
62
-
63
+
63
64
  const adapterProvider = createProvider(Provider)
64
- const adapterDB = new Database({
65
- dbUri: process.env.MONGO_DB_URI,
66
- dbName: process.env.MONGO_DB_NAME,
67
- })
65
+ const adapterDB = new Database({
66
+ dbUri: process.env.MONGO_DB_URI,
67
+ dbName: process.env.MONGO_DB_NAME,
68
+ })
68
69
 
69
70
  const { handleCtx, httpServer } = await createBot({
70
71
  flow: adapterFlow,
@@ -1,28 +1,37 @@
1
+ # Image size ~ 330MB
1
2
  FROM node:21-alpine3.18 as builder
2
3
 
4
+ WORKDIR /app
5
+
3
6
  RUN corepack enable && corepack prepare pnpm@latest --activate
4
7
  ENV PNPM_HOME=/usr/local/bin
5
8
 
6
- WORKDIR /app
7
-
8
- COPY package*.json pnpm-lock.yaml ./
9
+ COPY . .
9
10
 
10
- RUN apk add --no-cache \
11
- git
11
+ COPY package*.json *-lock.yaml ./
12
12
 
13
- # RUN pnpm install pm2 -g
13
+ RUN apk add --no-cache --virtual .gyp \
14
+ python3 \
15
+ make \
16
+ g++ \
17
+ && apk add --no-cache git \
18
+ && pnpm install \
19
+ && apk del .gyp
14
20
 
15
- COPY . .
16
- RUN pnpm i
21
+ FROM node:21-alpine3.18 as deploy
17
22
 
18
- FROM builder as deploy
23
+ WORKDIR /app
19
24
 
20
- ARG RAILWAY_STATIC_URL
21
- ARG PUBLIC_URL
22
25
  ARG PORT
23
- COPY --from=builder /app/src ./src
24
- COPY --from=builder /app/package.json /app/pnpm-lock.yaml ./
26
+ ENV PORT $PORT
27
+ EXPOSE $PORT
28
+
29
+ COPY --from=builder /app .
30
+
31
+ RUN corepack enable && corepack prepare pnpm@latest --activate
32
+ ENV PNPM_HOME=/usr/local/bin
33
+
34
+ RUN npm cache clean --force && pnpm install --frozen-lockfile --production --ignore-scripts \
35
+ && rm -rf $PNPM_HOME/.npm $PNPM_HOME/.node-gyp
25
36
 
26
- RUN pnpm install --frozen-lockfile --production
27
- # CMD ["pm2-runtime", "start", "./src/app.js", "--cron", "0 */12 * * *"]
28
37
  CMD ["npm", "start"]
@@ -1,7 +1,7 @@
1
1
  <p align="center">
2
2
  <a href="https://builderbot.vercel.app/">
3
3
  <picture>
4
- <img src="https://i.imgur.com/OPl026Z.png" height="80">
4
+ <img src="https://builderbot.vercel.app/assets/thumbnail-vector.png" height="80">
5
5
  </picture>
6
6
  <h2 align="center">BuilderBot</h2>
7
7
  </a>
@@ -6,7 +6,7 @@
6
6
  "type": "module",
7
7
  "scripts": {
8
8
  "lint": "eslint . --no-ignore",
9
- "dev": "npm run lint && nodemon ./src/app.js",
9
+ "dev": "node --no-warnings --watch-path=./src ./src/app.js",
10
10
  "start": "node ./src/app.js"
11
11
  },
12
12
  "keywords": [],
@@ -17,8 +17,7 @@
17
17
  },
18
18
  "devDependencies": {
19
19
  "eslint-plugin-builderbot": "latest",
20
- "eslint": "^8.57.0",
21
- "nodemon": "^3.1.0"
20
+ "eslint": "^8.57.0"
22
21
  },
23
22
  "author": "",
24
23
  "license": "ISC"
@@ -1,6 +1,7 @@
1
+ import { join } from 'path'
1
2
  import { createBot, createProvider, createFlow, addKeyword, utils } from '@builderbot/bot'
2
- import { MysqlAdapter as Database } from '@builderbot/database-mysql'
3
- import { VenomProvider as Provider } from '@builderbot/provider-venom'
3
+ import { MysqlAdapter as Database } from '@builderbot/database-mysql'
4
+ import { VenomProvider as Provider } from '@builderbot/provider-venom'
4
5
 
5
6
  const PORT = process.env.PORT ?? 3008
6
7
 
@@ -59,14 +60,14 @@ const fullSamplesFlow = addKeyword(['samples', utils.setEvent('SAMPLES')])
59
60
 
60
61
  const main = async () => {
61
62
  const adapterFlow = createFlow([welcomeFlow, registerFlow, fullSamplesFlow])
62
-
63
+
63
64
  const adapterProvider = createProvider(Provider)
64
- const adapterDB = new Database({
65
- host: process.env.MYSQL_DB_HOST,
66
- user: process.env.MYSQL_DB_USER,
67
- database: process.env.MYSQL_DB_NAME,
68
- password: process.env.MYSQL_DB_PASSWORD,
69
- })
65
+ const adapterDB = new Database({
66
+ host: process.env.MYSQL_DB_HOST,
67
+ user: process.env.MYSQL_DB_USER,
68
+ database: process.env.MYSQL_DB_NAME,
69
+ password: process.env.MYSQL_DB_PASSWORD,
70
+ })
70
71
 
71
72
  const { handleCtx, httpServer } = await createBot({
72
73
  flow: adapterFlow,
@@ -1,28 +1,37 @@
1
+ # Image size ~ 330MB
1
2
  FROM node:21-alpine3.18 as builder
2
3
 
4
+ WORKDIR /app
5
+
3
6
  RUN corepack enable && corepack prepare pnpm@latest --activate
4
7
  ENV PNPM_HOME=/usr/local/bin
5
8
 
6
- WORKDIR /app
7
-
8
- COPY package*.json pnpm-lock.yaml ./
9
+ COPY . .
9
10
 
10
- RUN apk add --no-cache \
11
- git
11
+ COPY package*.json *-lock.yaml ./
12
12
 
13
- # RUN pnpm install pm2 -g
13
+ RUN apk add --no-cache --virtual .gyp \
14
+ python3 \
15
+ make \
16
+ g++ \
17
+ && apk add --no-cache git \
18
+ && pnpm install \
19
+ && apk del .gyp
14
20
 
15
- COPY . .
16
- RUN pnpm i
21
+ FROM node:21-alpine3.18 as deploy
17
22
 
18
- FROM builder as deploy
23
+ WORKDIR /app
19
24
 
20
- ARG RAILWAY_STATIC_URL
21
- ARG PUBLIC_URL
22
25
  ARG PORT
23
- COPY --from=builder /app/src ./src
24
- COPY --from=builder /app/package.json /app/pnpm-lock.yaml ./
26
+ ENV PORT $PORT
27
+ EXPOSE $PORT
28
+
29
+ COPY --from=builder /app .
30
+
31
+ RUN corepack enable && corepack prepare pnpm@latest --activate
32
+ ENV PNPM_HOME=/usr/local/bin
33
+
34
+ RUN npm cache clean --force && pnpm install --frozen-lockfile --production --ignore-scripts \
35
+ && rm -rf $PNPM_HOME/.npm $PNPM_HOME/.node-gyp
25
36
 
26
- RUN pnpm install --frozen-lockfile --production
27
- # CMD ["pm2-runtime", "start", "./src/app.js", "--cron", "0 */12 * * *"]
28
37
  CMD ["npm", "start"]
@@ -1,7 +1,7 @@
1
1
  <p align="center">
2
2
  <a href="https://builderbot.vercel.app/">
3
3
  <picture>
4
- <img src="https://i.imgur.com/OPl026Z.png" height="80">
4
+ <img src="https://builderbot.vercel.app/assets/thumbnail-vector.png" height="80">
5
5
  </picture>
6
6
  <h2 align="center">BuilderBot</h2>
7
7
  </a>
@@ -6,7 +6,7 @@
6
6
  "type": "module",
7
7
  "scripts": {
8
8
  "lint": "eslint . --no-ignore",
9
- "dev": "npm run lint && nodemon ./src/app.js",
9
+ "dev": "node --no-warnings --watch-path=./src ./src/app.js",
10
10
  "start": "node ./src/app.js"
11
11
  },
12
12
  "keywords": [],
@@ -17,8 +17,7 @@
17
17
  },
18
18
  "devDependencies": {
19
19
  "eslint-plugin-builderbot": "latest",
20
- "eslint": "^8.57.0",
21
- "nodemon": "^3.1.0"
20
+ "eslint": "^8.57.0"
22
21
  },
23
22
  "author": "",
24
23
  "license": "ISC"
@@ -1,6 +1,7 @@
1
+ import { join } from 'path'
1
2
  import { createBot, createProvider, createFlow, addKeyword, utils } from '@builderbot/bot'
2
- import { PostgreSQLAdapter as Database } from '@builderbot/database-postgres'
3
- import { VenomProvider as Provider } from '@builderbot/provider-venom'
3
+ import { PostgreSQLAdapter as Database } from '@builderbot/database-postgres'
4
+ import { VenomProvider as Provider } from '@builderbot/provider-venom'
4
5
 
5
6
  const PORT = process.env.PORT ?? 3008
6
7
 
@@ -59,15 +60,15 @@ const fullSamplesFlow = addKeyword(['samples', utils.setEvent('SAMPLES')])
59
60
 
60
61
  const main = async () => {
61
62
  const adapterFlow = createFlow([welcomeFlow, registerFlow, fullSamplesFlow])
62
-
63
+
63
64
  const adapterProvider = createProvider(Provider)
64
- const adapterDB = new Database({
65
- host: process.env.POSTGRES_DB_HOST,
66
- user: process.env.POSTGRES_DB_USER,
67
- database: process.env.POSTGRES_DB_NAME,
68
- password: process.env.POSTGRES_DB_PASSWORD,
69
- port: +process.env.POSTGRES_DB_PORT
70
- })
65
+ const adapterDB = new Database({
66
+ host: process.env.POSTGRES_DB_HOST,
67
+ user: process.env.POSTGRES_DB_USER,
68
+ database: process.env.POSTGRES_DB_NAME,
69
+ password: process.env.POSTGRES_DB_PASSWORD,
70
+ port: +process.env.POSTGRES_DB_PORT
71
+ })
71
72
 
72
73
  const { handleCtx, httpServer } = await createBot({
73
74
  flow: adapterFlow,
@@ -1,28 +1,37 @@
1
+ # Image size ~ 330MB
1
2
  FROM node:21-alpine3.18 as builder
2
3
 
4
+ WORKDIR /app
5
+
3
6
  RUN corepack enable && corepack prepare pnpm@latest --activate
4
7
  ENV PNPM_HOME=/usr/local/bin
5
8
 
6
- WORKDIR /app
7
-
8
- COPY package*.json pnpm-lock.yaml ./
9
+ COPY . .
9
10
 
10
- RUN apk add --no-cache \
11
- git
11
+ COPY package*.json *-lock.yaml ./
12
12
 
13
- # RUN pnpm install pm2 -g
13
+ RUN apk add --no-cache --virtual .gyp \
14
+ python3 \
15
+ make \
16
+ g++ \
17
+ && apk add --no-cache git \
18
+ && pnpm install \
19
+ && apk del .gyp
14
20
 
15
- COPY . .
16
- RUN pnpm i
21
+ FROM node:21-alpine3.18 as deploy
17
22
 
18
- FROM builder as deploy
23
+ WORKDIR /app
19
24
 
20
- ARG RAILWAY_STATIC_URL
21
- ARG PUBLIC_URL
22
25
  ARG PORT
23
- COPY --from=builder /app/src ./src
24
- COPY --from=builder /app/package.json /app/pnpm-lock.yaml ./
26
+ ENV PORT $PORT
27
+ EXPOSE $PORT
28
+
29
+ COPY --from=builder /app .
30
+
31
+ RUN corepack enable && corepack prepare pnpm@latest --activate
32
+ ENV PNPM_HOME=/usr/local/bin
33
+
34
+ RUN npm cache clean --force && pnpm install --frozen-lockfile --production --ignore-scripts \
35
+ && rm -rf $PNPM_HOME/.npm $PNPM_HOME/.node-gyp
25
36
 
26
- RUN pnpm install --frozen-lockfile --production
27
- # CMD ["pm2-runtime", "start", "./src/app.js", "--cron", "0 */12 * * *"]
28
37
  CMD ["npm", "start"]
@@ -1,7 +1,7 @@
1
1
  <p align="center">
2
2
  <a href="https://builderbot.vercel.app/">
3
3
  <picture>
4
- <img src="https://i.imgur.com/OPl026Z.png" height="80">
4
+ <img src="https://builderbot.vercel.app/assets/thumbnail-vector.png" height="80">
5
5
  </picture>
6
6
  <h2 align="center">BuilderBot</h2>
7
7
  </a>
@@ -6,7 +6,7 @@
6
6
  "type": "module",
7
7
  "scripts": {
8
8
  "lint": "eslint . --no-ignore",
9
- "dev": "npm run lint && nodemon ./src/app.js",
9
+ "dev": "node --no-warnings --watch-path=./src ./src/app.js",
10
10
  "start": "node ./src/app.js"
11
11
  },
12
12
  "keywords": [],
@@ -17,8 +17,7 @@
17
17
  },
18
18
  "devDependencies": {
19
19
  "eslint-plugin-builderbot": "latest",
20
- "eslint": "^8.57.0",
21
- "nodemon": "^3.1.0"
20
+ "eslint": "^8.57.0"
22
21
  },
23
22
  "author": "",
24
23
  "license": "ISC"
@@ -1,6 +1,7 @@
1
+ import { join } from 'path'
1
2
  import { createBot, createProvider, createFlow, addKeyword, utils } from '@builderbot/bot'
2
- import { JsonFileDB as Database } from '@builderbot/database-json'
3
- import { WPPConnectProvider as Provider } from '@builderbot/provider-wppconnect'
3
+ import { JsonFileDB as Database } from '@builderbot/database-json'
4
+ import { WPPConnectProvider as Provider } from '@builderbot/provider-wppconnect'
4
5
 
5
6
  const PORT = process.env.PORT ?? 3008
6
7
 
@@ -59,10 +60,10 @@ const fullSamplesFlow = addKeyword(['samples', utils.setEvent('SAMPLES')])
59
60
 
60
61
  const main = async () => {
61
62
  const adapterFlow = createFlow([welcomeFlow, registerFlow, fullSamplesFlow])
62
-
63
+
63
64
  const adapterProvider = createProvider(Provider)
64
-
65
- const adapterDB = new Database({ filename: 'db.json' })
65
+
66
+ const adapterDB = new Database({ filename: 'db.json' })
66
67
 
67
68
  const { handleCtx, httpServer } = await createBot({
68
69
  flow: adapterFlow,
@@ -1,28 +1,37 @@
1
+ # Image size ~ 330MB
1
2
  FROM node:21-alpine3.18 as builder
2
3
 
4
+ WORKDIR /app
5
+
3
6
  RUN corepack enable && corepack prepare pnpm@latest --activate
4
7
  ENV PNPM_HOME=/usr/local/bin
5
8
 
6
- WORKDIR /app
7
-
8
- COPY package*.json pnpm-lock.yaml ./
9
+ COPY . .
9
10
 
10
- RUN apk add --no-cache \
11
- git
11
+ COPY package*.json *-lock.yaml ./
12
12
 
13
- # RUN pnpm install pm2 -g
13
+ RUN apk add --no-cache --virtual .gyp \
14
+ python3 \
15
+ make \
16
+ g++ \
17
+ && apk add --no-cache git \
18
+ && pnpm install \
19
+ && apk del .gyp
14
20
 
15
- COPY . .
16
- RUN pnpm i
21
+ FROM node:21-alpine3.18 as deploy
17
22
 
18
- FROM builder as deploy
23
+ WORKDIR /app
19
24
 
20
- ARG RAILWAY_STATIC_URL
21
- ARG PUBLIC_URL
22
25
  ARG PORT
23
- COPY --from=builder /app/src ./src
24
- COPY --from=builder /app/package.json /app/pnpm-lock.yaml ./
26
+ ENV PORT $PORT
27
+ EXPOSE $PORT
28
+
29
+ COPY --from=builder /app .
30
+
31
+ RUN corepack enable && corepack prepare pnpm@latest --activate
32
+ ENV PNPM_HOME=/usr/local/bin
33
+
34
+ RUN npm cache clean --force && pnpm install --frozen-lockfile --production --ignore-scripts \
35
+ && rm -rf $PNPM_HOME/.npm $PNPM_HOME/.node-gyp
25
36
 
26
- RUN pnpm install --frozen-lockfile --production
27
- # CMD ["pm2-runtime", "start", "./src/app.js", "--cron", "0 */12 * * *"]
28
37
  CMD ["npm", "start"]
@@ -1,7 +1,7 @@
1
1
  <p align="center">
2
2
  <a href="https://builderbot.vercel.app/">
3
3
  <picture>
4
- <img src="https://i.imgur.com/OPl026Z.png" height="80">
4
+ <img src="https://builderbot.vercel.app/assets/thumbnail-vector.png" height="80">
5
5
  </picture>
6
6
  <h2 align="center">BuilderBot</h2>
7
7
  </a>
@@ -6,7 +6,7 @@
6
6
  "type": "module",
7
7
  "scripts": {
8
8
  "lint": "eslint . --no-ignore",
9
- "dev": "npm run lint && nodemon ./src/app.js",
9
+ "dev": "node --no-warnings --watch-path=./src ./src/app.js",
10
10
  "start": "node ./src/app.js"
11
11
  },
12
12
  "keywords": [],
@@ -16,8 +16,7 @@
16
16
  },
17
17
  "devDependencies": {
18
18
  "eslint-plugin-builderbot": "latest",
19
- "eslint": "^8.57.0",
20
- "nodemon": "^3.1.0"
19
+ "eslint": "^8.57.0"
21
20
  },
22
21
  "author": "",
23
22
  "license": "ISC"
@@ -1,6 +1,7 @@
1
+ import { join } from 'path'
1
2
  import { createBot, createProvider, createFlow, addKeyword, utils } from '@builderbot/bot'
2
- import { MemoryDB as Database } from '@builderbot/bot'
3
- import { WPPConnectProvider as Provider } from '@builderbot/provider-wppconnect'
3
+ import { MemoryDB as Database } from '@builderbot/bot'
4
+ import { WPPConnectProvider as Provider } from '@builderbot/provider-wppconnect'
4
5
 
5
6
  const PORT = process.env.PORT ?? 3008
6
7
 
@@ -59,9 +60,9 @@ const fullSamplesFlow = addKeyword(['samples', utils.setEvent('SAMPLES')])
59
60
 
60
61
  const main = async () => {
61
62
  const adapterFlow = createFlow([welcomeFlow, registerFlow, fullSamplesFlow])
62
-
63
+
63
64
  const adapterProvider = createProvider(Provider)
64
- const adapterDB = new Database()
65
+ const adapterDB = new Database()
65
66
 
66
67
  const { handleCtx, httpServer } = await createBot({
67
68
  flow: adapterFlow,
@@ -1,28 +1,37 @@
1
+ # Image size ~ 330MB
1
2
  FROM node:21-alpine3.18 as builder
2
3
 
4
+ WORKDIR /app
5
+
3
6
  RUN corepack enable && corepack prepare pnpm@latest --activate
4
7
  ENV PNPM_HOME=/usr/local/bin
5
8
 
6
- WORKDIR /app
7
-
8
- COPY package*.json pnpm-lock.yaml ./
9
+ COPY . .
9
10
 
10
- RUN apk add --no-cache \
11
- git
11
+ COPY package*.json *-lock.yaml ./
12
12
 
13
- # RUN pnpm install pm2 -g
13
+ RUN apk add --no-cache --virtual .gyp \
14
+ python3 \
15
+ make \
16
+ g++ \
17
+ && apk add --no-cache git \
18
+ && pnpm install \
19
+ && apk del .gyp
14
20
 
15
- COPY . .
16
- RUN pnpm i
21
+ FROM node:21-alpine3.18 as deploy
17
22
 
18
- FROM builder as deploy
23
+ WORKDIR /app
19
24
 
20
- ARG RAILWAY_STATIC_URL
21
- ARG PUBLIC_URL
22
25
  ARG PORT
23
- COPY --from=builder /app/src ./src
24
- COPY --from=builder /app/package.json /app/pnpm-lock.yaml ./
26
+ ENV PORT $PORT
27
+ EXPOSE $PORT
28
+
29
+ COPY --from=builder /app .
30
+
31
+ RUN corepack enable && corepack prepare pnpm@latest --activate
32
+ ENV PNPM_HOME=/usr/local/bin
33
+
34
+ RUN npm cache clean --force && pnpm install --frozen-lockfile --production --ignore-scripts \
35
+ && rm -rf $PNPM_HOME/.npm $PNPM_HOME/.node-gyp
25
36
 
26
- RUN pnpm install --frozen-lockfile --production
27
- # CMD ["pm2-runtime", "start", "./src/app.js", "--cron", "0 */12 * * *"]
28
37
  CMD ["npm", "start"]