mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-06-22 15:35:03 +00:00
passport user auth with session, bearer api-key
This commit is contained in:
parent
96d6f56e85
commit
331360098f
10
package-lock.json
generated
10
package-lock.json
generated
@ -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",
|
||||
|
@ -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",
|
||||
|
@ -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) => {
|
||||
|
@ -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,
|
||||
|
@ -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);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user