Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php namespace Pagekit\Auth\Handler; use Pagekit\Cookie\CookieJar; use Pagekit\Database..

Decoded Output download

<?php

namespace Pagekit\Auth\Handler;

use Pagekit\Cookie\CookieJar;
use Pagekit\Database\Connection;
use RandomLib\Generator;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\RequestStack;

class DatabaseHandler implements HandlerInterface
{
    const STATUS_INACTIVE   = 0;
    const STATUS_ACTIVE     = 1;
    const STATUS_REMEMBERED = 2;

    /**
     * @var array
     */
    protected $config;

    /**
     * @var CookieJar
     */
    protected $cookie;

    /**
     * @var RequestStack
     */
    protected $requests;

    /**
     * @var Connection
     */
    protected $connection;

    /**
     * @var Generator
     */
    protected $random;

    /**
     * Constructor.
     *
     * @param Connection   $connection
     * @param RequestStack $requests
     * @param CookieJar    $cookie
     * @param Generator    $random
     * @param array        $config
     */
    public function __construct(Connection $connection, RequestStack $requests, CookieJar $cookie, Generator $random, $config = null)
    {
        $this->connection = $connection;
        $this->requests = $requests;
        $this->cookie = $cookie;
        $this->random = $random;
        $this->config = $config;
    }

    /**
     * {@inheritdoc}
     */
    public function read()
    {
        if ($token = $this->getToken() and $data = $this->connection->executeQuery("SELECT user_id, status, access FROM {$this->config['table']} WHERE id = :id AND status > :status", [
                'id' => sha1($token),
                'status' => self::STATUS_INACTIVE
            ])->fetch(\PDO::FETCH_ASSOC)) {

            if (strtotime($data['access']) + $this->config['timeout'] < time()) {

                if ($data['status'] == self::STATUS_REMEMBERED) {
                    $this->write($data['user_id'], self::STATUS_REMEMBERED);
                } else {
                    return null;
                }

            }

            $this->connection->update($this->config['table'], ['access' => date('Y-m-d H:i:s')], ['id' => sha1($token)]);

            return $data['user_id'];
        }

        return null;
    }

    /**
     * {@inheritdoc}
     */
    public function write($user, $remember = false)
    {
        if ($token = $this->getToken()) {
            $this->connection->delete($this->config['table'], ['id' => sha1($token)]);
        }

        $id = $this->random->generateString(64);

        $this->cookie->set($this->config['cookie']['name'], $id, $this->config['cookie']['lifetime'] + time());

        $this->createTable();

        $this->connection->insert($this->config['table'], [
            'id' => sha1($id),
            'user_id' => $user,
            'access' => date('Y-m-d H:i:s'),
            'status' => $remember ? self::STATUS_REMEMBERED : self::STATUS_ACTIVE,
            'data' => json_encode([
                'ip' => $this->getRequest()->getClientIp(),
                'user-agent' => $this->getRequest()->headers->get('User-Agent')
            ])
        ]);
    }

    /**
     * {@inheritdoc}
     */
    public function destroy()
    {
        if ($token = $this->getToken()) {
            $this->connection->update($this->config['table'], ['status' => self::STATUS_INACTIVE], ['id' => sha1($token)]);
        }
    }

    /**
     * Gets the token from the request.
     *
     * @return mixed
     */
    protected function getToken()
    {
        if ($request = $this->getRequest()) {
            return $request->cookies->get($this->config['cookie']['name']);
        }
    }

    /**
     * @return null|Request
     */
    protected function getRequest()
    {
        return $this->requests->getCurrentRequest();
    }

    /**
     * @deprecated to be removed in Pagekit 1.0
     */
    protected function createTable()
    {
        $util = $this->connection->getUtility();
        if ($util->tableExists($this->config['table']) === false) {
            $util->createTable($this->config['table'], function ($table) {
                $table->addColumn('id', 'string', ['length' => 255]);
                $table->addColumn('user_id', 'integer', ['unsigned' => true, 'length' => 10, 'default' => 0]);
                $table->addColumn('access', 'datetime', ['notnull' => false]);
                $table->addColumn('status', 'smallint');
                $table->addColumn('data', 'json_array', ['notnull' => false]);
                $table->setPrimaryKey(['id']);
            });
        }
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

namespace Pagekit\Auth\Handler;

use Pagekit\Cookie\CookieJar;
use Pagekit\Database\Connection;
use RandomLib\Generator;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\RequestStack;

class DatabaseHandler implements HandlerInterface
{
    const STATUS_INACTIVE   = 0;
    const STATUS_ACTIVE     = 1;
    const STATUS_REMEMBERED = 2;

    /**
     * @var array
     */
    protected $config;

    /**
     * @var CookieJar
     */
    protected $cookie;

    /**
     * @var RequestStack
     */
    protected $requests;

    /**
     * @var Connection
     */
    protected $connection;

    /**
     * @var Generator
     */
    protected $random;

    /**
     * Constructor.
     *
     * @param Connection   $connection
     * @param RequestStack $requests
     * @param CookieJar    $cookie
     * @param Generator    $random
     * @param array        $config
     */
    public function __construct(Connection $connection, RequestStack $requests, CookieJar $cookie, Generator $random, $config = null)
    {
        $this->connection = $connection;
        $this->requests = $requests;
        $this->cookie = $cookie;
        $this->random = $random;
        $this->config = $config;
    }

    /**
     * {@inheritdoc}
     */
    public function read()
    {
        if ($token = $this->getToken() and $data = $this->connection->executeQuery("SELECT user_id, status, access FROM {$this->config['table']} WHERE id = :id AND status > :status", [
                'id' => sha1($token),
                'status' => self::STATUS_INACTIVE
            ])->fetch(\PDO::FETCH_ASSOC)) {

            if (strtotime($data['access']) + $this->config['timeout'] < time()) {

                if ($data['status'] == self::STATUS_REMEMBERED) {
                    $this->write($data['user_id'], self::STATUS_REMEMBERED);
                } else {
                    return null;
                }

            }

            $this->connection->update($this->config['table'], ['access' => date('Y-m-d H:i:s')], ['id' => sha1($token)]);

            return $data['user_id'];
        }

        return null;
    }

    /**
     * {@inheritdoc}
     */
    public function write($user, $remember = false)
    {
        if ($token = $this->getToken()) {
            $this->connection->delete($this->config['table'], ['id' => sha1($token)]);
        }

        $id = $this->random->generateString(64);

        $this->cookie->set($this->config['cookie']['name'], $id, $this->config['cookie']['lifetime'] + time());

        $this->createTable();

        $this->connection->insert($this->config['table'], [
            'id' => sha1($id),
            'user_id' => $user,
            'access' => date('Y-m-d H:i:s'),
            'status' => $remember ? self::STATUS_REMEMBERED : self::STATUS_ACTIVE,
            'data' => json_encode([
                'ip' => $this->getRequest()->getClientIp(),
                'user-agent' => $this->getRequest()->headers->get('User-Agent')
            ])
        ]);
    }

    /**
     * {@inheritdoc}
     */
    public function destroy()
    {
        if ($token = $this->getToken()) {
            $this->connection->update($this->config['table'], ['status' => self::STATUS_INACTIVE], ['id' => sha1($token)]);
        }
    }

    /**
     * Gets the token from the request.
     *
     * @return mixed
     */
    protected function getToken()
    {
        if ($request = $this->getRequest()) {
            return $request->cookies->get($this->config['cookie']['name']);
        }
    }

    /**
     * @return null|Request
     */
    protected function getRequest()
    {
        return $this->requests->getCurrentRequest();
    }

    /**
     * @deprecated to be removed in Pagekit 1.0
     */
    protected function createTable()
    {
        $util = $this->connection->getUtility();
        if ($util->tableExists($this->config['table']) === false) {
            $util->createTable($this->config['table'], function ($table) {
                $table->addColumn('id', 'string', ['length' => 255]);
                $table->addColumn('user_id', 'integer', ['unsigned' => true, 'length' => 10, 'default' => 0]);
                $table->addColumn('access', 'datetime', ['notnull' => false]);
                $table->addColumn('status', 'smallint');
                $table->addColumn('data', 'json_array', ['notnull' => false]);
                $table->setPrimaryKey(['id']);
            });
        }
    }
}

Function Calls

None

Variables

None

Stats

MD5 c173e835ccdb7e2ab5ec0b64dc5c070a
Eval Count 0
Decode Time 110 ms