diff --git a/CHANGELOG.txt b/CHANGELOG.txt index efb8161ac85111aff8d7d71b5f603583733cf18d..a29fde9a74abeba2d31084ab0f785d6dc499e1a9 100644 --- a/CHANGELOG.txt +++ b/CHANGELOG.txt @@ -3,6 +3,7 @@ Feeds 6.x xxxxxxxxxxxxxxxxxxxxxx -------------------------------- +- #906654 alex_b: Fix phantom subscriptions. - #867892 alex_b: PubSubHubbub - slow down import frequency of feeds that are subscribed to hub. - #908964 alex_b: Break out scheduler. Note: Features depends on Job Scheduler diff --git a/includes/FeedsSource.inc b/includes/FeedsSource.inc index 682fdf768a51e436a2fec8e165fd033d26d6ab5e..b6f2a89be98b1760db4ae9cbab4adb889e61d1ac 100644 --- a/includes/FeedsSource.inc +++ b/includes/FeedsSource.inc @@ -287,13 +287,20 @@ class FeedsSource extends FeedsConfigurable { } /** - * Override existing, only return source if importer and source 'exist'. + * Only return source if configuration is persistent and valid. * * @see FeedsConfigurable::existing(). */ public function existing() { - $this->importer->existing(); - return parent::existing(); + // If there is no feed nid given, there must be no content type specified. + // If there is a feed nid given, there must be a content type specified. + // Ensure that importer is persistent (= defined in code or DB). + // Ensure that source is persistent (= defined in DB). + if ((empty($this->feed_nid) && empty($this->importer->config['content_type'])) || + (!empty($this->feed_nid) && !empty($this->importer->config['content_type']))) { + $this->importer->existing(); + return parent::existing(); + } } /**