Skip to content

Câmara Organizada é uma forma simplificada de estruturar e manter as informações de Brasília. Aqui é possível organizar os parlamentares, as comissões e as propostas em curso.

Notifications You must be signed in to change notification settings

marcusvlc/camara-organizada

Repository files navigation

Câmara Organizada

Câmara Organizada é uma forma simplificada de estruturar e manter as informações de Brasília. Aqui é possível organizar os parlamentares, as comissões e as propostas em curso. Com isso, fica fácil de acompanhar quais as propostas estão sendo votadas e qual o posicionamento dos representantes e das comissões, além de manter um histórico do que já aconteceu.

Començando...

Por enquanto, você pode executar o Câmara com Java e Spring Boot instalados. Caso não os tenha, siga esse e esse, respectivamente.

Se você utilizar o Eclipse como IDE, fica ainda mais fácil. É só instalar o SpringSTS no Eclipse e definir as configurações de execução do código como projeto Spring e, assim, executá-lo normalmente.

Se você preferir executar pelo terminal, rode este comando:

mvn spring-boot:run

Como funciona?

  1. Como você tá deve ter percebido, este é um projeto codificado em Java usando o framework SpringBoot que facilita a configuração da aplicação.

  2. Arquitetura do código se baseia na divisão de funcionalidades de Controller, Service e Repository. Onde os Controllers recebem as requisições e as encaminha ao services especializados. Service tem a lógica da aplicação. A camada de Repository disponibiliza serviços para armazenar, alterar, deletar e buscar as informaçes do sistema. Confira o diagrama abaixo ou, se preferir, veja o diagrama de classes alt text

  3. Foi utilizado ORM Hibernate para a persistência, enquanto que para o banco de dados, é utilizado o H2. Para conferir o que foi armazenado, acesse http://localhost:8080/h2 e preencha os campos conforme os dados no arquivo application.properties. Para adicionar entidades e relações no BD é preciso apenas o uso de anotações como @Entity, @OneToOne, @OneToMany, @ManyToOne.

  4. Há o uso do Redis para a disponibilização de cache para algumas informações da aplicação. Assim como para o BD, a definição de informações cacheaveis é feita com anotações como @Cacheable, já disponibilizadas pelo Spring. Resultados: alt text

  5. No câmara organizada, existe a opção de fornecer dados para um servidor Kafka(Publisher). Atualmente apenas dados dos deputados registrados são enviados. A utilização é feita da seguinte maneira:

Antes de executar o câmara organizada, entre na pasta do kafka disponível no repositório e execute os seguintes comandos para subir os servidores do zookeeper/kafka.

bin/zookeeper-server-start.sh config/zookeeper.properties
bin/kafka-server-start.sh config/server.properties

Após ter o servidor do Kafka executando, execute o servidor do câmara organizada e toda vez que um novo deputado for registrado, ele será enviado para o servidor Kafka. O câmara cidadã é um micro-serviço que também utiliza-se do servidor Kafka (Consumer) para obter esses dados e mostrá-los em tempo real para a população. Para mais detalhes de como executar o câmara cidadã, confira o README.md da pasta cidada.

O Sistema pode ter administrador

  • Um administrador é cadastrável pela rota /admin com a operação de post. Ele pode realizar login como administrador, pela rota /login.
  • O login retorna um token, gerado a partir das informações do admininstrador, utilizando a biblioteca Json Web Token. Esse token permite ao administrador para consultar informações sobre usuários.
  • Como administrador o request GET para /user que possui retorno diferente, variando de acordo com as informações no cabeçalho Authorization Bearer <token>.
    • Caso seja feita uma requisição de consulta de usuários sem passar o token, apenas a informação DNI será retornada. Se o header contiver Authorization Bearer <token>, e o token for um token válido, a requisição GET para /user irá retornar, além do DNI, os campos de: nome, partido e estado.
    • Caso o token esteja mal formatado ou inválido, a requisição irá retornar um erro conforme a biblioteca JWT.

Quem está por trás disso

Se você quiser enteder mais detalhes do sistema, dá uma olhada no conjunto das funcionalidades que implementamos aqui. E qualquer dúvida é só perguntar aos contribuidores por email mesmo [email protected] e [email protected]

About

Câmara Organizada é uma forma simplificada de estruturar e manter as informações de Brasília. Aqui é possível organizar os parlamentares, as comissões e as propostas em curso.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published