Skip to main content

ServiceNow Is value in array?

ServiceNow Is value in array?

//--RDS Jan2018
//--monthly job to remove group memberships & roles from users in ServiceNow
//--where user.active=false
//--hence, licence tidy up task so that reporting reflects more accurate license allocation
beforeChecks('');
beforeChecks('active=true');
beforeChecks('active=false');
//gs.print('set bDelete=true to run the actual deletions, otherwise safe to run this script to spit out the numbers only');
var logSource='schJob:RolesTidyUp';
var grUserRoles= new GlideRecord('sys_user_has_role');
grUserRoles.addQuery('user.active=false');
grUserRoles.orderBy('user');
grUserRoles.query();
var rowCount=grUserRoles.getRowCount();
gs.log('START:: rowcount of inactive user> user roles in ServiceNow: ' + rowCount, logSource);
if (rowCount>0){
    var userArr=[];
    while (grUserRoles.next()){
        userArr.push(grUserRoles.user.sys_id);
    }
    var newarr = (function(userArr){
        var m = {}, newarr = [];
            for (var i=0; i<userArr.length; i++) {
                var v = userArr[i];
                if (!m[v]) {
                    newarr.push(v);
                    m[v]=true;
                }
            }
            return newarr;
        })(userArr);
       
        gs.log(newarr.length + ' distinct inactive user records with roles',logSource);
        //gs.print('##################################');
       
       
    }else{
        gs.log('inactive row count is zero--no further action needed',logSource);
    }
   
    for (i=0;i<newarr.length;i++){
        gs.log('inactive user sysid: ' + newarr[i],logSource);
        //--remove user from any groups
        var bDelete=false;
        //bDelete=true;//--comment this line out to hold off deleting
        removeUserFromGroups(newarr[i], bDelete);
        mopUpRemainingRoles_nogroups(newarr[i], bDelete);
    }
   
    gs.log('::END',logSource);
   
    function removeUserFromGroups(userSYSID, bDelete){
        //--this removes users from groups, which will auto-remove any roles inherited from the groups
        var userGroups=new GlideRecord('sys_user_grmember');
        userGroups.addQuery('user.active', false); //belt-and-braces
        userGroups.addQuery('user', userSYSID);
        if (bDelete){
            userGroups.deleteMultiple();
        }else{
            userGroups.query();
            gs.log('TOTAL GROUPS: ' + userGroups.getRowCount(),logSource);
            var i=0;
            while (userGroups.next()){
                if (i==0){
                    gs.log('USER: ' + userGroups.user.name + ' [' + userSYSID + ']',logSource);
                }
                gs.log(userGroups.user.name + ' [active=' + userGroups.user.active + '] member of group: ' + userGroups.group.name, logSource);
                i++;
            }
            if (i==0){
                gs.log('USER not in any groups [' + userSYSID + ']',logSource);
            }
        }
    }
    function mopUpRemainingRoles_nogroups(userSYSID, bDelete){
       
        var grUserRoles= new GlideRecord('sys_user_has_role');
        grUserRoles.addQuery('user.active=false');
        grUserRoles.addQuery('user', userSYSID);
        if (bDelete){
            grUserRoles.deleteMultiple();
        }else{
            grUserRoles.query();
            gs.log('TOTAL ROLES: ' + grUserRoles.getRowCount(),logSource);
            var i=0;
            while (grUserRoles.next()){
                if (i==0){
                    gs.log('USER: ' + grUserRoles.user.name + ' [' + userSYSID + ']',logSource);
                }
                gs.log(grUserRoles.user.name + ' [active=' + grUserRoles.user.active + '] has role: ' + grUserRoles.role.name,logSource);
                i++;
            }
            if (i==0){
                gs.log('USER does not have any roles [' + userSYSID + ']',logSource);
            }
        }
    }
   
    function beforeChecks(s_query){
        var grUserRoles= new GlideRecord('sys_user_has_role');
        if (s_query!=''){
            grUserRoles.addQuery('user.' + s_query);
        }
        grUserRoles.orderBy('user');
        grUserRoles.query();
        var rowCount=grUserRoles.getRowCount();
        if (s_query==''){
            s_query ='total ' ;
        }
        gs.log(s_query + ':: result total= ' + rowCount, logSource);
    }

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 ; } } }