| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | // Load modulesvar Http = require('http');var Request = require('request');var Hawk = require('../lib');// Declare internalsvar internals = {    credentials: {        dh37fgj492je: {            id: 'dh37fgj492je',                                             // Required by Hawk.client.header            key: 'werxhqb98rpaxn39848xrunpaw3489ruxnpa98w4rxn',            algorithm: 'sha256',            user: 'Steve'        }    }};// Credentials lookup functionvar credentialsFunc = function (id, callback) {    return callback(null, internals.credentials[id]);};// Create HTTP servervar handler = function (req, res) {    Hawk.server.authenticate(req, credentialsFunc, {}, function (err, credentials, artifacts) {        var payload = (!err ? 'Hello ' + credentials.user + ' ' + artifacts.ext : 'Shoosh!');        var headers = {            'Content-Type': 'text/plain',            'Server-Authorization': Hawk.server.header(credentials, artifacts, { payload: payload, contentType: 'text/plain' })        };        res.writeHead(!err ? 200 : 401, headers);        res.end(payload);    });};Http.createServer(handler).listen(8000, '127.0.0.1');// Send unauthenticated requestRequest('http://127.0.0.1:8000/resource/1?b=1&a=2', function (error, response, body) {    console.log(response.statusCode + ': ' + body);});// Send authenticated requestcredentialsFunc('dh37fgj492je', function (err, credentials) {    var header = Hawk.client.header('http://127.0.0.1:8000/resource/1?b=1&a=2', 'GET', { credentials: credentials, ext: 'and welcome!' });    var options = {        uri: 'http://127.0.0.1:8000/resource/1?b=1&a=2',        method: 'GET',        headers: {            authorization: header.field        }    };    Request(options, function (error, response, body) {        var isValid = Hawk.client.authenticate(response, credentials, header.artifacts, { payload: body });        console.log(response.statusCode + ': ' + body + (isValid ? ' (valid)' : ' (invalid)'));        process.exit(0);    });});
 |