Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php /** * This file is part of the Zephir. * * (c) Phalcon Team <[email protected]..

Decoded Output download

<?php

/**
 * This file is part of the Zephir.
 *
 * (c) Phalcon Team <[email protected]>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

declare(strict_types=1);

namespace Zephir\Backend;

use Zephir\FileSystem\HardDisk;
use Zephir\StringsManager as BaseStringsManager;

use function count;
use function implode;
use function ksort;
use function strlen;
use function strtoupper;
use function substr;

use const PHP_EOL;
use const SORT_STRING;

/**
 * Manages the concatenation keys for the extension and the interned strings
 */
class StringsManager extends BaseStringsManager
{
    /**
     * Adds a concatenation combination to the manager.
     */
    public function addConcatKey(string $key): void
    {
        $this->concatKeys[$key] = true;
    }

    /**
     * Generates the concatenation code.
     */
    public function genConcatCode(): void
    {
        $code   = '
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <php.h>
#include "php_ext.h"
#include <ext/standard/php_string.h>
#include "ext.h"
#include "kernel/main.h"
#include "kernel/memory.h"
#include "kernel/concat.h"' . PHP_EOL . PHP_EOL;
        $pcodeh = '
#ifndef ZEPHIR_KERNEL_CONCAT_H
#define ZEPHIR_KERNEL_CONCAT_H
#include <php.h>
#include <Zend/zend.h>
#include "kernel/main.h"
';
        $codeh  = '';

        $macros = [];
        ksort($this->concatKeys, SORT_STRING);
        foreach ($this->concatKeys as $key => $one) {
            $len      = strlen($key);
            $params   = [];
            $zvalCopy = [];
            $useCopy  = [];
            $avars    = [];
            $zvars    = [];
            $lengths  = [];
            $sparams  = [];
            $lparams  = [];
            for ($i = 0; $i < $len; ++$i) {
                $n         = $i + 1;
                $t         = substr($key, $i, 1);
                $sparams[] = 'op' . $n;
                if ('s' == $t) {
                    $params[]  = 'const char *op' . $n . ', uint32_t op' . $n . '_len';
                    $lparams[] = 'op' . $n . ', sizeof(op' . $n . ')-1';
                    $lengths[] = 'op' . $n . '_len';
                    $avars[$n] = 's';
                } else {
                    $params[]   = 'zval *op' . $n;
                    $lparams[]  = 'op' . $n;
                    $zvalCopy[] = 'op' . $n . '_copy';
                    $useCopy[]  = 'use_copy' . $n . ' = 0';
                    $lengths[]  = 'Z_STRLEN_P(op' . $n . ')';
                    $zvars[]    = $n;
                    $avars[$n]  = 'v';
                }
            }

            $macros[] = '#define ZEPHIR_CONCAT_'
                . strtoupper($key)
                . '(result, '
                . implode(', ', $sparams)
                . ') \'
                . PHP_EOL
                . "	"
                . ' zephir_concat_'
                . $key
                . '(result, '
                . implode(', ', $lparams)
                . ', 0);';
            $macros[] = '#define ZEPHIR_SCONCAT_'
                . strtoupper($key)
                . '(result, '
                . implode(', ', $sparams)
                . ') \'
                . PHP_EOL
                . "	"
                . ' zephir_concat_'
                . $key
                . '(result, '
                . implode(', ', $lparams)
                . ', 1);';
            $macros[] = '';

            $proto = 'void zephir_concat_'
                . $key
                . '(zval *result, '
                . implode(', ', $params)
                . ', int self_var)';

            $codeh .= $proto . ';' . PHP_EOL;

            $code .= $proto . '{' . PHP_EOL . PHP_EOL;

            if (count($zvalCopy)) {
                $code .= "	" . 'zval result_copy, ' . implode(', ', $zvalCopy) . ';' . PHP_EOL;
                $code .= "	" . 'int use_copy = 0, ' . implode(', ', $useCopy) . ';' . PHP_EOL;
            } else {
                $code .= "	" . 'zval result_copy;' . PHP_EOL;
                $code .= "	" . 'int use_copy = 0;' . PHP_EOL;
            }
            $code .= "	" . 'size_t offset = 0, length;' . PHP_EOL . PHP_EOL;

            foreach ($zvars as $zvar) {
                $code .= "	" . 'if (Z_TYPE_P(op' . $zvar . ') != IS_STRING) {' . PHP_EOL;
                $code .= "	" . '   use_copy' . $zvar . ' = zend_make_printable_zval(op' . $zvar . ', &op' . $zvar . '_copy);' . PHP_EOL;
                $code .= "	" . '   if (use_copy' . $zvar . ') {' . PHP_EOL;
                $code .= "	" . '       op' . $zvar . ' = &op' . $zvar . '_copy;' . PHP_EOL;
                $code .= "	" . '   }' . PHP_EOL;
                $code .= "	" . '}' . PHP_EOL . PHP_EOL;
            }

            $code .= "	" . 'length = ' . implode(' + ', $lengths) . ';' . PHP_EOL;
            $code .= "	" . 'if (self_var) {' . PHP_EOL;
            $code .= PHP_EOL;
            $code .= "		" . 'if (Z_TYPE_P(result) != IS_STRING) {' . PHP_EOL;
            $code .= "			" . 'use_copy = zend_make_printable_zval(result, &result_copy);' . PHP_EOL;
            $code .= "			" . 'if (use_copy) {' . PHP_EOL;
            $code .= "				" . 'ZEPHIR_CPY_WRT_CTOR(result, (&result_copy));' . PHP_EOL;
            $code .= "			" . '}' . PHP_EOL;
            $code .= "		" . '}' . PHP_EOL . PHP_EOL;
            $code .= "		" . 'offset = Z_STRLEN_P(result);' . PHP_EOL;
            $code .= "		" . 'length += offset;' . PHP_EOL;
            $code .= "		" . 'Z_STR_P(result) = zend_string_realloc(Z_STR_P(result), length, 0);' . PHP_EOL;
            $code .= PHP_EOL;
            $code .= "	" . '} else {' . PHP_EOL;
            $code .= "		" . 'ZVAL_STR(result, zend_string_alloc(length, 0));' . PHP_EOL;
            $code .= "	" . '}' . PHP_EOL . PHP_EOL;

            $position = '';
            foreach ($avars as $n => $type) {
                if ('s' == $type) {
                    $code     .= "	" . 'memcpy(Z_STRVAL_P(result) + offset' . $position . ', op' . $n . ', op' . $n . '_len);' . PHP_EOL;
                    $position .= ' + op' . $n . '_len';
                } else {
                    $code     .= "	" . 'memcpy(Z_STRVAL_P(result) + offset' . $position . ', Z_STRVAL_P(op' . $n . '), Z_STRLEN_P(op' . $n . '));' . PHP_EOL;
                    $position .= ' + Z_STRLEN_P(op' . $n . ')';
                }
            }

            $code .= "	" . 'Z_STRVAL_P(result)[length] = 0;' . PHP_EOL;
            $code .= "	" . 'zend_string_forget_hash_val(Z_STR_P(result));' . PHP_EOL;

            foreach ($zvars as $zvar) {
                $code .= "	" . 'if (use_copy' . $zvar . ') {' . PHP_EOL;
                $code .= "	" . '   zval_dtor(op' . $zvar . ');' . PHP_EOL;
                $code .= "	" . '}' . PHP_EOL . PHP_EOL;
            }

            $code .= "	" . 'if (use_copy) {' . PHP_EOL;
            $code .= "	" . '   zval_dtor(&result_copy);' . PHP_EOL;
            $code .= "	" . '}' . PHP_EOL . PHP_EOL;

            $code .= '}' . PHP_EOL . PHP_EOL;
        }

        $code .= <<<EOF
            void zephir_concat_function(zval *result, zval *op1, zval *op2)
            {
            	zval tmp;
            	SEPARATE_ZVAL_NOREF(result);

            	/*
            		res == op1 == op2: won't leak
            		res == op1 != op2: won't leak
            		res == op2 != op1: will leak
            	 */
            	if (result == op2 && result != op1) {
            		ZVAL_COPY_VALUE(&tmp, result);
            		ZVAL_NULL(result);
            		op2 = &tmp;
            	}
            	else {
            		ZVAL_UNDEF(&tmp);
            	}

            	concat_function(result, op1, op2);
            	assert(!Z_REFCOUNTED(tmp) || 1 == Z_REFCOUNT(tmp));
            	zval_dtor(&tmp);
            }
            EOF;

        $codeh    .= 'void zephir_concat_function(zval *result, zval *op1, zval *op2);
#endif /* ZEPHIR_KERNEL_CONCAT_H */
';
        $contents = $pcodeh . implode(PHP_EOL, $macros) . PHP_EOL . PHP_EOL . $codeh;
        HardDisk::persistByHash($contents, 'ext/kernel/concat.h');
        HardDisk::persistByHash($code, 'ext/kernel/concat.c');
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

/**
 * This file is part of the Zephir.
 *
 * (c) Phalcon Team <[email protected]>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

declare(strict_types=1);

namespace Zephir\Backend;

use Zephir\FileSystem\HardDisk;
use Zephir\StringsManager as BaseStringsManager;

use function count;
use function implode;
use function ksort;
use function strlen;
use function strtoupper;
use function substr;

use const PHP_EOL;
use const SORT_STRING;

/**
 * Manages the concatenation keys for the extension and the interned strings
 */
class StringsManager extends BaseStringsManager
{
    /**
     * Adds a concatenation combination to the manager.
     */
    public function addConcatKey(string $key): void
    {
        $this->concatKeys[$key] = true;
    }

    /**
     * Generates the concatenation code.
     */
    public function genConcatCode(): void
    {
        $code   = '
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <php.h>
#include "php_ext.h"
#include <ext/standard/php_string.h>
#include "ext.h"
#include "kernel/main.h"
#include "kernel/memory.h"
#include "kernel/concat.h"' . PHP_EOL . PHP_EOL;
        $pcodeh = '
#ifndef ZEPHIR_KERNEL_CONCAT_H
#define ZEPHIR_KERNEL_CONCAT_H
#include <php.h>
#include <Zend/zend.h>
#include "kernel/main.h"
';
        $codeh  = '';

        $macros = [];
        ksort($this->concatKeys, SORT_STRING);
        foreach ($this->concatKeys as $key => $one) {
            $len      = strlen($key);
            $params   = [];
            $zvalCopy = [];
            $useCopy  = [];
            $avars    = [];
            $zvars    = [];
            $lengths  = [];
            $sparams  = [];
            $lparams  = [];
            for ($i = 0; $i < $len; ++$i) {
                $n         = $i + 1;
                $t         = substr($key, $i, 1);
                $sparams[] = 'op' . $n;
                if ('s' == $t) {
                    $params[]  = 'const char *op' . $n . ', uint32_t op' . $n . '_len';
                    $lparams[] = 'op' . $n . ', sizeof(op' . $n . ')-1';
                    $lengths[] = 'op' . $n . '_len';
                    $avars[$n] = 's';
                } else {
                    $params[]   = 'zval *op' . $n;
                    $lparams[]  = 'op' . $n;
                    $zvalCopy[] = 'op' . $n . '_copy';
                    $useCopy[]  = 'use_copy' . $n . ' = 0';
                    $lengths[]  = 'Z_STRLEN_P(op' . $n . ')';
                    $zvars[]    = $n;
                    $avars[$n]  = 'v';
                }
            }

            $macros[] = '#define ZEPHIR_CONCAT_'
                . strtoupper($key)
                . '(result, '
                . implode(', ', $sparams)
                . ') \\'
                . PHP_EOL
                . "\t"
                . ' zephir_concat_'
                . $key
                . '(result, '
                . implode(', ', $lparams)
                . ', 0);';
            $macros[] = '#define ZEPHIR_SCONCAT_'
                . strtoupper($key)
                . '(result, '
                . implode(', ', $sparams)
                . ') \\'
                . PHP_EOL
                . "\t"
                . ' zephir_concat_'
                . $key
                . '(result, '
                . implode(', ', $lparams)
                . ', 1);';
            $macros[] = '';

            $proto = 'void zephir_concat_'
                . $key
                . '(zval *result, '
                . implode(', ', $params)
                . ', int self_var)';

            $codeh .= $proto . ';' . PHP_EOL;

            $code .= $proto . '{' . PHP_EOL . PHP_EOL;

            if (count($zvalCopy)) {
                $code .= "\t" . 'zval result_copy, ' . implode(', ', $zvalCopy) . ';' . PHP_EOL;
                $code .= "\t" . 'int use_copy = 0, ' . implode(', ', $useCopy) . ';' . PHP_EOL;
            } else {
                $code .= "\t" . 'zval result_copy;' . PHP_EOL;
                $code .= "\t" . 'int use_copy = 0;' . PHP_EOL;
            }
            $code .= "\t" . 'size_t offset = 0, length;' . PHP_EOL . PHP_EOL;

            foreach ($zvars as $zvar) {
                $code .= "\t" . 'if (Z_TYPE_P(op' . $zvar . ') != IS_STRING) {' . PHP_EOL;
                $code .= "\t" . '   use_copy' . $zvar . ' = zend_make_printable_zval(op' . $zvar . ', &op' . $zvar . '_copy);' . PHP_EOL;
                $code .= "\t" . '   if (use_copy' . $zvar . ') {' . PHP_EOL;
                $code .= "\t" . '       op' . $zvar . ' = &op' . $zvar . '_copy;' . PHP_EOL;
                $code .= "\t" . '   }' . PHP_EOL;
                $code .= "\t" . '}' . PHP_EOL . PHP_EOL;
            }

            $code .= "\t" . 'length = ' . implode(' + ', $lengths) . ';' . PHP_EOL;
            $code .= "\t" . 'if (self_var) {' . PHP_EOL;
            $code .= PHP_EOL;
            $code .= "\t\t" . 'if (Z_TYPE_P(result) != IS_STRING) {' . PHP_EOL;
            $code .= "\t\t\t" . 'use_copy = zend_make_printable_zval(result, &result_copy);' . PHP_EOL;
            $code .= "\t\t\t" . 'if (use_copy) {' . PHP_EOL;
            $code .= "\t\t\t\t" . 'ZEPHIR_CPY_WRT_CTOR(result, (&result_copy));' . PHP_EOL;
            $code .= "\t\t\t" . '}' . PHP_EOL;
            $code .= "\t\t" . '}' . PHP_EOL . PHP_EOL;
            $code .= "\t\t" . 'offset = Z_STRLEN_P(result);' . PHP_EOL;
            $code .= "\t\t" . 'length += offset;' . PHP_EOL;
            $code .= "\t\t" . 'Z_STR_P(result) = zend_string_realloc(Z_STR_P(result), length, 0);' . PHP_EOL;
            $code .= PHP_EOL;
            $code .= "\t" . '} else {' . PHP_EOL;
            $code .= "\t\t" . 'ZVAL_STR(result, zend_string_alloc(length, 0));' . PHP_EOL;
            $code .= "\t" . '}' . PHP_EOL . PHP_EOL;

            $position = '';
            foreach ($avars as $n => $type) {
                if ('s' == $type) {
                    $code     .= "\t" . 'memcpy(Z_STRVAL_P(result) + offset' . $position . ', op' . $n . ', op' . $n . '_len);' . PHP_EOL;
                    $position .= ' + op' . $n . '_len';
                } else {
                    $code     .= "\t" . 'memcpy(Z_STRVAL_P(result) + offset' . $position . ', Z_STRVAL_P(op' . $n . '), Z_STRLEN_P(op' . $n . '));' . PHP_EOL;
                    $position .= ' + Z_STRLEN_P(op' . $n . ')';
                }
            }

            $code .= "\t" . 'Z_STRVAL_P(result)[length] = 0;' . PHP_EOL;
            $code .= "\t" . 'zend_string_forget_hash_val(Z_STR_P(result));' . PHP_EOL;

            foreach ($zvars as $zvar) {
                $code .= "\t" . 'if (use_copy' . $zvar . ') {' . PHP_EOL;
                $code .= "\t" . '   zval_dtor(op' . $zvar . ');' . PHP_EOL;
                $code .= "\t" . '}' . PHP_EOL . PHP_EOL;
            }

            $code .= "\t" . 'if (use_copy) {' . PHP_EOL;
            $code .= "\t" . '   zval_dtor(&result_copy);' . PHP_EOL;
            $code .= "\t" . '}' . PHP_EOL . PHP_EOL;

            $code .= '}' . PHP_EOL . PHP_EOL;
        }

        $code .= <<<EOF
            void zephir_concat_function(zval *result, zval *op1, zval *op2)
            {
            	zval tmp;
            	SEPARATE_ZVAL_NOREF(result);

            	/*
            		res == op1 == op2: won't leak
            		res == op1 != op2: won't leak
            		res == op2 != op1: will leak
            	 */
            	if (result == op2 && result != op1) {
            		ZVAL_COPY_VALUE(&tmp, result);
            		ZVAL_NULL(result);
            		op2 = &tmp;
            	}
            	else {
            		ZVAL_UNDEF(&tmp);
            	}

            	concat_function(result, op1, op2);
            	assert(!Z_REFCOUNTED(tmp) || 1 == Z_REFCOUNT(tmp));
            	zval_dtor(&tmp);
            }
            EOF;

        $codeh    .= 'void zephir_concat_function(zval *result, zval *op1, zval *op2);
#endif /* ZEPHIR_KERNEL_CONCAT_H */
';
        $contents = $pcodeh . implode(PHP_EOL, $macros) . PHP_EOL . PHP_EOL . $codeh;
        HardDisk::persistByHash($contents, 'ext/kernel/concat.h');
        HardDisk::persistByHash($code, 'ext/kernel/concat.c');
    }
}

Function Calls

None

Variables

None

Stats

MD5 1e168beee569f2a05c9ea7ebb8aac97b
Eval Count 0
Decode Time 94 ms