diff --git a/.gitignore b/.gitignore
index 89394e873..ceb3329c9 100644
--- a/.gitignore
+++ b/.gitignore
@@ -23,3 +23,4 @@ sync.sh
.env
/node_modules
/.vs
+.vscode/sftp.json
diff --git a/application/config/migration.php b/application/config/migration.php
index 574240d66..6e6072fac 100644
--- a/application/config/migration.php
+++ b/application/config/migration.php
@@ -22,7 +22,7 @@
|
*/
-$config['migration_version'] = 186;
+$config['migration_version'] = 188;
/*
|--------------------------------------------------------------------------
diff --git a/application/controllers/Distances.php b/application/controllers/Distances.php
index 1854fb5b8..9812ada27 100644
--- a/application/controllers/Distances.php
+++ b/application/controllers/Distances.php
@@ -17,8 +17,12 @@ public function index()
$data['page_title'] = "Distances Worked";
$this->load->model('bands');
+ $this->load->model('gridmap_model');
+
$data['bands_available'] = $this->bands->get_worked_bands_distances();
$data['sats_available'] = $this->bands->get_worked_sats();
+ $data['modes'] = $this->gridmap_model->get_worked_modes();
+ $data['powers'] = $this->bands->get_worked_powers();
$this->load->view('interface_assets/header', $data);
$this->load->view('distances/index');
@@ -72,12 +76,27 @@ public function getDistanceQsos(){
$distance = $this->security->xss_clean($this->input->post('distance'));
$band = $this->security->xss_clean($this->input->post('band'));
$sat = $this->security->xss_clean($this->input->post('sat'));
+ $mode = $this->security->xss_clean($this->input->post('mode'));
+ $power = $this->security->xss_clean($this->input->post('pwr'));
+
+ $data['results'] = $this->distances_model->qso_details($distance, $band, $sat, $mode, $power);
- $data['results'] = $this->distances_model->qso_details($distance, $band, $sat);
+ // Render Page
+ if (strtolower($band) == 'all') $band = lang('statistics_distances_bands_all');
+ (strtolower($mode) == 'all') ? $mode = lang('statistics_distances_modes_all') : $mode = strtoupper($mode);
+ switch (strtolower($power)) {
+ case 'all':
+ $power = lang('statistics_distances_bands_all');
+ break;
+ case '':
+ $power = lang('general_word_undefined');
+ break;
+ default:
+ $power .= 'W';
+ }
- // Render Page
$data['page_title'] = "Log View - " . $distance;
- $data['filter'] = lang('statistics_distances_qsos_with') . " " . $distance . " " . lang('statistics_distances_and_band'). " " . $band;
+ $data['filter'] = lang('statistics_distances_qsos_with') . " " . $distance . lang('statistics_distances_and_band') . " " . $band . lang('statistics_distances_and_mode') . $mode . lang('statistics_distances_and_power') . $power;
$this->load->view('awards/details', $data);
}
}
diff --git a/application/controllers/Logbook.php b/application/controllers/Logbook.php
index 76b0cca16..de881007e 100644
--- a/application/controllers/Logbook.php
+++ b/application/controllers/Logbook.php
@@ -820,18 +820,25 @@ function partial($id) {
$html .= "";
return $html;
} else {
- if ($this->config->item('callbook') == "qrz" && $this->config->item('qrz_username') != null && $this->config->item('qrz_password') != null) {
+ // if session data callbook_type is qrz
+ if ($this->session->userdata('callbook_type') == "QRZ") {
// Lookup using QRZ
$this->load->library('qrz');
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
if(!$this->session->userdata('qrz_session_key')) {
- $qrz_session_key = $this->qrz->session($this->config->item('qrz_username'), $this->config->item('qrz_password'));
+ $qrz_session_key = $this->qrz->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('qrz_session_key', $qrz_session_key);
}
$callsign['callsign'] = $this->qrz->search($id, $this->session->userdata('qrz_session_key'), $this->config->item('use_fullname'));
if (empty($callsign['callsign']['callsign'])) {
- $qrz_session_key = $this->qrz->session($this->config->item('qrz_username'), $this->config->item('qrz_password'));
+ $qrz_session_key = $this->qrz->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('qrz_session_key', $qrz_session_key);
$callsign['callsign'] = $this->qrz->search($id, $this->session->userdata('qrz_session_key'), $this->config->item('use_fullname'));
}
@@ -840,12 +847,19 @@ function partial($id) {
$entity = $this->logbook_model->get_entity($callsign['callsign']['dxcc']);
$callsign['callsign']['dxcc_name'] = $entity['name'];
}
- } else if ($this->config->item('callbook') == "hamqth" && $this->config->item('hamqth_username') != null && $this->config->item('hamqth_password') != null) {
+ } elseif ($this->session->userdata('callbook_type') == "HamQTH") {
// Load the HamQTH library
$this->load->library('hamqth');
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
+
if(!$this->session->userdata('hamqth_session_key')) {
- $hamqth_session_key = $this->hamqth->session($this->config->item('hamqth_username'), $this->config->item('hamqth_password'));
+ $hamqth_session_key = $this->hamqth->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
}
@@ -853,7 +867,7 @@ function partial($id) {
// If HamQTH session has expired, start a new session and retry the search.
if($callsign['callsign']['error'] == "Session does not exist or expired") {
- $hamqth_session_key = $this->hamqth->session($this->config->item('hamqth_username'), $this->config->item('hamqth_password'));
+ $hamqth_session_key = $this->hamqth->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
$callsign['callsign'] = $this->hamqth->search($callsign, $this->session->userdata('hamqth_session_key'));
}
@@ -873,13 +887,6 @@ function partial($id) {
$callsign['error'] = 'Lookup not configured. Please review configuration.';
}
- // There's no hamli integration? Disabled for now.
- /*else {
- // Lookup using hamli
- $this->load->library('hamli');
-
- $callsign['callsign'] = $this->hamli->callsign($id);
- }*/
if (isset($callsign['callsign']['gridsquare'])) {
$this->load->model('logbook_model');
@@ -929,44 +936,60 @@ function search_result($id="", $id2="") {
$this->load->view('view_log/partial/log_ajax.php', $data);
} else {
- if ($this->config->item('callbook') == "qrz" && $this->config->item('qrz_username') != null && $this->config->item('qrz_password') != null) {
+ // if session data callbook_type is qrz
+ if ($this->session->userdata('callbook_type') == "QRZ") {
// Lookup using QRZ
$this->load->library('qrz');
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
if(!$this->session->userdata('qrz_session_key')) {
- $qrz_session_key = $this->qrz->session($this->config->item('qrz_username'), $this->config->item('qrz_password'));
+ $qrz_session_key = $this->qrz->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('qrz_session_key', $qrz_session_key);
}
+ $data['callsign'] = $this->qrz->search($fixedid, $this->session->userdata('qrz_session_key'), $this->config->item('use_fullname'));
- $data['callsign'] = $this->qrz->search($id, $this->session->userdata('qrz_session_key'), $this->config->item('use_fullname'));
- if (isset($data['callsign']['gridsquare'])) {
- $this->load->model('logbook_model');
- $data['grid_worked'] = $this->logbook_model->check_if_grid_worked_in_logbook(strtoupper(substr($data['callsign']['gridsquare'],0,4)), 0, $this->session->userdata('user_default_band'));
+ if (empty($data['callsign']['callsign'])) {
+ $qrz_session_key = $this->qrz->session($this->session->userdata('callbook_username'), $decrypted_password);
+ $this->session->set_userdata('qrz_session_key', $qrz_session_key);
+ $data['callsign'] = $this->qrz->search($fixedid, $this->session->userdata('qrz_session_key'), $this->config->item('use_fullname'));
}
if (isset($data['callsign']['dxcc'])) {
$this->load->model('logbook_model');
$entity = $this->logbook_model->get_entity($data['callsign']['dxcc']);
$data['callsign']['dxcc_name'] = $entity['name'];
}
- if (isset($data['callsign']['error'])) {
- $data['error'] = $data['callsign']['error'];
+ if (isset($data['callsign']['gridsquare'])) {
+ $this->load->model('logbook_model');
+ $data['grid_worked'] = $this->logbook_model->check_if_grid_worked_in_logbook(strtoupper(substr($data['callsign']['gridsquare'],0,4)), 0, $this->session->userdata('user_default_band'));
}
- } else if ($this->config->item('callbook') == "hamqth" && $this->config->item('hamqth_username') != null && $this->config->item('hamqth_password') != null) {
+ } elseif ($this->session->userdata('callbook_type') == "HamQTH") {
// Load the HamQTH library
$this->load->library('hamqth');
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
+
if(!$this->session->userdata('hamqth_session_key')) {
- $hamqth_session_key = $this->hamqth->session($this->config->item('hamqth_username'), $this->config->item('hamqth_password'));
+ $hamqth_session_key = $this->hamqth->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
}
- $data['callsign'] = $this->hamqth->search($id, $this->session->userdata('hamqth_session_key'));
+ $data['callsign'] = $this->hamqth->search($fixedid, $this->session->userdata('hamqth_session_key'));
// If HamQTH session has expired, start a new session and retry the search.
if($data['callsign']['error'] == "Session does not exist or expired") {
- $hamqth_session_key = $this->hamqth->session($this->config->item('hamqth_username'), $this->config->item('hamqth_password'));
+ $hamqth_session_key = $this->hamqth->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
- $data['callsign'] = $this->hamqth->search($id, $this->session->userdata('hamqth_session_key'));
+ $data['callsign'] = $this->hamqth->search($fixedid, $this->session->userdata('hamqth_session_key'));
}
if (isset($data['callsign']['gridsquare'])) {
$this->load->model('logbook_model');
@@ -982,12 +1005,7 @@ function search_result($id="", $id2="") {
}
} else {
$data['error'] = 'Lookup not configured. Please review configuration.';
- } /*else {
- // Lookup using hamli
- $this->load->library('hamli');
-
- $data['callsign'] = $this->hamli->callsign($id);
- }*/
+ }
$data['id'] = strtoupper($id);
diff --git a/application/controllers/User.php b/application/controllers/User.php
index 9ec6ffe9a..5cb9da117 100644
--- a/application/controllers/User.php
+++ b/application/controllers/User.php
@@ -210,7 +210,10 @@ function add()
$this->input->post('user_quicklog_enter'),
$this->input->post('language'),
$this->input->post('user_hamsat_key'),
- $this->input->post('user_hamsat_workable_only')
+ $this->input->post('user_hamsat_workable_only'),
+ $this->input->post('user_callbook_type'),
+ $this->input->post('user_callbook_username'),
+ $this->input->post('user_callbook_password')
)) {
// Check for errors
case EUSERNAMEEXISTS:
@@ -228,6 +231,8 @@ function add()
redirect('user');
return;
}
+
+
$data['page_title'] = "Users";
$this->load->view('interface_assets/header', $data);
@@ -571,6 +576,43 @@ function edit()
$data['user_winkey'] = $q->winkey;
}
+ $this->load->model('user_options_model');
+ $callbook_type_object = $this->user_options_model->get_options('callbook')->result();
+
+ if ($this->input->post('user_callbook_type', true)) {
+ $data['user_callbook_type'] = $this->input->post('user_callbook_type', true);
+ } else {
+ if (isset($callbook_type_object[1]->option_value)) {
+ $data['user_callbook_type'] = $callbook_type_object[1]->option_value;
+ } else {
+ $data['user_callbook_type'] = "";
+ }
+ }
+
+
+ // Handle user_callbook_username
+ if ($this->input->post('user_callbook_username', true)) {
+ $data['user_callbook_username'] = $this->input->post('user_callbook_username', true);
+ } else {
+ if (isset($callbook_type_object[2]->option_value)) {
+ $data['user_callbook_username'] = $callbook_type_object[2]->option_value;
+ } else {
+ $data['user_callbook_username'] = "";
+ }
+ }
+
+ // Handle user_callbook_password
+ if ($this->input->post('user_callbook_password', true)) {
+ $data['user_callbook_password'] = $this->input->post('user_callbook_password', true);
+ } else {
+ if (isset($callbook_type_object[0]->option_value)) {
+ $data['user_callbook_password'] = $callbook_type_object[0]->option_value;
+ } else {
+ $data['user_callbook_password'] = "";
+ }
+ }
+
+
$this->load->model('user_options_model');
$hamsat_user_object = $this->user_options_model->get_options('hamsat')->result();
@@ -595,8 +637,6 @@ function edit()
}
}
- // Get Settings for Dashboard
-
// Set defaults
$data['dashboard_upcoming_dx_card'] = false;
$data['dashboard_qslcard_card'] = false;
@@ -715,6 +755,33 @@ function edit()
$this->input->set_cookie($cookie);
}
if ($this->session->userdata('user_id') == $this->input->post('id', true)) {
+
+ // Handle user_callbook_type
+ if (isset($_POST['user_callbook_type'])) {
+ $this->user_options_model->set_option('callbook', 'callbook_type', array('value' => $_POST['user_callbook_type']));
+ } else {
+ $this->user_options_model->set_option('callbook', 'callbook_type', array('value' => ''));
+ }
+
+ // Handle user_callbook_username
+ if (isset($_POST['user_callbook_username'])) {
+ $this->user_options_model->set_option('callbook', 'callbook_username', array('value' => $_POST['user_callbook_username']));
+ } else {
+ $this->user_options_model->set_option('callbook', 'callbook_username', array('value' => ''));
+ }
+
+ // Handle user_callbook_password
+ if (isset($_POST['user_callbook_password']) && !empty($_POST['user_callbook_password'])) {
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Encrypt the password
+ $encrypted_password = $this->encryption->encrypt($_POST['user_callbook_password']);
+
+ // Save the encrypted password
+ $this->user_options_model->set_option('callbook', 'callbook_password', array('value' => $encrypted_password));
+ }
+
if (isset($_POST['user_dashboard_enable_dxpedition_card'])) {
$this->user_options_model->set_option('dashboard', 'dashboard_upcoming_dx_card', array('enabled' => 'true'));
} else {
@@ -958,7 +1025,6 @@ function login()
'secure' => FALSE
);
- $this->input->set_cookie($cookie);
// Create a remember me cookie
if ($this->input->post('remember_me') == '1') {
diff --git a/application/language/bulgarian/general_words_lang.php b/application/language/bulgarian/general_words_lang.php
index abde6b3ea..1b5a159a1 100644
--- a/application/language/bulgarian/general_words_lang.php
+++ b/application/language/bulgarian/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Дата';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/bulgarian/statistics_lang.php b/application/language/bulgarian/statistics_lang.php
index 70bb61035..dfae52d21 100644
--- a/application/language/bulgarian/statistics_lang.php
+++ b/application/language/bulgarian/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/chinese_simplified/general_words_lang.php b/application/language/chinese_simplified/general_words_lang.php
index 193d64289..cf86ac37f 100644
--- a/application/language/chinese_simplified/general_words_lang.php
+++ b/application/language/chinese_simplified/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "不显示";
$lang['general_word_icon'] = "图标";
$lang['general_word_never'] = "从不";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = '日期';
$lang['general_word_startdate'] = "开始时间";
diff --git a/application/language/chinese_simplified/statistics_lang.php b/application/language/chinese_simplified/statistics_lang.php
index 76c298c37..724c53281 100644
--- a/application/language/chinese_simplified/statistics_lang.php
+++ b/application/language/chinese_simplified/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "全部";
+$lang['statistics_distances_modes_all'] = "全部";
$lang['statistics_distances_worked'] = "通联距离";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "次通联
您最远的通联是与";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "在网格";
@@ -35,6 +36,8 @@
$lang['statistics_distances_callsigns_worked'] = "通联的呼号(最多显示5个):";
$lang['statistics_distances_qsos_with'] = "QSO 与";
$lang['statistics_distances_and_band'] = "和波段";
+$lang['statistics_distances_and_mode'] = ", 模式 : ";
+$lang['statistics_distances_and_power'] = ", 发射功率 : ";
/*
*
diff --git a/application/language/czech/general_words_lang.php b/application/language/czech/general_words_lang.php
index bfb0c5dcb..b62c1d837 100644
--- a/application/language/czech/general_words_lang.php
+++ b/application/language/czech/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Datum';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/czech/statistics_lang.php b/application/language/czech/statistics_lang.php
index 8ccc495d3..806539e8a 100644
--- a/application/language/czech/statistics_lang.php
+++ b/application/language/czech/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/dutch/general_words_lang.php b/application/language/dutch/general_words_lang.php
index 81304b696..ea4c6edf2 100644
--- a/application/language/dutch/general_words_lang.php
+++ b/application/language/dutch/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Datum';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/english/general_words_lang.php b/application/language/english/general_words_lang.php
index c1a4b2bdb..218d05c00 100644
--- a/application/language/english/general_words_lang.php
+++ b/application/language/english/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Date';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/english/statistics_lang.php b/application/language/english/statistics_lang.php
index a3576bf21..787f22b90 100644
--- a/application/language/english/statistics_lang.php
+++ b/application/language/english/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/finnish/general_words_lang.php b/application/language/finnish/general_words_lang.php
index d9d216e32..0d9ba5645 100644
--- a/application/language/finnish/general_words_lang.php
+++ b/application/language/finnish/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Päivä';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/finnish/statistics_lang.php b/application/language/finnish/statistics_lang.php
index c7811d6b8..681787280 100644
--- a/application/language/finnish/statistics_lang.php
+++ b/application/language/finnish/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/french/general_words_lang.php b/application/language/french/general_words_lang.php
index 368263ec2..c345247f3 100644
--- a/application/language/french/general_words_lang.php
+++ b/application/language/french/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Ne pas afficher";
$lang['general_word_icon'] = "Icône";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Indéfini(e)";
$lang['general_word_date'] = "Date";
$lang['general_word_startdate'] = "Date début";
@@ -124,8 +125,8 @@
$lang['gen_hamradio_call'] = "QRZ";
$lang['gen_hamradio_callsign'] = "Indicatif";
-$lang['gen_hamradio_prefix'] = "Préfix";
-$lang['gen_hamradio_suffix'] = "Suffix";
+$lang['gen_hamradio_prefix'] = "Préfixe";
+$lang['gen_hamradio_suffix'] = "Suffixe";
$lang['gen_hamradio_de'] = "De";
$lang['gen_hamradio_dx'] = "Dx";
$lang['gen_hamradio_mode'] = "Mode";
@@ -136,8 +137,8 @@
$lang['gen_hamradio_band'] = "Bande";
$lang['gen_hamradio_bandgroup'] = "Groupe de Bandes";
$lang['gen_hamradio_band_rx'] = "Bande (RX)";
-$lang['gen_hamradio_frequency'] = "Frequence";
-$lang['gen_hamradio_frequency_rx'] = "Frequence (RX)";
+$lang['gen_hamradio_frequency'] = "Fréquence";
+$lang['gen_hamradio_frequency_rx'] = "Fréquence (RX)";
$lang['gen_hamradio_radio'] = "Radio";
$lang['gen_hamradio_rsts'] = "RST (S)";
$lang['gen_hamradio_rstr'] = "RST (R)";
@@ -150,11 +151,11 @@
$lang['gen_hamradio_qslvia'] = "QSL via";
$lang['gen_hamradio_qslmsg'] = "QSL Msg";
$lang['gen_hamradio_locator'] = "Locator";
-$lang['gen_hamradio_transmit_power'] = "Puissance Emission (W)";
-$lang['gen_hamradio_propagation_mode'] = "Mode Propagation";
+$lang['gen_hamradio_transmit_power'] = "Puissance d'émission (W)";
+$lang['gen_hamradio_propagation_mode'] = "Mode de propagation";
-$lang['gen_hamradio_satellite_name'] = "Nom du Satellite";
-$lang['gen_hamradio_satellite_mode'] = "Mode du Satellite";
+$lang['gen_hamradio_satellite_name'] = "Nom du satellite";
+$lang['gen_hamradio_satellite_mode'] = "Mode du satellite";
$lang['gen_hamradio_logbook'] = "Journal de trafic";
$lang['gen_hamradio_award'] = "Award";
@@ -166,7 +167,7 @@
$lang['gen_hamradio_deleted_dxcc'] = "DXCC Supprimé";
$lang['gen_hamradio_continent'] = "Continent";
$lang['gen_hamradio_usa_state'] = "Etat USA";
-$lang['gen_hamradio_county_reference'] = "Compté USA";
+$lang['gen_hamradio_county_reference'] = "Comté USA";
$lang['gen_hamradio_iota_reference'] = "Référence IOTA";
$lang['gen_hamradio_sota_reference'] = "Référence SOTA";
$lang['gen_hamradio_wwff_reference'] = "Référence WWFF";
diff --git a/application/language/french/qso_lang.php b/application/language/french/qso_lang.php
index 567fde91b..340e2c2fc 100644
--- a/application/language/french/qso_lang.php
+++ b/application/language/french/qso_lang.php
@@ -14,7 +14,7 @@
$lang['qso_quicklog_enter_callsign'] = 'QUICKLOG Enter Callsign';
// Input Help Text on the /QSO Display
-$lang['qso_transmit_power_helptext'] = 'Saisissez la ouissance en Watts en utilisant uniquement des chiffres.';
+$lang['qso_transmit_power_helptext'] = 'Saisissez la puissance en Watts en utilisant uniquement des chiffres.';
$lang['qso_sota_ref_helptext'] = 'Par exemple: GM/NS-001.';
$lang['qso_wwff_ref_helptext'] = 'Par exemple: DLFF-0069.';
diff --git a/application/language/french/statistics_lang.php b/application/language/french/statistics_lang.php
index 930bee8a7..bf93247ed 100644
--- a/application/language/french/statistics_lang.php
+++ b/application/language/french/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "Toutes";
+$lang['statistics_distances_modes_all'] = "Tous";
$lang['statistics_distances_worked'] = "Nombre de QSOs réalisés par plage de distance";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts utilisés pour le graphique.
Le contact le plus lointain réalisé est ";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "avec le locator";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "La distance moyenne est de";
$lang['statistics_distances_number_of_qsos'] = "Nombre de QSOs";
$lang['statistics_distances_callsigns_worked'] = "Indicatif(s) contacté(s) (liste de 5 max)";
-$lang['statistics_distances_qsos_with'] = "QSOs avec";
-$lang['statistics_distances_and_band'] = "et bandes";
+$lang['statistics_distances_qsos_with'] = "QSOs avec distance : ";
+$lang['statistics_distances_and_band'] = ", bande : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", puissance : ";
/*
*
diff --git a/application/language/german/general_words_lang.php b/application/language/german/general_words_lang.php
index 4e8d2fe54..8beae5f90 100644
--- a/application/language/german/general_words_lang.php
+++ b/application/language/german/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Nie";
+$lang['general_word_undefined'] = "Unbestimmt";
$lang['general_word_date'] = 'Datum';
$lang['general_word_startdate'] = "Start Datum";
diff --git a/application/language/german/statistics_lang.php b/application/language/german/statistics_lang.php
index aa0071b1e..2cc71c30a 100644
--- a/application/language/german/statistics_lang.php
+++ b/application/language/german/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "Alle";
+$lang['statistics_distances_modes_all'] = "Alle";
$lang['statistics_distances_worked'] = "Gearbeitete Entfernungen";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "Kontakte wurden dargestellt.
Der weiteste Kontakt war"; // make sure'
' stays there
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "im Planquadrat";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "Die durchschnittliche Distanz ist";
$lang['statistics_distances_number_of_qsos'] = "Anzahl der QSOs";
$lang['statistics_distances_callsigns_worked'] = "Gearbeitete(s) Rufzeichen (max 5 werden gezeigt)";
-$lang['statistics_distances_qsos_with'] = "QSOs mit";
-$lang['statistics_distances_and_band'] = "und Band";
+$lang['statistics_distances_qsos_with'] = "QSOs mit Distanz : ";
+$lang['statistics_distances_and_band'] = ", Band : ";
+$lang['statistics_distances_and_mode'] = ", Mode : ";
+$lang['statistics_distances_and_power'] = ", Sendeleistung : ";
/*
*
diff --git a/application/language/greek/general_words_lang.php b/application/language/greek/general_words_lang.php
index 3f1d4fd13..f166f7dd7 100644
--- a/application/language/greek/general_words_lang.php
+++ b/application/language/greek/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Ημερομηνία';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/greek/statistics_lang.php b/application/language/greek/statistics_lang.php
index a3576bf21..787f22b90 100644
--- a/application/language/greek/statistics_lang.php
+++ b/application/language/greek/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/italian/general_words_lang.php b/application/language/italian/general_words_lang.php
index baaf37008..354998d7a 100644
--- a/application/language/italian/general_words_lang.php
+++ b/application/language/italian/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Non visualizzare";
$lang['general_word_icon'] = "Icona";
$lang['general_word_never'] = "Mai";
+$lang['general_word_undefined'] = "Indefinito";
$lang['general_word_date'] = 'Data';
$lang['general_word_startdate'] = "Data di inizio";
diff --git a/application/language/italian/statistics_lang.php b/application/language/italian/statistics_lang.php
index 8c412c23a..190ce5ff8 100644
--- a/application/language/italian/statistics_lang.php
+++ b/application/language/italian/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "Tutte";
+$lang['statistics_distances_modes_all'] = "Tutte";
$lang['statistics_distances_worked'] = "Distanze percorse";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "i contatti sono stati tracciati.
Il tuo contatto più lontano era con";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "nella griglia";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "La distanza media è";
$lang['statistics_distances_number_of_qsos'] = "Numero di QSO";
$lang['statistics_distances_callsigns_worked'] = "Nominativo(i) funzionante(i max 5 mostrati)";
-$lang['statistics_distances_qsos_with'] = "QSO con";
-$lang['statistics_distances_and_band'] = "e banda";
+$lang['statistics_distances_qsos_with'] = "QSO con distanza : ";
+$lang['statistics_distances_and_band'] = ", banda : ";
+$lang['statistics_distances_and_mode'] = ", modo : ";
+$lang['statistics_distances_and_power'] = ", potenza : ";
/*
*
diff --git a/application/language/polish/general_words_lang.php b/application/language/polish/general_words_lang.php
index 494910584..88867f7fa 100644
--- a/application/language/polish/general_words_lang.php
+++ b/application/language/polish/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Data';
$lang['general_word_startdate'] = "Start Date";
diff --git a/application/language/polish/statistics_lang.php b/application/language/polish/statistics_lang.php
index a3576bf21..787f22b90 100644
--- a/application/language/polish/statistics_lang.php
+++ b/application/language/polish/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/russian/general_words_lang.php b/application/language/russian/general_words_lang.php
index f474eaa59..2ee32139f 100644
--- a/application/language/russian/general_words_lang.php
+++ b/application/language/russian/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Не отображать";
$lang['general_word_icon'] = "Иконка";
$lang['general_word_never'] = "Никогда";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Дата';
$lang['general_word_startdate'] = "Дата начала";
diff --git a/application/language/russian/statistics_lang.php b/application/language/russian/statistics_lang.php
index 127d9f178..2c6b18847 100644
--- a/application/language/russian/statistics_lang.php
+++ b/application/language/russian/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "все";
+$lang['statistics_distances_modes_all'] = "все";
$lang['statistics_distances_worked'] = "Сработанные дистанции";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "контакты отображены.
Наиболее дальний контакт с";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "в квадрате";
@@ -34,7 +35,9 @@
$lang['statistics_distances_number_of_qsos'] = "Количество QSO";
$lang['statistics_distances_callsigns_worked'] = "Сработанные позывные(ной) (максимально 5 показано)";
$lang['statistics_distances_qsos_with'] = "QSOs с";
-$lang['statistics_distances_and_band'] = "и диапазоне";
+$lang['statistics_distances_and_band'] = ", диапазоне : ";
+$lang['statistics_distances_and_mode'] = ", Вид модуляции : ";
+$lang['statistics_distances_and_power'] = ", Мощность передачи : ";
/*
*
diff --git a/application/language/spanish/general_words_lang.php b/application/language/spanish/general_words_lang.php
index 0dabe3c21..cc78f8d1c 100644
--- a/application/language/spanish/general_words_lang.php
+++ b/application/language/spanish/general_words_lang.php
@@ -26,7 +26,8 @@
$lang['general_word_filtering_on'] = "Filtrado por";
$lang['general_word_not_display'] = "No mostrar";
$lang['general_word_icon'] = "Icono";
-
+$lang['general_word_never'] = "Nunca";
+$lang['general_word_undefined'] = "Indefinido";
$lang['general_word_date'] = 'Fecha';
$lang['general_word_startdate'] = "Fecha de inicio";
diff --git a/application/language/spanish/statistics_lang.php b/application/language/spanish/statistics_lang.php
index 719734ddd..b200ebca4 100644
--- a/application/language/spanish/statistics_lang.php
+++ b/application/language/spanish/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "Todas";
+$lang['statistics_distances_modes_all'] = "Todas";
$lang['statistics_distances_worked'] = "Distancias Logradas";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contactos fueron dibujados.
Su contacto más lejano fue con";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "en gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "La distancia promedio es";
$lang['statistics_distances_number_of_qsos'] = "Número de QSOs";
$lang['statistics_distances_callsigns_worked'] = "Indicativo(s) trabajados (se muestran máximo 5)";
-$lang['statistics_distances_qsos_with'] = "QSOs con";
-$lang['statistics_distances_and_band'] = "y banda";
+$lang['statistics_distances_qsos_with'] = "QSOs con distancia : ";
+$lang['statistics_distances_and_band'] = ", banda ; ";
+$lang['statistics_distances_and_mode'] = ", modo : ";
+$lang['statistics_distances_and_power'] = ", potencia : ";
/*
*
diff --git a/application/language/swedish/general_words_lang.php b/application/language/swedish/general_words_lang.php
index af79b0810..b8201b2e9 100644
--- a/application/language/swedish/general_words_lang.php
+++ b/application/language/swedish/general_words_lang.php
@@ -17,6 +17,8 @@
$lang['general_word_previous'] = 'Previous';
$lang['general_word_not_display'] = "Not display";
$lang['general_word_icon'] = "Icon";
+$lang['general_word_never'] = "Never";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_cancel'] = "Cancel";
$lang['general_word_ok'] = "OK";
diff --git a/application/language/swedish/statistics_lang.php b/application/language/swedish/statistics_lang.php
index 66b5fc30e..1ff46a2c4 100644
--- a/application/language/swedish/statistics_lang.php
+++ b/application/language/swedish/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "All";
+$lang['statistics_distances_modes_all'] = "All";
$lang['statistics_distances_worked'] = "Distances Worked";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "contacts were plotted.
Your furthest contact was with";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "in gridsquare";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "The average distance is";
$lang['statistics_distances_number_of_qsos'] = "Number of QSOs";
$lang['statistics_distances_callsigns_worked'] = "Callsign(s) worked (max 5 shown)";
-$lang['statistics_distances_qsos_with'] = "QSOs with";
-$lang['statistics_distances_and_band'] = "and band";
+$lang['statistics_distances_qsos_with'] = "QSOs with distance : ";
+$lang['statistics_distances_and_band'] = ", band : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", power : ";
/*
*
diff --git a/application/language/turkish/general_words_lang.php b/application/language/turkish/general_words_lang.php
index 497925726..8320c2d13 100644
--- a/application/language/turkish/general_words_lang.php
+++ b/application/language/turkish/general_words_lang.php
@@ -26,6 +26,7 @@
$lang['general_word_not_display'] = "Gösterme";
$lang['general_word_icon'] = "Ikon";
$lang['general_word_never'] = "Asla";
+$lang['general_word_undefined'] = "Undefined";
$lang['general_word_date'] = 'Tarih';
$lang['general_word_startdate'] = "Başlama Tarihi";
diff --git a/application/language/turkish/statistics_lang.php b/application/language/turkish/statistics_lang.php
index 6f0681692..34558cc9e 100644
--- a/application/language/turkish/statistics_lang.php
+++ b/application/language/turkish/statistics_lang.php
@@ -26,6 +26,7 @@
*/
$lang['statistics_distances_bands_all'] = "Tüm";
+$lang['statistics_distances_modes_all'] = "Tüm";
$lang['statistics_distances_worked'] = "Çalışılan Mesafeler";
$lang['statistics_distances_part1_contacts_were_plotted_furthest'] = "kişiler planlandı.
En uzak bağlantınız şununlaydı";
$lang['statistics_distances_part2_contacts_were_plotted_furthest'] = "gridsquare'de";
@@ -33,8 +34,10 @@
$lang['statistics_distances_part4_contacts_were_plotted_furthest'] = "Ortalama mesafe";
$lang['statistics_distances_number_of_qsos'] = "QSO sayısı";
$lang['statistics_distances_callsigns_worked'] = "Çağrı işaretleri çalıştı (en fazla 5 tane gösterildi)";
-$lang['statistics_distances_qsos_with'] = "QSO'lar ile";
-$lang['statistics_distances_and_band'] = "ve bant";
+$lang['statistics_distances_qsos_with'] = "mesafeli QSO'lar ile";
+$lang['statistics_distances_and_band'] = ", bant : ";
+$lang['statistics_distances_and_mode'] = ", mode : ";
+$lang['statistics_distances_and_power'] = ", gücü : ";
/*
*
diff --git a/application/libraries/AdifHelper.php b/application/libraries/AdifHelper.php
index 3c63280da..54f381423 100644
--- a/application/libraries/AdifHelper.php
+++ b/application/libraries/AdifHelper.php
@@ -212,14 +212,36 @@ public function getAdifLine($qso, $satellite_remap = false) {
$line .= $this->getAdifFieldLine("APP_CLOUDLOG_MY_WAB", $qso->station_wab);
$line .= $this->getAdifFieldLine("MY_ITU_ZONE", $qso->station_itu);
- if($qso->state) {
+ if($qso->state) {
+ $line .= $this->getAdifFieldLine("MY_STATE", $qso->state);
+ }
+
+ if ($qso->station_cnty) {
+ switch ($qso->station_dxcc) {
+ case '291':
+ case '6':
+ case '110':
$county = trim($qso->state) . "," . trim($qso->station_cnty);
- } else {
- $county = trim($qso->station_cnty);
+ break;
+ case '54':
+ case '15':
+ case '61':
+ case '126':
+ case '151':
+ $county = trim($qso->station_cnty);
+ break;
+ default:
+ $county = trim($qso->station_cnty);
}
+ } else {
+ $county = '';
+ }
+
$line .= $this->getAdifFieldLine("MY_CNTY", $county);
+
+
$line .= $this->getAdifFieldLine("WWFF_REF", $qso->{'COL_WWFF_REF'});
$line .= $this->getAdifFieldLine("MY_WWFF_REF", $qso->station_wwff);
@@ -259,7 +281,6 @@ public function getAdifLine($qso, $satellite_remap = false) {
MY_NAME
MY_POSTAL_CODE
MY_RIG
- MY_STATE
MY_STREET
MY_USACA_COUNTIES
*/
diff --git a/application/migrations/187_MESAT1_to_MO122.php b/application/migrations/187_MESAT1_to_MO122.php
new file mode 100644
index 000000000..4908d22f3
--- /dev/null
+++ b/application/migrations/187_MESAT1_to_MO122.php
@@ -0,0 +1,28 @@
+db->set('COL_SAT_NAME', 'MESAT1');
+ $this->db->where('COL_SAT_NAME', 'MO-122');
+ $this->db->update($this->config->item('table_name'));
+
+ $this->db->set('COL_SAT_NAME', 'MESAT-1');
+ $this->db->where('COL_SAT_NAME', 'MO-122');
+ $this->db->update($this->config->item('table_name'));
+ }
+
+ public function down()
+ {
+ // Not Possible
+ }
+
+}
\ No newline at end of file
diff --git a/application/migrations/188_tag_2_6_16.php b/application/migrations/188_tag_2_6_16.php
new file mode 100644
index 000000000..02c57fc79
--- /dev/null
+++ b/application/migrations/188_tag_2_6_16.php
@@ -0,0 +1,30 @@
+db->where('option_name', 'version');
+ $this->db->update('options', array('option_value' => '2.6.16'));
+
+ // Trigger Version Info Dialog
+ $this->db->where('option_type', 'version_dialog');
+ $this->db->where('option_name', 'confirmed');
+ $this->db->update('user_options', array('option_value' => 'false'));
+
+ }
+
+ public function down()
+ {
+ $this->db->where('option_name', 'version');
+ $this->db->update('options', array('option_value' => '2.6.15'));
+ }
+}
\ No newline at end of file
diff --git a/application/models/Bands.php b/application/models/Bands.php
index d3aac99c9..4586b8d27 100644
--- a/application/models/Bands.php
+++ b/application/models/Bands.php
@@ -224,6 +224,28 @@ function get_worked_bands_dok() {
return $results;
}
+ function get_worked_powers() {
+ $CI =& get_instance();
+ $CI->load->model('logbooks_model');
+ $logbooks_locations_array = $CI->logbooks_model->list_logbook_relationships($this->session->userdata('active_station_logbook'));
+
+ if (!$logbooks_locations_array) {
+ return array();
+ }
+
+ $location_list = "'".implode("','",$logbooks_locations_array)."'";
+
+ // get all worked powers from database
+ $sql = "SELECT distinct col_tx_pwr FROM ".$this->config->item('table_name')." WHERE station_id in (" . $location_list . ") ORDER BY col_tx_pwr";
+
+ $data = $this->db->query($sql);
+
+ $worked_powers = array();
+ foreach($data->result() as $row) array_push($worked_powers, $row->col_tx_pwr);
+
+ return $worked_powers;
+ }
+
function activateall() {
$data = array(
'active' => '1',
diff --git a/application/models/Distances_model.php b/application/models/Distances_model.php
index d895a0197..e8f843362 100644
--- a/application/models/Distances_model.php
+++ b/application/models/Distances_model.php
@@ -37,6 +37,19 @@ function get_distances($postdata, $measurement_base) {
$this->db->where('col_band', $postdata['band']);
}
+ if ($postdata['mode'] != 'all') {
+ $this->db->group_start()->where('col_mode', $postdata['mode'])->or_where('col_submode', $postdata['mode'])->group_end();
+ }
+
+ if ($postdata['pwr'] != 'all') {
+ if ($postdata['pwr']) {
+ $this->db->where('col_tx_pwr', $postdata['pwr']);
+ } else {
+ $this->db->where('col_tx_pwr is NULL');
+ }
+ }
+
+
$this->db->where('station_id', $station_id);
$queryresult = $this->db->get($this->config->item('table_name'));
@@ -83,6 +96,7 @@ function mergeresult($result, $add) {
if(isset($result['qsodata'][$i]['callcount'])) {
if ($result['qsodata'][$i]['callcount'] < 5 && $add['qsodata'][$i]['callcount'] > 0) {
$calls = explode(',', $add['qsodata'][$i]['calls']);
+ $calls = array_unique($calls);
foreach ($calls as $c) {
if ($result['qsodata'][$i]['callcount'] < 5) {
if ($result['qsodata'][$i]['callcount'] > 0) {
@@ -178,19 +192,21 @@ function plot($qsoArray, $gridsquare, $measurement_base) {
$this->db->where('COL_PRIMARY_KEY', $qso['COL_PRIMARY_KEY']);
$this->db->update($this->config->item('table_name'), $data);
}
- $arrayplacement = (int)($bearingdistance / 50); // Resolution is 50, calculates where to put result in array
+ $arrayplacement = (int)($bearingdistance / 50); // Resolution is 50, calculates where to put result in array
if ($bearingdistance > $qrb['Distance']) { // Saves the longest QSO
$qrb['Distance'] = $bearingdistance;
$qrb['Callsign'] = $qso['callsign'];
$qrb['Grid'] = $qso['grid'];
}
- $dataarray[$arrayplacement]['count']++; // Used for counting total qsos plotted
+ $dataarray[$arrayplacement]['count']++; // Used for counting total qsos plotted
if ($dataarray[$arrayplacement]['callcount'] < 5) { // Used for tooltip in graph, set limit to 5 calls shown
- if ($dataarray[$arrayplacement]['callcount'] > 0) {
- $dataarray[$arrayplacement]['calls'] .= ', ';
+ if (strpos($dataarray[$arrayplacement]['calls'], $qso['callsign']) === false) { // Avoids duplicated callsigns
+ if ($dataarray[$arrayplacement]['callcount'] > 0) {
+ $dataarray[$arrayplacement]['calls'] .= ', ';
+ }
+ $dataarray[$arrayplacement]['calls'] .= $qso['callsign'];
+ $dataarray[$arrayplacement]['callcount']++;
}
- $dataarray[$arrayplacement]['calls'] .= $qso['callsign'];
- $dataarray[$arrayplacement]['callcount']++;
}
}
@@ -223,7 +239,7 @@ function valid_locator ($loc) {
/*
* Used to fetch QSOs from the logbook in the awards
*/
- public function qso_details($distance, $band, $sat){
+ public function qso_details($distance, $band, $sat, $mode, $power){
$distarray = $this->getdistparams($distance);
$CI =& get_instance();
$CI->load->model('logbooks_model');
@@ -238,8 +254,8 @@ public function qso_details($distance, $band, $sat){
$this->db->where_in($this->config->item('table_name').'.station_id', $logbooks_locations_array);
- if ($band != 'All') {
- if($band != "sat") {
+ if ($band != 'all') {
+ if ($band != "sat") {
$this->db->where('COL_PROP_MODE !=', 'SAT');
$this->db->where('COL_BAND', $band);
} else {
@@ -249,6 +265,19 @@ public function qso_details($distance, $band, $sat){
}
}
}
+
+ if ($mode != 'all') {
+ $this->db->group_start()->where('COL_MODE', $mode)->or_where('COL_SUBMODE', $mode)->group_end();
+ }
+
+ if ($power != 'all') {
+ if ($power) {
+ $this->db->where('COL_TX_PWR', $power);
+ } else {
+ $this->db->where('COL_TX_PWR is NULL');
+ }
+ }
+
$this->db->order_by("COL_TIME_ON", "desc");
return $this->db->get($this->config->item('table_name'));
diff --git a/application/models/Logbook_model.php b/application/models/Logbook_model.php
index a7057aa39..02dae33fd 100755
--- a/application/models/Logbook_model.php
+++ b/application/models/Logbook_model.php
@@ -1024,6 +1024,10 @@ function upload_amsat_status($data)
if ($data['COL_BAND'] == '70cm' && $data['COL_BAND_RX'] == '2m') {
$sat_name = 'AO-7[B]';
}
+ } else if ($data['COL_SAT_NAME'] == 'MESAT-1') {
+ $sat_name = 'MESAT1';
+ } else if ($data['COL_SAT_NAME'] == 'SONATE-2') {
+ $sat_name = 'SONATE-2 APRS';
} else if ($data['COL_SAT_NAME'] == 'QO-100') {
$sat_name = 'QO-100_NB';
} else if ($data['COL_SAT_NAME'] == 'AO-92') {
@@ -4433,30 +4437,38 @@ public function check_missing_grid_id($all)
if ($r->num_rows() > 0) {
foreach ($r->result_array() as $row) {
$callsign = $row['COL_CALL'];
- if ($this->config->item('callbook') == "qrz" && $this->config->item('qrz_username') != null && $this->config->item('qrz_password') != null) {
- // Lookup using QRZ
- if (!$this->load->is_loaded('qrz')) {
- $this->load->library('qrz');
- }
+ if ($this->session->userdata('callbook_type') == "QRZ") {
+ // Lookup using QRZ
+ $this->load->library('qrz');
- if (!$this->session->userdata('qrz_session_key')) {
- $qrz_session_key = $this->qrz->session($this->config->item('qrz_username'), $this->config->item('qrz_password'));
- $this->session->set_userdata('qrz_session_key', $qrz_session_key);
- }
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
+ if(!$this->session->userdata('qrz_session_key')) {
+ $qrz_session_key = $this->qrz->session($this->session->userdata('callbook_username'), $decrypted_password);
+ $this->session->set_userdata('qrz_session_key', $qrz_session_key);
+ }
$callbook = $this->qrz->search($callsign, $this->session->userdata('qrz_session_key'));
}
- if ($this->config->item('callbook') == "hamqth" && $this->config->item('hamqth_username') != null && $this->config->item('hamqth_password') != null) {
- // Load the HamQTH library
- if (!$this->load->is_loaded('hamqth')) {
- $this->load->library('hamqth');
- }
+ if ($this->session->userdata('callbook_type') == "HamQTH") {
+ // Load the HamQTH library
+ $this->load->library('hamqth');
- if (!$this->session->userdata('hamqth_session_key')) {
- $hamqth_session_key = $this->hamqth->session($this->config->item('hamqth_username'), $this->config->item('hamqth_password'));
- $this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
- }
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
+ if(!$this->session->userdata('hamqth_session_key')) {
+ $hamqth_session_key = $this->hamqth->session($this->session->userdata('callbook_username'), $decrypted_password);
+ $this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
+ }
$callbook = $this->hamqth->search($callsign, $this->session->userdata('hamqth_session_key'));
@@ -4568,12 +4580,18 @@ public function loadCallBook($callsign, $use_fullname = false)
{
$callbook = null;
try {
- if ($this->config->item('callbook') == "qrz" && $this->config->item('qrz_username') != null && $this->config->item('qrz_password') != null) {
+ if ($this->session->userdata('callbook_type') == "QRZ") {
// Lookup using QRZ
$this->load->library('qrz');
- if (!$this->session->userdata('qrz_session_key')) {
- $qrz_session_key = $this->qrz->session($this->config->item('qrz_username'), $this->config->item('qrz_password'));
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
+ if(!$this->session->userdata('qrz_session_key')) {
+ $qrz_session_key = $this->qrz->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('qrz_session_key', $qrz_session_key);
}
@@ -4591,12 +4609,18 @@ public function loadCallBook($callsign, $use_fullname = false)
}
}
- if ($this->config->item('callbook') == "hamqth" && $this->config->item('hamqth_username') != null && $this->config->item('hamqth_password') != null) {
+ if ($this->session->userdata('callbook_type') == "HamQTH") {
// Load the HamQTH library
$this->load->library('hamqth');
- if (!$this->session->userdata('hamqth_session_key')) {
- $hamqth_session_key = $this->hamqth->session($this->config->item('hamqth_username'), $this->config->item('hamqth_password'));
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Decrypt the password
+ $decrypted_password = $this->encryption->decrypt($this->session->userdata('callbook_password'));
+
+ if(!$this->session->userdata('hamqth_session_key')) {
+ $hamqth_session_key = $this->hamqth->session($this->session->userdata('callbook_username'), $decrypted_password);
$this->session->set_userdata('hamqth_session_key', $hamqth_session_key);
}
diff --git a/application/models/Stations.php b/application/models/Stations.php
index 39c3d7e2c..034634271 100644
--- a/application/models/Stations.php
+++ b/application/models/Stations.php
@@ -30,6 +30,8 @@ function all_of_user($userid = null) {
$this->db->select('station_profile.*, dxcc_entities.name as station_country, dxcc_entities.end as dxcc_end');
$this->db->where('user_id', $userid);
$this->db->join('dxcc_entities','station_profile.station_dxcc = dxcc_entities.adif','left outer');
+ $this->db->order_by('station_profile.station_callsign');
+ $this->db->order_by('station_profile.station_profile_name');
return $this->db->get('station_profile');
}
diff --git a/application/models/User_model.php b/application/models/User_model.php
index b25d4d0dc..3a12405bd 100644
--- a/application/models/User_model.php
+++ b/application/models/User_model.php
@@ -150,7 +150,7 @@ function add($username, $password, $email, $type, $firstname, $lastname, $callsi
$user_pota_lookup, $user_show_notes, $user_column1, $user_column2, $user_column3, $user_column4, $user_column5,
$user_show_profile_image, $user_previous_qsl_type, $user_amsat_status_upload, $user_mastodon_url,
$user_default_band, $user_default_confirmation, $user_qso_end_times, $user_quicklog, $user_quicklog_enter,
- $language, $user_hamsat_key, $user_hamsat_workable_only) {
+ $language, $user_hamsat_key, $user_hamsat_workable_only, $callbook_type, $callbook_username, $callbook_password) {
// Check that the user isn't already used
if(!$this->exists($username)) {
$data = array(
@@ -206,6 +206,19 @@ function add($username, $password, $email, $type, $firstname, $lastname, $callsi
$this->db->query("insert into paper_types (user_id,paper_name,metric,width,orientation,height) SELECT ".$insert_id.", paper_name, metric, width, orientation,height FROM paper_types where user_id = -1;");
$this->db->query("insert into user_options (user_id, option_type, option_name, option_key, option_value) values (" . $insert_id . ", 'hamsat','hamsat_key','api','".xss_clean($user_hamsat_key)."');");
$this->db->query("insert into user_options (user_id, option_type, option_name, option_key, option_value) values (" . $insert_id . ", 'hamsat','hamsat_key','workable','".xss_clean($user_hamsat_workable_only)."');");
+
+ $this->db->query("insert into user_options (user_id, option_type, option_name, option_key, option_value) values (" . $insert_id . ", 'callbook','callbook_type','value','".xss_clean($callbook_type)."');");
+ $this->db->query("insert into user_options (user_id, option_type, option_name, option_key, option_value) values (" . $insert_id . ", 'callbook','callbook_username','value','".xss_clean($callbook_username)."');");
+
+ // Load the encryption library
+ $this->load->library('encryption');
+
+ // Encrypt the password
+ $encrypted_password = $this->encryption->encrypt($callbook_password);
+
+ // Insert the encrypted password into the database
+ $this->db->query("INSERT INTO user_options (user_id, option_type, option_name, option_key, option_value) VALUES (" . $insert_id . ", 'callbook', 'callbook_password', 'value', '" . xss_clean($encrypted_password) . "');");
+
return OK;
} else {
return EUSERNAMEEXISTS;
@@ -348,6 +361,31 @@ function clear_session() {
// TODO: This should return bool TRUE/FALSE or 0/1
function update_session($id) {
+ $CI =& get_instance();
+ $CI->load->model('user_options_model');
+ $callbook_type_object = $CI->user_options_model->get_options('callbook')->result();
+
+ // Get the callbook type
+ if (isset($callbook_type_object[1]->option_value)) {
+ $callbook_type = $callbook_type_object[1]->option_value;
+ } else {
+ $callbook_type = "None";
+ }
+
+ // Get the callbook type
+ if (isset($callbook_type_object[2]->option_value)) {
+ $callbook_username = $callbook_type_object[2]->option_value;
+ } else {
+ $callbook_username = "";
+ }
+
+ // Get the callbook type
+ if (isset($callbook_type_object[0]->option_value)) {
+ $callbook_password = $callbook_type_object[0]->option_value;
+ } else {
+ $callbook_password = "";
+ }
+
$u = $this->get_by_id($id);
$userdata = array(
@@ -388,7 +426,10 @@ function update_session($id) {
'active_station_logbook' => $u->row()->active_station_logbook,
'language' => isset($u->row()->language) ? $u->row()->language: 'english',
'isWinkeyEnabled' => $u->row()->winkey,
- 'hasQrzKey' => $this->hasQrzKey($u->row()->user_id)
+ 'hasQrzKey' => $this->hasQrzKey($u->row()->user_id),
+ 'callbook_type' => $callbook_type,
+ 'callbook_username' => $callbook_username,
+ 'callbook_password' => $callbook_password,
);
$this->session->set_userdata($userdata);
diff --git a/application/views/distances/index.php b/application/views/distances/index.php
index 3313c6498..f0d6972e0 100644
--- a/application/views/distances/index.php
+++ b/application/views/distances/index.php
@@ -17,7 +17,7 @@
Sorry, but we didn't find any past QSOs with
- -Sorry, but we didn't find any past QSOs with
+ + + + +