{"id":20122631,"url":"https://github.com/mspilari/springsecurityapi","last_synced_at":"2026-05-08T14:10:46.017Z","repository":{"id":248019787,"uuid":"827525059","full_name":"MSpilari/springSecurityApi","owner":"MSpilari","description":"Api using Spring boot, spring security, jwt and mysql","archived":false,"fork":false,"pushed_at":"2024-07-11T20:35:57.000Z","size":19,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-09-07T06:39:01.605Z","etag":null,"topics":["api-rest","jpa","jwt","mysql","oauth2","spring-boot","spring-security"],"latest_commit_sha":null,"homepage":"","language":"Java","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/MSpilari.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}},"created_at":"2024-07-11T20:27:00.000Z","updated_at":"2024-07-11T20:36:00.000Z","dependencies_parsed_at":"2024-07-11T23:30:49.179Z","dependency_job_id":"129df141-e256-4f8c-95f6-01ebc4880e0a","html_url":"https://github.com/MSpilari/springSecurityApi","commit_stats":null,"previous_names":["mspilari/springsecurityapi"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/MSpilari/springSecurityApi","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MSpilari%2FspringSecurityApi","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MSpilari%2FspringSecurityApi/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MSpilari%2FspringSecurityApi/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MSpilari%2FspringSecurityApi/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/MSpilari","download_url":"https://codeload.github.com/MSpilari/springSecurityApi/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MSpilari%2FspringSecurityApi/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":274005338,"owners_count":25205934,"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-07T02:00:09.463Z","response_time":67,"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-rest","jpa","jwt","mysql","oauth2","spring-boot","spring-security"],"created_at":"2024-11-13T19:39:27.588Z","updated_at":"2026-05-08T14:10:40.994Z","avatar_url":"https://github.com/MSpilari.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Spring Boot Application with Spring Security, JWT, OAuth2, Lombok, MySQL, JPA\n\n## Descrição\n\nEsta aplicação é uma API desenvolvida em Spring Boot que utiliza Spring Security, JWT, OAuth2, Lombok, MySQL e JPA. A aplicação possui três tabelas principais: `roles`, `users` e `tweets`. A autenticação é baseada em roles, com permissões de `admin` e `basic`.\n\n## Tecnologias Utilizadas\n\n- **Spring Boot**: Framework para criação de aplicações Java.\n- **Spring Security**: Framework para autenticação e autorização.\n- **JWT (JSON Web Tokens)**: Para autenticação segura com tokens.\n- **OAuth2**: Protocolo para autorização.\n- **Lombok**: Biblioteca para reduzir o código boilerplate.\n- **MySQL**: Sistema de gerenciamento de banco de dados relacional.\n- **JPA (Java Persistence API)**: Para mapeamento objeto-relacional.\n\n## Estrutura do Banco de Dados\n\nA aplicação possui três tabelas principais:\n\n1. **roles**:\n    - `id` (Long): Identificador único da role.\n    - `name` (String): Nome da role (e.g., `admin`, `basic`).\n\n2. **users**:\n    - `id` (UUID): Identificador único do usuário.\n    - `username` (String): Nome de usuário.\n    - `password` (String): Senha do usuário.\n    - `roles` (Set\u003cRole\u003e): Roles associadas ao usuário.\n\n3. **tweets**:\n    - `id` (Long): Identificador único do tweet.\n    - `content` (String): Conteúdo do tweet.\n    - `user` (User): Usuário que criou o tweet.\n\n## Funcionalidades\n\n- **Autenticação e Autorização**:\n    - Autenticação via JWT e OAuth2.\n    - Autorização baseada em roles (`admin` e `basic`).\n\n- **Operações CRUD**:\n    - Criação, leitura, atualização e exclusão de tweets.\n    - Gerenciamento de usuários e roles.\n\n## Configuração\n\n### Pré-requisitos\n\n- Java 17 ou superior\n- Maven 3.6 ou superior\n- MySQL 8.0 ou superior\n\n### Variáveis de Ambiente\n\nConfigure as seguintes variáveis de ambiente para a aplicação:\n\n```plaintext\nDATABASE_URL=jdbc:mysql://localhost:3306/mydb\nDATABASE_USERNAME=admin\nDATABASE_PASSWORD=123\nJWT_PUBLIC_KEY=classpath:app.pub\nJWT_PRIVATE_KEY=classpath:app.key\n```\n\n### Gerando as chaves privadas e públicas\n\n**Não compartilhe essas chaves com ninguém, nem coloque-as no github**\n\n1. Vá até o diretório resources e digite o comando para gerar a chave privada.\n```bash\ncd src/main/resources\nopenssl genrsa \n```\n\n2. Crie a chave pública vinculada a chave privada.\n```bash\nopenssl rsa -in nome_da_chave_privada.key -pubout -out nome_da_chave_pública.key \n```\n\n### Instalação\n\n1. Clone o repositório:\n\n```bash\ngit clone https://github.com/MSpilari/springSecurityApi.git\ncd sua-aplicacao\n```\n\n2. Configure o banco de dados MySQL conforme necessário e ajuste as variáveis de ambiente no arquivo `application.properties` ou configure-as no ambiente do sistema.\n\n3. Execute o Maven para construir a aplicação:\n\n```bash\nmvn clean install\n```\n\n4. Execute a aplicação:\n\n```bash\nmvn spring-boot:run\n```\n\n## Uso\n\n### Endpoints\n\nA aplicação expõe os seguintes endpoints principais:\n\n- **Autenticação**:\n    - `POST /login`: Autenticação do usuário.\n    - `POST /users`: Registro de novo usuário.\n    - `GET /users`: Mostra a lista de usuários apenas para o admin.\n\n- **Tweets**:\n    - `GET /feed`: Obter todos os tweets.\n    - `POST /tweets`: Criar um novo tweet.\n    - `DELETE /tweets/{id}`: Deletar um tweet por ID.\n\n### Exemplo de Requisição\n\n**Autenticação:**\n\n```bash\ncurl -X POST http://localhost:8080/login \\\n    -H \"Content-Type: application/json\" \\\n    -d '{\"username\":\"admin\", \"password\":\"password\"}'\n```\n\n**Criar um Tweet:**\n\n```bash\ncurl -X POST http://localhost:8080/tweets \\\n    -H \"Content-Type: application/json\" \\\n    -H \"Authorization: Bearer \u003cseu-token-jwt\u003e\" \\\n    -d '{\"content\":\"Hello, world!\"}'\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmspilari%2Fspringsecurityapi","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmspilari%2Fspringsecurityapi","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmspilari%2Fspringsecurityapi/lists"}