setPreferedResponseType('text'); // TODO - pref } /** * Set prefered response type to be used with * {@link sendResponse()} * * @param string $response_type xml|json|text */ public function setPreferedResponseType($response_type) { $this->_prefered_response_type = $response_type; } /** * Add response action & action instructions * 'action' equals to e107Ajax JS method (see JS API) * * @param string $action * @param array $data_array item data for the action * @return e_jshelper */ function addResponseAction($action, $data_array) { if(!isset($this->_response_actions[$action])) { $this->_response_actions[$action] = array(); } $this->_response_actions[$action] = array_merge($this->_response_actions[$action], $data_array); return $this; } /** * Attach response Items array to an action * Example: addResponseItem('element-invoke-by-id', 'show', array('category-clear','update-category')); * will add array('category-clear','update-category') to ['element-invoke-by-id']['show'] stack * * @param string $action * @param array $data_array item data for the action * @return e_jshelper */ function addResponseItem($action, $subaction, $data) { if(!isset($this->_response_actions[$action])) { $this->_response_actions[$action] = array(); } if(!isset($this->_response_actions[$action][$subaction])) { $this->_response_actions[$action][$subaction] = array(); } if(is_array($data)) { $this->_response_actions[$action][$subaction] = array_merge($this->_response_actions[$action][$subaction], $data); } else { $this->_response_actions[$action][$subaction][] = $data; } return $this; } /** * Response array getter * * @param bool $reset clear current response actions * @return array response actions */ function getResponseActions($reset = false) { if($reset) { $ret = $this->_response_actions; $this->_reset(); return $ret; } return $this->_response_actions; } /** * Buld XML response parsed by the JS API * Quick & dirty, this will be extended to * e107 web service standard (communication protocol). * * @return string XML response */ function buildXmlResponse() { $action_array = $this->getResponseActions(true); $ret = ''; $ret .= "\n\n"; foreach ($action_array as $action => $field_array) { $ret .= "\t\n"; foreach ($field_array as $field => $value) { //associative arrays only - no numeric keys! //to speed this up use $sql->db_Fetch(MYSQL_ASSOC); //when passing large data from the DB if (is_numeric($field) || empty($field)) continue; switch (gettype($value)) { case 'array': foreach ($value as $v) { if(is_string($v)) { $v = ""; } $ret .= "\t\t{$v}\n";; } break; case 'string': $value = ""; $ret .= "\t\t{$value}\n"; break; case 'boolean': case 'numeric': $ret .= "\t\t{$value}\n"; break; } } $ret .= "\t\n"; } $ret .= ''; return $ret; } /** * Convert (optional) and send array as XML response string * * @param string $action optional * @param array $data_array optional */ function sendXmlResponse($action = '', $data_array = array()) { header('Content-type: application/xml; charset='.CHARSET, true); if($action) { $this->addResponseAction($action, $data_array); } if(null !== $action) echo $this->buildXmlResponse(); exit; } /** * Build JSON response string * * @return string JSON response */ function buildJsonResponse($data = null) { if(null !== $data) return "/*-secure-\n".json_encode($data)."\n*/"; return "/*-secure-\n".json_encode($this->getResponseActions(true))."\n*/"; } /** * Convert (optional) and send array as JSON response string * * @param string $action optional * @param array $data_array optional */ function sendJsonResponse($action = '', $data_array = array()) { header('Content-type: application/json; charset='.CHARSET, true); if($action) { $this->addResponseAction($action, $data_array); } if(null !== $action) echo $this->buildJSONResponse(); exit; } /** * Add text response data * * @param string $text * @return e_jshelper */ public function addTextResponse($text) { if($text) { $this->_response_actions['text']['body'][] = $text; } return $this; } /** * Build Text response string * * @return string */ function buildTextResponse() { $content = $this->getResponseActions(true); if(!isset($content['text']) || !isset($content['text']['body'])) { return ''; } return implode('', $content['text']['body']); } /** * Add content (optional) and send text response * * @param string $action optional * @param array $data_array optional */ function sendTextResponse($data_text = '') { header('Content-type: text/html; charset='.CHARSET, true); echo $this->addTextResponse($data_text)->buildTextResponse(); exit; } /** * Send Server Response * Sends the response based on $response_type or the system * prefered response type (could be system preference in the future) * * @param string $action optional Action * @return boolean success */ function sendResponse($response_type = '') { if(!$response_type) { //TODO - pref? $response_type = strtolower(ucfirst($this->_prefered_response_type)); } $method = "send{$response_type}Response"; if(method_exists($this, $method)) { $this->$method(); return true; } return false; } /** * Add response by response type * * @param mixed $data * @param string $action 'text' or response action string * @return e_jshelper */ function addResponse($data, $action = '') { if(!$action) { $action = 'text'; } if('text' == $action) { $this->addTextResponse($data); } else { $this->addResponseAction($action, $data); } return $this; } /** * Reset response action array to prevent duplicates * * @access private * @return void */ function _reset() { $this->_response_actions = array(); } /** * Send error to the JS Ajax.response object * * @param integer $errcode * @param string $errmessage * @param string $errextended * @access public */ function sendAjaxError($errcode, $errmessage, $errextended = '') { header('Content-type: text/html; charset='.CHARSET, true); header("HTTP/1.0 {$errcode} {$errmessage}", true); header("e107ErrorMessage: {$errmessage}", true); header("e107ErrorCode: {$errcode}", true); //Safari expects some kind of output, even empty echo ($errextended ? $errextended : ' '); exit; } /** * Clean string to be used as JS string * Should be using for passing strings to e107 JS API - e.g Languages,Templates etc. * * @param string $string * @return string */ function toString($string) { return "'".str_replace(array("\\'", "'"), array("'", "\\'"), $string)."'"; } } ?>