Skip to main content

ServiceNow record producer variables in a business rule

ServiceNow record producer variables in a business rule


//--new code, RDS Dec2018
g_scratchpad.rp_sysid='';
var producerVars_allVars = new GlideRecord('question_answer');
//var allVars = [];
producerVars_allVars.addQuery('table_sys_id', current.sys_id);
//--Exclude Label and Container variables
producerVars_allVars.addQuery('question.type', '!=', 11);
producerVars_allVars.addQuery('question.type', '!=', 19);
producerVars_allVars.addQuery('question.type', '!=', 20);
//--note: UI Macro is question.type=14
producerVars_allVars.query();
//gs.addInfoMessage(current.producer.sys_id);
while(producerVars_allVars.next()){
//gs.addInfoMessage(producerVars_allVars.question.type + ' ' + producerVars_allVars.question.name.toString()  + ' ' + producerVars_allVars.value.toString());
if (producerVars_allVars.question.name.toString()=='hr_rp_sysid'){
g_scratchpad.rp_sysid=producerVars_allVars.value;

if (producerVars_allVars.value=='4b3a65e7dbce6b007e07db11ce96193c'){
//--some logic here specific to the 'HR Feedback' form:
//--get the 'sysparm_newcase=true' bit of the URL populated via the record producer. there must be a simpler way to do this using glide but couldn't spot it
var completeURL = GlideTransaction.get().getRequest().getHeader("referer");
var matchValArr=completeURL.match("sysparm_newcase=(.*)&").toString().split(',');
var isNewCase = matchValArr[1];
if (isNewCase=='true'){
g_scratchpad.newcase = 'true'; //--passed over to the client script
}
}
break;
}
//allVars.push(producerVars.question.name.toString());
}
//-----

Comments

Popular posts from this blog

ServiceNow check for null or nil or empty (or not)

Haven't tested these all recently within global/local scopes, so feel free to have a play! option 1 use an encoded query embedded in the GlideRecord , e.g.  var grProf = new GlideRecord ( 'x_cls_clear_skye_i_profile' ); grProf . addQuery ( 'status=1^ owner=NULL ' ); grProf . query (); even better use the glideRecord  addNotNullQuery or addNullQuery option 2 JSUtil.nil / notNil (this might be the most powerful. See this link ) example: if ( current . operation () == 'insert' && JSUtil . notNil ( current . parent ) && ! current . work_effort . nil ())  option 3 there might be times when you need to get inside the GlideRecord and perform the check there, for example if the code goes down 2 optional routes depending on null / not null can use gs.nil : var grAppr = new GlideRecord ( 'sysapproval_approver' ); var grUser = new GlideRecord ( 'sys_user' ); if ( grUser . get ( 'sys_id' , current . approver )){...

Code a pause/wait - gs.sleep or gs.wait alternative, pause script for specified seconds (timer)

Code a pause/wait - gs.sleep / gs.wait alternative, pause script for specified seconds (timer)  e.g. 10 seconds: do_sleep ( 10000 ); function do_sleep ( milliseconds ) { var start = new Date (). getTime (); for ( var i = 0 ; i < 1e7 ; i ++) { if (( new Date (). getTime () - start ) > milliseconds ){ gs . print ( 'waking up!' ); break ; } } }