2011-11-23 08:56:59 +08:00
|
|
|
var crypto = require('crypto')
|
|
|
|
, qs = require('querystring')
|
|
|
|
;
|
|
|
|
|
|
|
|
function sha1 (key, body) {
|
|
|
|
return crypto.createHmac('sha1', key).update(body).digest('base64')
|
|
|
|
}
|
|
|
|
|
2012-01-17 07:06:16 +08:00
|
|
|
function rfc3986 (str) {
|
|
|
|
return encodeURIComponent(str)
|
|
|
|
.replace('!','%21')
|
|
|
|
.replace('*','%2A')
|
|
|
|
.replace('(','%28')
|
|
|
|
.replace(')','%29')
|
|
|
|
.replace("'",'%27')
|
|
|
|
;
|
|
|
|
}
|
|
|
|
|
2011-11-23 08:56:59 +08:00
|
|
|
function hmacsign (httpMethod, base_uri, params, consumer_secret, token_secret, body) {
|
|
|
|
// adapted from https://dev.twitter.com/docs/auth/oauth
|
|
|
|
var base =
|
2012-02-25 10:52:17 +08:00
|
|
|
(httpMethod || 'GET') + "&" +
|
2011-11-23 08:56:59 +08:00
|
|
|
encodeURIComponent( base_uri ) + "&" +
|
|
|
|
Object.keys(params).sort().map(function (i) {
|
|
|
|
// big WTF here with the escape + encoding but it's what twitter wants
|
2012-01-17 07:06:16 +08:00
|
|
|
return escape(rfc3986(i)) + "%3D" + escape(rfc3986(params[i]))
|
2011-11-23 08:56:59 +08:00
|
|
|
}).join("%26")
|
|
|
|
var key = consumer_secret + '&'
|
|
|
|
if (token_secret) key += token_secret
|
|
|
|
return sha1(key, base)
|
|
|
|
}
|
|
|
|
|
2012-01-17 07:06:16 +08:00
|
|
|
exports.hmacsign = hmacsign
|
|
|
|
exports.rfc3986 = rfc3986
|