mirror of
https://github.com/magicbug/Cloudlog
synced 2024-11-22 17:52:16 +00:00
131 lines
3.3 KiB
PHP
131 lines
3.3 KiB
PHP
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
/*
|
|
|
|
Data lookup functions used within Cloudlog
|
|
|
|
*/
|
|
|
|
class Lookup extends CI_Controller {
|
|
|
|
|
|
function __construct()
|
|
{
|
|
parent::__construct();
|
|
|
|
$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'); }
|
|
}
|
|
|
|
public function index()
|
|
{
|
|
$data['page_title'] = "Quick Lookup";
|
|
$this->load->model('logbook_model');
|
|
$data['dxcc'] = $this->logbook_model->fetchDxcc();
|
|
$data['iota'] = $this->logbook_model->fetchIota();
|
|
$this->load->view('lookup/index', $data);
|
|
}
|
|
|
|
public function search() {
|
|
$CI =& get_instance();
|
|
$CI->load->model('logbooks_model');
|
|
$logbooks_locations_array = $CI->logbooks_model->list_logbook_relationships($this->session->userdata('active_station_logbook'));
|
|
|
|
$location_list = "'".implode("','",$logbooks_locations_array)."'";
|
|
|
|
$this->load->model('lookup_model');
|
|
$this->load->model('bands');
|
|
|
|
$data['bands'] = $this->bands->get_worked_bands(xss_clean($this->input->post('type')));
|
|
|
|
$data['type'] = xss_clean($this->input->post('type'));
|
|
$data['dxcc'] = xss_clean($this->input->post('dxcc'));
|
|
$data['was'] = xss_clean($this->input->post('was'));
|
|
$data['sota'] = xss_clean($this->input->post('sota'));
|
|
$data['grid'] = xss_clean($this->input->post('grid'));
|
|
$data['iota'] = xss_clean($this->input->post('iota'));
|
|
$data['cqz'] = xss_clean($this->input->post('cqz'));
|
|
$data['wwff'] = xss_clean($this->input->post('wwff'));
|
|
$data['location_list'] = $location_list;
|
|
|
|
$data['result'] = $this->lookup_model->getSearchResult($data);
|
|
|
|
$this->load->view('lookup/result', $data);
|
|
}
|
|
|
|
public function scp() {
|
|
if($_POST['callsign']) {
|
|
$uppercase_callsign = strtoupper($_POST['callsign']);
|
|
}
|
|
|
|
// SCP results from logbook
|
|
$this->load->model('logbook_model');
|
|
|
|
$arCalls = array();
|
|
|
|
$query = $this->logbook_model->get_callsigns($uppercase_callsign);
|
|
|
|
foreach ($query->result() as $row)
|
|
{
|
|
if (in_array($row->COL_CALL, $arCalls) == false)
|
|
{
|
|
$arCalls[] = str_replace('0', 'Ø', $row->COL_CALL);
|
|
}
|
|
}
|
|
|
|
// SCP results from master scp db
|
|
$file = 'updates/clublog_scp.txt';
|
|
|
|
if (is_readable($file)) {
|
|
$lines = file($file, FILE_IGNORE_NEW_LINES);
|
|
$input = preg_quote($uppercase_callsign, '~');
|
|
$result = preg_grep('~' . $input . '~', $lines, 0);
|
|
foreach ($result as &$value) {
|
|
if (in_array($value, $arCalls) == false)
|
|
{
|
|
$arCalls[] = str_replace('0', 'Ø', $value);
|
|
}
|
|
}
|
|
}
|
|
|
|
$file = 'updates/masterscp.txt';
|
|
|
|
if (is_readable($file)) {
|
|
$lines = file($file, FILE_IGNORE_NEW_LINES);
|
|
$input = preg_quote($uppercase_callsign, '~');
|
|
$result = preg_grep('~' . $input . '~', $lines, 0);
|
|
foreach ($result as &$value) {
|
|
if (in_array($value, $arCalls) == false)
|
|
{
|
|
$arCalls[] = str_replace('0', 'Ø', $value);
|
|
}
|
|
}
|
|
}
|
|
|
|
sort($arCalls);
|
|
|
|
foreach ($arCalls as $strCall)
|
|
{
|
|
echo " " . $strCall . " ";
|
|
}
|
|
|
|
}
|
|
|
|
public function dok($call) {
|
|
|
|
if($call) {
|
|
$uppercase_callsign = strtoupper($call);
|
|
}
|
|
|
|
// DOK results from logbook
|
|
$this->load->model('logbook_model');
|
|
|
|
$query = $this->logbook_model->get_dok($uppercase_callsign);
|
|
|
|
if ($query->row()) {
|
|
echo $query->row()->COL_DARC_DOK;
|
|
}
|
|
}
|
|
|
|
}
|