@zorilla/puppeteer-extra-plugin-stealth 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.
Files changed (270) hide show
  1. package/.claude/settings.local.json +21 -0
  2. package/LICENSE +21 -0
  3. package/README.md +324 -0
  4. package/dist/evasions/README.md +13 -0
  5. package/dist/evasions/_template/README.md +18 -0
  6. package/dist/evasions/_template/index.d.ts +13 -0
  7. package/dist/evasions/_template/index.d.ts.map +1 -0
  8. package/dist/evasions/_template/index.js +26 -0
  9. package/dist/evasions/_template/index.js.map +1 -0
  10. package/dist/evasions/_template/package.json +5 -0
  11. package/dist/evasions/_utils/README.md +287 -0
  12. package/dist/evasions/_utils/index.d.ts +238 -0
  13. package/dist/evasions/_utils/index.d.ts.map +1 -0
  14. package/dist/evasions/_utils/index.js +588 -0
  15. package/dist/evasions/_utils/index.js.map +1 -0
  16. package/dist/evasions/_utils/withUtils.d.ts +12 -0
  17. package/dist/evasions/_utils/withUtils.d.ts.map +1 -0
  18. package/dist/evasions/_utils/withUtils.js +47 -0
  19. package/dist/evasions/_utils/withUtils.js.map +1 -0
  20. package/dist/evasions/chrome.app/README.md +16 -0
  21. package/dist/evasions/chrome.app/index.d.ts +11 -0
  22. package/dist/evasions/chrome.app/index.d.ts.map +1 -0
  23. package/dist/evasions/chrome.app/index.js +97 -0
  24. package/dist/evasions/chrome.app/index.js.map +1 -0
  25. package/dist/evasions/chrome.app/package.json +5 -0
  26. package/dist/evasions/chrome.csi/README.md +29 -0
  27. package/dist/evasions/chrome.csi/index.d.ts +25 -0
  28. package/dist/evasions/chrome.csi/index.d.ts.map +1 -0
  29. package/dist/evasions/chrome.csi/index.js +69 -0
  30. package/dist/evasions/chrome.csi/index.js.map +1 -0
  31. package/dist/evasions/chrome.csi/package.json +5 -0
  32. package/dist/evasions/chrome.loadTimes/README.md +27 -0
  33. package/dist/evasions/chrome.loadTimes/index.d.ts +23 -0
  34. package/dist/evasions/chrome.loadTimes/index.d.ts.map +1 -0
  35. package/dist/evasions/chrome.loadTimes/index.js +163 -0
  36. package/dist/evasions/chrome.loadTimes/index.js.map +1 -0
  37. package/dist/evasions/chrome.loadTimes/package.json +5 -0
  38. package/dist/evasions/chrome.runtime/README.md +32 -0
  39. package/dist/evasions/chrome.runtime/index.d.ts +14 -0
  40. package/dist/evasions/chrome.runtime/index.d.ts.map +1 -0
  41. package/dist/evasions/chrome.runtime/index.js +252 -0
  42. package/dist/evasions/chrome.runtime/index.js.map +1 -0
  43. package/dist/evasions/chrome.runtime/package.json +5 -0
  44. package/dist/evasions/chrome.runtime/staticData.json +41 -0
  45. package/dist/evasions/defaultArgs/README.md +17 -0
  46. package/dist/evasions/defaultArgs/index.d.ts +2 -0
  47. package/dist/evasions/defaultArgs/index.d.ts.map +1 -0
  48. package/dist/evasions/defaultArgs/index.js +43 -0
  49. package/dist/evasions/defaultArgs/index.js.map +1 -0
  50. package/dist/evasions/defaultArgs/package.json +5 -0
  51. package/dist/evasions/iframe.contentWindow/README.md +19 -0
  52. package/dist/evasions/iframe.contentWindow/index.d.ts +15 -0
  53. package/dist/evasions/iframe.contentWindow/index.d.ts.map +1 -0
  54. package/dist/evasions/iframe.contentWindow/index.js +132 -0
  55. package/dist/evasions/iframe.contentWindow/index.js.map +1 -0
  56. package/dist/evasions/iframe.contentWindow/package.json +5 -0
  57. package/dist/evasions/media.codecs/README.md +38 -0
  58. package/dist/evasions/media.codecs/index.d.ts +12 -0
  59. package/dist/evasions/media.codecs/index.d.ts.map +1 -0
  60. package/dist/evasions/media.codecs/index.js +89 -0
  61. package/dist/evasions/media.codecs/index.js.map +1 -0
  62. package/dist/evasions/media.codecs/package.json +5 -0
  63. package/dist/evasions/navigator.hardwareConcurrency/README.md +19 -0
  64. package/dist/evasions/navigator.hardwareConcurrency/index.d.ts +2 -0
  65. package/dist/evasions/navigator.hardwareConcurrency/index.d.ts.map +1 -0
  66. package/dist/evasions/navigator.hardwareConcurrency/index.js +45 -0
  67. package/dist/evasions/navigator.hardwareConcurrency/index.js.map +1 -0
  68. package/dist/evasions/navigator.hardwareConcurrency/package.json +5 -0
  69. package/dist/evasions/navigator.languages/README.md +17 -0
  70. package/dist/evasions/navigator.languages/index.d.ts +2 -0
  71. package/dist/evasions/navigator.languages/index.d.ts.map +1 -0
  72. package/dist/evasions/navigator.languages/index.js +44 -0
  73. package/dist/evasions/navigator.languages/index.js.map +1 -0
  74. package/dist/evasions/navigator.languages/package.json +5 -0
  75. package/dist/evasions/navigator.permissions/README.md +16 -0
  76. package/dist/evasions/navigator.permissions/index.d.ts +2 -0
  77. package/dist/evasions/navigator.permissions/index.d.ts.map +1 -0
  78. package/dist/evasions/navigator.permissions/index.js +66 -0
  79. package/dist/evasions/navigator.permissions/index.js.map +1 -0
  80. package/dist/evasions/navigator.permissions/package.json +5 -0
  81. package/dist/evasions/navigator.plugins/README.md +24 -0
  82. package/dist/evasions/navigator.plugins/data.json +48 -0
  83. package/dist/evasions/navigator.plugins/functionMocks.d.ts +9 -0
  84. package/dist/evasions/navigator.plugins/functionMocks.d.ts.map +1 -0
  85. package/dist/evasions/navigator.plugins/functionMocks.js +47 -0
  86. package/dist/evasions/navigator.plugins/functionMocks.js.map +1 -0
  87. package/dist/evasions/navigator.plugins/index.d.ts +19 -0
  88. package/dist/evasions/navigator.plugins/index.d.ts.map +1 -0
  89. package/dist/evasions/navigator.plugins/index.js +98 -0
  90. package/dist/evasions/navigator.plugins/index.js.map +1 -0
  91. package/dist/evasions/navigator.plugins/magicArray.d.ts +2 -0
  92. package/dist/evasions/navigator.plugins/magicArray.d.ts.map +1 -0
  93. package/dist/evasions/navigator.plugins/magicArray.js +145 -0
  94. package/dist/evasions/navigator.plugins/magicArray.js.map +1 -0
  95. package/dist/evasions/navigator.plugins/mimeTypes.d.ts +2 -0
  96. package/dist/evasions/navigator.plugins/mimeTypes.d.ts.map +1 -0
  97. package/dist/evasions/navigator.plugins/mimeTypes.js +18 -0
  98. package/dist/evasions/navigator.plugins/mimeTypes.js.map +1 -0
  99. package/dist/evasions/navigator.plugins/package.json +5 -0
  100. package/dist/evasions/navigator.plugins/plugins.d.ts +2 -0
  101. package/dist/evasions/navigator.plugins/plugins.d.ts.map +1 -0
  102. package/dist/evasions/navigator.plugins/plugins.js +18 -0
  103. package/dist/evasions/navigator.plugins/plugins.js.map +1 -0
  104. package/dist/evasions/navigator.vendor/README.md +36 -0
  105. package/dist/evasions/navigator.vendor/index.d.ts +2 -0
  106. package/dist/evasions/navigator.vendor/index.d.ts.map +1 -0
  107. package/dist/evasions/navigator.vendor/index.js +64 -0
  108. package/dist/evasions/navigator.vendor/index.js.map +1 -0
  109. package/dist/evasions/navigator.vendor/package.json +5 -0
  110. package/dist/evasions/navigator.webdriver/README.md +17 -0
  111. package/dist/evasions/navigator.webdriver/index.d.ts +13 -0
  112. package/dist/evasions/navigator.webdriver/index.d.ts.map +1 -0
  113. package/dist/evasions/navigator.webdriver/index.js +48 -0
  114. package/dist/evasions/navigator.webdriver/index.js.map +1 -0
  115. package/dist/evasions/navigator.webdriver/package.json +5 -0
  116. package/dist/evasions/sourceurl/README.md +17 -0
  117. package/dist/evasions/sourceurl/_fixtures/test.html +35 -0
  118. package/dist/evasions/sourceurl/index.d.ts +12 -0
  119. package/dist/evasions/sourceurl/index.d.ts.map +1 -0
  120. package/dist/evasions/sourceurl/index.js +82 -0
  121. package/dist/evasions/sourceurl/index.js.map +1 -0
  122. package/dist/evasions/sourceurl/package.json +5 -0
  123. package/dist/evasions/user-agent-override/README.md +53 -0
  124. package/dist/evasions/user-agent-override/index.d.ts +2 -0
  125. package/dist/evasions/user-agent-override/index.d.ts.map +1 -0
  126. package/dist/evasions/user-agent-override/index.js +206 -0
  127. package/dist/evasions/user-agent-override/index.js.map +1 -0
  128. package/dist/evasions/user-agent-override/package.json +5 -0
  129. package/dist/evasions/webgl.vendor/README.md +20 -0
  130. package/dist/evasions/webgl.vendor/index.d.ts +17 -0
  131. package/dist/evasions/webgl.vendor/index.d.ts.map +1 -0
  132. package/dist/evasions/webgl.vendor/index.js +57 -0
  133. package/dist/evasions/webgl.vendor/index.js.map +1 -0
  134. package/dist/evasions/webgl.vendor/package.json +5 -0
  135. package/dist/evasions/window.outerdimensions/README.md +17 -0
  136. package/dist/evasions/window.outerdimensions/index.d.ts +13 -0
  137. package/dist/evasions/window.outerdimensions/index.d.ts.map +1 -0
  138. package/dist/evasions/window.outerdimensions/index.js +42 -0
  139. package/dist/evasions/window.outerdimensions/index.js.map +1 -0
  140. package/dist/evasions/window.outerdimensions/package.json +5 -0
  141. package/dist/index.d.ts +130 -0
  142. package/dist/index.d.ts.map +1 -0
  143. package/dist/index.js +164 -0
  144. package/dist/index.js.map +1 -0
  145. package/examples/detect-headless.js +95 -0
  146. package/examples/test1.js +20 -0
  147. package/examples/test2.js +25 -0
  148. package/package.json +70 -0
  149. package/src/evasions/README.md +13 -0
  150. package/src/evasions/_template/README.md +18 -0
  151. package/src/evasions/_template/index.js +26 -0
  152. package/src/evasions/_template/package.json +5 -0
  153. package/src/evasions/_utils/README.md +287 -0
  154. package/src/evasions/_utils/index.js +588 -0
  155. package/src/evasions/_utils/withUtils.js +47 -0
  156. package/src/evasions/chrome.app/README.md +16 -0
  157. package/src/evasions/chrome.app/index.js +97 -0
  158. package/src/evasions/chrome.app/package.json +5 -0
  159. package/src/evasions/chrome.csi/README.md +29 -0
  160. package/src/evasions/chrome.csi/index.js +69 -0
  161. package/src/evasions/chrome.csi/package.json +5 -0
  162. package/src/evasions/chrome.loadTimes/README.md +27 -0
  163. package/src/evasions/chrome.loadTimes/index.js +163 -0
  164. package/src/evasions/chrome.loadTimes/package.json +5 -0
  165. package/src/evasions/chrome.runtime/README.md +32 -0
  166. package/src/evasions/chrome.runtime/index.js +252 -0
  167. package/src/evasions/chrome.runtime/package.json +5 -0
  168. package/src/evasions/chrome.runtime/staticData.json +41 -0
  169. package/src/evasions/defaultArgs/README.md +17 -0
  170. package/src/evasions/defaultArgs/index.js +43 -0
  171. package/src/evasions/defaultArgs/package.json +5 -0
  172. package/src/evasions/iframe.contentWindow/README.md +19 -0
  173. package/src/evasions/iframe.contentWindow/index.js +132 -0
  174. package/src/evasions/iframe.contentWindow/package.json +5 -0
  175. package/src/evasions/media.codecs/README.md +38 -0
  176. package/src/evasions/media.codecs/index.js +89 -0
  177. package/src/evasions/media.codecs/package.json +5 -0
  178. package/src/evasions/navigator.hardwareConcurrency/README.md +19 -0
  179. package/src/evasions/navigator.hardwareConcurrency/index.js +45 -0
  180. package/src/evasions/navigator.hardwareConcurrency/package.json +5 -0
  181. package/src/evasions/navigator.languages/README.md +17 -0
  182. package/src/evasions/navigator.languages/index.js +44 -0
  183. package/src/evasions/navigator.languages/package.json +5 -0
  184. package/src/evasions/navigator.permissions/README.md +16 -0
  185. package/src/evasions/navigator.permissions/index.js +66 -0
  186. package/src/evasions/navigator.permissions/package.json +5 -0
  187. package/src/evasions/navigator.plugins/README.md +24 -0
  188. package/src/evasions/navigator.plugins/data.json +48 -0
  189. package/src/evasions/navigator.plugins/functionMocks.js +47 -0
  190. package/src/evasions/navigator.plugins/index.js +98 -0
  191. package/src/evasions/navigator.plugins/magicArray.js +145 -0
  192. package/src/evasions/navigator.plugins/mimeTypes.js +18 -0
  193. package/src/evasions/navigator.plugins/package.json +5 -0
  194. package/src/evasions/navigator.plugins/plugins.js +18 -0
  195. package/src/evasions/navigator.vendor/README.md +36 -0
  196. package/src/evasions/navigator.vendor/index.js +64 -0
  197. package/src/evasions/navigator.vendor/package.json +5 -0
  198. package/src/evasions/navigator.webdriver/README.md +17 -0
  199. package/src/evasions/navigator.webdriver/index.js +48 -0
  200. package/src/evasions/navigator.webdriver/package.json +5 -0
  201. package/src/evasions/sourceurl/README.md +17 -0
  202. package/src/evasions/sourceurl/_fixtures/test.html +35 -0
  203. package/src/evasions/sourceurl/index.js +82 -0
  204. package/src/evasions/sourceurl/package.json +5 -0
  205. package/src/evasions/user-agent-override/README.md +53 -0
  206. package/src/evasions/user-agent-override/index.js +206 -0
  207. package/src/evasions/user-agent-override/package.json +5 -0
  208. package/src/evasions/webgl.vendor/README.md +20 -0
  209. package/src/evasions/webgl.vendor/index.js +57 -0
  210. package/src/evasions/webgl.vendor/package.json +5 -0
  211. package/src/evasions/window.outerdimensions/README.md +17 -0
  212. package/src/evasions/window.outerdimensions/index.js +42 -0
  213. package/src/evasions/window.outerdimensions/package.json +5 -0
  214. package/src/index.d.ts +111 -0
  215. package/src/index.ts +188 -0
  216. package/test/cat-and-mouse.test.ts +170 -0
  217. package/test/evasions/_utils/index.test.ts +710 -0
  218. package/test/evasions/chrome.app/index.test.ts +69 -0
  219. package/test/evasions/chrome.csi/index.test.ts +46 -0
  220. package/test/evasions/chrome.loadTimes/index.test.ts +61 -0
  221. package/test/evasions/chrome.runtime/index.test.ts +282 -0
  222. package/test/evasions/defaultArgs/index.test.ts +36 -0
  223. package/test/evasions/iframe.contentWindow/index.test.js +450 -0
  224. package/test/evasions/media.codecs/index.test.js +103 -0
  225. package/test/evasions/navigator.hardwareConcurrency/index.test.js +58 -0
  226. package/test/evasions/navigator.languages/index.test.js +101 -0
  227. package/test/evasions/navigator.permissions/index.test.js +104 -0
  228. package/test/evasions/navigator.plugins/index.test.js +55 -0
  229. package/test/evasions/navigator.plugins/mimeTypes.test.js +220 -0
  230. package/test/evasions/navigator.plugins/plugins.test.js +181 -0
  231. package/test/evasions/navigator.vendor/index.test.js +68 -0
  232. package/test/evasions/navigator.webdriver/index.test.js +47 -0
  233. package/test/evasions/sourceurl/_fixtures/test.html +35 -0
  234. package/test/evasions/sourceurl/index.test.js +62 -0
  235. package/test/evasions/user-agent-override/index.test.js +338 -0
  236. package/test/evasions/webgl.vendor/index.test.js +220 -0
  237. package/test/fixtures/dummy-with-service-worker.html +22 -0
  238. package/test/fixtures/dummy.html +11 -0
  239. package/test/fixtures/sw.js +1 -0
  240. package/test/fpscanner.test.ts +54 -0
  241. package/test/index.test.ts +51 -0
  242. package/test/service-worker.test.ts +112 -0
  243. package/test/stealth/_results/_thumbs/headful-chrome-stealth.js.png +0 -0
  244. package/test/stealth/_results/_thumbs/headful-chrome-vanilla.js.png +0 -0
  245. package/test/stealth/_results/_thumbs/headful-chromium-stealth.js.png +0 -0
  246. package/test/stealth/_results/_thumbs/headful-chromium-vanilla.js.png +0 -0
  247. package/test/stealth/_results/_thumbs/headless-chrome-stealth.js.png +0 -0
  248. package/test/stealth/_results/_thumbs/headless-chrome-vanilla.js.png +0 -0
  249. package/test/stealth/_results/_thumbs/headless-chromium-stealth.js.png +0 -0
  250. package/test/stealth/_results/_thumbs/headless-chromium-vanilla.js.png +0 -0
  251. package/test/stealth/_results/headful-chrome-stealth.js.png +0 -0
  252. package/test/stealth/_results/headful-chrome-vanilla.js.png +0 -0
  253. package/test/stealth/_results/headful-chromium-stealth.js.png +0 -0
  254. package/test/stealth/_results/headful-chromium-vanilla.js.png +0 -0
  255. package/test/stealth/_results/headless-chrome-stealth.js.png +0 -0
  256. package/test/stealth/_results/headless-chrome-vanilla.js.png +0 -0
  257. package/test/stealth/_results/headless-chromium-stealth.js.png +0 -0
  258. package/test/stealth/_results/headless-chromium-vanilla.js.png +0 -0
  259. package/test/stealth/headful-chrome-stealth.js +25 -0
  260. package/test/stealth/headful-chrome-vanilla.js +23 -0
  261. package/test/stealth/headful-chromium-stealth.js +22 -0
  262. package/test/stealth/headful-chromium-vanilla.js +20 -0
  263. package/test/stealth/headless-chrome-stealth.js +25 -0
  264. package/test/stealth/headless-chrome-vanilla.js +23 -0
  265. package/test/stealth/headless-chromium-stealth.js +22 -0
  266. package/test/stealth/headless-chromium-vanilla.js +20 -0
  267. package/test/util.js +82 -0
  268. package/tsconfig.json +10 -0
  269. package/tsconfig.tsbuildinfo +1 -0
  270. package/vitest.config.ts +28 -0
@@ -0,0 +1,21 @@
1
+ {
2
+ "permissions": {
3
+ "allow": [
4
+ "Bash(pnpm outdated:*)",
5
+ "Bash(pnpm update:*)",
6
+ "Bash(pnpm build:*)",
7
+ "Bash(pnpm add:*)",
8
+ "Bash(pnpm test:*)",
9
+ "Bash(find:*)",
10
+ "Bash(grep:*)",
11
+ "Bash(npm run build:*)",
12
+ "Bash(npx puppeteer:*)",
13
+ "Bash(pnpm vitest run:*)",
14
+ "Bash(pnpm list:*)",
15
+ "Bash(pnpm install:*)",
16
+ "Bash(ls:*)",
17
+ "Bash(pnpm --filter @zorilla/puppeteer-extra-plugin-stealth install:*)",
18
+ "Bash(npm test:*)"
19
+ ]
20
+ }
21
+ }
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2019 berstend <github@berstend.com>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,324 @@
1
+ # puppeteer-extra-plugin-stealth [![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/zorillajs/zorilla/test.yml?branch=master&event=push) [![Discord](https://img.shields.io/discord/737009125862408274)](https://extra.community) [![npm](https://img.shields.io/npm/v/puppeteer-extra-plugin-stealth.svg)](https://www.npmjs.com/package/puppeteer-extra-plugin-stealth)
2
+
3
+ > A plugin for [puppeteer-extra](https://github.com/zorillajs/zorilla/tree/master/packages/puppeteer-extra) and [playwright-extra](https://github.com/zorillajs/zorilla/tree/master/packages/playwright-extra) to prevent detection.
4
+
5
+ <p align="center"><img src="https://i.imgur.com/q2xBjqH.png" /></p>
6
+
7
+ ## Install
8
+
9
+ ```bash
10
+ npm install @zorilla/puppeteer-extra-plugin-stealth
11
+ ```
12
+
13
+ If this is your first [puppeteer-extra](https://github.com/zorillajs/zorilla) plugin here's everything you need:
14
+
15
+ ```bash
16
+ npm install puppeteer @zorilla/puppeteer-extra @zorilla/puppeteer-extra-plugin-stealth
17
+ ```
18
+
19
+ ## Usage
20
+
21
+ ```js
22
+ // puppeteer-extra is a drop-in replacement for puppeteer,
23
+ // it augments the installed puppeteer with plugin functionality
24
+ const puppeteer = require('@zorilla/puppeteer-extra')
25
+
26
+ // add stealth plugin and use defaults (all evasion techniques)
27
+ const StealthPlugin = require('@zorilla/puppeteer-extra-plugin-stealth')
28
+ puppeteer.use(StealthPlugin())
29
+
30
+ // puppeteer usage as normal
31
+ puppeteer.launch({ headless: true }).then(async browser => {
32
+ console.log('Running tests..')
33
+ const page = await browser.newPage()
34
+ await page.goto('https://bot.sannysoft.com')
35
+ await page.waitForTimeout(5000)
36
+ await page.screenshot({ path: 'testresult.png', fullPage: true })
37
+ await browser.close()
38
+ console.log(`All done, check the screenshot. ✨`)
39
+ })
40
+ ```
41
+
42
+ <details>
43
+ <summary><strong>TypeScript usage</strong></summary><br/>
44
+
45
+ > `puppeteer-extra` and most plugins are written in TS,
46
+ > so you get perfect type support out of the box. :)
47
+
48
+ ```ts
49
+ import puppeteer from '@zorilla/puppeteer-extra'
50
+ import StealthPlugin from '@zorilla/puppeteer-extra-plugin-stealth'
51
+
52
+ puppeteer
53
+ .use(StealthPlugin())
54
+ .launch({ headless: true })
55
+ .then(async browser => {
56
+ const page = await browser.newPage()
57
+ await page.goto('https://bot.sannysoft.com')
58
+ await page.waitForTimeout(5000)
59
+ await page.screenshot({ path: 'stealth.png', fullPage: true })
60
+ await browser.close()
61
+ })
62
+ ```
63
+
64
+ > Please check this [wiki](https://github.com/zorillajs/zorilla/wiki/TypeScript-usage) entry in case you have TypeScript related import issues.
65
+
66
+ </details><br>
67
+
68
+ > Please check out the [puppeteer-extra package](https://github.com/zorillajs/zorilla/tree/master/packages/puppeteer-extra) to learn more about `puppeteer-extra` (Firefox usage, other Plugins, etc).
69
+
70
+ ## Status
71
+
72
+ - ✅ **`puppeteer-extra` with stealth passes all public bot tests.**
73
+
74
+ Please note: I consider this a friendly competition in a rather interesting cat and mouse game. If the other team (👋) wants to detect headless chromium there are still ways to do that (at least I noticed a few, which I'll tackle in future updates).
75
+
76
+ It's probably impossible to prevent all ways to detect headless chromium, but it should be possible to make it so difficult that it becomes cost-prohibitive or triggers too many false-positives to be feasible.
77
+
78
+ If something new comes up or you experience a problem, please do your homework and create a PR in a respectful way (this is Github, not reddit) or I might not be motivated to help. :)
79
+
80
+ ## Changelog
81
+
82
+ > 🎁 **Note:** Until we've automated changelog updates in markdown files please follow the `#announcements` channel in our [discord server](https://discord.gg/vz7PeKk) for the latest updates and changelog info.
83
+
84
+ _Older changelog:_
85
+
86
+ #### `v2.4.7`
87
+
88
+ - New: `user-agent-override` - Used to set a stealthy UA string, language & platform. This also fixes issues with the prior method of setting the `Accept-Language` header through request interception ([#104](https://github.com/zorillajs/zorilla/pull/104), kudos to [@Niek](https://github.com/Niek))
89
+ - New: `navigator.vendor` - Makes it possible to optionally override navigator.vendor ([#110](https://github.com/zorillajs/zorilla/pull/110), thanks [@Niek](https://github.com/Niek))
90
+ - Improved: `navigator.webdriver`: Now uses ES6 Proxies to pass `instanceof` tests ([#117](https://github.com/zorillajs/zorilla/pull/117), thanks [@aabbccsmith](https://github.com/aabbccsmith))
91
+ - Removed: `user-agent`, `accept-language` (now obsolete)
92
+
93
+ #### `v2.4.2` / `v2.4.1`
94
+
95
+ - Improved: `iframe.contentWindow` - We now proxy the original window object and smartly redirect calls that might reveal it's true identity, as opposed to mocking it like peasants :)
96
+ - Improved: `accept-language` - More robust and it's now possible to [set a custom locale](https://github.com/zorillajs/zorilla/tree/master/packages/puppeteer-extra-plugin-stealth/evasions/accept-language#readme) if needed.
97
+ - ⭐️ Passes the [headless-cat-n-mouse](https://github.com/paulirish/headless-cat-n-mouse) test
98
+
99
+ #### `v2.4.0`
100
+
101
+ Let's ring the bell for round 2 in this cat and mouse fight 😄
102
+
103
+ - New: All evasions now have a specific before and after test to make make this whole topic less voodoo
104
+ - New: `media.codecs` - we spoof the presence of proprietary codecs in Chromium now
105
+ - New & improved: `iframe.contentWindow` - Found a way to fix `srcdoc` frame based detection without breaking recaptcha inline popup & other iframes (please report any issues)
106
+ - New: `accept-language` - Adds a missing `Accept-Language` header in headless (capitalized correctly, `page.setExtraHTTPHeaders` is all lowercase which can be detected)
107
+ - Improved: `chrome.runtime` - More extensive mocking of the chrome object
108
+ - ⭐️ All [fpscanner](https://antoinevastel.com/bots/) tests are now green, as well as all [intoli](https://bot.sannysoft.com) tests and the [`areyouheadless`](https://arh.antoinevastel.com/bots/areyouheadless) test
109
+
110
+ <details>
111
+ <summary><code>v2.1.2</code></summary><br/>
112
+
113
+ - Improved: `navigator.plugins` - we fully emulate plugins/mimetypes in headless now 🎉
114
+ - New: `webgl.vendor` - is otherwise set to "Google" in headless
115
+ - New: `window.outerdimensions` - fix missing window.outerWidth/outerHeight and viewport
116
+ - Fixed: `navigator.webdriver` now returns undefined instead of false
117
+
118
+ </details>
119
+
120
+ ## Test results (red is bad)
121
+
122
+ #### Vanilla puppeteer <strong>without stealth 😢</strong>
123
+
124
+ <table class="image">
125
+ <tr>
126
+
127
+ <td><figure class="image"><a href="./stealthtests/_results/headless-chromium-vanilla.js.png"><img src="./stealthtests/_results/_thumbs/headless-chromium-vanilla.js.png"></a><figcaption>Chromium + headless</figcaption></figure></td>
128
+ <td><figure class="image"><a href="./stealthtests/_results/headful-chromium-vanilla.js.png"><img src="./stealthtests/_results/_thumbs/headful-chromium-vanilla.js.png"></a><figcaption>Chromium + headful</figcaption></figure></td>
129
+ <td><figure class="image"><a href="./stealthtests/_results/headless-chrome-vanilla.js.png"><img src="./stealthtests/_results/_thumbs/headless-chrome-vanilla.js.png"></a><figcaption>Chrome + headless</figcaption></figure></td>
130
+ <td><figure class="image"><a href="./stealthtests/_results/headful-chrome-vanilla.js.png"><img src="./stealthtests/_results/_thumbs/headful-chrome-vanilla.js.png"></a><figcaption>Chrome + headful</figcaption></figure></td>
131
+
132
+ </tr>
133
+ </table>
134
+
135
+ #### Puppeteer <strong>with stealth plugin 💯</strong>
136
+
137
+ <table class="image">
138
+ <tr>
139
+
140
+ <td><figure class="image"><a href="./stealthtests/_results/headless-chromium-stealth.js.png"><img src="./stealthtests/_results/_thumbs/headless-chromium-stealth.js.png"></a><figcaption>Chromium + headless</figcaption></figure></td>
141
+ <td><figure class="image"><a href="./stealthtests/_results/headful-chromium-stealth.js.png"><img src="./stealthtests/_results/_thumbs/headful-chromium-stealth.js.png"></a><figcaption>Chromium + headful</figcaption></figure></td>
142
+ <td><figure class="image"><a href="./stealthtests/_results/headless-chrome-stealth.js.png"><img src="./stealthtests/_results/_thumbs/headless-chrome-stealth.js.png"></a><figcaption>Chrome + headless</figcaption></figure></td>
143
+ <td><figure class="image"><a href="./stealthtests/_results/headful-chrome-stealth.js.png"><img src="./stealthtests/_results/_thumbs/headful-chrome-stealth.js.png"></a><figcaption>Chrome + headful</figcaption></figure></td>
144
+
145
+ </tr>
146
+ </table>
147
+
148
+ > Note: The `MQ_SCREEN` test is broken on their page (will fail in regular Chrome as well).
149
+
150
+ Tests have been done using [this test site](https://bot.sannysoft.com/) and [these scripts](./stealthtests/).
151
+
152
+ #### Improved reCAPTCHA v3 scores
153
+
154
+ Using stealth also seems to help with maintaining a normal [reCAPTCHA v3 score](https://developers.google.com/recaptcha/docs/v3#score).
155
+
156
+ <table class="image">
157
+ <tr>
158
+
159
+ <td><figure class="image"><figcaption><code>Regular Puppeteer</code></figcaption><br/><img src="https://i.imgur.com/rHEH69b.png"></figure></td>
160
+ <td><figure class="image"><figcaption><code>Stealth Puppeteer</code></figcaption><br/><img src="https://i.imgur.com/2if496Z.png"></figure></td>
161
+
162
+ </tr>
163
+ </table>
164
+
165
+ Note: The [official test](https://recaptcha-demo.appspot.com/recaptcha-v3-request-scores.php) is to be taken with a grain of salt, as the score is calculated individually per site and multiple other factors (past behaviour, IP address, etc). Based on anecdotal observations it still seems to work as a rough indicator.
166
+
167
+ _**Tip:** Have a look at the [recaptcha plugin](https://github.com/zorillajs/zorilla/tree/master/packages/puppeteer-extra-plugin-recaptcha) if you have issues with reCAPTCHAs._
168
+
169
+ ## API
170
+
171
+
172
+ #### Table of Contents
173
+
174
+ - [puppeteer-extra-plugin-stealth \[ ](#puppeteer-extra-plugin-stealth---)
175
+ - [Install](#install)
176
+ - [Usage](#usage)
177
+ - [Status](#status)
178
+ - [Changelog](#changelog)
179
+ - [`v2.4.7`](#v247)
180
+ - [`v2.4.2` / `v2.4.1`](#v242--v241)
181
+ - [`v2.4.0`](#v240)
182
+ - [Test results (red is bad)](#test-results-red-is-bad)
183
+ - [Vanilla puppeteer without stealth 😢](#vanilla-puppeteer-without-stealth-)
184
+ - [Puppeteer with stealth plugin 💯](#puppeteer-with-stealth-plugin-)
185
+ - [Improved reCAPTCHA v3 scores](#improved-recaptcha-v3-scores)
186
+ - [API](#api)
187
+ - [Table of Contents](#table-of-contents)
188
+ - [class: StealthPlugin](#class-stealthplugin)
189
+ - [Purpose](#purpose)
190
+ - [Modularity](#modularity)
191
+ - [Contributing](#contributing)
192
+ - [Kudos](#kudos)
193
+ - [.availableEvasions](#availableevasions)
194
+ - [.enabledEvasions](#enabledevasions)
195
+ - [defaultExport(opts?)](#defaultexportopts)
196
+ - [License](#license)
197
+
198
+ ### class: [StealthPlugin](https://github.com/zorillajs/zorilla/blob/e6133619b051febed630ada35241664eba59b9fa/packages/puppeteer-extra-plugin-stealth/index.js#L72-L162)
199
+
200
+ - `opts` **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)?** Options (optional, default `{}`)
201
+ - `opts.enabledEvasions` **[Set](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Set)&lt;[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)>?** Specify which evasions to use (by default all)
202
+
203
+ **Extends: PuppeteerExtraPlugin**
204
+
205
+ Stealth mode: Applies various techniques to make detection of headless puppeteer harder. 💯
206
+
207
+ #### Purpose
208
+
209
+ There are a couple of ways the use of puppeteer can easily be detected by a target website.
210
+ The addition of `HeadlessChrome` to the user-agent being only the most obvious one.
211
+
212
+ The goal of this plugin is to be the definite companion to puppeteer to avoid
213
+ detection, applying new techniques as they surface.
214
+
215
+ As this cat & mouse game is in it's infancy and fast-paced the plugin
216
+ is kept as flexibile as possible, to support quick testing and iterations.
217
+
218
+ #### Modularity
219
+
220
+ This plugin uses `puppeteer-extra`'s dependency system to only require
221
+ code mods for evasions that have been enabled, to keep things modular and efficient.
222
+
223
+ The `stealth` plugin is a convenience wrapper that requires multiple [evasion techniques](./evasions/)
224
+ automatically and comes with defaults. You could also bypass the main module and require
225
+ specific evasion plugins yourself, if you whish to do so (as they're standalone `puppeteer-extra` plugins):
226
+
227
+ ```es6
228
+ // bypass main module and require a specific stealth plugin directly:
229
+ puppeteer.use(
230
+ require('@zorilla/puppeteer-extra-plugin-stealth/evasions/console.debug')()
231
+ )
232
+ ```
233
+
234
+ #### Contributing
235
+
236
+ PRs are welcome, if you want to add a new evasion technique I suggest you
237
+ look at the [template](./evasions/_template) to kickstart things.
238
+
239
+ #### Kudos
240
+
241
+ Thanks to [Evan Sangaline](https://intoli.com/blog/not-possible-to-block-chrome-headless/) and [Paul Irish](https://github.com/paulirish/headless-cat-n-mouse) for kickstarting the discussion!
242
+
243
+ ---
244
+
245
+ Example:
246
+
247
+ ```javascript
248
+ const puppeteer = require('@zorilla/puppeteer-extra')
249
+ // Enable stealth plugin with all evasions
250
+ puppeteer.use(require('@zorilla/puppeteer-extra-plugin-stealth')())
251
+ ;(async () => {
252
+ // Launch the browser in headless mode and set up a page.
253
+ const browser = await puppeteer.launch({
254
+ args: ['--no-sandbox'],
255
+ headless: true
256
+ })
257
+ const page = await browser.newPage()
258
+
259
+ // Navigate to the page that will perform the tests.
260
+ const testUrl =
261
+ 'https://intoli.com/blog/' +
262
+ 'not-possible-to-block-chrome-headless/chrome-headless-test.html'
263
+ await page.goto(testUrl)
264
+
265
+ // Save a screenshot of the results.
266
+ const screenshotPath = '/tmp/headless-test-result.png'
267
+ await page.screenshot({ path: screenshotPath })
268
+ console.log('have a look at the screenshot:', screenshotPath)
269
+
270
+ await browser.close()
271
+ })()
272
+ ```
273
+
274
+ ---
275
+
276
+ #### .[availableEvasions](https://github.com/zorillajs/zorilla/blob/e6133619b051febed630ada35241664eba59b9fa/packages/puppeteer-extra-plugin-stealth/index.js#L128-L130)
277
+
278
+ Type: **[Set](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Set)&lt;[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)>**
279
+
280
+ Get all available evasions.
281
+
282
+ Please look into the [evasions directory](./evasions/) for an up to date list.
283
+
284
+ Example:
285
+
286
+ ```javascript
287
+ const pluginStealth = require('@zorilla/puppeteer-extra-plugin-stealth')()
288
+ console.log(pluginStealth.availableEvasions) // => Set { 'user-agent', 'console.debug' }
289
+ puppeteer.use(pluginStealth)
290
+ ```
291
+
292
+ ---
293
+
294
+ #### .[enabledEvasions](https://github.com/zorillajs/zorilla/blob/e6133619b051febed630ada35241664eba59b9fa/packages/puppeteer-extra-plugin-stealth/index.js#L145-L147)
295
+
296
+ Type: **[Set](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Set)&lt;[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)>**
297
+
298
+ Get all enabled evasions.
299
+
300
+ Enabled evasions can be configured either through `opts` or by modifying this property.
301
+
302
+ Example:
303
+
304
+ ```javascript
305
+ // Remove specific evasion from enabled ones dynamically
306
+ const pluginStealth = require('@zorilla/puppeteer-extra-plugin-stealth')()
307
+ pluginStealth.enabledEvasions.delete('console.debug')
308
+ puppeteer.use(pluginStealth)
309
+ ```
310
+
311
+ ---
312
+
313
+ ### [defaultExport(opts?)](https://github.com/zorillajs/zorilla/blob/e6133619b051febed630ada35241664eba59b9fa/packages/puppeteer-extra-plugin-stealth/index.js#L170-L170)
314
+
315
+ - `opts` **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)?** Options
316
+ - `opts.enabledEvasions` **[Set](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Set)&lt;[string](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)>?** Specify which evasions to use (by default all)
317
+
318
+ Default export, PuppeteerExtraStealthPlugin
319
+
320
+ ---
321
+
322
+ ## License
323
+
324
+ Copyright © 2018 - 2023, [berstend̡̲̫̹̠̖͚͓̔̄̓̐̄͛̀͘](mailto:github@berstend.com?subject=[GitHub]%20PuppeteerExtra). Released under the MIT License.
@@ -0,0 +1,13 @@
1
+ # puppeteer-extra-plugin-stealth/evasions
2
+
3
+ Various detection evasion plugins for `puppeteer-extra-plugin-stealth`.
4
+
5
+ You can bypass the main module and require specific evasion plugins yourself, if you wish to do so:
6
+
7
+ ```es6
8
+ puppeteer.use(
9
+ require('@zorilla/puppeteer-extra-plugin-stealth/evasions/console.debug')()
10
+ )
11
+ ```
12
+
13
+ If you want to add a new evasion technique I suggest you look at the [template](./_template/) to kickstart things.
@@ -0,0 +1,18 @@
1
+ ## API
2
+
3
+
4
+ #### Table of Contents
5
+
6
+ - [class: Plugin](#class-plugin)
7
+
8
+ ### class: [Plugin](https://github.com/zorillajs/zorilla/blob/e6133619b051febed630ada35241664eba59b9fa/packages/puppeteer-extra-plugin-stealth/evasions/_template/index.js#L10-L24)
9
+
10
+ - `opts` (optional, default `{}`)
11
+
12
+ **Extends: PuppeteerExtraPlugin**
13
+
14
+ Minimal stealth plugin template, not being used. :-)
15
+
16
+ Feel free to copy this folder as the basis for additional detection evasion plugins.
17
+
18
+ ---
@@ -0,0 +1,13 @@
1
+ export default function _default(pluginConfig: any): Plugin;
2
+ /**
3
+ * Minimal stealth plugin template, not being used. :-)
4
+ *
5
+ * Feel free to copy this folder as the basis for additional detection evasion plugins.
6
+ */
7
+ declare class Plugin extends PuppeteerExtraPlugin {
8
+ constructor(opts?: {});
9
+ onPageCreated(page: any): Promise<void>;
10
+ }
11
+ import { PuppeteerExtraPlugin } from '@zorilla/puppeteer-extra-plugin';
12
+ export {};
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/evasions/_template/index.js"],"names":[],"mappings":"AAuBA,4DAEC;AAvBD;;;;GAIG;AACH;IACE,uBAEC;IAMD,wCAIC;CACF;qCArBoC,iCAAiC"}
@@ -0,0 +1,26 @@
1
+ import { PuppeteerExtraPlugin } from '@zorilla/puppeteer-extra-plugin';
2
+
3
+ /**
4
+ * Minimal stealth plugin template, not being used. :-)
5
+ *
6
+ * Feel free to copy this folder as the basis for additional detection evasion plugins.
7
+ */
8
+ class Plugin extends PuppeteerExtraPlugin {
9
+ constructor(opts = {}) {
10
+ super(opts);
11
+ }
12
+
13
+ get name() {
14
+ return 'stealth/evasions/_template';
15
+ }
16
+
17
+ async onPageCreated(page) {
18
+ await page.evaluateOnNewDocument(() => {
19
+ console.debug('hello world');
20
+ });
21
+ }
22
+ }
23
+
24
+ export default function (pluginConfig) {
25
+ return new Plugin(pluginConfig);
26
+ }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/evasions/_template/index.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAEvE;;;;GAIG;AACH,MAAM,MAAO,SAAQ,oBAAoB;IACvC,YAAY,IAAI,GAAG,EAAE;QACnB,KAAK,CAAC,IAAI,CAAC,CAAC;IACd,CAAC;IAED,IAAI,IAAI;QACN,OAAO,4BAA4B,CAAC;IACtC,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,IAAI;QACtB,MAAM,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE;YACpC,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAED,MAAM,CAAC,OAAO,WAAW,YAAY;IACnC,OAAO,IAAI,MAAM,CAAC,YAAY,CAAC,CAAC;AAClC,CAAC"}
@@ -0,0 +1,5 @@
1
+ {
2
+ "private": true,
3
+ "type": "module",
4
+ "main": "index.js"
5
+ }