Пример #1
0
 protected function _set_field_filter($cond)
 {
     if (isset($cond['read']) && isset($this->id)) {
         $cond['update_timestamp'] = get_timestamp();
     }
     return $cond;
 }
Пример #2
0
 /**
  * store nu usefullinks
  * returns the id
  */
 public function save($type = 1)
 {
     $data = array('title' => $this->input->post('title'), 'title_np' => $this->input->post('title_np'), 'link' => $this->input->post('link'), 'description' => $this->input->post('description'), 'description_np' => $this->input->post('description_np'), 'created_by' => $this->ion_auth->get_user()->id, 'date_created' => get_timestamp(), 'date_published' => $this->input->post('date_published'), 'date_removed' => $this->input->post('date_removed'), 'active' => $this->input->post('active'), 'homepage' => $this->input->post('homepage'));
     /*
     echo '<pre>';
     print_r($data);
     print_r($_POST);
     echo '</pre>';
     */
     //print_r( $this->ion_auth->get_user()->id);
     //update existing usefullinks
     if (strlen($this->input->post('id')) > 0) {
         $data['id'] = $this->input->post('id');
         return $this->update($data);
         //insert new usefullinks
     } else {
         //echo '<pre>';
         //print_r($data);
         //echo '</pre>';
         if (!$this->db->insert($this->table, $data)) {
             return $this->db->_error_message();
         }
         return $this->db->insert_id();
     }
 }
Пример #3
0
    /** Inserts a log entry
     * 
     * @param string $str_LogLevel
     * @param string $str_Message
     * @param string $str_UserNick
     * @param string $str_Hostname
     * @return boolean
     */
    public function log($str_LogLevel, $str_Message, $str_UserNick = NULL, $str_Hostname = 'localhost')
    {
        // Check if proposed log level is acceptable, otherwise log entry is refused
        if (in_array($str_LogLevel, $this->logLevelsList) && array_search($str_LogLevel, $this->logLevelsList) <= array_search($this->logLevel, $this->logLevelsList)) {
            $str_Timestamp = get_timestamp();
            $arr_InsertValues = array(array($str_Timestamp => 's'), array($str_LogLevel => 's'), array($str_Hostname => 's'), array($str_UserNick => 's'), array($this->entity => 's'), array($this->module => 's'), array($str_Message => 's'));
            $str_LogPrepared = 'insert into ' . $this->logTableName . ' (
					logTimestamp,
					logLevel,
					hostname,
					userNick,
					entity,
					module,
					message
			) values (
					?,
					?,
					?,
					?,
					?,
					?,
					?
			)';
            $this->dbHandler->beginTransaction();
            $this->dbHandler->executePrepared($str_LogPrepared, $arr_InsertValues);
            $this->dbHandler->commit();
            return TRUE;
        } else {
            return FALSE;
        }
    }
Пример #4
0
 public function add($user, $file, $action = null)
 {
     $entry = get_timestamp() . " | " . basename($file) . " | " . $user . " | " . $action . "\n";
     $f = fopen($this->log_file, 'a');
     fwrite($f, $entry);
     fclose($f);
 }
Пример #5
0
function get_favicon($url)
{
    if (!$url || !is_url($url)) {
        return false;
    }
    if (!isset($_GET['refresh']) && UNIX_TIME <= get_timestamp($url) + FAVICON_CACHE_TTL) {
        $cache = get_url_filename($url);
        return file_get_contents($cache);
    } else {
        return update_cache($url);
    }
}
Пример #6
0
function process_form()
{
    global $vars, $phpcdb, $phpc_cal, $phpcid, $phpc_script;
    if (!isset($vars['eid']) && !isset($vars['oid'])) {
        soft_error(__("Cannot create occurrence."));
    }
    $start_ts = get_timestamp("start");
    $end_ts = get_timestamp("end");
    switch ($vars["time-type"]) {
        case 'normal':
            $time_type = 0;
            break;
        case 'full':
            $time_type = 1;
            break;
        case 'tba':
            $time_type = 2;
            break;
        default:
            soft_error(__("Unrecognized Time Type."));
    }
    $duration = $end_ts - $start_ts;
    if ($duration < 0) {
        soft_error(__("An event cannot have an end earlier than its start."));
    }
    verify_token();
    if (!$phpc_cal->can_write()) {
        permission_error(__('You do not have permission to write to this calendar.'));
    }
    if (!isset($vars['oid'])) {
        $modify = false;
        if (!isset($vars["eid"])) {
            soft_error(__("EID not set."));
        }
        $oid = $phpcdb->create_occurrence($vars["eid"], $time_type, $start_ts, $end_ts);
    } else {
        $modify = true;
        $oid = $vars["oid"];
        $phpcdb->modify_occurrence($oid, $time_type, $start_ts, $end_ts);
    }
    if ($oid != 0) {
        if ($modify) {
            $message = __("Modified occurence: ");
        } else {
            $message = __("Created occurence: ");
        }
        return message_redirect(tag('', $message, create_event_link($oid, 'display_event', $oid)), "{$phpc_script}?action=display_event&phpcid={$phpcid}&oid={$oid}");
    } else {
        return message_redirect(__('Error submitting occurrence.'), "{$phpc_script}?action=display_month&phpcid={$phpcid}");
    }
}
Пример #7
0
function search_results()
{
    global $vars, $phpcdb, $phpcid, $sort_options, $order_options;
    $searchstring = $vars['searchstring'];
    if (!empty($vars['search-from-date']) && strlen($vars['search-from-date']) > 0) {
        $start = get_timestamp('search-from');
    } else {
        $start = false;
    }
    if (!empty($vars['search-to-date']) && strlen($vars['search-to-date']) > 0) {
        $end = get_timestamp('search-to');
    } else {
        $end = false;
    }
    // make sure sort is valid
    $sort = htmlentities($vars['sort']);
    if (array_search($sort, array_keys($sort_options)) === false) {
        soft_error(__('Invalid sort option') . ": {$sort}");
    }
    // make sure order is valid
    $order = htmlentities($vars['order']);
    if (array_search($order, array_keys($order_options)) === false) {
        soft_error(__('Invalid order option') . ": {$order}");
    }
    $keywords = explode(" ", $searchstring);
    $results = $phpcdb->search($phpcid, $keywords, $start, $end, $sort, $order);
    $tags = array();
    foreach ($results as $event) {
        if (!$event->can_read()) {
            continue;
        }
        $name = $event->get_author();
        $subject = $event->get_subject();
        $desc = $event->get_desc();
        $date = $event->get_date_string();
        $time = $event->get_time_string();
        $eid = $event->get_eid();
        $tags[] = tag('tr', tag('td', tag('strong', create_event_link($subject, 'display_event', $eid))), tag('td', "{$date} {$time}"), tag('td', $desc));
    }
    if (sizeof($tags) == 0) {
        $html = tag('div', tag('strong', __('No events matched your search criteria.')));
    } else {
        $html = tag('table', attributes('class="phpc-main"'), tag('caption', __('Search Results')), tag('thead', tag('tr', tag('th', __('Subject')), tag('th', __('Date Time')), tag('th', __('Description')))));
        foreach ($tags as $tag) {
            $html->add($tag);
        }
    }
    return $html;
}
Пример #8
0
 /**
  * save nu poll
  */
 public function save()
 {
     $data = array('question' => $this->input->post('question'), 'question_np' => $this->input->post('question_np'), 'option1' => $this->input->post('option1'), 'option2' => $this->input->post('option2'), 'option3' => $this->input->post('option3'), 'option4' => $this->input->post('option4'), 'option1_np' => $this->input->post('option1_np'), 'option2_np' => $this->input->post('option2_np'), 'option3_np' => $this->input->post('option3_np'), 'option4_np' => $this->input->post('option4_np'), 'active' => $this->input->post('publish'));
     //store new poll
     if ($this->input->post('id') == null) {
         $data['created_by'] = $this->ion_auth->get_user()->id;
         $data['date_created'] = get_timestamp();
         $this->poll_library->new_poll($data);
         //update existing poll
     } else {
         $data['id'] = $this->input->post('id');
         $this->poll_library->update_poll($data);
     }
     redirect('admin/poll');
 }
Пример #9
0
 public function done_upload($category = '')
 {
     if ($this->file_name) {
         $dest = $this->system_upload_path . '/' . $category . '/';
         if (!file_exists($dest)) {
             mkdir($dest, 0755, true);
         }
         $path = $this->upload_path . $this->file_name;
         $name = md5(get_timestamp() . $this->file_name);
         $path_parts = pathinfo($path);
         $name .= '.' . $path_parts['extension'];
         rename($path, $dest . $name);
         $this->site_path = $dest . $name;
         $this->relative_path = $category . '/' . $name;
         return true;
     }
     return false;
 }
Пример #10
0
 /**
  * slider form
  */
 public function upload()
 {
     if ($this->input->post('upload')) {
         //upload the file
         $result = $this->slider_model->upload('slider');
         $result['status'] = 'image uploaded';
         //get uploaded file's info.
         $this->data = array_merge($this->data, array('result' => $result));
         redirect('admin/slider');
     }
     //generate username, current date if creating nu slider [not editing]
     $this->data['date_created'] = get_timestamp();
     $this->session->set_userdata('date_created', $this->data['date_created']);
     $this->data['created_by'] = $this->ion_auth->get_user()->username;
     //display
     $this->load->view('templates/admin_header');
     $this->load->view('admin/index.php');
     $this->load->view('admin/upload_slider.php', $this->data);
     $this->load->view('templates/admin_footer');
 }
Пример #11
0
function datediff($interval, $date1, $date2)
{
    return datediff_timestamp($interval, get_timestamp($date1), get_timestamp($date2));
}
Пример #12
0
 /**
  * organizations form
  */
 public function create()
 {
     $title_dropdown = $this->organizations_model->get(null, null, null, true);
     if (count($title_dropdown)) {
         $this->data['title_dropdown'] = '';
         $this->data['title_dropdown'] .= '<option></option>';
         foreach ($title_dropdown as $key => $val) {
             $this->data['title_dropdown'] .= '<option>' . $val->title . '</option>';
         }
     }
     //generate username, current date if creating nu acts [not editing]
     if (!isset($this->data['date_created'])) {
         $this->data['date_created'] = get_timestamp();
         $this->session->set_userdata('date_created', $this->data['date_created']);
     }
     if (!isset($this->data['created_by'])) {
         $this->data['created_by'] = $this->ion_auth->get_user()->username;
     } else {
         //get the username of the person who created the acts
         //			$this->data['created_by'] = $this->ion_auth->get_user($this->data['created_by'])->username;
     }
     //print_r($this->data[0]);
     //array_push($this->data,$this->data[0]);
     //array_push($this->data,(array)$this->data[0]);
     //array_merge($this->data[0],$this->data);
     //echo '<pre>';
     //print_r($this->data);
     //echo '</pre>';
     //display
     $this->load->view('templates/admin_header');
     $this->load->view('admin/index.php');
     $this->load->view('admin/create_organizations.php', $this->data);
     $this->load->view('templates/admin_footer');
 }
Пример #13
0
 /**
  * networks form
  */
 public function create()
 {
     //print_r($this->data);
     //generate username, current date if creating nu networks [not editing]
     if (!isset($this->data['date_created'])) {
         $this->data['date_created'] = get_timestamp();
         $this->session->set_userdata('date_created', $this->data['date_created']);
     }
     if (!isset($this->data['created_by'])) {
         $this->data['created_by'] = $this->ion_auth->get_user()->username;
         //		}else{
         //
         //			//get the username of the person who created the networks
         //			$this->data['created_by'] = $this->ion_auth->get_user($this->data['created_by'])->username;
     }
     //print_r($this->data[0]);
     //array_push($this->data,$this->data[0]);
     //array_push($this->data,(array)$this->data[0]);
     //array_merge($this->data[0],$this->data);
     //echo '<pre>';
     //print_r($this->data);
     //echo '</pre>';
     //display
     $this->load->view('templates/admin_header');
     $this->load->view('admin/index.php');
     $this->load->view('admin/create_networks.php', $this->data);
     $this->load->view('templates/admin_footer');
 }
Пример #14
0
function process_form()
{
    global $vars, $phpcdb, $phpc_cal, $phpcid, $phpc_script, $phpc_user;
    // When modifying events, this is the value of the checkbox that
    //   determines if the date should change
    $modify_occur = !isset($vars['eid']) || !empty($vars['phpc-modify']);
    if ($modify_occur) {
        $start_ts = get_timestamp("start");
        $end_ts = get_timestamp("end");
        switch ($vars["time-type"]) {
            case 'normal':
                $time_type = 0;
                break;
            case 'full':
                $time_type = 1;
                break;
            case 'tba':
                $time_type = 2;
                break;
            default:
                soft_error(__("Unrecognized Time Type."));
        }
        $duration = $end_ts - $start_ts;
        if ($duration < 0) {
            message(__("An event cannot have an end earlier than its start."));
            return display_form();
        }
    }
    verify_token();
    if (0) {
        permission_error(__('You do not have permission to write to this calendar.'));
    }
    if ($phpc_cal->can_create_readonly() && !empty($vars['readonly'])) {
        $readonly = true;
    } else {
        $readonly = false;
    }
    $catid = empty($vars['catid']) ? false : $vars['catid'];
    if (!isset($vars['eid'])) {
        $modify = false;
        $eid = $phpcdb->create_event($phpcid, $phpc_user->get_uid(), $vars["subject"], $vars["description"], $readonly, $catid);
    } else {
        $modify = true;
        $eid = $vars['eid'];
        $phpcdb->modify_event($eid, $vars['subject'], $vars['description'], $readonly, $catid);
        if ($modify_occur) {
            $phpcdb->delete_occurrences($eid);
        }
    }
    if ($modify_occur) {
        $oid = $phpcdb->create_occurrence($eid, $time_type, $start_ts, $end_ts);
        $occurrences = 1;
        switch ($vars["repeats"]) {
            case "never":
                break;
            case 'daily':
                if (!isset($vars["every-day"])) {
                    soft_error(__("Required field \"every-day\" is not set."));
                }
                $ndays = $vars["every-day"];
                if ($ndays < 1) {
                    soft_error(__("every-day must be greater than 1"));
                }
                $daily_until = get_timestamp("daily-until");
                while ($occurrences <= 730) {
                    $start_ts = add_days($start_ts, $ndays);
                    $end_ts = add_days($end_ts, $ndays);
                    if (days_between($start_ts, $daily_until) < 0) {
                        break;
                    }
                    $phpcdb->create_occurrence($eid, $time_type, $start_ts, $end_ts);
                    $occurrences++;
                }
                break;
            case 'weekly':
                if (!isset($vars["every-week"])) {
                    soft_error(__("Required field \"every-week\" is not set."));
                }
                if ($vars["every-week"] < 1) {
                    soft_error(__("every-week must be greater than 1"));
                }
                $ndays = $vars["every-week"] * 7;
                $weekly_until = get_timestamp("weekly-until");
                while ($occurrences <= 730) {
                    $start_ts = add_days($start_ts, $ndays);
                    $end_ts = add_days($end_ts, $ndays);
                    if (days_between($start_ts, $weekly_until) < 0) {
                        break;
                    }
                    $phpcdb->create_occurrence($eid, $time_type, $start_ts, $end_ts);
                    $occurrences++;
                }
                break;
            case 'monthly':
                if (!isset($vars["every-month"])) {
                    soft_error(__("Required field \"every-month\" is not set."));
                }
                if ($vars["every-month"] < 1) {
                    soft_error(__("every-month must be greater than 1"));
                }
                $nmonths = $vars["every-month"];
                $monthly_until = get_timestamp("monthly-until");
                while ($occurrences <= 730) {
                    $start_ts = add_months($start_ts, $nmonths);
                    $end_ts = add_months($end_ts, $nmonths);
                    if (days_between($start_ts, $monthly_until) < 0) {
                        break;
                    }
                    $phpcdb->create_occurrence($eid, $time_type, $start_ts, $end_ts);
                    $occurrences++;
                }
                break;
            case 'yearly':
                if (!isset($vars["every-year"])) {
                    soft_error(__("Required field \"every-year\" is not set."));
                }
                if ($vars["every-year"] < 1) {
                    soft_error(__("every-month must be greater than 1"));
                }
                $nyears = $vars["every-year"];
                $yearly_until = get_timestamp("yearly-until");
                while ($occurrences <= 730) {
                    $start_ts = add_years($start_ts, $nyears);
                    $end_ts = add_years($end_ts, $nyears);
                    if (days_between($start_ts, $yearly_until) < 0) {
                        break;
                    }
                    $phpcdb->create_occurrence($eid, $time_type, $start_ts, $end_ts);
                    $occurrences++;
                }
                break;
            default:
                soft_error(__("Invalid event type."));
        }
    }
    if ($eid != 0) {
        if ($modify) {
            $message = __("Modified event: ");
        } else {
            $message = __("Created event: ");
        }
        /* before
        return message_redirect(tag($eid, $message,
        					create_event_link('', 'display_event',
        						$eid)), */
        return message_redirect(tag('', $message, create_event_link('', 'display_event', '')), "{$phpc_script}?action=display_event&phpcid={$phpcid}&oid={$oid}");
        /* <-- before last paremeter was &eid=$eid instead of &oid=$oid */
    } else {
        return message_redirect(__('Error submitting event.'), "{$phpc_script}?action=display_month&phpcid={$phpcid}");
    }
}
Пример #15
0
 /**
  * pages form
  */
 public function create()
 {
     //generate WYSIWYG editor
     $this->_ckeditor_conf();
     $this->data['generated_editor'] = display_ckeditor($this->data['ckeditor']);
     $this->data['generated_editor2'] = display_ckeditor($this->data['ckeditor2']);
     //generate username, current date if creating nu pages [not editing]
     if (!isset($this->data['date_created'])) {
         $this->data['date_created'] = get_timestamp();
         $this->session->set_userdata('date_created', $this->data['date_created']);
     }
     if (!isset($this->data['created_by'])) {
         $this->data['created_by'] = $this->ion_auth->get_user()->username;
     } else {
         //get the username of the person who created the pages
         //			$this->data['created_by'] = $this->ion_auth->get_user($this->data['created_by'])->username;
     }
     if (!isset($this->data['output'])) {
         $this->data = array_merge($this->data, array('output' => '', 'js_files' => array(), 'css_files' => array()));
     }
     //array_push($this->data,$this->data[0]);
     //array_push($this->data,(array)$this->data[0]);
     //array_merge($this->data[0],$this->data);
     //echo '<pre>';
     //print_r($this->data);
     //echo '</pre>';
     //display
     $this->load->view('templates/admin_header');
     $this->load->view('admin/index.php');
     $this->load->view('admin/create_pages.php', $this->data);
     $this->load->view('templates/admin_footer');
 }
Пример #16
0
 /**
  * store vote count
  *
  * @param int user_id
  * @param int poll_id
  * @param int answer_id
  * @returns boolean
  */
 public function vote($user_id, $answer_id)
 {
     //get the id of the active poll
     $poll = $this->ci->db->get($this->table, array('active', 1))->result();
     //store user id & timestamp for historical purposes
     $this->ci->db->insert($this->history, array('question_id' => $poll[0]->id, 'user_id' => $user_id, 'date_submitted' => get_timestamp()));
     $data = array('count_option' . $answer_id => 'count_option' . $answer_id + 1);
     $this->ci->db->where('id', $poll[0]->id);
     $this->ci->db->update($this->table, $data);
     return true;
 }
Пример #17
0
function save_departure_details()
{
    static $external_data = false;
    global $post;
    if (empty($external_data)) {
        $external_data = array('departure_blogtrip_hashtag' => 'departure_blogtrip_hashtag', 'departure_destination' => 'departure_destination', 'departure_impression' => 'departure_impression', 'departure_date_start' => 'departure_date_start', 'departure_date_end' => 'departure_date_end', 'departure_people_reach' => 'departure_people_reach', 'departure_tweets_count' => 'departure_tweets_count');
    }
    $external_data_hidden = array('departure_destination' => array('_g_lat' => '1', '_g_long' => '2'), 'departure_blogtrip_hashtag' => array('departure_tweets_cache_data' => '', '_departure_tweet_since_id' => 0));
    $hidden_fields = array('_departure_tweet_image_cache' => '');
    if (is_object($post) && 'departures' == $post->post_type) {
        //
        global $wp_taxonomies;
        register_taxonomy_for_object_type("content_type", "departures");
        $terms = get_terms("content_type", array("hide_empty" => false, "slug" => "departures"));
        wp_set_post_terms($post->ID, $terms[0]->term_id, 'content_type', false);
        if (isset($_POST['dd_y']) && isset($_POST['dd_m']) && isset($_POST['dd_d'])) {
            $_POST['departure_date_start'] = get_timestamp($_POST['dd_y'], $_POST['dd_m'], $_POST['dd_d']);
            unset($_POST['dd_y'], $_POST['dd_m'], $_POST['dd_d']);
        }
        if (isset($_POST['rd_y']) && isset($_POST['rd_m']) && isset($_POST['rd_d'])) {
            $_POST['departure_date_end'] = get_timestamp($_POST['rd_y'], $_POST['rd_m'], $_POST['rd_d']);
            unset($_POST['rd_y'], $_POST['rd_m'], $_POST['rd_d']);
        }
        foreach ($external_data as $metadata => $postkey) {
            $metadata_post = get_post_meta($post->ID, $metadata);
            if (isset($_POST[$postkey])) {
                if (empty($metadata_post)) {
                    // create
                    add_post_meta($post->ID, $metadata, $_POST[$postkey]);
                    if (isset($external_data_hidden[$postkey])) {
                        if ('departure_destination' == $postkey) {
                            // get geocodes: lat and long
                            list($external_data_hidden[$postkey]['_g_lat'], $external_data_hidden[$postkey]['_g_long']) = departure_gmap_geocode($_POST[$postkey]);
                        }
                        // update hidden data
                        foreach ($external_data_hidden[$postkey] as $hiddenkey => $hiddenvalue) {
                            $metadata_post = get_post_meta($post->ID, $hiddenkey);
                            if (empty($metadata_post)) {
                                // create
                                add_post_meta($post->ID, $hiddenkey, $hiddenvalue);
                            } else {
                                // unset
                                update_post_meta($post->ID, $hiddenkey, $hiddenvalue);
                            }
                        }
                    }
                } else {
                    if ($metadata_post != $_POST[$postkey]) {
                        // update
                        update_post_meta($post->ID, $metadata, $_POST[$postkey]);
                        if (isset($external_data_hidden[$postkey])) {
                            if ('departure_destination' == $postkey) {
                                // get geocodes: lat and long
                                list($external_data_hidden[$postkey]['_g_lat'], $external_data_hidden[$postkey]['_g_long']) = departure_gmap_geocode($_POST[$postkey]);
                            }
                            // update hidden data
                            foreach ($external_data_hidden[$postkey] as $hiddenkey => $hiddenvalue) {
                                $metadata_post = get_post_meta($post->ID, $hiddenkey);
                                if (empty($metadata_post)) {
                                    // create
                                    add_post_meta($post->ID, $hiddenkey, $hiddenvalue);
                                } else {
                                    // unset
                                    update_post_meta($post->ID, $hiddenkey, $hiddenvalue);
                                }
                            }
                        }
                    }
                }
            }
        }
        // add hiddens values
        foreach ($hidden_fields as $hiddens => $default) {
            $metadata_hiddens = get_post_meta($post->ID, $hiddens);
            if (empty($metadata_hiddens) && $metadata_hiddens != $default) {
                add_post_meta($post->ID, $hiddens, $default);
            }
        }
    }
}
Пример #18
0
//functions from Cosm
include 'PachubeAPI.php';
//self-defined functions to get the values
include 'cosm_id_und_werte_f.php';
$pachube = new PachubeAPI("QgvMiPLj6wDkY3k2JSPpD3-rMAuSAKxLbVlLMVhxTURMOD0g");
//$alle contains all meta-information about all feeds with the tag 'munster' (ID,Title, see http://cosm.com/docs/v2/feed/list.html for further information) .
$alle = $pachube->getFeedsList("json", 0, 100000, "summary", "munster", "munster");
//array: contains all IDs with the tag 'munster'.
$ids = get_ids($alle);
//echo count($ids);
//array: contains the values for every ID in JSON format.
$json = get_json($ids);
//The following two arrays contain the coordinates. The values below are self-explaining.
$lat = get_lat($json);
$lon = get_lon($json);
$timestamp = get_timestamp($json);
$NO2 = get_NO2($json);
$CO = get_CO($json);
$O3 = get_O3($json);
$names = get_Name($json);
/*
for($i=0;$i<count($ids);$i++){
echo $ids[$i]."</br>";
echo $temperature[$i]."T"."</br>";
echo $humidity[$i]."H"."</br>";
}
for($i=0;$i<count($ids);$i++){
echo $ids[$i]."</br>";
echo $temperature[$i]."T"."</br>";
echo $humidity[$i]."H"."</br>";
}
Пример #19
0
 protected function _pre_update($data)
 {
     //檢查權限
     $this->auth->is_admin();
     if (count($data) == 0) {
         return $data;
     }
     //檢查note_index,加入斷詞
     if (isset($data['note']) && isset($this->modified_fields['note']) && $this->modified_fields['note'] == TRUE) {
         // 2010.11.5 因為斷詞器即時運作會影響效能,所以先關掉
         // 未來改用非同步的方式來斷詞吧
         /*
                     if (is_null($data['note']) == FALSE)
                     {
            $this->_load_segmentor();
            $note = $data['note'];
            //$note = urlencode($note);
            //$note = strip_tags($note);
            //$note = addslashes($note);
            //$note = trim($note);
         
            $data['note_index'] = $this->segmentor->text_to_index($note);
            $this->modified_fields['note_index'] = TRUE;
                     }
                     else
                     {
            $data['note_index'] = NULL;
            $this->modified_fields['note_index'] = TRUE;
                     }
         */
     } else {
         if (array_key_exists('note', $data) && is_null($data['note'])) {
             $data['note_index'] = NULL;
             //$data['note'] = NULL;
             //unset($data['note_index']);
         }
     }
     if (FALSE === isset($data['annotation_type_id'])) {
         $data['annotation_type_id'] = 1;
     }
     if (isset($this->id)) {
         $data['update_timestamp'] = get_timestamp();
     }
     return $data;
 }
Пример #20
0
function get_week_number($start_date)
{
    # Gets the week number of year
    $timestamp = get_timestamp($start_date);
    $week_number = date("W", $timestamp);
    return $week_number;
}
Пример #21
0
 public function create_type()
 {
     //generate WYSIWYG editor
     $this->_ckeditor_conf2();
     $this->data['generated_editor'] = display_ckeditor($this->data['ckeditor']);
     $this->data['generated_editor2'] = display_ckeditor($this->data['ckeditor2']);
     //generate username, current date if creating nu notices [not editing]
     if (!isset($this->data['date_created'])) {
         $this->data['date_created'] = get_timestamp();
         $this->session->set_userdata('date_created', $this->data['date_created']);
     }
     if (!isset($this->data['created_by'])) {
         $this->data['created_by'] = $this->ion_auth->get_user()->username;
     } else {
         //get the username of the person who created the notices
         //			$this->data['created_by'] = $this->ion_auth->get_user($this->data['created_by'])->username;
     }
     //display
     $this->load->view('templates/admin_header');
     $this->load->view('admin/index.php');
     $this->load->view('admin/create_faqs_type.php', $this->data);
     $this->load->view('templates/admin_footer');
 }
Пример #22
0
function process_xhprof_target($xhprof_target_dir, $logger)
{
    $tmp_file = $_FILES['uploadedfile']['tmp_name'];
    $source_ip = getRealIpAddr();
    $uploaded_file_name = basename($_FILES['uploadedfile']['name']);
    if (isset($_GET['shadow'])) {
        // rename <timestamp>.tar.bz__<ip> to <timestamp>.tar.bz__
        $uploaded_file_name = str_replace("__{$source_ip}", "", $uploaded_file_name);
    }
    $timestamp = get_timestamp($uploaded_file_name, false);
    //	$target_dir = create_directory($xhprof_target_dir, $timestamp);
    //	if ($target_dir === null) {
    //		$logger->log("uploader","Directory is not created",Logger::CRIT);
    //		header("HTTP/1.1 500 Server error");
    //		echo "Could not create directory $xhprof_target_dir\n";
    //		return;
    //	}
    $time_slot = (int) ($timestamp / (30 * 60));
    $target_dir = sprintf($xhprof_target_dir, (string) $time_slot);
    $target_file = "{$target_dir}/{$uploaded_file_name}__{$source_ip}";
    if (move_uploaded_file($tmp_file, $target_file)) {
        $logger->log("uploader", $target_file . " has been uploaded", Logger::INFO);
        echo "SUCCESS: {$target_file} has been uploaded<br></br>\n";
        //
        // Write the uploaded file name to .profiles for reference to what all files has been uploaded
        // This will be used while processing.
        //
        file_put_contents("{$target_dir}/.profiles", "{$uploaded_file_name}__{$source_ip},", FILE_APPEND | LOCK_EX);
        // functions file tag is inserted in-cron
        touch("{$target_dir}/.slowpages", time());
        touch("{$target_dir}/.apache_stats", time());
    } else {
        $logger->log("uploader", "could not move " . $tmp_file . " to " . $target_file, Logger::ERR);
        $target_file = null;
        header("HTTP/1.1 500 Server error");
        echo "FAILED: could not move {$tmp_file} to  {$target_file}<br></br>\n";
    }
    return $target_file;
}
Пример #23
0
 function index()
 {
     $issue = NULL;
     $browser = NULL;
     $imageData = NULL;
     //$receiver_email = "*****@*****.**";
     $receiver_email = $this->config->item("feedback.receiver_email");
     if (FALSE === isset($_POST) || FALSE === isset($_POST["data"])) {
         //return;
     } else {
         // 接收資料
         $feedback_data = json_decode($_POST["data"]);
         $issue = $feedback_data[0]->Issue;
         $browser = $feedback_data[0]->browser;
         if ($feedback_data[0]->receiver_email !== NULL) {
             $receiver_email = $feedback_data[0]->receiver_email;
         }
         $imageData = $feedback_data[1];
     }
     if (is_array($receiver_email)) {
         $receiver_email = implode(",", $receiver_email);
     }
     /**
      * 設定寄送訊息
      */
     $this->email->to($receiver_email);
     /**
      * 設定額外訊息
      */
     // Feedback header
     //$feedback_header = "KALS feedback report";
     $feedback_header = $this->lang->line("feedback.heading");
     $message_list[] = $feedback_header . "\n=============================";
     // Issue
     //$issue_header = "ISSUE";
     $issue_header = $this->lang->line("feedback.issue");
     $message_list[] = $issue_header . ": \n\n" . $issue . "\n";
     //$additional_header = "Additional Information";
     $additional_header = $this->lang->line("feedback.additional_information");
     $message_list[] = $additional_header . "\n-----------------------------";
     // =============================
     // -----------------------------
     // Time
     //$message_list[] = "Time: " . get_timestamp();
     $message_list[] = $this->lang->line("feedback.report_timestamp") . ": " . get_timestamp();
     // KALS Sever
     //$message_list[] = "KALS SERVER URL: " . get_kals_base_url();
     $message_list[] = $this->lang->line("feedback.kals_server_url") . ": " . get_kals_base_url();
     // URL
     //$message_list[] = "Referer URL: " . $this->url;
     $message_list[] = $this->lang->line("feedback.referer_url") . ": " . $this->url;
     $message_list[] = $this->lang->line("feedback.browser") . ": " . $browser;
     // Domain
     $domain_id = NULL;
     $domain = get_context_domain();
     if (isset($domain)) {
         $domain_id = $domain->get_id();
     }
     //$message_list[] = "Domain ID: " .$domain_id;
     $message_list[] = $this->lang->line("feedback.domain_id") . ": " . $domain_id;
     // Webpage
     $webpage_id = NULL;
     $webpage = get_context_webpage();
     if (isset($webpage)) {
         $webpage_id = $webpage->get_id();
     }
     //$message_list[] = "Webpage ID: " .$webpage_id;
     $message_list[] = $this->lang->line("feedback.webpage_id") . ": " . $webpage_id;
     // User
     $user_name = NULL;
     $user_id = NULL;
     $user_email = NULL;
     $user = get_context_user();
     if (isset($user)) {
         $user_id = $user->get_id();
         $user_name = $user->get_name();
         $user_email = $user->get_email();
     }
     //$message_list[] = "User ID: " .$user_id;
     $message_list[] = $this->lang->line("feedback.user_id") . ": " . $user_id;
     //$message_list[] = "User Name: " .$user_name;
     $message_list[] = $this->lang->line("feedback.user_name") . ": " . $user_name;
     //$message_list[] = "User E-Mail: " .$user_email;
     $message_list[] = $this->lang->line("feedback.user_email") . ": " . $user_email;
     $message = implode("\n", $message_list);
     $this->email->message($message);
     echo $message;
     /**
      * 處理郵件標頭
      */
     //$subject = "KALS Feedback Report";
     $subject = $this->lang->line("feedback.heading");
     if (isset($issue)) {
         $abstract_max_length = 15;
         $issue_text = strip_tags($issue);
         $issue_abstract = substr($issue_text, 0, $abstract_max_length);
         if (strlen($issue_text) > $abstract_max_length) {
             $issue_abstract = $issue_abstract . "...";
         }
         //$subject = $subject . " by " . $user_name . "(" . $user_id . ")";
         $subject = $subject . ": " . $issue_abstract;
     }
     $this->email->subject($subject);
     //$from_email = "*****@*****.**";
     $from_email = $this->config->item("feedback.default_sender_email");
     //$from_name = "Pudding Chen";
     $from_name = $this->config->item("feedback.default_sender_name");
     if (isset($user)) {
         $from_email = $user_email;
         $from_name = $user_name;
     }
     $this->email->from($from_email, $from_name);
     /**
      * 處理附件
      */
     if (FALSE === is_null($imageData)) {
         //$parts = explode(',', $imageData);
         //$encodedData = str_replace(' ','+',$parts[1]);
         //$data = base64_decode($encodedData);
         //$data = $imageData;
         //$png = "";
         $png = $imageData;
         $png = substr($png, strlen("data:image/png;base64,"));
         $png = base64_decode($png);
         $temp_path = tempnam(sys_get_temp_dir(), 'kals_feedback_') . ".png";
         file_put_contents($temp_path, $png);
         $this->email->attach($temp_path);
     }
     /**
      * 寄出並記錄後續動作
      */
     if (TRUE) {
         //if (FALSE) {
         $this->email->send();
         echo $this->email->print_debugger();
         $action = 29;
         kals_log($this->db, $action, $issue);
         context_complete();
     }
     //file_put_contents("log.js", json_encode($feedback_data[0]->Issue));
     if (FALSE === is_null($imageData)) {
         unlink($temp_path);
     }
 }
Пример #24
0
function evaluate_quiz($acode, $jobid, $newattempt, $blended)
{
    global $USER;
    global $CFG;
    mtrace("Evaluation QUIZ Processing..." . "<BR><BR>");
    try {
        print "New Attempt is: " . $newattempt . "<BR/>";
        $detected_userid = find_userid($acode, $jobid);
        if ($detected_userid == null or $detected_userid == '') {
            throw new EvaluationError(get_string('ErrorUserIDEmpty', 'blended'), EvaluationError::USERID_IS_EMPTY);
        }
        $user_reg = blended_get_user($detected_userid, $blended);
        if ($user_reg == null) {
            throw new EvaluationError(get_string('ErrorUserNotInCourse', 'blended'), EvaluationError::USER_NOT_IN_THIS_COURSE);
        }
        $userid = $user_reg->id;
        mtrace('Obtained USERID value: ' . $userid . " OK. <BR/>");
        $quiz = get_quiz($acode);
        $attempts = quiz_get_user_attempts($quiz->id, $userid, 'all', true);
        mtrace("Searching quiz... Success." . "<BR/>");
        $uniqueid = get_uniqueid($acode);
        mtrace('Obtained uniqueid: OK. <BR/>');
        $timestamp = get_timestamp($acode);
        mtrace('Obtained timestamp: OK. <BR/>');
        if (!get_record('quiz_attempts', 'uniqueid', $uniqueid)) {
            $newattempt = true;
        } else {
            $newattempt = false;
            mtrace("User {$userid} had opened this attempt already.");
        }
        $attemptnumber = 1;
        if ($newattempt == false) {
            mtrace('Obtaining user attempt...<BR/>');
            set_attempt_unfinished($uniqueid);
            $attempt = quiz_get_user_attempt_unfinished($quiz->id, $userid);
        } elseif ($newattempt == true) {
            mtrace('Creating new attempt...<BR/>');
            $attempt = create_new_attempt($quiz, $attemptnumber, $userid, $acode, $uniqueid, $timestamp);
            // Save the attempt
            if (!insert_record('quiz_attempts', $attempt)) {
                throw new EvaluationError(get_string('ErrorCouldNotCreateAttempt', 'blended'), EvaluationError::CREATE_QUIZ_ATTEMPT_ERROR);
            }
            // Actualizamos el estado de las imágenes para indicar que ya está creado un nuevo attempt
            update_images_status($acode, $jobid);
        }
        update_question_attempts($uniqueid);
        // /*
        mtrace('<BR>Getting questions and question options... ');
        $questions = get_questions($attempt, $quiz);
        if (!get_question_options($questions)) {
            error('Could not load question options');
        }
        mtrace('Success! <BR>');
        //	print ("<BR>He obtenido questions: ");
        //print_object($questions);
        $lastattemptid = false;
        //	 if ($attempt->attempt > 1 and $quiz->attemptonlast and !$attempt->preview) {
        // Find the previous attempt
        //      if (!$lastattemptid = get_field('quiz_attempts', 'uniqueid', 'quiz', $attempt->quiz, 'userid', $attempt->userid, 'attempt', $attempt->attempt-1)) {
        //        error('Could not find previous attempt to build on');
        //  }
        //}
        //print ('He obtenido lastattemptid');
        mtrace('Getting question states... ');
        if (!($states = get_question_states($questions, $quiz, $attempt, $lastattemptid))) {
            error('Could not restore question sessions');
        }
        mtrace('Success! <BR>');
        mtrace('Getting responses... <BR>');
        $responses = get_responses($acode, $jobid, $attempt);
        //print('Estas son las responses:');
        //print_object($responses);
        //$timestamp=time();
        $event = 8;
        $actions = question_extract_responses($questions, $responses, $event);
        $questionids = get_questionids($acode);
        //	print $questionids;
        $questionidarray = explode(',', $questionids);
        $success = true;
        mtrace('<BR> Processing responses and saving session... ');
        foreach ($questionidarray as $i) {
            if (!isset($actions[$i])) {
                $actions[$i]->responses = array('' => '');
                $actions[$i]->event = QUESTION_EVENTOPEN;
            }
            $actions[$i]->timestamp = $timestamp;
            if (question_process_responses($questions[$i], $states[$i], $actions[$i], $quiz, $attempt)) {
                save_question_session($questions[$i], $states[$i]);
            } else {
                $success = false;
            }
        }
        mtrace('Success! <BR>');
        // Set the attempt to be finished
        $timestamp = time();
        //$attempt->timefinish = $timestamp;
        // Update the quiz attempt and the overall grade for the quiz
        mtrace('<BR> Finishing the attempt... ');
        // print_object ($attempt);
        if (set_field('quiz_attempts', 'timefinish', $timestamp, 'uniqueid', $uniqueid) == false) {
            throw new EvaluationError('Unable to finish the quiz attempt!', EvaluationError::FINISH_QUIZ_ATTEMPT_ERROR);
        }
        mtrace('Success! <BR>');
        if ($attempt->attempt > 1 || $attempt->timefinish > 0 and !$attempt->preview) {
            mtrace('<BR> Saving quiz grade... ');
            quiz_save_best_grade($quiz, $userid);
        }
        mtrace('Success! <BR>');
        // */
        mtrace("Process Done. <BR><BR>");
        mtrace("<center> Your quiz has been succesfully evaluated!! </center>");
    } catch (EvaluationError $e) {
        throw $e;
    }
    return;
}
Пример #25
0
 /**
  * 接受建議。接受後回傳變更過後的標註資料
  * @param boolean $accept
  * @return Annotation
  */
 public function set_accept($accept = TRUE)
 {
     if ($accept == 'TRUE' or $accept == 'T') {
         $accept = TRUE;
     }
     $annotation = NULL;
     if ($accept === TRUE) {
         $this->set_field('accept', 'TRUE');
         //刪除原有標註,並且新增標註
         $recommend_by = $this->get_recommend_by();
         $recommended = $this->get_recommended();
         if (isset($recommend_by)) {
             $recommend_scope = $recommend_by->get_scopes();
             $user = $recommended->get_user();
             $this->_CI_load('library', 'kals_resource/Annotation', 'annotation');
             $annotation = $this->CI->annotation->create_annotation($user, $recommend_scope);
             //把其他特徵都加進去吧
             $annotation->import($recommended);
             //重新分數計算
             $webpage = $this->get_webpage();
             $calculator = $webpage->get_score_calculator();
             $calculator->setup_annotation_scores($annotation);
         } else {
             //$annotation = $this->get_recommended();
             $annotation = NULL;
         }
         $recommended = $this->get_recommended();
         $recommended->delete();
         $recommended->update();
     } else {
         $this->set_field('accept', 'FALSE');
         $annotation = $this->get_recommended();
     }
     $this->set_field('checked_timestamp', get_timestamp());
     $this->update();
     $this->delete();
     return $annotation;
 }
Пример #26
0
 private function parse_image($thumb)
 {
     $this->dimensions = getimagesize($this->image['tmp_name']);
     if ($this->dimensions[0] > 5000 || $this->dimensions[1] > 5000) {
         return false;
     }
     $newname = get_timestamp();
     $this->newfname = $newname[0] . '.' . $this->extension;
     $this->tempfile = $this->tempfolder . $this->newfname;
     $this->newfile = $this->folderpath . $this->newfname;
     $this->thumbfile = $thumb ? $this->thumbfolder . 't' . $newname[0] . '.' . $this->thumbext : '';
     $this->filesize = $this->image['size'];
     return true;
 }
Пример #27
0
   iRail is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.

   iRail is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with iRail.  If not, see <http://www.gnu.org/licenses/>.

	http://blog.irail.be - http://irail.be

	source available at http://github.com/Tuinslak/iRail
*/
//this is the entire array of stations in Belgium
//set content type in the header to XML
header('Content-Type: text/xml');
include "../includes/stationlist.php";
include "../includes/coordinates.php";
//make the damn document ;-)
echo "<?xml version=\"1.0\" encoding=\"UTF-8\"?>";
echo "<stations timestamp=\"" . get_timestamp() . "\">";
foreach ($stations as $i => $value) {
    echo "<station location=\"" . $coordinates[$value] . "\">";
    echo $value;
    echo "</station>";
}
echo "</stations>";
Пример #28
0
 /**
  * contacts form
  */
 public function create()
 {
     //print_r($this->data);
     //generate username, current date if creating nu contacts [not editing]
     if (!isset($this->data['date_created'])) {
         $this->data['date_created'] = get_timestamp();
         $this->session->set_userdata('date_created', $this->data['date_created']);
     }
     if (!isset($this->data['created_by'])) {
         $this->data['created_by'] = $this->ion_auth->get_user()->username;
     }
     $this->data['link'] = explode('/', $this->data['link']);
     $this->data['link'] = $this->data['link'][1];
     //display
     $this->load->view('templates/admin_header');
     $this->load->view('admin/index.php');
     $this->load->view('admin/create_contacts.php', $this->data);
     $this->load->view('templates/admin_footer');
 }
Пример #29
0
     clean(null, $dirUserPdf);
 }
 // Set name
 $str_to_replace = array(" ", ":", ".", "&", "/");
 //var_dump($value["assets"]);
 if (preg_match("/ENTITY\\:(\\d+)/", $value["assets"], $fnd)) {
     $conn = $db->connect();
     $e_name = Acl::get_entity_name($conn, $fnd[1]);
     $assets = "ENTITY: " . $e_name;
     $db->close($conn);
 } else {
     $assets = $value['assets'];
 }
 $pdfNameEmail = str_replace($str_to_replace, '_', $value['name_report']) . '_' . str_replace($str_to_replace, '_', $assets);
 $conn = $db->connect();
 $run_at = get_timestamp($conn, $user, gmdate('Y-m-d H:i:s', gmdate('U')));
 $user_name = $conn->GetOne("SELECT name FROM users WHERE login='******'");
 $db->close();
 $subject_email = _("Report") . ": " . $value["schedule_name"] . " " . $value['name_report'] . " " . _("run at") . " " . $run_at;
 $pdfName = $pdfNameEmail . "_" . time();
 $body_email = _("Run as") . ": " . $user_name . "<br />";
 $body_email .= _("Run at") . ": " . $run_at . "<br />";
 if ($assets == "ALL_ASSETS") {
     $assets = _("All Assets");
 }
 $body_email .= _("Assets") . ": " . $assets . "<br /><br />";
 $body_email .= _("Confidential Information - Do Not Distribute") . "<br />" . _("Copyright (c) AlienVault, LLC. All rights reserved.");
 $text = _('Save to') . ':';
 $to_text = sprintf("\n%-16s", $text);
 $to_text .= $dirUserPdf . $pdfName . ".pdf\n";
 echo $to_text;
Пример #30
0
function rrdgraph_cmd_add_overlay_events($command, $graph_start, $graph_end, $conf_overlay_events_color_map_file, $conf_overlay_events_shade_alpha, $conf_overlay_events_tick_alpha, $conf_overlay_events_line_type, $conf_graph_colors, $nagios_events)
{
    $debug = FALSE;
    // In order not to pollute the command line with all the possible VRULEs
    // we need to find the time range for the graph
    $graph_end_timestamp = get_timestamp($graph_end);
    $graph_start_timestamp = get_timestamp($graph_start);
    if ($graph_start_timestamp == NULL || $graph_end_timestamp == NULL) {
        error_log("process_over_events: " . "Start/end timestamp(s) are NULL");
        return $command;
    }
    // Get array of events for time range
    $events_array = ganglia_events_get($graph_start_timestamp, $graph_end_timestamp);
    if (empty($events_array)) {
        return $command;
    }
    $event_color_json = file_get_contents($conf_overlay_events_color_map_file);
    if ($debug) {
        error_log("{$event_color_json}");
    }
    $event_color_array = json_decode($event_color_json, TRUE);
    $initial_event_color_count = count($event_color_array);
    $event_color_map = array();
    foreach ($event_color_array as $event_color_entry) {
        $event_color_map[$event_color_entry['summary']] = $event_color_entry['color'];
        if ($debug) {
            error_log("Adding event color to map: " . $event_color_entry['summary'] . ' ' . $event_color_entry['color']);
        }
    }
    // Combine the nagios_events array, if it exists
    if (count($nagios_events) > 0) {
        // World's dumbest array merge:
        foreach ($nagios_events as $ne) {
            $events_array[] = $ne;
        }
    }
    foreach ($events_array as $key => $row) {
        $start_time[$key] = $row['start_time'];
    }
    // Sort events in reverse chronological order
    array_multisort($start_time, SORT_DESC, $events_array);
    // Default to dashed line unless events_line_type is set to solid
    if ($conf_overlay_events_line_type == "solid") {
        $overlay_events_line_type = "";
    } else {
        $overlay_events_line_type = ":dashes";
    }
    // Preserve original rrdtool command. That's the one we'll run regex checks
    // against
    $original_command = $command;
    // Loop through all the events
    $color_count = sizeof($conf_graph_colors);
    $counter = 0;
    $legend_items = array();
    foreach ($events_array as $id => $event) {
        $evt_start = $event['start_time'];
        // Make sure it's a number
        if (!is_numeric($evt_start)) {
            continue;
        }
        unset($evt_end);
        if (array_key_exists('end_time', $event) && is_numeric($event['end_time'])) {
            $evt_end = $event['end_time'];
        }
        // If event start is less than start bail out of the loop since
        // there is nothing more to do since events are sorted in reverse
        // chronological order and these events are not gonna show up in
        // the graph
        $in_graph = $evt_start >= $graph_start_timestamp && $evt_start <= $graph_end_timestamp || isset($evt_end) && $evt_end >= $graph_start_timestamp && $evt_start <= $graph_end_timestamp;
        if (!$in_graph) {
            if ($debug) {
                error_log("process_overlay_events: " . "Event [{$evt_start}] does not overlap with graph " . "[{$graph_start_timestamp}, {$graph_end_timestamp}]");
            }
            continue;
        }
        // Compute the part of the event to be displayed
        $evt_start_in_graph_range = TRUE;
        if ($evt_start < $graph_start_timestamp) {
            $evt_start = $graph_start_timestamp;
            $evt_start_in_graph_range = FALSE;
        }
        $evt_end_in_graph_range = TRUE;
        if (isset($evt_end)) {
            if ($evt_end > $graph_end_timestamp) {
                $evt_end = $graph_end_timestamp;
                $evt_end_in_graph_range = FALSE;
            }
        } else {
            $evt_end_in_graph_range = FALSE;
        }
        if (preg_match("/" . $event["host_regex"] . "/", $original_command)) {
            if ($evt_start >= $graph_start_timestamp) {
                // Do we have the end timestamp.
                if (!isset($graph_end_timestamp) || $evt_start < $graph_end_timestamp) {
                    // This is a potential vector since this gets added to the
                    // command line_width TODO: Look over sanitize
                    $summary = isset($event['summary']) ? sanitize($event['summary']) : "";
                    // We need to keep track of summaries so that if we have identical
                    // summaries e.g. Deploy we can use the same color
                    if (array_key_exists($summary, $event_color_map)) {
                        $color = $event_color_map[$summary];
                        if ($debug) {
                            error_log("process_overlay_events: " . "Found existing color: {$summary} {$color}");
                        }
                        // Reset summary to empty string if it is already present in
                        // the legend
                        if (array_key_exists($summary, $legend_items)) {
                            $summary = "";
                        } else {
                            $legend_items[$summary] = TRUE;
                        }
                    } else {
                        // Haven't seen this summary before. Assign it a color
                        $color_index = count($event_color_map) % $color_count;
                        $color = $conf_graph_colors[$color_index];
                        $event_color_map[$summary] = $color;
                        $event_color_array[] = array('summary' => $summary, 'color' => $color);
                        if ($debug) {
                            error_log("process_overlay_events: " . "Adding new event color: {$summary} {$color}");
                        }
                    }
                    if (isset($evt_end)) {
                        // Attempt to draw a shaded area between start and end points.
                        // Force solid line for ranges
                        $overlay_events_line_type = "";
                        $start_vrule = '';
                        if ($evt_start_in_graph_range) {
                            $start_vrule = " VRULE:" . $evt_start . "#{$color}" . $conf_overlay_events_tick_alpha . ":\"" . $summary . "\"" . $overlay_events_line_type;
                        }
                        $end_vrule = '';
                        if ($evt_end_in_graph_range) {
                            $end_vrule = " VRULE:" . $evt_end . "#{$color}" . $conf_overlay_events_tick_alpha . ':""' . $overlay_events_line_type;
                        }
                        // We need a dummpy DEF statement, because RRDtool is too stupid
                        // to plot graphs without a DEF statement.
                        // We can't count on a static name, so we have to "find" one.
                        if (preg_match("/DEF:['\"]?(\\w+)['\"]?=/", $command, $matches)) {
                            // stupid rrdtool limitation.
                            $area_cdef = " CDEF:area_{$counter}={$matches['1']},POP," . "TIME,{$evt_start},GT,1,UNKN,IF,TIME,{$evt_end},LT,1,UNKN,IF,+";
                            $area_shade = $color . $conf_overlay_events_shade_alpha;
                            $area = " TICK:area_{$counter}#{$area_shade}:1";
                            if (!$evt_start_in_graph_range) {
                                $area .= ':"' . $summary . '"';
                            }
                            $command .= "{$area_cdef} {$area} {$start_vrule} {$end_vrule}";
                        } else {
                            error_log("No DEF statements found in \$command?!");
                        }
                    } else {
                        $command .= " VRULE:" . $evt_start . "#" . $color . ":\"" . $summary . "\"" . $overlay_events_line_type;
                    }
                    $counter++;
                } else {
                    if ($debug) {
                        error_log("process_overlay_events: " . "Event start [{$evt_start}] >= graph end " . "[{$graph_end_timestamp}]");
                    }
                }
            } else {
                if ($debug) {
                    error_log("process_overlay_events: " . "Event start [{$evt_start}] < graph start " . "[{$graph_start_timestamp}]");
                }
            }
        } else {
            // error_log("Doesn't match host_regex");
        }
    }
    // end of foreach ( $events_array ...
    unset($events_array);
    if (count($event_color_array) > $initial_event_color_count) {
        $event_color_json = json_encode($event_color_array);
        file_put_contents($conf_overlay_events_color_map_file, $event_color_json);
    }
    return $command;
}