Hopefuly fixes #147; made tag sub delay configurable

This commit is contained in:
Renzo 2016-07-30 13:45:57 -05:00
parent 6e77aa849f
commit 48b182b2f6
2 changed files with 26 additions and 6 deletions

View File

@ -43,8 +43,15 @@ class JobTask extends Rails\ActiveRecord\Base
break;
case "calculate_tag_subscriptions":
return "last run: " . (isset($this->data->last_run) ? $this->data->last_run : 'never');
break;
if (CONFIG()->tag_subscription_delay && isset($this->data->last_run)) {
$nextRun = date('Y-m-d H:i:s', strtotime('+' . CONFIG()->tag_subscription_delay, strtotime($this->data->last_run)));
} else {
$nextRun = 'imminent';
}
$lastRun = (isset($this->data->last_run) ? $this->data->last_run : 'never');
return "last run: " . $lastRun . '; next run: ' . $nextRun;
// case "upload_posts_to_mirrors"
// ret = ""
@ -264,12 +271,17 @@ class JobTask extends Rails\ActiveRecord\Base
public function execute_calculate_tag_subscriptions()
{
if (CONFIG()->tag_subscription_delay) {
if (Rails::cache()->read("delay-tag-sub-calc")) {
return;
}
Rails::cache()->write("delay-tag-sub-calc", ['expires_in' => '360 minutes']);
Rails::cache()->write("delay-tag-sub-calc", 1, ['expires_in' => CONFIG()->tag_subscription_delay]);
}
TagSubscription::process_all();
$this->updateAttributes(['data' => ['last_run' => date('Y-m-d H:i')]]);
$this->updateAttributes(['data' => ['last_run' => date('Y-m-d H:i:s')]]);
}
protected function init()

View File

@ -462,6 +462,14 @@ abstract class DefaultConfig
# Set to 0 to wait indefinitely.
public $http_streaming_timeout = 10;
/**
* Don't process tag subscriptions again within this time.
* Set to null to process tag subscriptions asap.
*
* @param string
*/
public $tag_subscription_delay = '360 minutes';
public function __get($prop)
{
return null;