Non ci sono molti esempi là fuori per hapi e il suo plugin auth-cookie, ma ecco quello che ho finora nel tentativo di proteggere un percorso. Si noti, la maggior parte degli esempi che ho visto si utilizza una versione precedente di Hapi, che non sembrano applicarsi molto a questa situazione e im sperando im manca solo qualcosa di semplice:hapi-auth-cookie non riesce a caricare la strategia di sessione
var Hapi = require('hapi');
var Mongoose = require('mongoose');
Mongoose.connect('mongodb://localhost/rfmproducetogo');
var server = new Hapi.Server(8080, "localhost");
server.pack.register([{
plugin: require("lout")
}, {
plugin: require('hapi-auth-cookie')
}, {
plugin: require("./plugins/togo")
}, {
plugin: require("./plugins/auth")
}], function(err) {
if (err) throw err;
server.auth.strategy('session', 'cookie', {
password: 'shhasecret',
cookie: 'wtfisthisfor',
isSecure: false,
redirectTo: false
});
server.start(function() {
console.log("hapi server started @ " + server.info.uri);
});
});
E nella mia togo plug I avere questa configurazione percorso per utilizzare la sessione
exports.create = function(plugin) {
plugin.route({
method: 'POST',
path: '/togo/add',
handler: function(request, reply) {
produce = new Produce();
produce.label = request.payload.label;
produce.price = request.payload.price;
produce.uom = request.payload.uom;
produce.category = request.payload.category;
produce.save(function(err) {
if (!err) {
reply(produce).created('/togo/' + produce._id);
} else {
reply(err);
}
});
},
config: {
auth: 'session'
}
});
};
l'errore im vedere è questo:
/home/adam/Projects/bushhog/node_modules/hapi/node_modules/hoek/lib/index.js:421
throw new Error(msgs.join(' ') || 'Unknown error');
^
Error: Unknown authentication strategy: session in path: /togo/add
at Object.exports.assert (/home/adam/Projects/bushhog/node_modules/hapi/node_modules/hoek/lib/index.js:421:11)
at /home/adam/Projects/bushhog/node_modules/hapi/lib/auth.js:123:14
at Array.forEach (native)
at internals.Auth._setupRoute (/home/adam/Projects/bushhog/node_modules/hapi/lib/auth.js:121:24)
at new module.exports.internals.Route (/home/adam/Projects/bushhog/node_modules/hapi/lib/route.js:118:43)
at /home/adam/Projects/bushhog/node_modules/hapi/lib/router.js:110:25
at Array.forEach (native)
at /home/adam/Projects/bushhog/node_modules/hapi/lib/router.js:107:17
at Array.forEach (native)
at internals.Router.add (/home/adam/Projects/bushhog/node_modules/hapi/lib/router.js:104:13)
nodo 0.10.28 Correre, hapijs 6.x, Hapi-auth-cookie 1.02
Stai ancora vivendo un problema? Ho trovato il tuo repository in GitHub e sembra funzionare bene. – dylants
hi @dylants Sono stato in grado di aggirare il problema registrando la strategia di autenticazione all'interno del plugin stesso e funziona, ma non sono sicuro che questo sia il modo migliore. Dovrò sempre assicurarmi che il plugin auth sia caricato per primo – battlemidget