def shouldStartAfter(self): if self.endDate: return auction = self.__parent__ if auction.status not in ['active.tendering', 'active.auction']: return if self.startDate and get_now() > calc_auction_end_time(NUMBER_OF_STAGES, self.startDate): start_after = calc_auction_end_time(NUMBER_OF_STAGES, self.startDate) elif auction.enquiryPeriod and auction.enquiryPeriod.endDate: start_after = auction.enquiryPeriod.endDate else: return return rounding_shouldStartAfter_after_midnigth(start_after, auction).isoformat()
def next_check(self): if self.suspended: return None now = get_now() checks = [] if self.status == 'active.tendering' and self.enquiryPeriod and self.enquiryPeriod.endDate: checks.append(self.enquiryPeriod.endDate.astimezone(TZ)) elif not self.lots and self.status == 'active.auction' and self.auctionPeriod and self.auctionPeriod.startDate and not self.auctionPeriod.endDate: if now < self.auctionPeriod.startDate: checks.append(self.auctionPeriod.startDate.astimezone(TZ)) elif now < calc_auction_end_time(NUMBER_OF_STAGES, self.auctionPeriod.startDate).astimezone(TZ): checks.append(calc_auction_end_time(NUMBER_OF_STAGES, self.auctionPeriod.startDate).astimezone(TZ)) elif not self.lots and self.status == 'active.qualification': for award in self.awards: if award.status == 'pending': checks.append(award.verificationPeriod.endDate.astimezone(TZ)) elif not self.lots and self.status == 'active.awarded' and not any([ i.status in self.block_complaint_status for i in self.complaints ]) and not any([ i.status in self.block_complaint_status for a in self.awards for i in a.complaints ]): standStillEnds = [ a.complaintPeriod.endDate.astimezone(TZ) for a in self.awards if a.complaintPeriod.endDate ] for award in self.awards: if award.status == 'active': checks.append(award.signingPeriod.endDate.astimezone(TZ)) last_award_status = self.awards[-1].status if self.awards else '' if standStillEnds and last_award_status == 'unsuccessful': checks.append(max(standStillEnds)) if self.status.startswith('active'): from openprocurement.auctions.core.utils import calculate_business_date for complaint in self.complaints: if complaint.status == 'claim' and complaint.dateSubmitted: checks.append(calculate_business_date(complaint.dateSubmitted, AUCTIONS_COMPLAINT_STAND_STILL_TIME, self)) elif complaint.status == 'answered' and complaint.dateAnswered: checks.append(calculate_business_date(complaint.dateAnswered, AUCTIONS_COMPLAINT_STAND_STILL_TIME, self)) for award in self.awards: for complaint in award.complaints: if complaint.status == 'claim' and complaint.dateSubmitted: checks.append(calculate_business_date(complaint.dateSubmitted, AUCTIONS_COMPLAINT_STAND_STILL_TIME, self)) elif complaint.status == 'answered' and complaint.dateAnswered: checks.append(calculate_business_date(complaint.dateAnswered, AUCTIONS_COMPLAINT_STAND_STILL_TIME, self)) return min(checks).isoformat() if checks else None