cleanup some auth stuff

This commit is contained in:
2024-03-17 10:46:18 -05:00
parent 832fb654ec
commit 2a2eb07823
2 changed files with 28 additions and 37 deletions

View File

@@ -50,17 +50,6 @@ teamsnapMembersSortAvailabilityLastName = (a, b) => {
} }
exports.teamsnapMembersSortAvailabilityLastName = teamsnapMembersSortAvailabilityLastName exports.teamsnapMembersSortAvailabilityLastName = teamsnapMembersSortAvailabilityLastName
exports.initTeamsnap = (req, res, next) => {
if (!teamsnap.isAuthed()) {
teamsnap.init(process.env["TEAMSNAP_CLIENT_ID"]);
teamsnap.auth(req.user.accessToken);
}
teamsnap.loadCollections((err) => {
teamsnap.enablePersistence();
next(req, res, next);
});
};
exports.teamsnapCallback = (err,result, d) => { exports.teamsnapCallback = (err,result, d) => {
if (Array.isArray(result)){ if (Array.isArray(result)){
types = new Set(result.map(i=>i.type)) types = new Set(result.map(i=>i.type))

View File

@@ -1,6 +1,7 @@
var express = require("express"); const express = require("express");
var passport = require("passport"); const passport = require("passport");
var TeamsnapStrategy = require("passport-teamsnap"); const TeamsnapStrategy = require("passport-teamsnap");
const {teamsnapCallback} = require('../lib/utils')
// const {teamsnap} = require("../app"); // const {teamsnap} = require("../app");
// Configure the TeamSnap strategy for use by Passport. // Configure the TeamSnap strategy for use by Passport.
// //
@@ -21,20 +22,17 @@ passport.use(
proxy: true proxy: true
}, },
async function (req, accessToken, refreshToken, profile, done) { async function (req, accessToken, refreshToken, profile, done) {
json = JSON.parse(profile._raw); // json = JSON.parse(profile._raw);
field_from_collection = (field_name) => { const new_profile = {
return json.collection.items[0].data.filter( access_token: accessToken,
(e) => e.name == field_name };
)[0].value; ['id', 'email', 'first_name', 'last_name', 'managed_team_ids'].forEach(
} k => {
const new_profile = { access_token: accessToken }; new_profile[k] = profile.data[0].get(k)
new_profile["id"] = field_from_collection("id") })
new_profile["email"] = field_from_collection("email")
new_profile["first_name"] = field_from_collection("first_name")
new_profile["last_name"] = field_from_collection("last_name")
req.session.teamsnap_access_token = accessToken; req.session.teamsnap_access_token = accessToken;
await initTeamsnap(process.env["TEAMSNAP_CLIENT_ID"], accessToken) await initTeamsnap(accessToken)
return done(null, new_profile); return done(null, new_profile);
} }
) )
@@ -59,6 +57,7 @@ passport.serializeUser(function (user, cb) {
first_name: user.first_name, first_name: user.first_name,
last_name: user.last_name, last_name: user.last_name,
accessToken: user.access_token, accessToken: user.access_token,
managed_team_ids: user.managed_team_ids
}); });
}); });
}); });
@@ -66,10 +65,12 @@ passport.serializeUser(function (user, cb) {
passport.deserializeUser(function (user, cb) { passport.deserializeUser(function (user, cb) {
process.nextTick(async function () { process.nextTick(async function () {
console.log("L#68 deserializing user id", user.id); console.log("L#68 deserializing user id", user.id);
if (!teamsnap.isAuthed()){ try {
await initTeamsnap(process.env["TEAMSNAP_CLIENT_ID"], user.accessToken) await initTeamsnap(user.accessToken)
return cb(null, user);
} catch (err) {
return cb(err)
} }
return cb(null, user);
}); });
}); });
@@ -86,9 +87,11 @@ var router = express.Router();
router.get("/login", function (req, res, next) { router.get("/login", function (req, res, next) {
// https://stackoverflow.com/a/73056806/20522015 // https://stackoverflow.com/a/73056806/20522015
returnTo = req.session.returnTo; returnTo = req.session.returnTo;
// req.session.regenerate(); // this is not working right as of now... if (req.user.accessToken){
req.session.returnTo = returnTo; res.redirect(returnTo || "/");
res.render("login", {layout:"layouts/main"}); } else {
res.render("login", {layout:"layouts/main"});
}
}); });
/* GET /login/federated/teamsnap /* GET /login/federated/teamsnap
@@ -125,10 +128,9 @@ router.get(
}) })
); );
const initTeamsnap = async (clientID, accessToken) => { const initTeamsnap = async (accessToken) => {
teamsnap.init(clientID); await teamsnap.auth(accessToken);
teamsnap.auth(accessToken); await teamsnap.loadCollections(teamsnapCallback);
await teamsnap.loadCollections();
await teamsnap.enablePersistence(); await teamsnap.enablePersistence();
} }
@@ -138,7 +140,7 @@ const ensureLoggedIn = (req, res, next) => {
res.redirect("/login"); res.redirect("/login");
// return next(); // return next();
} }
else{ else {
req.user = req.session.passport.user req.user = req.session.passport.user
next(); next();
} }