{"id":30883124,"url":"https://github.com/jimcostdev/jimcostdev-fastapi-template","last_synced_at":"2026-05-08T14:14:05.500Z","repository":{"id":286597067,"uuid":"859372470","full_name":"JimcostDev/jimcostdev-fastapi-template","owner":"JimcostDev","description":"Plantilla inicial para proyectos web con FastAPI, MongoDB y PostgreSQL, pensada para acelerar el desarrollo y servir de referencia.","archived":false,"fork":false,"pushed_at":"2025-08-29T10:03:34.000Z","size":49,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-09-08T09:07:41.815Z","etag":null,"topics":["fastapi","mongodb","python"],"latest_commit_sha":null,"homepage":"https://jimcostdev.com","language":"Python","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/JimcostDev.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":"2024-09-18T14:51:35.000Z","updated_at":"2025-08-29T10:03:37.000Z","dependencies_parsed_at":null,"dependency_job_id":"f339ee6a-0429-41fe-b9bb-78d13a464ede","html_url":"https://github.com/JimcostDev/jimcostdev-fastapi-template","commit_stats":null,"previous_names":["jimcostdev/fastapi-mongo-template","jimcostdev/jimcostdev-fastapi-template"],"tags_count":0,"template":true,"template_full_name":null,"purl":"pkg:github/JimcostDev/jimcostdev-fastapi-template","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JimcostDev%2Fjimcostdev-fastapi-template","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JimcostDev%2Fjimcostdev-fastapi-template/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JimcostDev%2Fjimcostdev-fastapi-template/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JimcostDev%2Fjimcostdev-fastapi-template/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/JimcostDev","download_url":"https://codeload.github.com/JimcostDev/jimcostdev-fastapi-template/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JimcostDev%2Fjimcostdev-fastapi-template/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32783663,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-08T08:22:46.396Z","status":"ssl_error","status_checked_at":"2026-05-08T08:22:45.650Z","response_time":54,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: 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":["fastapi","mongodb","python"],"created_at":"2025-09-08T09:05:30.525Z","updated_at":"2026-05-08T14:14:05.492Z","avatar_url":"https://github.com/JimcostDev.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# FastAPI + MongoDB + PostgreSQL Template\n\nPlantilla inicial para proyectos web con FastAPI, MongoDB y PostgreSQL, pensada para acelerar el desarrollo y servir de referencia.\n\n\u003e [!NOTE]\n\u003e Esta plantilla refleja mis preferencias (JimcostDev). No garantiza que cubra todas las mejores prácticas, pero puede ser un excelente punto de partida.\n\n\u003e [!TIP]\n\u003e Además, como es un template de GitHub, también puedes utilizarlo haciendo clic en el botón correspondiente para crear un nuevo repositorio basado en esta plantilla.\n\n## 📋 Características\n- Estructura de carpetas organizada\n- Conexión asíncrona a **MongoDB** con `motor`\n- Conexión asíncrona a **PostgreSQL** con `SQLAlchemy` + `asyncpg`\n- Configuración mediante variables de entorno con `pydantic-settings`\n- Hashing de contraseñas con `bcrypt` (o `aiobcrypt`)\n- Autenticación basada en JWT con `python-jose`\n- Suite de tests con `pytest` y `pytest-asyncio`\n\n---\n\n## 🏗️ Estructura del Proyecto\n\nEl proyecto sigue una **arquitectura en capas** para promover la separación de responsabilidades y facilitar la mantenibilidad y escalabilidad.\n\n- **`api/`**: Contiene los **controladores** (`routers`). Cada archivo en esta carpeta define los endpoints de la API para una entidad o un conjunto de funcionalidades, manejando las solicitudes HTTP y devolviendo las respuestas.\n- **`services/`**: Aquí reside la **lógica de negocio**. Los servicios orquestan las operaciones, validan los datos y utilizan los repositorios para interactuar con la capa de persistencia.\n- **`repositories/`**: Implementa el **patrón Repositorio**. Esta capa es la encargada de la lógica de acceso a datos, abstrayendo la interacción con la base de datos (ya sea MongoDB o PostgreSQL) del resto de la aplicación.\n- **`models/`**: Define los **modelos de datos** para las entidades de la aplicación. Aquí se establecen las estructuras de datos y se utilizan para la validación y el mapeo de objetos.\n- **`core/`**: Incluye la **configuración** principal, como las variables de entorno, la inicialización de la base de datos y otras configuraciones globales del proyecto.\n- **`tests/`**: Contiene la suite de pruebas unitarias y de integración con `pytest`, asegurando el correcto funcionamiento de la API.\n- **`utils/`**: Almacena **funciones de utilidad** y clases auxiliares que pueden ser reutilizadas en diferentes partes del proyecto.\n\n---\n\n## 🚀 Instrucciones de Uso\n\n1. **Clona este repositorio** ejecutando el siguiente comando:\n\n    ```bash\n    git clone https://github.com/JimcostDev/jimcostdev-fastapi-template.git\n    ```\n\n2. **Crea y activa tu entorno virtual**:\n\n    - Crea un entorno virtual:\n\n        ```bash\n        python -m venv venv\n        ```\n\n    - Activa el entorno virtual:\n\n        - En **Windows**:\n\n            ```bash\n            venv\\Scripts\\activate\n            ```\n\n        - En **macOS y Linux**:\n\n            ```bash\n            source venv/bin/activate\n            ```\n\n3. **Instala las dependencias requeridas**:\n    - Instalar todas con `requirements.txt`:\n        ```bash\n        pip install -r requirements.txt\n        ```\n    - Instalar dependencias individuales (opcional):\n        ```bash\n        pip install \"fastapi[standard]\" motor pymongo asyncpg sqlalchemy pytest pytest-asyncio pydantic-settings aiobcrypt python-jose\n        ```\n\n---\n\n## 🛠️ Configuración de Base de Datos\n\n\u003e [!IMPORTANT]  \n\u003e Debes configurar correctamente las variables de entorno en tu archivo `core/config.env` o exportarlas en tu sistema.\n\n### ⚙️ Configuración MongoDB\n\n```sh\nMONGODB_URI_DEV_LAB_TEST=mongodb+srv://user:password@server/\nMONGODB_NAME=db_name\n```\n\n### ⚙️ Configuración PostgreSQL\n\n```sh\nPOSTGRES_URI=postgresql+asyncpg://user:password@localhost:5432/db_name\n```\n\n### ⚙️ Otros\n\n```sh\nDB_ENGINE=postgresql/mongodb # elegir motor\nJWT_SECRET_KEY=secreto-muy-secreto\n```\n\n---\n\n4. **Ejecuta el servidor**:\n\n    Inicia el servidor en modo de desarrollo o producción:\n\n    - Modo **desarrollo**:\n        ```bash\n        fastapi dev main.py\n        ```\n\n    - Modo **producción**:\n        ```bash\n        fastapi run\n        ```\n\n5. **Actualizar versión de FastAPI** (opcional):\n    ```bash\n    pip install --upgrade fastapi\n    ```\n\n6. **Documentación oficial**: [FastAPI](https://fastapi.tiangolo.com/#requirements)\n\n---\n\n\u003e [!TIP]  \n\u003e ¡Si te resulta útil este proyecto, apóyalo con una ⭐! Tu apoyo nos motiva a crear más contenido y mejorar los recursos disponibles. ¡Gracias! :octocat:\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjimcostdev%2Fjimcostdev-fastapi-template","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjimcostdev%2Fjimcostdev-fastapi-template","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjimcostdev%2Fjimcostdev-fastapi-template/lists"}