Don't try to replace http with https if https already exists
This commit is contained in:
parent
83cb1dfa68
commit
bacd49a6a8
@ -306,10 +306,13 @@ class HubSub extends Managed_DataObject
|
|||||||
if ('http' === parse_url($this->callback, PHP_URL_SCHEME)) {
|
if ('http' === parse_url($this->callback, PHP_URL_SCHEME)) {
|
||||||
// Test if the feed callback for this node has migrated to HTTPS
|
// Test if the feed callback for this node has migrated to HTTPS
|
||||||
$httpscallback = preg_replace('/^http/', 'https', $this->callback, 1);
|
$httpscallback = preg_replace('/^http/', 'https', $this->callback, 1);
|
||||||
if ($httpscallback === $this->callback) {
|
$alreadyreplaced = self::getByHashKey(self::hashkey($this->getTopic(), $httpscallback));
|
||||||
throw new ServerException('Trying to preg_replace http to https on '._ve($this->callback).' failed and resulted in an identical string: '._ve($httpscallback).'.');
|
if ($alreadyreplaced instanceof HubSub) {
|
||||||
|
$this->delete();
|
||||||
|
throw new AlreadyFulfilledException('The remote side has already established an HTTPS callback, deleting the legacy HTTP entry.');
|
||||||
}
|
}
|
||||||
common_debug('PuSH callback to '._ve($this->callback).' for '._ve($this->getTopic()).' testing with HTTPS callback: '._ve($httpscallback));
|
|
||||||
|
common_debug('PuSH callback to '._ve($this->callback).' for '._ve($this->getTopic()).' trying HTTPS callback: '._ve($httpscallback));
|
||||||
$response = $request->post($httpscallback, $headers);
|
$response = $request->post($httpscallback, $headers);
|
||||||
if ($response->isOk()) {
|
if ($response->isOk()) {
|
||||||
$orig = clone($this);
|
$orig = clone($this);
|
||||||
|
@ -44,10 +44,11 @@ class HubOutQueueHandler extends QueueHandler
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
$sub->push($atom);
|
$sub->push($atom);
|
||||||
|
} catch (AlreadyFulfilledException $e) {
|
||||||
|
common_log(LOG_INFO, "Failed PuSH to $sub->callback for $sub->topic (".get_class($e)."): " . $e->getMessage());
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
$retries--;
|
$retries--;
|
||||||
$msg = "Failed PuSH to $sub->callback for $sub->topic: " .
|
$msg = "Failed PuSH to $sub->callback for $sub->topic (".get_class($e)."): " . $e->getMessage();
|
||||||
$e->getMessage();
|
|
||||||
if ($retries > 0) {
|
if ($retries > 0) {
|
||||||
common_log(LOG_INFO, "$msg; scheduling for $retries more tries");
|
common_log(LOG_INFO, "$msg; scheduling for $retries more tries");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user