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

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,