{"id":30735601,"url":"https://github.com/wagnersuzano2/rocketseat-api-nodejs","last_synced_at":"2026-04-09T02:02:06.975Z","repository":{"id":309488763,"uuid":"1036414670","full_name":"WagnerSuzano2/rocketseat-api-nodejs","owner":"WagnerSuzano2","description":"Repositório do projeto \"Sua Primeira API com Node.js\" da Rocketseat. Uma API RESTful construída com Node.js, TypeScript e Fastify, com integração de banco de dados PostgreSQL via Docker, testes automatizados e documentação com Swagger","archived":false,"fork":false,"pushed_at":"2025-09-11T18:55:02.000Z","size":20,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-09-11T21:41:17.045Z","etag":null,"topics":["docker","nodejs","postgresql","rest-api","rocketseat","typescript"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/WagnerSuzano2.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-08-12T03:41:39.000Z","updated_at":"2025-09-11T18:55:06.000Z","dependencies_parsed_at":"2025-09-11T20:31:32.471Z","dependency_job_id":"30626dc3-78db-4040-84b7-77d4a2abc726","html_url":"https://github.com/WagnerSuzano2/rocketseat-api-nodejs","commit_stats":null,"previous_names":["wagnersuzano2/rocketseat-api-nodejs"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/WagnerSuzano2/rocketseat-api-nodejs","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/WagnerSuzano2%2Frocketseat-api-nodejs","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/WagnerSuzano2%2Frocketseat-api-nodejs/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/WagnerSuzano2%2Frocketseat-api-nodejs/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/WagnerSuzano2%2Frocketseat-api-nodejs/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/WagnerSuzano2","download_url":"https://codeload.github.com/WagnerSuzano2/rocketseat-api-nodejs/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/WagnerSuzano2%2Frocketseat-api-nodejs/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31581864,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-08T14:31:17.711Z","status":"online","status_checked_at":"2026-04-09T02:00:06.848Z","response_time":112,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","nodejs","postgresql","rest-api","rocketseat","typescript"],"created_at":"2025-09-03T20:11:43.302Z","updated_at":"2026-04-09T02:02:06.941Z","avatar_url":"https://github.com/WagnerSuzano2.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Desafio Node.js – API de Cursos\n\n[![Node.js](https://img.shields.io/badge/Node.js-22.x-green)](https://nodejs.org/en/)\n[![TypeScript](https://img.shields.io/badge/TypeScript-5.x-blue)](https://www.typescriptlang.org/)\n[![Fastify](https://img.shields.io/badge/Fastify-5.x-darkblue)](https://www.fastify.io/)\n[![PostgreSQL](https://img.shields.io/badge/PostgreSQL-17-blue)](https://www.postgresql.org/)\n[![Docker](https://img.shields.io/badge/Docker-24.x-blue)](https://www.docker.com/)\n\n## 📝 Sobre o Projeto\n\nEste projeto é uma API RESTful para o gerenciamento de cursos, desenvolvida durante o **Desafio: Sua Primeira API com Node.js** da Rocketseat.\n\nA API foi construída com um foco em arquitetura robusta, seguindo as melhores práticas de mercado para garantir segurança, desempenho e manutenibilidade. O projeto inclui um ambiente completo de desenvolvimento e testes.\n\n### Funcionalidades\n\n- **Autenticação de Usuário** (`POST /sessions`): Login de usuário com validação de credenciais e geração de JWT.\n- **Gerenciamento de Cursos** (`POST`, `GET`): Rotas para criar, listar e buscar cursos por ID.\n- **Busca, Paginação e Ordenação**: Funcionalidades avançadas para filtrar, ordenar e paginar a lista de cursos.\n- **Documentação Interativa**: Documentação da API gerada automaticamente com **Swagger** e **Scalar**.\n\n---\n\n## 💻 Tecnologias\n\nAs seguintes tecnologias foram utilizadas na construção do projeto:\n\n- **Back-end:** `Node.js`, `Fastify`, `TypeScript`\n- **Banco de Dados:** `PostgreSQL` (Docker e Neon)\n- **ORM:** `Drizzle ORM` (`drizzle-kit`)\n- **Validação:** `Zod`\n- **Autenticação:** `argon2`, `jsonwebtoken`\n- **Testes:** `Vitest`, `Supertest`, `@faker-js/faker` (para dados de teste)\n\n---\n\n## ⚙️ Configuração e Execução\n\n### Pré-requisitos\n\n- `Node.js` (v22.x ou superior)\n- `Docker` e `Docker Compose`\n- `npm`\n\n### Passos\n\n1.  Clone o repositório:\n\n    - Clone o repositório e acesse a pasta do projeto.\n\n2.  Instale as dependências:\n\n    ```bash\n    npm install\n    ```\n\n3.  Configure o banco de dados localmente:\n\n    - Crie um arquivo `.env` na raiz do projeto.\n    - Defina a URL do seu banco de dados local e a chave secreta JWT.\n\n    ```env\n    DATABASE_URL=\"postgresql://postgres:postgres@localhost:5432/desafio\"\n    JWT_SECRET=\"sua_chave_secreta_aqui\"\n    ```\n\n4.  Inicie o banco de dados com Docker:\n\n    ```bash\n    docker-compose up -d\n    ```\n\n5.  Aplique as migrações do banco de dados para criar as tabelas:\n\n    ```bash\n    npm run db:migrate\n    ```\n\n6.  Inicie a aplicação em modo de desenvolvimento:\n    ```bash\n    npm run dev\n    ```\n\n---\n\n## 📄 Documentação da API\n\nApós iniciar o servidor, a documentação interativa da API estará disponível em:\n\n`http://localhost:3333/docs`\n\n---\n\n## 🧪 Testes\n\nPara rodar os testes de integração do projeto:\n\n```bash\nnpm run test\n```\n\n---\n\n## Scripts\n\n- `npm run dev`: inicia o servidor com reload e carrega variáveis de `.env`\n- `npm run db:generate`: gera artefatos do Drizzle a partir do schema\n- `npm run db:migrate`: aplica migrações no banco\n- `npm run db:studio`: abre o Drizzle Studio\n\n## Licença\nISC (ver `package.json`).","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwagnersuzano2%2Frocketseat-api-nodejs","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fwagnersuzano2%2Frocketseat-api-nodejs","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwagnersuzano2%2Frocketseat-api-nodejs/lists"}