{"id":29353736,"url":"https://github.com/natysant/imersao-devops","last_synced_at":"2026-05-19T09:03:03.681Z","repository":{"id":303241056,"uuid":"1014830592","full_name":"natysant/imersao-devops","owner":"natysant","description":"This repository documents my learning journey during the Alura and Google Cloud DevOps Immersion, focusing on efficient pipelines, automation, application scalability, and cloud deployment for a real-world project.","archived":false,"fork":false,"pushed_at":"2025-07-06T15:00:01.000Z","size":13,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-07-28T08:55:19.709Z","etag":null,"topics":["devops","docker"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/natysant.png","metadata":{"files":{"readme":"readme.md","changelog":null,"contributing":null,"funding":null,"license":null,"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-07-06T13:55:46.000Z","updated_at":"2025-07-06T15:07:47.000Z","dependencies_parsed_at":"2025-07-06T15:21:23.851Z","dependency_job_id":"30ea65fb-7a50-44ce-be3d-e5924989ce7f","html_url":"https://github.com/natysant/imersao-devops","commit_stats":null,"previous_names":["natysant/imersao-devops"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/natysant/imersao-devops","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/natysant%2Fimersao-devops","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/natysant%2Fimersao-devops/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/natysant%2Fimersao-devops/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/natysant%2Fimersao-devops/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/natysant","download_url":"https://codeload.github.com/natysant/imersao-devops/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/natysant%2Fimersao-devops/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33209414,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-19T07:54:09.561Z","status":"ssl_error","status_checked_at":"2026-05-19T07:54:08.508Z","response_time":58,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"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":["devops","docker"],"created_at":"2025-07-09T02:09:05.468Z","updated_at":"2026-05-19T09:03:03.630Z","avatar_url":"https://github.com/natysant.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Imersão DevOps - Alura Google Cloud\n\n# API de Gestão Escolar\n\n[![Python Version](https://img.shields.io/badge/python-3.10+-blue.svg)](https://www.python.org/downloads/)\n[![Framework](https://img.shields.io/badge/framework-FastAPI-green.svg)](https://fastapi.tiangolo.com/)\n[![Database](https://img.shields.io/badge/database-SQLite-blue.svg)](https://www.sqlite.org/index.html)\n\nAPI RESTful desenvolvida com FastAPI para gerenciar alunos, cursos e matrículas em uma instituição de ensino. Este projeto foi criado como parte da Imersão DevOps da Alura.\n\n## ✨ Funcionalidades\n\n- **Gestão de Alunos:** CRUD completo para alunos (Criar, Ler, Atualizar, Deletar).\n- **Busca de Alunos:** Pesquisa de alunos por nome (parcial) ou e-mail.\n- **Gestão de Cursos:** Criação, listagem e atualização de cursos.\n- **Sistema de Matrículas:**\n  - Realizar matrícula de um aluno em um curso.\n  - Listar todos os cursos em que um aluno está matriculado.\n  - Listar todos os alunos matriculados em um determinado curso.\n- **Documentação Interativa:** Geração automática de documentação da API com Swagger UI e ReDoc.\n\n## Endpoints da API\n\nA documentação completa e interativa está disponível em `/docs` após iniciar a aplicação.\n\n### Alunos (`/alunos`)\n- `GET /alunos`: Lista todos os alunos.\n- `GET /alunos/{aluno_id}`: Busca um aluno pelo ID.\n- `GET /alunos/nome/{nome_aluno}`: Busca aluno(s) por nome.\n- `GET /alunos/email/{email_aluno}`: Busca um aluno pelo e-mail.\n- `POST /alunos`: Cria um novo aluno.\n- `PUT /alunos/{aluno_id}`: Atualiza um aluno existente.\n- `DELETE /alunos/{aluno_id}`: Deleta um aluno.\n\n### Cursos (`/cursos`)\n- `GET /cursos`: Lista todos os cursos.\n- `GET /cursos/{codigo_curso}`: Busca um curso pelo seu código.\n- `POST /cursos`: Cria um novo curso.\n- `PUT /cursos/{codigo_curso}`: Atualiza um curso existente.\n\n### Matrículas (`/matriculas`)\n- `POST /matriculas`: Cria uma nova matrícula (vincula um aluno a um curso).\n- `GET /matriculas/aluno/{nome_aluno}`: Lista os cursos de um aluno.\n- `GET /matriculas/curso/{codigo_curso}`: Lista os alunos de um curso.\n\n## 🛠️ Tecnologias Utilizadas\n\n- Python 3.10+\n- FastAPI - Framework web.\n- Pydantic - Para validação de dados.\n- SQLAlchemy - ORM para interação com o banco de dados.\n- SQLite - Banco de dados relacional.\n- Uvicorn - Servidor ASGI.\n\n## 🚀 Começando\n\n### Pré-requisitos\n\n- Python 3.10 ou superior\n- Git\n- Docker (Opcional, para containerização)\n\n## 🗃️ Banco de Dados\n\n- O projeto utiliza **SQLite** como banco de dados.\n- O arquivo do banco, `escola.db`, será criado automaticamente na raiz do projeto na primeira vez que a aplicação for executada.\n- Para reiniciar o banco de dados (apagando todos os dados), simplesmente delete o arquivo `escola.db`.\n\n## 📁 Estrutura do Projeto\n```\n.\n├── app.py              # Arquivo principal da aplicação FastAPI\n├── database.py         # Configuração do banco de dados (SQLAlchemy)\n├── models.py           # Modelos do banco de dados (tabelas)\n├── schemas.py          # Schemas de validação de dados (Pydantic)\n├── requirements.txt    # Lista de dependências Python\n├── readme.md           # Este arquivo\n└── routers/\n    ├── alunos.py       # Rotas para a entidade Aluno\n    ├── cursos.py       # Rotas para a entidade Curso\n    └── matriculas.py   # Rotas para a entidade Matrícula\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnatysant%2Fimersao-devops","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fnatysant%2Fimersao-devops","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnatysant%2Fimersao-devops/lists"}