O pass.in é uma aplicação de gestão de participantes em eventos presenciais. A ferramenta permite que o organizador cadastre um evento e abra uma página pública de inscrição. Os participantes inscritos podem emitir uma credencial para check-in no dia do evento. O sistema fará um scan da credencial do participante para permitir a entrada no evento.
- Clone este repositório
- Execute
npm install
para instalar as dependências - Execute
npm run dev
para iniciar o servidor local - Execute
npm run db:migrate
para rodar as migrations no banco de dados
Para documentação da API, acesse o link: http://localhost:3333/docs
- O organizador deve poder cadastrar um novo evento
- O organizador deve poder visualizar dados de um evento
- 0 organizador deve poder visualizar a lista de participantes
- 0 participante deve poder se inscrever em um evento
- 0 participante deve poder visualizar seu crachá de inscrição
- 0 participante deve poder realizar check-in no evento
- 0 participante só pode se inscrever em um evento uma única vez
- 0 participante só pode se inscrever em eventos com vagas disponíveis
- 0 participante só pode realizar check-in em um evento uma única vez
- 0 check-in no evento será realizado através de um QRCode
Nessa aplicação foi utilizado banco de dados relacional (SQL). Para ambiente de desenvolvimento adotei o SQLite pela facilidade do ambiente.
-- CreateTable
CREATE TABLE IF NOT EXISTS "events" (
"id" TEXT NOT NULL PRIMARY KEY,
"title" TEXT NOT NULL,
"details" TEXT,
"slug" TEXT NOT NULL,
"maximum_attendees" INTEGER,
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
);
-- CreateTable
CREATE TABLE IF NOT EXISTS "attendees" (
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
"name" TEXT NOT NULL,
"email" TEXT NOT NULL,
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
"event_id" TEXT NOT NULL,
CONSTRAINT "attendees_event_id_fkey" FOREIGN KEY ("event_id") REFERENCES "events" ("id") ON DELETE CASCADE ON UPDATE CASCADE
);
-- CreateTable
CREATE TABLE IF NOT EXISTS "check_ins" (
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
"attendee_id" INTEGER NOT NULL,
CONSTRAINT "check_ins_attendee_id_fkey" FOREIGN KEY ("attendee_id") REFERENCES "attendees" ("id") ON DELETE CASCADE ON UPDATE CASCADE
);
-- CreateIndex
CREATE UNIQUE INDEX "events_slug_key" ON "events"("slug");
-- CreateIndex
CREATE UNIQUE INDEX "attendees_event_id_email_key" ON "attendees"("event_id", "email");
-- CreateIndex
CREATE UNIQUE INDEX "check_ins_attendee_id_key" ON "check_ins"("attendee_id");