puppyproxy 1.1.1 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -0
- package/package.json +1 -1
- package/src/PuppyProxy.js +4 -0
- package/src/network/RequestClient.js +24 -0
package/README.md
CHANGED
|
@@ -50,6 +50,8 @@ log.highlight("TESTING: runCollector");
|
|
|
50
50
|
|
|
51
51
|
await pp.init(true); // true forces run the collector
|
|
52
52
|
|
|
53
|
+
console.log(pp.request.createProxyRequestPool().length, "proxies in the pool after init");
|
|
54
|
+
|
|
53
55
|
log.highlight("TESTING: RequestClient");
|
|
54
56
|
|
|
55
57
|
log.bold("----- pp.request.fetch")
|
package/package.json
CHANGED
package/src/PuppyProxy.js
CHANGED
|
@@ -97,6 +97,10 @@ export default class PuppyProxy {
|
|
|
97
97
|
return this.request.createProxyRequest(url, options);
|
|
98
98
|
}
|
|
99
99
|
|
|
100
|
+
createProxyRequestPool(url, options = {}) {
|
|
101
|
+
return this.request.createProxyRequestPool(url, options);
|
|
102
|
+
}
|
|
103
|
+
|
|
100
104
|
/**
|
|
101
105
|
* Trigger the proxy collection worker
|
|
102
106
|
*/
|
|
@@ -281,4 +281,28 @@ export default class RequestClient {
|
|
|
281
281
|
createProxyRequest(url, options) {
|
|
282
282
|
return new ProxyRequest(this, url, options);
|
|
283
283
|
}
|
|
284
|
+
|
|
285
|
+
//return an array of ProxyRequest objects, one for each proxy
|
|
286
|
+
createProxyRequestPool(url, options = {}) {
|
|
287
|
+
const oldLOG = this.config.LOG;
|
|
288
|
+
this.config.LOG = {}; //suppress logs for this operation
|
|
289
|
+
let currentWithoutNew = 0;
|
|
290
|
+
const withoutNewLimit = 1000;
|
|
291
|
+
const proxyRequests = [];
|
|
292
|
+
const uniqueProxies = [];
|
|
293
|
+
|
|
294
|
+
while (currentWithoutNew < withoutNewLimit) {
|
|
295
|
+
const pr = this.createProxyRequest(url, options);
|
|
296
|
+
const proxy = pr.options.AGENT?.USINGSCRAPED;
|
|
297
|
+
|
|
298
|
+
if (proxy && !uniqueProxies.includes(proxy)) {
|
|
299
|
+
proxyRequests.push(pr);
|
|
300
|
+
uniqueProxies.push(proxy);
|
|
301
|
+
currentWithoutNew = 0;
|
|
302
|
+
} else currentWithoutNew++;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
this.config.LOG = oldLOG;
|
|
306
|
+
return proxyRequests;
|
|
307
|
+
}
|
|
284
308
|
}
|