79 lines
2.5 KiB
JavaScript
79 lines
2.5 KiB
JavaScript
import { Meteor } from 'meteor/meteor';
|
|
import RedisPubSub from '/imports/startup/server/redis';
|
|
import Logger from '/imports/startup/server/logger';
|
|
import upsertValidationState from '/imports/api/auth-token-validation/server/modifiers/upsertValidationState';
|
|
import AuthTokenValidation, { ValidationStates } from '/imports/api/auth-token-validation';
|
|
import pendingAuthenticationsStore from '../store/pendingAuthentications';
|
|
|
|
const AUTH_TIMEOUT = 120000;
|
|
|
|
async function validateAuthToken(meetingId, requesterUserId, requesterToken, externalId) {
|
|
let setTimeoutRef = null;
|
|
const userValidation = await new Promise((res, rej) => {
|
|
const observeFunc = (obj) => {
|
|
if (obj.validationStatus === ValidationStates.VALIDATED) {
|
|
clearTimeout(setTimeoutRef);
|
|
return res(obj);
|
|
}
|
|
if (obj.validationStatus === ValidationStates.INVALID) {
|
|
clearTimeout(setTimeoutRef);
|
|
return res(obj);
|
|
}
|
|
};
|
|
const authTokenValidationObserver = AuthTokenValidation.find({
|
|
connectionId: this.connection.id,
|
|
}).observe({
|
|
added: observeFunc,
|
|
changed: observeFunc,
|
|
});
|
|
|
|
setTimeoutRef = setTimeout(() => {
|
|
observeFunc.stop();
|
|
rej();
|
|
}, AUTH_TIMEOUT);
|
|
|
|
try {
|
|
const REDIS_CONFIG = Meteor.settings.private.redis;
|
|
const CHANNEL = REDIS_CONFIG.channels.toAkkaApps;
|
|
const EVENT_NAME = 'ValidateAuthTokenReqMsg';
|
|
|
|
Logger.debug('ValidateAuthToken method called', { meetingId, requesterUserId, requesterToken, externalId });
|
|
|
|
if (!meetingId) return false;
|
|
|
|
// Store reference of methodInvocationObject ( to postpone the connection userId definition )
|
|
pendingAuthenticationsStore.add(meetingId, requesterUserId, requesterToken, this);
|
|
upsertValidationState(
|
|
meetingId,
|
|
requesterUserId,
|
|
ValidationStates.VALIDATING,
|
|
this.connection.id,
|
|
);
|
|
|
|
const payload = {
|
|
userId: requesterUserId,
|
|
authToken: requesterToken,
|
|
};
|
|
|
|
Logger.info(`User '${requesterUserId}' is trying to validate auth token for meeting '${meetingId}' from connection '${this.connection.id}'`);
|
|
|
|
return RedisPubSub.publishUserMessage(
|
|
CHANNEL,
|
|
EVENT_NAME,
|
|
meetingId,
|
|
requesterUserId,
|
|
payload,
|
|
);
|
|
} catch (err) {
|
|
const errMsg = `Exception while invoking method validateAuthToken ${err}`;
|
|
Logger.error(errMsg);
|
|
rej(errMsg);
|
|
clearTimeout(setTimeoutRef);
|
|
authTokenValidationObserver.stop();
|
|
}
|
|
});
|
|
return userValidation;
|
|
}
|
|
|
|
export default validateAuthToken;
|