db->get_where('ea_roles', array('slug' => $role_slug))->row()->id; } /** * Returns all the privileges (bool values) of a role slug. * * The privilege numbers are converted into bool values of the four main actions (view, * add, edit, delete). By checking each value you can know if the user is able to perform * this action. * * @param string $slug The role slug. * @return array Returns the privilege value. */ public function get_privileges($slug) { $privileges = $this->db->get_where('ea_roles', array('slug' => $slug))->row_array(); unset($privileges['id'], $privileges['name'], $privileges['slug'], $privileges['is_admin']); // Convert the numeric values to bool so that is easier to check whether a // user has the required privileges for a specific action. foreach($privileges as &$value) { $privileges_number = $value; $value = array( 'view' => FALSE, 'add' => FALSE, 'edit' => FALSE, 'delete' => FALSE ); if ($privileges_number > 0) { if (intval($privileges_number / PRIV_DELETE) == 1) { $value['delete'] = TRUE; $privileges_number -= PRIV_DELETE; } if (intval($privileges_number / PRIV_EDIT) == 1) { $value['edit'] = TRUE; $privileges_number -= PRIV_EDIT; } if (intval($privileges_number / PRIV_ADD) == 1) { $value['add'] = TRUE; $privileges_number -= PRIV_ADD; } $value['view'] = TRUE; } } return $privileges; } } /* End of file roles_model.php */ /* Location: ./application/models/roles_model.php */