public function isActive($time = null) { if (is_null($time)) { $time = time(); } $c = SubscriptionPeer::getActiveCriteria($time); $c->addAnd(SubscriptionPeer::ID, $this->getId(), Criteria::EQUAL); return SubscriptionPeer::doCount($c) > 0; }
/** * Returns the number of related Subscription objects. * * @param Criteria $criteria * @param boolean $distinct * @param PropelPDO $con * @return int Count of related Subscription objects. * @throws PropelException */ public function countSubscriptions(Criteria $criteria = null, $distinct = false, PropelPDO $con = null) { if ($criteria === null) { $criteria = new Criteria(ZonePeer::DATABASE_NAME); } else { $criteria = clone $criteria; } if ($distinct) { $criteria->setDistinct(); } $count = null; if ($this->collSubscriptions === null) { if ($this->isNew()) { $count = 0; } else { $criteria->add(SubscriptionPeer::ZONE_ID, $this->id); $count = SubscriptionPeer::doCount($criteria, $con); } } else { // criteria has no effect for a new object if (!$this->isNew()) { // the following code is to determine if a new query is // called for. If the criteria is the same as the last // one, just return count of the collection. $criteria->add(SubscriptionPeer::ZONE_ID, $this->id); if (!isset($this->lastSubscriptionCriteria) || !$this->lastSubscriptionCriteria->equals($criteria)) { $count = SubscriptionPeer::doCount($criteria, $con); } else { $count = count($this->collSubscriptions); } } else { $count = count($this->collSubscriptions); } } return $count; }
public function hasActivity($activityId) { $c = SubscriptionPeer::getActiveCriteria(); $c->addAnd(SubscriptionPeer::CARD_ID, $this->getId(), Criteria::EQUAL); $c->addAnd(SubscriptionPeer::ACTIVITY_ID, $activityId); return SubscriptionPeer::doCount($c) > 0; }