diff --git a/airtime_mvc/application/Bootstrap.php b/airtime_mvc/application/Bootstrap.php
index f8d0886aa..1bf0abc88 100644
--- a/airtime_mvc/application/Bootstrap.php
+++ b/airtime_mvc/application/Bootstrap.php
@@ -93,5 +93,27 @@ class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
$view = $this->getResource('view');
$view->headTitle(Application_Model_Preference::GetHeadTitle());
}
+
+ protected function _initZFDebug()
+ {
+ if (APPLICATION_ENV == "development"){
+ global $CC_DBC;
+
+ $autoloader = Zend_Loader_Autoloader::getInstance();
+ $autoloader->registerNamespace('ZFDebug');
+
+ $options = array(
+ 'plugins' => array('Variables',
+ 'Exception',
+ 'Memory',
+ 'Time')
+ );
+ $debug = new ZFDebug_Controller_Plugin_Debug($options);
+
+ $this->bootstrap('frontController');
+ $frontController = $this->getResource('frontController');
+ $frontController->registerPlugin($debug);
+ }
+ }
}
diff --git a/airtime_mvc/library/ZFDebug/Controller/Plugin/Debug.php b/airtime_mvc/library/ZFDebug/Controller/Plugin/Debug.php
new file mode 100644
index 000000000..830701a81
--- /dev/null
+++ b/airtime_mvc/library/ZFDebug/Controller/Plugin/Debug.php
@@ -0,0 +1,485 @@
+ array(
+ 'Variables' => null,
+ 'Time' => null,
+ 'Memory' => null),
+ 'z-index' => 255,
+ 'jquery_path' => 'http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js',
+ 'image_path' => null
+ );
+
+ /**
+ * Standard plugins
+ *
+ * @var array
+ */
+ public static $standardPlugins = array('Cache', 'Html', 'Database', 'Exception', 'File', 'Memory', 'Registry', 'Time', 'Variables');
+
+ /**
+ * Debug Bar Version Number
+ * for internal use only
+ *
+ * @var string
+ */
+ protected $_version = '1.5.4';
+
+ /**
+ * Creates a new instance of the Debug Bar
+ *
+ * @param array|Zend_Config $options
+ * @throws Zend_Controller_Exception
+ * @return void
+ */
+
+ protected $_closingBracket = null;
+
+ public function __construct($options = null)
+ {
+ if (isset($options)) {
+ if ($options instanceof Zend_Config) {
+ $options = $options->toArray();
+ }
+
+ /*
+ * Verify that adapter parameters are in an array.
+ */
+ if (!is_array($options)) {
+ throw new Zend_Exception('Debug parameters must be in an array or a Zend_Config object');
+ }
+
+ $this->setOptions($options);
+ }
+
+ /**
+ * Creating ZF Version Tab always shown
+ */
+ $version = new ZFDebug_Controller_Plugin_Debug_Plugin_Text();
+ $version->setPanel($this->_getVersionPanel())
+ ->setTab($this->_getVersionTab())
+ ->setIdentifier('copyright')
+ ->setIconData('');
+ $this->registerPlugin($version);
+
+ /**
+ * Loading aready defined plugins
+ */
+ $this->_loadPlugins();
+ }
+
+ /**
+ * Sets options of the Debug Bar
+ *
+ * @param array $options
+ * @return ZFDebug_Controller_Plugin_Debug
+ */
+ public function setOptions(array $options = array())
+ {
+ if (isset($options['jquery_path'])) {
+ $this->_options['jquery_path'] = $options['jquery_path'];
+ }
+
+ if (isset($options['z-index'])) {
+ $this->_options['z-index'] = $options['z-index'];
+ }
+
+ if (isset($options['image_path'])) {
+ $this->_options['image_path'] = $options['image_path'];
+ }
+
+ if (isset($options['plugins'])) {
+ $this->_options['plugins'] = $options['plugins'];
+ }
+ return $this;
+ }
+
+ /**
+ * Register a new plugin in the Debug Bar
+ *
+ * @param ZFDebug_Controller_Plugin_Debug_Plugin_Interface
+ * @return ZFDebug_Controller_Plugin_Debug
+ */
+ public function registerPlugin(ZFDebug_Controller_Plugin_Debug_Plugin_Interface $plugin)
+ {
+ $this->_plugins[$plugin->getIdentifier()] = $plugin;
+ return $this;
+ }
+
+ /**
+ * Unregister a plugin in the Debug Bar
+ *
+ * @param string $plugin
+ * @return ZFDebug_Controller_Plugin_Debug
+ */
+ public function unregisterPlugin($plugin)
+ {
+ if (false !== strpos($plugin, '_')) {
+ foreach ($this->_plugins as $key => $_plugin) {
+ if ($plugin == get_class($_plugin)) {
+ unset($this->_plugins[$key]);
+ }
+ }
+ } else {
+ $plugin = strtolower($plugin);
+ if (isset($this->_plugins[$plugin])) {
+ unset($this->_plugins[$plugin]);
+ }
+ }
+ return $this;
+ }
+
+ /**
+ * Get a registered plugin in the Debug Bar
+ *
+ * @param string $identifier
+ * @return ZFDebug_Controller_Plugin_Debug_Plugin_Interface
+ */
+ public function getPlugin($identifier)
+ {
+ $identifier = strtolower($identifier);
+ if (isset($this->_plugins[$identifier])) {
+ return $this->_plugins[$identifier];
+ }
+ return false;
+ }
+
+ /**
+ * Defined by Zend_Controller_Plugin_Abstract
+ */
+ public function dispatchLoopShutdown()
+ {
+ if ($this->getRequest()->isXmlHttpRequest()) {
+ return;
+ }
+ $disable = Zend_Controller_Front::getInstance()->getRequest()->getParam('ZFDEBUG_DISABLE');
+ if (isset($disable)) {
+ return;
+ }
+
+ $html = '';
+
+ /**
+ * Creating menu tab for all registered plugins
+ */
+ foreach ($this->_plugins as $plugin)
+ {
+ $panel = $plugin->getPanel();
+ if ($panel == '') {
+ continue;
+ }
+
+ /* @var $plugin ZFDebug_Controller_Plugin_Debug_Plugin_Interface */
+ $html .= '
' . $panel . '
';
+ }
+
+ $html .= '';
+
+ /**
+ * Creating panel content for all registered plugins
+ */
+ foreach ($this->_plugins as $plugin)
+ {
+ $tab = $plugin->getTab();
+ if ($tab == '') {
+ continue;
+ }
+
+ if (null !== $this->_options['image_path'] && file_exists($this->_options['image_path'] .'/'. $plugin->getIdentifier() .'.png')) {
+ $plugin_icon = $this->_options['image_path'] .'/'. $plugin->getIdentifier() .'.png';
+ } else {
+ $plugin_icon = $plugin->getIconData();
+ }
+
+ /* @var $plugin ZFDebug_Controller_Plugin_Debug_Plugin_Interface */
+ $html .= '
';
+ $html .= '
getClosingBracket() .' ';
+ $html .= $tab . '';
+ }
+
+ $html .= '
«';
+
+ $html .= '
';
+ $this->_output($html);
+ }
+
+ ### INTERNAL METHODS BELOW ###
+
+ /**
+ * Load plugins set in config option
+ *
+ * @return void;
+ */
+ protected function _loadPlugins()
+ {
+ foreach($this->_options['plugins'] as $plugin => $options) {
+ if (is_numeric($plugin)) {
+ # Plugin passed as array value instead of key
+ $plugin = $options;
+ $options = array();
+ }
+
+ // Register an instance
+ if (is_object($plugin) && in_array('ZFDebug_Controller_Plugin_Debug_Plugin_Interface', class_implements($plugin))) {
+ $this->registerPlugin($plugin);
+ continue;
+ }
+
+ if (!is_string($plugin)) {
+ throw new Exception("Invalid plugin name", 1);
+ }
+ $plugin = ucfirst($plugin);
+
+ // Register a classname
+ if (in_array($plugin, ZFDebug_Controller_Plugin_Debug::$standardPlugins)) {
+ // standard plugin
+ $pluginClass = 'ZFDebug_Controller_Plugin_Debug_Plugin_' . $plugin;
+ } else {
+ // we use a custom plugin
+ if (!preg_match('~^[\w]+$~D', $plugin)) {
+ throw new Zend_Exception("ZFDebug: Invalid plugin name [$plugin]");
+ }
+ $pluginClass = $plugin;
+ }
+
+ require_once str_replace('_', DIRECTORY_SEPARATOR, $pluginClass) . '.php';
+ $object = new $pluginClass($options);
+ $this->registerPlugin($object);
+ }
+ }
+
+ /**
+ * Return version tab
+ *
+ * @return string
+ */
+ protected function _getVersionTab()
+ {
+ return ' ' . Zend_Version::VERSION . '/'.phpversion();
+ }
+
+ /**
+ * Returns version panel
+ *
+ * @return string
+ */
+ protected function _getVersionPanel()
+ {
+ $panel = 'ZFDebug v'.$this->_version.'
' .
+ '©2008-2009 Joakim Nygård & Andreas Pankratz
' .
+ 'The project is hosted at http://zfdebug.googlecode.com and released under the BSD License' . $this->getLinebreak() .
+ 'Includes images from the Silk Icon set by Mark James
'.
+ 'Disable ZFDebug temporarily by sending ZFDEBUG_DISABLE as a GET/POST parameter
';
+ // $panel .= 'Zend Framework '.Zend_Version::VERSION.' / PHP '.phpversion().' with extensions:
';
+ // $extensions = get_loaded_extensions();
+ // natcasesort($extensions);
+ // $panel .= implode('
', $extensions);
+ return $panel;
+ }
+
+ /**
+ * Returns path to the specific icon
+ *
+ * @return string
+ */
+ protected function _icon($kind)
+ {
+ switch ($kind) {
+ case 'database':
+ if (null === $this->_options['image_path'])
+ return '';
+
+ return $this->_options['image_path'] . '/database.png';
+ break;
+ case 'exception':
+ if (null === $this->_options['image_path'])
+ return '';
+
+ return $this->_options['image_path'] . '/exception.png';
+ break;
+ case 'error':
+ if (null === $this->_options['image_path'])
+ return '';
+
+ return $this->_options['image_path'] . '/error.png';
+ break;
+ default:
+ if (null === $this->_options['image_path'])
+ return '';
+
+ return $this->_options['image_path'] . '/unknown.png';
+ break;
+ }
+ }
+
+ /**
+ * Returns html header for the Debug Bar
+ *
+ * @return string
+ */
+ protected function _headerOutput() {
+ $collapsed = isset($_COOKIE['ZFDebugCollapsed']) ? $_COOKIE['ZFDebugCollapsed'] : 0;
+
+ return ('
+
+ ');
+ }
+
+ /**
+ * Appends Debug Bar html output to the original page
+ *
+ * @param string $html
+ * @return void
+ */
+ protected function _output($html)
+ {
+ $response = $this->getResponse();
+ $response->setBody(preg_replace('/(<\/head>)/i', $this->_headerOutput() . '$1', $response->getBody()));
+ $response->setBody(str_ireplace('