function onStartNoticeSave($notice) { $args = $this->testArgs($notice); common_debug("Blogspamnet args = " . print_r($args, TRUE)); $requestBody = xmlrpc_encode_request('testComment', array($args)); $request = new HTTPClient($this->baseUrl, HTTPClient::METHOD_POST); $request->setHeader('Content-Type', 'text/xml'); $request->setBody($requestBody); $httpResponse = $request->send(); $response = xmlrpc_decode($httpResponse->getBody()); if (xmlrpc_is_fault($response)) { throw new ServerException("{$response['faultString']} ({$response['faultCode']})", 500); } else { common_debug("Blogspamnet results = " . $response); if (preg_match('/^ERROR(:(.*))?$/', $response, $match)) { throw new ServerException(sprintf(_("Error from %s: %s"), $this->baseUrl, $match[2]), 500); } else { if (preg_match('/^SPAM(:(.*))?$/', $response, $match)) { throw new ClientException(sprintf(_("Spam checker results: %s"), $match[2]), 400); } else { if (preg_match('/^OK$/', $response)) { // don't do anything } else { throw new ServerException(sprintf(_("Unexpected response from %s: %s"), $this->baseUrl, $response), 500); } } } } return true; }
function extract_posts($arg_url) { $httpclient = new HTTPClient(); $json_data = $httpclient->send($arg_url, 'get'); if (empty($json_data)) { $this->message = 'Empty content returned'; return false; } // convert json to php array $array_data = json_decode($json_data, true); // get data $facebook_posts = $array_data['data']; if (count($facebook_posts) > 0) { foreach ($facebook_posts as $facebook_post) { $post_content = $facebook_post['message']; $post_title = $facebook_post['name']; $post_author = $this->author_id; $post_status = $this->status_id; $post_date_gmt = gmdate('Y-m-d H:i:s', strtotime($facebook_post['created_time'])); $post_date = get_date_from_gmt($post_date_gmt); $facebook_id = $facebook_post['id']; // build the post array $this->posts[] = compact('post_content', 'post_title', 'post_author', 'post_status', 'post_date', 'post_date_gmt', 'facebook_id'); } // end of foreach } // end of if return true; }
function onStartNoticeSave($notice) { $args = $this->testArgs($notice); common_debug("Blogspamnet args = " . print_r($args, TRUE)); $requestBody = xmlrpc_encode_request('testComment', array($args)); $request = new HTTPClient($this->baseUrl, HTTPClient::METHOD_POST); $request->setHeader('Content-Type', 'text/xml'); $request->setBody($requestBody); $httpResponse = $request->send(); $response = xmlrpc_decode($httpResponse->getBody()); if (xmlrpc_is_fault($response)) { throw new ServerException("{$response['faultString']} ({$response['faultCode']})", 500); } else { common_debug("Blogspamnet results = " . $response); if (preg_match('/^ERROR(:(.*))?$/', $response, $match)) { // TRANS: Server exception thrown when blogspam.net returns error status. // TRANS: %1$s is the base URL, %2$s is the error (unknown contents; no period). throw new ServerException(sprintf(_m('Error from %1$s: %2$s'), $this->baseUrl, $match[2]), 500); } else { if (preg_match('/^SPAM(:(.*))?$/', $response, $match)) { // TRANS: Server exception thrown when blogspam.net returns spam status. // TRANS: Does not end with period because of unknown contents for %s (spam match). throw new ClientException(sprintf(_m('Spam checker results: %s'), $match[2]), 400); } else { if (preg_match('/^OK$/', $response)) { // don't do anything } else { // TRANS: Server exception thrown when blogspam.net returns an unexpected status. // TRANS: %1$s is the base URL, %2$s is the response (unknown contents; no period). throw new ServerException(sprintf(_m('Unexpected response from %1$s: %2$s'), $this->baseUrl, $response), 500); } } } } return true; }
/** * Make a HTTP request. * * @param string $url Where to make the * @param array $params post parameters * * @return mixed the request */ function httpRequest($url, $params = null) { $request = new HTTPClient($url); $request->setConfig(array('connect_timeout' => 120, 'timeout' => 120, 'follow_redirects' => true, 'ssl_verify_peer' => false, 'ssl_verify_host' => false)); // Twitter is strict about accepting invalid "Expect" headers $request->setHeader('Expect', ''); if (isset($params)) { $request->setMethod(HTTP_Request2::METHOD_POST); $request->setBody($params); } try { $response = $request->send(); $code = $response->getStatus(); if ($code < 200 || $code >= 400) { throw new OAuthClientException($response->getBody(), $code); } return $response->getBody(); } catch (Exception $e) { throw new OAuthClientException($e->getMessage(), $e->getCode()); } }
function postToCollection($url, $activity) { $client = new HTTPClient($url); $client->setMethod('POST'); $client->setAuth($this->username, $this->password); $client->setHeader('Content-Type', 'application/atom+xml;type=entry'); $client->setBody($activity->asString(true, true, true)); $response = $client->send(); $status = $response->getStatus(); $reason = $response->getReasonPhrase(); if ($status >= 200 && $status < 300) { return true; } else { if ($status >= 400 && $status < 500) { // TRANS: Client exception thrown when post to collection fails with a 400 status. // TRANS: %1$s is a URL, %2$s is the status, %s$s is the fail reason. throw new ClientException(sprintf(_m('URLSTATUSREASON', '%1$s %2$s %3$s'), $url, $status, $reason)); } else { if ($status >= 500 && $status < 600) { // TRANS: Server exception thrown when post to collection fails with a 500 status. // TRANS: %1$s is a URL, %2$s is the status, %s$s is the fail reason. throw new ServerException(sprintf(_m('URLSTATUSREASON', '%1$s %2$s %3$s'), $url, $status, $reason)); } else { // That's unexpected. // TRANS: Exception thrown when post to collection fails with a status that is not handled. // TRANS: %1$s is a URL, %2$s is the status, %s$s is the fail reason. throw new Exception(sprintf(_m('URLSTATUSREASON', '%1$s %2$s %3$s'), $url, $status, $reason)); } } } }
function postJSON($url, $body) { $request = OAuthRequest::from_consumer_and_token($this->consumer, $this->token, 'POST', $url); $request->sign_request($this->sha1_method, $this->consumer, $this->token); $hclient = new HTTPClient($url); $hclient->setConfig(array('connect_timeout' => 120, 'timeout' => 120, 'follow_redirects' => true, 'ssl_verify_peer' => false, 'ssl_verify_host' => false)); $hclient->setMethod(HTTP_Request2::METHOD_POST); $hclient->setBody(json_encode($body)); $hclient->setHeader('Content-Type', 'application/json'); $hclient->setHeader($request->to_header()); // Twitter is strict about accepting invalid "Expect" headers // No reason not to clear it still here -ESP $hclient->setHeader('Expect', ''); try { $response = $hclient->send(); $code = $response->getStatus(); if (!$response->isOK()) { throw new OAuthClientException($response->getBody(), $code); } return $response; } catch (Exception $e) { throw new OAuthClientException($e->getMessage(), $e->getCode()); } }