Need help troubleshooting client callable script include

neil_b
Tera Guru

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. 

1 ACCEPTED SOLUTION

Brad Bowman
Kilo Patron
Kilo Patron

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?

View solution in original post

20 REPLIES 20

Here is the screenshot of your version where I am still getting incorrect syntax.checkIfGroupMember(2).png

Bert_c1
Kilo Patron

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

 

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?

I have no idea on that aspect. Your original script has syntax problems.

Hi @Bert_c1 this is my client callable script include now. This appears to be in the correct syntax, yes? checkIfGroupMember.png