{"id":25403095,"url":"https://github.com/lauratrigo/person_api","last_synced_at":"2026-05-20T05:03:41.576Z","repository":{"id":276670276,"uuid":"929926272","full_name":"lauratrigo/Person_API","owner":"lauratrigo","description":"Person API é uma API desenvolvida com .NET 9 e Entity Framework Core para gerenciamento de pessoas. Permite realizar operações de CRUD com armazenamento em SQLite. Projeto criado para estudo e prática de desenvolvimento de APIs RESTful. 💾","archived":false,"fork":false,"pushed_at":"2025-02-09T20:06:39.000Z","size":20,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-04-12T14:46:48.748Z","etag":null,"topics":["api","api-rest","crud","csharp","entity-framework-core","net9","sqlite","sqlite3"],"latest_commit_sha":null,"homepage":"","language":"C#","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/lauratrigo.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}},"created_at":"2025-02-09T18:06:20.000Z","updated_at":"2025-02-09T20:06:43.000Z","dependencies_parsed_at":"2025-04-12T14:09:43.692Z","dependency_job_id":null,"html_url":"https://github.com/lauratrigo/Person_API","commit_stats":null,"previous_names":["lauratrigo/person_api"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/lauratrigo/Person_API","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lauratrigo%2FPerson_API","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lauratrigo%2FPerson_API/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lauratrigo%2FPerson_API/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lauratrigo%2FPerson_API/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/lauratrigo","download_url":"https://codeload.github.com/lauratrigo/Person_API/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lauratrigo%2FPerson_API/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":275925790,"owners_count":25553967,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-19T02:00:09.700Z","response_time":108,"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":["api","api-rest","crud","csharp","entity-framework-core","net9","sqlite","sqlite3"],"created_at":"2025-02-16T02:27:53.682Z","updated_at":"2025-09-19T10:55:40.901Z","avatar_url":"https://github.com/lauratrigo.png","language":"C#","funding_links":[],"categories":[],"sub_categories":[],"readme":"# 💻 Person API \n\nEsta é uma API simples desenvolvida com **.NET 9** (entretanto, tem como adapta-la de acordo com a sua versão) e **Entity Framework Core**. A API permite realizar operações **CRUD** (Criar, Ler, Atualizar e Deletar) em um banco de dados **SQLite** que armazena informações sobre pessoas.\n\n# 🛠 Tecnologias Usadas\n\n- **.NET 9**\n- **Entity Framework Core**\n  - Entity Framework Core Sqlite\n  - Entity Framework Core Design\n- **SQLite**\n- **Swagger**\n\n![.NET 9 Badge](https://img.shields.io/badge/.NET-9.0-blue?logo=.net\u0026logoColor=white)\n![Entity Framework Core Badge](https://img.shields.io/badge/Entity_Framework_Core-9.0-blue?logo=entity-framework\u0026logoColor=white)\n![Entity Framework Core Sqlite Badge](https://img.shields.io/badge/Entity_Framework_Core_Sqlite-9.0-blue?logo=sqlite\u0026logoColor=white)\n![Entity Framework Core Design Badge](https://img.shields.io/badge/Entity_Framework_Core_Design-9.0-blue?logo=visualstudio\u0026logoColor=white)\n![SQLite Badge](https://img.shields.io/badge/SQLite-3.49-green?logo=sqlite\u0026logoColor=white)\n![Swagger Badge](https://img.shields.io/badge/Swagger-API-orange?logo=swagger\u0026logoColor=white)\n\n## 💡 Objetivo \n\nO objetivo deste projeto é implementar uma **API RESTful** simples que permite realizar operações **CRUD** (Criar, Ler, Atualizar e Deletar) de **pessoas** em um banco de dados **SQLite**. A API tem como foco a gestão de dados de pessoas, com a capacidade de adicionar, listar, atualizar e excluir registros. Além disso, ela utiliza o **Entity Framework Core** para comunicação com o banco de dados e **Swagger** para facilitar os testes e documentação das rotas.\n\n## 🚀 Funcionalidades \n\n- **POST /person**: Adiciona uma nova pessoa ao banco de dados.\n- **GET /person**: Retorna todas as pessoas armazenadas no banco de dados.\n- **PUT /person/{id}**: Atualiza as informações de uma pessoa com base no `id`.\n- **DELETE /person/{id}**: Exclui uma pessoa com base no `id`.\n\n## 📋 Pré-Requisitos \n\nAntes de rodar a aplicação, certifique-se de ter os seguintes itens instalados:\n\n- [Visual Studio Code](https://code.visualstudio.com/)\n- [.NET SDK](https://dotnet.microsoft.com/download)\n- [SQLite](https://www.sqlite.org/download.html)\n\n## 📦 Como Rodar o Projeto\n\n### Passo 1: Clone o repositório\n\n```bash\ngit clone https://github.com/lauratrigo/Person_API.git\ncd Person_API\n```\n\n### Passo 2: Clone o repositório\n\nCertifique-se de ter o .NET SDK instalado. Depois, no diretório do projeto, execute:\n\n```bash\ndotnet restore\n```\n\n### Passo 3: Migre o banco de dados\n\nAntes de rodar a API pela primeira vez, será necessário aplicar as migrações ao banco de dados:\n\n```bash\ndotnet ef database update\n```\n\n### Passo 4: Execute o projeto\n\n```bash\ndotnet run\n```\nA API estará disponível em http://localhost:5199\n\n### Passo 5: Teste as rotas\n\nAcesse http://localhost:5199/swagger para explorar e testar as rotas da API através do Swagger.\n\n## 📂 Estrutura do Projeto\n\n```\nperson/\n├── bin/                                     # Arquivos compilados do projeto\n├── obj/                                     # Arquivos temporários de build\n├── Data/                                    # Contém o contexto do banco de dados\n│   └── PersonContext.cs                     # Contexto do banco de dados (SQLite)\n├── Migrations/                              # Armazena as migrações do banco de dados\n│   ├── 20250209152812_Initial.cs            # Arquivo de migração gerado\n│   ├── 20250209152812_Initial.Designer.cs   # Arquivo de migração gerado\n│   └── PersonContextModelSnapshot.cs        # Snapshot do contexto do banco de dados\n├── Models/                                  # Modelos de dados utilizados na aplicação\n│   ├── PersonModel.cs                       # Modelo de dados para a pessoa\n│   └── PersonRequest.cs                     # Request para criação de uma pessoa\n├── Properties/                              # Configurações de propriedades do projeto\n│   └── launchSettings.json                  # Configurações de inicialização do projeto\n├── routes/                                  # Contém as rotas da API\n│   └── PersonRoute.cs                       # Arquivo com as rotas de pessoa\n├── appsettings.Development.json             # Configurações para o ambiente de desenvolvimento\n├── appsettings.json                         # Configurações gerais da aplicação\n├── Person.csproj                            # Arquivo do projeto .NET\n├── Person.http                              # Arquivo para testar rotas (se necessário)\n├── Person.sln                               # Arquivo da solução do projeto\n├── person.sqlite                            # Banco de dados SQLite\n├── Program.cs                               # Configuração inicial da API\n└── tempCodeRunnerFile.cs                    # Arquivo temporário criado pelo VSCode\n```\n\n\n## 🤝 Agradecimentos\n\nEste projeto foi criado com base em um vídeo do YouTube, onde pude aprender as práticas de criação de uma API com **.NET**. O objetivo principal foi praticar o uso de **C#** e **SQLite** em uma API RESTful.\n\nCaso deseje contribuir, fique à vontade! Para sugestões e melhorias, você pode fazer um fork do repositório, criar uma branch com suas mudanças e enviar um pull request.\n\n## 📜 Licença\n\nEste projeto está licenciado sob a Licença MIT - veja o arquivo LICENSE para mais detalhes.\n\n## 🎥 Créditos\n\nEste projeto foi desenvolvido por Laura Trigo com base no vídeo [API CRUD completa com C# e .NET 8 do Zero](https://www.youtube.com/watch?v=UXMKOgmQ7zI\u0026list=PLdP0_O7ZLFU1ze1Lkg1aE8AilZ-_B2JOG\u0026index=2).\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flauratrigo%2Fperson_api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flauratrigo%2Fperson_api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flauratrigo%2Fperson_api/lists"}