We don't do local_push_bypass
This commit is contained in:
		| @@ -157,7 +157,7 @@ class HubSub extends Managed_DataObject | |||||||
|         $status = $response->getStatus(); |         $status = $response->getStatus(); | ||||||
|  |  | ||||||
|         if ($status >= 200 && $status < 300) { |         if ($status >= 200 && $status < 300) { | ||||||
|             common_log(LOG_INFO, "Verified $mode of $this->callback:$this->topic"); |             common_log(LOG_INFO, "Verified {$mode} of {$this->callback}:{$this->topic}"); | ||||||
|         } else { |         } else { | ||||||
|             // TRANS: Client exception. %s is a HTTP status code. |             // TRANS: Client exception. %s is a HTTP status code. | ||||||
|             throw new ClientException(sprintf(_m('Hub subscriber verification returned HTTP %s.'),$status)); |             throw new ClientException(sprintf(_m('Hub subscriber verification returned HTTP %s.'),$status)); | ||||||
| @@ -165,13 +165,13 @@ class HubSub extends Managed_DataObject | |||||||
|  |  | ||||||
|         $old = HubSub::getByHashkey($this->topic, $this->callback); |         $old = HubSub::getByHashkey($this->topic, $this->callback); | ||||||
|         if ($mode == 'subscribe') { |         if ($mode == 'subscribe') { | ||||||
|             if ($old) { |             if ($old instanceof HubSub) { | ||||||
|                 $this->update($old); |                 $this->update($old); | ||||||
|             } else { |             } else { | ||||||
|                 $ok = $this->insert(); |                 $ok = $this->insert(); | ||||||
|             } |             } | ||||||
|         } else if ($mode == 'unsubscribe') { |         } else if ($mode == 'unsubscribe') { | ||||||
|             if ($old) { |             if ($old instanceof HubSub) { | ||||||
|                 $old->delete(); |                 $old->delete(); | ||||||
|             } else { |             } else { | ||||||
|                 // That's ok, we're already unsubscribed. |                 // That's ok, we're already unsubscribed. | ||||||
| @@ -204,37 +204,6 @@ class HubSub extends Managed_DataObject | |||||||
|             $retries = intval(common_config('ostatus', 'hub_retries')); |             $retries = intval(common_config('ostatus', 'hub_retries')); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (common_config('ostatus', 'local_push_bypass')) { |  | ||||||
|             // If target is a local site, bypass the web server and drop the |  | ||||||
|             // item directly into the target's input queue. |  | ||||||
|             $url = parse_url($this->callback); |  | ||||||
|             $wildcard = common_config('ostatus', 'local_wildcard'); |  | ||||||
|             $site = Status_network::getFromHostname($url['host'], $wildcard); |  | ||||||
|  |  | ||||||
|             if ($site) { |  | ||||||
|                 if ($this->secret) { |  | ||||||
|                     $hmac = 'sha1=' . hash_hmac('sha1', $atom, $this->secret); |  | ||||||
|                 } else { |  | ||||||
|                     $hmac = ''; |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 // Hack: at the moment we stick the subscription ID in the callback |  | ||||||
|                 // URL so we don't have to look inside the Atom to route the subscription. |  | ||||||
|                 // For now this means we need to extract that from the target URL |  | ||||||
|                 // so we can include it in the data. |  | ||||||
|                 $parts = explode('/', $url['path']); |  | ||||||
|                 $subId = intval(array_pop($parts)); |  | ||||||
|  |  | ||||||
|                 $data = array('feedsub_id' => $subId, |  | ||||||
|                               'post' => $atom, |  | ||||||
|                               'hmac' => $hmac); |  | ||||||
|                 common_log(LOG_DEBUG, "Cross-site PuSH bypass enqueueing straight to $site->nickname feed $subId"); |  | ||||||
|                 $qm = QueueManager::get(); |  | ||||||
|                 $qm->enqueue($data, 'pushin', $site->nickname); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // We dare not clone() as when the clone is discarded it'll |         // We dare not clone() as when the clone is discarded it'll | ||||||
|         // destroy the result data for the parent query. |         // destroy the result data for the parent query. | ||||||
|         // @fixme use clone() again when it's safe to copy an |         // @fixme use clone() again when it's safe to copy an | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user