Comprobar que CRON se ejecuta correctamente

Haz una copia del fichero ow_cron/run.php con otro nombre, por ejemplo ow_cron/ por si la cagas.

Edita el fichero: ow_cron/run.php y busca la línea donde pone

foreach ( $plugins as $plugin ){ 

y después de la llave { añades esta línea:

echo "Ejecutando cron.php de: " . $plugin->getKey();

y al final, antes de la última llave } de cierre añades:

echo " OK<br>";

y después de la última llave } de cierre añades:

echo "Proceso finalizado.<br>";

Una vez guardado, desde tu navegador ejecutas:

(cambia por el nombre de tu web)

y tendrás el resultado de la imagen si todo funciona correctamente.

Si no llega a mostrarse "Proceso finalizado" es que el último plugin mostrado, el que no pondrá OK ha fallado o que se ha acabado el tiempo máximo de ejecución de PHP.

Una vez soluciones los problemas (si los hubiese) puedes dejar el fichero ow_cron.php como está o recuperar tu copia (si la hiciste, que nos conocemos :) ) de ow_cron/

Recomiendo que todos los ficheros que edites mantengas la versión original con la extensión .ph , y así si algo no funcionase puedes buscar todos los fichero con esta extensión y sabrás lo que has editado de tus plugins o del núcleo de OxWall, como en este caso.

Si te da pereza escribir, aquí tienes el fichero ow_cron/run.php ya editado, he puesto // Patri modif justo antes de cada linea que he añadido.



 * EXHIBIT A. Common Public Attribution License Version 1.0

 * The contents of this file are subject to the Common Public Attribution License Version 1.0 (the “License”);

 * you may not use this file except in compliance with the License. You may obtain a copy of the License at

 * The License is based on the Mozilla Public License Version 1.1

 * but Sections 14 and 15 have been added to cover use of software over a computer network and provide for

 * limited attribution for the Original Developer. In addition, Exhibit A has been modified to be consistent

 * with Exhibit B. Software distributed under the License is distributed on an “AS IS” basis,

 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific language

 * governing rights and limitations under the License. The Original Code is Oxwall software.

 * The Initial Developer of the Original Code is Oxwall Foundation (

 * All portions of the code written by Oxwall Foundation are Copyright (c) 2011. All Rights Reserved.

 * EXHIBIT B. Attribution Information

 * Attribution Copyright Notice: Copyright 2011 Oxwall Foundation. All rights reserved.

 * Attribution Phrase (not exceeding 10 words): Powered by Oxwall community software

 * Attribution URL:

 * Graphic Image as provided in the Covered Code.

 * Display of Attribution Information is required in Larger Works which are defined in the CPAL as a work

 * which combines Covered Code or portions thereof with code not governed by the terms of the CPAL.



 * @author Nurlan Dzhumakaliev <>

 * @package ow_cron

 * @since 1.0


define('_OW_', true);


define('OW_DIR_ROOT', substr(dirname(__FILE__), 0, - strlen('ow_cron')));

define('OW_CRON', true);

require_once(OW_DIR_ROOT . 'ow_includes' . DS . 'init.php');

// set error log file

if ( !defined('OW_ERROR_LOG_ENABLE') || (bool) OW_ERROR_LOG_ENABLE )


    $logFilePath = OW_DIR_LOG . 'cron_error.log';

    $logger = OW::getLogger('ow_core_log');

    $logger->setLogWriter(new BASE_CLASS_FileLogWriter($logFilePath));



if ( !isset($_GET['ow-light-cron']) && !OW::getConfig()->getValue('base', 'cron_is_configured') )


    if ( OW::getConfig()->configExists('base', 'cron_is_configured') )


        OW::getConfig()->saveConfig('base', 'cron_is_configured', 1);




        OW::getConfig()->addConfig('base', 'cron_is_configured', 1);




date_default_timezone_set(OW::getConfig()->getValue('base', 'site_timezone'));

OW_Auth::getInstance()->setAuthenticator(new OW_SessionAuthenticator());


$event = new OW_Event(OW_EventManager::ON_PLUGINS_INIT);


//init cache manager

$beckend = OW::getEventManager()->call('base.cache_backend_init');

if ( $beckend !== null )







// setting current theme

$activeThemeName = OW::getConfig()->getValue('base', 'selectedTheme');

if ( $activeThemeName !== BOL_ThemeService::DEFAULT_THEME && OW::getThemeManager()->getThemeService()->themeExists($activeThemeName) )




$plugins = BOL_PluginService::getInstance()->findActivePlugins();

foreach ( $plugins as $plugin )


// Patri modif

echo "Ejecutando cron.php de: " . $plugin->getKey();

    /* @var $plugin BOL_Plugin */

    $pluginRootDir = OW::getPluginManager()->getPlugin($plugin->getKey())->getRootDir();

    if ( file_exists($pluginRootDir . 'cron.php') )


        include $pluginRootDir . 'cron.php';

        $className = strtoupper($plugin->getKey()) . '_Cron';

        $cron = new $className;

        $runJobs = array();

        $newRunJobDtos = array();

        foreach ( BOL_CronService::getInstance()->findJobList() as $runJob )


            /* @var $runJob BOL_CronJob */

            $runJobs[$runJob->methodName] = $runJob->runStamp;


        $jobs = $cron->getJobList();

        foreach ( $jobs as $job => $interval )


            $methodName = $className . '::' . $job;

            $runStamp = ( isset($runJobs[$methodName]) ) ? $runJobs[$methodName] : 0;

            $currentStamp = time();

            if ( ( $currentStamp - $runStamp ) > ( $interval * 60 ) )


                $runJobDto = new BOL_CronJob();

                $runJobDto->methodName = $methodName;

                $runJobDto->runStamp = $currentStamp;

                $newRunJobDtos[] = $runJobDto;


                $newRunJobDtos = array();





// Patri modif

echo " OK<br>";


// Patri modif

echo "Proceso finalizado.<br>";


No comments
You need to sign in to comment


Your rate:
Total: (0 rates)

Next article


If on your website you need to maintain a virtual ...
Update installation instructions: Download Oxwall...
Displays guests visited user profile This plugi...
"Contact us" page with the ability to choose depar...
User blogs with archives, tags, comments and rates...
Allow users to send private and public virtual gif...
Simple banner ad management.Use the Geolocation IP...
This is the complete package of OxWall 1.87You nee...
This is the complete package of OxWall 1.87You nee...
Friending functionality to be used across multiple...
This version is the last one that OxWall published...
Real-time and email notifications about site activ...