Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
PD9waHANCi8vIGluYyBhZG1pbiBjb25maWcgZmlsZQ0KcmVxdWlyZV9vbmNlKCBkaXJuYW1lKCBfX0ZJTEVfXyApIC..
Decoded Output download
<? <?php
// inc admin config file
require_once( dirname( __FILE__ ) . "/../admin/config.php" );

// Startup
require_once( DIR_SYSTEM . 'startup.php' );

// Registry
$registry = new Registry();

// Loader
$loader = new Loader( $registry );
$registry->set( 'load', $loader );

// Config
$config = new Config();
$registry->set( 'config', $config );

// Database
$db = new DB( DB_DRIVER, DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_DATABASE, DB_PORT );
$registry->set( 'db', $db );

putenv( "SERVER_NAME=localhost" );
apache_setenv ( "SERVER_NAME","localhost" );

// Error Handler
set_error_handler( 'error_handler' );


// Request
$request = new Request();
$registry->set( 'request', $request );

// Settings
$query = $db->query( "SELECT * FROM `" . DB_PREFIX . "setting` WHERE store_id = '0' OR store_id = '" . (int)$config->get( 'config_store_id' ) . "' ORDER BY store_id ASC" );
foreach ( $query->rows as $result ) {
    if ( !$result['serialized'] ) {
        $config->set( $result['key'], $result['value'] );
    } else {
        $config->set( $result['key'], json_decode( $result['value'], true ) );
    }
}

// Language Detection
$languages = array();
$query = $db->query( "SELECT * FROM " . DB_PREFIX . "language WHERE status = '1'" );
foreach ( $query->rows as $result ) {
    $languages[$result['code']] = $result;
}
$code = $config->get( 'config_language' );
$config->set( 'config_language_id', $languages[$code]['language_id'] );
$config->set( 'config_language', $languages[$code]['code'] );

// Language
$language = new Language( $languages[$code]['directory'] );
$language->load( 'default' );
$registry->set( 'language', $language );


if ( !empty( $request->get['check'] ) && $_SERVER['REQUEST_METHOD'] == 'GET' ) {

    require_once( dirname( __FILE__ ) . "/../system/library/timeout_vw/vw.class.php" );
    require_once( dirname( __FILE__ ) . "/../system/library/mail.php" );
    
    $VWidget = new TimeOutVWidget();

    $status_module = false;
    $is_logger = false;
    $is_enable_log = false;
    $send_email = false;
    $arParams = array();

    // get setting
    $TM_STATUS = $config->get( 'module_timeout_vw_status' );
    $TM = $config->get( 'module_timeout_vw' );
    $arParams['VERSION_OPENCART'] = '3.0';
    
    if ( version_compare( $arParams['VERSION_OPENCART'], '2.3', '>=' ) ) {
        $language->load( 'extension/module/timeout_vw' );
    } else {
        $language->load( 'module/timeout_vw' );
    }
    
    if ( version_compare( $arParams['VERSION_OPENCART'], '2.3', '>=' ) ) {
        $arParams['EDIT_MODULE'] = HTTP_CATALOG.'/admin/index.php?route=extension/module/timeout_vw';
    } else {
        $arParams['EDIT_MODULE'] = HTTP_CATALOG.'/admin/index.php?route=module/timeout_vw';
    }

    $arParams['TXT_VALID1'] = htmlspecialchars( $VWidget->getKey() );
    $arParams['TXT_VALID2'] = htmlspecialchars( $request->get['check'], ENT_COMPAT, 'UTF-8' );
    $arParams['STATUS']['MODULE'] = intval( $TM_STATUS );
    $arParams['STATUS']['CRON'] = intval( $TM[ 'enable' ] );
    $arParams['STATUS']['LOG'] = intval( $TM[ 'logger' ] );
    $arParams['STATUS']['TO_EMAIL'] = intval( $TM[ 'email' ] );
    $arParams['ADMIN_TIMEZONE'] = $TM[ 'timezone' ];
    $arParams['CLIENT_DOMAIN'] = HTTP_CATALOG;
    $arParams['MODULE_TITLE'] = $language->get( 'heading_title' );
    $arParams['STORE_EMAIL'] = $config->get( 'config_email' );
    $arParams['STORE_TITLE'] = $config->get( 'config_name' );
    $arParams['STORE_ADMIN'] = $config->get( 'config_owner' );
    $arParams['SERVER_TIME'] = date( "H:i:s" );

    
    $FROM = $TM[ 'time_before' ];
    $AFTER = $TM[ 'time_after' ];
    $arParams['CURRENT_TIME_ENABLED'] = ( isset( $FROM ) ) ? $FROM . ':00' : '10' . ':00';
    $arParams['CURRENT_TIME_DISABLED'] = ( isset( $AFTER ) ) ? $AFTER . ':00' : '19' . ':00';

    // статус модуля
    if ( $arParams['STATUS']['MODULE'] == 1 ) {
        $status_module = true;
    }

    // если вкл cron
    if ( $arParams['STATUS']['CRON'] == 1 ) {
        $is_enable_cron = true;
    } else {
        unset( $_POST, $_GET, $arParams );
        die();
    }

    // статус почты
    if ( $arParams['STATUS']['TO_EMAIL'] == 1 ) {
        $send_email = true;
    }

    // статус: запись в лог
    if ( $arParams['STATUS']['LOG'] == 1 ) {
        $is_logger = true;
    }
    
    
    
    

    //проверка входных данных
    if ( isset( $request->get['check'] ) && $is_enable_cron ) {

        //проверка хеш-строки
        if ( $arParams['TXT_VALID2'] === $arParams['TXT_VALID1'] ) {

            $vw_point = $VWidget->timeoutWork( $arParams );
            $arParams['WORK'] = $vw_point;
            $arParams['VW_DESCRIPTION'] = $vw_point['STATUS_TEXT'];
            $arParams['VW_POINT'] = $vw_point['STATUS'];
            $arParams['VW_TITLE'] = $language->get( 'email_title' );


            if ( $vw_point['STATUS'] == 1 ) { // если рабочее время то проверяем дальше состояние кнопки
                $res = $db->query( "UPDATE `" . DB_PREFIX . "setting` SET `value` = '1' WHERE `code` = 'timeout_vw' AND `key` = 'timeout_vw_status'" );
                if ( !$res ) {
                    if ( $is_logger ) { //если вкл то записывать в лог-файл
                        $VWidget->logger( $language->get( "error_database" ) );
                    }
                }

                $arParams['VW_MESSAGE'] = $language->get( 'email_desc_open' );

                if ( $is_logger ) { // save log
                    $VWidget->logger( $language->get( "support_widget_enable" ) );
                }

                if ( $send_email ) { //если вкл опция то отправлять уведомление на почту
                    $VWidget->send_email( $arParams );
                }

            } else

                // если не рабочее время то проверяем дальше состояние кнопки
                if ( $vw_point['STATUS'] == 2 ) {
                    $res = $db->query( "UPDATE `" . DB_PREFIX . "setting` SET `value` = '0' WHERE `code` = 'timeout_vw' AND `key` = 'timeout_vw_status'" );
                    if ( !$res ) {
                        if ( $is_logger ) {
                            $VWidget->logger( $language->get( "error_database" ) );
                        }
                    }

                    $arParams['VW_MESSAGE'] = $language->get( 'email_desc_close' );

                    if ( $is_logger ) {
                        $VWidget->logger( $language->get( "support_widget_disable" ) );
                    }
                    if ( $send_email ) {
                        $VWidget->send_email( $arParams );
                    }

                } else {

                    if ( $is_logger ) { //если вкл то записывать в лог-файл
                        $VWidget->logger( $language->get( "error_unknown" ) );
                    }

                }


        } else {

            if ( $is_logger ) { //если вкл то записывать в лог-файл
                $VWidget->logger( $language->get("error_request_server") );
            }

        }

    } else {

        if ( $is_logger ) {
            $VWidget->logger( $language->get("error_request_cron") );
        }

    }

    unset( $arParams );
    die();

} else {
    die();
}



/**
 * @param $errno
 * @param $errstr
 * @param $errfile
 * @param $errline
 * @return bool
 */
function error_handler( $errno, $errstr, $errfile, $errline )
{
    $VWidget = new TimeOutVWidget();
    switch ( $errno ) {
        case E_NOTICE:
        case E_USER_NOTICE:
            $error = 'Notice';
            break;
        case E_WARNING:
        case E_USER_WARNING:
            $error = 'Warning';
            break;
        case E_ERROR:
        case E_USER_ERROR:
            $error = 'Fatal Error';
            break;
        default:
            $error = 'Unknown';
            break;
    }
    $VWidget->logger( 'PHP ' . $error . ':  ' . $errstr . ' in ' . $errfile . ' on line ' . $errline );
    return true;
}

?> ?>
Did this file decode correctly?
Original Code
<?php
// inc admin config file
require_once( dirname( __FILE__ ) . "/../admin/config.php" );

// Startup
require_once( DIR_SYSTEM . 'startup.php' );

// Registry
$registry = new Registry();

// Loader
$loader = new Loader( $registry );
$registry->set( 'load', $loader );

// Config
$config = new Config();
$registry->set( 'config', $config );

// Database
$db = new DB( DB_DRIVER, DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_DATABASE, DB_PORT );
$registry->set( 'db', $db );

putenv( "SERVER_NAME=localhost" );
apache_setenv ( "SERVER_NAME","localhost" );

// Error Handler
set_error_handler( 'error_handler' );


// Request
$request = new Request();
$registry->set( 'request', $request );

// Settings
$query = $db->query( "SELECT * FROM `" . DB_PREFIX . "setting` WHERE store_id = '0' OR store_id = '" . (int)$config->get( 'config_store_id' ) . "' ORDER BY store_id ASC" );
foreach ( $query->rows as $result ) {
    if ( !$result['serialized'] ) {
        $config->set( $result['key'], $result['value'] );
    } else {
        $config->set( $result['key'], json_decode( $result['value'], true ) );
    }
}

// Language Detection
$languages = array();
$query = $db->query( "SELECT * FROM " . DB_PREFIX . "language WHERE status = '1'" );
foreach ( $query->rows as $result ) {
    $languages[$result['code']] = $result;
}
$code = $config->get( 'config_language' );
$config->set( 'config_language_id', $languages[$code]['language_id'] );
$config->set( 'config_language', $languages[$code]['code'] );

// Language
$language = new Language( $languages[$code]['directory'] );
$language->load( 'default' );
$registry->set( 'language', $language );


if ( !empty( $request->get['check'] ) && $_SERVER['REQUEST_METHOD'] == 'GET' ) {

    require_once( dirname( __FILE__ ) . "/../system/library/timeout_vw/vw.class.php" );
    require_once( dirname( __FILE__ ) . "/../system/library/mail.php" );
    
    $VWidget = new TimeOutVWidget();

    $status_module = false;
    $is_logger = false;
    $is_enable_log = false;
    $send_email = false;
    $arParams = array();

    // get setting
    $TM_STATUS = $config->get( 'module_timeout_vw_status' );
    $TM = $config->get( 'module_timeout_vw' );
    $arParams['VERSION_OPENCART'] = '3.0';
    
    if ( version_compare( $arParams['VERSION_OPENCART'], '2.3', '>=' ) ) {
        $language->load( 'extension/module/timeout_vw' );
    } else {
        $language->load( 'module/timeout_vw' );
    }
    
    if ( version_compare( $arParams['VERSION_OPENCART'], '2.3', '>=' ) ) {
        $arParams['EDIT_MODULE'] = HTTP_CATALOG.'/admin/index.php?route=extension/module/timeout_vw';
    } else {
        $arParams['EDIT_MODULE'] = HTTP_CATALOG.'/admin/index.php?route=module/timeout_vw';
    }

    $arParams['TXT_VALID1'] = htmlspecialchars( $VWidget->getKey() );
    $arParams['TXT_VALID2'] = htmlspecialchars( $request->get['check'], ENT_COMPAT, 'UTF-8' );
    $arParams['STATUS']['MODULE'] = intval( $TM_STATUS );
    $arParams['STATUS']['CRON'] = intval( $TM[ 'enable' ] );
    $arParams['STATUS']['LOG'] = intval( $TM[ 'logger' ] );
    $arParams['STATUS']['TO_EMAIL'] = intval( $TM[ 'email' ] );
    $arParams['ADMIN_TIMEZONE'] = $TM[ 'timezone' ];
    $arParams['CLIENT_DOMAIN'] = HTTP_CATALOG;
    $arParams['MODULE_TITLE'] = $language->get( 'heading_title' );
    $arParams['STORE_EMAIL'] = $config->get( 'config_email' );
    $arParams['STORE_TITLE'] = $config->get( 'config_name' );
    $arParams['STORE_ADMIN'] = $config->get( 'config_owner' );
    $arParams['SERVER_TIME'] = date( "H:i:s" );

    
    $FROM = $TM[ 'time_before' ];
    $AFTER = $TM[ 'time_after' ];
    $arParams['CURRENT_TIME_ENABLED'] = ( isset( $FROM ) ) ? $FROM . ':00' : '10' . ':00';
    $arParams['CURRENT_TIME_DISABLED'] = ( isset( $AFTER ) ) ? $AFTER . ':00' : '19' . ':00';

    // статус модуля
    if ( $arParams['STATUS']['MODULE'] == 1 ) {
        $status_module = true;
    }

    // если вкл cron
    if ( $arParams['STATUS']['CRON'] == 1 ) {
        $is_enable_cron = true;
    } else {
        unset( $_POST, $_GET, $arParams );
        die();
    }

    // статус почты
    if ( $arParams['STATUS']['TO_EMAIL'] == 1 ) {
        $send_email = true;
    }

    // статус: запись в лог
    if ( $arParams['STATUS']['LOG'] == 1 ) {
        $is_logger = true;
    }
    
    
    
    

    //проверка входных данных
    if ( isset( $request->get['check'] ) && $is_enable_cron ) {

        //проверка хеш-строки
        if ( $arParams['TXT_VALID2'] === $arParams['TXT_VALID1'] ) {

            $vw_point = $VWidget->timeoutWork( $arParams );
            $arParams['WORK'] = $vw_point;
            $arParams['VW_DESCRIPTION'] = $vw_point['STATUS_TEXT'];
            $arParams['VW_POINT'] = $vw_point['STATUS'];
            $arParams['VW_TITLE'] = $language->get( 'email_title' );


            if ( $vw_point['STATUS'] == 1 ) { // если рабочее время то проверяем дальше состояние кнопки
                $res = $db->query( "UPDATE `" . DB_PREFIX . "setting` SET `value` = '1' WHERE `code` = 'timeout_vw' AND `key` = 'timeout_vw_status'" );
                if ( !$res ) {
                    if ( $is_logger ) { //если вкл то записывать в лог-файл
                        $VWidget->logger( $language->get( "error_database" ) );
                    }
                }

                $arParams['VW_MESSAGE'] = $language->get( 'email_desc_open' );

                if ( $is_logger ) { // save log
                    $VWidget->logger( $language->get( "support_widget_enable" ) );
                }

                if ( $send_email ) { //если вкл опция то отправлять уведомление на почту
                    $VWidget->send_email( $arParams );
                }

            } else

                // если не рабочее время то проверяем дальше состояние кнопки
                if ( $vw_point['STATUS'] == 2 ) {
                    $res = $db->query( "UPDATE `" . DB_PREFIX . "setting` SET `value` = '0' WHERE `code` = 'timeout_vw' AND `key` = 'timeout_vw_status'" );
                    if ( !$res ) {
                        if ( $is_logger ) {
                            $VWidget->logger( $language->get( "error_database" ) );
                        }
                    }

                    $arParams['VW_MESSAGE'] = $language->get( 'email_desc_close' );

                    if ( $is_logger ) {
                        $VWidget->logger( $language->get( "support_widget_disable" ) );
                    }
                    if ( $send_email ) {
                        $VWidget->send_email( $arParams );
                    }

                } else {

                    if ( $is_logger ) { //если вкл то записывать в лог-файл
                        $VWidget->logger( $language->get( "error_unknown" ) );
                    }

                }


        } else {

            if ( $is_logger ) { //если вкл то записывать в лог-файл
                $VWidget->logger( $language->get("error_request_server") );
            }

        }

    } else {

        if ( $is_logger ) {
            $VWidget->logger( $language->get("error_request_cron") );
        }

    }

    unset( $arParams );
    die();

} else {
    die();
}



/**
 * @param $errno
 * @param $errstr
 * @param $errfile
 * @param $errline
 * @return bool
 */
function error_handler( $errno, $errstr, $errfile, $errline )
{
    $VWidget = new TimeOutVWidget();
    switch ( $errno ) {
        case E_NOTICE:
        case E_USER_NOTICE:
            $error = 'Notice';
            break;
        case E_WARNING:
        case E_USER_WARNING:
            $error = 'Warning';
            break;
        case E_ERROR:
        case E_USER_ERROR:
            $error = 'Fatal Error';
            break;
        default:
            $error = 'Unknown';
            break;
    }
    $VWidget->logger( 'PHP ' . $error . ':  ' . $errstr . ' in ' . $errfile . ' on line ' . $errline );
    return true;
}

?>
Function Calls
None |
Stats
MD5 | 89474fbe35a4e7dc5b07ff5e25c7b9a0 |
Eval Count | 0 |
Decode Time | 100 ms |