add functionality for oidc login to change MongoDB data for email, fullname, username, user.teams

This commit is contained in:
viehlieb 2022-02-23 15:09:03 +01:00
parent 9ca8d78514
commit 6b404da9f8
3 changed files with 107 additions and 0 deletions

View file

@ -0,0 +1,88 @@
module.exports = {
addGroups: function (user, groups){
teamArray=[]
teams = user.teams
if (!teams)
{
for (group of groups){
team = Team.findOne({"teamDisplayName": group});
if (team)
{
team_hash = {'teamId': team._id, 'teamDisplayName': group}
teamArray.push(team_hash);
}
}
teams = {'teams': teamArray}
users.update({ _id: user._id }, { $set: teams});
return;
}
else{
for (group of groups){
team = Team.findOne({"teamDisplayName": group})
team_contained= false;
if (team)
{
team_hash = {'teamId': team._id, 'teamDisplayName': group}
for (const [count,teams_hash] of Object.entries(teams))
{
if (teams_hash["teamId"] === team._id)
{
team_contained=true;
break;
}
}
if (team_contained)
{
continue;
}
else
{
console.log("TEAM to be added:", team);
teams.push({'teamId': Team.findOne({'teamDisplayName': group})._id, 'teamDisplayName': group});
}
}
}
console.log("XXXXXXXXXXX Team Array: ", teams);
teams = {'teams': teams}
users.update({ _id: user._id }, { $set: teams});
}
},
changeUsername: function(user, name)
{
username = {'username': name};
if (user.username != username) users.update({ _id: user._id }, { $set: username});
},
changeFullname: function(user, name)
{
username = {'profile.fullname': name};
if (user.username != username) users.update({ _id: user._id }, { $set: username});
},
addEmail: function(user, email)
{
user_email = user.emails || [];
var contained = false;
position = 0;
for (const [count, mail_hash] of Object.entries(user_email))
{
if (mail_hash['address'] === email)
{
contained = true;
position = count;
break;
}
}
if(contained && position != 0)
{
user_email.splice(position,1);
contained = false;
}
if(!contained)
{
user_email.unshift({'address': email, 'verified': true});
user_email = {'emails': user_email};
console.log(user_email);
users.update({ _id: user._id }, { $set: user_email});
}
}
}

View file

@ -1,3 +1,5 @@
import {addGroups, addEmail,changeFullname, changeUsername} from './loginHandler';
Oidc = {};
httpCa = false;
@ -16,6 +18,8 @@ if (process.env.OAUTH2_CA_CERT !== undefined) {
OAuth.registerService('oidc', 2, null, function (query) {
var debug = process.env.DEBUG || false;
var propagateOidcData = process.env.PROPAGATE_OIDC_DATA || false;
var token = getToken(query);
if (debug) console.log('XXX: register token:', token);
@ -73,6 +77,20 @@ OAuth.registerService('oidc', 2, null, function (query) {
var profile = {};
profile.name = userinfo[process.env.OAUTH2_FULLNAME_MAP]; // || userinfo["displayName"];
profile.email = userinfo[process.env.OAUTH2_EMAIL_MAP]; // || userinfo["email"];
if (propagateOidcData)
{
if(user)
{
serviceData.groups = profile.groups
profile.groups = userinfo["groups"];
users= Meteor.users;
user = users.findOne({'services.oidc.id': serviceData.id});
if(userinfo["groups"]) addGroups(user, userinfo["groups"]);
if(profile.email) addEmail(user, profile.email)
if(profile.name) changeFullname(user, profile.name)
if(profile.username) changeUsername(user, profile.username)
}
}
if (debug) console.log('XXX: profile:', profile);
return {

View file

@ -10,6 +10,7 @@ Package.onUse(function(api) {
api.use('oauth@1.1.0', ['client', 'server']);
api.use('http@1.1.0', ['server']);
api.use('underscore@1.0.0', 'client');
api.use('ecmascript@0.9.0');
api.use('templating@1.1.0', 'client');
api.use('random@1.0.0', 'client');
api.use('service-configuration@1.0.0', ['client', 'server']);