mirror of
https://github.com/magicbug/Cloudlog
synced 2024-11-23 01:59:14 +00:00
390 lines
12 KiB
PHP
390 lines
12 KiB
PHP
<?php
|
|
|
|
class Oqrs_model extends CI_Model {
|
|
function get_oqrs_stations() {
|
|
$this->db->where('oqrs', "1");
|
|
return $this->db->get('station_profile');
|
|
}
|
|
|
|
function get_station_info($station_id) {
|
|
$station_id = $this->security->xss_clean($station_id);
|
|
|
|
$sql = 'select
|
|
count(*) as count,
|
|
min(col_time_on) as mindate,
|
|
max(col_time_on) as maxdate
|
|
from ' . $this->config->item('table_name') . ' where station_id = ' . $station_id;
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
return $query->row();
|
|
}
|
|
|
|
function get_qsos($station_id, $callsign, $bands){
|
|
$modes = $this->get_worked_modes($station_id);
|
|
|
|
// Creating an empty array with all the bands and modes from the database
|
|
foreach ($modes as $mode) {
|
|
foreach ($bands as $band) {
|
|
$resultArray[$mode][$band] = '-';
|
|
}
|
|
}
|
|
|
|
// Populating array with worked band/mode combinations
|
|
$worked = $this->getQueryData($station_id, $callsign);
|
|
foreach ($worked as $w) {
|
|
$resultArray[$w->col_mode][$w->col_band] = '<i class="fa fa-check" aria-hidden="true"></i>';
|
|
}
|
|
|
|
$result['qsocount'] = count($worked);
|
|
$result['qsoarray'] = $resultArray;
|
|
|
|
return $result;
|
|
}
|
|
|
|
|
|
function get_qsos_grouped($callsign){
|
|
|
|
// Populating array with worked band/mode combinations
|
|
$worked = $this->getQueryData($station_id, $callsign);
|
|
|
|
$result['qsocount'] = count($worked);
|
|
$result['qsoarray'] = $resultArray;
|
|
|
|
return $result;
|
|
}
|
|
|
|
/*
|
|
* Builds query depending on what we are searching for
|
|
*/
|
|
function getQueryData($station_id, $callsign) {
|
|
$station_id = $this->security->xss_clean($station_id);
|
|
$callsign = $this->security->xss_clean($callsign);
|
|
$sql = 'select lower(col_mode) col_mode, coalesce(col_submode, "") col_submode, col_band from ' . $this->config->item('table_name') . ' where station_id = ' . $station_id . ' and col_call ="' . $callsign . '" and col_prop_mode != "SAT"';
|
|
|
|
$sql .= ' union all select lower(col_mode) col_mode, coalesce(col_submode, "") col_submode, "SAT" col_band from ' . $this->config->item('table_name') . ' where station_id = ' . $station_id . ' and col_call ="' . $callsign . '" and col_prop_mode = "SAT"';
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
return $query->result();
|
|
}
|
|
|
|
/*
|
|
* Builds query depending on what we are searching for
|
|
*/
|
|
function getQueryDataGrouped($callsign) {
|
|
$callsign = $this->security->xss_clean($callsign);
|
|
$sql = 'select lower(col_mode) col_mode, coalesce(col_submode, "") col_submode, col_band, station_callsign, station_profile_name, l.station_id from ' . $this->config->item('table_name') . ' as l join station_profile on l.station_id = station_profile.station_id where station_profile.oqrs = "1" and l.col_call ="' . $callsign . '" and l.col_prop_mode != "SAT"';
|
|
|
|
$sql .= ' union all select lower(col_mode) col_mode, coalesce(col_submode, "") col_submode, "SAT" col_band, station_callsign, station_profile_name, l.station_id from ' .
|
|
$this->config->item('table_name') . ' l' .
|
|
' join station_profile on l.station_id = station_profile.station_id where station_profile.oqrs = "1" and col_call ="' . $callsign . '" and col_prop_mode = "SAT"';
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
if ($query) {
|
|
return $query->result();
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
/*
|
|
* Get's the worked modes from the log
|
|
*/
|
|
function get_worked_modes($station_id)
|
|
{
|
|
// get all worked modes from database
|
|
$data = $this->db->query(
|
|
"SELECT distinct LOWER(`COL_MODE`) as `COL_MODE` FROM `" . $this->config->item('table_name') . "` WHERE station_id in (" . $station_id . ") order by COL_MODE ASC"
|
|
);
|
|
$results = array();
|
|
foreach ($data->result() as $row) {
|
|
array_push($results, $row->COL_MODE);
|
|
}
|
|
|
|
$data = $this->db->query(
|
|
"SELECT distinct LOWER(`COL_SUBMODE`) as `COL_SUBMODE` FROM `" . $this->config->item('table_name') . "` WHERE station_id in (" . $station_id . ") and coalesce(COL_SUBMODE, '') <> '' order by COL_SUBMODE ASC"
|
|
);
|
|
foreach ($data->result() as $row) {
|
|
if (!in_array($row, $results)) {
|
|
array_push($results, $row->COL_SUBMODE);
|
|
}
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
function getOqrsRequests($location_list) {
|
|
$sql = 'select * from oqrs join station_profile on oqrs.station_id = station_profile.station_id where oqrs.station_id in (' . $location_list . ')';
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
return $query->result();
|
|
}
|
|
|
|
function save_oqrs_request($postdata) {
|
|
$station_ids = array();
|
|
$qsos = $postdata['qsos'];
|
|
foreach($qsos as $qso) {
|
|
$data = array(
|
|
'date' => xss_clean($qso[0]),
|
|
'time' => xss_clean($qso[1]),
|
|
'band' => xss_clean($qso[2]),
|
|
'mode' => xss_clean($qso[3]),
|
|
'requestcallsign' => xss_clean($postdata['callsign']),
|
|
'station_id' => xss_clean($postdata['station_id']),
|
|
'note' => xss_clean($postdata['message']),
|
|
'email' => xss_clean($postdata['email']),
|
|
'qslroute' => xss_clean($postdata['qslroute']),
|
|
'status' => '0',
|
|
);
|
|
|
|
$qsoid = $this->check_oqrs($data);
|
|
|
|
if ($qsoid > 0) {
|
|
$data['status'] = '2';
|
|
}
|
|
$data['qsoid'] = $qsoid;
|
|
|
|
$this->db->insert('oqrs', $data);
|
|
if(!in_array(xss_clean($postdata['station_id']), $station_ids)){
|
|
array_push($station_ids, xss_clean($postdata['station_id']));
|
|
}
|
|
}
|
|
|
|
return $station_ids;
|
|
}
|
|
|
|
function save_oqrs_request_grouped($postdata) {
|
|
$station_ids = array();
|
|
$qsos = $postdata['qsos'];
|
|
foreach($qsos as $qso) {
|
|
$data = array(
|
|
'date' => xss_clean($qso[0]),
|
|
'time' => xss_clean($qso[1]),
|
|
'band' => xss_clean($qso[2]),
|
|
'mode' => xss_clean($qso[3]),
|
|
'requestcallsign' => xss_clean($postdata['callsign']),
|
|
'station_id' => xss_clean($qso[4]),
|
|
'note' => xss_clean($postdata['message']),
|
|
'email' => xss_clean($postdata['email']),
|
|
'qslroute' => xss_clean($postdata['qslroute']),
|
|
'status' => '0',
|
|
);
|
|
|
|
$qsoid = $this->check_oqrs($data);
|
|
|
|
if ($qsoid > 0) {
|
|
$data['status'] = '2';
|
|
}
|
|
$data['qsoid'] = $qsoid;
|
|
|
|
$this->db->insert('oqrs', $data);
|
|
|
|
if(!in_array(xss_clean($qso[4]), $station_ids)){
|
|
array_push($station_ids, xss_clean($qso[4]));
|
|
}
|
|
}
|
|
return $station_ids;
|
|
}
|
|
|
|
function delete_oqrs_line($id) {
|
|
$sql = 'delete from oqrs where id =' . xss_clean($id);
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
// Status:
|
|
// 0 = open request
|
|
// 1 = not in log request
|
|
// 2 = request done, means we found a match in the log
|
|
function save_not_in_log($postdata) {
|
|
$qsos = $postdata['qsos'];
|
|
foreach($qsos as $qso) {
|
|
$data = array(
|
|
'date' => xss_clean($qso[0]),
|
|
'time' => xss_clean($qso[1]),
|
|
'band' => xss_clean($qso[2]),
|
|
'mode' => xss_clean($qso[3]),
|
|
'requestcallsign' => xss_clean($postdata['callsign']),
|
|
'station_id' => xss_clean($postdata['station_id']),
|
|
'note' => xss_clean($postdata['message']),
|
|
'email' => xss_clean($postdata['email']),
|
|
'qslroute' => '',
|
|
'status' => '1',
|
|
'qsoid' => '0',
|
|
);
|
|
|
|
$this->db->insert('oqrs', $data);
|
|
}
|
|
}
|
|
|
|
function check_oqrs($qsodata) {
|
|
$sql = 'select * from ' . $this->config->item('table_name') .
|
|
' where (col_band = \'' . $qsodata['band'] . '\' or col_prop_mode = \'' . $qsodata['band'] . '\')
|
|
and col_call = \'' . $qsodata['requestcallsign'] . '\'
|
|
and date(col_time_on) = \'' . $qsodata['date'] . '\'
|
|
and (col_mode = \'' . $qsodata['mode'] . '\'
|
|
or col_submode = \'' . $qsodata['mode'] . '\')
|
|
and timediff(time(col_time_on), \'' . $qsodata['time'] . '\') <= 3000
|
|
and station_id = ' . $qsodata['station_id'];
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
if ($result = $query->result()) {
|
|
$id = 0;
|
|
foreach ($result as $qso) {
|
|
$this->paperqsl_requested($qso->COL_PRIMARY_KEY, $qsodata['qslroute']);
|
|
$id = $qso->COL_PRIMARY_KEY;
|
|
}
|
|
return $id;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
// Set Paper to requested
|
|
function paperqsl_requested($qso_id, $method) {
|
|
$data = array(
|
|
'COL_QSLSDATE' => date('Y-m-d H:i:s'),
|
|
'COL_QSL_SENT' => 'R',
|
|
'COL_QSL_SENT_VIA ' => $method
|
|
);
|
|
|
|
$this->db->where('COL_PRIMARY_KEY', $qso_id);
|
|
|
|
$this->db->update($this->config->item('table_name'), $data);
|
|
}
|
|
|
|
function search_log($callsign) {
|
|
$this->db->join('station_profile', 'station_profile.station_id = '.$this->config->item('table_name').'.station_id');
|
|
// always filter user. this ensures that no inaccesible QSOs will be returned
|
|
$this->db->where('station_profile.user_id', $this->session->userdata('user_id'));
|
|
$this->db->where('COL_CALL like "%'.$callsign.'%"');
|
|
$this->db->order_by("COL_TIME_ON", "ASC");
|
|
$query = $this->db->get($this->config->item('table_name'));
|
|
|
|
return $query;
|
|
}
|
|
|
|
function search_log_time_date($time, $date, $band, $mode) {
|
|
$sql = 'select * from ' . $this->config->item('table_name') . ' thcv
|
|
join station_profile on thcv.station_id = station_profile.station_id where (col_band = \'' . $band . '\' or col_prop_mode = \'' . $band . '\')
|
|
and date(col_time_on) = \'' . $date . '\'
|
|
and (col_mode = \'' . $mode . '\'
|
|
or col_submode = \'' . $mode . '\')
|
|
and timediff(time(col_time_on), \'' . $time . '\') <= 3000
|
|
and station_profile.user_id = '. $this->session->userdata('user_id');
|
|
|
|
return $this->db->query($sql);;
|
|
}
|
|
|
|
function mark_oqrs_line_as_done($id) {
|
|
$data = array(
|
|
'status' => '2',
|
|
);
|
|
|
|
$this->db->where('id', $id);
|
|
|
|
$this->db->update('oqrs', $data);
|
|
}
|
|
|
|
function getQslInfo($station_id) {
|
|
$sql = 'select oqrs_text from station_profile where station_id = ' . $station_id;
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
if ($query->num_rows() > 0)
|
|
{
|
|
$row = $query->row();
|
|
return $row->oqrs_text;
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
function getOqrsEmailSetting($station_id) {
|
|
$sql = 'select oqrs_email from station_profile where station_id = ' . $station_id;
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
if ($query->num_rows() > 0)
|
|
{
|
|
$row = $query->row();
|
|
return $row->oqrs_email;
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
/*
|
|
* @param array $searchCriteria
|
|
* @return array
|
|
*/
|
|
public function searchOqrs($searchCriteria) : array {
|
|
$conditions = [];
|
|
$binding = [$searchCriteria['user_id']];
|
|
|
|
if ($searchCriteria['de'] !== '') {
|
|
$conditions[] = "station_profile.station_id = ?";
|
|
$binding[] = trim($searchCriteria['de']);
|
|
}
|
|
if ($searchCriteria['dx'] !== '') {
|
|
$conditions[] = "oqrs.requestcallsign LIKE ?";
|
|
$binding[] = '%' . trim($searchCriteria['dx']) . '%';
|
|
}
|
|
if ($searchCriteria['status'] !== '') {
|
|
$conditions[] = "oqrs.status = ?";
|
|
$binding[] = $searchCriteria['status'];
|
|
}
|
|
|
|
$where = trim(implode(" AND ", $conditions));
|
|
if ($where != "") {
|
|
$where = "AND $where";
|
|
}
|
|
|
|
$limit = $searchCriteria['oqrsResults'];
|
|
|
|
$sql = "
|
|
SELECT *, DATE_FORMAT(requesttime, \"%Y-%m-%d %H:%i\") as requesttime, DATE_FORMAT(time, \"%H:%i\") as time
|
|
FROM oqrs
|
|
INNER JOIN station_profile ON oqrs.station_id=station_profile.station_id
|
|
WHERE station_profile.user_id = ?
|
|
$where
|
|
ORDER BY oqrs.id
|
|
LIMIT $limit
|
|
";
|
|
|
|
$data = $this->db->query($sql, $binding);
|
|
|
|
return $data->result('array');
|
|
}
|
|
|
|
public function oqrs_requests($location_list) {
|
|
if ($location_list != "") {
|
|
$sql = 'SELECT COUNT(*) AS number FROM oqrs JOIN station_profile ON oqrs.station_id = station_profile.station_id WHERE oqrs.station_id IN ('.$location_list.') AND status < 2';
|
|
$query = $this->db->query($sql);
|
|
$row = $query->row();
|
|
return $row->number;
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
function getOqrsStationsFromSlug($logbook_id) {
|
|
$sql = 'SELECT station_callsign FROM `station_logbooks_relationship` JOIN `station_profile` ON station_logbooks_relationship.station_location_id = station_profile.station_id WHERE station_profile.oqrs = 1 AND station_logbook_id = '.$logbook_id.';';
|
|
|
|
$query = $this->db->query($sql);
|
|
|
|
if ($query->num_rows() > 0) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
}
|