title = $this->get_config('title', $this->title); $propbag->add('name', PLUGIN_EVENT_STATISTICS_NAME); $propbag->add('description', PLUGIN_EVENT_STATISTICS_NAME); $propbag->add('stackable', true); $propbag->add('author', 'Arnan de Gans, Garvin Hicking'); $propbag->add('version', '1.3'); $propbag->add('requirements', array( 'serendipity' => '0.8', 'smarty' => '2.6.7', 'php' => '4.1.0' )); $propbag->add('groups', array('STATISTICS')); $propbag->add('configuration', array( 'title', 'show_lastentry', 'text_lastentry', 'show_entrycount', 'text_entrycount', 'show_commentcount', 'text_commentcount', 'show_monthvisitors', 'text_monthvisitors', 'show_currentvisitors', 'text_currentvisitors', 'cachetimeout' )); } function introspect_config_item($name, &$propbag) { switch($name) { case 'cachetimeout': $propbag->add('type', 'string'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_SHOW_CACHETIMEOUT); $propbag->add('description', PLUGIN_EVENT_STATISTICS_SHOW_CACHETIMEOUT_DESC); $propbag->add('default', 60); break; case 'show_lastentry': $propbag->add('type', 'boolean'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_SHOW_LASTENTRY); $propbag->add('description', ''); $propbag->add('default', true); break; case 'show_entrycount': $propbag->add('type', 'boolean'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_SHOW_ENTRYCOUNT); $propbag->add('description', ''); $propbag->add('default', true); break; case 'show_commentcount': $propbag->add('type', 'boolean'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_SHOW_COMMENTCOUNT); $propbag->add('description', ''); $propbag->add('default', true); break; case 'show_monthvisitors': $propbag->add('type', 'boolean'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_SHOW_MONTHVISITORS); $propbag->add('description', ''); $propbag->add('default', true); break; case 'text_lastentry': $propbag->add('type', 'string'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_TEXT); $propbag->add('description', PLUGIN_EVENT_STATISTICS_TEXT_DESC); $propbag->add('default', PLUGIN_EVENT_STATISTICS_TEXT_LASTENTRY); break; case 'text_entrycount': $propbag->add('type', 'string'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_TEXT); $propbag->add('description', PLUGIN_EVENT_STATISTICS_TEXT_DESC); $propbag->add('default', PLUGIN_EVENT_STATISTICS_TEXT_ENTRYCOUNT); break; case 'text_commentcount': $propbag->add('type', 'string'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_TEXT); $propbag->add('description', PLUGIN_EVENT_STATISTICS_TEXT_DESC); $propbag->add('default', PLUGIN_EVENT_STATISTICS_TEXT_COMMENTCOUNT); break; case 'text_monthvisitors': $propbag->add('type', 'string'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_TEXT); $propbag->add('description', PLUGIN_EVENT_STATISTICS_TEXT_DESC); $propbag->add('default', PLUGIN_EVENT_STATISTICS_TEXT_MONTHVISITORS); break; case 'text_currentvisitors': $propbag->add('type', 'string'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_TEXT); $propbag->add('description', PLUGIN_EVENT_STATISTICS_TEXT_DESC); $propbag->add('default', PLUGIN_EVENT_STATISTICS_TEXT_CURRENTVISITORS); break; case 'show_currentvisitors': $propbag->add('type', 'boolean'); $propbag->add('name', PLUGIN_EVENT_STATISTICS_SHOW_CURRENTVISITORS); $propbag->add('description', ''); $propbag->add('default', true); break; case 'title': $propbag->add('type', 'string'); $propbag->add('name', TITLE); $propbag->add('description', ''); $propbag->add('default', PLUGIN_EVENT_STATISTICS_NAME); break; default: return false; } return true; } function cleanup() { global $serendipity; @unlink($serendipity['serendipityPath'] . 'templates_c/statistics_cache.html'); } function generate_content(&$title) { global $serendipity; $title = $this->get_config('title', $this->title); $cachetime = $this->get_config('cachetimeout', 60) * 60; // turn to seconds $cachef = $serendipity['serendipityPath'] . 'templates_c/statistics_cache.html'; if (!file_exists($cachef) || filesize($cachef) == 0 || filemtime($cachef) < (time() - $cachetime)) { // Create statistics list($year, $month, $day) = split('-', date('Y-m-d')); $content = ''; if (serendipity_db_bool($this->get_config('show_lastentry'))) { $res = serendipity_db_query("SELECT timestamp FROM {$serendipity['dbPrefix']}entries WHERE isdraft = 'false' AND timestamp <= " . time() . " ORDER BY timestamp DESC LIMIT 1", true, 'assoc'); if (is_array($res) && isset($res['timestamp'])) { $content .= '
' . sprintf($this->get_config('text_lastentry'), '' . htmlspecialchars(serendipity_strftime(DATE_FORMAT_SHORT, $res['timestamp'])) . '') . "
\n"; } } if (serendipity_db_bool($this->get_config('show_entrycount'))) { $res = serendipity_db_query("SELECT count(id) as entrycount FROM {$serendipity['dbPrefix']}entries WHERE isdraft = 'false' AND timestamp <= " . time(), true, 'assoc'); if (is_array($res) && isset($res['entrycount'])) { $content .= '
' . sprintf($this->get_config('text_entrycount'), '' . $res['entrycount'] . '') . "
\n"; } } if (serendipity_db_bool($this->get_config('show_commentcount'))) { $res = serendipity_db_query("SELECT count(id) AS commentcount FROM {$serendipity['dbPrefix']}comments WHERE type = 'NORMAL' AND status = 'approved'", true, 'assoc'); if (is_array($res) && isset($res['commentcount'])) { $content .= '
' . sprintf($this->get_config('text_commentcount'), '' . $res['commentcount'] . '') . "
\n"; } } if (serendipity_db_bool($this->get_config('show_monthvisitors'))) { $res = serendipity_db_query("SELECT sum(visits) AS monthvisitors FROM {$serendipity['dbPrefix']}visitors_count WHERE year='".$year."' AND month='".$month."'", true, 'assoc'); if (is_array($res) && isset($res['monthvisitors'])) { $content .= '
' . sprintf($this->get_config('text_monthvisitors'), '' . $res['monthvisitors'] . '') . "
\n"; } } // This one is MySQL specific. Don't know how postgreSQL does it. if (serendipity_db_bool($this->get_config('show_currentvisitors'))) { $max = time(); $min = $max - (15 * 60); $max_ts = date('Hi', $max); $min_ts = date('Hi', $min); $q = "SELECT count(counter_id) AS currentvisitors FROM {$serendipity['dbPrefix']}visitors WHERE day LIKE '" . date('Y-m-d') . "' AND (REPLACE(time, ':', '') BETWEEN $min_ts AND $max_ts)"; $res = serendipity_db_query($q, true, 'assoc'); if (is_array($res) && isset($res['currentvisitors'])) { $content .= '
' . sprintf($this->get_config('text_currentvisitors'), '' . $res['currentvisitors'] . '') . "
\n"; } } // Write cache $fp = @fopen($cachef, 'w'); if ($fp) { fwrite($fp, $content); fclose($fp); } } else { // Read from cache $content = @file_get_contents($cachef); } echo $content; } } /* vim: set sts=4 ts=4 expandtab : */