forked from GNUsocial/gnu-social
Disable PubSubHubBub hub pings automatically on private site (hub wouldn't be able to read feeds anyway)
[Might be good to think of a core way to mark a plugin as disabled when it initializes.]
This commit is contained in:
parent
73f6250b9d
commit
c10d5320dd
@ -79,6 +79,21 @@ class PubSubHubBubPlugin extends Plugin
|
||||
parent::__construct();
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if plugin should be active; may be mass-enabled.
|
||||
* @return boolean
|
||||
*/
|
||||
|
||||
function enabled()
|
||||
{
|
||||
if (common_config('site', 'private')) {
|
||||
// PuSH relies on public feeds
|
||||
return false;
|
||||
}
|
||||
// @fixme check for being on a private network?
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Hooks the StartApiAtom event
|
||||
*
|
||||
@ -92,8 +107,9 @@ class PubSubHubBubPlugin extends Plugin
|
||||
|
||||
function onStartApiAtom($action)
|
||||
{
|
||||
$action->element('link', array('rel' => 'hub', 'href' => $this->hub), null);
|
||||
|
||||
if ($this->enabled()) {
|
||||
$action->element('link', array('rel' => 'hub', 'href' => $this->hub), null);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -110,9 +126,11 @@ class PubSubHubBubPlugin extends Plugin
|
||||
|
||||
function onStartApiRss($action)
|
||||
{
|
||||
$action->element('atom:link', array('rel' => 'hub',
|
||||
'href' => $this->hub),
|
||||
null);
|
||||
if ($this->enabled()) {
|
||||
$action->element('atom:link', array('rel' => 'hub',
|
||||
'href' => $this->hub),
|
||||
null);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -130,6 +148,9 @@ class PubSubHubBubPlugin extends Plugin
|
||||
|
||||
function onHandleQueuedNotice($notice)
|
||||
{
|
||||
if (!$this->enabled()) {
|
||||
return false;
|
||||
}
|
||||
$publisher = new Publisher($this->hub);
|
||||
|
||||
$feeds = array();
|
||||
@ -243,16 +264,21 @@ class PubSubHubBubPlugin extends Plugin
|
||||
|
||||
function onPluginVersion(&$versions)
|
||||
{
|
||||
$about = _m('The PubSubHubBub plugin pushes RSS/Atom updates '.
|
||||
'to a <a href = "'.
|
||||
'http://pubsubhubbub.googlecode.com/'.
|
||||
'">PubSubHubBub</a> hub.');
|
||||
if (!$this->enabled()) {
|
||||
$about = '<span class="disabled" style="color:gray">' . $about . '</span> ' .
|
||||
_m('(inactive on private site)');
|
||||
}
|
||||
$versions[] = array('name' => 'PubSubHubBub',
|
||||
'version' => STATUSNET_VERSION,
|
||||
'author' => 'Craig Andrews',
|
||||
'homepage' =>
|
||||
'http://status.net/wiki/Plugin:PubSubHubBub',
|
||||
'rawdescription' =>
|
||||
_m('The PubSubHubBub plugin pushes RSS/Atom updates '.
|
||||
'to a <a href = "'.
|
||||
'http://pubsubhubbub.googlecode.com/'.
|
||||
'">PubSubHubBub</a> hub.'));
|
||||
$about);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user