2011-06-17 12:52:00 +00:00
|
|
|
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
|
|
|
|
class Search extends CI_Controller {
|
|
|
|
|
2019-09-04 22:12:45 +00:00
|
|
|
|
|
|
|
function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
|
|
|
|
$this->load->helper(array('form', 'url'));
|
2021-02-09 17:52:23 +00:00
|
|
|
if($this->optionslib->get_option('global_search') != "true") {
|
2019-09-11 16:35:31 +00:00
|
|
|
$this->load->model('user_model');
|
|
|
|
if(!$this->user_model->authorize(2)) { $this->session->set_flashdata('notice', 'You\'re not allowed to do that!'); redirect('dashboard'); }
|
|
|
|
}
|
2019-09-04 22:12:45 +00:00
|
|
|
}
|
|
|
|
|
2011-06-17 12:52:00 +00:00
|
|
|
public function index()
|
|
|
|
{
|
2011-11-04 17:32:03 +00:00
|
|
|
$data['page_title'] = "Search";
|
|
|
|
|
2019-05-14 10:52:11 +00:00
|
|
|
$this->load->view('interface_assets/header', $data);
|
2011-06-17 12:52:00 +00:00
|
|
|
$this->load->view('search/main');
|
2019-05-14 10:52:11 +00:00
|
|
|
$this->load->view('interface_assets/footer');
|
2011-06-17 12:52:00 +00:00
|
|
|
}
|
2019-09-04 22:12:45 +00:00
|
|
|
|
|
|
|
// Filter is for advanced searching and filtering of the logbook
|
|
|
|
public function filter() {
|
|
|
|
$data['page_title'] = "Search & Filter Logbook";
|
|
|
|
|
|
|
|
$this->load->library('form_validation');
|
|
|
|
|
2019-09-04 22:42:11 +00:00
|
|
|
$this->load->model('Search_filter');
|
|
|
|
|
|
|
|
$data['get_table_names'] = $this->Search_filter->get_table_columns();
|
2021-09-25 15:40:15 +00:00
|
|
|
$data['stored_queries'] = $this->Search_filter->get_stored_queries();
|
2019-09-04 22:42:11 +00:00
|
|
|
|
|
|
|
//print_r($this->Search_filter->get_table_columns());
|
|
|
|
|
2019-09-04 22:12:45 +00:00
|
|
|
if ($this->form_validation->run() == FALSE)
|
|
|
|
{
|
|
|
|
$this->load->view('interface_assets/header', $data);
|
|
|
|
$this->load->view('search/filter');
|
|
|
|
$this->load->view('interface_assets/footer');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$this->load->view('interface_assets/header', $data);
|
|
|
|
$this->load->view('search/filter');
|
|
|
|
$this->load->view('interface_assets/footer');
|
|
|
|
}
|
|
|
|
}
|
2019-09-11 23:53:39 +00:00
|
|
|
|
|
|
|
function json_result() {
|
|
|
|
if(isset($_POST['search'])) {
|
2021-09-25 15:40:15 +00:00
|
|
|
$result = $this->fetchQueryResult($_POST['search'], false);
|
2021-09-23 18:18:47 +00:00
|
|
|
echo json_encode($result->result_array());
|
2021-09-25 16:08:31 +00:00
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
}
|
|
|
|
|
2021-09-25 15:40:15 +00:00
|
|
|
function get_stored_queries() {
|
|
|
|
$this->load->model('Search_filter');
|
|
|
|
$data['result'] = $this->Search_filter->get_stored_queries();
|
|
|
|
$this->load->view('search/stored_queries', $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
function search_result() {
|
|
|
|
if(isset($_POST['search'])) {
|
|
|
|
$data['results'] = $this->fetchQueryResult($_POST['search'], false);
|
|
|
|
$this->load->view('search/search_result_ajax', $data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-23 18:18:47 +00:00
|
|
|
function export_to_adif() {
|
|
|
|
if(isset($_POST['search'])) {
|
2021-09-25 15:40:15 +00:00
|
|
|
$data['qsos'] = $this->fetchQueryResult($_POST['search'], false);
|
2021-09-23 18:18:47 +00:00
|
|
|
$this->load->view('adif/data/exportall', $data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-25 15:40:15 +00:00
|
|
|
function export_stored_query_to_adif() {
|
|
|
|
$this->db->where('id', xss_clean($this->input->post('id')));
|
|
|
|
$sql = $this->db->get('queries')->result();
|
|
|
|
|
|
|
|
$data['qsos'] = $this->db->query($sql[0]->query);
|
|
|
|
$this->load->view('adif/data/exportall', $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
function run_query() {
|
|
|
|
$this->db->where('id', xss_clean($this->input->post('id')));
|
|
|
|
$sql = $this->db->get('queries')->result();
|
2021-09-25 17:49:28 +00:00
|
|
|
$sql = $sql[0]->query;
|
2021-09-25 15:40:15 +00:00
|
|
|
|
2021-10-07 14:08:28 +00:00
|
|
|
if (stristr($sql, 'select') && !stristr($sql, 'delete') && !stristr($sql, 'update')) {
|
2021-09-25 17:49:28 +00:00
|
|
|
$data['results'] = $this->db->query($sql);
|
2021-09-25 15:40:15 +00:00
|
|
|
|
2021-09-25 17:49:28 +00:00
|
|
|
$this->load->view('search/search_result_ajax', $data);
|
|
|
|
}
|
2021-09-25 15:40:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function save_query() {
|
|
|
|
if(isset($_POST['search'])) {
|
|
|
|
$query = $this->fetchQueryResult($_POST['search'], true);
|
|
|
|
|
|
|
|
$data = array(
|
|
|
|
'userid' => xss_clean($this->session->userdata('user_id')),
|
|
|
|
'query' => $query,
|
|
|
|
'description' => xss_clean($_POST['description'])
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->db->insert('queries', $data);
|
2021-09-25 16:08:31 +00:00
|
|
|
$last_id = $this->db->insert_id();
|
|
|
|
header('Content-Type: application/json');
|
|
|
|
echo json_encode(array('id' => $last_id, 'description' => xss_clean($_POST['description'])));
|
2021-09-25 15:40:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function delete_query() {
|
|
|
|
$id = xss_clean($this->input->post('id'));
|
|
|
|
$this->load->model('search_filter');
|
|
|
|
$this->search_filter->delete_query($id);
|
|
|
|
}
|
|
|
|
|
2021-10-03 18:06:08 +00:00
|
|
|
function save_edited_query() {
|
2021-09-25 15:40:15 +00:00
|
|
|
$data = array(
|
2021-10-03 18:06:08 +00:00
|
|
|
'description' => xss_clean($this->input->post('description')),
|
2021-09-25 15:40:15 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->db->where('id', xss_clean($this->input->post('id')));
|
2021-10-03 18:06:08 +00:00
|
|
|
$this->db->where('userid', $this->session->userdata['user_id']);
|
|
|
|
$this->db->update('queries', $data);
|
2021-09-25 15:40:15 +00:00
|
|
|
}
|
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
function buildWhere(array $object, string $condition = null): void
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* The $object is one of the following:
|
|
|
|
* - a group, with 'condition' and 'rules' keys
|
|
|
|
* - a condition, that is either 'AND' or 'OR' depending on the parent group setting
|
|
|
|
*/
|
|
|
|
$objectIsGroup = isset($object['condition']);
|
|
|
|
if ($objectIsGroup) {
|
|
|
|
if ($condition === null || $condition === 'AND') {
|
|
|
|
$this->db->group_start();
|
|
|
|
} else {
|
|
|
|
$this->db->or_group_start();
|
|
|
|
}
|
|
|
|
foreach ($object['rules'] as $rule) {
|
|
|
|
/*
|
|
|
|
* Now iterate over the children, that are either groups or conditions
|
|
|
|
*/
|
|
|
|
$this->buildWhere($rule, $object['condition']);
|
|
|
|
}
|
|
|
|
$this->db->group_end();
|
|
|
|
} else {
|
|
|
|
$object['field'] = $this->config->item('table_name') . '.' . $object['field'];
|
2021-09-23 18:18:47 +00:00
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "equal") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'], $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'], $object['value']);
|
|
|
|
}
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "not_equal") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' !=', $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' !=', $object['value']);
|
|
|
|
}
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "begins_with") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' like ', $object['value'] . "%");
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' like ', $object['value'] . "%");
|
|
|
|
}
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "contains") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' like ', "%" . $object['value'] . "%");
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' like ', "%" . $object['value'] . "%");
|
|
|
|
}
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "ends_with") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' like ', "%" . $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' like ', "%" . $object['value']);
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
}
|
2021-12-20 19:15:22 +00:00
|
|
|
|
|
|
|
if ($object['operator'] == "is_empty") {
|
|
|
|
if ($condition == "AND") {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->where($object['field'], '');
|
2021-12-20 19:15:22 +00:00
|
|
|
} else {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->or_where($object['field'], '');
|
2021-12-20 19:15:22 +00:00
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
}
|
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "is_not_empty") {
|
|
|
|
if ($condition == "AND") {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->where($object['field'] . ' !=', '');
|
2021-12-20 19:15:22 +00:00
|
|
|
} else {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->or_where($object['field'] . ' !=', '');
|
2021-12-20 19:15:22 +00:00
|
|
|
}
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
|
2021-12-20 19:15:22 +00:00
|
|
|
if ($object['operator'] == "is_null") {
|
|
|
|
if ($condition == "AND") {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->where($object['field'] . ' IS NULL');
|
2021-12-20 19:15:22 +00:00
|
|
|
} else {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->or_where($object['field'] . ' IS NULL');
|
2021-12-20 19:15:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($object['operator'] == "is_not_null") {
|
|
|
|
if ($condition == "AND") {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->where($object['field'] . ' IS NOT NULL');
|
2021-12-20 19:15:22 +00:00
|
|
|
} else {
|
2022-01-23 19:52:23 +00:00
|
|
|
$this->db->or_where($object['field'] . ' IS NOT NULL');
|
2021-12-20 19:15:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if ($object['operator'] == "less") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' <', $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' <', $object['value']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($object['operator'] == "less_or_equal") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' <=', $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' <=', $object['value']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($object['operator'] == "greater") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' >', $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' >', $object['value']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($object['operator'] == "greater_or_equal") {
|
|
|
|
if ($condition == "AND") {
|
|
|
|
$this->db->where($object['field'] . ' >=', $object['value']);
|
|
|
|
} else {
|
|
|
|
$this->db->or_where($object['field'] . ' >=', $object['value']);
|
2021-09-23 18:18:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-12-20 19:15:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function fetchQueryResult($json, $returnquery) {
|
2022-01-09 11:09:35 +00:00
|
|
|
$CI =& get_instance();
|
|
|
|
$CI->load->model('logbooks_model');
|
|
|
|
$logbooks_locations_array = $CI->logbooks_model->list_logbook_relationships($this->session->userdata('active_station_logbook'));
|
2021-12-20 19:15:22 +00:00
|
|
|
|
|
|
|
$search_items = json_decode($json, true);
|
|
|
|
|
2022-01-09 11:09:35 +00:00
|
|
|
$this->db->group_start();
|
2021-12-20 19:15:22 +00:00
|
|
|
$this->buildWhere($search_items);
|
2022-01-09 11:09:35 +00:00
|
|
|
$this->db->group_end();
|
|
|
|
$this->db->where_in($this->config->item('table_name').'.station_id', $logbooks_locations_array);
|
2021-09-25 15:40:15 +00:00
|
|
|
|
2021-09-23 18:18:47 +00:00
|
|
|
$this->db->order_by('COL_TIME_ON', 'DESC');
|
|
|
|
$this->db->join('station_profile', 'station_profile.station_id = '.$this->config->item('table_name').'.station_id');
|
2021-09-25 15:40:15 +00:00
|
|
|
|
|
|
|
if ($returnquery) {
|
|
|
|
$query = $this->db->get_compiled_select($this->config->item('table_name'));
|
|
|
|
} else {
|
|
|
|
$query = $this->db->get($this->config->item('table_name'));
|
|
|
|
}
|
2021-09-23 18:18:47 +00:00
|
|
|
return $query;
|
|
|
|
}
|
2021-12-20 19:15:22 +00:00
|
|
|
}
|