Im currently using a home brewed groups permission code in my site,
but for limited users/groups its ok. Beyond that, the code will take the fast road to hell.
I started to look in depth at bitwise operations today,
and after much googling, and looking at other code, came up with this
mock up, of a basic permissions routine (not neccessarilly the final product), that utilizes bitwise operations.
Im looking for advise, to see if Im heading in the right way, and/or improvements with this.
Thanks for your time...
-- start code -- <?php
$perm = $user = array(); $perm_total = 0;
// Permissions from some source like a database/file $perm['execute'] = 1; $perm['write'] = 2; $perm['read'] = 4;
// User permissions (predetermined) from sessions maybe $user['tom'] = 7; // rwx $user['joe'] = 5; // rx $user['dirty_harry'] = 9; // illegal in this case?? $user['whats_his_face'] = 6; // rw
// Set the sum of "source" permissions foreach($perm as $value) { $perm_total |= $value; }
echo "<ul>";
// Loop over the users foreach($user as $id => $user_perm) { // User permissions should be between 1 & 7, else set it to 0 if ($user_perm > $perm_total || $user_perm < 0) { $user_perm = 0; }
// Compare user bits to permission bits $compare = $perm_total & $user_perm;
// Make it an even 4 bit string (for visual effect) $bits_string = sprintf("%03d", decbin( $compare ));
echo "<li>User: " . $id . "</li>";
// Check to see if the comparision contains any permission bits
$can_read = (($compare & $perm['read']) == $perm['read']) === TRUE ? "TRUE" : "FALSE";
$can_write = (($compare & $perm['write']) == $perm['write']) === TRUE ? "TRUE" : "FALSE";
$can_execute = (($compare & $perm['execute']) == $perm['execute']) === TRUE ? "TRUE" : "FALSE";
echo "<ul>"; echo "<li>" . $user_perm . ' -> ' . $bits_string . "</li>"; echo "<li>Can Read: $can_read</li>"; echo "<li>Can Write: $can_write</li>"; echo "<li>Can Execute: $can_execute</li>";
echo "</ul>"; }
echo "</ul>";
?> -- end code --
-- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php