load->helper(array('form', 'url')); $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() { $this->load->model('stations'); $this->load->model('Logbook_model'); $this->load->model('user_model'); $data['is_admin'] = ($this->user_model->authorize(99)); $data['stations'] = $this->stations->all_with_count(); $data['current_active'] = $this->stations->find_active(); $data['is_there_qsos_with_no_station_id'] = $this->Logbook_model->check_for_station_id(); // Render Page $data['page_title'] = lang('station_location'); $this->load->view('interface_assets/header', $data); $this->load->view('station_profile/index'); $this->load->view('interface_assets/footer'); } public function create() { $this->load->model('stations'); $this->load->model('dxcc'); $data['dxcc_list'] = $this->dxcc->list(); $this->load->model('logbook_model'); $data['iota_list'] = $this->logbook_model->fetchIota(); $this->load->library('form_validation'); $this->form_validation->set_rules('station_profile_name', 'Station Profile Name', 'required'); if ($this->form_validation->run() == FALSE) { $data['page_title'] = lang('station_location_create_header'); $this->load->view('interface_assets/header', $data); $this->load->view('station_profile/create'); $this->load->view('interface_assets/footer'); } else { if (($station_id = $this->stations->add()) !== false) { // [eQSL default msg] ADD to user options (option_type='eqsl_default_qslmsg'; option_name='key_station_id'; option_key=station_id; option_value=value) // $eqsl_default_qslmsg = xss_clean($this->input->post('eqsl_default_qslmsg', true)); if (!empty(trim($eqsl_default_qslmsg))) { $this->load->model('user_options_model'); $this->user_options_model->set_option('eqsl_default_qslmsg','key_station_id',array($station_id=>$eqsl_default_qslmsg)); } } redirect('station'); } } public function edit($id) { $this->load->model('stations'); if ($this->stations->check_station_is_accessible($id)) { $data = $this->load_station_for_editing($id); $data['page_title'] = lang('station_location_edit') . $data['my_station_profile']->station_profile_name; if ($this->form_validation->run() == FALSE) { // [eQSL default msg] GET from user options (option_type='eqsl_default_qslmsg'; option_name='key_station_id'; option_key=station_id) // $this->load->model('user_options_model'); $options_object = $this->user_options_model->get_options('eqsl_default_qslmsg',array('option_name'=>'key_station_id','option_key'=>$id))->result(); $data['eqsl_default_qslmsg'] = (isset($options_object[0]->option_value))?$options_object[0]->option_value:''; $this->load->view('interface_assets/header', $data); $this->load->view('station_profile/edit'); $this->load->view('interface_assets/footer'); } else { if ($this->stations->edit() !== false) { // [eQSL default msg] ADD to user options (option_type='eqsl_default_qslmsg'; option_name='key_station_id'; option_key=station_id; option_value=value) // $eqsl_default_qslmsg = xss_clean($this->input->post('eqsl_default_qslmsg', true)); $this->load->model('user_options_model'); if (!empty(trim($eqsl_default_qslmsg))) { $this->user_options_model->set_option('eqsl_default_qslmsg','key_station_id',array($id=>$eqsl_default_qslmsg)); } else { $this->user_options_model->del_option('eqsl_default_qslmsg','key_station_id',array('option_key'=>$id)); } } $data['notice'] = lang('station_location') . $this->security->xss_clean($this->input->post('station_profile_name', true)) . " Updated"; redirect('station'); } } else { redirect('station'); } } public function copy($id) { $this->load->model('stations'); if ($this->stations->check_station_is_accessible($id)) { $data = $this->load_station_for_editing($id); $data['page_title'] = "Duplicate Station Location: {$data['my_station_profile']->station_profile_name}"; // we NULLify station_id and station_profile_name to make sure we are creating a new station $data['copy_from'] = $data['my_station_profile']->station_id; $data['my_station_profile']->station_id = NULL; $data['my_station_profile']->station_profile_name = ''; if ($this->form_validation->run() == FALSE) { $this->load->view('interface_assets/header', $data); $this->load->view('station_profile/edit'); $this->load->view('interface_assets/footer'); } else { $this->stations->add(); redirect('station'); } } else { redirect('station'); } } function load_station_for_editing($id): array { $this->load->library('form_validation'); $this->load->model('stations'); $this->load->model('dxcc'); $this->load->model('logbook_model'); $data['iota_list'] = $this->logbook_model->fetchIota(); $item_id_clean = $this->security->xss_clean($id); $station_profile_query = $this->stations->profile($item_id_clean); $data['my_station_profile'] = $station_profile_query->row(); $data['dxcc_list'] = $this->dxcc->list(); $this->form_validation->set_rules('station_profile_name', 'Station Profile Name', 'required'); return $data; } // This function allows a user to claim ownership of a station location function claim_user($id) { // $id is the profile id $this->load->model('stations'); $this->stations->claim_user($id); redirect('station'); } function reassign_profile($id) { // $id is the profile that needs reassigned to QSOs $this->load->model('stations'); $this->stations->reassign($id); //$this->stations->logbook_session_data(); redirect('station'); } function set_active($current, $new) { $this->load->model('stations'); $this->stations->set_active($current, $new); //$this->stations->logbook_session_data(); redirect('station'); } public function delete($id) { $this->load->model('stations'); if ($this->stations->check_station_is_accessible($id)) { $this->stations->delete($id); // [eQSL default msg] DELETE user options // $this->load->model('user_options_model'); $this->user_options_model->del_option('eqsl_default_qslmsg','key_station_id',array('option_key'=>$id)); } redirect('station'); } public function deletelog($id) { $this->load->model('stations'); if ($this->stations->check_station_is_accessible($id)) { $this->stations->deletelog($id); } redirect('station'); } /* * Function is used for autocompletion of Counties in the station profile form */ public function get_county() { $json = []; if(!empty($this->input->get("query"))) { $query = isset($_GET['query']) ? $_GET['query'] : FALSE; $county = $this->input->get("state"); $file = 'assets/json/US_counties.csv'; if (is_readable($file)) { $lines = file($file, FILE_IGNORE_NEW_LINES); $input = preg_quote($county, '~'); $reg = '~^'. $input .'(.*)$~'; $result = preg_grep($reg, $lines); $json = []; $i = 0; foreach ($result as &$value) { $county = explode(',', $value); // Limit to 300 as to not slowdown browser too much if (count($json) <= 300) { $json[] = ["name"=>$county[1]]; } } } } header('Content-Type: application/json'); echo json_encode($json); } // [eQSL default msg] Function return options from this station (but can be general use) // public function get_options() { $return_json = array(); $option_type = $this->input->post('option_type'); $option_name = $this->input->post('option_name'); $option_key = $this->input->post('option_key'); if (!empty($option_type) && !empty($option_name) && ($option_key>0)) { $this->load->model('user_options_model'); $options_object = $this->user_options_model->get_options($option_type,array('option_name'=>$option_name,'option_key'=>$option_key))->result(); $return_json[$option_type] = (isset($options_object[0]->option_value))?$options_object[0]->option_value:''; } header('Content-Type: application/json'); echo json_encode($return_json); } }