Automatically migrated from Gitolite
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Sven Slootweg 2f8d3dcca2 1.0.2 9 years ago
lib td.country contains countryname itself 9 years ago
.gitignore v1.0.0 10 years ago
README.md v1.0.1: README update (safety warning) 10 years ago
gulpfile.js v1.0.0 10 years ago
index.coffee v1.0.0 10 years ago
index.js v1.0.0 10 years ago
package.json 1.0.2 9 years ago
test.coffee v1.0.0 10 years ago

README.md

hma-proxy-parse

Good game, HideMyAss, but I win :)

This module extracts (parses) proxy details including the IP address from http://proxylist.hidemyass.com/ and anything else using the same system, despite their (rather heavy) CSS-based obfuscation.

Note that this module only does the parsing; you're responsible for fetching the source HTML yourself.

Caution!

Public proxies are not safe to use. They can see your IP address and the traffic you send. You are effectively giving the proxy operator full control and knowledge over your browsing, and they may even inject malware in the responses.

If you need to browse the internet privately, consider using Tor instead - however, please make sure to read the caveats that you need to keep in mind. Even with these caveats, Tor is vastly more secure than a public proxy.

License

WTFPL or CC0, whichever you prefer. A donation and/or attribution are appreciated, but not required.

Donate

My income consists entirely of donations for my projects. If this module is useful to you, consider making a donation!

You can donate using Bitcoin, PayPal, Gratipay, Flattr, cash-in-mail, SEPA transfers, and pretty much anything else.

Bitcoins can also be sent to 1KafMHn6YEDFkUSoHK6pKkqqmfJUF5Wd1C directly :)

Contributing

Pull requests welcome. Please make sure your modifications are in line with the overall code style, and ensure that you're editing the .coffee files, not the .js files.

Build tool of choice is gulp; simply run gulp while developing, and it will watch for changes.

Be aware that by making a pull request, you agree to release your modifications under the licenses stated above.

Usage

You can input HTML from any source, but this example uses bhttp in Promises mode.

var hmaProxyParse = require("hma-proxy-parse");
var bhttp = require("bhttp");
var Promise = require("bluebird");

Promise.try(function(){
	return bhttp.get("http://proxylist.hidemyass.com/");
}).then(function(response){
	console.log(hmaProxyParse(response.body.toString()));
});

API

hmaProxyParse(html)

Parses the specified html, and returns an array of objects with proxy information. The objects look something like this:

{
	updateTimestamp: '1422645602',
	ip: '187.108.223.204',
	port: '8080',
	country: 'br',
	speed: '2441',
	connectionTime: '235',
	protocol: 'HTTP',
	anonymity: 'Low'
}

It doesn't attempt to parse the actual data provided - all data is directly as specified in the list, and you'll have to figure out what to do with it. I have no idea, for example, what the bounds on speed or connectionTime are, or what the possible options for anonymity are.

If this helped you, don't forget to donate ;)