Compare commits

...

2 Commits

4 changed files with 70 additions and 30 deletions

2
cron/.htaccess Normal file
View File

@ -0,0 +1,2 @@
order allow,deny
deny from all

9
cron/README.md Normal file
View File

@ -0,0 +1,9 @@
## Scripts intended for use by cron
Scripts in this folder are intended to be run by cron, likely as the user running the web server process.
* __clearextracts.php:__ Used to purge the folder used for extracting comics for viewing by clients. It should be run by the web service owner and takes a single parameter for the number of days to keep extracts before removing them.
- "su" to root: `sudo su -`
- Run crontab as web server owner: `sudo web -c "crontab -e"`
- Add crontab line with frequency and days/age parameter
- `15 3 * * * /usr/local/bin/php /var/www/htdocs/comics/cron/clearextracts.php 5 1>/dev/null 2>&1`

27
cron/clearextracts.php Normal file
View File

@ -0,0 +1,27 @@
<?php
$projectRoot = dirname(dirname(__FILE__));
require "{$projectRoot}/header.php";
if ( $argc != 2 ) {
echo "Invalid number of days to keep\n";
exit();
}
$daysToKeep = intval($argv[1]);
$ed = $projectRoot . "/" . EXTRACTSDIR;
$now = time();
$maxAge = $now - (86400*$daysToKeep);
$it = new RecursiveDirectoryIterator($ed, RecursiveDirectoryIterator::SKIP_DOTS);
$files = new RecursiveIteratorIterator($it, RecursiveIteratorIterator::CHILD_FIRST);
$validExtensions = array("cbr","cbz");
foreach ( $files as $file ) {
if ( $file->isDir() && in_array($file->getExtension(), $validExtensions) ) {
if ( filemtime($file->getRealPath()) <= $maxAge ) {
echo "Found aged extracted comic: {$file->getFilename()}\n";
exec("rm -rf \"{$file->getRealPath()}\"", $output, $retval);
}
}
}

View File

@ -9,6 +9,7 @@ require 'functions.php';
// be named "require_login() and take no parameters // be named "require_login() and take no parameters
require 'authfunctions.php'; require 'authfunctions.php';
if ( php_sapi_name() != "cli" ) {
// Start the session // Start the session
session_name(SESSIONCOMICS); session_name(SESSIONCOMICS);
session_start(); session_start();
@ -45,6 +46,7 @@ if ( isset($_REQUEST['hash']) ) {
if ( !isset($_SESSION['sortorder']) ) { if ( !isset($_SESSION['sortorder']) ) {
$_SESSION['sortorder'] = SORTBYDATE; $_SESSION['sortorder'] = SORTBYDATE;
} }
}
// Make our PDO database connection which will be used in all scripts // Make our PDO database connection which will be used in all scripts
$globaldbh = new PDO("mysql:host=" . DBHOST . ";dbname=" . DBNAME, DBUSER, DBPASS); $globaldbh = new PDO("mysql:host=" . DBHOST . ";dbname=" . DBNAME, DBUSER, DBPASS);