File tree 6 files changed +224
-0
lines changed
6 files changed +224
-0
lines changed Original file line number Diff line number Diff line change
1
+ # Logs
2
+ logs
3
+ * .log
4
+ npm-debug.log *
5
+ yarn-debug.log *
6
+ yarn-error.log *
7
+ lerna-debug.log *
8
+ .pnpm-debug.log *
9
+
10
+ # Diagnostic reports (https://nodejs.org/api/report.html)
11
+ report. [0-9 ]* . [0-9 ]* . [0-9 ]* . [0-9 ]* .json
12
+
13
+ # Runtime data
14
+ pids
15
+ * .pid
16
+ * .seed
17
+ * .pid.lock
18
+
19
+ # Directory for instrumented libs generated by jscoverage/JSCover
20
+ lib-cov
21
+
22
+ # Coverage directory used by tools like istanbul
23
+ coverage
24
+ * .lcov
25
+
26
+ # nyc test coverage
27
+ .nyc_output
28
+
29
+ # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
30
+ .grunt
31
+
32
+ # Bower dependency directory (https://bower.io/)
33
+ bower_components
34
+
35
+ # node-waf configuration
36
+ .lock-wscript
37
+
38
+ # Compiled binary addons (https://nodejs.org/api/addons.html)
39
+ build /Release
40
+
41
+ # Dependency directories
42
+ node_modules /
43
+ jspm_packages /
44
+
45
+ # Snowpack dependency directory (https://snowpack.dev/)
46
+ web_modules /
47
+
48
+ # TypeScript cache
49
+ * .tsbuildinfo
50
+
51
+ # Optional npm cache directory
52
+ .npm
53
+
54
+ # Optional eslint cache
55
+ .eslintcache
56
+
57
+ # Optional stylelint cache
58
+ .stylelintcache
59
+
60
+ # Microbundle cache
61
+ .rpt2_cache /
62
+ .rts2_cache_cjs /
63
+ .rts2_cache_es /
64
+ .rts2_cache_umd /
65
+
66
+ # Optional REPL history
67
+ .node_repl_history
68
+
69
+ # Output of 'npm pack'
70
+ * .tgz
71
+
72
+ # Yarn Integrity file
73
+ .yarn-integrity
74
+
75
+ # dotenv environment variable files
76
+ .env
77
+ .env.development.local
78
+ .env.test.local
79
+ .env.production.local
80
+ .env.local
81
+
82
+ # parcel-bundler cache (https://parceljs.org/)
83
+ .cache
84
+ .parcel-cache
85
+
86
+ # Next.js build output
87
+ .next
88
+ out
89
+
90
+ # Nuxt.js build / generate output
91
+ .nuxt
92
+ dist
93
+
94
+ # Gatsby files
95
+ .cache /
96
+ # Comment in the public line in if your project uses Gatsby and not Next.js
97
+ # https://nextjs.org/blog/next-9-1#public-directory-support
98
+ # public
99
+
100
+ # vuepress build output
101
+ .vuepress /dist
102
+
103
+ # vuepress v2.x temp and cache directory
104
+ .temp
105
+ .cache
106
+
107
+ # Docusaurus cache and generated files
108
+ .docusaurus
109
+
110
+ # Serverless directories
111
+ .serverless /
112
+
113
+ # FuseBox cache
114
+ .fusebox /
115
+
116
+ # DynamoDB Local files
117
+ .dynamodb /
118
+
119
+ # TernJS port file
120
+ .tern-port
121
+
122
+ # Stores VSCode versions used for testing VSCode extensions
123
+ .vscode-test
124
+
125
+ # yarn v2
126
+ .yarn /cache
127
+ .yarn /unplugged
128
+ .yarn /build-state.yml
129
+ .yarn /install-state.gz
130
+ .pnp. *
Original file line number Diff line number Diff line change
1
+ # WebSocket API demo for Node.js and [ ws] ( https://www.npmjs.com/package/ws )
2
+
3
+ ## Install dependencies
4
+ Definetely works fine with Node.js v16+
5
+
6
+ ``` sh
7
+ yarn
8
+ # or
9
+ npm i
10
+ ```
11
+
12
+ ## Run
13
+
14
+ ``` sh
15
+ yarn start
16
+ # or
17
+ npm start
18
+ ```
Original file line number Diff line number Diff line change
1
+ import WebSocket from 'ws'
2
+ import { readFile } from 'node:fs/promises'
3
+
4
+ const img = await readFile ( './captcha.jpeg' , { encoding : 'base64' } )
5
+ const ws = new WebSocket ( 'wss://s.2captcha.com' )
6
+
7
+ const authData = {
8
+ method : 'auth' ,
9
+ requestId : `auth_${ Date . now ( ) } ` ,
10
+ key : process . env . APIKEY || '' ,
11
+ options : {
12
+ allSessions : true ,
13
+ suppressSuccess : false
14
+ }
15
+ }
16
+
17
+ const captchData = {
18
+ method : 'normal' ,
19
+ body : img ,
20
+ requestId : `captcha_${ Date . now ( ) } ` ,
21
+ options : {
22
+ minLen : 4 ,
23
+ maxLen : 7 ,
24
+ lang : 'ru'
25
+ }
26
+ }
27
+
28
+
29
+ ws . on ( 'open' , ( ) => {
30
+ console . log ( `connection opened` )
31
+ ws . send ( JSON . stringify ( authData ) )
32
+ } )
33
+
34
+ ws . on ( 'close' , ( ) => {
35
+ console . log ( `Connection closed.` ) ;
36
+ } )
37
+
38
+ ws . on ( 'message' , ( incomingMsg ) => {
39
+ const data = JSON . parse ( incomingMsg )
40
+ switch ( data . method ) {
41
+ case 'auth' :
42
+ if ( ! data . success ) return console . log ( `Auth failed: ${ data . error } ` )
43
+ console . log ( `Authenticated, sending captcha...` )
44
+ ws . send ( JSON . stringify ( captchData ) )
45
+ break
46
+ case 'normal' :
47
+ if ( ! data . success ) return console . log ( `Captcha not accepted: ${ data . error } ` )
48
+ console . log ( `Captcha accepted. Id is ${ data . captchaId } ` )
49
+ break
50
+ case 'solution' :
51
+ if ( ! data . success ) return console . log ( `Solution failed: ${ data . error } ` )
52
+ console . log ( `Captcha with id ${ data . captchaId } is solved. The answer is: ${ data . code } ` )
53
+ ws . close ( )
54
+ break
55
+ default :
56
+ console . log ( data )
57
+ }
58
+ } )
59
+
Original file line number Diff line number Diff line change
1
+ {
2
+ "type" : " module" ,
3
+ "scripts" : {
4
+ "start" : " node index.js"
5
+ },
6
+ "dependencies" : {
7
+ "ws" : " ^8.11.0"
8
+ }
9
+ }
Original file line number Diff line number Diff line change
1
+ # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
2
+ # yarn lockfile v1
3
+
4
+
5
+ ws@^8.11.0 :
6
+ version "8.11.0"
7
+ resolved "https://registry.yarnpkg.com/ws/-/ws-8.11.0.tgz#6a0d36b8edfd9f96d8b25683db2f8d7de6e8e143"
8
+ integrity sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg==
You can’t perform that action at this time.
0 commit comments