gsearch-node
API for making google search requests with captcha support
Installation
`npm install -S gsearch-node`
API explained
- Initailization (with deathbycaptcha as captcha solver)
var deathByCaptcha = require("deathbycaptcha")
var dbc = new deathByCaptcha("username", "password")
var gsearch = require("gsearch-node")
var gs = new gsearch({solver: dbc})
-
Initailization (with custom solver)
var captchaSolver = {
solve: function (img, cb) {
if (err) {
cb (null, {
err: err,
solution: null
})
return
}
cb (null, {
err: null,
solution: "solved captcha as string"
})
}
}
-
API methods
-
gs.get(searchString, cb)
This is an async function which returns a cb
with (nullVar, respObj)
.
nullVar
is a variable with null
value.
respObj
is an object with following structure :-
respObj = {
err: null,
resp: {},
parsed: {}
}
-
gs.getSync(seachString)
This is a sync function which returns 'respObj' as described above.
-
Note on callbacks
The format of callbacks for this API is not (err, resp)
but is (nullVar, respObj)
where err
is a property of respObj
.
This is because I have used deasync lib which throws err
if (err, resp)
format is used for the callback which make the code to break.
Error handling is more easier as we can use if
syntax instead of try catch
.
Test/Usage
(function () {
var gsearch = require("gsearch-node")
var gs = new gsearch({solver: {}})
console.log("Sync version")
var searchPage = gs.getSync("Everyone shifting to nodejs?")
if (!searchPage.err) {
$ = searchPage.parsed
$("a").each(function (i, a) {
console.log($(a).attr("href"))
})
} else {
console.log(searchPage.err)
}
console.log("\nAsync version")
gs.get("Everyone shifting to nodejs?", function (nullVar, searchPage) {
if (!searchPage.err) {
$ = searchPage.parsed
$("a").each(function (i, a) {
console.log($(a).attr("href"))
})
} else {
console.log(searchPage.err)
}
})
})()
Donate
If this repository helps you anyhow, please don't mind coming back and
Buy Me Coffee
OR you can use
Gratipay
to show your appreciation and gratitude.