-
Notifications
You must be signed in to change notification settings - Fork 116
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Support for multiple duplicate keys in the QS of the url (#58)
Fix for multiple duplicate querystring parameter keys in the url
- Loading branch information
1 parent
9900055
commit 8f40b64
Showing
3 changed files
with
65 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
var expect = require('chai').expect; | ||
var OAuth = require('../../oauth-1.0a'); | ||
var crypto = require('crypto'); | ||
|
||
function hash_function_SHA1(base_string, key) { | ||
return crypto.createHmac('sha1', key).update(base_string).digest('base64'); | ||
} | ||
|
||
describe("Signature method", function() { | ||
describe("HMAC-SHA1 signature method with multiple duplicate values in the querystring", function() { | ||
var oauth = new OAuth({ | ||
consumer: { | ||
key: "batch-8f4fd2c6-9fa3-4368-9797-52876d723dd1", | ||
secret: "ZACXtYe6LQ4C5X0KbJcDkbW77GYtlaoU" | ||
}, | ||
signature_method: 'HMAC-SHA1', | ||
hash_function: hash_function_SHA1 | ||
}); | ||
|
||
//overide for testing only !!! | ||
oauth.getTimeStamp = function() { | ||
return 1504882975; | ||
}; | ||
|
||
//overide for testing only !!! | ||
oauth.getNonce = function(length) { | ||
return 'xsEYfvjTEiPTR3TqJbmhCpUdrDoHF6nk'; | ||
}; | ||
|
||
|
||
var request_data = { | ||
url: "http://localhost:3737/rest/profiles?property=email&value=vel.arcu%40ultriciesornareelit.ca&property=visitdate&value=abc&alt=json", | ||
method: "GET" | ||
}; | ||
|
||
var result = oauth.authorize(request_data); | ||
|
||
it("Signature should match", function() { | ||
expect(result.oauth_signature).to.equal("b6nMehqpHnpx0VlZB9IhqFh4Jq0="); | ||
}); | ||
|
||
it("Nonce should match", function() { | ||
expect(result.oauth_nonce).to.equal("xsEYfvjTEiPTR3TqJbmhCpUdrDoHF6nk"); | ||
}); | ||
|
||
it("Timestamp should match", function() { | ||
expect(result.oauth_timestamp).to.equal(1504882975); | ||
}); | ||
}); | ||
}); |