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 use App\Models\CustomField; use Illuminate\Database\Migrations\Migration; use Illum..

Decoded Output download

<?php

use App\Models\CustomField;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Str;

/**
 * Fixes issue #2551 where columns got donked if the field name in non-ascii
 * format.
 *
 * The only time this is ever called is in the
 * 2017_01_25_063357_fix_utf8_custom_field_column_names.php migration
 * as a one-time fix.
 *
 * @author [A. Gianotto] [<[email protected]>]
 * @since [v4.0]
 * @return array
 */
function updateLegacyColumnName($customfield)
{
    $name_to_db_name = CustomField::name_to_db_name($customfield->name);
    //\Log::debug('Trying to rename '.$name_to_db_name." to ".$customfield->convertUnicodeDbSlug()."...
");

    if (Schema::hasColumn(CustomField::$table_name, $name_to_db_name)) {
        return Schema::table(CustomField::$table_name,
            function ($table) use ($name_to_db_name, $customfield) {
                $table->renameColumn($name_to_db_name, $customfield->convertUnicodeDbSlug());
            }
        );
    } else {
        //\Log::debug('Legacy DB column '.$name_to_db_name.' was not found on the assets table.');
    }
}

class FixUtf8CustomFieldColumnNames extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        $platform = Schema::getConnection()->getDoctrineSchemaManager()->getDatabasePlatform();
        $platform->registerDoctrineTypeMapping('enum', 'string');

        if (! Schema::hasColumn('custom_fields', 'db_column')) {
            Schema::table('custom_fields', function ($table) {
                $table->string('db_column')->nullable();
                $table->text('help_text')->nullable();
            });
        }

        foreach (CustomField::all() as $field) {
            $db_column = $field->convertUnicodeDbSlug();

            DB::table('custom_fields')
                ->where('id', $field->id)
                ->update(['db_column' => $db_column]);

            // change the name of the column
            updateLegacyColumnName($field);
        }
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        // In the up method above, updateLegacyColumnName is called and custom fields in the assets table are prefixed
        // with "_snipe_it_", suffixed with "_{id of the CustomField}", and stored in custom_fields.db_column.
        // The following reverses those changes.
        foreach (CustomField::all() as $field) {
            $currentColumnName = $field->db_column;

            // "_snipeit_imei_1" becomes "_snipeit_imei"
            $legacyColumnName = (string) Str::of($currentColumnName)->replaceMatches('/_(\d)+$/', '');

            if (Schema::hasColumn(CustomField::$table_name, $currentColumnName)) {
                Schema::table(CustomField::$table_name, function (Blueprint $table) use ($currentColumnName, $legacyColumnName) {
                    $table->renameColumn(
                        $currentColumnName,
                        $legacyColumnName
                    );
                });
            }
        }

        Schema::table('custom_fields', function ($table) {
            $table->dropColumn('db_column');
            $table->dropColumn('help_text');
        });
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

use App\Models\CustomField;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Str;

/**
 * Fixes issue #2551 where columns got donked if the field name in non-ascii
 * format.
 *
 * The only time this is ever called is in the
 * 2017_01_25_063357_fix_utf8_custom_field_column_names.php migration
 * as a one-time fix.
 *
 * @author [A. Gianotto] [<[email protected]>]
 * @since [v4.0]
 * @return array
 */
function updateLegacyColumnName($customfield)
{
    $name_to_db_name = CustomField::name_to_db_name($customfield->name);
    //\Log::debug('Trying to rename '.$name_to_db_name." to ".$customfield->convertUnicodeDbSlug()."...\n");

    if (Schema::hasColumn(CustomField::$table_name, $name_to_db_name)) {
        return Schema::table(CustomField::$table_name,
            function ($table) use ($name_to_db_name, $customfield) {
                $table->renameColumn($name_to_db_name, $customfield->convertUnicodeDbSlug());
            }
        );
    } else {
        //\Log::debug('Legacy DB column '.$name_to_db_name.' was not found on the assets table.');
    }
}

class FixUtf8CustomFieldColumnNames extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        $platform = Schema::getConnection()->getDoctrineSchemaManager()->getDatabasePlatform();
        $platform->registerDoctrineTypeMapping('enum', 'string');

        if (! Schema::hasColumn('custom_fields', 'db_column')) {
            Schema::table('custom_fields', function ($table) {
                $table->string('db_column')->nullable();
                $table->text('help_text')->nullable();
            });
        }

        foreach (CustomField::all() as $field) {
            $db_column = $field->convertUnicodeDbSlug();

            DB::table('custom_fields')
                ->where('id', $field->id)
                ->update(['db_column' => $db_column]);

            // change the name of the column
            updateLegacyColumnName($field);
        }
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        // In the up method above, updateLegacyColumnName is called and custom fields in the assets table are prefixed
        // with "_snipe_it_", suffixed with "_{id of the CustomField}", and stored in custom_fields.db_column.
        // The following reverses those changes.
        foreach (CustomField::all() as $field) {
            $currentColumnName = $field->db_column;

            // "_snipeit_imei_1" becomes "_snipeit_imei"
            $legacyColumnName = (string) Str::of($currentColumnName)->replaceMatches('/_(\d)+$/', '');

            if (Schema::hasColumn(CustomField::$table_name, $currentColumnName)) {
                Schema::table(CustomField::$table_name, function (Blueprint $table) use ($currentColumnName, $legacyColumnName) {
                    $table->renameColumn(
                        $currentColumnName,
                        $legacyColumnName
                    );
                });
            }
        }

        Schema::table('custom_fields', function ($table) {
            $table->dropColumn('db_column');
            $table->dropColumn('help_text');
        });
    }
}

Function Calls

None

Variables

None

Stats

MD5 4dfd9c09c7b3335a17820cf648a52859
Eval Count 0
Decode Time 101 ms