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

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/laravel-crm/packages/Webkul/DataTransfer/src/Helpers/Importers/Persons/   drwxrwxrwx
Free 12.99 GB of 57.97 GB (22.41%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     Storage.php (2.11 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace Webkul\DataTransfer\Helpers\Importers\Persons;

use 
Webkul\Contact\Repositories\PersonRepository;

class 
Storage
{
    
/**
     * Items contains email as key and product information as value.
     */
    
protected array $items = [];

    
/**
     * Columns which will be selected from database.
     */
    
protected array $selectColumns = [
        
'id',
        
'emails',
    ];

    
/**
     * Create a new helper instance.
     *
     * @return void
     */
    
public function __construct(protected PersonRepository $personRepository) {}

    
/**
     * Initialize storage.
     */
    
public function init(): void
    
{
        
$this->items = [];

        
$this->load();
    }

    
/**
     * Load the Emails.
     */
    
public function load(array $emails = []): void
    
{
        if (empty(
$emails)) {
            
$persons $this->personRepository->all($this->selectColumns);
        } else {
            
$persons $this->personRepository->scopeQuery(function ($query) use ($emails) {
                return 
$query->where(function ($subQuery) use ($emails) {
                    foreach (
$emails as $email) {
                        
$subQuery->orWhereJsonContains('emails', ['value' => $email]);
                    }
                });
            })->
all($this->selectColumns);
        }

        
$persons->each(function ($person) {
            
collect($person->emails)
                ->
each(fn ($email) => $this->set($email['value'], $person->id));
        });
    }

    
/**
     * Get email information.
     */
    
public function set(string $emailint $id): self
    
{
        
$this->items[$email] = $id;

        return 
$this;
    }

    
/**
     * Check if email exists.
     */
    
public function has(string $email): bool
    
{
        return isset(
$this->items[$email]);
    }

    
/**
     * Get email information.
     */
    
public function get(string $email): ?int
    
{
        if (! 
$this->has($email)) {
            return 
null;
        }

        return 
$this->items[$email];
    }

    
/**
     * Is storage is empty.
     */
    
public function isEmpty(): int
    
{
        return empty(
$this->items);
    }
}

:: 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.0091 ]--