HasObjectPermissionTo: Difference between revisions
| mNo edit summary | No edit summary | ||
| (11 intermediate revisions by 8 users not shown) | |||
| Line 4: | Line 4: | ||
| {{Note|Only certain action names work. This function seems to return ''nil'' and output a bad argument error when checking if an object has rights for an action which doesn't start with ''function.'', ''command.'' or ''resource.'' keywords.}} | {{Note|Only certain action names work. This function seems to return ''nil'' and output a bad argument error when checking if an object has rights for an action which doesn't start with ''function.'', ''command.'' or ''resource.'' keywords.}} | ||
| Scripts frequently wish to limit access to features to particular users. The  | Scripts frequently wish to limit access to features to particular users. The naive way to do this would be to check if the player who is attempting to perform an action is in a particular group (usually the Admin group). The main issue with doing this is that the Admin group is not guaranteed to exist. It also doesn't give the server admin any flexibility. He might want to allow his 'moderators' access to the function you're limiting access to, or he may want it disabled entirely.   | ||
| This is where using the ACL properly comes in, and luckily this is very easy. It all comes down to using this function. This, somewhat confusingly named function lets you check if an ACL object (a player or a resource) has a particular ACL right. In this case, we just care about players. | This is where using the ACL properly comes in, and luckily this is very easy. It all comes down to using this function. This, somewhat confusingly named function lets you check if an ACL object (a player or a resource) has a particular ACL right. In this case, we just care about players. | ||
| Line 20: | Line 20: | ||
| The only downside of using this method is that the admin has to modify his config. The upsides are that the admin has much more control and your script will work for any server, however the admin has configured it. | The only downside of using this method is that the admin has to modify his config. The upsides are that the admin has much more control and your script will work for any server, however the admin has configured it. | ||
| ==Syntax==   | ==Syntax== | ||
| {{New feature/item|3.0162|1.7.0|25445| | |||
| '''defaultPermission''' argument now defaults to '''false'''. If third argument is '''nil'''/'''false''' (or not specified), then action (unless explicitly allowed in '''ACL''') won't be processed due to missing rights. May affect the normal operation of existing scripts. | |||
| }} | |||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| bool hasObjectPermissionTo ( string / element theObject, string theAction [, bool defaultPermission = true ] ) | bool hasObjectPermissionTo ( string / element theObject, string theAction [, bool defaultPermission = true/false ] ) | ||
| </syntaxhighlight>   | </syntaxhighlight>   | ||
| {{OOP|This function is also a static function underneath the  | <!-- Yes! This is actually correct this time ^^ notice theObject can be a string! --> | ||
| {{OOP|This function is also a static function underneath the ACL class.|[[ACL]].hasObjectPermissionTo||}} | |||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''theObject:''' The object to test if has permission to. This can be a client element (ie. a player), a resource or a string in the form "user.<name>" or "resource.<name>". | *'''theObject:''' The object to test if has permission to. This can be a client element (ie. a player), a resource or a string in the form "user.<name>" or "resource.<name>". | ||
| Line 48: | Line 52: | ||
|          -- Do we have permission to kick the player? We do this so we can fail |          -- Do we have permission to kick the player? We do this so we can fail | ||
|          -- nicely if this resource doesn't have access to call that function. |          -- nicely if this resource doesn't have access to call that function. | ||
|          if ( hasObjectPermissionTo (  |          if ( hasObjectPermissionTo ( resource, "function.kickPlayer", true ) ) then | ||
|              -- Kick him |              -- Kick him | ||
|              kickPlayer ( playerToKick, playerSource, stringReason ) |              kickPlayer ( playerToKick, playerSource, stringReason ) | ||
| Line 66: | Line 70: | ||
| <!-- Change FunctionArea to the area that this function is in on the main function list page, e.g. Server, Player, Vehicle etc --> | <!-- Change FunctionArea to the area that this function is in on the main function list page, e.g. Server, Player, Vehicle etc --> | ||
| {{ACL_functions}} | {{ACL_functions}} | ||
| [[zh-cn:hasObjectPermissionTo]] | |||
| [[pt-br:hasObjectPermissionTo]] | |||
| [[ru:hasObjectPermissionTo]] | |||
Latest revision as of 11:54, 25 August 2025
This function returns whether or not the given object has access to perform the given action.
Scripts frequently wish to limit access to features to particular users. The naive way to do this would be to check if the player who is attempting to perform an action is in a particular group (usually the Admin group). The main issue with doing this is that the Admin group is not guaranteed to exist. It also doesn't give the server admin any flexibility. He might want to allow his 'moderators' access to the function you're limiting access to, or he may want it disabled entirely.
This is where using the ACL properly comes in, and luckily this is very easy. It all comes down to using this function. This, somewhat confusingly named function lets you check if an ACL object (a player or a resource) has a particular ACL right. In this case, we just care about players.
So, first of all, think of a name for your 'right'. Let's say we want a private area only certain people can go in, we'll call our right accessPrivateArea. Then, all you need to do is add one 'if' statement to your code:
if hasObjectPermissionTo ( player, "resource.YourResourceName.accessPrivateArea", false ) then -- Whatever you want to happen if they're allowed in else -- Whatever you want to happen if they aren't end
Notice that we've named the right using resource.YourResourceName.accessPrivateArea - this is just for neatness, so that the admin knows what resource the right belongs to. It's strongly advised you follow this convention. The false argument specifies the 'defaultPermission', false indicating that if the user hasn't had the right allowed or dissallowed (i.e. the admin hasn't added it to the config), that it should default to being not allowed.
The only downside of using this method is that the admin has to modify his config. The upsides are that the admin has much more control and your script will work for any server, however the admin has configured it.
Syntax
bool hasObjectPermissionTo ( string / element theObject, string theAction [, bool defaultPermission = true/false ] )
OOP Syntax Help! I don't understand this!
- Note: This function is also a static function underneath the ACL class.
- Method: ACL.hasObjectPermissionTo(...)
Required Arguments
- theObject: The object to test if has permission to. This can be a client element (ie. a player), a resource or a string in the form "user.<name>" or "resource.<name>".
- theAction: The action to test if the given object has access to. Ie. "function.kickPlayer".
Optional Arguments
NOTE: When using optional arguments, you might need to supply all arguments before the one you wish to use. For more information on optional arguments, see optional arguments.
- defaultPermission: The default permission if none is specified in either of the groups the given object is a member of. If this is left to true, the given object will have permissions to perform the action unless the opposite is explicitly specified in the ACL. If false, the action will be denied by default unless explicitly approved by the Access Control List.
Returns
Returns true if the given object has permission to perform the given action, false otherwise. Returns nil if the function failed because of bad arguments.
Example
This example kicks a player if the user using it has access to the kickPlayer function.
-- Kick command
function onKickCommandHandler ( playerSource, commandName, playerToKick, stringReason )
    -- Does the calling user have permission to kick the player? Default
    -- to false for safety reasons. We do this so any user can't use us to
    -- kick players.
    if ( hasObjectPermissionTo ( playerSource, "function.kickPlayer", false ) ) then
        -- Do we have permission to kick the player? We do this so we can fail
        -- nicely if this resource doesn't have access to call that function.
        if ( hasObjectPermissionTo ( resource, "function.kickPlayer", true ) ) then
            -- Kick him
            kickPlayer ( playerToKick, playerSource, stringReason )
        else
            -- Resource doesn't have any permissions, sorry
            outputChatBox ( "kick: The admin resource is not able to kick players. Please give this resource access to 'function.kickPlayer' in the ACL to use this function.", playerSource )
        end
    else
        -- User doesn't have any permissions
        outputChatBox ( "kick: You don't have permissions to use this command.", playerSource )
    end
end
addCommandHandler ( "kick", onKickCommandHandler )
See Also
- aclCreate
- aclCreateGroup
- aclDestroy
- aclDestroyGroup
- aclGet
- aclGetGroup
- aclGetName
- aclGetRight
- aclGroupAddACL
- aclGroupAddObject
- aclGroupGetName
- aclGroupList
- aclGroupListACL
- aclGroupListObjects
- aclGroupRemoveACL
- aclGroupRemoveObject
- aclList
- aclListRights
- aclReload
- aclRemoveRight
- aclSave
- aclSetRight
- hasObjectPermissionTo
- isObjectInACLGroup