96 lines
3.7 KiB
Python
96 lines
3.7 KiB
Python
# Copyright The IETF Trust 2007-2019, All Rights Reserved
|
|
# -*- coding: utf-8 -*-
|
|
#
|
|
# Portion Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies).
|
|
# All rights reserved. Contact: Pasi Eronen <pasi.eronen@nokia.com>
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions
|
|
# are met:
|
|
#
|
|
# * Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
#
|
|
# * Redistributions in binary form must reproduce the above
|
|
# copyright notice, this list of conditions and the following
|
|
# disclaimer in the documentation and/or other materials provided
|
|
# with the distribution.
|
|
#
|
|
# * Neither the name of the Nokia Corporation and/or its
|
|
# subsidiary(-ies) nor the names of its contributors may be used
|
|
# to endorse or promote products derived from this software
|
|
# without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
from __future__ import absolute_import, print_function, unicode_literals
|
|
|
|
import datetime
|
|
|
|
from django.db import models
|
|
from django.utils.encoding import python_2_unicode_compatible
|
|
|
|
@python_2_unicode_compatible
|
|
class TelechatAgendaItem(models.Model):
|
|
TYPE_CHOICES = (
|
|
(1, "Any Other Business (WG News, New Proposals, etc.)"),
|
|
(2, "IAB News"),
|
|
(3, "Management Item")
|
|
)
|
|
TYPE_CHOICES_DICT = dict(TYPE_CHOICES)
|
|
id = models.AutoField(primary_key=True, db_column='template_id')
|
|
text = models.TextField(blank=True, db_column='template_text')
|
|
type = models.IntegerField(db_column='template_type', choices=TYPE_CHOICES, default=3)
|
|
title = models.CharField(max_length=255, db_column='template_title')
|
|
|
|
def __str__(self):
|
|
type_name = self.TYPE_CHOICES_DICT.get(self.type, str(self.type))
|
|
return "%s: %s" % (type_name, self.title or "")
|
|
|
|
class Telechat(models.Model):
|
|
telechat_id = models.IntegerField(primary_key=True)
|
|
telechat_date = models.DateField(null=True, blank=True)
|
|
minute_approved = models.IntegerField(null=True, blank=True)
|
|
wg_news_txt = models.TextField(blank=True)
|
|
iab_news_txt = models.TextField(blank=True)
|
|
management_issue = models.TextField(blank=True)
|
|
frozen = models.IntegerField(null=True, blank=True)
|
|
mi_frozen = models.IntegerField(null=True, blank=True)
|
|
|
|
class Meta:
|
|
db_table = 'telechat'
|
|
|
|
|
|
def next_telechat_date():
|
|
dates = TelechatDate.objects.order_by("-date")
|
|
if dates:
|
|
return dates[0].date + datetime.timedelta(days=14)
|
|
return datetime.date.today()
|
|
|
|
class TelechatDateManager(models.Manager):
|
|
def active(self):
|
|
return self.get_queryset().filter(date__gte=datetime.date.today())
|
|
|
|
@python_2_unicode_compatible
|
|
class TelechatDate(models.Model):
|
|
objects = TelechatDateManager()
|
|
|
|
date = models.DateField(default=next_telechat_date)
|
|
|
|
def __str__(self):
|
|
return self.date.isoformat()
|
|
|
|
class Meta:
|
|
ordering = ['-date']
|