mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00
64 lines
1.6 KiB
PHP
64 lines
1.6 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2016 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
use Alchemy\Phrasea\Application;
|
|
|
|
class random
|
|
{
|
|
private $app;
|
|
|
|
public function __construct(Application $app)
|
|
{
|
|
$this->app = $app;
|
|
}
|
|
|
|
/**
|
|
* @return Boolean
|
|
*/
|
|
public function cleanTokens()
|
|
{
|
|
try {
|
|
$conn = $this->app->getApplicationBox()->get_connection();
|
|
|
|
$date = new DateTime();
|
|
$date = $this->app['date-formatter']->format_mysql($date);
|
|
|
|
$sql = 'SELECT * FROM tokens WHERE expire_on < :date
|
|
AND datas IS NOT NULL AND (type="download" OR type="email")';
|
|
$stmt = $conn->prepare($sql);
|
|
$stmt->execute([':date' => $date]);
|
|
$rs = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
$stmt->closeCursor();
|
|
foreach ($rs as $row) {
|
|
switch ($row['type']) {
|
|
case 'download':
|
|
case 'email':
|
|
$file = $this->app['tmp.download.path'].'/'.$row['value'].'.zip';
|
|
if (is_file($file))
|
|
unlink($file);
|
|
break;
|
|
}
|
|
}
|
|
|
|
$sql = 'DELETE FROM tokens WHERE expire_on < :date and (type="download" OR type="email")';
|
|
$stmt = $conn->prepare($sql);
|
|
$stmt->execute([':date' => $date]);
|
|
$stmt->closeCursor();
|
|
|
|
return true;
|
|
} catch (\Exception $e) {
|
|
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|