[PITCH] - Kairos - Church Management System | Sistema de Gestão para Igrejas

🎉 Pessoal, quero compartilhar um projeto que está ganhando vida!

☕ Entre códigos e ideias, estou desenvolvendo o Kairos - um projeto que tem me deixado super empolgado! Ainda está em desenvolvimento, mas já quero compartilhar essa jornada com vocês.

💡 A ideia surgiu da vontade de criar um sistema de gestão organizacional que seja realmente intuitivo e agradável de usar. Cada linha de código está sendo escrita pensando na melhor experiência possível!

🛠️ Stack escolhida para o projeto: • Next.js 15 • Fastify no backend • UI moderna com shadcn/ui • Orval para tipagem automática entre front e back Em breve compartilho mais novidades! Estou muito animado para ver esse projeto crescer e evoluir.

uma demonstração: https://drive.google.com/file/d/1yEquZaR1ftQdMZzzzwsX_jjLNtGJd90D/view?usp=sharing

Kairos é um sistema abrangente de gestão para igrejas, projetado para simplificar tarefas administrativas e melhorar o engajamento da comunidade. Construído com tecnologias modernas e focado na experiência do usuário, fornece ferramentas para gestão de membros, coordenação de grupos e organização de eventos.

🚀 Funcionalidades

Autenticação e Configuração

  • Sistema completo de autenticação baseado em JWT
  • Configuração inicial da igreja
  • Recuperação de senha
  • Controle de acesso baseado em funções

Gestão de Membros

  • Perfis completos dos membros
    • Informações pessoais
    • Dados de contato
    • Datas importantes
    • Informações profissionais
    • Estado civil
  • Sistema avançado de filtros
  • Histórico de participação
  • Suporte à deleção em cascata

Grupos e Células

  • Suporte a múltiplos tipos de grupos (células, ministérios, cursos)
  • Sistema inteligente de agendamento
    • Prevenção de conflitos
    • Suporte a múltiplas salas
    • Validação de formato de horário
  • Atribuição de liderança
  • Associação de membros
  • Acompanhamento de participação

Eventos

  • Criação e gestão de eventos
  • Controle de presença
  • Sistema de check-in
  • Listagem de participantes

🛠 Stack Tecnológica

Backend

  • Framework: Fastify
  • Banco de Dados: SQLite com Prisma ORM
  • Autenticação: JWT
  • Validação: Zod
  • Testes: Cobertura completa para funcionalidades principais

Frontend

  • Framework: Next.js 15
  • Linguagem: TypeScript
  • Estilização: Tailwind CSS
  • Componentes UI: shadcn/ui

💼 Estou disponível para projetos freelancer!

Se sua igreja ou organização estiver interessada em uma solução de gestão personalizada, ou se você precisar de ajuda com desenvolvimento de software, fique à vontade para me contatar! Estou sempre aberto a novas oportunidades.

📞 Contato via WhatsApp: 21 98168-6736

Mano muito legal que esteja fazendo um sistema pra parte de igrejas, creio que existe uma necessidade latente, porém creio que pra esse projeto ir pro ar mais fácil, você deveria reduzir o escopo, é um escopo muito grande o que você quer e se estiver sozinho vai ser meio treta.

Eu acho que seria bacana focar na parte de membresia

Como contribuição também deixo um link de um possível concorrente, acho que vale dar uma fuçada pra ver quais problemas que você ache nele que seu projeto pode resolver melhor, o https://voluts.com.br/

Qualquer coisa to a disposição mano! Tmj.

Ah sim mano, obg pelo feedback, a maior parte das coisas como auth, membros, grupos e eventos, ja estao feitas no back.. a princípio vou focar nessas, mas vou dar uma olhada no link q vc compartilhou.. obg mesmo.. abs.

Parabéns pelo projeto! Curti muito a sua landing page de divulgação, comprou ou usou algum layout pronto?

Opa, obg pelo feedback, que bom que gostou.. Fui eu que fiz a landing page tbm.. normalmente eu faço todas as partes dos meus projetos rs. se precisar so chamar rs.

Convenhamos, resolveria com uma tabela de excel!

Até pq todo mundo sabe mexer com excel né? fazer graficos e funções no excel. Dependendo de quem faria sim .. resolveria. mas não em todos os casos, e não para todas as igrejas.

Só acho que SQLite, por mais que seja simples, é fraquinho demais para colocar um projeto em produção. Talvez deva pensar um pouco sobre implementar PostgreSQL ou até MySQL.

E ai, `silvestrini` ! Beleza ? Na sua opinião o que de fato ele está perdendo em utilizar o SQLite nessa situação ? É uma pergunta honesta, tenho zero conhecimento...
Falando de maneira geral, primeiro a gente tem que definir o que seria "colocar em produção". Pois no meu entendimento, este termo significa que o produto/sistema/aplicativo foi lançado e está sendo efetivamente utilizado pelos usuários/clientes. E nesse sentido, o SQLite é um dos *softwares* mais usados - [senão o mais usado](https://www.sqlite.org/mostdeployed.html) - do mundo em ambiente de produção, se considerarmos a quantidade de instâncias ativas. Afinal, só no seu computador e celular estão instalados vários programas que usam o SQLite de alguma forma. A lista de sistemas e programas usando-o em produção é enorme ([esta lista parcial dá uma ideia de que não é só "peixe pequeno" que usa](https://www.sqlite.org/famous.html)). Ou seja, o SQLite está em produção e muito bem, com bilhões (talvez trilhões) de instâncias ativas. Por isso dizer que ele é "fraco para colocar em produção" eu acho bem equivocado, pois na verdade depende muito da situação. Tem casos em que ele funciona e atende muito bem a demanda, e casos em que outros bancos atendem melhor. Sobre o caso específico do post, pela breve descrição *parece* que haverá múltiplas escritas simultâneas e muitos acessos vindos de _clients_ diferentes a um servidor único, e neste cenário o SQLite não se sai bem. E isso não é demérito: toda tecnologia tem casos em que ela atende bem e outros nos quais ela não é a melhor opção. --- Acho que o problema é que a maioria das pessoas costuma considerar apenas sistemas web distribuídos, e aí realmente existem outros bancos de dados que podem se encaixar melhor nestes cenários. Mas isso não quer dizer que o SQLite é "fraquinho" ou não sirva pra web. [No próprio site deles](https://www.sqlite.org/whentouse.html) diz o seguinte (em tradução livre): > *O SQLite funciona bem como banco de dados para sites com tráfego pequeno e médio (que é a maioria dos sites). O tráfego que ele suporta depende muito de como o site usa o banco. De forma geral, qualquer site que tenha menos de 100 mil acessos por dia funcionará bem com SQLite. E este número é uma estimativa conservadora, não um limite. O SQLite já mostrou que consegue lidar com tráfego 10 vezes maior que isso.* > > *O próprio site do SQLite (https://www.sqlite.org) usa SQLite, claro, e atualmente (2015) suporta entre 400 e 500 mil requests HTTP por dia, dos quais cerca de 15% a 20% são páginas dinâmicas que são consultadas no banco. Este conteúdo dinâmico usa cerca de 200 instruções SQL por página. Esta configuração roda em uma única máquina virtual que compartilha um servidor físico com outras 23, e ainda sim mantém uma carga média de 0.1 na maior parte do tempo.* Claro que o site do SQLite não parece fazer uso extensivo do banco, e os acessos são todos (ou a grande maioria) de leitura. E obviamente que eles vão tentar vender o próprio peixe. Mas a questão não é ser "fraquinho", e sim ser o resultado de várias decisões de *design* para que ele atinja sua proposta, que inclusive é citada no mesmo link indicado acima: > *O SQLite não pode ser comparado com engines de bancos de dados cliente/servidor como MySQL, Oracle, PostgreSQL ou SQL Server, porque o SQLite está tentando resolver problemas diferentes.* Então não é questão de ser "fraco", apenas de seguir uma abordagem diferente a fim de atacar problemas que os bancos "tradicionais" não conseguem resolver tão bem quanto ele. E nesses tipos específicos de problema que o SQLite quer atacar, ele serve muito bem para colocar em produção. Tudo depende do que vc precisa, e claro que ele não vai servir para todos os casos. Inclusive, [no link já citado](https://www.sqlite.org/whentouse.html) tem uma lista bem extensa de situações em que ele pode ser usado sem problemas, e casos em que outros bancos de dados se saem melhor. O problema é que - pelo menos essa é minha impressão - as pessoas geralmente pensam em sistemas web distribuídos, com muitos clients acessando o banco através de rede, escritas simultâneas, etc (situação na qual o SQLite realmente não é a melhor opção). E aí generalizam para "SQLite é fraco", "não serve pra produção", etc.
Curiosamente na web é onde o SQLite deveria ser mais usado. Claro que tem sistemas que está falando que caem na questão de grande escrita simultânea, mas é raro e provavelmente não deveria ser web. Existem soluções prontas e não é tão difícil fazer o SQLite suportar escritas simultâneas (em geral fazendo fila). Não é o ideal e dá um pouco de trabalho, pelo menos uma vez, mas é possível usar para este objetivo também, ainda que eu não esteja recomendando, de fato existem outros mais adequados. Tem que pesar o que é mais importante. O ponto fraco dele é este mesmo, mas tem solução se a pessoa realmente quiser, e souber fazer. Escrita simultânea acontece bem menos do que as pessoas imaginam na esmagadora maioria dos casos. O site deles descreve onde deve ser usado de forma extremamente conservadora e foi escrito e nunca mudado na época que o SQLite era bem mais limitado, inclusive não podia fazer escrita e leitura simultânea. Hoje ele é adequado para muito mais que eles descrevem lá, nem vendem bem o peixe. Websites mesmo é para ele ser adequado em praticamente 100% dos casos. O autor do comentário deu mais parâmetros para a opinião dele e vimos que o SQLite é fraquinho usando o Laravel. Aí já diz muito. Portanto "a culpa é do SQLite e não do Laravel". O segundo item dele não faz o menor sentido, inclusive inverte o próprio argumento. e não entende como os outros dbs funcionam, parece achar que é mágica. O SQLite realmente funciona melhor na mão de quem sabe desenvolver software, que não precisa se valer de *frameworks* e coisas prontas. Você o coloca onde quiser e for adequado para a necessidade, igual acontece com os outros SGDBs que você instala um software para poder usar. O item 3 ignora que a maioria das aplicações só precisa ter acesso a um usuário que é a própria aplicação e o sistema tem seu próprio controle de usuários. O sistema de usuários do banco de dados é feito para casos em que os usuários acessam diretamente o db e não através de um sistema. Se a pessoa souber fazer sistemas e ainda assim precisa ter controle de usuários nele de fato o SQLite não é adequado, que é diferente de ser fraquinho ou não servir para produção. A pessoa ignora também que qualquer um pode acessar os dados do MySQL, PostgreSQL, SQL Server, etc. O fato dele não saber disso é que deixa **tudo** inseguro. O que pode ser feito para tornar esses sistemas seguros, pode ser feito de forma idêntica com o SQLite. Uma coisa é certa, para quem não conhece o SQLite, e outros aspectos da computação, realmente essa pessoa não deve usá-lo, porque ela é fraquinha e não deveria colocar coisas em produção. Eu não tenho dados suficientes para avaliar se o Kairos deveria ou não usar o SQLite, mas estatisticamente a chance é grande de ser uma boa ou até a melhor ferramenta para a tarefa. Espero que o autor esteja usado ele certo e tenha sucesso pensando fora da caixa. --- Farei algo que muitos pedem para aprender a programar corretamente, **gratuitamente** (não vendo nada, é retribuição na minha aposentadoria) ([links aqui](https://github.com/maniero/SOpt) no perfil também).
Se velocidade, confiabilidade e segurança importar para o seu projeto, então sim, está perdendo. Por que? 1 - (Velocidade/Performance) - Eu utilizo Laravel para meus projetos, o padrão dele é SQLite, pois é muito fácil, não precisa instalar nada demais, então para iniciantes é ótimo. Você só instala uma extensão para ler o arquivo no VS Code e já era. Porém, nem tudo são flores. Quando se roda as migrations para criar as tabelas e popular o banco de dados com dados fake, aí que você percebe o abismo de velocidade que tem entre SQLite e PostgreSQL, por exemplo, o primeiro sendo o mais lento e o segundo o mais rápido. E o MySQL fica no meio do caminho. O Artisan mostra o tempo que levou para cada coisa. Como o exemplo na imagem abaixo. E isso impacta o seu sistema como um todo, todas as queries são mais lentas. ![](https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fgzxr94jhigem9pmdnlt9.png) 2 - (Confiabilidade) - Um banco de dados SQLite, nada mais é que apenas um arquivo com a extensão .sqlite, que é guardado em qualquer lugar, geralmente na pasta do projeto, pois não suporta multiplos databases no mesmo arquivo. Cada arquivo se refere apenas a um banco de dados. Como é um arquivo que pode ser salvo em qualquer lugar, há a possibilidade, por exemplo, de se corromper mais fácil, ou ter algum problema com permissões e você não conseguir utilizá-lo. 3 - (Segurança) - Aqui é um pouco indiscutível, pois é o que define que o SQLite realmente não seja utilizado em produção, a não ser em casos muitos específicos, como app mobile. No SQLite não se tem controle de usuários, permissões, controle de hosts que podem acessar, como existe no MySQL e no PostgreSQL (que ainda tem o pg_hba para configurar ips liberados). Qualquer um pode acessar o seu banco e ver todas as informações nele contidas, o que não é nada interessante. Ou seja, em geral, SQLite deve ser utilizado somente para desenvolvimento, pois peca nos aspectos por mim citados acima. Claro que essa é uma visão pessoal, mas fica a reflexão desses pontos. Mesmo em desenvolvimento, dificilmente utilizo SQLite, pois para mim, a performance importa muito.
Olá bom dia SQLite não é fraco, ele atende muito bem ao que é proposto. Em muitos casos você não precisa de uma basuca pra matar uma formiga. Se você só precisa salvar informações de texto e número no banco, SQLite vai te atender. - https://youtu.be/VzQgr-TgBzc?si=H7LwmsZ0gv673HLB
Com certeza mano.. o sqlite eh só pra desenvolvimento.. to usando o prisma q facilita eu poder trocar de bd.. normalmente eu uso o PostgreSQL.