Permissions in Phorum 5
=======================
This document describes the way the permission system of Phorum works.
It is targeted at developers that need inside information on the
API calls that are related to permission handling.
Table of contents:
1. Checking user permissions
2. Modifying user permissions
3. Some final notes
1. Checking user permissions
-------------------------------------------------------------------------------
First and foremost, your code should use the function called
phorum_user_access_allowed() to check for a given user permission
in the current forum. However, if you find yourself needing to check
the permisssion directly, here is some information.
Permissions are stored using a bitmask. To check for a certain permission,
simply use the bitwise AND (&) operator to match the permission against the
user's permissions.
For example, if we want to check if a user has permission to read
a particular forum, we would use the following if statement:
if($PHORUM["user"]["permissions"] & PHORUM_USER_ALLOW_READ){
// the user can read this forum
} else {
// the user can NOT read this forum
}
2. Modifying user permissions
-------------------------------------------------------------------------------
If you need to modify the permissions, use the bitwise OR (|) to add
a permission or the bitwise XOR (^) to remove a permission. After you
make the change, save the user. Here is some example code:
// add new topic permissions
$permissions = $PHORUM["user"]["permissions"] | PHORUM_USER_ALLOW_NEW_TOPIC;
$userdata = array(
"user_id" => $PHORUM["user"]["user_id"],
"permissions" => $permissions
);
phorum_user_save($userdata);
// remove new topic permissions
$permissions = $PHORUM["user"]["permissions"] ^ PHORUM_USER_ALLOW_NEW_TOPIC;
$userdata = array(
"user_id" => $PHORUM["user"]["user_id"],
"permissions" => $permissions
);
phorum_user_save($userdata);
3. Some final notes
-------------------------------------------------------------------------------
That should be all you need to know about the Phorum permission system.
Here is some stuff that helped explain this to the other developers:
> select (256 | 16);
> That OR's the two numbers together.
> you get 272
> then:
> select 16 & 272;
> That returns 16.
> So, in our data, the 272 represents what is in the database.
> The 16 would be one of the permission constancts
> Our constants would look like this:
> define("PHORUM_USER_ALLOW_READ", 1);
> define("PHORUM_USER_ALLOW_REPLY", 2);
> define("PHORUM_USER_ALLOW_EDIT", 4);
> define("PHORUM_USER_ALLOW_NEW_TOPIC", 8);
> define("PHORUM_USER_ALLOW_UPLOAD", 16);
> define("PHORUM_USER_ALLOW_ATTACH", 32);
> define("PHORUM_USER_ALLOW_MODERATE_MESSAGES", 64);
> define("PHORUM_USER_ALLOW_MODERATE_USERS", 128);
> define("PHORUM_USER_ALLOW_FORUM_PROPERTIES", 256);
> To give someone read and reply, we would set their perm to 1 | 2
> Then, to check it, we would $user_perm_value & $perm == $perm
> or in sql
> where permission & $perm = $perm
Another example to show that the = $perm can be left out:
> select 1 | 2
> read, reply
> = 3
> select 3 & 16
> =0