Fix BitlyUrl plugin.
Since Bit.ly changed its API from v2 to v3, BitlyURL plugin doesn't work anymore. This fix API version issue and also imporve a little plugin performance in removing useless code.
This commit is contained in:
parent
98f064e4fd
commit
e25400b4f2
@ -38,7 +38,7 @@ require_once INSTALLDIR.'/plugins/UrlShortener/UrlShortenerPlugin.php';
|
|||||||
class BitlyUrlPlugin extends UrlShortenerPlugin
|
class BitlyUrlPlugin extends UrlShortenerPlugin
|
||||||
{
|
{
|
||||||
public $shortenerName = 'bit.ly';
|
public $shortenerName = 'bit.ly';
|
||||||
public $serviceUrl = 'http://bit.ly/api?method=shorten&version=2.0.1&longUrl=%s';
|
public $serviceUrl = 'http://api.bit.ly/v3/shorten?longUrl=%s';
|
||||||
public $login; // To set a site-default when admins or users don't override it.
|
public $login; // To set a site-default when admins or users don't override it.
|
||||||
public $apiKey;
|
public $apiKey;
|
||||||
|
|
||||||
@ -70,12 +70,10 @@ class BitlyUrlPlugin extends UrlShortenerPlugin
|
|||||||
* @return string shortened version of the url, or null if URL shortening failed
|
* @return string shortened version of the url, or null if URL shortening failed
|
||||||
*/
|
*/
|
||||||
protected function shorten($url) {
|
protected function shorten($url) {
|
||||||
|
common_log(LOG_INFO, "bit.ly call for $url");
|
||||||
$response = $this->query($url);
|
$response = $this->query($url);
|
||||||
if ($this->isOk($url, $response)) {
|
common_log(LOG_INFO, "bit.ly answer for $url is ".$response->getBody());
|
||||||
return $this->decode($url, $response->getBody());
|
return $this->decode($url, $response);
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -127,42 +125,25 @@ class BitlyUrlPlugin extends UrlShortenerPlugin
|
|||||||
/**
|
/**
|
||||||
* JSON decode for API result
|
* JSON decode for API result
|
||||||
*/
|
*/
|
||||||
protected function decode($url, $body)
|
protected function decode($url, $response)
|
||||||
{
|
{
|
||||||
$json = json_decode($body, true);
|
$msg = "bit.ly returned unknown response with unknown message for $url";
|
||||||
return $json['results'][$url]['shortUrl'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* JSON decode for API result
|
|
||||||
*/
|
|
||||||
protected function isOk($url, $response)
|
|
||||||
{
|
|
||||||
$code = 'unknown';
|
|
||||||
$msg = '';
|
|
||||||
if ($response->isOk()) {
|
if ($response->isOk()) {
|
||||||
$body = $response->getBody();
|
$body = $response->getBody();
|
||||||
common_log(LOG_INFO, $body);
|
common_log(LOG_INFO, $body);
|
||||||
$json = json_decode($body, true);
|
$json = json_decode($body, true);
|
||||||
if ($json['statusCode'] == 'OK') {
|
if ($json['status_code'] == 200) {
|
||||||
if (!isset($json['results'][$url])) {
|
if (isset($json['data']['url'])) {
|
||||||
common_log(LOG_ERR, "bit.ly returned OK response, but didn't find expected URL $url in $body");
|
common_log(LOG_INFO, "bit.ly returned ".$json['data']['url']." as short URL for $url");
|
||||||
return false;
|
return $json['data']['url'];
|
||||||
}
|
}
|
||||||
$data = $json['results'][$url];
|
$msg = "bit.ly returned ".$json['status_code']." response, but didn't find expected URL $url in $body";
|
||||||
if (isset($data['shortUrl'])) {
|
}else{
|
||||||
return true;
|
$msg = "bit.ly returned ".$json['status_code']." response with ".$json['status_txt']." for $url";
|
||||||
} else if (isset($data['statusCode']) && $data['statusCode'] == 'ERROR') {
|
|
||||||
$code = $data['errorCode'];
|
|
||||||
$msg = $data['errorMessage'];
|
|
||||||
}
|
}
|
||||||
} else if ($json['statusCode'] == 'ERROR') {
|
|
||||||
$code = $json['errorCode'];
|
|
||||||
$msg = $json['errorMessage'];
|
|
||||||
}
|
}
|
||||||
common_log(LOG_ERR, "bit.ly returned error $code $msg for $url");
|
common_log(LOG_ERR, $msg);
|
||||||
}
|
return null;
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function onPluginVersion(&$versions)
|
function onPluginVersion(&$versions)
|
||||||
|
Loading…
Reference in New Issue
Block a user