passport user auth with session, bearer api-key

This commit is contained in:
Felix Kaspar 2024-05-27 20:36:38 +02:00
parent 96d6f56e85
commit 331360098f
5 changed files with 36 additions and 5 deletions

10
package-lock.json generated
View File

@ -7364,6 +7364,15 @@
"url": "https://github.com/sponsors/jaredhanson"
}
},
"node_modules/passport-headerapikey": {
"version": "1.2.2",
"resolved": "https://registry.npmjs.org/passport-headerapikey/-/passport-headerapikey-1.2.2.tgz",
"integrity": "sha512-4BvVJRrWsNJPrd3UoZfcnnl4zvUWYKEtfYkoDsaOKBsrWHYmzTApCjs7qUbncOLexE9ul0IRiYBFfBG0y9IVQA==",
"dependencies": {
"lodash": "^4.17.15",
"passport-strategy": "^1.0.0"
}
},
"node_modules/passport-local": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/passport-local/-/passport-local-1.0.0.tgz",
@ -10250,6 +10259,7 @@
"jsqr": "^1.4.0",
"multer": "^1.4.5-lts.1",
"passport": "^0.7.0",
"passport-headerapikey": "^1.2.2",
"passport-local": "^1.0.0",
"pdf-lib": "^1.17.1",
"rollup-plugin-copy": "^3.5.0",

View File

@ -36,6 +36,7 @@
"jsqr": "^1.4.0",
"multer": "^1.4.5-lts.1",
"passport": "^0.7.0",
"passport-headerapikey": "^1.2.2",
"passport-local": "^1.0.0",
"pdf-lib": "^1.17.1",
"rollup-plugin-copy": "^3.5.0",

View File

@ -1,8 +1,10 @@
import LocalStrategy from "passport-local";
import * as User from "./user/user-controller";
import { Strategy as LocalStrategy} from "passport-local";
import { HeaderAPIKeyStrategy as HeaderAPIKeyStrategy } from "passport-headerapikey";
export function initialize(passport: typeof import("passport")) {
passport.use("local", new LocalStrategy.Strategy(
passport.use("local", new LocalStrategy(
function(username, password, done) {
User.findOne({ username: username }, function (err, user) {
if (err) {
@ -19,8 +21,24 @@ export function initialize(passport: typeof import("passport")) {
}
));
passport.use(new HeaderAPIKeyStrategy(
{ header: 'Authorization', prefix: 'Bearer ' },
false,
function(apikey, done) {
User.findOne({ apikey: apikey }, function (err, user) {
if (err) {
return done(err);
}
if (!user) {
return done(null, false);
}
return done(null, user);
});
}
));
passport.serializeUser((user, done) => {
done(null, user.id)
done(null, user.id) //TODO: Extend Express.User to include id wich is set by passport
});
passport.deserializeUser((id: number, done) => {

View File

@ -1,6 +1,6 @@
import { User } from "./user-model";
export function findOne(params: {id?: number, username?: string}, cb: (err: Error | null, user: User) => void): undefined {
export function findOne(params: {id?: number, username?: string, apikey?: string}, cb: (err: Error | null, user: User) => void): undefined {
//TODO: replace with db connection.
cb(null, {
id: 1,

View File

@ -51,7 +51,9 @@ app.use(session({
}));
app.use(passport.initialize());
app.use(passport.session());
app.use(passport.authenticate(['headerapikey', 'session'], {
session: false, // Only set a session on the login request.
}));
initialize(passport);