Name
global.PwdVerifyEmailProcessor
Description
Extension for Email verification of user input on the second page.
Script
var PwdVerifyEmailProcessor = Class.create();
PwdVerifyEmailProcessor.prototype = {
category: 'password_reset.extension.verification_form_processor', // DO NOT REMOVE THIS LINE!
/**********
* Initialization stuff here...
**********/
initialize: function() {
},
/**********
* Process the verification form request, and return whether the user was successfully verified
*
* @param params.resetRequestId The sys-id of the current password-reset request (table: pwd_reset_request)
* @param params.userId The sys-id of the user trying to be verified (table: sys_user)
* @param params.verificationId The sys-id of the verification to be processed (table: pwd_verification)
* @param request The form request object. fields in the form can be accessed using: request.getParameter('<element-id>')
* @return boolean telling whether the user is successfully verified
**********/
processForm: function(params, request) {
var isVerified = false;
try {
isVerified = this.verify(params.resetRequestId, params.userId, params.verificationId, request);
} catch (scriptErr) {
gs.logError("[PwdVerifyEmailProcessor.processForm]: '" + scriptErr + "'");
isVerified = false;
}
return isVerified;
},
/*********
* verify - returns true/false whether the user is verified for this verification method.
*
* Params:
* @enrolled_user_id
* @verification_id
* @request - the request object that was submitted by the user in the verification form
*********/
verify: function(reset_request_id, enrolled_user_id, verification_id, request) {
var LOG_ID = '[PwdVerifyEmailProcessor.verify] ';
var mode = request.getParameter('sysparm_email_verification_mode');
var answer = request.getParameter('sysparm_answer_email_code').trim();
gs.log(LOG_ID + "request_id: '" + reset_request_id + "', answer: '" + answer + "'");
var ret = false;
var emailMgr = new PwdEmailNotificationManager ();
if (mode == 'subscription' || mode == 'notEnrolled')
ret = emailMgr.verifyResetCode(reset_request_id, verification_id, answer);
else
gs.logError(LOG_ID + " unknown operation requested. request_id: '" + reset_request_id + "'");
//If the code has been previously validated, return that result.
//The code is expired after initial validation, resulting in an incorrect result
var reqVerGr = new GlideRecord('pwd_map_request_to_verification');
reqVerGr.addQuery('verification', verification_id);
reqVerGr.addQuery('request', reset_request_id);
reqVerGr.query();
var recordExists = reqVerGr.next();
if (recordExists && reqVerGr.getValue('status') == 'verified')
return true;
reqVerGr.setValue('status', ret ? 'verified' : 'not_verified');
if (!recordExists) {
reqVerGr.setValue('request', reset_request_id);
reqVerGr.setValue('verification', verification_id);
reqVerGr.insert();
}
else
reqVerGr.update();
return ret;
},
type: 'PwdVerifyEmailProcessor'
};
Sys ID
878d1a940b333200572a6f3ef6673a8d