- 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:50 AM
Here is the screenshot of your version where I am still getting incorrect syntax.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:43 AM - edited 11-26-2024 09:43 AM
Try making the following changes:
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',
};
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:45 AM
Hi @Bert_c1 I tried your code, and it accepted the syntax, but it is still not working correctly. I logged in with a user who is not part of Groups1-3 and they are still able to see the dashboard.
Is the issue perhaps with my condition statement?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:46 AM
I have no idea on that aspect. Your original script has syntax problems.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
11-26-2024 09:49 AM
Hi @Bert_c1 this is my client callable script include now. This appears to be in the correct syntax, yes?