mirror of
https://github.com/wavelog/wavelog.git
synced 2026-03-22 02:14:13 +00:00
238 lines
6.6 KiB
PHP
238 lines
6.6 KiB
PHP
<?php
|
|
|
|
class Club_model extends CI_Model {
|
|
|
|
/**
|
|
* Authorization for Club Features
|
|
*
|
|
* @param int $level
|
|
* @param int $club_id
|
|
* @param int $user_id (optional)
|
|
*
|
|
* @return boolean
|
|
*/
|
|
function club_authorize($level, $club_id, $user_id = NULL) {
|
|
|
|
if ($level == 0 || !is_numeric($level)) {
|
|
log_message('error', 'Club Authorization Level not set!');
|
|
return false;
|
|
}
|
|
|
|
if ($club_id == 0 || !is_numeric($club_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid Club ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
// admin is always allowed
|
|
$this->load->model('user_model');
|
|
if ($user_id != NULL) {
|
|
if ($this->user_model->get_by_id($user_id)->row()->user_type == 99) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
if ($user_id == NULL || !is_numeric($user_id)) {
|
|
$user_id = $this->session->userdata('user_id');
|
|
} else {
|
|
$user_id = xss_clean($user_id);
|
|
}
|
|
|
|
// Now we can check the database for permissions
|
|
$binding = [];
|
|
$sql = 'SELECT * FROM `club_permissions` WHERE user_id = ? AND club_id = ? AND p_level >= ?';
|
|
$binding[] = $user_id;
|
|
$binding[] = $club_id;
|
|
$binding[] = $level;
|
|
|
|
$query = $this->db->query($sql, $binding);
|
|
|
|
if ($query->num_rows() > 0) {
|
|
return true;
|
|
} else {
|
|
$this->session->set_flashdata('error', __("You're not allowed to do that!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Get Permissionlevel for User in Club in a real model-way without UI
|
|
*
|
|
* @param int $club_id
|
|
* @param int $user_id
|
|
*
|
|
* @return int
|
|
*/
|
|
function get_permission_noui($club_id, $user_id) {
|
|
|
|
if ($club_id == 0 || !is_numeric($club_id)) {
|
|
return 0;
|
|
}
|
|
|
|
if ($user_id == 0 || !is_numeric($user_id)) {
|
|
return 0;
|
|
}
|
|
|
|
$binding = [];
|
|
$sql = 'SELECT p_level FROM `club_permissions` WHERE user_id = ? AND club_id = ?';
|
|
$binding[] = $user_id;
|
|
$binding[] = $club_id;
|
|
|
|
$query = $this->db->query($sql, $binding);
|
|
|
|
if ($query->num_rows() > 0) {
|
|
return $query->row()->p_level;
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get Permissionlevel for User in Club
|
|
*
|
|
* @param int $club_id
|
|
* @param int $user_id
|
|
*
|
|
* @return int
|
|
*/
|
|
function get_permission($club_id, $user_id) {
|
|
|
|
if ($club_id == 0 || !is_numeric($club_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid Club ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
if ($user_id == 0 || !is_numeric($user_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid User ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
$binding = [];
|
|
$sql = 'SELECT p_level FROM `club_permissions` WHERE user_id = ? AND club_id = ?';
|
|
$binding[] = $user_id;
|
|
$binding[] = $club_id;
|
|
|
|
$query = $this->db->query($sql, $binding);
|
|
|
|
if ($query->num_rows() > 0) {
|
|
return $query->row()->p_level;
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get Club Members
|
|
*
|
|
* @param int $club_id
|
|
*
|
|
* @return array
|
|
*/
|
|
function get_club_members($club_id) {
|
|
|
|
$sql = 'SELECT users.user_id, users.user_type, users.user_callsign, users.user_name, users.user_firstname, users.user_lastname, users.user_email, club_permissions.p_level
|
|
FROM club_permissions
|
|
JOIN users ON club_permissions.user_id = users.user_id
|
|
WHERE club_permissions.club_id = ?;';
|
|
|
|
$members = $this->db->query($sql, [$club_id])->result();
|
|
|
|
return $members;
|
|
}
|
|
|
|
/**
|
|
* Get available Clubstations per User
|
|
*
|
|
* @param int $user_id
|
|
*
|
|
* @return array
|
|
*/
|
|
function get_clubstations($user_id) {
|
|
|
|
$sql = 'SELECT users.user_id, users.user_callsign, club_permissions.p_level
|
|
FROM club_permissions
|
|
JOIN users ON club_permissions.club_id = users.user_id
|
|
WHERE club_permissions.user_id = ?;';
|
|
|
|
$clubs = $this->db->query($sql, [$user_id])->result();
|
|
|
|
return $clubs;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Add Club Member
|
|
*
|
|
* @param int $club_id
|
|
* @param int $user_id
|
|
* @param int $p_level
|
|
*
|
|
* @return boolean
|
|
*/
|
|
function alter_member($club_id, $user_id, $p_level) {
|
|
|
|
if ($club_id == 0 || !is_numeric($club_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid Club ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
if ($user_id == 0 || !is_numeric($user_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid User ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
if ($p_level == 0 || !is_numeric($p_level)) {
|
|
$this->session->set_flashdata('error', __("Invalid Permission Level!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
$binding = [];
|
|
$sql = "INSERT INTO club_permissions (club_id, user_id, p_level)
|
|
VALUES (?, ?, ?)
|
|
ON DUPLICATE KEY UPDATE p_level = VALUES(p_level)";
|
|
$binding[] = $club_id;
|
|
$binding[] = $user_id;
|
|
$binding[] = $p_level;
|
|
|
|
if ($this->db->query($sql, $binding)) {
|
|
return true;
|
|
} else {
|
|
$this->session->set_flashdata('error', __("Error adding Club Member!"));
|
|
redirect('club/permissions/' . $club_id);
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Delete Club Member
|
|
*
|
|
* @param int $club_id
|
|
* @param int $user_id
|
|
*
|
|
* @return boolean
|
|
*/
|
|
function delete_member($club_id, $user_id) {
|
|
|
|
if ($club_id == 0 || !is_numeric($club_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid Club ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
if ($user_id == 0 || !is_numeric($user_id)) {
|
|
$this->session->set_flashdata('error', __("Invalid User ID!"));
|
|
redirect('dashboard');
|
|
}
|
|
|
|
try {
|
|
$this->db->query('DELETE FROM club_permissions WHERE club_id = ? AND user_id = ?', [$club_id, $user_id]);
|
|
$this->db->query('DELETE FROM api WHERE user_id = ? AND created_by = ?', [$club_id, $user_id]);
|
|
$this->db->query('DELETE FROM cat WHERE user_id = ? AND operator = ?', [$club_id, $user_id]);
|
|
return true;
|
|
} catch (Exception $e) {
|
|
log_message('error', 'Error deleting Club Member: ' . $e->getMessage());
|
|
return false;
|
|
}
|
|
}
|
|
}
|