lbry.com/controller/Actions.class.php
2015-10-25 12:01:04 -04:00

82 lines
No EOL
1.8 KiB
PHP

<?php
/**
* Description of Actions
*
* @author jeremy
*/
class Actions
{
/**
* @var Session
*/
protected $session;
public function __construct()
{
$this->session = new Session();
}
public function executeHome()
{
return ['page/home', []];
}
public function executeGet()
{
if ($this->validateDownloadAccess())
{
return ['page/get-allowed', []];
}
$inviteError = $this->session->get('invite_error');
$this->session->unsetKey('invite_error');
return ['page/get-denied', ['inviteError' => $inviteError]];
}
public function executePostCommit()
{
$payload = json_decode($_REQUEST['payload']);
$secret = file_get_contents('data/secret/github-secret');
$isToMaster = $payload->ref === 'refs/heads/master';
file_put_contents('github.txt', ($isToMaster ? 'master' : 'apprentince') . "\n$secret\n" . print_r($payload, TRUE), FILE_APPEND);
return [null, []];
}
protected function validateDownloadAccess()
{
$seshionKey = 'has-download-access';
if ($this->session->get($seshionKey))
{
return true;
}
if ($_SERVER['REQUEST_METHOD'] === 'POST')
{
$this->accessCodes = include $_SERVER['ROOT_DIR'] . '/data/secret/access_list.php';
$today = date('Y-m-d H:i:s');
foreach($this->accessCodes as $code => $date)
{
if ($_POST['invite'] == $code && $today <= $date)
{
$this->session->set($seshionKey, true);
Controller::redirect('/get', 302);
}
}
if ($_POST['invite'])
{
$this->session->set('invite_error', 'Please provide a valid invite code.');
}
else
{
$this->session->set('invite_error', 'Please provide an invite code.');
}
Controller::redirect('/get', 401);
}
return false;
}
}