Skip to content

Instantly share code, notes, and snippets.

View BrunoBernardino's full-sized avatar

Bruno Bernardino BrunoBernardino

View GitHub Profile
@BrunoBernardino
BrunoBernardino / breakVisualCaptcha.js
Created August 15, 2013 20:06
This is code based off of https://gist.github.com/ipeychev/6234050, refactored to be possible to make multiple attempts in one execution. 100 attempts are equivalent to 500 post requests (every "attempt" tries to post 5 images). I'm actually getting < 5-7% successful break attempt rates, but it's still unnacceptable and I'll use this code to che…
// This code has a break rate of < 10%. It's still unnacceptable, though.
var request = require( 'request' ).defaults( { jar: true } ),
q = require( 'q' );
var URI = 'http://demo.visualcaptcha.net/';
// Make a post
var makePost = function makePost( imgHash, partialURL, tryNumber ) {
var deferred = q.defer(),
@BrunoBernardino
BrunoBernardino / code.js
Created December 3, 2016 14:05
AWS Lambda Redirect code
'use strict';
const finish = (cb, url) => {
console.log('Sending to', url);
cb(null, {url: url});
}
exports.handler = (event, context, callback) => {
const defaultURL = 'http://example.com';
@BrunoBernardino
BrunoBernardino / session.js
Last active November 13, 2017 17:37
Webtask for session auth.
module.exports = function(context, cb) {
if (context.body) {
if (!context.body.email || !context.body.pass) {
return cb(401, 'Unauthorized');
}
} else if (!context.headers['x-token']) {
return cb(403, 'Forbidden');
}
const now = new Date();
@BrunoBernardino
BrunoBernardino / api-query.js
Created October 17, 2017 09:24
Webtask for api-query auth
module.exports = function(context, cb) {
if (!context.query.apiKey) {
return cb(401, 'Unauthorized');
}
cb(null, {
authenticated: true,
user: 'Zapier',
});
};
@BrunoBernardino
BrunoBernardino / api-header.js
Last active November 13, 2017 17:37
Webtask for api-header auth.
module.exports = function(context, cb) {
if (!context.headers['x-api-key']) {
return cb(401, 'Unauthorized');
}
cb(null, {
authenticated: true,
user: 'user',
});
};
@BrunoBernardino
BrunoBernardino / oauth2-authorize.js
Created October 20, 2017 10:39
Webtask for oauth2-authorize.
module.exports = function(context, request, response) {
if (request.method !== 'GET') {
response.writeHead(400, { 'Content-Type': 'text/html' });
return response.end('Must be GET request');
}
if (context.query.response_type !== 'code') {
response.writeHead(400, { 'Content-Type': 'text/html' });
return response.end('response_type must be "code"');
}
@BrunoBernardino
BrunoBernardino / oauth2-test.js
Created October 20, 2017 10:27
Webtask for oauth2-test.
module.exports = function(context, cb) {
if (!context.headers.authorization) {
return cb(403, 'Forbidden');
}
if (context.headers.authorization !== 'Bearer a_token' && context.headers.authorization !== 'Bearer a_new_token') {
return cb(401, 'Unauthorized');
}
cb(null, {
@BrunoBernardino
BrunoBernardino / recipe-create.js
Created November 13, 2017 17:34
Webtask for recipe-create.
module.exports = function(context, cb) {
cb(null, {
"id":"1",
"createdAt":1471984289,
"name":"name 1",
"authorId":63,
"directions":"directions 1",
"style":"style 1"
});
};
@BrunoBernardino
BrunoBernardino / fields-input.js
Created October 24, 2017 15:45
Webtask for getting input fields.
module.exports = function(context, cb) {
cb(null, [
{
"key":"authorId",
"label":"Author",
"type":"number",
"required": true,
"helpText": "This is some help, yo!"
}
]);
@BrunoBernardino
BrunoBernardino / fields-output.js
Created October 24, 2017 15:10
Webtask for output fields.
module.exports = function(context, cb) {
cb(null, [
{
"key":"name",
"label":"Better Name",
"type":"string"
},
{
"key":"authorId",
"label":"Author",