PageRenderTime 45ms CodeModel.GetById 20ms RepoModel.GetById 0ms app.codeStats 0ms

/include/SugarQueue/SugarCronRemoteJobs.php

https://bitbucket.org/cviolette/sugarcrm
PHP | 116 lines | 44 code | 10 blank | 62 comment | 10 complexity | 8a30786e408efd58067d73d0acb630f9 MD5 | raw file
Possible License(s): LGPL-2.1, MPL-2.0-no-copyleft-exception, BSD-3-Clause
  1. <?php
  2. if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
  3. /*********************************************************************************
  4. * SugarCRM Community Edition is a customer relationship management program developed by
  5. * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
  6. *
  7. * This program is free software; you can redistribute it and/or modify it under
  8. * the terms of the GNU Affero General Public License version 3 as published by the
  9. * Free Software Foundation with the addition of the following permission added
  10. * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
  11. * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
  12. * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
  13. *
  14. * This program is distributed in the hope that it will be useful, but WITHOUT
  15. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  16. * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
  17. * details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License along with
  20. * this program; if not, see http://www.gnu.org/licenses or write to the Free
  21. * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  22. * 02110-1301 USA.
  23. *
  24. * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
  25. * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
  26. *
  27. * The interactive user interfaces in modified source and object code versions
  28. * of this program must display Appropriate Legal Notices, as required under
  29. * Section 5 of the GNU Affero General Public License version 3.
  30. *
  31. * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
  32. * these Appropriate Legal Notices must retain the display of the "Powered by
  33. * SugarCRM" logo. If the display of the logo is not reasonably feasible for
  34. * technical reasons, the Appropriate Legal Notices must display the words
  35. * "Powered by SugarCRM".
  36. ********************************************************************************/
  37. require_once 'include/SugarQueue/SugarCronJobs.php';
  38. require_once 'include/SugarHttpClient.php';
  39. /**
  40. * CRON driver for job queue that ships jobs outside
  41. * @api
  42. */
  43. class SugarCronRemoteJobs extends SugarCronJobs
  44. {
  45. /**
  46. * URL for remote job server
  47. * @var string
  48. */
  49. protected $jobserver;
  50. /**
  51. * Just in case we'd ever need to override...
  52. * @var string
  53. */
  54. protected $submitURL = "submitJob";
  55. /**
  56. * REST client
  57. * @var string
  58. */
  59. protected $client;
  60. public function __construct()
  61. {
  62. parent::__construct();
  63. if(!empty($GLOBALS['sugar_config']['job_server'])) {
  64. $this->jobserver = $GLOBALS['sugar_config']['job_server'];
  65. }
  66. $this->setClient(new SugarHttpClient());
  67. }
  68. /**
  69. * Set client to talk to SNIP
  70. * @param SugarHttpClient $client
  71. */
  72. public function setClient(SugarHttpClient $client)
  73. {
  74. $this->client = $client;
  75. return $this;
  76. }
  77. /**
  78. * Return ID for this client
  79. * @return string
  80. */
  81. public function getMyId()
  82. {
  83. return 'CRON'.$GLOBALS['sugar_config']['unique_key'].':'.md5($this->jobserver);
  84. }
  85. /**
  86. * Execute given job
  87. * @param SchedulersJob $job
  88. */
  89. public function executeJob($job)
  90. {
  91. $data = http_build_query(array("data" => json_encode(array("job" => $job->id, "client" => $this->getMyId(), "instance" => $GLOBALS['sugar_config']['site_url']))));
  92. $response = $this->client->callRest($this->jobserver.$this->submitURL, $data);
  93. if(!empty($response)) {
  94. $result = json_decode($response, true);
  95. if(empty($result) || empty($result['ok']) || $result['ok'] != $job->id) {
  96. $GLOBALS['log']->debug("CRON Remote: Job {$job->id} not accepted by server: $response");
  97. $this->jobFailed($job);
  98. $job->failJob("Job not accepted by server: $response");
  99. }
  100. } else {
  101. $GLOBALS['log']->debug("CRON Remote: REST request failed for job {$job->id}");
  102. $this->jobFailed($job);
  103. $job->failJob("Could not connect to job server");
  104. }
  105. }
  106. }