Skip to content
Snippets Groups Projects
Commit 486bfa5c authored by Lukas Reschke's avatar Lukas Reschke Committed by GitHub
Browse files

Merge pull request #4788 from nextcloud/issue-4756-cron-error

Fix errors with LookupServerConnector background job
parents d84a6ec3 5c20d2ca
No related branches found
No related tags found
No related merge requests found
...@@ -19,13 +19,14 @@ ...@@ -19,13 +19,14 @@
* *
*/ */
namespace OCA\LookupServerConnector\BackgroundJobs; namespace OCA\LookupServerConnector\BackgroundJobs;
use OC\BackgroundJob\Job; use OC\BackgroundJob\Job;
use OC\BackgroundJob\JobList;
use OCP\BackgroundJob\IJobList; use OCP\BackgroundJob\IJobList;
use OCP\Http\Client\IClientService; use OCP\Http\Client\IClientService;
use OCP\IConfig;
use OCP\ILogger; use OCP\ILogger;
class RetryJob extends Job { class RetryJob extends Job {
...@@ -34,16 +35,24 @@ class RetryJob extends Job { ...@@ -34,16 +35,24 @@ class RetryJob extends Job {
/** @var IJobList */ /** @var IJobList */
private $jobList; private $jobList;
/** @var string */ /** @var string */
private $lookupServer = 'https://lookup.nextcloud.com/users'; private $lookupServer;
/** @var int how much time should be between two tries (10 minutes) */
private $interval = 600;
/** /**
* @param IClientService $clientService * @param IClientService $clientService
* @param IJobList $jobList * @param IJobList $jobList
* @param IConfig $config
*/ */
public function __construct(IClientService $clientService, public function __construct(IClientService $clientService,
IJobList $jobList) { IJobList $jobList,
IConfig $config) {
$this->clientService = $clientService; $this->clientService = $clientService;
$this->jobList = $jobList; $this->jobList = $jobList;
$this->lookupServer = $config->getSystemValue('lookup_server', 'https://lookup.nextcloud.com');
$this->lookupServer = rtrim($this->lookupServer, '/');
$this->lookupServer .= '/users';
} }
/** /**
...@@ -53,12 +62,10 @@ class RetryJob extends Job { ...@@ -53,12 +62,10 @@ class RetryJob extends Job {
* @param ILogger $logger * @param ILogger $logger
*/ */
public function execute($jobList, ILogger $logger = null) { public function execute($jobList, ILogger $logger = null) {
if ($this->shouldRun($this->argument)) { if ($this->shouldRun($this->argument)) {
parent::execute($jobList, $logger); parent::execute($jobList, $logger);
$jobList->remove($this, $this->argument); $jobList->remove($this, $this->argument);
} }
} }
protected function run($argument) { protected function run($argument) {
...@@ -81,9 +88,20 @@ class RetryJob extends Job { ...@@ -81,9 +88,20 @@ class RetryJob extends Job {
[ [
'dataArray' => $argument['dataArray'], 'dataArray' => $argument['dataArray'],
'retryNo' => $argument['retryNo'] + 1, 'retryNo' => $argument['retryNo'] + 1,
'lastRun' => time(),
] ]
); );
} }
} }
/**
* test if it is time for the next run
*
* @param array $argument
* @return bool
*/
protected function shouldRun($argument) {
return !isset($argument['lastRun']) || ((time() - $argument['lastRun']) > $this->interval);
}
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment