- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 08:50 AM
I have condition on the Menu Item set to the following:
gs.getSession().isLoggedIn() && new checkIfGroupMember().verifyMembership();
The intent of this condition is to check if the user is Logged In and is part of a specific group.
Here is the client callable script include:
var checkIfGroupMember = Class.create();
checkIfGroupMember.prototype = {
initialize: function() {},
verifyMembership: function() {
if (gs.getUser().isMemberOf('group_name1') || gs.getUser().isMemberOf('group_name2') || gs.getUser().isMemberOf('group_name3'))
return true;
}, else: {
return: false,
},
type: 'checkIfGroupMember'
};
This is not working, as any user regardless of group can see the dashboard menu item. Can someone help me where I have gone wrong? I don't know if my script include is incorrect or if my condition is incorrect.
Solved! Go to Solution.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:53 AM
You might need to pass the current user as an argument in the Script Include. Where exactly are you using this? Is your Script Include in the same scope as whatever is calling it? Your Script Include is not truly Client callable as the extended AjaxProcessor was not added to the beginning, which happens when the box is clicked after the script exists, but it doesn't need to be Client callable in this case - that's only necessary for GlideAjax calls from a client script.
Your if statement is not formatted correctly. Change it to:
if (gs.getUser().isMemberOf('group_name1') || gs.getUser().isMemberOf('group_name2') || gs.getUser().isMemberOf('group_name3')) {
return true;
} else {
return false;
},
You may need to add some log lines to confirm this is running, based on the call in the condition, and confirm the value of gs.getUser(). Do you really need the first part of the Condition - is it possible for users in your environment to not be logged in, yet still be members of groups?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:37 AM - edited 11-26-2024 09:39 AM
Hi @neil_b ,
Please try below:
var checkIfGroupMember = Class.create();
checkIfGroupMember.prototype = {
initialize: function() {},
verifyMembership: function() {
if ((gs.getUser().isMemberOf('group_name1'))|| (gs.getUser().isMemberOf('group_name2')) || (gs.getUser().isMemberOf('group_name3'))){
return true;
}else{
return false;
}
},
type: 'checkIfGroupMember'
};
Thanks,
Gopi
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:41 AM
Hi @Gopi Naik1 I tried your code but I'm getting incorrect syntax on lines 10 and 11.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:44 AM
Please add complete screenshot of your script include.
Thanks,
Gopi
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:46 AM
var checkIfGroupMember = Class.create();
checkIfGroupMember.prototype = {
initialize: function() {},
verifyMembership: function() {
if (gs.getUser().isMemberOf('group_name1') || gs.getUser().isMemberOf('group_name2') || gs.getUser().isMemberOf('group_name3'))
return true;
}else{
return false;
},
type: 'checkIfGroupMember'
};