@browserless.io/browserless 2.38.0 → 2.38.2

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 (213) hide show
  1. package/CHANGELOG.md +26 -1
  2. package/build/browsers/index.js +12 -6
  3. package/build/routes/management/http/kill.get.js +2 -2
  4. package/build/shared/utils/function/handler.js +2 -2
  5. package/build/utils.d.ts +1 -0
  6. package/build/utils.js +1 -0
  7. package/build/utils.spec.d.ts +1 -0
  8. package/build/utils.spec.js +27 -0
  9. package/extensions/ublocklite/_locales/be/messages.json +5 -5
  10. package/extensions/ublocklite/_locales/id/messages.json +9 -9
  11. package/extensions/ublocklite/_locales/ja/messages.json +4 -4
  12. package/extensions/ublocklite/_locales/pt_PT/messages.json +1 -1
  13. package/extensions/ublocklite/_locales/th/messages.json +2 -2
  14. package/extensions/ublocklite/_locales/uk/messages.json +9 -9
  15. package/extensions/ublocklite/_locales/vi/messages.json +5 -5
  16. package/extensions/ublocklite/_locales/zh_CN/messages.json +8 -8
  17. package/extensions/ublocklite/js/jsonpath.js +2 -2
  18. package/extensions/ublocklite/js/static-filtering-parser.js +3 -1
  19. package/extensions/ublocklite/js/utils.js +1 -3
  20. package/extensions/ublocklite/manifest.json +1 -1
  21. package/extensions/ublocklite/rulesets/generic-details.json +2 -0
  22. package/extensions/ublocklite/rulesets/main/adguard-mobile.json +1 -2
  23. package/extensions/ublocklite/rulesets/main/adguard-spyware-url.json +7 -4
  24. package/extensions/ublocklite/rulesets/main/annoyances-cookies.json +2 -1
  25. package/extensions/ublocklite/rulesets/main/chn-0.json +23 -13
  26. package/extensions/ublocklite/rulesets/main/deu-0.json +2 -1
  27. package/extensions/ublocklite/rulesets/main/dpollock-0.json +1 -0
  28. package/extensions/ublocklite/rulesets/main/easylist.json +12 -4
  29. package/extensions/ublocklite/rulesets/main/easyprivacy.json +19 -6
  30. package/extensions/ublocklite/rulesets/main/fra-0.json +2 -2
  31. package/extensions/ublocklite/rulesets/main/hrv-0.json +6 -15
  32. package/extensions/ublocklite/rulesets/main/idn-0.json +6 -2
  33. package/extensions/ublocklite/rulesets/main/ind-0.json +27 -11
  34. package/extensions/ublocklite/rulesets/main/isr-0.json +1 -0
  35. package/extensions/ublocklite/rulesets/main/jpn-1.json +9 -4
  36. package/extensions/ublocklite/rulesets/main/kor-1.json +3 -2
  37. package/extensions/ublocklite/rulesets/main/nld-0.json +9 -7
  38. package/extensions/ublocklite/rulesets/main/nor-0.json +6 -3
  39. package/extensions/ublocklite/rulesets/main/pgl.json +10 -3
  40. package/extensions/ublocklite/rulesets/main/pol-0.json +2 -0
  41. package/extensions/ublocklite/rulesets/main/rus-0.json +11 -9
  42. package/extensions/ublocklite/rulesets/main/rus-1.json +2 -1
  43. package/extensions/ublocklite/rulesets/main/spa-1.json +2 -1
  44. package/extensions/ublocklite/rulesets/main/stevenblack-hosts.json +15646 -4853
  45. package/extensions/ublocklite/rulesets/main/swe-1.json +7 -9
  46. package/extensions/ublocklite/rulesets/main/tur-0.json +3 -4
  47. package/extensions/ublocklite/rulesets/main/ublock-badware.json +4 -7
  48. package/extensions/ublocklite/rulesets/main/ublock-filters.json +46 -21
  49. package/extensions/ublocklite/rulesets/main/ukr-0.json +3 -5
  50. package/extensions/ublocklite/rulesets/main/urlhaus-full.json +1554 -196
  51. package/extensions/ublocklite/rulesets/main/vie-1.json +26 -26
  52. package/extensions/ublocklite/rulesets/regex/chn-0.json +2 -2
  53. package/extensions/ublocklite/rulesets/regex/hrv-0.json +20 -0
  54. package/extensions/ublocklite/rulesets/regex/jpn-1.json +1 -1
  55. package/extensions/ublocklite/rulesets/regex/ublock-filters.json +10 -9
  56. package/extensions/ublocklite/rulesets/ruleset-details.json +160 -160
  57. package/extensions/ublocklite/rulesets/scripting/generic/annoyances-notifications.js +1 -1
  58. package/extensions/ublocklite/rulesets/scripting/generic/chn-0.js +1 -1
  59. package/extensions/ublocklite/rulesets/scripting/generic/easylist.js +1 -1
  60. package/extensions/ublocklite/rulesets/scripting/generic/hrv-0.js +1 -1
  61. package/extensions/ublocklite/rulesets/scripting/generic/rus-0.js +1 -1
  62. package/extensions/ublocklite/rulesets/scripting/generic/spa-1.js +2 -2
  63. package/extensions/ublocklite/rulesets/scripting/generic/ublock-filters.js +3 -3
  64. package/extensions/ublocklite/rulesets/scripting/generic/vie-1.js +1 -1
  65. package/extensions/ublocklite/rulesets/scripting/generichigh/rus-0.css +1 -0
  66. package/extensions/ublocklite/rulesets/scripting/procedural/annoyances-cookies.js +1 -1
  67. package/extensions/ublocklite/rulesets/scripting/procedural/annoyances-overlays.js +2 -2
  68. package/extensions/ublocklite/rulesets/scripting/procedural/easylist.js +3 -3
  69. package/extensions/ublocklite/rulesets/scripting/procedural/hrv-0.js +3 -3
  70. package/extensions/ublocklite/rulesets/scripting/procedural/jpn-1.js +3 -3
  71. package/extensions/ublocklite/rulesets/scripting/procedural/rou-1.js +3 -3
  72. package/extensions/ublocklite/rulesets/scripting/procedural/rus-0.js +3 -3
  73. package/extensions/ublocklite/rulesets/scripting/procedural/swe-1.js +2 -2
  74. package/extensions/ublocklite/rulesets/scripting/procedural/tur-0.js +3 -3
  75. package/extensions/ublocklite/rulesets/scripting/procedural/ublock-filters.js +3 -3
  76. package/extensions/ublocklite/rulesets/scripting/procedural/vie-1.js +3 -3
  77. package/extensions/ublocklite/rulesets/scripting/scriptlet/adguard-mobile.abort-on-property-read.js +2 -2
  78. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.remove-node-text.js +1 -1
  79. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.set-cookie.js +2 -2
  80. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.trusted-click-element.js +3 -3
  81. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.trusted-set-cookie.js +2 -2
  82. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.addEventListener-defuser.js +1 -1
  83. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.prevent-fetch.js +10 -5
  84. package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.remove-node-text.js +2 -2
  85. package/extensions/ublocklite/rulesets/scripting/scriptlet/chn-0.abort-on-property-read.js +2 -2
  86. package/extensions/ublocklite/rulesets/scripting/scriptlet/chn-0.abort-on-stack-trace.js +2 -2
  87. package/extensions/ublocklite/rulesets/scripting/scriptlet/chn-0.prevent-fetch.js +10 -5
  88. package/extensions/ublocklite/rulesets/scripting/scriptlet/easyprivacy.prevent-fetch.js +10 -5
  89. package/extensions/ublocklite/rulesets/scripting/scriptlet/fin-0.set-constant.js +541 -0
  90. package/extensions/ublocklite/rulesets/scripting/scriptlet/fra-0.prevent-fetch.js +10 -5
  91. package/extensions/ublocklite/rulesets/scripting/scriptlet/hrv-0.set-constant.js +541 -0
  92. package/extensions/ublocklite/rulesets/scripting/scriptlet/idn-0.prevent-fetch.js +10 -5
  93. package/extensions/ublocklite/rulesets/scripting/scriptlet/irn-0.prevent-fetch.js +10 -5
  94. package/extensions/ublocklite/rulesets/scripting/scriptlet/isr-0.prevent-fetch.js +10 -5
  95. package/extensions/ublocklite/rulesets/scripting/scriptlet/jpn-1.prevent-fetch.js +10 -5
  96. package/extensions/ublocklite/rulesets/scripting/scriptlet/kor-1.json-prune-xhr-response.js +1 -1
  97. package/extensions/ublocklite/rulesets/scripting/scriptlet/kor-1.prevent-fetch.js +10 -5
  98. package/extensions/ublocklite/rulesets/scripting/scriptlet/nld-0.abort-current-script.js +2 -2
  99. package/extensions/ublocklite/rulesets/scripting/scriptlet/nld-0.prevent-fetch.js +11 -6
  100. package/extensions/ublocklite/rulesets/scripting/scriptlet/nld-0.xml-prune.js +1 -1
  101. package/extensions/ublocklite/rulesets/scripting/scriptlet/nor-0.prevent-fetch.js +10 -5
  102. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.abort-on-property-read.js +2 -2
  103. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.abort-on-stack-trace.js +1 -1
  104. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.addEventListener-defuser.js +3 -3
  105. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.href-sanitizer.js +2 -2
  106. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.prevent-fetch.js +10 -5
  107. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.remove-attr.js +2 -2
  108. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.remove-cookie.js +1 -1
  109. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.set-attr.js +1 -1
  110. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.set-constant.js +2 -2
  111. package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-1.prevent-fetch.js +10 -5
  112. package/extensions/ublocklite/rulesets/scripting/scriptlet/spa-1.prevent-fetch.js +10 -5
  113. package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.addEventListener-defuser.js +2 -2
  114. package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.prevent-fetch.js +10 -5
  115. package/extensions/ublocklite/rulesets/scripting/scriptlet/{fin-0.spoof-css.js → tur-0.remove-cookie.js} +69 -115
  116. package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.set-constant.js +2 -2
  117. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-experimental.trusted-json-edit-fetch-request.js +941 -0
  118. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-experimental.trusted-json-edit-xhr-request.js +3 -3
  119. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-experimental.trusted-replace-node-text.js +1 -1
  120. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.abort-current-script.js +3 -3
  121. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.abort-on-property-read.js +1 -1
  122. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.abort-on-stack-trace.js +1 -1
  123. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.addEventListener-defuser.js +2 -2
  124. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-edit-fetch-response.js +2 -2
  125. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-edit-xhr-response.js +2 -2
  126. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-edit.js +2 -2
  127. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-prune-fetch-response.js +2 -2
  128. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.jsonl-edit-xhr-response.js +2 -2
  129. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.noeval-if.js +1 -1
  130. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-fetch.js +12 -7
  131. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-setInterval.js +3 -3
  132. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-setTimeout.js +3 -3
  133. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-window-open.js +2 -2
  134. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-xhr.js +1 -1
  135. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.remove-node-text.js +3 -3
  136. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.set-constant.js +3 -3
  137. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.set-cookie.js +2 -2
  138. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.set-local-storage-item.js +2 -2
  139. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.spoof-css.js +3 -3
  140. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-json-edit-fetch-request.js +941 -0
  141. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-json-edit-fetch-response.js +2 -2
  142. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-json-edit.js +2 -2
  143. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-prevent-fetch.js +10 -5
  144. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-replace-argument.js +2 -2
  145. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-replace-node-text.js +2 -2
  146. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-replace-outbound-text.js +2 -2
  147. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-set-attr.js +3 -3
  148. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-set-constant.js +2 -2
  149. package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-suppress-native-method.js +2 -2
  150. package/extensions/ublocklite/rulesets/scripting/scriptlet/ubol-tests.jsonl-edit-fetch-response.js +2 -2
  151. package/extensions/ublocklite/rulesets/scripting/scriptlet/ubol-tests.jsonl-edit-xhr-response.js +2 -2
  152. package/extensions/ublocklite/rulesets/scripting/scriptlet/ukr-0.prevent-fetch.js +10 -5
  153. package/extensions/ublocklite/rulesets/scripting/scriptlet/vie-1.abort-current-script.js +2 -2
  154. package/extensions/ublocklite/rulesets/scripting/scriptlet/vie-1.abort-on-property-read.js +1 -1
  155. package/extensions/ublocklite/rulesets/scripting/scriptlet/vie-1.prevent-fetch.js +10 -5
  156. package/extensions/ublocklite/rulesets/scripting/scriptlet/vie-1.set-constant.js +2 -2
  157. package/extensions/ublocklite/rulesets/scripting/specific/adguard-mobile.js +3 -3
  158. package/extensions/ublocklite/rulesets/scripting/specific/annoyances-cookies.js +3 -3
  159. package/extensions/ublocklite/rulesets/scripting/specific/annoyances-notifications.js +3 -3
  160. package/extensions/ublocklite/rulesets/scripting/specific/annoyances-others.js +3 -3
  161. package/extensions/ublocklite/rulesets/scripting/specific/annoyances-overlays.js +3 -3
  162. package/extensions/ublocklite/rulesets/scripting/specific/annoyances-social.js +2 -2
  163. package/extensions/ublocklite/rulesets/scripting/specific/chn-0.js +3 -3
  164. package/extensions/ublocklite/rulesets/scripting/specific/deu-0.js +3 -3
  165. package/extensions/ublocklite/rulesets/scripting/specific/easylist.js +3 -3
  166. package/extensions/ublocklite/rulesets/scripting/specific/est-0.js +3 -3
  167. package/extensions/ublocklite/rulesets/scripting/specific/fin-0.js +3 -3
  168. package/extensions/ublocklite/rulesets/scripting/specific/fra-0.js +3 -3
  169. package/extensions/ublocklite/rulesets/scripting/specific/hrv-0.js +4 -4
  170. package/extensions/ublocklite/rulesets/scripting/specific/hun-0.js +3 -3
  171. package/extensions/ublocklite/rulesets/scripting/specific/idn-0.js +3 -3
  172. package/extensions/ublocklite/rulesets/scripting/specific/ind-0.js +3 -3
  173. package/extensions/ublocklite/rulesets/scripting/specific/ita-0.js +3 -3
  174. package/extensions/ublocklite/rulesets/scripting/specific/jpn-1.js +3 -3
  175. package/extensions/ublocklite/rulesets/scripting/specific/kor-1.js +3 -3
  176. package/extensions/ublocklite/rulesets/scripting/specific/nld-0.js +3 -3
  177. package/extensions/ublocklite/rulesets/scripting/specific/nor-0.js +3 -3
  178. package/extensions/ublocklite/rulesets/scripting/specific/pol-0.js +3 -3
  179. package/extensions/ublocklite/rulesets/scripting/specific/rou-1.js +3 -3
  180. package/extensions/ublocklite/rulesets/scripting/specific/rus-0.js +3 -3
  181. package/extensions/ublocklite/rulesets/scripting/specific/spa-0.js +3 -3
  182. package/extensions/ublocklite/rulesets/scripting/specific/spa-1.js +3 -3
  183. package/extensions/ublocklite/rulesets/scripting/specific/swe-1.js +3 -3
  184. package/extensions/ublocklite/rulesets/scripting/specific/tur-0.js +3 -3
  185. package/extensions/ublocklite/rulesets/scripting/specific/ublock-badware.js +3 -3
  186. package/extensions/ublocklite/rulesets/scripting/specific/ublock-filters.js +3 -3
  187. package/extensions/ublocklite/rulesets/scripting/specific/ukr-0.js +1 -1
  188. package/extensions/ublocklite/rulesets/scripting/specific/vie-1.js +3 -3
  189. package/extensions/ublocklite/rulesets/scriptlet-details.json +113 -60
  190. package/extensions/ublocklite/rulesets/strictblock/chn-0.json +117 -2
  191. package/extensions/ublocklite/rulesets/strictblock/dpollock-0.json +1 -0
  192. package/extensions/ublocklite/rulesets/strictblock/easylist.json +1 -1
  193. package/extensions/ublocklite/rulesets/strictblock/easyprivacy.json +7 -1
  194. package/extensions/ublocklite/rulesets/strictblock/hrv-0.json +8 -1
  195. package/extensions/ublocklite/rulesets/strictblock/jpn-1.json +134 -133
  196. package/extensions/ublocklite/rulesets/strictblock/nor-0.json +1 -1
  197. package/extensions/ublocklite/rulesets/strictblock/pgl.json +10 -3
  198. package/extensions/ublocklite/rulesets/strictblock/stevenblack-hosts.json +15646 -4853
  199. package/extensions/ublocklite/rulesets/strictblock/tur-0.json +1 -0
  200. package/extensions/ublocklite/rulesets/strictblock/ublock-badware.json +10 -10
  201. package/extensions/ublocklite/rulesets/strictblock/ublock-filters.json +3 -3
  202. package/extensions/ublocklite/rulesets/strictblock/ukr-0.json +1 -0
  203. package/extensions/ublocklite/rulesets/strictblock/urlhaus-full.json +1554 -196
  204. package/extensions/ublocklite/ublock.zip +0 -0
  205. package/package.json +1 -1
  206. package/src/browsers/index.ts +17 -8
  207. package/src/routes/management/http/kill.get.ts +2 -1
  208. package/src/shared/utils/function/handler.ts +2 -1
  209. package/src/utils.spec.ts +62 -0
  210. package/src/utils.ts +3 -0
  211. package/static/docs/swagger.json +2 -2
  212. package/static/docs/swagger.min.json +1 -1
  213. package/extensions/ublocklite/rulesets/scripting/procedural/ublock-experimental.js +0 -42
@@ -984,12 +984,12 @@
984
984
  },
985
985
  "info": {
986
986
  "title": "Browserless",
987
- "version": "2.38.0",
987
+ "version": "2.38.2",
988
988
  "x-logo": {
989
989
  "altText": "browserless logo",
990
990
  "url": "./docs/browserless-logo-inline.svg"
991
991
  },
992
- "description": "<!-- markdownlint-disable commands-show-output first-line-h1 no-emphasis-as-heading no-inline-html -->\n\n<div align=\"center\">\n <a href=\"https://browserless.io\" align=\"center\">\n <center align=\"center\">\n <picture>\n <source media=\"(prefers-color-scheme: dark)\" srcset=\"./assets/logo-white.svg\" width=\"600\">\n <source media=\"(prefers-color-scheme: light)\" srcset=\"./assets/logo.svg\" width=\"600\">\n <img src=\"./assets/logo.svg\" alt=\"Browserless logo\" width=\"600\">\n </picture>\n </center>\n </a>\n <br>\n <h3 align=\"center\"><center>Deploy headless browsers in Docker. Run on our cloud or bring your own.</center></h3>\n <br>\n <center>\n <a href=\"https://hub.docker.com/r/browserless/chrome\">\n <img src=\"https://img.shields.io/docker/pulls/browserless/chrome\" alt=\"Docker pulls\" />\n </a>\n <a href=\"https://github.com/browserless/browserless/tags\">\n <img src=\"https://img.shields.io/github/package-json/v/browserless/chrome\" alt=\"Version\" />\n </a>\n </center>\n <br>\n <center>\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-chromium.yml/badge.svg\" alt=\"Chromium build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-firefox.yml/badge.svg\" alt=\"Firefox build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-webkit.yml/badge.svg\" alt=\"Webkit build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-edge.yml/badge.svg\" alt=\"Edge build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-multi.yml/badge.svg\" alt=\"Mulltibrowser build\" />\n </center>\n <br>\n <hr>\n <br>\n</div>\n\n> [!NOTE] \n> Looking to bypass bot detectors and solve captchas? [We would recommend using BrowserQL as our stealthiest option](https://www.browserless.io/feature/browserql).\n\nBrowserless allows remote clients to connect and execute headless work, all inside of docker. It supports the standard, unforked Puppeteer and Playwright libraries, as well offering REST-based APIs for common actions like data collection, PDF generation and more.\n\nWe take care of common issues such as missing system-fonts, missing external libraries, and performance improvements, along with edge-cases like downloading files and managing sessions. For details, check out the documentation site built into the project which includes Open API docs.\n\nIf you've been struggling to deploy headless browsers without running into issues or bloated resource requirements, then Browserless was built for you. Run the browsers in [our cloud](https://browserless.io/) or your own, [free for non-commercial uses](https://github.com/browserless/browserless#licensing).\n\n## Table of Contents\n\n- [External links](#external-links)\n- [Features](#features)\n- [How it works](#how-it-works)\n - [Docker](#docker)\n - [Hosting Providers](#hosting-providers)\n - [Puppeteer](#puppeteer)\n - [Playwright](#playwright)\n- [Extending (NodeJS SDK)](#extending-nodejs-sdk)\n- [Debugger](#debugger)\n - [Install debugger](#install-debugger)\n- [Usage with other libraries](#usage-with-other-libraries)\n- [Motivations](#motivations)\n- [Licensing](#licensing)\n\n## External links\n\n1. [Full documentation site](https://docs.browserless.io/)\n2. [Live Debugger (using browserless.io)](https://chrome.browserless.io/)\n3. [Docker](https://github.com/browserless/browserless/pkgs/container/base)\n\n## Features\n\n### General\n\n- Parallelism and request-queueing are built-in + configurable.\n- Fonts and emoji's working out-of-the-box.\n- Debug Viewer for actively viewing/debugging running sessions.\n- An interactive puppeteer debugger, so you can see what the headless browser is doing and use its DevTools.\n- Works with unforked Puppeteer and Playwright.\n- Configurable session timers and health-checks to keep things running smoothly.\n- Error tolerant: if Chrome dies it won't.\n- Support for running and development on Apple's M1 machines\n\n### Cloud-only\n\nOur [cloud accounts](https://www.browserless.io/pricing/) include all the general features plus extras, such as:\n\n- [BrowserQL](https://www.browserless.io/feature/browserql) for avoiding detectors and solving captchas\n- [Hybrid automations](https://www.browserless.io/blog/hybrid-automations-for-puppeteer/) for streaming login windows during scripts\n- [/reconnect API](https://www.browserless.io/blog/reconnect-api) for keeping browsers alive for reuse\n- [REST APIs](https://www.browserless.io/feature/rest-apis) for tasks such as retrieving HTML, PDFs or Lighthouse metrics\n- Inbuilt [residential proxy](https://www.browserless.io/blog/residential-proxying/)\n- SSO, tokens and user roles\n\n## How it works\n\nBrowserless listens for both incoming websocket requests, generally issued by most libraries, as well as pre-build REST APIs to do common functions (PDF generation, images and so on). When a websocket connects to Browserless it starts Chrome and proxies your request into it. Once the session is done then it closes and awaits for more connections. Some libraries use Chrome's HTTP endpoints, like `/json` to inspect debug-able targets, which Browserless also supports.\n\nYou still execute the script itself which gives you total control over what library you want to choose and when to do upgrades. This also comes with the benefit of keep your code proprietary and able to run on numerous platforms. We simply take care of all the browser-aspects and offer a management layer on top of the browser.\n\n### Docker\n\n> [!TIP]\n> See more options on our [full documentation site](https://docs.browserless.io/baas/docker/quickstart).\n\n1. `docker run -p 3000:3000 ghcr.io/browserless/chromium`\n2. Visit `http://localhost:3000/docs` to see the documentation site.\n3. See more at our [docker package](https://github.com/browserless/browserless/pkgs/container/base).\n\n### Hosting Providers\n\nWe offer a first-class hosted product located [here](https://browserless.io). Alternatively you can host this image on just about any major platform that offers hosting for docker. Our hosted service takes care of all the machine provisioning, notifications, dashboards and monitoring plus more:\n\n- Easily upgrade and toggle between versions at the press of a button. No managing repositories and other code artifacts.\n- Never need to update or pull anything from docker. There's literally zero software to install to get started.\n- Scale your consumption up or down with different plans. We support up to thousands of concurrent sessions at a given time.\n\nIf you're interested in using this image for commercial aspects, then please read the below section on licensing.\n\n### Puppeteer\n\nPuppeteer allows you to specify a remote location for chrome via the `browserWSEndpoint` option. Setting this for Browserless is a single line of code change.\n\n**Before**\n\n```js\nconst browser = await puppeteer.launch();\n```\n\n**After**\n\n```js\nconst browser = await puppeteer.connect({\n browserWSEndpoint: 'ws://localhost:3000',\n});\n```\n\n### Playwright\n\nWe support running with playwright via their browser's remote connection protocols interface out of the box. Just make sure that your Docker image, playwright browser type _and_ endpoint match:\n\n**Before**\n\n```js\nimport pw from 'playwright';\nconst browser = await pw.firefox.launch();\n```\n\n**After**\n\n```sh\ndocker run -p 3000:3000 ghcr.io/browserless/firefox\n# or ghcr.io/browserless/multi for all the browsers\n```\n\n```js\nimport pw from 'playwright-core';\n\nconst browser = await pw.firefox.connect(\n 'ws://localhost:3000/firefox/playwright',\n);\n```\n\nAfter that, the rest of your code remains the same with no other changes required.\n\n## Extending (NodeJS SDK)\n\nBrowserless comes with built-in extension capabilities, and allows for extending nearly any aspect of the system (for Version 2+). For more details on how to write your own routes, build docker images, and more, [see our SDK README.md](/bin/scaffold/README.md) or simply run \"npx @browserless.io/browserless create\" in a terminal and follow the onscreen prompts.\n\n## Debugger\n\nYou can install a first-party interactive debugger for Browserless, that makes writing scripts faster and interactive. You can take advantage of things like `debugger;` calls and the page's console output to see what's happening on the page while your script is running. All of the Chrome devtools are there at your disposal.\n\n![browserless.io logo](/assets/debugger.png)\n\nA small list of features includes:\n\n- Running `debugger;` and `console.log` calls\n- Errors in the script are caught and show up in the console tab\n- DOM inspection, watch network requests, and even see how the page is rendering\n- Exporting you debugging script as a Node project\n- Everything included in Chrome DevTools\n\n### Install debugger\n\nInstalling the debugger is as simple as running the `install:debugger` script _after_ the project has been built. This way:\n\n```sh\n$ npm run build\n$ npm run install:debugger #or npm install:dev\n```\n\nYou will then see the debugger url during the startup process.\n\n```log\n---------------------------------------------------------\n| browserless.io\n| To read documentation and more, load in your browser:\n|\n| OpenAPI: http://localhost:3000/docs\n| Full Documentation: https://docs.browserless.io/\n| Debbuger: http://localhost:3000/debugger/?token=6R0W53R135510\n---------------------------------------------------------\n```\n\n## Usage with other libraries\n\nMost libraries allow you to specify a remote instance of Chrome to interact with. They are either looking for a websocket endpoint, a host and port, or some address. Browserless supports these by default, however if you're having issues please make an issue in this project and we'll try and work with the library authors to get them integrated with browserless. Please note that in V2 we no longer support selenium or webdriver integrations.\n\nYou can find a much larger list of supported libraries [on our documentation site](https://docs.browserless.io/libraries/puppeteer).\n\n## Motivations\n\nRunning Chrome on lambda or on your own is a fantastic idea but in practice is quite challenging in production. You're met with pretty tough cloud limits, possibly building Chrome yourself, and then dealing with odd invocation issues should everything else go ok. A lot of issues in various repositories are due to just challenges of getting Chrome running smoothly in AWS (see [here](https://github.com/GoogleChrome/puppeteer/issues?q=is%3Aissue+is%3Aopen+sort%3Acomments-desc)). You can see for yourself by going to nearly any library and sorting issues by most commented.\n\nGetting Chrome running well in docker is also a challenge as there's quiet a few packages you need in order to get Chrome running. Once that's done then there's still missing fonts, getting libraries to work with it, and having limitations on service reliability. This is also ignoring CVEs, access-controls, and scaling strategies.\n\nAll of these issues prompted us to build a first-class image and workflow for interacting with Chrome in a more streamlined way. With Browserless you never have to worry about fonts, extra packages, library support, security, or anything else. It just works reliably like any other modern web service. On top of that it comes with a prescribed approach on how you interact with Chrome, which is through socket connections (similar to a database or any other external appliance). What this means is that you get the ability to drive Chrome remotely without having to do updates/releases to the thing that runs Chrome since it's divorced from your application.\n\n## Licensing\n\nSPDX-License-Identifier: SSPL-1.0 OR Browserless Commercial License.\n\nIf you want to use Browserless to build commercial sites, applications, or in a continuous-integration system that's closed-source then you'll need to purchase a commercial license. This allows you to keep your software proprietary whilst still using browserless. [You can purchase a commercial license here](https://www.browserless.io/contact). A commercial license grants you:\n\n- Priority support on issues and features.\n- On-premise running as well as running on public cloud providers for commercial/CI purposes for proprietary systems.\n- Ability to modify the source (forking) for your own purposes.\n- A new admin user-interface.\n\nNot only does it grant you a license to run such a critical piece of infrastructure, but you are also supporting further innovation in this space and our ability to contribute to it.\n\nIf you are creating an open source application under a license compatible with the Server Side License 1.0, you may use Browserless under those terms.\n\n# Changelog\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.38.0...main\">Latest</a></h1>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.37.1...v2.38.0\">v2.38.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.26.1</code></li>\n<li>playwright-core: <code>1.56.1</code>, <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, and <code>1.52.0</code>.</li>\n<li>Chromium: <code>141.0.7390.37</code></li>\n<li>Chrome: <code>141.0.7390.123</code> (amd64 only)</li>\n<li>Firefox: <code>142.0.1</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>141.0.3537.99</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.37.1...v2.37.0\">v2.37.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Handling of <code>ignoreHTTPSErrors</code> to <code>acceptInsecureCerts</code>.</li>\n<li>Smaller fixes, testing updates, and graceful shutdown handling.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.23.0</code></li>\n<li>playwright-core: <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, <code>1.52.0</code>, and <code>1.51.1</code>.</li>\n<li>Chromium: <code>140.0.7339.16</code></li>\n<li>Chrome: <code>141.0.7390.66</code> (amd64 only)</li>\n<li>Firefox: <code>141.0</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>141.0.3537.57</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.36.0...v2.37.0\">v2.37.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Adds a new <code>/function/connect</code> route to distinguish function API calls and not have them add to concurrency.</li>\n<li>Fix installs in SDK projects not working.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.22.3</code></li>\n<li>playwright-core: <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, <code>1.52.0</code>, and <code>1.51.1</code>.</li>\n<li>Chromium: <code>140.0.7339.16</code></li>\n<li>Chrome: <code>140.0.7339.214</code> (amd64 only)</li>\n<li>Firefox: <code>141.0</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>140.0.3485.94</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.34.1...v2.36.0\">v2.36.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Updates base image to Ubuntu <code>24.04</code>.</li>\n<li>Updates NodeJS to <code>24.8.0</code>.</li>\n<li>Move to <code>npm ci</code> for automated tests and release processes.</li>\n<li>Small cleanup in dockerfiles for consistency.</li>\n<li>Added a <code>npm run coverage</code> command for determining areas of code needing coverage.</li>\n<li><code>bestAttempt</code> fixes in the <code>/scrape</code> API.</li>\n<li>Fixes a few OpenAPI issues in the swagger.json manifests.</li>\n<li>Fixes issues where install-adblock can fail.</li>\n<li>Updated messaging around concurrency limits being reached.</li>\n<li>Few more unit-tests.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.22.0</code></li>\n<li>playwright-core: <code>1.55.0</code>, <code>1.54.2</code>, <code>1.53.2</code>, <code>1.52.0</code>, and <code>1.51.1</code>.</li>\n<li>Chromium: <code>140.0.7339.16</code></li>\n<li>Chrome: <code>140.0.7339.186</code> (amd64 only)</li>\n<li>Firefox: <code>141.0</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>140.0.3485.81</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.34.0...v2.34.1\">v2.34.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an issue with absolute path in swagger.json docs.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.33.0...v2.34.0\">v2.34.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>README spelling fixes.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.16.0</code>.</li>\n<li>Bumps <code>playwright-core</code> to <code>1.54.2</code>.</li>\n<li>Updates the /pressure API to return a <code>503</code> error when under load and the <code>Accept</code> header is <code>text/plain</code>. All other headers for &quot;Accept&quot; are treated similarly.</li>\n<li>Internally, when Authorization is sent via the <code>token</code> query-parameter, browserless now migrates it to a more secure <code>Authorization</code> header before processing the request. This prevents accidental logging in source as well as SDK projects.</li>\n<li>Supports a <code>before</code> hook in routes so that pre-route logic can be applied before the request is handled by the route.</li>\n<li>Fixes an issue in API&#39;s where a <code>requestInterceptor</code> has a <code>body</code> with base64 encoded content. This is now properly handled and fulfills the request.</li>\n<li>Minor internal changes and spec file updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.32.1...v2.33.0\">v2.33.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix <code>page</code>&#39;s created by playwright&#39;s <code>context</code> object hanging.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.12.1</code>.</li>\n<li>Bumps <code>playwright-core</code> to <code>1.54.1</code>.</li>\n<li>Drops support for <code>playwright-core</code> at <code>1.49</code>.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.12.1</li>\n<li>playwright-core: 1.54.1, 1.53.1, 1.52.0, and 1.50.1</li>\n<li>Chromium: 139.0.7258.5</li>\n<li>Chrome: 138.0.7204.101 (amd64 only)</li>\n<li>Firefox: 140.0.2</li>\n<li>Webkit: 26.0</li>\n<li>Edge: 138.0.3351.83 (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.32.0...v2.32.1\">v2.32.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an in request shimming when no params are sent.</li>\n<li>Fixes an issue in OpenAPI JSON schema parsing on routes with <code>.d</code> in their name.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.31.1...v2.32.0\">v2.32.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump nodeJS to 24.2.0.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.10.2</code>.</li>\n<li>Bumps <code>playwright-core</code> to <code>1.53.1</code>.</li>\n<li>Drops support for <code>playwright-core</code> at <code>1.48</code>.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.10.2</li>\n<li>playwright-core: 1.53.1, 1.52.0, 1.50.1, and 1.49.1</li>\n<li>Chromium: 138.0.7204.23</li>\n<li>Chrome: 137.0.7151.120 (amd64 only)</li>\n<li>Firefox: 139.0</li>\n<li>Webkit: 18.5</li>\n<li>Edge: 137.0.3296.93 (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.31.0...v2.31.1\">v2.31.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an issue where ARM64 Platforms attempt to load non-compatible routes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.30.1...v2.31.0\">v2.31.0</a></h1>\n<ul>\n<li>Dependency updates -- including fix for tar-fs.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.10.0</code>.</li>\n<li>Remove stray console.log&#39;s in route building.</li>\n<li>Fixes for duplicative user-data-dir flags (fixes CI issues).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.30.0...v2.30.1\">v2.30.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Cleans up the embedded Open API docs.</li>\n<li>Prettier</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.29.0...v2.30.0\">v2.30.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.8.2</code>.</li>\n<li>Fixes a small issue in SDK OpenAPI docgen when overwriting an existing route.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.28.0...v2.29.0\">v2.29.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>The <code>build</code> command for SDK projects will no longer run <code>clean</code> prior.</li>\n<li>On startup, browserless will check dependencies and log if a browser isn&#39;t available for that platform. This only effects non-macOS arm64 platform Chrome and Edge routes. Prior to this an error would cause the application to quit at startup.</li>\n<li>Fixes for running Chrome and Chromium &quot;non-headless&quot; in playwright.</li>\n<li>Formatting, and stray console message cleanup.</li>\n<li>Logo fixes in README.md file.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.27.0...v2.28.0\">v2.28.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Propagate library process exit codes through for SDK project commands.</li>\n<li>Better error messaging when queuing and concurrency are full.</li>\n<li>No browser binary changes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.26.1...v2.27.0\">v2.27.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>MAX_PAYLOAD_SIZE</code> env variable for specifying a max-payload size in HTTP-based APIs. Value is a number specified in bytes, so <code>10485760</code> = 10MB.</li>\n<li>Consolidation of HTTP and Websocket Error handling into a singular method.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.26.0...v2.26.1\">v2.26.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix http routes being ignored in SDK projects.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.25.2...v2.26.0\">v2.26.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Moves relevant ad-blocking infrastructure over to uBlock Lite.</li>\n<li>You can now supply a glob-pattern for the <code>CORS_ALLOW_ORIGIN</code> parameter in order to support multiple domains and URLs. When a domain doesn&#39;t match, browserless will return a 404.</li>\n<li>Support for IPv6 when running on <code>::</code>.</li>\n<li>SDK projects will now ignore files found in <code>node_modules</code>, <code>dist</code>, <code>.next</code>, <code>.cache</code>, or <code>coverage</code>.</li>\n<li>New <code>isMatch</code> utility to do glob pattern matching in SDK and other projects.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.4.0</li>\n<li>playwright-core: 1.51.1, 1.50.1, 1.49.1, 1.48.2, and 1.47.2</li>\n<li>Chromium: 134.0.6998.35</li>\n<li>Chrome: 134.0.6998.166</li>\n<li>Firefox: 135.0</li>\n<li>Webkit: 18.4</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.25.1...v2.25.2\">v2.25.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes to the <code>/session</code> API to include proper host and port.</li>\n<li>Bumping timeout for certain unit-tests.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.3.0</li>\n<li>playwright-core: 1.50.1, 1.49.1, 1.48.2, 1.47.2, and 1.46.1.</li>\n<li>Chromium: 133.0.6943.16</li>\n<li>Chrome: 133.0.6943.127</li>\n<li>Firefox: 134.0</li>\n<li>Webkit: 18.2</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.25.0...v2.25.1\">v2.25.1</a></h1>\n<ul>\n<li>Removes edge from <code>arm64</code> builds due to lack of support.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.3...v2.25.0\">v2.25.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.2.1</li>\n<li>playwright-core: 1.50.1, 1.49.1, 1.48.2, 1.47.2, and 1.46.1.</li>\n<li>Chromium: 133.0.6943.16</li>\n<li>Chrome: 133.0.6943.127</li>\n<li>Firefox: 134.0</li>\n<li>Webkit: 18.2</li>\n</ul>\n</li>\n<li>Pins playwright and puppeteer deps in package.json for browser-version consistency in SDK projects</li>\n<li>Added support for Edge browser! <a href=\"https://github.com/orgs/browserless/packages\">Check out available packages here.</a></li>\n<li>Fixes headers object in the /scrape API</li>\n<li>Code formatting fixes</li>\n<li>Link fixes in certain READMEs</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.2...v2.24.3\">v2.24.3</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Pins <a href=\"mailto:Ubuntu@22.04\">Ubuntu@22.04</a> in Github Actions.</li>\n<li>Fixes <code>headless</code> types to use <code>--headless=new</code> when prior libraries attempt to do <code>--headless=old</code> (older playwright).</li>\n<li>Typing fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.1...v2.24.2\">v2.24.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix issues with Firefox when using a proxy.</li>\n<li>Fixes for the <code>/meta</code> API in SDK projects.</li>\n<li>Lint fixes.</li>\n<li>Link fixes in this CHANGELOG.md file.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.0...v2.24.1\">v2.24.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes for /performance API in SDK projects.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.23.0...v2.24.0\">v2.24.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 23.10.1.</li>\n<li>playwright-core: 1.49.0, 1.48.2, 1.47.2, 1.46.1, 1.45.3 and 1.44.1.</li>\n<li>Chromium: 131.0.6778.33.</li>\n<li>Chrome: 131.0.6778.109.</li>\n<li>Firefox: 132.0.</li>\n<li>Webkit: 18.2.</li>\n</ul>\n</li>\n<li>New <code>/meta</code> API route for getting details about the container (versions, etc).</li>\n<li>Bump NodeJS to <code>v22.11.0</code>.</li>\n<li>Add <code>libwebp-dev</code> for Webkit.</li>\n<li>Add support for <code>trackingId</code> and <code>/kill/{id}</code> and <code>/kill/all</code>.</li>\n<li>Prettier, internal fixes and improvements.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.22.0...v2.23.0\">v2.23.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes <code>--proxy-bypass-list</code> CLI arguments not being passed through with function API.</li>\n<li>Addition of <code>fonts-open-sans</code> to image.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.21.1...v2.22.0\">v2.22.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New SDK project command of <code>npm run install:browsers</code> to help with browser management.</li>\n<li>SDK projects now appropriately handle routes when only certain browsers are available.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.21.0...v2.21.1\">v2.21.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Ensure we don&#39;t load Chrome routes for SDK projects running linux/arm64.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.20.2...v2.21.0\">v2.21.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 23.4.1</li>\n<li>playwright-core: 1.47.2, 1.46.1, 1.45.3, 1.44, and 1.43.</li>\n</ul>\n</li>\n<li>Stream PDF using createPDFStream() in the PDF APIs.</li>\n<li>Inject file-system managers in browser-manager.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.20.1...v2.20.2\">v2.20.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Adds a fix to SDK routes that might not require a browser but browserless will still make one.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.20.0...v2.20.1\">v2.20.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix issues where connecting to a bad /devtools/page route can cause 500&#39;s.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.19.0...v2.20.\">v2.20.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports <code>puppeteer@23.3.0</code>.</li>\n<li>Support <code>playwright@1.47.0</code>.</li>\n<li>Use installed playwright-core for downloading browser binaries instead of <code>npx</code>, ensuring the appropriate browsers are installed.</li>\n<li>Fix JSON routes 404-ing when charset is specified in the content-type header.</li>\n<li>Disable the built-in debugger by setting <code>ENABLE_DEBUGGER=false</code>.</li>\n<li>Automatically run prettier on file save in VS Code.</li>\n<li>Windows fixes for SDK projects.</li>\n<li>README link fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.18.0...v2.19.0\">v2.19.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Drop <code>sort-keys</code> for eslint integrations.</li>\n<li>Fix devtools URLs when <code>PROXY</code> is set and contains a path.</li>\n<li>Disable <code>auth</code> when using Chrome&#39;s internal <code>/page</code> APIs.</li>\n<li>Small fixes for new eslint rules.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.17.0...v2.18.0\">v2.18.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports <code>puppeteer-core@23.1.1</code>.</li>\n<li>Supports <code>playwright-core@1.46.1, 1.44.1, 1.43.1, 1.42.1, 1.41.2</code>.</li>\n<li>Trailing slashes on routes now won&#39;t 404, so <code>/chrome</code> and <code>/chrome/</code> are treated as the same and will route properly.</li>\n<li><code>/function</code> API now works properly when applying a 3rd-party proxy.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.16.1...v2.17.0\">v2.17.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Hide token in logs on startup.</li>\n<li>Fixes an issue where using <code>--proxy-server</code> now works with /function-API calls.</li>\n<li>Adds support for the following CORS headers via env variables (headers and their corresponding config names are below). <em>Please note that these are very permissive by default, but only set when <code>ENABLE_CORS</code> is <code>true</code>!</em><ul>\n<li>&#39;Access-Control-Allow-Credentials&#39;: CORS_ALLOW_CREDENTIALS (default &#39;*&#39;)</li>\n<li>&#39;Access-Control-Allow-Headers&#39;: CORS_ALLOW_HEADERS (default: &#39;*&#39;)</li>\n<li>&#39;Access-Control-Allow-Methods&#39;: CORS_ALLOW_METHODS (default: &#39;OPTIONS, POST, GET&#39;)</li>\n<li>&#39;Access-Control-Allow-Origin&#39;: CORS_ALLOW_ORIGIN (default: &#39;*&#39;)</li>\n<li>&#39;Access-Control-Expose-Headers&#39;: CORS_EXPOSE_HEADERS (default: &#39;*&#39;)</li>\n<li>&#39;Access-Control-Max-Age&#39;: CORS_MAX_AGE (default: &#39;2592000&#39;)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.16.0...v2.16.1\">v2.16.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes numerous SDK issues when creating and building new projects.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.15.0...v2.16.0\">v2.16.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Better extension handling and merging when passing in custom extensions.</li>\n<li>Fixes a bug where a failed job (error thrown) causes the internal queue to drain.</li>\n<li>Prettier and other source improvements.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.14.0...v2.15.0\">v2.15.0</a></h1>\n<ul>\n<li>Bug fix to avoid removing healthy jobs from limiter when a job fails</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.13.0...v2.14.0\">v2.14.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Merged duplicate code in browsers and fixed name <code>WebkitPlaywright</code> to <code>WebKitPlaywright</code> (capitalized &quot;K&quot;).</li>\n<li>Devtools now bundled into the repository at build-time for the <code>/debugger</code> route.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.12.0...v2.13.0\">v2.13.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>The <code>browser</code> hook now gets the <code>req</code> property for the full request instead of <code>meta</code>.</li>\n<li>Now embeds the debugger located at <code>/debugger</code>.</li>\n<li>Preliminary support for <code>trackingId</code>.</li>\n<li>Bug fixes when dealing with ignoreHTTPSError parameters.</li>\n<li>Bug fixes to the /function API when it throws errors.</li>\n<li>Prettier fixes.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.11.0...v2.12.0\">v2.12.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>SDK projects should now use conventional class method properties versus the &quot;fat-arrow&quot; style instance methods.</li>\n</ul>\n<p><strong>Updates</strong></p>\n<ul>\n<li>Support for multi-version playwright (puppeteer coming soon). Browserless now checks the version in the User-Agent header and loads the appropriate playwright server for it.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.10.0...v2.11.0\">v2.11.0</a></h1>\n<ul>\n<li>Wrap the pressure response in a pressure key.</li>\n<li>New <code>keepAlive</code> property on browser objects for downstream SDK projects to flag.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.9.0...v2.10.0\">v2.10.0</a></h1>\n<ul>\n<li>Adds back in the <code>/pressure</code> API from V1.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.8.0...v2.9.0\">v2.9.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Debugger is now included and mounted under the <code>/debugger</code> path.</li>\n<li>Browserless now uses the <code>Logger</code> utility internally. Better logs for certain classes as well.</li>\n<li>Fix number of connected clients when using the Page websocket route.</li>\n<li>Allows &quot;HEAD&quot; requests for most &quot;GET&quot;-based APIs.</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.7.1...v2.8.0\">v2.8.0</a></h1>\n<p><strong>April 12, 2024</strong>\n<strong>Potentially Breaking</strong></p>\n<ul>\n<li>New <code>Logger</code> class and SDK primitives in support of that.</li>\n<li>Routes now get an instance of <code>Logger</code>, before the <code>browser</code> argument or as the last argument for HTTP routes.</li>\n</ul>\n<p><strong>Updates</strong></p>\n<ul>\n<li>Numerous SDK fixes and updates in the CLI.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.7.0...v2.7.1\">v2.7.1</a></h1>\n<p><strong>April 11, 2024</strong></p>\n<ul>\n<li>Fixes a boot-looping issue due to bad startup script. Adds tests for this as well.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.6.1...v2.7.0\">v2.7.0</a></h1>\n<ul>\n<li>Support for Running GPUs</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.6.0...v2.6.1\">v2.6.1</a></h1>\n<ul>\n<li>Fixes for function API calls when behind an external URL.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.5.0...v2.6.0\">v2.6.0</a></h1>\n<ul>\n<li>Adds a <code>GET /active</code> route that responds with no message and a <code>204</code> http code.</li>\n<li>Move to NodeJS 20.12.0.</li>\n<li>README, CHANGELOG, Migration and spelling fixes.</li>\n<li>New <code>/active</code> route for determining if server is able to handle requests.</li>\n<li>Better logging around 404&#39;d HTTP requests.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.4.0...v2.5.0\">v2.5.0</a></h1>\n<ul>\n<li><code>Config</code> now allows for programmatic getting and setting of the external address.</li>\n<li>Support for a new <code>Hooks</code> module for setting up hooks in a more SDK-friendly manner.</li>\n<li>Adds new exports for building downstream SDK projects more easily, versus using our CLI:<ul>\n<li><code>getArgSwitches</code></li>\n<li><code>getSourceFiles</code></li>\n<li><code>installDependencies</code></li>\n<li><code>buildDockerImage</code></li>\n<li><code>buildTypeScript</code></li>\n</ul>\n</li>\n<li><code>README.md</code> updates.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.3.0...v2.4.0\">v2.4.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Drops support for recording and screencasting in favor of library-based approaches.</li>\n<li><code>playwright@1.42.1</code> and <code>puppeteer@22.4.0</code>.</li>\n</ul>\n<p><strong>Other Changes</strong></p>\n<ul>\n<li>SDK routes now take precedence over core routes when a path-collision occurs.</li>\n<li>Support SDK projects with their own <code>static</code> directories.</li>\n<li>Adds support for user-specified <code>stop</code> methods in SDK Module extensions.</li>\n<li>Core modules now extend <code>EventEmitter</code>, making them able to publish events.</li>\n<li>Fixes issues with <code>addStyleTag</code> happening before <code>goto</code> calls in REST APIs.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.2.0...v2.3.0\">v2.3.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Routes must define a unique <code>name</code> property in order to remove them in SDK projects.</li>\n<li>A new <code>browserless</code> object in the SDK <code>package.json</code> file can specify module overrides, in camelCase, instead of using a path-based semantic.</li>\n<li>Fixes issues with <code>npx playwright-core install...</code> potentially installing other browser versions than what is a dependency of Browserless.</li>\n<li>Fixes and other general improvements.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.1.0...v2.2.0\">v2.2.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li><code>ghcr.io/browserless/chrome</code> now runs actual Chrome and not Chromium! If you were using this tag please update to use <code>ghcr.io/browserless/chromium</code>!<ul>\n<li>This Chrome tag uses the new routing convention below. If you get random 404&#39;s, please add <code>/chrome</code> to the start of the route. EG, <code>/pdf</code> becomes <code>/chrome/pdf</code>.</li>\n<li>Websocket connections follow a similar breakage in that the URL will go from something like <code>ws://localhost:3000</code> to <code>ws://localhost:3000/chrome</code>.</li>\n</ul>\n</li>\n<li>Adds a new <code>ghcr.io/browserless/chromium</code>, and updates <code>ghcr.io/browserless/chrome</code> to use actual Chrome.</li>\n<li>New and current APIs now follow a routing convention of <code>/$BROWSER/$ACTION</code>. In our Chrome image, you&#39;ll see <code>/chrome/pdf</code> for the PDF route as opposed to <code>/pdf</code>.<ul>\n<li>To keep things backwards compatible, all our prior REST APIs still have the same path as well as the new semantic, but only in the <code>multi</code> and <code>chromium</code> tags.</li>\n<li>These backwards compatible routes are ONLY available in <code>ghcr.io/browserless/chromium</code> and <code>ghcr.io/browserless/multi</code>.</li>\n</ul>\n</li>\n<li>Refer to the embedded documentation site for any and all updates on API differences.</li>\n</ul>\n<p><strong>Other Changes</strong></p>\n<ul>\n<li>HTTPRoutes and WebSocket routes can now have multiple paths to listen on.</li>\n<li>Add <code>clean</code> command to <code>@browserless.io/browserless</code> CLI.</li>\n<li>Adds support for <code>/json/list</code>, <code>/json/new</code>, <code>/json/version</code> and <code>json/protocol</code> APIs (Chrome and Chromium only).<ul>\n<li>When both Chrome and Chromium are present (in the case of the multi image), browserless opts for Chromium for these requests.</li>\n</ul>\n</li>\n<li>Removes legacy <code>browser.json</code> files since browserless now generates those and caches when requested.</li>\n<li>Stable docker images are coming! Please be sure to see our packages page for stable tags.</li>\n<li>Only verify that internally managed browsers are installed when starting.</li>\n<li>Preliminary support for <code>--headless=shell</code>.</li>\n<li>More unit-tests for the Chrome /json APIs.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/browserless/compare/v2.0.0-beta-1...v2.1.0\">v2.1.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Name is now <code>@browserless.io/browserless</code> to reflect our npm package.</li>\n<li>NEW: SDK is now live here: <a href=\"https://www.npmjs.com/package/@browserless.io/browserless\">https://www.npmjs.com/package/@browserless.io/browserless</a>.</li>\n<li>Drops gulp and other gulp utilities in favor of our own. Move to modules in <code>scripts</code> dir.</li>\n<li>Many private class properties now use <code>protected</code> so they can be referenced in SDK extensions.</li>\n<li>Adds a <code>/json/version</code> route for older libraries that use it.</li>\n<li>Merge startup/test scripts into <code>scripts</code> dir.</li>\n<li>Moves installed browsers to <code>/usr/local/bin/playwright-browsers</code>.</li>\n<li>Merge root files into package.json where possible.</li>\n<li>README updates and fixes.</li>\n<li>Numerous link and copyright fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/master...feat/browserless-2.0\">v2.0.0</a></h1>\n<p>browserless 2.0.0 represents the best body of work after running browserless for over 5 years. It contains mostly the same functionality and more, and is rebuilt to be more modular and offer a NodeJS SDK. It&#39;s also much lighter and faster than prior versions and includes a lot of semantic changes.</p>\n<h2>Features</h2>\n<ul>\n<li>ECMAScript style module loading and dependencies.</li>\n<li>New routing system using purely NodeJS&#39;s HTTP module.</li>\n<li>Better logs and concurrency/queueing parameters.</li>\n<li>Support for running the other major browser vendors in the same format and package.</li>\n<li>The service now compiles TypeScript to runtime JOI validation for our routes.</li>\n<li>Soon: upcoming support for extensions, long-running sessions and more.</li>\n</ul>\n<h2>Breaking Changes</h2>\n<ul>\n<li>Remove support for Selenium.</li>\n<li>The <code>/function</code> API now runs inside the context of the browser and not in Node.</li>\n<li>Drop support for keep-alive and pre-booting.</li>\n<li>Support for a single <code>launch</code> query-string parameter for launching a browser versus many individual parameters.</li>\n</ul>\n<h2>Minor Changes</h2>\n<ul>\n<li>Many docker parameters have been renamed, but are backwards compatible. See config.ts for details.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.60.2...v1.61.0\">v1.61.0</a></h1>\n<ul>\n<li><strong>FINAL of V1 for browserless/chrome. <a href=\"https://github.com/browserless/chrome/pull/3345\">See notes on V2 here</a></strong></li>\n<li>Dependency updates.</li>\n<li>Added <code>fonts-urw-base35</code>.</li>\n<li>Supports puppeteer <code>1.20</code>, <code>10.4.0</code>, <code>13.1.3</code>, <code>14.4.1</code>, <code>16.2.0</code>, <code>19.7.5</code> and <code>21.4.1</code>.</li>\n<li>Supports playwright <code>1.39</code>, <code>1.38</code>, <code>1.37</code>, <code>1.36</code>, <code>1.35</code>, <code>1.34</code>, and <code>1.33</code>.</li>\n<li>Fixes an issue where keep-alive chrome instances aren&#39;t properly tracked when <code>browser.close</code> is called.</li>\n<li>Fix improper handling of HTTP writing on bare sockets with 500 errors.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.60.1...v1.60.2\">v1.60.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an issue where calls to GET /sessions sometimes return blank results.</li>\n<li>Drop puppeteer <code>21.3.1</code> in favor of <code>21.3.6</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.60.0...v1.60.1\">v1.60.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Drop the <code>partner</code> repo from builds as we no longer use it for installing <code>flash</code>.</li>\n<li>Bump to <code>Ubuntu</code> lunar.</li>\n<li>Bump to NodeJS 18.17.0</li>\n<li>Package.json <code>engines.node</code> now reflects what node version we run on the docker image.</li>\n<li>Drops support for playwright@<code>1.33</code> and default playwright to <code>1.38</code>.</li>\n<li>Drops support for puppeteer@<code>21.1.1</code> in favor of <code>21.3.1</code>.</li>\n<li>Replaces legacy <code>request</code> module with Node&#39;s native <code>fetch</code> for webhooks.</li>\n<li>Drops <code>node-fetch</code> across the board in favor of <code>fetch</code> native.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.59.0...v1.60.0\">v1.60.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New build arguments in our Dockerfile to apply different named base repo.</li>\n<li>New <code>CHROME_STABLE_VERSION</code> build arg for specifying a particular chrome stable version.</li>\n<li>Fixes in postinstall hooks for various platforms and chrome-stable.</li>\n<li>NEW: <code>waitFor</code> properties in our APIs now supports an object with selector + timeouts for more fine tuning.</li>\n<li>Bump puppeteer <code>20.x.x</code> to <code>21.1.1</code> (116.0.5845.96).</li>\n<li>Supports playwright versions <code>1.37</code>, <code>1.36</code>, <code>1.35</code>, <code>1.34</code>, and <code>1.33</code>.</li>\n<li>Fixes in deploy script to handle versions, platforms and architectures.</li>\n<li>Fixes an issue where headless defaults to <code>DEFAULT_STEALTH</code>.</li>\n<li>New <code>PREBOOT_QUANTITY</code> for overriding the amount of pre-booted instances of Chrome.</li>\n<li>Allow using a host&#39;s display by setting <code>DISPLAY</code> env variable.</li>\n<li>Link fixes in README.md.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.58.0...v1.59.0\">v1.59.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump to Ubuntu Kinetic release + updates to use relevant packages.</li>\n<li>In support of puppeteer 20+, updates to <code>env.js</code> for finding/symlinking Chrome.</li>\n<li>Supports playwright <code>1.33</code>, <code>1.32</code>, <code>1.31</code>, and <code>1.29.</code>. Drops support for earlier versions.</li>\n<li>Ad-blocking and other request-interception in browserless is graceful using the <code>isInterceptResolutionHandled</code> method.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.57.0...v1.58.0\">v1.58.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Documentation link fixes.</li>\n<li>Add new required lib <code>libu2f-udev</code>.</li>\n<li>Support for <a href=\"mailto:puppeteer@19.7.5\">puppeteer@19.7.5</a>.</li>\n<li>Supports playwright versions: <code>1.27</code>, <code>1.28</code>, <code>1.29</code>, <code>1.30</code> and <code>1.31</code>.</li>\n<li>Better internal TypeScript definitions.</li>\n<li>Print&#39;s a few extra log-lines at startup for links to various resources.</li>\n<li><code>/kill/all</code> now supports rebooting when PREBOOT is turned on.</li>\n<li>Fixes an issue with chromedriver boot-looping in modern versions.</li>\n<li>Adds support for <code>--headless=new</code>.</li>\n<li>Fixes an issue where user-data-dirs aren&#39;t deleted due to a crashed container.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.56.0...v1.57.0\">v1.57.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Add back in <code>puppeteer@13.1.3</code> for PDF/Screenshot performance.</li>\n<li>Replace <code>puppeteer@18.0.5</code> in favor of <code>puppeteer@19.2.2</code>.</li>\n<li>Better puppeteer install/binary path lookups.</li>\n<li>Support for the following playwright versions via the /playwright path:<ul>\n<li>1.23.3</li>\n<li>1.24.2</li>\n<li>1.25.2</li>\n<li>1.26.1</li>\n<li>1.27.1</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.55.0...v1.56.0\">v1.56.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes various puppeteer issues with regards to revision information and browser-fetching.</li>\n<li>Fixes a Selenium issue where failed browsers can cause session to zombie.</li>\n<li>Small fix for route error handling.</li>\n<li>Better selenium W3C support.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.55.0...v1.54.1\">v1.55.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Update base OS from Ubuntu 20.04 to Ubuntu 22.04.</li>\n<li>Drops <code>path</code> support for both <code>addScriptTag</code> and <code>addStyleTag</code>. Use <code>url</code> or inject content directly.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency updates.</li>\n<li>We now support multiple versions of playwright via <code>playwright-core</code>. browserless checks the User-Agent string and tries to load a compatible playwright server at runtime in order to avoid breakages between versions.</li>\n<li>New <code>scrollPage</code> boolean parameter for the screenshot and other relevant APIs.</li>\n<li>browserless now writes appropriately formatted HTTP and WebSocket messages for non-2xx responses.</li>\n<li>Better CI coverage with prior puppeteer versions.</li>\n<li>Adds back a <code>browser.json</code> file in our docker images for easier CDP-related queries.</li>\n<li>A new <code>PORT</code> arg is available at build time in order to specify a PORT to listen onto.</li>\n<li>Updated links for browserless documentation in docs.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.54.1...v1.54.0\">v1.54.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Add <code>browser.json</code> file to git tags.</li>\n<li>Prettier fixes on source.</li>\n<li>deploy.js file fixes for creating production tags.</li>\n<li>Fix: add the <code>userDataDir</code> option so that we don&#39;t fill disks when using <code>stealth</code>.</li>\n<li>Fix: allow <code>disconnect</code> listeners to fire before closing.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.53.0...v1.54.0\">v1.54.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Move to using <code>mocha</code> for better esm support.</li>\n<li>Drop puppeteer <code>13.6.0</code> in favor of <code>14.4.1</code>.</li>\n<li>Utilize puppeteer <code>14.4.1</code> for <code>chrome-stable</code>.</li>\n<li>New internal <code>getCDPClient</code> for loading a page&#39;s CPD connection.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.52.1...v1.53.0\">v1.53.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump <code>browserless:base</code> to <code>1.16.0</code>.</li>\n<li>Drop <code>--quiet</code> from deploy scripts.</li>\n<li><code>arm64</code> support for latest as well as puppeteer at versions 9,10 and 13.</li>\n<li>Update puppeteer 13 from <code>13.5.2</code> to <code>13.6.0</code> (revision <code>982053</code>).</li>\n<li>README updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.52.0...v1.52.1\">v1.52.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Playwright example correction in README.md.</li>\n<li>Use revision <code>970485</code> for puppeteer 13.x.x, <code>latest</code>, chrome-stable and <code>arm64</code>.</li>\n<li>When using <code>KEEPALIVE</code> and <code>PREBOOT</code>, don&#39;t create new blank pages, and use the existing one instead.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.51.1...v1.52.0\">v1.52.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Added in new fonts: <code>fonts-gfs-neohellenic</code>.</li>\n<li>Minor code formatting changes.</li>\n<li>Drop <a href=\"mailto:puppeteer@13.1.3\">puppeteer@13.1.3</a> in favor of 13.5.2.</li>\n<li>Make <code>heapdump</code> an optional dependency as it&#39;s not always used, and add it back in.</li>\n<li>Utilize <code>fs/promise</code> vs home-rolled promisified utils.</li>\n<li>Fix an issue where PREBOOT and KEEPALIVE might return an <code>undefined</code> browser.</li>\n<li>Logging when file-protocol requests happen and terminate a session.</li>\n<li>Move the browser process exit listener into the puppeteer-provider for better session cleanup.</li>\n<li>Allow &quot;headfull&quot; playwright sessions.</li>\n<li>Don&#39;t <code>await</code> chrome-helper&#39;s closing of the browser as it&#39;s not truly async.</li>\n<li>Remove <code>body-parser</code> in favor of <code>express</code>&#39;s JSON and other parsers.</li>\n<li>Fixes an issue where using a user-data-dir that doesn&#39;t exist causes chrome to crash.</li>\n<li>Add in more unit and integration tests.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.51.1...v1.52.0\">v1.52.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Added in new fonts: <code>fonts-gfs-neohellenic</code>.</li>\n<li>Minor code formatting changes.</li>\n<li>Drop <a href=\"mailto:puppeteer@13.1.3\">puppeteer@13.1.3</a> in favor of 13.5.2.</li>\n<li>Make <code>heapdump</code> an optional dependency as it&#39;s not always used, and add it back in.</li>\n<li>Utilize <code>fs/promise</code> vs home-rolled promisified utils.</li>\n<li>Fix an issue where PREBOOT and KEEPALIVE might return an <code>undefined</code> browser.</li>\n<li>Logging when file-protocol requests happen and terminate a session.</li>\n<li>Move the browser process exit listener into the puppeteer-provider for better session cleanup.</li>\n<li>Allow &quot;headfull&quot; playwright sessions.</li>\n<li>Don&#39;t <code>await</code> chrome-helper&#39;s closing of the browser as it&#39;s not truly async.</li>\n<li>Remove <code>body-parser</code> in favor of <code>express</code>&#39;s JSON and other parsers.</li>\n<li>Fixes an issue where using a user-data-dir that doesn&#39;t exist causes chrome to crash.</li>\n<li>Add in more unit and integration tests.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.51.0...v1.51.1\">v1.51.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Updates the <code>vm2</code> module to <code>3.9.7</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.50.0...v1.51.0\">v1.51.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>viewport</code> option inside of the content API.</li>\n<li>New <code>encoding</code> option in the screenshot API.</li>\n<li>Drop <a href=\"mailto:puppeteer@12.x.x\">puppeteer@12.x.x</a> in favor of 13.x.x.</li>\n<li>Fixes in our deploy scripts.</li>\n<li>Fixes for windows binaries in our postinstall hook.</li>\n<li>Fixes an issue where playwright tries to use a pre-booted chrome instance.</li>\n<li>Small type updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.49.1...v1.50.0\">v1.50.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Drops support for <code>puppeteer-4.0.1</code> in favor of <code>puppeteer-12.0.1</code>.</li>\n<li>Chrome-stable now utilizes puppeteer @ <code>12.0.1</code>.</li>\n<li>Support for <code>arm64</code> via production tags (<code>1-arm64</code>) as well as in <code>latest</code>.</li>\n<li>Static JSON files (<code>protocol.json</code>, <code>version.json</code>) are built at runtime on their first request and then cached in memory.</li>\n<li>Bumps <code>browserless/base</code> to <code>1.14.0</code>.</li>\n<li>New <code>selector</code> property for screenshot-ing a single DOM node in the screenshot API.</li>\n<li><code>puppeteerVersions</code> in the package.json file has been rename do <code>chromeVersions</code>.</li>\n<li>Internal changes for deploying production tag scripts.</li>\n<li>Consolidate scripts for <code>postinstall</code>.</li>\n<li>Drop support for <code>heapdump</code> due to its age and lack of platform varieties.</li>\n<li>New <code>/metrics/total</code> route for summing up all statistics in a single JSON payload.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.49.0...v1.49.1\">v1.49.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix webhook not using timeout URL.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.48.0...v1.49.0\">v1.49.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Support for ARM64 builds by dropping flash for it.</li>\n<li>Bump puppeteer 10.2.0 for 10.4.0.</li>\n<li>New puppeteer-hook for injecting a puppeteer-compatible library, eg. puppeteer-extra.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.47.0...v1.48.0\">v1.48.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>API calls with <code>html</code> in their payloads now use the <code>page.setContent</code> API versus a prior hack using one-time network-request interception (<a href=\"https://github.com/browserless/chrome/compare/v1.47.0...master#diff-67b699af1b24472604e21081d0509620d4ab3d986fcd4f8aa0b04d5ee5e4c63fL88\">example here</a>). Old versions of puppeteer might not work properly with this (&lt;= 5.x.x). This effects the following APIS: <code>/content</code>, <code>/pdf</code> and <code>/screenshot</code>.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump <code>browserless/base</code> to <code>1.12.0</code> (add user-id to <code>blessuser</code> of <code>BLESS_USER_ID=999</code>).</li>\n<li>Bumps puppeteer @10.x.x to <code>10.2.0</code> with revision <code>901912</code>.</li>\n<li>Makes API calls use <code>setContent</code> properly now (no more one-time network interception). This fixes certain issues with images not loading in PDFs and screenshots.</li>\n<li>Fix some typings in tests.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.46.0...v1.47.0\">v1.47.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump <code>browserless/base</code> to <code>1.11.0</code>.</li>\n<li>Add new lint task and rename GitHub actions tasks, remove <code>tslint</code>.</li>\n<li>Lint and prettier fixes.</li>\n<li>Delay url parsing until after <code>before</code> hook runs.</li>\n<li>New <code>meta</code> object param for page hooks (passing through arbitrary meta data set by prior hooks).</li>\n<li>New <code>FUNCTION_ENV_VARS</code> environment variable pass through an allow-list of environment variables for functions to access.</li>\n<li>Fix <code>someObject.hasOwnProperty</code> to <code>Object.prototype.hasOwnProperty.call</code>.</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.45.0...v1.46.0\">v1.46.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Move to Node 16.x.x.</li>\n<li>Bump browserless/base to 1.10.0.</li>\n<li>Limit <code>x-response-url</code> to 100 characters.</li>\n<li>Add support for <a href=\"mailto:puppeteer@10.x.x\">puppeteer@10.x.x</a>.</li>\n<li>Add <code>maxConcurrent</code> stat for metrics API + log stats every 5 minutes to stdout.</li>\n<li>Some performance improvements to how pages/browsers are setup and torn down.</li>\n<li>Add <code>API_DOCS_ENDPOINT</code> as a filterable API to deny access to.</li>\n<li>Minor code reformatting from prettier.</li>\n<li>Better page setup and logging.</li>\n<li>Fixes <code>DEFAULT_STEALTH</code> for self-hosted deployments.</li>\n<li>Improvements on how chrome is closed.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.44.0...v1.45.0\">1.45.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Support for <a href=\"https://github.com/browserless/chrome/commit/0903795e936b93a511ec04f7ae35c03397682905\">playwright proxies</a>.</li>\n<li>Fixes an issue with larger headers potentially causing load-balancers to crash and fail.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.43.0...v1.44.0\">v1.44.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li><code>PROXY_HOST</code> and <code>PROXY_PORT</code> are now replaced with a single <code>PROXY_URL</code> param, eg: <code>https://www.mybrowserless.com/optional/paths</code>. When set, browserless uses this fully-qualified URL to build out links <em>back</em> to its internal debugger and sessions. Useful when you&#39;re instance is behind a proxy or load-balancer of some kind.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency Updates.</li>\n<li>Use recent Node 14 (browserless-base 1.7.0).</li>\n<li>New <code>rejectResourceTypes</code> property on most APIs (content, screenshot, pdf, etc.).</li>\n<li>Allow serving of <code>file://</code> protocols when explicitly enabled (default is off due to security concerns). Set <code>ALLOW_FILE_PROTOCOL=true</code> in your env params.</li>\n<li>The <code>/pressure</code> API now takes into account CPU/Memory consumption, and adds a &quot;reason&quot; property for why the machine might be not available.</li>\n<li>Fixes an issue where playwright couldn&#39;t download files.</li>\n<li>You can now filter /sessions calls with a <code>trackingId</code> parameter.</li>\n<li><code>detached</code> functions now return a <code>trackingId</code> when present.</li>\n<li>More types, tests, and utility consolidation.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.42.0...v1.43.0\">v1.43.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fixes an issue where --user-data-dirs aren&#39;t deleted properly, potentially filling disks.</li>\n<li>Changes CPU/Memory checks to be user-based and not the entire OS.</li>\n<li>Adds tests for the user-data-dir issue.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.41.0...v1.42.0\">v1.42.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Move to Node 14!</li>\n<li>Use <code>esModuleInterop</code> for imports.</li>\n<li>Remove <code>page.waitFor</code> in favor of downstream methods.</li>\n<li>Adds new <code>?stealth</code> parameter for API calls (see puppeteer-extra-stealth-plugin).</li>\n<li>New <code>DEFAULT_STEALTH</code> param for making stealth calls by default.</li>\n<li>Fixes <code>ignoreDefaultArgs</code> in chrome stable.</li>\n<li>Ensure temp user-data-dirs are always cleaned up.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.40.2...v1.41.0\">v1.41.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>New <code>SESSION_CHECK_FAIL_URL</code> webhook for when pre-session checks fail.</li>\n<li>Health checks now take the last two CPU/Memory samples to determine if a failure (5 minutes).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.40.1...v1.40.2\">v1.40.2</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fix potentially unhandled stream error events when closing chrome.</li>\n<li>Bump puppeteer to 5.4.1 for major 5.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.40.0...v1.40.1\">v1.40.1</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>New <code>SOCKET_CLOSE_METHOD</code> for better load-balancing behavior when under load.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.39.0...v1.40.0\">v1.40.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Support for playwright 1.4.0 and greater. <a href=\"https://github.com/microsoft/playwright/issues/4054\">See more here</a>.</li>\n<li>New <code>PRE_REQUEST_HEALTH_CHECK</code> env variable to check CPU/Memory prior to running a session. Set <code>MAX_CPU_PERCENT</code> or <code>MAX_MEMORY_PERCENT</code> for setting these thresholds. Responds with a <code>503</code> HTTP code if CPU/Memory are high on any inbound session (API, puppeteer or webdriver).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.38.0...v1.39.0\">v1.39.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes a crash due to <code>browser.close</code> streams not completing properly.</li>\n<li>Adds a <code>dumpio</code> query-string parameter for launching with puppeteer.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.37.2...v1.38.0\">v1.38.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes a memory leak when browsers don&#39;t close properly.</li>\n<li>Adds a <code>/heapdump</code> route for capturing heap dumps. Turn on by setting <code>ENABLE_HEAP_DUMP=true</code> in your docker env.</li>\n<li><code>emulateMedia</code> fixes on the pdf route.</li>\n<li>CodeQL implemented.</li>\n<li>README fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.37.1...v1.37.2\">v1.37.2</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes an issue where the webserver can crash after rejecting a request.</li>\n<li>Fixes deployment script not waiting for zip files to be finished unzipped.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.37.0...v1.37.1\">1.37.1</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes an issue in webdriver not starting properly.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.36.0...v1.37.0\">1.37.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Due to stability issues, puppeteer version 3.x.x and 4.x.x now use chromium revision <code>782078</code>. See our <code>package.json</code> for details.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency Updates</li>\n<li>README Updates</li>\n<li>Fixes an issue for secured containers using prometheus (plus tests).</li>\n<li>Support for puppeteer <code>5.2.1</code></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.35.0...v1.36.0\">1.36.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Drops support for puppeteer <code>2.0.0</code> and <code>3.0.4</code>, please use <code>2.1.1</code> and <code>3.3.0</code> for those revisions.</li>\n<li>Adds support for puppeteer <code>5.0.0</code>.</li>\n<li>Bug-fix with the server randomly closing with an uncaught error event thrown from inside underlying socket connection.</li>\n<li>Adds back in <code>--disable-dev-shm-usage</code> to default arguments for better SHM performance.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.34.0...v1.35.0\">1.35.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>New <code>maxTime</code>, <code>minTime</code>, <code>meanTime</code> and <code>totalTime</code> of all sessions for a given period in /stats.</li>\n<li>Bugfix on CPU/Memory triggering health failure webhooks.</li>\n<li>Fix issues in websocket errors by awaiting browser.close (or 5 seconds, whichever is quickest).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.33.1...v1.34.0\">v1.34.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>screencast API no longer supports <code>audio</code> or the <code>setPreferences</code> function in order to offer a better video experience. In order to set the width/height, simply set a page width height to what you&#39;d like.</li>\n<li><code>chrome-stable</code> will now use <code>puppeteer@3.1.0</code> for better compatibility.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency updates.</li>\n<li>Drops puppeteer version <code>1.20.0</code> and below.</li>\n<li>Move <code>browserless/base</code> to <code>v1.5.0</code>.</li>\n<li>Puppeteer support for <code>3.3.0</code> (3.2.x and 3.1.x have the same chromium revision).</li>\n<li>Fixes <code>trackingId</code> on pre-booted sessions.</li>\n<li><code>about:blank</code> pages now are returned in the <code>/sessions</code> API for transparency of open sessions/browsers.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.33.0...v1.33.1\">1.33.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix socket errors from accidentally firing error webhooks.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.32.0...v1.33.0\">1.33.0</a></h1>\n<ul>\n<li>Drops support for puppeteer 1.17.x and 1.18.x</li>\n<li>Support for puppeteer 3.0.x</li>\n<li>Dependency updates</li>\n<li>Fix reject stat firing on debugger pages not being found</li>\n<li>Consolidates more types.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.31.1...v1.32.0\">1.32.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Adds roboto fonts.</li>\n<li>Updates <code>pressure</code> API to take account of running browsers in the <code>running</code> count.</li>\n<li>Adds <code>maxConcurrent</code>, <code>maxQueued</code>, <code>cpu</code> and <code>memory</code> to pressure.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.31.0...v1.31.1\">1.31.1</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fixes a small issue where XVFB doesn&#39;t start properly during an automated restart.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.30.0...v1.31.0\">1.31.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Allows <code>trackingId</code> on uploaded files to save in the appropriate tracking-ID folder.</li>\n<li>New <code>userAgent</code> param for setting user-agent in API requests.</li>\n<li>Fixes an issue where chrome wasn&#39;t being closed in rare cases.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.29.1...v1.30.0\">1.30.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Updates to Node 13 for speed and memory improvements.</li>\n<li>browserless/<a href=\"mailto:base@1.4.0\">base@1.4.0</a></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.29.0...v1.29.1\">1.29.1</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fixes how deploy script determines errors when running child commands.</li>\n<li>Fixes issues when many selenium sessions can potentially fill up disk space.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.28.0...v1.29.0\">1.29.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Uses <code>pipe</code>&#39;s for most API calls and other internal endpoints for faster/better throughput. Works only for <code>headless</code> API/puppeteer calls.</li>\n<li>Allows custom lighthouse configs via POST <code>config</code> property.</li>\n<li>Patches vm2.</li>\n<li>Before hooks no longer end requests forcefully -- external hooks must manually end the request/sockets themselves.</li>\n<li>Properly passes socket errors to the error handler/webhook</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.27.0...v1.28.0\">1.28.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Sets a system-default font of Ubuntu for most sites that use <code>system-ui</code> in their font declarations.</li>\n<li>Fixes health-check failure webhooks.</li>\n<li>New <code>PROXY_HOST</code>, <code>PROXY_PORT</code> and <code>PROXY_SSL</code> for external load-balancers. <a href=\"https://www.browserless.io/docs/docker.html#using-a-proxy\">See docsite for more info</a>.</li>\n<li>Moves over to GH actions over Travis for CI.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.26.1...v1.27.0\">1.27.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>manipulate</code> params for screenshots, allowing for resizing, flipping and more.</li>\n<li>Better tracking of chrome-process for cleanup of zombied sessions.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.26.0...v1.26.1\">1.26.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Added <code>git</code> as a dependency in dockerfile for git-based npm dependencies to work.</li>\n<li>Fixed an issue in <code>start.sh</code> so that errors bubble up properly and close the process.</li>\n<li>Bumps <code>browserless/base</code> to <code>1.2.0</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.25.0...v1.26.0\">1.26.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Dropping pre-push hooks for speed.</li>\n<li>Consolidate all interfaces/types to a types.d.ts file.</li>\n<li>Fixes an issue where numerous chrome instances launch when prebooting.</li>\n<li>Fixes an issue where incoming requests don&#39;t use the pre-booted chrome instance.</li>\n<li>Uses <code>page.setViewport</code> when <code>--window-size</code> is set in params to help with screenshots not appearing properly (chromedriver only).</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.24.0...v1.25.0\">1.25.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Stricter build-time arguments for chromium and chromedriver assets.</li>\n<li>Better XVFB functionality.</li>\n<li>New parameters for most API&#39;s, <code>addScriptTag</code> and <code>addStyleTag</code>, accepting an array of scripts/styles respectively.</li>\n<li>Drop support for <code>puppeteer@1.17.0</code>.</li>\n<li>Proper support for parsing <code>ignoreDefaultArgs</code> query-parameters.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.23.1...v1.24.0\">1.24.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bugfix on our debugger&#39;s play button being off-center.</li>\n<li>Fixes driver.close() calls not cleaning the browser.</li>\n<li>New <code>/GET</code> option for most our APIs. Stringify your JSON and add a ?body=YOUR-JSON with a /GET call to most of our functions! Requires <code>ENABLE_API_GET=true</code> in you docker env variables.</li>\n<li>WebSocket (Socket) exception handling and logging.</li>\n<li>More integration and unit tests added.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.23.0...v1.23.1\">1.23.1</a></h1>\n<ul>\n<li>Fixes an issue in chromedriver where commands would hang.</li>\n<li>Fixes an issue in chromedriver sessions not being removed properly.</li>\n<li>Fixes and pins the base image so that headful sessions work again.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.22.0...v1.23.0\">1.23.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Use <code>apt-get</code> to install <code>dumb-init</code>.</li>\n<li>Add a LANG arg in docker.</li>\n<li>New <code>setJavaScriptEnabled</code> property for REST APIs.</li>\n<li>Fixes an issue with <code>waitFor</code> functions in REST API calls.</li>\n<li>Fixes issues when PREBOOT_CHROME and KEEPALIVE are true.</li>\n<li>Updates protocol and host information in ad-blocking.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.21.0...v1.22.0\">1.22.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Removal of unnecessary &#39;--disable-dev-shm-usage&#39;</li>\n<li>Squelching of chromedriver&#39;s verbose args unless <code>DEBUG=*</code> is set.</li>\n<li>New <code>/kill/${id}</code> route for remotely killing a certain browser.</li>\n<li>Allowing of sub-child routes in workspaces.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.20.0...v1.21.0\">1.21.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>viewport</code> property option for PDF endpoint.</li>\n<li>The <code>/stats</code> endpoint now runs in a separate process meaning it can be parallelized.</li>\n<li>Fixed a bug where hardware monitoring can cause the container to restart/crash.</li>\n<li>Fixes an issue with the file-chooser API not working in puppeteer.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.19.0...v1.20.0\">1.20.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>/scrape</code> API!</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.18.0...v1.19.0\">1.19.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes chrome-stable&#39;s binary chromedriver.</li>\n<li>Move over to Node 12.</li>\n<li>Bugfix on width/height in the screencast API.</li>\n<li>Support for <a href=\"mailto:puppeteer@2.0.0\">puppeteer@2.0.0</a>.</li>\n<li>Fixed issues with the devtools JS files missing.</li>\n<li>Adds support for blacklisting routes in Docker.</li>\n<li>Consolidates hooks into a hooks module.</li>\n<li>Allows Selenium to specify download-paths and pausing via preferences.</li>\n<li>Fixes an issue in certain JSON-based CDP libraries.</li>\n<li>Function API&#39;s can now run incognito mode with a new Docker param.</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.17.0...v1.18.0\">1.18.0</a></h1>\n<ul>\n<li>Dependency updates</li>\n<li>Better <code>IS_DOCKER</code> check for kubernetes.</li>\n<li>Updates to README.md, spelling fixes and Slack link.</li>\n<li>Fixes to debugger and larger code bodies.</li>\n<li>Removal of analytics in debugger.</li>\n<li>Screencast improvements and adding ability to set new options.</li>\n<li>New <code>waitFor</code> property in our APIs (content, pdf and screenshot).</li>\n<li>Don&#39;t allow file requests on the debugger for security reasons.</li>\n<li>Better metrics monitoring.</li>\n<li><code>singleRun</code> mode in docker.</li>\n<li>New prometheus support!</li>\n<li>Fixing issues with keeping chrome alive (only closing once TTL is met).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.16.0...v1.17.0\">1.17.0</a></h1>\n<ul>\n<li>Dependency updates</li>\n<li>Splitting docker images into two repositories for faster builds and pulls</li>\n<li>Adding in external routing capabilities</li>\n<li>New error hook</li>\n<li>More/better types</li>\n<li>Updating <code>deviceScaleFactor</code> in API&#39;s for more granular control.</li>\n<li>Better chromedriver failure messages.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.15.0...v1.16.0\">1.16.0</a></h1>\n<ul>\n<li>Adding <code>ffmpeg</code> to the docker dependency list.</li>\n<li>Add <code>timecut</code> as a dependency for recording.</li>\n<li>Better logs on chrome PID&#39;s and closing forcefully.</li>\n<li>Fixed <code>DEFAULT_CHROME</code> =&gt; <code>DEFAULT_HEADLESS</code>.</li>\n<li>Fixed a bug where <code>xvfb</code> doesn&#39;t start in time.</li>\n<li>Use <code>SIGKILL</code> for killing chromedriver.</li>\n<li><code>/json/version</code> now returns a <code>webSocketDebuggerUrl</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.14.1...v1.15.0\">1.15.0</a></h1>\n<ul>\n<li>New <code>page</code> and <code>browser</code> hooks for docker images that <code>FROM</code> browserless.</li>\n<li><code>bluebird</code> added as a module for <code>function</code> and other endpoints.</li>\n<li>More dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.14.0...v1.14.1\">1.14.1</a></h1>\n<ul>\n<li>Bugfix when running multiple &quot;headfull&quot; sessions.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.13.0...v1.14.0\">1.14.0</a></h1>\n<ul>\n<li>New <code>WORKSPACE_DELETE_EXPIRED</code> and <code>WORKSPACE_EXPIRE_DAYS</code> to auto-cleanup workspace dirs.</li>\n<li>README.md cleanup now that HTTPS is no longer required.</li>\n<li>Support for <code>~</code> in docker env parameters.</li>\n<li>More alignment with how chromedriver and puppeteer sessions get cleaned up.</li>\n<li><code>/session</code> API now returns <code>browserWSEndpoint</code> and <code>browserId</code> properties for having multiple debuggers connected.</li>\n<li>Support for reconnecting(!!). When a <code>?keepalive=KEEP-ALIVE-IN-MS</code> is seen in the <code>puppeteer.connect</code> call we keep the browser active for that many ms after the debugger disconnects.</li>\n<li>New <code>/kill/all</code> route which closes <em>all</em> actively running sessions.</li>\n<li>New internal scheduler module, making future things like cron-based jobs a possibility.</li>\n<li>Better internal types.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.12.0...v1.13.0\">1.13.0</a></h1>\n<ul>\n<li>A minor refactor to consolidate calls to <code>url.parse</code> for performance gains.</li>\n<li>Introduces a per-session based timeout that overrides the global timeout.</li>\n<li>Consolidates authorization checks to remove duplication.</li>\n<li>Moves more types into their backing modules in order to better consolidate files.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.11.0...v1.12.0\">1.12.0</a></h1>\n<ul>\n<li>Set&#39;s a non-conflicting <code>WORKSPACE_DIR</code> and <code>DEFAULT_USER_DATA_DIR</code> in docker by default.</li>\n<li>Drops support for puppeteer <code>1.15.0</code> and adds <code>1.19.0</code>.</li>\n<li>Web-based debugger now sends cookies for docker deployments that are secure.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.10.0...v1.11.0\">1.11.0</a></h1>\n<ul>\n<li>Live debugger is now self-hosted, no more enforced https though it&#39;s still recommended.</li>\n<li>Consolidated build steps.</li>\n<li>Using the same chromedriver binary that matches the puppeteer&#39;s bundled chromium.</li>\n<li>Introducing <code>trackingId</code> workflows.</li>\n<li>Fixing unused export&#39;s, removing extraneous internal methods.</li>\n<li><code>/workspace</code> API now returns sub-files and scopes sessions by <code>trackingId</code> when present.</li>\n<li>Support for <code>/json/new</code> protocol.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.9.0...v1.10.0\">1.10.0</a></h1>\n<ul>\n<li>Dropped support for puppeteer <code>1.9.0 =&gt; 1.14.0</code>.</li>\n<li>Added support for puppeteer <code>1.16.0 =&gt; 1.18.0</code>.</li>\n<li>A version of chromedriver is now installed to perfectly match the version of puppeteer&#39;s chromium.</li>\n<li>In dev, chromedriver now uses the puppeteer version of chromium.</li>\n<li>Defaulted most ENV-variables in docker to sensible defaults.</li>\n<li>New <code>rotate</code> feature for PDF endpoint: <code>{ rotate: 90 }</code> =&gt; rotate left 90 degrees.</li>\n<li>Support for <code>browserless.token</code> in the docker image.</li>\n<li>puppeteer integration now returns semantic HTTP codes for certain errors (<code>400</code>, <code>403</code> and <code>429</code>).</li>\n<li>Support for chromedriver&#39;s move to the W3C spec &#39;goog:chromeOptions&#39;.</li>\n<li>The debugger now filters out <code>about:blank</code> pages, and includes sessions by Selenium.</li>\n<li>Workspace support for selenium-based integrations.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.8.0...v1.9.0\">1.9.0</a></h1>\n<ul>\n<li>Better handling of browser/socket closing in puppeteer integrations.</li>\n<li>Numerous screencast fixes.</li>\n<li>Moved all GH links to new repo location.</li>\n<li>Dep updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.7.0...v1.8.0\">1.8.0</a></h1>\n<ul>\n<li>Better windows dev experience.</li>\n<li>Indian font support.</li>\n<li>Video capture now supports audio and browser width/height.</li>\n<li>Dependency updates.</li>\n<li>DEFAULT env variables for launching pre-booted Chrome.</li>\n</ul>\n<h1>1.7.0</h1>\n<ul>\n<li>Dep updates</li>\n<li>New <code>?blockAds</code> query-parameter for disabling 3rd-party ad calls.</li>\n</ul>\n<h1>1.6.0</h1>\n<ul>\n<li>New <code>authenticate</code> and <code>setExtraHTTPHeaders</code> params for the <code>content</code>, <code>pdf</code>, and <code>screenshot</code> APIs. Useful for using proxies in our REST APIs.</li>\n<li>Fixed a bunch of bugs inside of the webdriver integration, making it more REST-ful.</li>\n<li>Updated dependencies inside of Chromedriver.</li>\n<li>New <code>DISABLE_AUTO_SET_DOWNLOAD_BEHAVIOR</code> for mitigating errors in puppeteer &lt; 1.15.0.</li>\n<li>Bumped Puppeteer to 1.15.0.</li>\n</ul>\n<h1>1.5.0</h1>\n<ul>\n<li>New <code>/session</code> API (and accompanying routes) for display/viewing active sesions in a remote debugger(!).</li>\n<li>New <code>?pause</code> query-param for pausing sessions prior to running them (useful for the live debug viewer).</li>\n<li>The browserless debugger now exposes links to these debug pages via the sidebar.</li>\n<li>New Debugger page can be disabled via the <code>ENABLE_DEBUG_VIEWER=false</code> environment variable flag.</li>\n<li>Move to use <code>node@10</code>.</li>\n<li>No more <code>no-implicit-any</code>&#39;s inside the codebase.</li>\n</ul>\n<h1>1.4.0</h1>\n<ul>\n<li>During connection, we now set the download dir of REST and puppeteer sessions. Cloud users and docker users no longer have to manually set this field, and the <code>/workspace</code> API references it as well!</li>\n</ul>\n<h1>1.3.1</h1>\n<h1>Fixes</h1>\n<ul>\n<li>New deploy.js file to do deployments &quot;on-prem&quot;</li>\n<li>Updated new builds for puppeteer 1.12.2 and 1.13.0</li>\n<li>Fixes an issues in CORS handling</li>\n</ul>\n<h1>1.3.0</h1>\n<h1>Minor changes</h1>\n<ul>\n<li>The <code>screenshot</code>, <code>function</code>, <code>pdf</code>, and <code>content</code> API&#39;s now accept new content-types for easier POSTing of small payloads (see docsite).</li>\n<li>The <code>screencast</code> API can now start/stop recording programmatically via a <code>startScreencast</code> and <code>stopScreencast</code> params (see docsite).</li>\n<li>New <code>external</code> dir for injecting custom <code>before</code> and <code>after</code> hooks in external docker builds.</li>\n<li>A new <code>timeout</code> query-option for session-based timeouts vs using the global one.</li>\n<li>New <code>requestInterceptors</code> for injection custom request behavior.</li>\n</ul>\n<h1>Fixes</h1>\n<ul>\n<li>Numerous default fixes in the APIs.</li>\n<li>Stray consoles removed :)</li>\n<li>Consolidated download behavior in <code>screencast</code> and <code>download</code> APIs</li>\n</ul>\n<h1>1.2.0</h1>\n<h1>Minor Changes</h1>\n<ul>\n<li>New <code>requestInterceptors</code> for the /screenshot API, <a href=\"https://github.com/browserless/chrome/pull/119\">allowing you to mock data in response to a request</a>.</li>\n<li>Code debugger now transmits code over-the-wire via cookies to avoid URL max-length issues.</li>\n<li>Now supports cookie-based authentication via a <code>browserless_token=TOKEN;</code> cookie.</li>\n</ul>\n<h1>Fixes</h1>\n<ul>\n<li><a href=\"https://github.com/browserless/chrome/issues/118\">Comments in the debugger won&#39;t break it.</a></li>\n<li>Requests that are rejected due to auth reasons aren&#39;t logged in stats.</li>\n</ul>\n<h1>1.1.0</h1>\n<p>With 1.1.0 we offer a refined way of dealing with both downloads and uploads. Both use-cases are tightly coupled to the file-system, and can leave you scratching your head as to what&#39;s going one. For more information and detailed documentation, please refer to our doc-site at <a href=\"https://www.browserless.io/\">https://www.browserless.io/</a></p>\n<h2>Minor Changes</h2>\n<ul>\n<li>New <code>WORKSPACE_DIR</code> variable for controlling where browserless stores files and uploads.</li>\n<li>New <code>/workspace</code> API for doing RESTful operations on the downloads/uploads file-system.</li>\n<li>New <code>/download</code> API for running a puppeteer-script, and responding with the resulting downloaded file.</li>\n</ul>\n<h2>Internal Changes</h2>\n<ul>\n<li>Moved routes out of the browserless module and into their own file/module.</li>\n<li>Renamed the <code>browserless-web-service</code> module to just <code>browserless</code> for simplicity.</li>\n<li>Moved the <code>DOWNLOAD_DIR</code> to <code>WORKSPACE_DIR</code> since it handles both uploads and downloads.</li>\n</ul>\n<h1>1.0.0</h1>\n<p>🥁 -- Stable version 1.0 is here! While this doesn&#39;t include major functionality changes, it <em>does</em> change how the docker builds are generated going forward. The versioning will now contain two pieces of crucial information: the version of the <em>browserless</em> service + the version of Chrome under-the-hood. For instance <code>1.2.3-puppeteer-1.10.0</code> is browserless at <code>1.2.3</code>, exposing puppeteer at <code>1.10.0</code>.</p>\n<p>Similar to how NodeJS itself does docker releases, we&#39;ll now provide releases in 3 distinct ways:</p>\n<ul>\n<li>An <em>immutable</em>, pinned version release: <code>1.0.0-puppeteer-1.11.0</code></li>\n<li>A mutable minor version release: <code>1.1-puppeteer-1.12.0</code></li>\n<li>A mutable major version release: <code>1-puppeteer-1.9.0</code></li>\n</ul>\n<p>For production deployments, we recommend using <em>pinned</em> version releases as they won&#39;t change once released. The mutable minor/major releases will receive on-going updates whenever we do changes that are bug-fixes or feature release. Even with the best intentions it&#39;s possible that instability can be introduced with these mutable images, hence why recommend the pinned version releases.</p>\n<p>Finally, we&#39;ll continue to ship support for the last 5 minor versions of Puppeteer + the Google Chrome (stable). Old images will remain, but newer versions of browserless won&#39;t be included.</p>\n<p>We&#39;ll continue to keep this changelog up-to-date anytime we do docker releases.</p>\n"
992
+ "description": "<!-- markdownlint-disable commands-show-output first-line-h1 no-emphasis-as-heading no-inline-html -->\n\n<div align=\"center\">\n <a href=\"https://browserless.io\" align=\"center\">\n <center align=\"center\">\n <picture>\n <source media=\"(prefers-color-scheme: dark)\" srcset=\"./assets/logo-white.svg\" width=\"600\">\n <source media=\"(prefers-color-scheme: light)\" srcset=\"./assets/logo.svg\" width=\"600\">\n <img src=\"./assets/logo.svg\" alt=\"Browserless logo\" width=\"600\">\n </picture>\n </center>\n </a>\n <br>\n <h3 align=\"center\"><center>Deploy headless browsers in Docker. Run on our cloud or bring your own.</center></h3>\n <br>\n <center>\n <a href=\"https://hub.docker.com/r/browserless/chrome\">\n <img src=\"https://img.shields.io/docker/pulls/browserless/chrome\" alt=\"Docker pulls\" />\n </a>\n <a href=\"https://github.com/browserless/browserless/tags\">\n <img src=\"https://img.shields.io/github/package-json/v/browserless/chrome\" alt=\"Version\" />\n </a>\n </center>\n <br>\n <center>\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-chromium.yml/badge.svg\" alt=\"Chromium build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-firefox.yml/badge.svg\" alt=\"Firefox build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-webkit.yml/badge.svg\" alt=\"Webkit build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-edge.yml/badge.svg\" alt=\"Edge build\" />\n <img src=\"https://github.com/browserless/chrome/actions/workflows/docker-multi.yml/badge.svg\" alt=\"Mulltibrowser build\" />\n </center>\n <br>\n <hr>\n <br>\n</div>\n\n> [!NOTE] \n> Looking to bypass bot detectors and solve captchas? [We would recommend using BrowserQL as our stealthiest option](https://www.browserless.io/feature/browserql).\n\nBrowserless allows remote clients to connect and execute headless work, all inside of docker. It supports the standard, unforked Puppeteer and Playwright libraries, as well offering REST-based APIs for common actions like data collection, PDF generation and more.\n\nWe take care of common issues such as missing system-fonts, missing external libraries, and performance improvements, along with edge-cases like downloading files and managing sessions. For details, check out the documentation site built into the project which includes Open API docs.\n\nIf you've been struggling to deploy headless browsers without running into issues or bloated resource requirements, then Browserless was built for you. Run the browsers in [our cloud](https://browserless.io/) or your own, [free for non-commercial uses](https://github.com/browserless/browserless#licensing).\n\n## Table of Contents\n\n- [External links](#external-links)\n- [Features](#features)\n- [How it works](#how-it-works)\n - [Docker](#docker)\n - [Hosting Providers](#hosting-providers)\n - [Puppeteer](#puppeteer)\n - [Playwright](#playwright)\n- [Extending (NodeJS SDK)](#extending-nodejs-sdk)\n- [Debugger](#debugger)\n - [Install debugger](#install-debugger)\n- [Usage with other libraries](#usage-with-other-libraries)\n- [Motivations](#motivations)\n- [Licensing](#licensing)\n\n## External links\n\n1. [Full documentation site](https://docs.browserless.io/)\n2. [Live Debugger (using browserless.io)](https://chrome.browserless.io/)\n3. [Docker](https://github.com/browserless/browserless/pkgs/container/base)\n\n## Features\n\n### General\n\n- Parallelism and request-queueing are built-in + configurable.\n- Fonts and emoji's working out-of-the-box.\n- Debug Viewer for actively viewing/debugging running sessions.\n- An interactive puppeteer debugger, so you can see what the headless browser is doing and use its DevTools.\n- Works with unforked Puppeteer and Playwright.\n- Configurable session timers and health-checks to keep things running smoothly.\n- Error tolerant: if Chrome dies it won't.\n- Support for running and development on Apple's M1 machines\n\n### Cloud-only\n\nOur [cloud accounts](https://www.browserless.io/pricing/) include all the general features plus extras, such as:\n\n- [BrowserQL](https://www.browserless.io/feature/browserql) for avoiding detectors and solving captchas\n- [Hybrid automations](https://www.browserless.io/blog/hybrid-automations-for-puppeteer/) for streaming login windows during scripts\n- [/reconnect API](https://www.browserless.io/blog/reconnect-api) for keeping browsers alive for reuse\n- [REST APIs](https://www.browserless.io/feature/rest-apis) for tasks such as retrieving HTML, PDFs or Lighthouse metrics\n- Inbuilt [residential proxy](https://www.browserless.io/blog/residential-proxying/)\n- SSO, tokens and user roles\n\n## How it works\n\nBrowserless listens for both incoming websocket requests, generally issued by most libraries, as well as pre-build REST APIs to do common functions (PDF generation, images and so on). When a websocket connects to Browserless it starts Chrome and proxies your request into it. Once the session is done then it closes and awaits for more connections. Some libraries use Chrome's HTTP endpoints, like `/json` to inspect debug-able targets, which Browserless also supports.\n\nYou still execute the script itself which gives you total control over what library you want to choose and when to do upgrades. This also comes with the benefit of keep your code proprietary and able to run on numerous platforms. We simply take care of all the browser-aspects and offer a management layer on top of the browser.\n\n### Docker\n\n> [!TIP]\n> See more options on our [full documentation site](https://docs.browserless.io/baas/docker/quickstart).\n\n1. `docker run -p 3000:3000 ghcr.io/browserless/chromium`\n2. Visit `http://localhost:3000/docs` to see the documentation site.\n3. See more at our [docker package](https://github.com/browserless/browserless/pkgs/container/base).\n\n### Hosting Providers\n\nWe offer a first-class hosted product located [here](https://browserless.io). Alternatively you can host this image on just about any major platform that offers hosting for docker. Our hosted service takes care of all the machine provisioning, notifications, dashboards and monitoring plus more:\n\n- Easily upgrade and toggle between versions at the press of a button. No managing repositories and other code artifacts.\n- Never need to update or pull anything from docker. There's literally zero software to install to get started.\n- Scale your consumption up or down with different plans. We support up to thousands of concurrent sessions at a given time.\n\nIf you're interested in using this image for commercial aspects, then please read the below section on licensing.\n\n### Puppeteer\n\nPuppeteer allows you to specify a remote location for chrome via the `browserWSEndpoint` option. Setting this for Browserless is a single line of code change.\n\n**Before**\n\n```js\nconst browser = await puppeteer.launch();\n```\n\n**After**\n\n```js\nconst browser = await puppeteer.connect({\n browserWSEndpoint: 'ws://localhost:3000',\n});\n```\n\n### Playwright\n\nWe support running with playwright via their browser's remote connection protocols interface out of the box. Just make sure that your Docker image, playwright browser type _and_ endpoint match:\n\n**Before**\n\n```js\nimport pw from 'playwright';\nconst browser = await pw.firefox.launch();\n```\n\n**After**\n\n```sh\ndocker run -p 3000:3000 ghcr.io/browserless/firefox\n# or ghcr.io/browserless/multi for all the browsers\n```\n\n```js\nimport pw from 'playwright-core';\n\nconst browser = await pw.firefox.connect(\n 'ws://localhost:3000/firefox/playwright',\n);\n```\n\nAfter that, the rest of your code remains the same with no other changes required.\n\n## Extending (NodeJS SDK)\n\nBrowserless comes with built-in extension capabilities, and allows for extending nearly any aspect of the system (for Version 2+). For more details on how to write your own routes, build docker images, and more, [see our SDK README.md](/bin/scaffold/README.md) or simply run \"npx @browserless.io/browserless create\" in a terminal and follow the onscreen prompts.\n\n## Debugger\n\nYou can install a first-party interactive debugger for Browserless, that makes writing scripts faster and interactive. You can take advantage of things like `debugger;` calls and the page's console output to see what's happening on the page while your script is running. All of the Chrome devtools are there at your disposal.\n\n![browserless.io logo](/assets/debugger.png)\n\nA small list of features includes:\n\n- Running `debugger;` and `console.log` calls\n- Errors in the script are caught and show up in the console tab\n- DOM inspection, watch network requests, and even see how the page is rendering\n- Exporting you debugging script as a Node project\n- Everything included in Chrome DevTools\n\n### Install debugger\n\nInstalling the debugger is as simple as running the `install:debugger` script _after_ the project has been built. This way:\n\n```sh\n$ npm run build\n$ npm run install:debugger #or npm install:dev\n```\n\nYou will then see the debugger url during the startup process.\n\n```log\n---------------------------------------------------------\n| browserless.io\n| To read documentation and more, load in your browser:\n|\n| OpenAPI: http://localhost:3000/docs\n| Full Documentation: https://docs.browserless.io/\n| Debbuger: http://localhost:3000/debugger/?token=6R0W53R135510\n---------------------------------------------------------\n```\n\n## Usage with other libraries\n\nMost libraries allow you to specify a remote instance of Chrome to interact with. They are either looking for a websocket endpoint, a host and port, or some address. Browserless supports these by default, however if you're having issues please make an issue in this project and we'll try and work with the library authors to get them integrated with browserless. Please note that in V2 we no longer support selenium or webdriver integrations.\n\nYou can find a much larger list of supported libraries [on our documentation site](https://docs.browserless.io/libraries/puppeteer).\n\n## Motivations\n\nRunning Chrome on lambda or on your own is a fantastic idea but in practice is quite challenging in production. You're met with pretty tough cloud limits, possibly building Chrome yourself, and then dealing with odd invocation issues should everything else go ok. A lot of issues in various repositories are due to just challenges of getting Chrome running smoothly in AWS (see [here](https://github.com/GoogleChrome/puppeteer/issues?q=is%3Aissue+is%3Aopen+sort%3Acomments-desc)). You can see for yourself by going to nearly any library and sorting issues by most commented.\n\nGetting Chrome running well in docker is also a challenge as there's quiet a few packages you need in order to get Chrome running. Once that's done then there's still missing fonts, getting libraries to work with it, and having limitations on service reliability. This is also ignoring CVEs, access-controls, and scaling strategies.\n\nAll of these issues prompted us to build a first-class image and workflow for interacting with Chrome in a more streamlined way. With Browserless you never have to worry about fonts, extra packages, library support, security, or anything else. It just works reliably like any other modern web service. On top of that it comes with a prescribed approach on how you interact with Chrome, which is through socket connections (similar to a database or any other external appliance). What this means is that you get the ability to drive Chrome remotely without having to do updates/releases to the thing that runs Chrome since it's divorced from your application.\n\n## Licensing\n\nSPDX-License-Identifier: SSPL-1.0 OR Browserless Commercial License.\n\nIf you want to use Browserless to build commercial sites, applications, or in a continuous-integration system that's closed-source then you'll need to purchase a commercial license. This allows you to keep your software proprietary whilst still using browserless. [You can purchase a commercial license here](https://www.browserless.io/contact). A commercial license grants you:\n\n- Priority support on issues and features.\n- On-premise running as well as running on public cloud providers for commercial/CI purposes for proprietary systems.\n- Ability to modify the source (forking) for your own purposes.\n- A new admin user-interface.\n\nNot only does it grant you a license to run such a critical piece of infrastructure, but you are also supporting further innovation in this space and our ability to contribute to it.\n\nIf you are creating an open source application under a license compatible with the Server Side License 1.0, you may use Browserless under those terms.\n\n# Changelog\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.38.2...main\">Latest</a></h1>\n<h1><a href=\"https://github.com/browserless/browserless/compare/v2.38.1...v2.38.2\">v2.38.2</a></h1>\n<ul>\n<li>Standardizes on how path parsing works internally, exports the utility as well.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.26.1</code></li>\n<li>playwright-core: <code>1.56.1</code>, <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, and <code>1.52.0</code>.</li>\n<li>Chromium: <code>141.0.7390.37</code></li>\n<li>Chrome: <code>141.0.7390.123</code> (amd64 only)</li>\n<li>Firefox: <code>142.0.1</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>141.0.3537.99</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/browserless/compare/v2.38.0...v2.38.1\">v2.38.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bugfix when a trailing slash is present in /function API call.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.26.1</code></li>\n<li>playwright-core: <code>1.56.1</code>, <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, and <code>1.52.0</code>.</li>\n<li>Chromium: <code>141.0.7390.37</code></li>\n<li>Chrome: <code>141.0.7390.123</code> (amd64 only)</li>\n<li>Firefox: <code>142.0.1</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>141.0.3537.99</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.37.1...v2.38.0\">v2.38.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.26.1</code></li>\n<li>playwright-core: <code>1.56.1</code>, <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, and <code>1.52.0</code>.</li>\n<li>Chromium: <code>141.0.7390.37</code></li>\n<li>Chrome: <code>141.0.7390.123</code> (amd64 only)</li>\n<li>Firefox: <code>142.0.1</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>141.0.3537.99</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.37.1...v2.37.0\">v2.37.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Handling of <code>ignoreHTTPSErrors</code> to <code>acceptInsecureCerts</code>.</li>\n<li>Smaller fixes, testing updates, and graceful shutdown handling.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.23.0</code></li>\n<li>playwright-core: <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, <code>1.52.0</code>, and <code>1.51.1</code>.</li>\n<li>Chromium: <code>140.0.7339.16</code></li>\n<li>Chrome: <code>141.0.7390.66</code> (amd64 only)</li>\n<li>Firefox: <code>141.0</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>141.0.3537.57</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.36.0...v2.37.0\">v2.37.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Adds a new <code>/function/connect</code> route to distinguish function API calls and not have them add to concurrency.</li>\n<li>Fix installs in SDK projects not working.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.22.3</code></li>\n<li>playwright-core: <code>1.55.1</code>, <code>1.54.2</code>, <code>1.53.2</code>, <code>1.52.0</code>, and <code>1.51.1</code>.</li>\n<li>Chromium: <code>140.0.7339.16</code></li>\n<li>Chrome: <code>140.0.7339.214</code> (amd64 only)</li>\n<li>Firefox: <code>141.0</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>140.0.3485.94</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.34.1...v2.36.0\">v2.36.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Updates base image to Ubuntu <code>24.04</code>.</li>\n<li>Updates NodeJS to <code>24.8.0</code>.</li>\n<li>Move to <code>npm ci</code> for automated tests and release processes.</li>\n<li>Small cleanup in dockerfiles for consistency.</li>\n<li>Added a <code>npm run coverage</code> command for determining areas of code needing coverage.</li>\n<li><code>bestAttempt</code> fixes in the <code>/scrape</code> API.</li>\n<li>Fixes a few OpenAPI issues in the swagger.json manifests.</li>\n<li>Fixes issues where install-adblock can fail.</li>\n<li>Updated messaging around concurrency limits being reached.</li>\n<li>Few more unit-tests.</li>\n<li>Supports the following libraries and browsers:<ul>\n<li>puppeteer-core: <code>24.22.0</code></li>\n<li>playwright-core: <code>1.55.0</code>, <code>1.54.2</code>, <code>1.53.2</code>, <code>1.52.0</code>, and <code>1.51.1</code>.</li>\n<li>Chromium: <code>140.0.7339.16</code></li>\n<li>Chrome: <code>140.0.7339.186</code> (amd64 only)</li>\n<li>Firefox: <code>141.0</code></li>\n<li>Webkit: <code>26.0</code></li>\n<li>Edge: <code>140.0.3485.81</code> (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.34.0...v2.34.1\">v2.34.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an issue with absolute path in swagger.json docs.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.33.0...v2.34.0\">v2.34.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>README spelling fixes.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.16.0</code>.</li>\n<li>Bumps <code>playwright-core</code> to <code>1.54.2</code>.</li>\n<li>Updates the /pressure API to return a <code>503</code> error when under load and the <code>Accept</code> header is <code>text/plain</code>. All other headers for &quot;Accept&quot; are treated similarly.</li>\n<li>Internally, when Authorization is sent via the <code>token</code> query-parameter, browserless now migrates it to a more secure <code>Authorization</code> header before processing the request. This prevents accidental logging in source as well as SDK projects.</li>\n<li>Supports a <code>before</code> hook in routes so that pre-route logic can be applied before the request is handled by the route.</li>\n<li>Fixes an issue in API&#39;s where a <code>requestInterceptor</code> has a <code>body</code> with base64 encoded content. This is now properly handled and fulfills the request.</li>\n<li>Minor internal changes and spec file updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.32.1...v2.33.0\">v2.33.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix <code>page</code>&#39;s created by playwright&#39;s <code>context</code> object hanging.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.12.1</code>.</li>\n<li>Bumps <code>playwright-core</code> to <code>1.54.1</code>.</li>\n<li>Drops support for <code>playwright-core</code> at <code>1.49</code>.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.12.1</li>\n<li>playwright-core: 1.54.1, 1.53.1, 1.52.0, and 1.50.1</li>\n<li>Chromium: 139.0.7258.5</li>\n<li>Chrome: 138.0.7204.101 (amd64 only)</li>\n<li>Firefox: 140.0.2</li>\n<li>Webkit: 26.0</li>\n<li>Edge: 138.0.3351.83 (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.32.0...v2.32.1\">v2.32.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an in request shimming when no params are sent.</li>\n<li>Fixes an issue in OpenAPI JSON schema parsing on routes with <code>.d</code> in their name.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.31.1...v2.32.0\">v2.32.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump nodeJS to 24.2.0.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.10.2</code>.</li>\n<li>Bumps <code>playwright-core</code> to <code>1.53.1</code>.</li>\n<li>Drops support for <code>playwright-core</code> at <code>1.48</code>.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.10.2</li>\n<li>playwright-core: 1.53.1, 1.52.0, 1.50.1, and 1.49.1</li>\n<li>Chromium: 138.0.7204.23</li>\n<li>Chrome: 137.0.7151.120 (amd64 only)</li>\n<li>Firefox: 139.0</li>\n<li>Webkit: 18.5</li>\n<li>Edge: 137.0.3296.93 (amd64 only)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.31.0...v2.31.1\">v2.31.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an issue where ARM64 Platforms attempt to load non-compatible routes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.30.1...v2.31.0\">v2.31.0</a></h1>\n<ul>\n<li>Dependency updates -- including fix for tar-fs.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.10.0</code>.</li>\n<li>Remove stray console.log&#39;s in route building.</li>\n<li>Fixes for duplicative user-data-dir flags (fixes CI issues).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.30.0...v2.30.1\">v2.30.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Cleans up the embedded Open API docs.</li>\n<li>Prettier</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.29.0...v2.30.0\">v2.30.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bumps <code>puppeteer-core</code> to <code>24.8.2</code>.</li>\n<li>Fixes a small issue in SDK OpenAPI docgen when overwriting an existing route.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.28.0...v2.29.0\">v2.29.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>The <code>build</code> command for SDK projects will no longer run <code>clean</code> prior.</li>\n<li>On startup, browserless will check dependencies and log if a browser isn&#39;t available for that platform. This only effects non-macOS arm64 platform Chrome and Edge routes. Prior to this an error would cause the application to quit at startup.</li>\n<li>Fixes for running Chrome and Chromium &quot;non-headless&quot; in playwright.</li>\n<li>Formatting, and stray console message cleanup.</li>\n<li>Logo fixes in README.md file.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.27.0...v2.28.0\">v2.28.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Propagate library process exit codes through for SDK project commands.</li>\n<li>Better error messaging when queuing and concurrency are full.</li>\n<li>No browser binary changes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.26.1...v2.27.0\">v2.27.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>MAX_PAYLOAD_SIZE</code> env variable for specifying a max-payload size in HTTP-based APIs. Value is a number specified in bytes, so <code>10485760</code> = 10MB.</li>\n<li>Consolidation of HTTP and Websocket Error handling into a singular method.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.26.0...v2.26.1\">v2.26.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix http routes being ignored in SDK projects.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.25.2...v2.26.0\">v2.26.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Moves relevant ad-blocking infrastructure over to uBlock Lite.</li>\n<li>You can now supply a glob-pattern for the <code>CORS_ALLOW_ORIGIN</code> parameter in order to support multiple domains and URLs. When a domain doesn&#39;t match, browserless will return a 404.</li>\n<li>Support for IPv6 when running on <code>::</code>.</li>\n<li>SDK projects will now ignore files found in <code>node_modules</code>, <code>dist</code>, <code>.next</code>, <code>.cache</code>, or <code>coverage</code>.</li>\n<li>New <code>isMatch</code> utility to do glob pattern matching in SDK and other projects.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.4.0</li>\n<li>playwright-core: 1.51.1, 1.50.1, 1.49.1, 1.48.2, and 1.47.2</li>\n<li>Chromium: 134.0.6998.35</li>\n<li>Chrome: 134.0.6998.166</li>\n<li>Firefox: 135.0</li>\n<li>Webkit: 18.4</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.25.1...v2.25.2\">v2.25.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes to the <code>/session</code> API to include proper host and port.</li>\n<li>Bumping timeout for certain unit-tests.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.3.0</li>\n<li>playwright-core: 1.50.1, 1.49.1, 1.48.2, 1.47.2, and 1.46.1.</li>\n<li>Chromium: 133.0.6943.16</li>\n<li>Chrome: 133.0.6943.127</li>\n<li>Firefox: 134.0</li>\n<li>Webkit: 18.2</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.25.0...v2.25.1\">v2.25.1</a></h1>\n<ul>\n<li>Removes edge from <code>arm64</code> builds due to lack of support.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.3...v2.25.0\">v2.25.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 24.2.1</li>\n<li>playwright-core: 1.50.1, 1.49.1, 1.48.2, 1.47.2, and 1.46.1.</li>\n<li>Chromium: 133.0.6943.16</li>\n<li>Chrome: 133.0.6943.127</li>\n<li>Firefox: 134.0</li>\n<li>Webkit: 18.2</li>\n</ul>\n</li>\n<li>Pins playwright and puppeteer deps in package.json for browser-version consistency in SDK projects</li>\n<li>Added support for Edge browser! <a href=\"https://github.com/orgs/browserless/packages\">Check out available packages here.</a></li>\n<li>Fixes headers object in the /scrape API</li>\n<li>Code formatting fixes</li>\n<li>Link fixes in certain READMEs</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.2...v2.24.3\">v2.24.3</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Pins <a href=\"mailto:Ubuntu@22.04\">Ubuntu@22.04</a> in Github Actions.</li>\n<li>Fixes <code>headless</code> types to use <code>--headless=new</code> when prior libraries attempt to do <code>--headless=old</code> (older playwright).</li>\n<li>Typing fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.1...v2.24.2\">v2.24.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix issues with Firefox when using a proxy.</li>\n<li>Fixes for the <code>/meta</code> API in SDK projects.</li>\n<li>Lint fixes.</li>\n<li>Link fixes in this CHANGELOG.md file.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.24.0...v2.24.1\">v2.24.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes for /performance API in SDK projects.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.23.0...v2.24.0\">v2.24.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 23.10.1.</li>\n<li>playwright-core: 1.49.0, 1.48.2, 1.47.2, 1.46.1, 1.45.3 and 1.44.1.</li>\n<li>Chromium: 131.0.6778.33.</li>\n<li>Chrome: 131.0.6778.109.</li>\n<li>Firefox: 132.0.</li>\n<li>Webkit: 18.2.</li>\n</ul>\n</li>\n<li>New <code>/meta</code> API route for getting details about the container (versions, etc).</li>\n<li>Bump NodeJS to <code>v22.11.0</code>.</li>\n<li>Add <code>libwebp-dev</code> for Webkit.</li>\n<li>Add support for <code>trackingId</code> and <code>/kill/{id}</code> and <code>/kill/all</code>.</li>\n<li>Prettier, internal fixes and improvements.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.22.0...v2.23.0\">v2.23.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes <code>--proxy-bypass-list</code> CLI arguments not being passed through with function API.</li>\n<li>Addition of <code>fonts-open-sans</code> to image.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.21.1...v2.22.0\">v2.22.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New SDK project command of <code>npm run install:browsers</code> to help with browser management.</li>\n<li>SDK projects now appropriately handle routes when only certain browsers are available.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.21.0...v2.21.1\">v2.21.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Ensure we don&#39;t load Chrome routes for SDK projects running linux/arm64.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.20.2...v2.21.0\">v2.21.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports:<ul>\n<li>puppeteer-core: 23.4.1</li>\n<li>playwright-core: 1.47.2, 1.46.1, 1.45.3, 1.44, and 1.43.</li>\n</ul>\n</li>\n<li>Stream PDF using createPDFStream() in the PDF APIs.</li>\n<li>Inject file-system managers in browser-manager.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.20.1...v2.20.2\">v2.20.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Adds a fix to SDK routes that might not require a browser but browserless will still make one.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.20.0...v2.20.1\">v2.20.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix issues where connecting to a bad /devtools/page route can cause 500&#39;s.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.19.0...v2.20.\">v2.20.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports <code>puppeteer@23.3.0</code>.</li>\n<li>Support <code>playwright@1.47.0</code>.</li>\n<li>Use installed playwright-core for downloading browser binaries instead of <code>npx</code>, ensuring the appropriate browsers are installed.</li>\n<li>Fix JSON routes 404-ing when charset is specified in the content-type header.</li>\n<li>Disable the built-in debugger by setting <code>ENABLE_DEBUGGER=false</code>.</li>\n<li>Automatically run prettier on file save in VS Code.</li>\n<li>Windows fixes for SDK projects.</li>\n<li>README link fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.18.0...v2.19.0\">v2.19.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Drop <code>sort-keys</code> for eslint integrations.</li>\n<li>Fix devtools URLs when <code>PROXY</code> is set and contains a path.</li>\n<li>Disable <code>auth</code> when using Chrome&#39;s internal <code>/page</code> APIs.</li>\n<li>Small fixes for new eslint rules.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.17.0...v2.18.0\">v2.18.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Supports <code>puppeteer-core@23.1.1</code>.</li>\n<li>Supports <code>playwright-core@1.46.1, 1.44.1, 1.43.1, 1.42.1, 1.41.2</code>.</li>\n<li>Trailing slashes on routes now won&#39;t 404, so <code>/chrome</code> and <code>/chrome/</code> are treated as the same and will route properly.</li>\n<li><code>/function</code> API now works properly when applying a 3rd-party proxy.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.16.1...v2.17.0\">v2.17.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Hide token in logs on startup.</li>\n<li>Fixes an issue where using <code>--proxy-server</code> now works with /function-API calls.</li>\n<li>Adds support for the following CORS headers via env variables (headers and their corresponding config names are below). <em>Please note that these are very permissive by default, but only set when <code>ENABLE_CORS</code> is <code>true</code>!</em><ul>\n<li>&#39;Access-Control-Allow-Credentials&#39;: CORS_ALLOW_CREDENTIALS (default &#39;*&#39;)</li>\n<li>&#39;Access-Control-Allow-Headers&#39;: CORS_ALLOW_HEADERS (default: &#39;*&#39;)</li>\n<li>&#39;Access-Control-Allow-Methods&#39;: CORS_ALLOW_METHODS (default: &#39;OPTIONS, POST, GET&#39;)</li>\n<li>&#39;Access-Control-Allow-Origin&#39;: CORS_ALLOW_ORIGIN (default: &#39;*&#39;)</li>\n<li>&#39;Access-Control-Expose-Headers&#39;: CORS_EXPOSE_HEADERS (default: &#39;*&#39;)</li>\n<li>&#39;Access-Control-Max-Age&#39;: CORS_MAX_AGE (default: &#39;2592000&#39;)</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.16.0...v2.16.1\">v2.16.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes numerous SDK issues when creating and building new projects.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.15.0...v2.16.0\">v2.16.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Better extension handling and merging when passing in custom extensions.</li>\n<li>Fixes a bug where a failed job (error thrown) causes the internal queue to drain.</li>\n<li>Prettier and other source improvements.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.14.0...v2.15.0\">v2.15.0</a></h1>\n<ul>\n<li>Bug fix to avoid removing healthy jobs from limiter when a job fails</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.13.0...v2.14.0\">v2.14.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Merged duplicate code in browsers and fixed name <code>WebkitPlaywright</code> to <code>WebKitPlaywright</code> (capitalized &quot;K&quot;).</li>\n<li>Devtools now bundled into the repository at build-time for the <code>/debugger</code> route.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.12.0...v2.13.0\">v2.13.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>The <code>browser</code> hook now gets the <code>req</code> property for the full request instead of <code>meta</code>.</li>\n<li>Now embeds the debugger located at <code>/debugger</code>.</li>\n<li>Preliminary support for <code>trackingId</code>.</li>\n<li>Bug fixes when dealing with ignoreHTTPSError parameters.</li>\n<li>Bug fixes to the /function API when it throws errors.</li>\n<li>Prettier fixes.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.11.0...v2.12.0\">v2.12.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>SDK projects should now use conventional class method properties versus the &quot;fat-arrow&quot; style instance methods.</li>\n</ul>\n<p><strong>Updates</strong></p>\n<ul>\n<li>Support for multi-version playwright (puppeteer coming soon). Browserless now checks the version in the User-Agent header and loads the appropriate playwright server for it.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.10.0...v2.11.0\">v2.11.0</a></h1>\n<ul>\n<li>Wrap the pressure response in a pressure key.</li>\n<li>New <code>keepAlive</code> property on browser objects for downstream SDK projects to flag.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.9.0...v2.10.0\">v2.10.0</a></h1>\n<ul>\n<li>Adds back in the <code>/pressure</code> API from V1.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.8.0...v2.9.0\">v2.9.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Debugger is now included and mounted under the <code>/debugger</code> path.</li>\n<li>Browserless now uses the <code>Logger</code> utility internally. Better logs for certain classes as well.</li>\n<li>Fix number of connected clients when using the Page websocket route.</li>\n<li>Allows &quot;HEAD&quot; requests for most &quot;GET&quot;-based APIs.</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.7.1...v2.8.0\">v2.8.0</a></h1>\n<p><strong>April 12, 2024</strong>\n<strong>Potentially Breaking</strong></p>\n<ul>\n<li>New <code>Logger</code> class and SDK primitives in support of that.</li>\n<li>Routes now get an instance of <code>Logger</code>, before the <code>browser</code> argument or as the last argument for HTTP routes.</li>\n</ul>\n<p><strong>Updates</strong></p>\n<ul>\n<li>Numerous SDK fixes and updates in the CLI.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.7.0...v2.7.1\">v2.7.1</a></h1>\n<p><strong>April 11, 2024</strong></p>\n<ul>\n<li>Fixes a boot-looping issue due to bad startup script. Adds tests for this as well.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.6.1...v2.7.0\">v2.7.0</a></h1>\n<ul>\n<li>Support for Running GPUs</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.6.0...v2.6.1\">v2.6.1</a></h1>\n<ul>\n<li>Fixes for function API calls when behind an external URL.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.5.0...v2.6.0\">v2.6.0</a></h1>\n<ul>\n<li>Adds a <code>GET /active</code> route that responds with no message and a <code>204</code> http code.</li>\n<li>Move to NodeJS 20.12.0.</li>\n<li>README, CHANGELOG, Migration and spelling fixes.</li>\n<li>New <code>/active</code> route for determining if server is able to handle requests.</li>\n<li>Better logging around 404&#39;d HTTP requests.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.4.0...v2.5.0\">v2.5.0</a></h1>\n<ul>\n<li><code>Config</code> now allows for programmatic getting and setting of the external address.</li>\n<li>Support for a new <code>Hooks</code> module for setting up hooks in a more SDK-friendly manner.</li>\n<li>Adds new exports for building downstream SDK projects more easily, versus using our CLI:<ul>\n<li><code>getArgSwitches</code></li>\n<li><code>getSourceFiles</code></li>\n<li><code>installDependencies</code></li>\n<li><code>buildDockerImage</code></li>\n<li><code>buildTypeScript</code></li>\n</ul>\n</li>\n<li><code>README.md</code> updates.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.3.0...v2.4.0\">v2.4.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Drops support for recording and screencasting in favor of library-based approaches.</li>\n<li><code>playwright@1.42.1</code> and <code>puppeteer@22.4.0</code>.</li>\n</ul>\n<p><strong>Other Changes</strong></p>\n<ul>\n<li>SDK routes now take precedence over core routes when a path-collision occurs.</li>\n<li>Support SDK projects with their own <code>static</code> directories.</li>\n<li>Adds support for user-specified <code>stop</code> methods in SDK Module extensions.</li>\n<li>Core modules now extend <code>EventEmitter</code>, making them able to publish events.</li>\n<li>Fixes issues with <code>addStyleTag</code> happening before <code>goto</code> calls in REST APIs.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.2.0...v2.3.0\">v2.3.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Routes must define a unique <code>name</code> property in order to remove them in SDK projects.</li>\n<li>A new <code>browserless</code> object in the SDK <code>package.json</code> file can specify module overrides, in camelCase, instead of using a path-based semantic.</li>\n<li>Fixes issues with <code>npx playwright-core install...</code> potentially installing other browser versions than what is a dependency of Browserless.</li>\n<li>Fixes and other general improvements.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v2.1.0...v2.2.0\">v2.2.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li><code>ghcr.io/browserless/chrome</code> now runs actual Chrome and not Chromium! If you were using this tag please update to use <code>ghcr.io/browserless/chromium</code>!<ul>\n<li>This Chrome tag uses the new routing convention below. If you get random 404&#39;s, please add <code>/chrome</code> to the start of the route. EG, <code>/pdf</code> becomes <code>/chrome/pdf</code>.</li>\n<li>Websocket connections follow a similar breakage in that the URL will go from something like <code>ws://localhost:3000</code> to <code>ws://localhost:3000/chrome</code>.</li>\n</ul>\n</li>\n<li>Adds a new <code>ghcr.io/browserless/chromium</code>, and updates <code>ghcr.io/browserless/chrome</code> to use actual Chrome.</li>\n<li>New and current APIs now follow a routing convention of <code>/$BROWSER/$ACTION</code>. In our Chrome image, you&#39;ll see <code>/chrome/pdf</code> for the PDF route as opposed to <code>/pdf</code>.<ul>\n<li>To keep things backwards compatible, all our prior REST APIs still have the same path as well as the new semantic, but only in the <code>multi</code> and <code>chromium</code> tags.</li>\n<li>These backwards compatible routes are ONLY available in <code>ghcr.io/browserless/chromium</code> and <code>ghcr.io/browserless/multi</code>.</li>\n</ul>\n</li>\n<li>Refer to the embedded documentation site for any and all updates on API differences.</li>\n</ul>\n<p><strong>Other Changes</strong></p>\n<ul>\n<li>HTTPRoutes and WebSocket routes can now have multiple paths to listen on.</li>\n<li>Add <code>clean</code> command to <code>@browserless.io/browserless</code> CLI.</li>\n<li>Adds support for <code>/json/list</code>, <code>/json/new</code>, <code>/json/version</code> and <code>json/protocol</code> APIs (Chrome and Chromium only).<ul>\n<li>When both Chrome and Chromium are present (in the case of the multi image), browserless opts for Chromium for these requests.</li>\n</ul>\n</li>\n<li>Removes legacy <code>browser.json</code> files since browserless now generates those and caches when requested.</li>\n<li>Stable docker images are coming! Please be sure to see our packages page for stable tags.</li>\n<li>Only verify that internally managed browsers are installed when starting.</li>\n<li>Preliminary support for <code>--headless=shell</code>.</li>\n<li>More unit-tests for the Chrome /json APIs.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/browserless/compare/v2.0.0-beta-1...v2.1.0\">v2.1.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Name is now <code>@browserless.io/browserless</code> to reflect our npm package.</li>\n<li>NEW: SDK is now live here: <a href=\"https://www.npmjs.com/package/@browserless.io/browserless\">https://www.npmjs.com/package/@browserless.io/browserless</a>.</li>\n<li>Drops gulp and other gulp utilities in favor of our own. Move to modules in <code>scripts</code> dir.</li>\n<li>Many private class properties now use <code>protected</code> so they can be referenced in SDK extensions.</li>\n<li>Adds a <code>/json/version</code> route for older libraries that use it.</li>\n<li>Merge startup/test scripts into <code>scripts</code> dir.</li>\n<li>Moves installed browsers to <code>/usr/local/bin/playwright-browsers</code>.</li>\n<li>Merge root files into package.json where possible.</li>\n<li>README updates and fixes.</li>\n<li>Numerous link and copyright fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/master...feat/browserless-2.0\">v2.0.0</a></h1>\n<p>browserless 2.0.0 represents the best body of work after running browserless for over 5 years. It contains mostly the same functionality and more, and is rebuilt to be more modular and offer a NodeJS SDK. It&#39;s also much lighter and faster than prior versions and includes a lot of semantic changes.</p>\n<h2>Features</h2>\n<ul>\n<li>ECMAScript style module loading and dependencies.</li>\n<li>New routing system using purely NodeJS&#39;s HTTP module.</li>\n<li>Better logs and concurrency/queueing parameters.</li>\n<li>Support for running the other major browser vendors in the same format and package.</li>\n<li>The service now compiles TypeScript to runtime JOI validation for our routes.</li>\n<li>Soon: upcoming support for extensions, long-running sessions and more.</li>\n</ul>\n<h2>Breaking Changes</h2>\n<ul>\n<li>Remove support for Selenium.</li>\n<li>The <code>/function</code> API now runs inside the context of the browser and not in Node.</li>\n<li>Drop support for keep-alive and pre-booting.</li>\n<li>Support for a single <code>launch</code> query-string parameter for launching a browser versus many individual parameters.</li>\n</ul>\n<h2>Minor Changes</h2>\n<ul>\n<li>Many docker parameters have been renamed, but are backwards compatible. See config.ts for details.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.60.2...v1.61.0\">v1.61.0</a></h1>\n<ul>\n<li><strong>FINAL of V1 for browserless/chrome. <a href=\"https://github.com/browserless/chrome/pull/3345\">See notes on V2 here</a></strong></li>\n<li>Dependency updates.</li>\n<li>Added <code>fonts-urw-base35</code>.</li>\n<li>Supports puppeteer <code>1.20</code>, <code>10.4.0</code>, <code>13.1.3</code>, <code>14.4.1</code>, <code>16.2.0</code>, <code>19.7.5</code> and <code>21.4.1</code>.</li>\n<li>Supports playwright <code>1.39</code>, <code>1.38</code>, <code>1.37</code>, <code>1.36</code>, <code>1.35</code>, <code>1.34</code>, and <code>1.33</code>.</li>\n<li>Fixes an issue where keep-alive chrome instances aren&#39;t properly tracked when <code>browser.close</code> is called.</li>\n<li>Fix improper handling of HTTP writing on bare sockets with 500 errors.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.60.1...v1.60.2\">v1.60.2</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes an issue where calls to GET /sessions sometimes return blank results.</li>\n<li>Drop puppeteer <code>21.3.1</code> in favor of <code>21.3.6</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.60.0...v1.60.1\">v1.60.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Drop the <code>partner</code> repo from builds as we no longer use it for installing <code>flash</code>.</li>\n<li>Bump to <code>Ubuntu</code> lunar.</li>\n<li>Bump to NodeJS 18.17.0</li>\n<li>Package.json <code>engines.node</code> now reflects what node version we run on the docker image.</li>\n<li>Drops support for playwright@<code>1.33</code> and default playwright to <code>1.38</code>.</li>\n<li>Drops support for puppeteer@<code>21.1.1</code> in favor of <code>21.3.1</code>.</li>\n<li>Replaces legacy <code>request</code> module with Node&#39;s native <code>fetch</code> for webhooks.</li>\n<li>Drops <code>node-fetch</code> across the board in favor of <code>fetch</code> native.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.59.0...v1.60.0\">v1.60.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New build arguments in our Dockerfile to apply different named base repo.</li>\n<li>New <code>CHROME_STABLE_VERSION</code> build arg for specifying a particular chrome stable version.</li>\n<li>Fixes in postinstall hooks for various platforms and chrome-stable.</li>\n<li>NEW: <code>waitFor</code> properties in our APIs now supports an object with selector + timeouts for more fine tuning.</li>\n<li>Bump puppeteer <code>20.x.x</code> to <code>21.1.1</code> (116.0.5845.96).</li>\n<li>Supports playwright versions <code>1.37</code>, <code>1.36</code>, <code>1.35</code>, <code>1.34</code>, and <code>1.33</code>.</li>\n<li>Fixes in deploy script to handle versions, platforms and architectures.</li>\n<li>Fixes an issue where headless defaults to <code>DEFAULT_STEALTH</code>.</li>\n<li>New <code>PREBOOT_QUANTITY</code> for overriding the amount of pre-booted instances of Chrome.</li>\n<li>Allow using a host&#39;s display by setting <code>DISPLAY</code> env variable.</li>\n<li>Link fixes in README.md.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.58.0...v1.59.0\">v1.59.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump to Ubuntu Kinetic release + updates to use relevant packages.</li>\n<li>In support of puppeteer 20+, updates to <code>env.js</code> for finding/symlinking Chrome.</li>\n<li>Supports playwright <code>1.33</code>, <code>1.32</code>, <code>1.31</code>, and <code>1.29.</code>. Drops support for earlier versions.</li>\n<li>Ad-blocking and other request-interception in browserless is graceful using the <code>isInterceptResolutionHandled</code> method.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.57.0...v1.58.0\">v1.58.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Documentation link fixes.</li>\n<li>Add new required lib <code>libu2f-udev</code>.</li>\n<li>Support for <a href=\"mailto:puppeteer@19.7.5\">puppeteer@19.7.5</a>.</li>\n<li>Supports playwright versions: <code>1.27</code>, <code>1.28</code>, <code>1.29</code>, <code>1.30</code> and <code>1.31</code>.</li>\n<li>Better internal TypeScript definitions.</li>\n<li>Print&#39;s a few extra log-lines at startup for links to various resources.</li>\n<li><code>/kill/all</code> now supports rebooting when PREBOOT is turned on.</li>\n<li>Fixes an issue with chromedriver boot-looping in modern versions.</li>\n<li>Adds support for <code>--headless=new</code>.</li>\n<li>Fixes an issue where user-data-dirs aren&#39;t deleted due to a crashed container.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.56.0...v1.57.0\">v1.57.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Add back in <code>puppeteer@13.1.3</code> for PDF/Screenshot performance.</li>\n<li>Replace <code>puppeteer@18.0.5</code> in favor of <code>puppeteer@19.2.2</code>.</li>\n<li>Better puppeteer install/binary path lookups.</li>\n<li>Support for the following playwright versions via the /playwright path:<ul>\n<li>1.23.3</li>\n<li>1.24.2</li>\n<li>1.25.2</li>\n<li>1.26.1</li>\n<li>1.27.1</li>\n</ul>\n</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.55.0...v1.56.0\">v1.56.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes various puppeteer issues with regards to revision information and browser-fetching.</li>\n<li>Fixes a Selenium issue where failed browsers can cause session to zombie.</li>\n<li>Small fix for route error handling.</li>\n<li>Better selenium W3C support.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.55.0...v1.54.1\">v1.55.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Update base OS from Ubuntu 20.04 to Ubuntu 22.04.</li>\n<li>Drops <code>path</code> support for both <code>addScriptTag</code> and <code>addStyleTag</code>. Use <code>url</code> or inject content directly.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency updates.</li>\n<li>We now support multiple versions of playwright via <code>playwright-core</code>. browserless checks the User-Agent string and tries to load a compatible playwright server at runtime in order to avoid breakages between versions.</li>\n<li>New <code>scrollPage</code> boolean parameter for the screenshot and other relevant APIs.</li>\n<li>browserless now writes appropriately formatted HTTP and WebSocket messages for non-2xx responses.</li>\n<li>Better CI coverage with prior puppeteer versions.</li>\n<li>Adds back a <code>browser.json</code> file in our docker images for easier CDP-related queries.</li>\n<li>A new <code>PORT</code> arg is available at build time in order to specify a PORT to listen onto.</li>\n<li>Updated links for browserless documentation in docs.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.54.1...v1.54.0\">v1.54.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Add <code>browser.json</code> file to git tags.</li>\n<li>Prettier fixes on source.</li>\n<li>deploy.js file fixes for creating production tags.</li>\n<li>Fix: add the <code>userDataDir</code> option so that we don&#39;t fill disks when using <code>stealth</code>.</li>\n<li>Fix: allow <code>disconnect</code> listeners to fire before closing.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.53.0...v1.54.0\">v1.54.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Move to using <code>mocha</code> for better esm support.</li>\n<li>Drop puppeteer <code>13.6.0</code> in favor of <code>14.4.1</code>.</li>\n<li>Utilize puppeteer <code>14.4.1</code> for <code>chrome-stable</code>.</li>\n<li>New internal <code>getCDPClient</code> for loading a page&#39;s CPD connection.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.52.1...v1.53.0\">v1.53.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump <code>browserless:base</code> to <code>1.16.0</code>.</li>\n<li>Drop <code>--quiet</code> from deploy scripts.</li>\n<li><code>arm64</code> support for latest as well as puppeteer at versions 9,10 and 13.</li>\n<li>Update puppeteer 13 from <code>13.5.2</code> to <code>13.6.0</code> (revision <code>982053</code>).</li>\n<li>README updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.52.0...v1.52.1\">v1.52.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Playwright example correction in README.md.</li>\n<li>Use revision <code>970485</code> for puppeteer 13.x.x, <code>latest</code>, chrome-stable and <code>arm64</code>.</li>\n<li>When using <code>KEEPALIVE</code> and <code>PREBOOT</code>, don&#39;t create new blank pages, and use the existing one instead.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.51.1...v1.52.0\">v1.52.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Added in new fonts: <code>fonts-gfs-neohellenic</code>.</li>\n<li>Minor code formatting changes.</li>\n<li>Drop <a href=\"mailto:puppeteer@13.1.3\">puppeteer@13.1.3</a> in favor of 13.5.2.</li>\n<li>Make <code>heapdump</code> an optional dependency as it&#39;s not always used, and add it back in.</li>\n<li>Utilize <code>fs/promise</code> vs home-rolled promisified utils.</li>\n<li>Fix an issue where PREBOOT and KEEPALIVE might return an <code>undefined</code> browser.</li>\n<li>Logging when file-protocol requests happen and terminate a session.</li>\n<li>Move the browser process exit listener into the puppeteer-provider for better session cleanup.</li>\n<li>Allow &quot;headfull&quot; playwright sessions.</li>\n<li>Don&#39;t <code>await</code> chrome-helper&#39;s closing of the browser as it&#39;s not truly async.</li>\n<li>Remove <code>body-parser</code> in favor of <code>express</code>&#39;s JSON and other parsers.</li>\n<li>Fixes an issue where using a user-data-dir that doesn&#39;t exist causes chrome to crash.</li>\n<li>Add in more unit and integration tests.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.51.1...v1.52.0\">v1.52.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Added in new fonts: <code>fonts-gfs-neohellenic</code>.</li>\n<li>Minor code formatting changes.</li>\n<li>Drop <a href=\"mailto:puppeteer@13.1.3\">puppeteer@13.1.3</a> in favor of 13.5.2.</li>\n<li>Make <code>heapdump</code> an optional dependency as it&#39;s not always used, and add it back in.</li>\n<li>Utilize <code>fs/promise</code> vs home-rolled promisified utils.</li>\n<li>Fix an issue where PREBOOT and KEEPALIVE might return an <code>undefined</code> browser.</li>\n<li>Logging when file-protocol requests happen and terminate a session.</li>\n<li>Move the browser process exit listener into the puppeteer-provider for better session cleanup.</li>\n<li>Allow &quot;headfull&quot; playwright sessions.</li>\n<li>Don&#39;t <code>await</code> chrome-helper&#39;s closing of the browser as it&#39;s not truly async.</li>\n<li>Remove <code>body-parser</code> in favor of <code>express</code>&#39;s JSON and other parsers.</li>\n<li>Fixes an issue where using a user-data-dir that doesn&#39;t exist causes chrome to crash.</li>\n<li>Add in more unit and integration tests.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.51.0...v1.51.1\">v1.51.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Updates the <code>vm2</code> module to <code>3.9.7</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.50.0...v1.51.0\">v1.51.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>viewport</code> option inside of the content API.</li>\n<li>New <code>encoding</code> option in the screenshot API.</li>\n<li>Drop <a href=\"mailto:puppeteer@12.x.x\">puppeteer@12.x.x</a> in favor of 13.x.x.</li>\n<li>Fixes in our deploy scripts.</li>\n<li>Fixes for windows binaries in our postinstall hook.</li>\n<li>Fixes an issue where playwright tries to use a pre-booted chrome instance.</li>\n<li>Small type updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.49.1...v1.50.0\">v1.50.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Drops support for <code>puppeteer-4.0.1</code> in favor of <code>puppeteer-12.0.1</code>.</li>\n<li>Chrome-stable now utilizes puppeteer @ <code>12.0.1</code>.</li>\n<li>Support for <code>arm64</code> via production tags (<code>1-arm64</code>) as well as in <code>latest</code>.</li>\n<li>Static JSON files (<code>protocol.json</code>, <code>version.json</code>) are built at runtime on their first request and then cached in memory.</li>\n<li>Bumps <code>browserless/base</code> to <code>1.14.0</code>.</li>\n<li>New <code>selector</code> property for screenshot-ing a single DOM node in the screenshot API.</li>\n<li><code>puppeteerVersions</code> in the package.json file has been rename do <code>chromeVersions</code>.</li>\n<li>Internal changes for deploying production tag scripts.</li>\n<li>Consolidate scripts for <code>postinstall</code>.</li>\n<li>Drop support for <code>heapdump</code> due to its age and lack of platform varieties.</li>\n<li>New <code>/metrics/total</code> route for summing up all statistics in a single JSON payload.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.49.0...v1.49.1\">v1.49.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix webhook not using timeout URL.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.48.0...v1.49.0\">v1.49.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Support for ARM64 builds by dropping flash for it.</li>\n<li>Bump puppeteer 10.2.0 for 10.4.0.</li>\n<li>New puppeteer-hook for injecting a puppeteer-compatible library, eg. puppeteer-extra.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.47.0...v1.48.0\">v1.48.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>API calls with <code>html</code> in their payloads now use the <code>page.setContent</code> API versus a prior hack using one-time network-request interception (<a href=\"https://github.com/browserless/chrome/compare/v1.47.0...master#diff-67b699af1b24472604e21081d0509620d4ab3d986fcd4f8aa0b04d5ee5e4c63fL88\">example here</a>). Old versions of puppeteer might not work properly with this (&lt;= 5.x.x). This effects the following APIS: <code>/content</code>, <code>/pdf</code> and <code>/screenshot</code>.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump <code>browserless/base</code> to <code>1.12.0</code> (add user-id to <code>blessuser</code> of <code>BLESS_USER_ID=999</code>).</li>\n<li>Bumps puppeteer @10.x.x to <code>10.2.0</code> with revision <code>901912</code>.</li>\n<li>Makes API calls use <code>setContent</code> properly now (no more one-time network interception). This fixes certain issues with images not loading in PDFs and screenshots.</li>\n<li>Fix some typings in tests.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.46.0...v1.47.0\">v1.47.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bump <code>browserless/base</code> to <code>1.11.0</code>.</li>\n<li>Add new lint task and rename GitHub actions tasks, remove <code>tslint</code>.</li>\n<li>Lint and prettier fixes.</li>\n<li>Delay url parsing until after <code>before</code> hook runs.</li>\n<li>New <code>meta</code> object param for page hooks (passing through arbitrary meta data set by prior hooks).</li>\n<li>New <code>FUNCTION_ENV_VARS</code> environment variable pass through an allow-list of environment variables for functions to access.</li>\n<li>Fix <code>someObject.hasOwnProperty</code> to <code>Object.prototype.hasOwnProperty.call</code>.</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.45.0...v1.46.0\">v1.46.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Move to Node 16.x.x.</li>\n<li>Bump browserless/base to 1.10.0.</li>\n<li>Limit <code>x-response-url</code> to 100 characters.</li>\n<li>Add support for <a href=\"mailto:puppeteer@10.x.x\">puppeteer@10.x.x</a>.</li>\n<li>Add <code>maxConcurrent</code> stat for metrics API + log stats every 5 minutes to stdout.</li>\n<li>Some performance improvements to how pages/browsers are setup and torn down.</li>\n<li>Add <code>API_DOCS_ENDPOINT</code> as a filterable API to deny access to.</li>\n<li>Minor code reformatting from prettier.</li>\n<li>Better page setup and logging.</li>\n<li>Fixes <code>DEFAULT_STEALTH</code> for self-hosted deployments.</li>\n<li>Improvements on how chrome is closed.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.44.0...v1.45.0\">1.45.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Support for <a href=\"https://github.com/browserless/chrome/commit/0903795e936b93a511ec04f7ae35c03397682905\">playwright proxies</a>.</li>\n<li>Fixes an issue with larger headers potentially causing load-balancers to crash and fail.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.43.0...v1.44.0\">v1.44.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li><code>PROXY_HOST</code> and <code>PROXY_PORT</code> are now replaced with a single <code>PROXY_URL</code> param, eg: <code>https://www.mybrowserless.com/optional/paths</code>. When set, browserless uses this fully-qualified URL to build out links <em>back</em> to its internal debugger and sessions. Useful when you&#39;re instance is behind a proxy or load-balancer of some kind.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency Updates.</li>\n<li>Use recent Node 14 (browserless-base 1.7.0).</li>\n<li>New <code>rejectResourceTypes</code> property on most APIs (content, screenshot, pdf, etc.).</li>\n<li>Allow serving of <code>file://</code> protocols when explicitly enabled (default is off due to security concerns). Set <code>ALLOW_FILE_PROTOCOL=true</code> in your env params.</li>\n<li>The <code>/pressure</code> API now takes into account CPU/Memory consumption, and adds a &quot;reason&quot; property for why the machine might be not available.</li>\n<li>Fixes an issue where playwright couldn&#39;t download files.</li>\n<li>You can now filter /sessions calls with a <code>trackingId</code> parameter.</li>\n<li><code>detached</code> functions now return a <code>trackingId</code> when present.</li>\n<li>More types, tests, and utility consolidation.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.42.0...v1.43.0\">v1.43.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fixes an issue where --user-data-dirs aren&#39;t deleted properly, potentially filling disks.</li>\n<li>Changes CPU/Memory checks to be user-based and not the entire OS.</li>\n<li>Adds tests for the user-data-dir issue.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.41.0...v1.42.0\">v1.42.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Move to Node 14!</li>\n<li>Use <code>esModuleInterop</code> for imports.</li>\n<li>Remove <code>page.waitFor</code> in favor of downstream methods.</li>\n<li>Adds new <code>?stealth</code> parameter for API calls (see puppeteer-extra-stealth-plugin).</li>\n<li>New <code>DEFAULT_STEALTH</code> param for making stealth calls by default.</li>\n<li>Fixes <code>ignoreDefaultArgs</code> in chrome stable.</li>\n<li>Ensure temp user-data-dirs are always cleaned up.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.40.2...v1.41.0\">v1.41.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>New <code>SESSION_CHECK_FAIL_URL</code> webhook for when pre-session checks fail.</li>\n<li>Health checks now take the last two CPU/Memory samples to determine if a failure (5 minutes).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.40.1...v1.40.2\">v1.40.2</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fix potentially unhandled stream error events when closing chrome.</li>\n<li>Bump puppeteer to 5.4.1 for major 5.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.40.0...v1.40.1\">v1.40.1</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>New <code>SOCKET_CLOSE_METHOD</code> for better load-balancing behavior when under load.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.39.0...v1.40.0\">v1.40.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Support for playwright 1.4.0 and greater. <a href=\"https://github.com/microsoft/playwright/issues/4054\">See more here</a>.</li>\n<li>New <code>PRE_REQUEST_HEALTH_CHECK</code> env variable to check CPU/Memory prior to running a session. Set <code>MAX_CPU_PERCENT</code> or <code>MAX_MEMORY_PERCENT</code> for setting these thresholds. Responds with a <code>503</code> HTTP code if CPU/Memory are high on any inbound session (API, puppeteer or webdriver).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.38.0...v1.39.0\">v1.39.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes a crash due to <code>browser.close</code> streams not completing properly.</li>\n<li>Adds a <code>dumpio</code> query-string parameter for launching with puppeteer.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.37.2...v1.38.0\">v1.38.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes a memory leak when browsers don&#39;t close properly.</li>\n<li>Adds a <code>/heapdump</code> route for capturing heap dumps. Turn on by setting <code>ENABLE_HEAP_DUMP=true</code> in your docker env.</li>\n<li><code>emulateMedia</code> fixes on the pdf route.</li>\n<li>CodeQL implemented.</li>\n<li>README fixes.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.37.1...v1.37.2\">v1.37.2</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes an issue where the webserver can crash after rejecting a request.</li>\n<li>Fixes deployment script not waiting for zip files to be finished unzipped.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.37.0...v1.37.1\">1.37.1</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Fixes an issue in webdriver not starting properly.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.36.0...v1.37.0\">1.37.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>Due to stability issues, puppeteer version 3.x.x and 4.x.x now use chromium revision <code>782078</code>. See our <code>package.json</code> for details.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency Updates</li>\n<li>README Updates</li>\n<li>Fixes an issue for secured containers using prometheus (plus tests).</li>\n<li>Support for puppeteer <code>5.2.1</code></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.35.0...v1.36.0\">1.36.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>Drops support for puppeteer <code>2.0.0</code> and <code>3.0.4</code>, please use <code>2.1.1</code> and <code>3.3.0</code> for those revisions.</li>\n<li>Adds support for puppeteer <code>5.0.0</code>.</li>\n<li>Bug-fix with the server randomly closing with an uncaught error event thrown from inside underlying socket connection.</li>\n<li>Adds back in <code>--disable-dev-shm-usage</code> to default arguments for better SHM performance.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.34.0...v1.35.0\">1.35.0</a></h1>\n<ul>\n<li>Dependency Updates</li>\n<li>New <code>maxTime</code>, <code>minTime</code>, <code>meanTime</code> and <code>totalTime</code> of all sessions for a given period in /stats.</li>\n<li>Bugfix on CPU/Memory triggering health failure webhooks.</li>\n<li>Fix issues in websocket errors by awaiting browser.close (or 5 seconds, whichever is quickest).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.33.1...v1.34.0\">v1.34.0</a></h1>\n<p><strong>Potentially Breaking</strong></p>\n<ul>\n<li>screencast API no longer supports <code>audio</code> or the <code>setPreferences</code> function in order to offer a better video experience. In order to set the width/height, simply set a page width height to what you&#39;d like.</li>\n<li><code>chrome-stable</code> will now use <code>puppeteer@3.1.0</code> for better compatibility.</li>\n</ul>\n<hr>\n<ul>\n<li>Dependency updates.</li>\n<li>Drops puppeteer version <code>1.20.0</code> and below.</li>\n<li>Move <code>browserless/base</code> to <code>v1.5.0</code>.</li>\n<li>Puppeteer support for <code>3.3.0</code> (3.2.x and 3.1.x have the same chromium revision).</li>\n<li>Fixes <code>trackingId</code> on pre-booted sessions.</li>\n<li><code>about:blank</code> pages now are returned in the <code>/sessions</code> API for transparency of open sessions/browsers.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.33.0...v1.33.1\">1.33.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fix socket errors from accidentally firing error webhooks.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.32.0...v1.33.0\">1.33.0</a></h1>\n<ul>\n<li>Drops support for puppeteer 1.17.x and 1.18.x</li>\n<li>Support for puppeteer 3.0.x</li>\n<li>Dependency updates</li>\n<li>Fix reject stat firing on debugger pages not being found</li>\n<li>Consolidates more types.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.31.1...v1.32.0\">1.32.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Adds roboto fonts.</li>\n<li>Updates <code>pressure</code> API to take account of running browsers in the <code>running</code> count.</li>\n<li>Adds <code>maxConcurrent</code>, <code>maxQueued</code>, <code>cpu</code> and <code>memory</code> to pressure.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.31.0...v1.31.1\">1.31.1</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fixes a small issue where XVFB doesn&#39;t start properly during an automated restart.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.30.0...v1.31.0\">1.31.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Allows <code>trackingId</code> on uploaded files to save in the appropriate tracking-ID folder.</li>\n<li>New <code>userAgent</code> param for setting user-agent in API requests.</li>\n<li>Fixes an issue where chrome wasn&#39;t being closed in rare cases.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.29.1...v1.30.0\">1.30.0</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Updates to Node 13 for speed and memory improvements.</li>\n<li>browserless/<a href=\"mailto:base@1.4.0\">base@1.4.0</a></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.29.0...v1.29.1\">1.29.1</a></h1>\n<ul>\n<li>Dependency Updates.</li>\n<li>Fixes how deploy script determines errors when running child commands.</li>\n<li>Fixes issues when many selenium sessions can potentially fill up disk space.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.28.0...v1.29.0\">1.29.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Uses <code>pipe</code>&#39;s for most API calls and other internal endpoints for faster/better throughput. Works only for <code>headless</code> API/puppeteer calls.</li>\n<li>Allows custom lighthouse configs via POST <code>config</code> property.</li>\n<li>Patches vm2.</li>\n<li>Before hooks no longer end requests forcefully -- external hooks must manually end the request/sockets themselves.</li>\n<li>Properly passes socket errors to the error handler/webhook</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.27.0...v1.28.0\">1.28.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Sets a system-default font of Ubuntu for most sites that use <code>system-ui</code> in their font declarations.</li>\n<li>Fixes health-check failure webhooks.</li>\n<li>New <code>PROXY_HOST</code>, <code>PROXY_PORT</code> and <code>PROXY_SSL</code> for external load-balancers. <a href=\"https://www.browserless.io/docs/docker.html#using-a-proxy\">See docsite for more info</a>.</li>\n<li>Moves over to GH actions over Travis for CI.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.26.1...v1.27.0\">1.27.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>manipulate</code> params for screenshots, allowing for resizing, flipping and more.</li>\n<li>Better tracking of chrome-process for cleanup of zombied sessions.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.26.0...v1.26.1\">1.26.1</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Added <code>git</code> as a dependency in dockerfile for git-based npm dependencies to work.</li>\n<li>Fixed an issue in <code>start.sh</code> so that errors bubble up properly and close the process.</li>\n<li>Bumps <code>browserless/base</code> to <code>1.2.0</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.25.0...v1.26.0\">1.26.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Dropping pre-push hooks for speed.</li>\n<li>Consolidate all interfaces/types to a types.d.ts file.</li>\n<li>Fixes an issue where numerous chrome instances launch when prebooting.</li>\n<li>Fixes an issue where incoming requests don&#39;t use the pre-booted chrome instance.</li>\n<li>Uses <code>page.setViewport</code> when <code>--window-size</code> is set in params to help with screenshots not appearing properly (chromedriver only).</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.24.0...v1.25.0\">1.25.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Stricter build-time arguments for chromium and chromedriver assets.</li>\n<li>Better XVFB functionality.</li>\n<li>New parameters for most API&#39;s, <code>addScriptTag</code> and <code>addStyleTag</code>, accepting an array of scripts/styles respectively.</li>\n<li>Drop support for <code>puppeteer@1.17.0</code>.</li>\n<li>Proper support for parsing <code>ignoreDefaultArgs</code> query-parameters.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.23.1...v1.24.0\">1.24.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Bugfix on our debugger&#39;s play button being off-center.</li>\n<li>Fixes driver.close() calls not cleaning the browser.</li>\n<li>New <code>/GET</code> option for most our APIs. Stringify your JSON and add a ?body=YOUR-JSON with a /GET call to most of our functions! Requires <code>ENABLE_API_GET=true</code> in you docker env variables.</li>\n<li>WebSocket (Socket) exception handling and logging.</li>\n<li>More integration and unit tests added.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.23.0...v1.23.1\">1.23.1</a></h1>\n<ul>\n<li>Fixes an issue in chromedriver where commands would hang.</li>\n<li>Fixes an issue in chromedriver sessions not being removed properly.</li>\n<li>Fixes and pins the base image so that headful sessions work again.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.22.0...v1.23.0\">1.23.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Use <code>apt-get</code> to install <code>dumb-init</code>.</li>\n<li>Add a LANG arg in docker.</li>\n<li>New <code>setJavaScriptEnabled</code> property for REST APIs.</li>\n<li>Fixes an issue with <code>waitFor</code> functions in REST API calls.</li>\n<li>Fixes issues when PREBOOT_CHROME and KEEPALIVE are true.</li>\n<li>Updates protocol and host information in ad-blocking.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.21.0...v1.22.0\">1.22.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Removal of unnecessary &#39;--disable-dev-shm-usage&#39;</li>\n<li>Squelching of chromedriver&#39;s verbose args unless <code>DEBUG=*</code> is set.</li>\n<li>New <code>/kill/${id}</code> route for remotely killing a certain browser.</li>\n<li>Allowing of sub-child routes in workspaces.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.20.0...v1.21.0\">1.21.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>viewport</code> property option for PDF endpoint.</li>\n<li>The <code>/stats</code> endpoint now runs in a separate process meaning it can be parallelized.</li>\n<li>Fixed a bug where hardware monitoring can cause the container to restart/crash.</li>\n<li>Fixes an issue with the file-chooser API not working in puppeteer.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.19.0...v1.20.0\">1.20.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>New <code>/scrape</code> API!</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.18.0...v1.19.0\">1.19.0</a></h1>\n<ul>\n<li>Dependency updates.</li>\n<li>Fixes chrome-stable&#39;s binary chromedriver.</li>\n<li>Move over to Node 12.</li>\n<li>Bugfix on width/height in the screencast API.</li>\n<li>Support for <a href=\"mailto:puppeteer@2.0.0\">puppeteer@2.0.0</a>.</li>\n<li>Fixed issues with the devtools JS files missing.</li>\n<li>Adds support for blacklisting routes in Docker.</li>\n<li>Consolidates hooks into a hooks module.</li>\n<li>Allows Selenium to specify download-paths and pausing via preferences.</li>\n<li>Fixes an issue in certain JSON-based CDP libraries.</li>\n<li>Function API&#39;s can now run incognito mode with a new Docker param.</li>\n<li></li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.17.0...v1.18.0\">1.18.0</a></h1>\n<ul>\n<li>Dependency updates</li>\n<li>Better <code>IS_DOCKER</code> check for kubernetes.</li>\n<li>Updates to README.md, spelling fixes and Slack link.</li>\n<li>Fixes to debugger and larger code bodies.</li>\n<li>Removal of analytics in debugger.</li>\n<li>Screencast improvements and adding ability to set new options.</li>\n<li>New <code>waitFor</code> property in our APIs (content, pdf and screenshot).</li>\n<li>Don&#39;t allow file requests on the debugger for security reasons.</li>\n<li>Better metrics monitoring.</li>\n<li><code>singleRun</code> mode in docker.</li>\n<li>New prometheus support!</li>\n<li>Fixing issues with keeping chrome alive (only closing once TTL is met).</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.16.0...v1.17.0\">1.17.0</a></h1>\n<ul>\n<li>Dependency updates</li>\n<li>Splitting docker images into two repositories for faster builds and pulls</li>\n<li>Adding in external routing capabilities</li>\n<li>New error hook</li>\n<li>More/better types</li>\n<li>Updating <code>deviceScaleFactor</code> in API&#39;s for more granular control.</li>\n<li>Better chromedriver failure messages.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.15.0...v1.16.0\">1.16.0</a></h1>\n<ul>\n<li>Adding <code>ffmpeg</code> to the docker dependency list.</li>\n<li>Add <code>timecut</code> as a dependency for recording.</li>\n<li>Better logs on chrome PID&#39;s and closing forcefully.</li>\n<li>Fixed <code>DEFAULT_CHROME</code> =&gt; <code>DEFAULT_HEADLESS</code>.</li>\n<li>Fixed a bug where <code>xvfb</code> doesn&#39;t start in time.</li>\n<li>Use <code>SIGKILL</code> for killing chromedriver.</li>\n<li><code>/json/version</code> now returns a <code>webSocketDebuggerUrl</code>.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.14.1...v1.15.0\">1.15.0</a></h1>\n<ul>\n<li>New <code>page</code> and <code>browser</code> hooks for docker images that <code>FROM</code> browserless.</li>\n<li><code>bluebird</code> added as a module for <code>function</code> and other endpoints.</li>\n<li>More dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.14.0...v1.14.1\">1.14.1</a></h1>\n<ul>\n<li>Bugfix when running multiple &quot;headfull&quot; sessions.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.13.0...v1.14.0\">1.14.0</a></h1>\n<ul>\n<li>New <code>WORKSPACE_DELETE_EXPIRED</code> and <code>WORKSPACE_EXPIRE_DAYS</code> to auto-cleanup workspace dirs.</li>\n<li>README.md cleanup now that HTTPS is no longer required.</li>\n<li>Support for <code>~</code> in docker env parameters.</li>\n<li>More alignment with how chromedriver and puppeteer sessions get cleaned up.</li>\n<li><code>/session</code> API now returns <code>browserWSEndpoint</code> and <code>browserId</code> properties for having multiple debuggers connected.</li>\n<li>Support for reconnecting(!!). When a <code>?keepalive=KEEP-ALIVE-IN-MS</code> is seen in the <code>puppeteer.connect</code> call we keep the browser active for that many ms after the debugger disconnects.</li>\n<li>New <code>/kill/all</code> route which closes <em>all</em> actively running sessions.</li>\n<li>New internal scheduler module, making future things like cron-based jobs a possibility.</li>\n<li>Better internal types.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.12.0...v1.13.0\">1.13.0</a></h1>\n<ul>\n<li>A minor refactor to consolidate calls to <code>url.parse</code> for performance gains.</li>\n<li>Introduces a per-session based timeout that overrides the global timeout.</li>\n<li>Consolidates authorization checks to remove duplication.</li>\n<li>Moves more types into their backing modules in order to better consolidate files.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.11.0...v1.12.0\">1.12.0</a></h1>\n<ul>\n<li>Set&#39;s a non-conflicting <code>WORKSPACE_DIR</code> and <code>DEFAULT_USER_DATA_DIR</code> in docker by default.</li>\n<li>Drops support for puppeteer <code>1.15.0</code> and adds <code>1.19.0</code>.</li>\n<li>Web-based debugger now sends cookies for docker deployments that are secure.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.10.0...v1.11.0\">1.11.0</a></h1>\n<ul>\n<li>Live debugger is now self-hosted, no more enforced https though it&#39;s still recommended.</li>\n<li>Consolidated build steps.</li>\n<li>Using the same chromedriver binary that matches the puppeteer&#39;s bundled chromium.</li>\n<li>Introducing <code>trackingId</code> workflows.</li>\n<li>Fixing unused export&#39;s, removing extraneous internal methods.</li>\n<li><code>/workspace</code> API now returns sub-files and scopes sessions by <code>trackingId</code> when present.</li>\n<li>Support for <code>/json/new</code> protocol.</li>\n<li>Dependency updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.9.0...v1.10.0\">1.10.0</a></h1>\n<ul>\n<li>Dropped support for puppeteer <code>1.9.0 =&gt; 1.14.0</code>.</li>\n<li>Added support for puppeteer <code>1.16.0 =&gt; 1.18.0</code>.</li>\n<li>A version of chromedriver is now installed to perfectly match the version of puppeteer&#39;s chromium.</li>\n<li>In dev, chromedriver now uses the puppeteer version of chromium.</li>\n<li>Defaulted most ENV-variables in docker to sensible defaults.</li>\n<li>New <code>rotate</code> feature for PDF endpoint: <code>{ rotate: 90 }</code> =&gt; rotate left 90 degrees.</li>\n<li>Support for <code>browserless.token</code> in the docker image.</li>\n<li>puppeteer integration now returns semantic HTTP codes for certain errors (<code>400</code>, <code>403</code> and <code>429</code>).</li>\n<li>Support for chromedriver&#39;s move to the W3C spec &#39;goog:chromeOptions&#39;.</li>\n<li>The debugger now filters out <code>about:blank</code> pages, and includes sessions by Selenium.</li>\n<li>Workspace support for selenium-based integrations.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.8.0...v1.9.0\">1.9.0</a></h1>\n<ul>\n<li>Better handling of browser/socket closing in puppeteer integrations.</li>\n<li>Numerous screencast fixes.</li>\n<li>Moved all GH links to new repo location.</li>\n<li>Dep updates.</li>\n</ul>\n<h1><a href=\"https://github.com/browserless/chrome/compare/v1.7.0...v1.8.0\">1.8.0</a></h1>\n<ul>\n<li>Better windows dev experience.</li>\n<li>Indian font support.</li>\n<li>Video capture now supports audio and browser width/height.</li>\n<li>Dependency updates.</li>\n<li>DEFAULT env variables for launching pre-booted Chrome.</li>\n</ul>\n<h1>1.7.0</h1>\n<ul>\n<li>Dep updates</li>\n<li>New <code>?blockAds</code> query-parameter for disabling 3rd-party ad calls.</li>\n</ul>\n<h1>1.6.0</h1>\n<ul>\n<li>New <code>authenticate</code> and <code>setExtraHTTPHeaders</code> params for the <code>content</code>, <code>pdf</code>, and <code>screenshot</code> APIs. Useful for using proxies in our REST APIs.</li>\n<li>Fixed a bunch of bugs inside of the webdriver integration, making it more REST-ful.</li>\n<li>Updated dependencies inside of Chromedriver.</li>\n<li>New <code>DISABLE_AUTO_SET_DOWNLOAD_BEHAVIOR</code> for mitigating errors in puppeteer &lt; 1.15.0.</li>\n<li>Bumped Puppeteer to 1.15.0.</li>\n</ul>\n<h1>1.5.0</h1>\n<ul>\n<li>New <code>/session</code> API (and accompanying routes) for display/viewing active sesions in a remote debugger(!).</li>\n<li>New <code>?pause</code> query-param for pausing sessions prior to running them (useful for the live debug viewer).</li>\n<li>The browserless debugger now exposes links to these debug pages via the sidebar.</li>\n<li>New Debugger page can be disabled via the <code>ENABLE_DEBUG_VIEWER=false</code> environment variable flag.</li>\n<li>Move to use <code>node@10</code>.</li>\n<li>No more <code>no-implicit-any</code>&#39;s inside the codebase.</li>\n</ul>\n<h1>1.4.0</h1>\n<ul>\n<li>During connection, we now set the download dir of REST and puppeteer sessions. Cloud users and docker users no longer have to manually set this field, and the <code>/workspace</code> API references it as well!</li>\n</ul>\n<h1>1.3.1</h1>\n<h1>Fixes</h1>\n<ul>\n<li>New deploy.js file to do deployments &quot;on-prem&quot;</li>\n<li>Updated new builds for puppeteer 1.12.2 and 1.13.0</li>\n<li>Fixes an issues in CORS handling</li>\n</ul>\n<h1>1.3.0</h1>\n<h1>Minor changes</h1>\n<ul>\n<li>The <code>screenshot</code>, <code>function</code>, <code>pdf</code>, and <code>content</code> API&#39;s now accept new content-types for easier POSTing of small payloads (see docsite).</li>\n<li>The <code>screencast</code> API can now start/stop recording programmatically via a <code>startScreencast</code> and <code>stopScreencast</code> params (see docsite).</li>\n<li>New <code>external</code> dir for injecting custom <code>before</code> and <code>after</code> hooks in external docker builds.</li>\n<li>A new <code>timeout</code> query-option for session-based timeouts vs using the global one.</li>\n<li>New <code>requestInterceptors</code> for injection custom request behavior.</li>\n</ul>\n<h1>Fixes</h1>\n<ul>\n<li>Numerous default fixes in the APIs.</li>\n<li>Stray consoles removed :)</li>\n<li>Consolidated download behavior in <code>screencast</code> and <code>download</code> APIs</li>\n</ul>\n<h1>1.2.0</h1>\n<h1>Minor Changes</h1>\n<ul>\n<li>New <code>requestInterceptors</code> for the /screenshot API, <a href=\"https://github.com/browserless/chrome/pull/119\">allowing you to mock data in response to a request</a>.</li>\n<li>Code debugger now transmits code over-the-wire via cookies to avoid URL max-length issues.</li>\n<li>Now supports cookie-based authentication via a <code>browserless_token=TOKEN;</code> cookie.</li>\n</ul>\n<h1>Fixes</h1>\n<ul>\n<li><a href=\"https://github.com/browserless/chrome/issues/118\">Comments in the debugger won&#39;t break it.</a></li>\n<li>Requests that are rejected due to auth reasons aren&#39;t logged in stats.</li>\n</ul>\n<h1>1.1.0</h1>\n<p>With 1.1.0 we offer a refined way of dealing with both downloads and uploads. Both use-cases are tightly coupled to the file-system, and can leave you scratching your head as to what&#39;s going one. For more information and detailed documentation, please refer to our doc-site at <a href=\"https://www.browserless.io/\">https://www.browserless.io/</a></p>\n<h2>Minor Changes</h2>\n<ul>\n<li>New <code>WORKSPACE_DIR</code> variable for controlling where browserless stores files and uploads.</li>\n<li>New <code>/workspace</code> API for doing RESTful operations on the downloads/uploads file-system.</li>\n<li>New <code>/download</code> API for running a puppeteer-script, and responding with the resulting downloaded file.</li>\n</ul>\n<h2>Internal Changes</h2>\n<ul>\n<li>Moved routes out of the browserless module and into their own file/module.</li>\n<li>Renamed the <code>browserless-web-service</code> module to just <code>browserless</code> for simplicity.</li>\n<li>Moved the <code>DOWNLOAD_DIR</code> to <code>WORKSPACE_DIR</code> since it handles both uploads and downloads.</li>\n</ul>\n<h1>1.0.0</h1>\n<p>🥁 -- Stable version 1.0 is here! While this doesn&#39;t include major functionality changes, it <em>does</em> change how the docker builds are generated going forward. The versioning will now contain two pieces of crucial information: the version of the <em>browserless</em> service + the version of Chrome under-the-hood. For instance <code>1.2.3-puppeteer-1.10.0</code> is browserless at <code>1.2.3</code>, exposing puppeteer at <code>1.10.0</code>.</p>\n<p>Similar to how NodeJS itself does docker releases, we&#39;ll now provide releases in 3 distinct ways:</p>\n<ul>\n<li>An <em>immutable</em>, pinned version release: <code>1.0.0-puppeteer-1.11.0</code></li>\n<li>A mutable minor version release: <code>1.1-puppeteer-1.12.0</code></li>\n<li>A mutable major version release: <code>1-puppeteer-1.9.0</code></li>\n</ul>\n<p>For production deployments, we recommend using <em>pinned</em> version releases as they won&#39;t change once released. The mutable minor/major releases will receive on-going updates whenever we do changes that are bug-fixes or feature release. Even with the best intentions it&#39;s possible that instability can be introduced with these mutable images, hence why recommend the pinned version releases.</p>\n<p>Finally, we&#39;ll continue to ship support for the last 5 minor versions of Puppeteer + the Google Chrome (stable). Old images will remain, but newer versions of browserless won&#39;t be included.</p>\n<p>We&#39;ll continue to keep this changelog up-to-date anytime we do docker releases.</p>\n"
993
993
  },
994
994
  "openapi": "3.0.0",
995
995
  "paths": {