From 918758f76de2d7e14ae8f45815ec4bb05a9f0ffe Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Mon, 24 Jun 2024 19:56:13 +0400 Subject: [PATCH 1/8] Update README.md --- README.md | 276 +++++++++++++++++++++++++++++++++--------------------- 1 file changed, 169 insertions(+), 107 deletions(-) diff --git a/README.md b/README.md index 2b5b5cd..de1c3ae 100644 --- a/README.md +++ b/README.md @@ -1,69 +1,123 @@ # JavaScript captcha solver module for 2Captcha API -## Description -A wrapper around the [2captcha](https://2captcha.com/) API. This wrapper supports any captcha bypass: reCAPTCHA V2, reCAPTCHA V3, hCaptcha, Arkose Labs FunCaptcha, image captcha, Coordinates (Click Captcha), Geetest, Geetest V4, Yandex Smart Captcha, Lemin captcha, Amazon WAF, Cloudflare Turnstile, Capy Puzzle, DataDome CAPTCHA, CyberSiARA, MTCaptcha, Friendly Captcha. - -Also added support for the `bounding_box` method. The Bounding Box Method allows you to mark data on the image. This method can be used to mark up datasets or highlight any objects in an image according to the given instructions. Read more about using *Bounding Box Method* on [documentation](https://2captcha.com/2captcha-api#bounding_box). - -[2captcha](https://2captcha.com/) is a service that solves many different types of captchas, this library serves as a wrapper around API 2captcha to bring easy, promise-based functionality to Node.js. This library specializes in concurrent solves, and Bulk API usage. - -- [Install](#install) -- [Configuration](#configuration) -- [Solve captcha](#solve-captcha) - - [reCAPTCHA v2](#recaptcha-v2) - - [reCAPTCHA v3](#recaptcha-v3) - - [hCaptcha](#hcaptcha) - - [Arkose Labs FunCaptcha](#arkose-labs-funcaptcha) - - [Image captchas](#image-captcha) (`base64` format) - - [GeeTest](#geetest-captcha) - - [GeeTest V4](#geetest-v4-captcha) - - [Yandex Smart Captcha](#yandex-smart-captcha) - - [Lemin Cropped Captcha](#lemin-captcha) - - [Cloudflare Turnstile](#cloudflare-turnstile) - - [Amazon WAF Captcha](#amazon-waf-captcha) - - [Capy Puzzle](#capy-puzzle) - - [Coordinates (Click Captcha)](#coordinates-captcha) - - [DataDome CAPTCHA](#datadome-captcha) - - [CyberSiARA](#cybersiara) - - [MTCaptcha](#mtcaptcha) - - [Friendly Captcha](#friendly-captcha) - - [Bounding Box Method](#bounding-box-method) - - [Usage of proxy](#usage-of-proxy) -- [Other methods](#other-methods) - - [badReport](#badreport) - - [goodReport](#goodreport) - - [balance](#balance) -- [Proxies](#proxies) -- [Useful articles](#useful-articles) - - [How to bypass Geetest v4 CAPTCHA](https://2captcha.com/blog/geetest-v4-support) - - [Automatic reCAPTCHA V3 resolution - a tutorial for developers and customers](https://2captcha.com/blog/recaptcha-v3-automatic-resolution) - - Finding Sitekey hCaptcha - - -## Install +The easiest way to quickly integrate the [2Captcha](https://2captcha.com/) captcha-solving service into your code and automate the solving of any type of captcha. + +- [JavaScript captcha solver module for 2Captcha API](#javascript-captcha-solver-module-for-2captcha-api) + - [Installation](#installation) + - [Configuration](#configuration) + - [TwoCaptcha instance options](#twocaptcha-instance-options) + - [Solve captcha](#solve-captcha) + - [Image captchas](#image-captcha) + - [reCAPTCHA v2](#recaptcha-v2) + - [reCAPTCHA v3](#recaptcha-v3) + - [hCaptcha](#hcaptcha) + - [FunCaptcha](#funcaptcha) + - [GeeTest](#geetest-captcha) + - [GeeTest V4](#geetest-v4-captcha) + - [Yandex Smart Captcha](#yandex-smart-captcha) + - [Lemin Cropped Captcha](#lemin-cropped-captcha) + - [Cloudflare Turnstile](#cloudflare-turnstile) + - [Amazon WAF](#amazon-waf) + - [Capy](#capy) + - [ClickCaptcha](#clickcaptcha) + - [DataDome CAPTCHA](#datadome-captcha) + - [CyberSiARA](#cybersiara) + - [MTCaptcha](#mtcaptcha) + - [Friendly Captcha](#friendly-captcha) + - [Bounding Box Method](#bounding-box-method) + - [Other methods](#other-methods) + - [goodReport](#goodreport) + - [badReport](#badreport) + - [balance](#balance) + - [Proxies](#proxies) + - [Examples](#examples) + - [Useful articles](#useful-articles) + + +## Installation +This package can be installed with NPM: ```sh npm install @2captcha/captcha-solver ``` -or +or Yarn: ```sh yarn add @2captcha/captcha-solver ``` ## Configuration -Instance can be created like this: +TwoCaptcha instance can be created like this: ```js -const Captcha = require("@2captcha/captcha-solver") -const solver = new Captcha.Solver("") +const TwoCaptcha = require("@2captcha/captcha-solver") +const solver = new TwoCaptcha.Solver("") ``` +Also, there are a few options that can be configured: + +```javascript +const apiKey = 'YOUR_API_KEY' +const pollingInterval = 10 + +const solver = new TwoCaptcha.Solver(apiKey, pollingInterval) +``` +### TwoCaptcha instance options + +| Option | Default value | Description | +| ---------------- | -------------- | -------------------------------------------------------------------------------------------- | +| apiKey | - | Your API key | +| pollingInterval | 5000 | Interval in milliseconds between requests to the `res.php` API endpoint. Setting values less than 5 seconds is not recommended | + ## Solve captcha +When you submit any image-based captcha use can provide additional options to help 2captcha workers to solve it properly. + +### Captcha options + +| Option | Default Value | Description | +| ------------- | ------------- | -------------------------------------------------------------------------------------------------- | +| numeric | 0 | Defines if the captcha contains numeric or other symbols [see more info in the API docs][post options] | +| min_len | 0 | minimal answer length | +| max_len | 0 | maximum answer length | +| phrase | 0 | defines if the answer contains multiple words or not | +| regsense | 0 | defines if the answer is case sensitive | +| calc | 0 | defines captcha requires calculation | +| lang | - | defines the captcha language; see the [list of supported languages] | +| textinstructions| - | hint or task text shown to workers with the captcha | + +Below you can find basic examples for every captcha type, check out the code below. + +### Image captcha + +[API method description.](https://2captcha.com/2captcha-api#solving_normal_captcha) + +To bypass a normal captcha (distorted text on an image) use the following method. This method can also be used to recognize any text in an image. + +```js +// Read from a file as base64 text +const imageBase64 = fs.readFileSync("./examples/media/imageCaptcha_6e584.png", "base64") + +solver.imageCaptcha({ + body: imageBase64, + numeric: 4, + min_len: 5, + max_len: 5 +}) +.then((res) => { + // Logs the image text + console.log(res); +}) +.catch((err) => { + console.log(err); +}) +``` + ### reCAPTCHA V2 -Use this method to solve reCAPTCHA V2 and obtain a token to bypass the protection. +[API method description.](https://2captcha.com/2captcha-api#solving_recaptchav2_new) + +Use the following method to solve reCAPTCHA V2 and obtain a token to bypass the protection. ```js solver.recaptcha({ @@ -80,7 +134,9 @@ solver.recaptcha({ ### reCAPTCHA V3 -This method provides reCAPTCHA V3 solver and returns a token. +[API method description.](https://2captcha.com/2captcha-api#solving_recaptchav3) + +This method provides a reCAPTCHA V3 solver and returns a token. ```js solver.recaptcha({ @@ -101,7 +157,9 @@ solver.recaptcha({ ### hCaptcha -Use this method to solve hCaptcha challenge. Returns a token to bypass captcha. +[API method description.](https://2captcha.com/2captcha-api#solving_hcaptcha) + +Use this method to solve the hCaptcha challenge. Returns a token to bypass the captcha. ```js solver.hcaptcha({ @@ -116,7 +174,9 @@ solver.hcaptcha({ }) ``` -### Arkose Labs FunCaptcha +### FunCaptcha + +[API method description.](https://2captcha.com/2captcha-api#solving_funcaptcha_new) FunCaptcha (Arkoselabs) solving method. Returns a token. @@ -133,32 +193,10 @@ solver.funCaptcha({ }) ``` -### Image captcha - -To bypass a normal captcha (distorted text on image) use this method. This method also can be used to recognize any text on the image. - -```js -// Read from a file as base64 text -const imageBase64 = fs.readFileSync("./tests/media/imageCaptcha_6e584.png", "base64") - -solver.imageCaptcha({ - body: imageBase64, - numeric: 4, - min_len: 5, - max_len: 5 -}) -.then((res) => { - // Logs the image text - console.log(res); -}) -.catch((err) => { - console.log(err); -}) -``` - - ### GeeTest Captcha +[API method description.](https://2captcha.com/2captcha-api#solving_geetest) + Method to solve GeeTest puzzle captcha. Returns a set of tokens as JSON. ```js @@ -178,7 +216,9 @@ solver.geetest({ ### GeeTest V4 Captcha -Method to solve GeeTest V4 puzzle captcha. Returns a set of tokens as JSON. +[API method description.](https://2captcha.com/2captcha-api#geetest-v4) + +Use this method to solve GeeTest v4. Returns the response in JSON. ```js solver.geetestV4({ @@ -210,9 +250,11 @@ solver.yandexSmart({ }) ``` -### Lemin captcha +### Lemin Cropped Captcha -Use this method to solve Lemin captcha and obtain a token to bypass the protection. +[API method description.](https://2captcha.com/2captcha-api#lemin) + +Use this method to solve Lemin and obtain a token to bypass the protection. ```js solver.lemin({ @@ -231,7 +273,11 @@ solver.lemin({ ### Cloudflare Turnstile -Use this method to solve Turnstile and obtain a token to bypass the protection. +[API method description.](https://2captcha.com/2captcha-api#turnstile) + +Use this method to solve Cloudflare Turnstile. Returns JSON with the token. + +Turnstile captcha has two types, one of them is Cloudflare Turnstile Challenge page. For Turnstile Challenge page cases, we have a [demo](https://github.com/2captcha/cloudflare-demo). Try this [demo](https://github.com/2captcha/cloudflare-demo) if you need to solve Cloudflare Turnstile Challenge page captcha. ```js solver.cloudflareTurnstile({ @@ -246,9 +292,11 @@ solver.cloudflareTurnstile({ }) ``` -

Amazon WAF Captcha (AWS WAF):

+### Amazon WAF -Use this method to solve AmazonWaf and obtain a token to bypass the protection. +[API method description.](https://2captcha.com/2captcha-api#amazon-waf) + +Use this method to solve Amazon WAF Captcha also known as AWS WAF Captcha is a part of Intelligent threat mitigation for Amazon AWS. Returns JSON with the token. ```js //INFO: The `context` value is dynamic, it is necessary to take the actual value from the page each time. @@ -266,7 +314,9 @@ solver.amazonWaf({ }) ``` -### Capy Puzzle +### Capy + +[API method description.](https://2captcha.com/2captcha-api#solving_capy) Token-based method to bypass Capy puzzle captcha. @@ -285,10 +335,12 @@ solver.capyPuzzle({ ### DataDome CAPTCHA +[API method description.](https://2captcha.com/2captcha-api#datadome) + Use this method to solve DataDome and obtain a token to bypass the protection. > [!IMPORTANT] -> To solve the DataDome captcha, you must use a proxy. It is recommended to use mobile residential proxies. +> To solve the DataDome captcha, you must use a proxy. It is recommended to use [residential proxies][Buy residential proxies]. ```js solver.dataDome({ @@ -308,6 +360,8 @@ console.log(err); ### CyberSiARA +[API method description.](https://2captcha.com/2captcha-api#cybersiara) + Use this method to solve CyberSiARA and obtain a token to bypass the protection. ```js @@ -326,6 +380,8 @@ console.log(err); ### MTCaptcha +[API method description.](https://2captcha.com/2captcha-api#mtcaptcha) + Use this method to solve MTCaptcha and obtain a token to bypass the protection. ```js @@ -343,8 +399,12 @@ console.log(err); ### Friendly Captcha +[API method description.](https://2captcha.com/2captcha-api#friendly-captcha) + Use this method to solve Friendly Captcha and obtain a token to bypass the protection. -> **Important:** To successfully use the received token, the captcha widget must not be loaded on the page. To do this, you need to abort request to `/friendlycaptcha/...module.min.js` on the page. When the captcha widget is already loaded on the page, there is a high probability that the received token will not work. + +> [!IMPORTANT] +> To successfully use the received token, the captcha widget must not be loaded on the page. To do this, you need to abort request to `/friendlycaptcha/...module.min.js` on the page. When the captcha widget is already loaded on the page, there is a high probability that the received token will not work. ```js solver.friendlyCaptcha({ @@ -359,9 +419,11 @@ console.log(err); }) ``` -

Coordinates (Click Captcha):

+### ClickCaptcha -ClickCaptcha method returns coordinates of points on captcha image. Can be used if you need to click on particular points on the image. +[API method description.](https://2captcha.com/2captcha-api#coordinates) + +The ClickCaptcha method returns the coordinates of points on the captcha image. It can be used if you need to click on particular points in the image. ```js const imageBase64 = fs.readFileSync("./tests/media/hCaptchaImage.jpg", "base64") @@ -380,7 +442,12 @@ solver.coordinates({ ### Bounding Box Method: -Bounding Box Method allows you to select objects specified in the image. To do this, you need to pass markup instructions. The instructions can be sent as text or as an image encoded in `base64` format. It is mandatory to pass at least one instruction `imginstructions` or `textinstructions`. +[API method description.](https://2captcha.com/2captcha-api#bounding_box) + + +Use Bounding Box Method when you need to select objects on the image. To do this, you need to pass the markup instructions and image for markup. The instructions can be sent as text or as an image encoded in `base64` format. +> [!IMPORTANT] +> You must to send instruction `imginstructions` or `textinstructions`. ```js solver.boundingBox({ @@ -395,29 +462,12 @@ solver.boundingBox({ }) ``` -### Usage of proxy - -Solving reCAPTCHA V2 whis a proxy, code example: - -```js -solver.recaptcha({ - pageurl: 'https://2captcha.com/demo/recaptcha-v2', - googlekey: '6LfD3PIbAAAAAJs_eEHvoOl75_83eXSqpPSRFJ_u', - proxy: "login:password@1.2.3.4:8888", // The (Username : Password @ Address : Port) of our chosen proxy - proxytype: "http" // The 'Type' of proxy, http, https, socks4, socks5. -}) -.then((res) => { - console.log(res) -}) -.catch((err) => { - console.error(err.message) -}) -``` - ## Other methods ### goodReport +[API method description.](https://2captcha.com/2captcha-api#reporting-answers) + Use this method to report good captcha answer. ```js @@ -426,6 +476,8 @@ solver.goodReport('7031846604') ### badReport +[API method description.](https://2captcha.com/2captcha-api#reporting-answers) + Use this method to report bad captcha answer. ```js @@ -434,7 +486,9 @@ solver.badReport('7031854546') ### balance -Use this method to get your account's balance +[API method description.](https://2captcha.com/2captcha-api#additional-methods) + +Use this method to get your account's balance. ```js solver.balance() @@ -458,13 +512,21 @@ solver.recaptcha({ proxytype: 'login:password@123.123.123.123:3128' }) ``` +## Examples +Examples of solving all supported captcha types are located in the [examples] directory. ## Useful articles +* [How to bypass captcha using JavaScript](https://2captcha.com/blog/how-to-use-javascript-to-bypass-captcha#how-to-solve-and-bypass-a-captcha-with-javascript-using-npm-package-2captchacaptcha-solver) +* [Bypassing Cloudflare Challenge with Puppeteer and 2Captcha](https://2captcha.com/blog/bypassing-cloudflare-challenge-with-puppeteer-and-2captcha) * [How to bypass Geetest v4 CAPTCHA](https://2captcha.com/blog/geetest-v4-support) * [Automatic reCAPTCHA V3 resolution - a tutorial for developers and customers](https://2captcha.com/blog/recaptcha-v3-automatic-resolution) -* Finding Sitekey hCaptcha +* [Custom Slider Captcha Demo](https://github.com/2captcha/custom-slider-demo) +* [Cloudflare Challenge page bypass code example](https://github.com/2captcha/cloudflare-demo) +[post options]: https://2captcha.com/2captcha-api#normal_post +[list of supported languages]: https://2captcha.com/2captcha-api#language [Buy residential proxies]: https://2captcha.com/proxy/residential-proxies -[Quick start]: https://2captcha.com/proxy?openAddTrafficModal=true \ No newline at end of file +[Quick start]: https://2captcha.com/proxy?openAddTrafficModal=true +[examples]: ./examples \ No newline at end of file From 7bd5e528340d5df2942af292c0bd6c9e4a69f242 Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Mon, 24 Jun 2024 20:01:32 +0400 Subject: [PATCH 2/8] Update package.json --- package.json | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/package.json b/package.json index c621cdb..1b38a57 100644 --- a/package.json +++ b/package.json @@ -44,11 +44,10 @@ "Friendly Captcha" ], "scripts": { - "go": "tsc && node ./dist/index.js", - "dev": "tsc && node ./issues/dev", + "build": "tsc && node ./dist/index.js", "jsdoc": "jsdoc", "docgen": "tsc && yarn jsdoc ./dist -R \"./readme.md\" -P \"./package.json\" -t \"./node_modules/jaguarjs-jsdoc\" -d \"./docs\" -r", - "test": "tsc && node ./tests/mtCaptcha.js" + "example": "tsc && node ./tests/mtCaptcha.js" }, "dependencies": { "node-fetch": "^2.6.1" From a0282a7ec8f9e35f779395360ac46c0f59dc79b9 Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Mon, 24 Jun 2024 20:03:05 +0400 Subject: [PATCH 3/8] Update tsconfig.json --- tsconfig.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tsconfig.json b/tsconfig.json index 663beed..bd926ad 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -64,7 +64,7 @@ "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */ }, "exclude": [ - "tests/*", + "examples/*", "dist/*" ] } From a9f100c1be1c1f45b49b6153bd3f1ad8eac7b675 Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Mon, 24 Jun 2024 20:30:31 +0400 Subject: [PATCH 4/8] refactor examples --- {tests => examples}/amazonWaf.js | 0 {tests => examples}/boundingBox.js | 0 {tests => examples}/capyPuzzle.js | 0 {tests => examples}/coordinates.js | 2 +- {tests => examples}/cyberSiARA.js | 0 {tests => examples}/dataDome.js | 0 {tests => examples}/friendlyCaptcha.js | 0 {tests => examples}/funcaptcha.js | 0 {tests => examples}/geetest.js | 6 +++--- {tests => examples}/geetestV4.js | 0 {tests => examples}/hcaptcha.js | 0 {tests => examples}/imageCaptcha.js | 6 ++++-- {tests => examples}/lemin.js | 0 {tests => examples}/media/hCaptchaImage.jpg | Bin {tests => examples}/media/imageCaptcha_6e584.png | Bin {tests => examples}/mtCaptcha.js | 0 {tests => examples}/recaptcha.js | 4 ++-- {tests => examples}/recaptcha_v3.js | 0 {tests => examples}/turnstile.js | 0 {tests => examples}/yandexSmart.js | 0 20 files changed, 10 insertions(+), 8 deletions(-) rename {tests => examples}/amazonWaf.js (100%) rename {tests => examples}/boundingBox.js (100%) rename {tests => examples}/capyPuzzle.js (100%) rename {tests => examples}/coordinates.js (82%) rename {tests => examples}/cyberSiARA.js (100%) rename {tests => examples}/dataDome.js (100%) rename {tests => examples}/friendlyCaptcha.js (100%) rename {tests => examples}/funcaptcha.js (100%) rename {tests => examples}/geetest.js (79%) rename {tests => examples}/geetestV4.js (100%) rename {tests => examples}/hcaptcha.js (100%) rename {tests => examples}/imageCaptcha.js (68%) rename {tests => examples}/lemin.js (100%) rename {tests => examples}/media/hCaptchaImage.jpg (100%) rename {tests => examples}/media/imageCaptcha_6e584.png (100%) rename {tests => examples}/mtCaptcha.js (100%) rename {tests => examples}/recaptcha.js (75%) rename {tests => examples}/recaptcha_v3.js (100%) rename {tests => examples}/turnstile.js (100%) rename {tests => examples}/yandexSmart.js (100%) diff --git a/tests/amazonWaf.js b/examples/amazonWaf.js similarity index 100% rename from tests/amazonWaf.js rename to examples/amazonWaf.js diff --git a/tests/boundingBox.js b/examples/boundingBox.js similarity index 100% rename from tests/boundingBox.js rename to examples/boundingBox.js diff --git a/tests/capyPuzzle.js b/examples/capyPuzzle.js similarity index 100% rename from tests/capyPuzzle.js rename to examples/capyPuzzle.js diff --git a/tests/coordinates.js b/examples/coordinates.js similarity index 82% rename from tests/coordinates.js rename to examples/coordinates.js index c98f333..f2ead1d 100644 --- a/tests/coordinates.js +++ b/examples/coordinates.js @@ -5,7 +5,7 @@ const APIKEY = process.env.APIKEY const solver = new Captcha.Solver(APIKEY); -const imageBase64 = fs.readFileSync("./tests/media/hCaptchaImage.jpg", "base64") +const imageBase64 = fs.readFileSync("./media/hCaptchaImage.jpg", "base64") solver.coordinates({ body: imageBase64, diff --git a/tests/cyberSiARA.js b/examples/cyberSiARA.js similarity index 100% rename from tests/cyberSiARA.js rename to examples/cyberSiARA.js diff --git a/tests/dataDome.js b/examples/dataDome.js similarity index 100% rename from tests/dataDome.js rename to examples/dataDome.js diff --git a/tests/friendlyCaptcha.js b/examples/friendlyCaptcha.js similarity index 100% rename from tests/friendlyCaptcha.js rename to examples/friendlyCaptcha.js diff --git a/tests/funcaptcha.js b/examples/funcaptcha.js similarity index 100% rename from tests/funcaptcha.js rename to examples/funcaptcha.js diff --git a/tests/geetest.js b/examples/geetest.js similarity index 79% rename from tests/geetest.js rename to examples/geetest.js index 35cbe20..2a79e8a 100644 --- a/tests/geetest.js +++ b/examples/geetest.js @@ -10,16 +10,16 @@ const solver = new Captcha.Solver(APIKEY); * You need to find the queries that makes the captcha on the page to API. * Then you need to make request to this API and get new `challenge`. * - * For page https://rucaptcha.com/demo/geetest, api address is https://rucaptcha.com/api/v1/captcha-demo/gee-test/init-params?t=${t} + * For page https://2captcha.com/demo/geetest, api address is https://2captcha.com/api/v1/captcha-demo/gee-test/init-params?t=${t} * Also note that when make request to API, the request uses the dynamic parameter `t` * * You can read more about sending GeeTest here https://2captcha.com/2captcha-api#solving_geetest, or here https://2captcha.com/p/geetest - * In this example I solve GeeTest from page https://2captcha.com/demo/geetest + * In this example you can see how to solve GeeTest on the page https://2captcha.com/demo/geetest * */ const t = new Date().getTime() - // below i make a request to get a new `challenge`. + // below is a request to get a new `challenge`. const response = await fetch(`https://2captcha.com/api/v1/captcha-demo/gee-test/init-params?t=${t}`) const data = await response.json() diff --git a/tests/geetestV4.js b/examples/geetestV4.js similarity index 100% rename from tests/geetestV4.js rename to examples/geetestV4.js diff --git a/tests/hcaptcha.js b/examples/hcaptcha.js similarity index 100% rename from tests/hcaptcha.js rename to examples/hcaptcha.js diff --git a/tests/imageCaptcha.js b/examples/imageCaptcha.js similarity index 68% rename from tests/imageCaptcha.js rename to examples/imageCaptcha.js index 0e32472..c89b2dc 100644 --- a/tests/imageCaptcha.js +++ b/examples/imageCaptcha.js @@ -4,13 +4,15 @@ require('dotenv').config(); const APIKEY = process.env.APIKEY const solver = new Captcha.Solver(APIKEY); -const imageBase64 = fs.readFileSync("./tests/media/imageCaptcha_6e584.png", "base64") +const imageBase64 = fs.readFileSync("./media/imageCaptcha_6e584.png", "base64") solver.imageCaptcha({ body: imageBase64, numeric: 4, min_len: 5, - max_len: 5 + max_len: 5, + lang: 'en', + textinstructions: 'Type text on the image' }) .then((res) => { console.log(res); diff --git a/tests/lemin.js b/examples/lemin.js similarity index 100% rename from tests/lemin.js rename to examples/lemin.js diff --git a/tests/media/hCaptchaImage.jpg b/examples/media/hCaptchaImage.jpg similarity index 100% rename from tests/media/hCaptchaImage.jpg rename to examples/media/hCaptchaImage.jpg diff --git a/tests/media/imageCaptcha_6e584.png b/examples/media/imageCaptcha_6e584.png similarity index 100% rename from tests/media/imageCaptcha_6e584.png rename to examples/media/imageCaptcha_6e584.png diff --git a/tests/mtCaptcha.js b/examples/mtCaptcha.js similarity index 100% rename from tests/mtCaptcha.js rename to examples/mtCaptcha.js diff --git a/tests/recaptcha.js b/examples/recaptcha.js similarity index 75% rename from tests/recaptcha.js rename to examples/recaptcha.js index 1e94967..9f9febe 100644 --- a/tests/recaptcha.js +++ b/examples/recaptcha.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY) solver.recaptcha({ pageurl: 'https://2captcha.com/demo/recaptcha-v2', diff --git a/tests/recaptcha_v3.js b/examples/recaptcha_v3.js similarity index 100% rename from tests/recaptcha_v3.js rename to examples/recaptcha_v3.js diff --git a/tests/turnstile.js b/examples/turnstile.js similarity index 100% rename from tests/turnstile.js rename to examples/turnstile.js diff --git a/tests/yandexSmart.js b/examples/yandexSmart.js similarity index 100% rename from tests/yandexSmart.js rename to examples/yandexSmart.js From ec9ed48d0b009e1937b04748b68daf6d54203a0d Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Mon, 24 Jun 2024 20:32:41 +0400 Subject: [PATCH 5/8] delete hcaptcha.md --- docs/hcaptcha.md | 56 ------------------------------------------------ 1 file changed, 56 deletions(-) delete mode 100644 docs/hcaptcha.md diff --git a/docs/hcaptcha.md b/docs/hcaptcha.md deleted file mode 100644 index 35efb8e..0000000 --- a/docs/hcaptcha.md +++ /dev/null @@ -1,56 +0,0 @@ -

hCaptcha

-

< - Back To Home

- - -

What is HCaptcha and how does it work?

-

hCaptcha is a primarally image-based bot prevention. It comes in two models, Publisher and Enterprise. hCaptcha Publisher being the free-to-use model. hCaptcha Enterprise employs machine-learning based threat detection, allowing select fingerprints and analyitics bypass the captcha all togther through gathered telemetry on the user. When using 2Captcha, both of these are treated virtually the same, 2Captha's solutions solve the captcha regardless, ignoring the optional fingerprint method.

-

-

How to find an hCaptcha sitekey

- -
-

-A major site that uses hCaptcha is Discord, so for this example that's what we'll use. The two required parameters for using the 2captcha service for hCaptcha is a SiteKey & the domain the hCaptcha widget/iframe shows up on. Due to how hCaptcha works, the iFrame only is accessable if hCaptcha Enterprise determines you to be of moderate risk, so you may have to try a few times to get it. - -
- -Enter some random data, and press continue. -
- -
- -With a little bit of luck, you should see the hCaptcha widget. -
- -
- -From there, you'll be able to open up dev-tools. (With Chromium, Ctrl + Shift + I), and be able to find a line similar to the one highlighted in this image. -
- -The URL there contains the sitekey within the Query Parameter portions of the URL. -https://newassets.hcaptcha.com/captcha/v1/f6912ef/static/hcaptcha-checkbox.html#id=0iqupfjeet7&host=discord.com&sentry=true&reportapi=https%3A%2F%2Faccounts.hcaptcha.com&recaptchacompat=true&custom=false&hl=en&tplinks=on&sitekey=4c672d35-0701-42b2-88c3-78380b0db560&theme=dark - -Here we can see it says sitekey=4c672d35-0701-42b2-88c3-78380b0db560, and thats the site key! The host is also specified, host=discord.com. Using both of these parameters, we're able to construct some code to automatically complete this captcha. -

-
- -```js -const Captcha = require("2captcha"); -const solver = new Captcha.Solver(""); - -// Sitekey & Domain -solver.hCaptcha("4c672d35-0701-42b2-88c3-78380b0db560", "discord.com") -.then((res) = { - console.log(res); -}) - -solver.hcaptcha({ - pageurl: "https://discord.com", - sitekey: "4c672d35-0701-42b2-88c3-78380b0db560" -}) -.then((res) => { - console.log(res); -}) -.catch((err) => { - console.log(err); -}) -``` \ No newline at end of file From 5cfc4035f022254bdbead5d62b3a6ee817f4b609 Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Mon, 24 Jun 2024 20:45:04 +0400 Subject: [PATCH 6/8] update ignore files --- .gitignore | 5 ++--- .npmignore | 5 +---- 2 files changed, 3 insertions(+), 7 deletions(-) diff --git a/.gitignore b/.gitignore index 5c7fd09..670a631 100644 --- a/.gitignore +++ b/.gitignore @@ -1,8 +1,7 @@ +# Directories /dist /node_modules /out -issues/ - -download.jpg +# Files .env \ No newline at end of file diff --git a/.npmignore b/.npmignore index 211f99d..46edbad 100644 --- a/.npmignore +++ b/.npmignore @@ -1,16 +1,13 @@ # Directories src/ node_modules/ -tests/ +examples/ tsconfig.json/ out/ -docs/ -issues/ # Files .yarn.lock .gitignore -download.jpg readme.md jsdoc.json .env \ No newline at end of file From 4d1287d5fa766a3a7a778fa6b498cc398df1ece0 Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Tue, 25 Jun 2024 22:11:31 +0400 Subject: [PATCH 7/8] refactoring of example files --- examples/amazonWaf.js | 4 ++-- examples/boundingBox.js | 4 ++-- examples/capyPuzzle.js | 4 ++-- examples/coordinates.js | 6 +++--- examples/cyberSiARA.js | 4 ++-- examples/dataDome.js | 4 ++-- examples/friendlyCaptcha.js | 4 ++-- examples/funcaptcha.js | 4 ++-- examples/geetest.js | 4 ++-- examples/geetestV4.js | 4 ++-- examples/hcaptcha.js | 4 ++-- examples/imageCaptcha.js | 4 ++-- examples/lemin.js | 4 ++-- examples/mtCaptcha.js | 4 ++-- examples/recaptcha_v3.js | 4 ++-- examples/turnstile.js | 4 ++-- examples/yandexSmart.js | 4 ++-- 17 files changed, 35 insertions(+), 35 deletions(-) diff --git a/examples/amazonWaf.js b/examples/amazonWaf.js index 14fad6a..f475c53 100644 --- a/examples/amazonWaf.js +++ b/examples/amazonWaf.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); //INFO: The `context` value is dynamic, it is necessary to take the actual value from the page each time. solver.amazonWaf({ diff --git a/examples/boundingBox.js b/examples/boundingBox.js index ce75812..56a79c1 100644 --- a/examples/boundingBox.js +++ b/examples/boundingBox.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.boundingBox({ image: "", diff --git a/examples/capyPuzzle.js b/examples/capyPuzzle.js index 1cc37e6..27ca164 100644 --- a/examples/capyPuzzle.js +++ b/examples/capyPuzzle.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.capyPuzzle({ pageurl: "https://www.capy.me/account/register/", diff --git a/examples/coordinates.js b/examples/coordinates.js index f2ead1d..3c21f14 100644 --- a/examples/coordinates.js +++ b/examples/coordinates.js @@ -1,8 +1,8 @@ const fs = require('fs') -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); const imageBase64 = fs.readFileSync("./media/hCaptchaImage.jpg", "base64") @@ -10,7 +10,7 @@ const imageBase64 = fs.readFileSync("./media/hCaptchaImage.jpg", "base64") solver.coordinates({ body: imageBase64, textinstructions: 'Select all photos containing the boat' - }) +}) .then((res) => { console.log(res); }) diff --git a/examples/cyberSiARA.js b/examples/cyberSiARA.js index 20d9e16..4a8ae98 100644 --- a/examples/cyberSiARA.js +++ b/examples/cyberSiARA.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.cyberSiARA({ pageurl: "https://www.cybersiara.com/book-a-demo", diff --git a/examples/dataDome.js b/examples/dataDome.js index b1e21ad..3e70f5b 100644 --- a/examples/dataDome.js +++ b/examples/dataDome.js @@ -1,9 +1,9 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY const proxy = process.env.proxy const proxytype = process.env.proxytype -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.dataDome({ pageurl: "https://rendezvousparis.hermes.com/client/register", diff --git a/examples/friendlyCaptcha.js b/examples/friendlyCaptcha.js index f78317c..4b38e51 100644 --- a/examples/friendlyCaptcha.js +++ b/examples/friendlyCaptcha.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.friendlyCaptcha({ pageurl: "https://geizhals.de/?liftban=1&from=/455973138?fsean=5901747021356", diff --git a/examples/funcaptcha.js b/examples/funcaptcha.js index 38a7005..bd4fee6 100644 --- a/examples/funcaptcha.js +++ b/examples/funcaptcha.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.funCaptcha({ pageurl: "https://api.funcaptcha.com/fc/api/nojs/?pkey=69A21A01-CC7B-B9C6-0F9A-E7FA06677FFC", diff --git a/examples/geetest.js b/examples/geetest.js index 2a79e8a..28219e4 100644 --- a/examples/geetest.js +++ b/examples/geetest.js @@ -1,8 +1,8 @@ const fetch = require('node-fetch'); -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); ;(async () => { /** diff --git a/examples/geetestV4.js b/examples/geetestV4.js index 19afc93..bbfef3e 100644 --- a/examples/geetestV4.js +++ b/examples/geetestV4.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.geetestV4({ pageurl: 'https://2captcha.com/demo/geetest-v4', diff --git a/examples/hcaptcha.js b/examples/hcaptcha.js index 6bb574c..767dd1e 100644 --- a/examples/hcaptcha.js +++ b/examples/hcaptcha.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.hcaptcha({ pageurl: "https://2captcha.com/demo/hcaptcha", diff --git a/examples/imageCaptcha.js b/examples/imageCaptcha.js index c89b2dc..6e7a3bf 100644 --- a/examples/imageCaptcha.js +++ b/examples/imageCaptcha.js @@ -1,8 +1,8 @@ const fs = require('fs') -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); const imageBase64 = fs.readFileSync("./media/imageCaptcha_6e584.png", "base64") diff --git a/examples/lemin.js b/examples/lemin.js index a4c9b9a..6479305 100644 --- a/examples/lemin.js +++ b/examples/lemin.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.lemin({ pageurl:'https://2captcha.com/demo/lemin', diff --git a/examples/mtCaptcha.js b/examples/mtCaptcha.js index 46624a6..922e9a9 100644 --- a/examples/mtCaptcha.js +++ b/examples/mtCaptcha.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.mtCaptcha({ pageurl: "https://service.mtcaptcha.com/mtcv1/demo/index.html", diff --git a/examples/recaptcha_v3.js b/examples/recaptcha_v3.js index 356fbe4..8a8e6e9 100644 --- a/examples/recaptcha_v3.js +++ b/examples/recaptcha_v3.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.recaptcha({ pageurl: 'https://2captcha.com/demo/recaptcha-v3', diff --git a/examples/turnstile.js b/examples/turnstile.js index 100dea3..e204866 100644 --- a/examples/turnstile.js +++ b/examples/turnstile.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.cloudflareTurnstile({ pageurl: "https://app.nodecraft.com/login", diff --git a/examples/yandexSmart.js b/examples/yandexSmart.js index ba2d249..2886d64 100644 --- a/examples/yandexSmart.js +++ b/examples/yandexSmart.js @@ -1,7 +1,7 @@ -const Captcha = require("../dist/index.js"); +const TwoCaptcha = require("../dist/index.js"); require('dotenv').config(); const APIKEY = process.env.APIKEY -const solver = new Captcha.Solver(APIKEY); +const solver = new TwoCaptcha.Solver(APIKEY); solver.yandexSmart({ pageurl: "https://captcha-api.yandex.ru/demo", From 230757f5f8ae7cec70958e20f7440b01d6c01b44 Mon Sep 17 00:00:00 2001 From: dzmitry-duboyski Date: Tue, 25 Jun 2024 22:28:10 +0400 Subject: [PATCH 8/8] add params for Amazon WAF captcha --- src/structs/2captcha.ts | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/structs/2captcha.ts b/src/structs/2captcha.ts index f95c5aa..5185bdb 100644 --- a/src/structs/2captcha.ts +++ b/src/structs/2captcha.ts @@ -140,6 +140,8 @@ export interface paramsAmazonWAF { sitekey: string, iv: string context: string, + challenge_script?: string, + captcha_script?: string, header_acao?: boolean, pingback?: string, soft_id?: number, @@ -821,11 +823,13 @@ export class Solver { * * [Read more about "Amazon WAF" captcha](https://2captcha.com/2captcha-api#amazon-waf). * - * @param {{ pageurl, sitekey, iv, context, pingback, proxy, proxytype}} params The `amazonWaf` method takes arguments as an object. Thus, the `pageurl`, `sitekey`, `iv`, `context` fields in the passed object are mandatory. + * @param {{ pageurl, sitekey, iv, context, challenge_script, captcha_script, pingback, proxy, proxytype}} params The `amazonWaf` method takes arguments as an object. Thus, the `pageurl`, `sitekey`, `iv`, `context` fields in the passed object are mandatory. * @param {string} params.pageurl Is the full `URL` of page where you were challenged by the captcha. * @param {string} params.sitekey Is a value of `key` parameter in the page source. * @param {string} params.iv Is a value of `iv` parameter in the page source. * @param {string} params.context Is a value of `context` parameter in the page source. + * @param {string} params.challenge_script The source URL of `challenge.js` script on the page. + * @param {string} params.captcha_script The source URL of `captcha.js` script on the page. * @param {string} params.pingback URL for pingback (callback) response that will be sent when captcha is solved. URL should be registered on the server. [More info here](https://2captcha.com/2captcha-api#pingback). * @param {string} params.proxy Format: `login:password@123.123.123.123:3128` You can find more info about proxies [here](https://2captcha.com/2captcha-api#proxies). * @param {string} params.proxytype Type of your proxy: `HTTP`, `HTTPS`, `SOCKS4`, `SOCKS5`.