!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache. PHP/8.1.30 

uname -a: Linux server1.tuhinhossain.com 5.15.0-163-generic #173-Ubuntu SMP Tue Oct 14 17:51:00 UTC
2025 x86_64
 

uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root)  

Safe-mode: OFF (not secure)

/home/picotech/domains/test.sms.picotech.app/public_html/database/migrations/   drwxr-xr-x
Free 25.19 GB of 117.98 GB (21.35%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     2025_07_07_070234_permission.php (6.32 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

use Illuminate\Support\Facades\Schema;
use 
Illuminate\Database\Schema\Blueprint;
use 
Illuminate\Database\Migrations\Migration;

return new class extends 
Migration
{
    
/**
     * Run the migrations.
     */
    
public function up(): void
    
{
        
$teams config('permission.teams');
        
$tableNames config('permission.table_names');
        
$columnNames config('permission.column_names');
        
$pivotRole $columnNames['role_pivot_key'] ?? 'role_id';
        
$pivotPermission $columnNames['permission_pivot_key'] ?? 'permission_id';

        if (empty(
$tableNames)) {
            throw new 
\Exception('Error: config/permission.php not loaded. Run [php artisan config:clear] and try again.');
        }
        if (
$teams && empty($columnNames['team_foreign_key'] ?? null)) {
            throw new 
\Exception('Error: team_foreign_key on config/permission.php not loaded. Run [php artisan config:clear] and try again.');
        }

        
Schema::create($tableNames['permissions'], function (Blueprint $table) {
            
$table->bigIncrements('id'); // permission id
            
$table->string('name');       // For MySQL 8.0 use string('name', 125);
            
$table->string('guard_name'); // For MySQL 8.0 use string('guard_name', 125);
            
$table->timestamps();

            
$table->unique(['name''guard_name']);
        });

        
Schema::create($tableNames['roles'], function (Blueprint $table) use ($teams$columnNames) {
            
$table->bigIncrements('id'); // role id
            
if ($teams || config('permission.testing')) { // permission.testing is a fix for sqlite testing
                
$table->unsignedBigInteger($columnNames['team_foreign_key'])->nullable();
                
$table->index($columnNames['team_foreign_key'], 'roles_team_foreign_key_index');
            }
            
$table->string('name');       // For MySQL 8.0 use string('name', 125);
            
$table->string('guard_name'); // For MySQL 8.0 use string('guard_name', 125);
            
$table->string('admin_id')->nullable(); // For MySQL 8.0 use string('guard_name', 125);
            
$table->timestamps();
            if (
$teams || config('permission.testing')) {
                
$table->unique([$columnNames['team_foreign_key'], 'name''guard_name']);
            } else {
                
$table->unique(['name''guard_name']);
            }
        });

        
Schema::create($tableNames['model_has_permissions'], function (Blueprint $table) use ($tableNames$columnNames$pivotPermission$teams) {
            
$table->unsignedBigInteger($pivotPermission);

            
$table->string('model_type');
            
$table->unsignedBigInteger($columnNames['model_morph_key']);
            
$table->index([$columnNames['model_morph_key'], 'model_type'], 'model_has_permissions_model_id_model_type_index');

            
$table->foreign($pivotPermission)
                ->
references('id'// permission id
                
->on($tableNames['permissions'])
                ->
onDelete('cascade');
            if (
$teams) {
                
$table->unsignedBigInteger($columnNames['team_foreign_key']);
                
$table->index($columnNames['team_foreign_key'], 'model_has_permissions_team_foreign_key_index');

                
$table->primary([$columnNames['team_foreign_key'], $pivotPermission$columnNames['model_morph_key'], 'model_type'],
                    
'model_has_permissions_permission_model_type_primary');
            } else {
                
$table->primary([$pivotPermission$columnNames['model_morph_key'], 'model_type'],
                    
'model_has_permissions_permission_model_type_primary');
            }

        });

        
Schema::create($tableNames['model_has_roles'], function (Blueprint $table) use ($tableNames$columnNames$pivotRole$teams) {
            
$table->unsignedBigInteger($pivotRole);

            
$table->string('model_type');
            
$table->unsignedBigInteger($columnNames['model_morph_key']);
            
$table->index([$columnNames['model_morph_key'], 'model_type'], 'model_has_roles_model_id_model_type_index');

            
$table->foreign($pivotRole)
                ->
references('id'// role id
                
->on($tableNames['roles'])
                ->
onDelete('cascade');
            if (
$teams) {
                
$table->unsignedBigInteger($columnNames['team_foreign_key']);
                
$table->index($columnNames['team_foreign_key'], 'model_has_roles_team_foreign_key_index');

                
$table->primary([$columnNames['team_foreign_key'], $pivotRole$columnNames['model_morph_key'], 'model_type'],
                    
'model_has_roles_role_model_type_primary');
            } else {
                
$table->primary([$pivotRole$columnNames['model_morph_key'], 'model_type'],
                    
'model_has_roles_role_model_type_primary');
            }
        });

        
Schema::create($tableNames['role_has_permissions'], function (Blueprint $table) use ($tableNames$pivotRole$pivotPermission) {
            
$table->unsignedBigInteger($pivotPermission);
            
$table->unsignedBigInteger($pivotRole);

            
$table->foreign($pivotPermission)
                ->
references('id'// permission id
                
->on($tableNames['permissions'])
                ->
onDelete('cascade');

            
$table->foreign($pivotRole)
                ->
references('id'// role id
                
->on($tableNames['roles'])
                ->
onDelete('cascade');

            
$table->primary([$pivotPermission$pivotRole], 'role_has_permissions_permission_id_role_id_primary');
        });

        
app('cache')
            ->
store(config('permission.cache.store') != 'default' config('permission.cache.store') : null)
            ->
forget(config('permission.cache.key'));
    }

    
/**
     * Reverse the migrations.
     */
    
public function down(): void
    
{
        
$tableNames config('permission.table_names');

        if (empty(
$tableNames)) {
            throw new 
\Exception('Error: config/permission.php not found and defaults could not be merged. Please publish the package configuration before proceeding, or drop the tables manually.');
        }

        
Schema::drop($tableNames['role_has_permissions']);
        
Schema::drop($tableNames['model_has_roles']);
        
Schema::drop($tableNames['model_has_permissions']);
        
Schema::drop($tableNames['roles']);
        
Schema::drop($tableNames['permissions']);
    }
};

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0046 ]--