cleanup some auth stuff
This commit is contained in:
@@ -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))
|
||||||
|
|||||||
@@ -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();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user