Esempio n. 1
0
class TurnoCargo(db.Model):
    id_turno_cargo = db.Column(db.Integer, primary_key=True)
    id_turno = db.Column(db.Integer,
                         db.ForeignKey('turno.id_turno'),
                         nullable=False)
    id_cargo = db.Column(db.Integer,
                         db.ForeignKey('cargo.id_cargo'),
                         nullable=False)
    turno_cargo_regioes = db.relationship('TurnoCargoRegiao',
                                          backref='turnoCargo',
                                          cascade='all, delete-orphan')

    def __repr__(self):
        return f'idTurnoCargo: {self.id_turno_cargo}'

    def to_json(self):
        return {
            'idTurnoCargo':
            self.id_turno_cargo,
            'idTurno':
            self.id_turno,
            'cargo':
            self.cargo.to_json(),
            'turnoCargoRegioes':
            [tcr.to_json() for tcr in self.turno_cargo_regioes]
        }

    def turno_cargo_regiao_by_id(self, id_turno_cargo_regiao):
        regioes = [
            tcr for tcr in self.turno_cargo_regioes
            if tcr.id_turno_cargo_regiao == id_turno_cargo_regiao
        ]
        return regioes[0] if len(regioes) == 1 else TurnoCargoRegiao()
Esempio n. 2
0
class VotoEncriptado(db.Model):
    id_voto_encriptado = db.Column(db.Integer, primary_key=True)
    id_turno_cargo_regiao = db.Column(
        db.Integer,
        db.ForeignKey('turno_cargo_regiao.id_turno_cargo_regiao'),
        nullable=False)
    id_cidade = db.Column(db.Integer,
                          db.ForeignKey('cidade.id_cidade'),
                          nullable=False)
    id_candidato = db.Column(db.Text)
    id_partido = db.Column(db.Text)
    id_eleitor = db.Column(db.Text, nullable=False)
Esempio n. 3
0
class EleitorTurno(db.Model):
    id_eleitor_turno = db.Column(db.Integer, primary_key=True)
    id_eleitor = db.Column(db.Integer,
                           db.ForeignKey('eleitor.id_eleitor'),
                           nullable=False)
    id_turno = db.Column(db.Integer,
                         db.ForeignKey('turno.id_turno'),
                         nullable=False)
    hash = db.Column(db.String, nullable=False)
    hora_voto = db.Column(db.DateTime, nullable=False)

    __table_args__ = (db.UniqueConstraint('id_eleitor',
                                          'id_turno',
                                          name='unique_eleitor_turno'), )
Esempio n. 4
0
class Cidade(db.Model):
    id_cidade = db.Column(db.Integer, primary_key=True)
    id_estado = db.Column(db.Integer,
                          db.ForeignKey('estado.id_estado'),
                          nullable=False)
    nome = db.Column(db.String(100), nullable=False)
    turno_cargo_regioes = db.relationship('TurnoCargoRegiao',
                                          backref='cidade',
                                          lazy=True)
    eleitores = db.relationship('Eleitor', backref='cidade', lazy=True)
    votos_encriptados = db.relationship('VotoEncriptado',
                                        backref='cidade',
                                        lazy=True)
    votos_apurados = db.relationship('VotoApurado',
                                     backref='cidade',
                                     lazy=True)

    def __repr__(self):
        return f'idCidade: {self.id_cidade}, nome: {self.nome}'

    def to_json(self):
        return {
            'idCidade': self.id_cidade,
            'nome': self.nome,
            'estado': self.estado.to_json()
        }
Esempio n. 5
0
class Apuracao(db.Model):
    id_apuracao = db.Column(db.Integer, primary_key=True)
    id_turno = db.Column(db.Integer,
                         db.ForeignKey('turno.id_turno'),
                         nullable=False)
    inicio_apuracao = db.Column(db.DateTime, nullable=False)
    termino_apuracao = db.Column(db.DateTime)
Esempio n. 6
0
class VotoApurado(db.Model):
    id_voto_apurado = db.Column(db.Integer, primary_key=True)
    id_turno_cargo_regiao = db.Column(
        db.Integer,
        db.ForeignKey('turno_cargo_regiao.id_turno_cargo_regiao'),
        nullable=False)
    id_cidade = db.Column(db.Integer, db.ForeignKey('cidade.id_cidade'))
    id_candidato = db.Column(db.Integer,
                             db.ForeignKey('candidato.id_candidato'))
    id_partido = db.Column(db.Integer, db.ForeignKey('partido.id_partido'))
    id_apuracao = db.Column(db.Integer, db.ForeignKey('apuracao.id_apuracao'))

    def to_json(self):
        return {
            'idCargo': self.id_cargo,
            'idEleicao': self.id_eleicao,
            'idCidade': self.id_cidade,
            'candidato': self.candidato
        }
Esempio n. 7
0
class TurnoCargoRegiao(db.Model):
    id_turno_cargo_regiao = db.Column(db.Integer, primary_key=True)
    id_turno_cargo = db.Column(db.Integer,
                               db.ForeignKey('turno_cargo.id_turno_cargo'),
                               nullable=False)
    qtd_cadeiras = db.Column(db.Integer, nullable=False)
    possui_segundo_turno = db.Column(db.Boolean, nullable=False)
    id_cidade = db.Column(db.Integer, db.ForeignKey('cidade.id_cidade'))
    id_estado = db.Column(db.Integer, db.ForeignKey('estado.id_estado'))
    votosEncriptados = db.relationship('VotoEncriptado',
                                       backref='turnoCargoRegiao',
                                       lazy=True,
                                       cascade='all, delete-orphan')
    votosApurados = db.relationship('VotoApurado',
                                    backref='turnoCargoRegiao',
                                    lazy=True,
                                    cascade='all, delete-orphan')
    candidatos = db.relationship('Candidato',
                                 backref='turnoCargoRegiao',
                                 lazy=True,
                                 cascade='all, delete-orphan')

    def __repr__(self):
        return f'idTurnoCargoRegiao: {self.id_turno_cargo_regiao}'

    def to_json(self):
        json = {
            'idTurnoCargoRegiao': self.id_turno_cargo_regiao,
            'qtdCadeiras': self.qtd_cadeiras,
            'possuiSegundoTurno': self.possui_segundo_turno,
        }

        if self.cidade is not None:
            json['cidade'] = self.cidade.to_json()
        if self.estado is not None:
            json['estado'] = self.estado.to_json()
        return json

    __table_args__ = (db.UniqueConstraint('id_turno_cargo',
                                          'id_cidade',
                                          'id_estado',
                                          name='unique_turno_cargo_regiao'), )
Esempio n. 8
0
class Coligacao(db.Model):
    id_coligacao = db.Column(db.Integer, primary_key=True)
    nome = db.Column(db.String(100), nullable=False)
    id_eleicao = db.Column(db.Integer,
                           db.ForeignKey('eleicao.id_eleicao'),
                           nullable=False)
    partidos = db.relationship('Partido', secondary=coligacao_partido)
    id_cidade = db.Column(db.Integer, db.ForeignKey('cidade.id_cidade'))
    id_estado = db.Column(db.Integer, db.ForeignKey('estado.id_estado'))

    def __repr__(self):
        return f'idColigacao: {self.id_coligacao}, nome: {self.nome}'

    def to_json(self):
        return {
            'idColigacao': self.id_coligacao,
            'nome': self.nome,
            'idEleicao': self.id_eleicao,
            'partidos': [p.to_json() for p in self.partidos]
        }
Esempio n. 9
0
class Candidato(db.Model):
    id_candidato = db.Column(db.Integer, primary_key=True)
    numero = db.Column(db.Integer, nullable=False)
    id_partido = db.Column(db.Integer,
                           db.ForeignKey('partido.id_partido'),
                           nullable=False)
    id_turno_cargo_regiao = db.Column(
        db.Integer,
        db.ForeignKey('turno_cargo_regiao.id_turno_cargo_regiao'),
        nullable=False)
    id_candidato_principal = db.Column(db.Integer,
                                       db.ForeignKey('candidato.id_candidato'))
    id_pessoa = db.Column(db.Integer,
                          db.ForeignKey('pessoa.id_pessoa'),
                          nullable=False)
    vice = db.relationship('Candidato',
                           backref=db.backref(
                               'candidato_principal',
                               remote_side='Candidato.id_candidato',
                               uselist=False),
                           uselist=False)
    votos = db.relationship('VotoApurado', backref='candidato', lazy=True)
    qt_votos = db.Column(db.Integer, nullable=False, default=0)
    situacao = db.Column(db.String(50), nullable=False, default='Não Eleito')

    def __repr__(self):
        return f'idCandidato: {self.id_candidato}, número: {self.numero}'

    def to_json(self):
        return {
            'idCandidato': self.id_candidato,
            'numero': self.numero,
            'partido': self.partido.to_json(),
            'turnoCargoRegiao': self.turnoCargoRegiao.to_json(),
            'pessoa': self.pessoa.to_json(),
            'situacao': self.situacao,
            'votos': self.qt_votos if self.qt_votos != 0 else len(self.votos),
            'viceCandidato':
            self.vice.to_json() if self.vice is not None else None
        }
Esempio n. 10
0
class PinEleitor(db.Model):
    id_pin_eleitor = db.Column(db.Integer, primary_key=True)
    id_eleitor = db.Column(db.Integer,
                           db.ForeignKey('eleitor.id_eleitor'),
                           nullable=False)
    pin = db.Column(db.String, nullable=False)
    criacao = db.Column(db.DateTime, nullable=False)

    def __repr__(self):
        return f'idEleitor: {self.id_eleitor}, pin: {self.pin}, criação: {self.criacao}'

    def to_json(self):
        return {'pin': self.pin}
Esempio n. 11
0
class Eleitor(db.Model):
    id_eleitor = db.Column(db.Integer, primary_key=True)
    id_pessoa = db.Column(db.Integer,
                          db.ForeignKey('pessoa.id_pessoa'),
                          nullable=False)
    zona_eleitoral = db.Column(db.String(3), nullable=False)
    secao = db.Column(db.String(4), nullable=False)
    numero_inscricao = db.Column(db.String(12), nullable=False, unique=True)
    id_cidade = db.Column(db.Integer,
                          db.ForeignKey('cidade.id_cidade'),
                          nullable=False)
    eleitor_turnos = db.relationship('EleitorTurno', backref='eleitor')

    def __repr__(self):
        return f'idEleitor: {self.id_eleitor}, número inscrição: {self.numero_inscricao}'

    def to_json(self):
        return {
            'idEleitor': self.id_eleitor,
            'zonaEleitoral': self.zona_eleitoral,
            'numeroInscricao': self.numero_inscricao,
            'secao': self.secao,
            'cidade': self.cidade.to_json()
        }
Esempio n. 12
0
class Turno(db.Model):
    id_turno = db.Column(db.Integer, primary_key=True)
    id_eleicao = db.Column(db.Integer,
                           db.ForeignKey('eleicao.id_eleicao'),
                           nullable=False)
    turno = db.Column(db.Integer, nullable=False)
    inicio = db.Column(db.DateTime)
    termino = db.Column(db.DateTime)
    turnosCargos = db.relationship('TurnoCargo',
                                   backref='turno',
                                   lazy=True,
                                   cascade='all, delete-orphan')
    apuracoes = db.relationship('Apuracao', backref='turno')

    __table_args__ = (db.UniqueConstraint('id_eleicao',
                                          'turno',
                                          name='unique_turno_eleicao'), )

    def __repr__(self):
        return f'idTurno: {self.id_turno}, idEleicao: {self.id_eleicao}, início: {self.inicio}, término: {self.termino}'

    def turno_cargo_by_id(self, id_turno_cargo):
        tcs = [
            tc for tc in self.turnosCargos
            if tc.id_turno_cargo == id_turno_cargo
        ]
        return tcs[0] if len(tcs) == 1 else TurnoCargo()

    def to_json(self):
        if self.termino is None or not self.eleicao.confirmada:
            situacao = 'Aguardando lançamento'
        elif self.termino > datetime.now():
            situacao = 'Em andamento'
        elif not self.apuracoes:
            situacao = 'Aguardando apuração'
        elif [a for a in self.apuracoes if a.termino_apuracao is None]:
            situacao = 'Em apuração'
        else:
            situacao = 'Apurado'

        return {
            'idTurno': self.id_turno,
            'turno': self.turno,
            'inicio': str(self.inicio) if self.inicio is not None else None,
            'termino': str(self.termino) if self.termino is not None else None,
            'turnoCargos': [tc.to_json() for tc in self.turnosCargos],
            'situacao': situacao
        }
Esempio n. 13
0
class Login(db.Model):
    id_login = db.Column(db.Integer, primary_key=True)
    usuario = db.Column(db.String(50), nullable=False, unique=True)
    senha = db.Column(db.String(100), nullable=False)
    id_pessoa = db.Column(db.Integer,
                          db.ForeignKey('pessoa.id_pessoa'),
                          nullable=False)
    perfis = db.relationship('Perfil', secondary=login_perfil)

    def __repr__(self):
        return f'idLogin: {self.id_login}, usuário: {self.usuario}'

    def has_perfil(self, perfil):
        return len([p for p in self.perfis if p.nome == perfil]) > 0

    def to_json(self):
        return {
            'pessoa': self.pessoa.to_json(),
            'perfis': [perfil.to_json() for perfil in self.perfis]
        }
Esempio n. 14
0
class Cargo(db.Model):
    id_cargo = db.Column(db.Integer, primary_key=True)
    id_tipo_cargo = db.Column(db.Integer,
                              db.ForeignKey('tipo_cargo.id_tipo_cargo'),
                              nullable=False)
    nome = db.Column(db.String(20), nullable=False, unique=True)
    max_votos = db.Column(db.Integer, nullable=False)
    tam_numero_candidato = db.Column(db.Integer, nullable=False)
    sistema_eleicao = db.Column(db.String(30), nullable=False)
    permite_segundo_turno = db.Column(db.Boolean, nullable=False)
    turnosCargos = db.relationship('TurnoCargo', backref='cargo', lazy=True)

    def __repr__(self):
        return f'idCargo: {self.id_cargo}, nome: {self.nome}'

    def to_json(self):
        return {
            'idCargo': self.id_cargo,
            'nome': self.nome,
            'sistemaEleicao': self.sistema_eleicao,
            'permiteSegundoTurno': self.permite_segundo_turno,
            'tipoCargo': self.tipoCargo.nome,
            'tamNumeroCandiato': self.tam_numero_candidato
        }
Esempio n. 15
0
        if self.cidade is not None:
            json['cidade'] = self.cidade.to_json()
        if self.estado is not None:
            json['estado'] = self.estado.to_json()
        return json

    __table_args__ = (db.UniqueConstraint('id_turno_cargo',
                                          'id_cidade',
                                          'id_estado',
                                          name='unique_turno_cargo_regiao'), )


coligacao_partido = db.Table(
    'coligacao_partido', db.Model.metadata,
    db.Column('id_coligacao', db.Integer,
              db.ForeignKey('coligacao.id_coligacao')),
    db.Column('id_partido', db.Integer, db.ForeignKey('partido.id_partido')))


class Coligacao(db.Model):
    id_coligacao = db.Column(db.Integer, primary_key=True)
    nome = db.Column(db.String(100), nullable=False)
    id_eleicao = db.Column(db.Integer,
                           db.ForeignKey('eleicao.id_eleicao'),
                           nullable=False)
    partidos = db.relationship('Partido', secondary=coligacao_partido)
    id_cidade = db.Column(db.Integer, db.ForeignKey('cidade.id_cidade'))
    id_estado = db.Column(db.Integer, db.ForeignKey('estado.id_estado'))

    def __repr__(self):
        return f'idColigacao: {self.id_coligacao}, nome: {self.nome}'