2 if(!defined('sugarEntry'))define('sugarEntry', true);
3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
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.
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
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
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.
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.
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 ********************************************************************************/
39 require_once('service/core/REST/SugarRest.php');
42 * This class is a serialize implementation of REST protocol
45 class SugarRestRSS extends SugarRest
48 * It will serialize the input object and echo's it
50 * @param array $input - assoc array of input values: key = param name, value = param type
51 * @return String - echos serialize string of $input
53 public function generateResponse($input)
55 if(!isset($input['entry_list'])) {
56 $this->fault($app_strings['ERR_RSS_INVALID_RESPONSE']);
59 $this->generateResponseHeader(count($input['entry_list']));
60 $this->generateItems($input);
61 $this->generateResponseFooter();
64 protected function generateResponseHeader($count)
66 global $app_strings, $sugar_version, $sugar_flavor;
68 $date = TimeDate::httpTime();
71 <?xml version="1.0" encoding="UTF-8" ?>
74 <title>{$app_strings['LBL_RSS_FEED']} » {$app_strings['LBL_BROWSER_TITLE']}</title>
75 <link>{$GLOBALS['sugar_config']['site_url']}</link>
76 <description>{$count} {$app_strings['LBL_RSS_RECORDS_FOUND']}</description>
77 <pubDate>{$date}</pubDate>
78 <generator>SugarCRM $sugar_version $sugar_flavor</generator>
83 protected function generateItems($input)
87 if(!empty($input['entry_list'])){
88 foreach($input['entry_list'] as $item){
89 $this->generateItem($item);
94 protected function generateItem($item)
96 $name = !empty($item['name_value_list']['name']['value'])?htmlentities( $item['name_value_list']['name']['value']): '';
97 $url = $GLOBALS['sugar_config']['site_url'] . htmlentities('/index.php?module=' . $item['module_name']. '&action=DetailView&record=' . $item['id']);
98 $date = TimeDate::httpTime(TimeDate::getInstance()->fromDb($item['name_value_list']['date_modified']['value'])->getTimestamp());
100 $displayFieldNames = true;
101 if(count($item['name_value_list']) == 2 &&isset($item['name_value_list']['name']))$displayFieldNames = false;
102 foreach($item['name_value_list'] as $k=>$v){
103 if ( $k == 'name' || $k == 'date_modified') {
106 if($displayFieldNames) $description .= '<b>' .htmlentities( $k) . ':<b> ';
107 $description .= htmlentities( $v['value']) . "<br>";
114 <description><![CDATA[$description]]></description>
115 <pubDate>$date GMT</pubDate>
116 <guid>{$item['id']}</guid>
122 protected function generateResponseFooter()
131 * Returns a fault since we cannot accept RSS as an input type
133 * @see SugarRest::serve()
135 public function serve()
139 $this->fault($app_strings['ERR_RSS_INVALID_INPUT']);
143 * @see SugarRest::fault()
145 public function fault($errorObject)
148 $this->generateResponseHeader();
150 if(is_object($errorObject)){
151 $error = $errorObject->number . ': ' . $errorObject->name . '<br>' . $errorObject->description;
152 $GLOBALS['log']->error($error);
154 $GLOBALS['log']->error(var_export($errorObject, true));
155 $error = var_export($errorObject, true);
158 echo '</name></item>';
159 $this->generateResponseFooter();