{"id":18547354,"url":"https://github.com/jeanpgr/authentication_api-jwt","last_synced_at":"2025-04-09T20:31:13.888Z","repository":{"id":228916173,"uuid":"775259978","full_name":"jeanpgr/Authentication_API-JWT","owner":"jeanpgr","description":"Módulo REST de login con autenticación y autorización de usuarios JWT (JSON WEB TOKEN) desarrollado con el microframework FlightPHP.","archived":false,"fork":false,"pushed_at":"2024-06-30T16:26:09.000Z","size":97,"stargazers_count":4,"open_issues_count":1,"forks_count":2,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-03-24T11:21:30.640Z","etag":null,"topics":["composer","flightphp","jwt-authentication","mvc-architecture","php"],"latest_commit_sha":null,"homepage":"","language":"PHP","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/jeanpgr.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}},"created_at":"2024-03-21T03:37:54.000Z","updated_at":"2024-06-11T02:54:52.000Z","dependencies_parsed_at":"2024-06-08T05:33:38.093Z","dependency_job_id":"df2f2644-537a-4beb-b77a-935049a77f31","html_url":"https://github.com/jeanpgr/Authentication_API-JWT","commit_stats":null,"previous_names":["jean20jp/authentication_api-jwt","jeangr-dev/authentication_api-jwt","jeanpgr/authentication_api-jwt"],"tags_count":1,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jeanpgr%2FAuthentication_API-JWT","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jeanpgr%2FAuthentication_API-JWT/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jeanpgr%2FAuthentication_API-JWT/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jeanpgr%2FAuthentication_API-JWT/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/jeanpgr","download_url":"https://codeload.github.com/jeanpgr/Authentication_API-JWT/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":248107286,"owners_count":21048893,"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","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":["composer","flightphp","jwt-authentication","mvc-architecture","php"],"created_at":"2024-11-06T20:29:05.407Z","updated_at":"2025-04-09T20:31:13.396Z","avatar_url":"https://github.com/jeanpgr.png","language":"PHP","readme":"# API con FlightPHP y JWT\nEsta es una API construida con el microframework FlightPHP y utiliza JWT (JSON Web Tokens) para la autenticación y autorización de usuarios. \nEn esta API se puede implementar más endpoints para acceder a diferentes recursos y realizar operaciones CRUD (Crear, Leer, Actualizar, Eliminar) en la base de datos.\n\n## Requisitos\n* PHP 7.4 o superior\n* Composer (Gestor de paquetes)\n* Base de datos MySQL u otro compatible\n### Instalar \n```\ncomposer require firebase/php-jwt\ncomposer require mikecao/flight\n```\n\n## Endpoints\n  ### Autenticación\n  * `POST /login`: Permite a un usuario autenticarse, se debe enviar un JSON con las credenciales de usuario (correo y contraseña) y devuelve un JSON con el token JWT y status `OK` si la autenticación es exitosa.\n  ### Usuarios\n  * `POST /registerUser`: Crea un nuevo usuario, se deben proporcionar los datos del usuario en un JSON en el cuerpo de la solicitud.\n  * `GET /getUsers`: Obtiene todos los usuarios registrados en la base de datos (Para acceder a este recurso es necesario enviar el token en la cabecera de la solicitud para validar el token)\n\n## Autenticación con JWT\nPara acceder a los endpoints protegidos, debes incluir el token JWT en la cabecera `Authorization` de la solicitud. El token se obtiene después de iniciar sesión exitosamente en el endpoint `/login`.\n### Ejemplo\n```\nAuthorization: Bearer \u003ctoken\u003e\n```\n\u003e [!NOTE]\n\u003e Para proteger los endpoints que se vaya a implementar llamar a la función `validarToken` en un condicional.\n\n## Ejemplo de solicitud y respuesta\n### Solicitud\n```\nPOST /login\nContent-Type: application/json\n\n{\n    \"email\": \"test@test.com\",\n    \"contraseña\": \"test\"\n}\n```\n### Respuesta Exitosa\n```\nHTTP/1.1 200 OK\nContent-Type: application/json\n\n{\n    \"message\": \"Inicio de sesión exitoso\",\n    \"token\": \"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxMjM0NTY3ODkwLCJpYXQiOjE2MzI4MzM2NjAsImV4cCI6MTYzMjgzMzc2MH0\",\n    \"status\": \"OK\"\n}\n```\n### Contribuciones\nSi deseas contribuir a este proyecto, ¡siéntete libre de hacer un fork y enviar tus pull requests!\n\n### Licencia\nEste proyecto está bajo la Licencia MIT. Consulta el archivo [LICENSE](https://github.com/jeangr-dev/Authentication_API-JWT/blob/main/LICENSE) para más detalles.\n\n\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjeanpgr%2Fauthentication_api-jwt","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjeanpgr%2Fauthentication_api-jwt","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjeanpgr%2Fauthentication_api-jwt/lists"}