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
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
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
-
-
-
-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
diff --git a/tests/amazonWaf.js b/examples/amazonWaf.js
similarity index 91%
rename from tests/amazonWaf.js
rename to examples/amazonWaf.js
index 14fad6a..f475c53 100644
--- a/tests/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/tests/boundingBox.js b/examples/boundingBox.js
similarity index 99%
rename from tests/boundingBox.js
rename to examples/boundingBox.js
index ce75812..56a79c1 100644
--- a/tests/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/tests/capyPuzzle.js b/examples/capyPuzzle.js
similarity index 74%
rename from tests/capyPuzzle.js
rename to examples/capyPuzzle.js
index 1cc37e6..27ca164 100644
--- a/tests/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/tests/coordinates.js b/examples/coordinates.js
similarity index 61%
rename from tests/coordinates.js
rename to examples/coordinates.js
index c98f333..3c21f14 100644
--- a/tests/coordinates.js
+++ b/examples/coordinates.js
@@ -1,16 +1,16 @@
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("./tests/media/hCaptchaImage.jpg", "base64")
+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/tests/cyberSiARA.js b/examples/cyberSiARA.js
similarity index 81%
rename from tests/cyberSiARA.js
rename to examples/cyberSiARA.js
index 20d9e16..4a8ae98 100644
--- a/tests/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/tests/dataDome.js b/examples/dataDome.js
similarity index 90%
rename from tests/dataDome.js
rename to examples/dataDome.js
index b1e21ad..3e70f5b 100644
--- a/tests/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/tests/friendlyCaptcha.js b/examples/friendlyCaptcha.js
similarity index 75%
rename from tests/friendlyCaptcha.js
rename to examples/friendlyCaptcha.js
index f78317c..4b38e51 100644
--- a/tests/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/tests/funcaptcha.js b/examples/funcaptcha.js
similarity index 78%
rename from tests/funcaptcha.js
rename to examples/funcaptcha.js
index 38a7005..bd4fee6 100644
--- a/tests/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/tests/geetest.js b/examples/geetest.js
similarity index 73%
rename from tests/geetest.js
rename to examples/geetest.js
index 35cbe20..28219e4 100644
--- a/tests/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 () => {
/**
@@ -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 74%
rename from tests/geetestV4.js
rename to examples/geetestV4.js
index 19afc93..bbfef3e 100644
--- a/tests/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/tests/hcaptcha.js b/examples/hcaptcha.js
similarity index 74%
rename from tests/hcaptcha.js
rename to examples/hcaptcha.js
index 6bb574c..767dd1e 100644
--- a/tests/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/tests/imageCaptcha.js b/examples/imageCaptcha.js
similarity index 50%
rename from tests/imageCaptcha.js
rename to examples/imageCaptcha.js
index 0e32472..6e7a3bf 100644
--- a/tests/imageCaptcha.js
+++ b/examples/imageCaptcha.js
@@ -1,16 +1,18 @@
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("./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 78%
rename from tests/lemin.js
rename to examples/lemin.js
index a4c9b9a..6479305 100644
--- a/tests/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/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 73%
rename from tests/mtCaptcha.js
rename to examples/mtCaptcha.js
index 46624a6..922e9a9 100644
--- a/tests/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/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 78%
rename from tests/recaptcha_v3.js
rename to examples/recaptcha_v3.js
index 356fbe4..8a8e6e9 100644
--- a/tests/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/tests/turnstile.js b/examples/turnstile.js
similarity index 74%
rename from tests/turnstile.js
rename to examples/turnstile.js
index 100dea3..e204866 100644
--- a/tests/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/tests/yandexSmart.js b/examples/yandexSmart.js
similarity index 74%
rename from tests/yandexSmart.js
rename to examples/yandexSmart.js
index ba2d249..2886d64 100644
--- a/tests/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",
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"
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`.
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/*"
]
}