404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.14.130.58: ~ $
<?php

namespace Illuminate\Cache;

use Illuminate\Contracts\Cache\LockProvider;
use Illuminate\Support\InteractsWithTime;

class ArrayStore extends TaggableStore implements LockProvider
{
    use InteractsWithTime, RetrievesMultipleKeys;

    /**
     * The array of stored values.
     *
     * @var array
     */
    protected $storage = [];

    /**
     * The array of locks.
     *
     * @var array
     */
    public $locks = [];

    /**
     * Indicates if values are serialized within the store.
     *
     * @var bool
     */
    protected $serializesValues;

    /**
     * Create a new Array store.
     *
     * @param  bool  $serializesValues
     * @return void
     */
    public function __construct($serializesValues = false)
    {
        $this->serializesValues = $serializesValues;
    }

    /**
     * Retrieve an item from the cache by key.
     *
     * @param  string|array  $key
     * @return mixed
     */
    public function get($key)
    {
        if (! isset($this->storage[$key])) {
            return;
        }

        $item = $this->storage[$key];

        $expiresAt = $item['expiresAt'] ?? 0;

        if ($expiresAt !== 0 && $this->currentTime() > $expiresAt) {
            $this->forget($key);

            return;
        }

        return $this->serializesValues ? unserialize($item['value']) : $item['value'];
    }

    /**
     * Store an item in the cache for a given number of seconds.
     *
     * @param  string  $key
     * @param  mixed  $value
     * @param  int  $seconds
     * @return bool
     */
    public function put($key, $value, $seconds)
    {
        $this->storage[$key] = [
            'value' => $this->serializesValues ? serialize($value) : $value,
            'expiresAt' => $this->calculateExpiration($seconds),
        ];

        return true;
    }

    /**
     * Increment the value of an item in the cache.
     *
     * @param  string  $key
     * @param  mixed  $value
     * @return int
     */
    public function increment($key, $value = 1)
    {
        if (! is_null($existing = $this->get($key))) {
            return tap(((int) $existing) + $value, function ($incremented) use ($key) {
                $value = $this->serializesValues ? serialize($incremented) : $incremented;

                $this->storage[$key]['value'] = $value;
            });
        }

        $this->forever($key, $value);

        return $value;
    }

    /**
     * Decrement the value of an item in the cache.
     *
     * @param  string  $key
     * @param  mixed  $value
     * @return int
     */
    public function decrement($key, $value = 1)
    {
        return $this->increment($key, $value * -1);
    }

    /**
     * Store an item in the cache indefinitely.
     *
     * @param  string  $key
     * @param  mixed  $value
     * @return bool
     */
    public function forever($key, $value)
    {
        return $this->put($key, $value, 0);
    }

    /**
     * Remove an item from the cache.
     *
     * @param  string  $key
     * @return bool
     */
    public function forget($key)
    {
        if (array_key_exists($key, $this->storage)) {
            unset($this->storage[$key]);

            return true;
        }

        return false;
    }

    /**
     * Remove all items from the cache.
     *
     * @return bool
     */
    public function flush()
    {
        $this->storage = [];

        return true;
    }

    /**
     * Get the cache key prefix.
     *
     * @return string
     */
    public function getPrefix()
    {
        return '';
    }

    /**
     * Get the expiration time of the key.
     *
     * @param  int  $seconds
     * @return int
     */
    protected function calculateExpiration($seconds)
    {
        return $this->toTimestamp($seconds);
    }

    /**
     * Get the UNIX timestamp for the given number of seconds.
     *
     * @param  int  $seconds
     * @return int
     */
    protected function toTimestamp($seconds)
    {
        return $seconds > 0 ? $this->availableAt($seconds) : 0;
    }

    /**
     * Get a lock instance.
     *
     * @param  string  $name
     * @param  int  $seconds
     * @param  string|null  $owner
     * @return \Illuminate\Contracts\Cache\Lock
     */
    public function lock($name, $seconds = 0, $owner = null)
    {
        return new ArrayLock($this, $name, $seconds, $owner);
    }

    /**
     * Restore a lock instance using the owner identifier.
     *
     * @param  string  $name
     * @param  string  $owner
     * @return \Illuminate\Contracts\Cache\Lock
     */
    public function restoreLock($name, $owner)
    {
        return $this->lock($name, 0, $owner);
    }
}

Filemanager

Name Type Size Permission Actions
Console Folder 0755
Events Folder 0755
RateLimiting Folder 0755
ApcStore.php File 2.53 KB 0644
ApcWrapper.php File 1.85 KB 0644
ArrayLock.php File 2.03 KB 0644
ArrayStore.php File 4.55 KB 0644
CacheLock.php File 1.79 KB 0644
CacheManager.php File 10.44 KB 0644
CacheServiceProvider.php File 1.32 KB 0644
DatabaseLock.php File 3.52 KB 0644
DatabaseStore.php File 10.1 KB 0644
DynamoDbLock.php File 1.56 KB 0644
DynamoDbStore.php File 14.63 KB 0644
FileLock.php File 271 B 0644
FileStore.php File 9 KB 0644
HasCacheLock.php File 681 B 0644
LICENSE.md File 1.05 KB 0644
Lock.php File 3.46 KB 0644
LuaScripts.php File 462 B 0644
MemcachedConnector.php File 2.33 KB 0644
MemcachedLock.php File 1.42 KB 0644
MemcachedStore.php File 6.18 KB 0644
NoLock.php File 692 B 0644
NullStore.php File 2.34 KB 0644
PhpRedisLock.php File 829 B 0644
RateLimiter.php File 4.93 KB 0644
RedisLock.php File 1.75 KB 0644
RedisStore.php File 9.83 KB 0644
RedisTagSet.php File 3.07 KB 0644
RedisTaggedCache.php File 2.8 KB 0644
Repository.php File 16.67 KB 0644
RetrievesMultipleKeys.php File 1.13 KB 0644
TagSet.php File 2.46 KB 0644
TaggableStore.php File 421 B 0644
TaggedCache.php File 2.5 KB 0644
composer.json File 1.49 KB 0644