how to get key and values in an object
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
07-06-2020 10:46 PM
var obj = {
prodUsers: {
"aatest15": ["test016", "Test Automation 2"]
},
nonProdUsers: {
"aatest14": ["test016", "Test Automation 2"]
}
};
In this object aatest15 and aatest16 are users, test016 and Test Automation 2 are groups
how to check users are exist in user table or not and groups are exist in group table or not.
thanks
- Labels:
-
Integrations
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
07-09-2020 03:18 AM
Hello,
This script should get you started.
var obj = {
prodUsers: {
"admin": ["test016", "Test Automation 2"]
},
nonProdUsers: {
"aatest14": ["test016", "Test Automation 2"]
}
};
for (var user in obj.prodUsers) {
var groups = obj.prodUsers[user];
if ( checkUser(user) ) {
if ( checkGroups(groups ) ) {
gs.print('user ' + user + ' exists and his groups exist');
} else {
gs.print('user ' + user + ' exists but one of his groups do not exist');
}
} else {
gs.print('user ' + user + ' does not exist');
}
}
for (var user in obj.nonProdUsers) {
var groups = obj.nonProdUsers[user];
if ( checkUser(user) ) {
if ( checkGroups(groups ) ) {
gs.print('user ' + user + ' exists and his groups exist');
} else {
gs.print('user ' + user + ' exists but one of his groups do not exist');
}
} else {
gs.print('user ' + user + ' does not exist');
}
}
function checkUser(user) {
var userGr = new GlideRecord('sys_user');
return userGr.get('user_name',user)
}
function checkGroups(groups) {
for (var i =0; i<groups.length; i++) {
var groupsGr = new GlideRecord('sys_user_group');
if (!groupsGr.get('name', groups[i])) return false;
}
return true;
}
Regards,

- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
07-09-2020 09:32 AM
Hi ,
Here is a link which will help you.
https://community.servicenow.com/community?id=community_blog&sys_id=b7603572db77130067a72926ca961910
If it helps,Please mark ✅ Correct and 👍 Helpful.
Warm Regards,
Milind