{"id":26371871,"url":"https://github.com/danielfreitassc/e-commerce","last_synced_at":"2025-03-17T00:47:15.024Z","repository":{"id":225039469,"uuid":"764895946","full_name":"DanielFreitassc/E-Commerce","owner":"DanielFreitassc","description":null,"archived":false,"fork":false,"pushed_at":"2024-10-23T02:55:34.000Z","size":102,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2024-10-24T05:33:51.353Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"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/DanielFreitassc.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-02-28T22:47:39.000Z","updated_at":"2024-10-23T02:55:38.000Z","dependencies_parsed_at":"2024-03-14T13:53:38.994Z","dependency_job_id":"e928d0f9-c1a7-4653-b83d-9856419ff99a","html_url":"https://github.com/DanielFreitassc/E-Commerce","commit_stats":null,"previous_names":["danielfreitassc/bancodedadosquintafeira"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DanielFreitassc%2FE-Commerce","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DanielFreitassc%2FE-Commerce/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DanielFreitassc%2FE-Commerce/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DanielFreitassc%2FE-Commerce/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/DanielFreitassc","download_url":"https://codeload.github.com/DanielFreitassc/E-Commerce/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243955728,"owners_count":20374373,"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":[],"created_at":"2025-03-17T00:47:14.554Z","updated_at":"2025-03-17T00:47:15.009Z","avatar_url":"https://github.com/DanielFreitassc.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# API de Produtos para ecommerce\n\nEsta API permite a criação, leitura, atualização e exclusão de produtos. A rota principal é `/product`, com métodos para listar, adicionar, buscar por ID, atualizar e excluir produtos.\n\n### Estrutura do Payload\n\n```json\n{\n  \"name\": \"nome do produto\",\n  \"description\": \"descrição do produto\",\n  \"price\": 200,\n  \"quantity\": 10\n}\n```\n\n---\n\n## Endpoints\n\n### 1. **Criar Produto**\n\n- **Método:** `POST`\n- **Rota:** `/product`\n- **Descrição:** Cria um novo produto.\n- **Request Body:**\n  ```json\n  {\n    \"name\": \"nome do produto\",\n    \"description\": \"descrição do produto\",\n    \"price\": 200,\n    \"quantity\": 10\n  }\n  ```\n- **Response:**\n  - **Status:** `201 Created`\n  - **Body:** Retorna os detalhes do produto criado com o ID gerado.\n  ```json\n  {\n    \"id\": 1,\n    \"name\": \"nome do produto\",\n    \"description\": \"descrição do produto\",\n    \"price\": 200,\n    \"quantity\": 10\n  }\n  ```\n\n---\n\n### 2. **Listar Todos os Produtos**\n\n- **Método:** `GET`\n- **Rota:** `/product`\n- **Descrição:** Retorna uma lista de todos os produtos cadastrados.\n- **Response:**\n  - **Status:** `200 OK`\n  - **Body:** Uma lista de produtos.\n  ```json\n  [\n    {\n      \"id\": 1,\n      \"name\": \"nome do produto\",\n      \"description\": \"descrição do produto\",\n      \"price\": 200,\n      \"quantity\": 10\n    },\n    {\n      \"id\": 2,\n      \"name\": \"outro produto\",\n      \"description\": \"outra descrição\",\n      \"price\": 150,\n      \"quantity\": 5\n    }\n  ]\n  ```\n\n---\n\n### 3. **Buscar Produto por ID**\n\n- **Método:** `GET`\n- **Rota:** `/product/{id}`\n- **Descrição:** Retorna os detalhes de um produto específico, identificado pelo seu ID.\n- **Parâmetros de Rota:**\n  - `id` (obrigatório): O ID do produto a ser buscado.\n- **Response:**\n  - **Status:** `200 OK`\n  - **Body:** Detalhes do produto.\n  ```json\n  {\n    \"id\": 1,\n    \"name\": \"nome do produto\",\n    \"description\": \"descrição do produto\",\n    \"price\": 200,\n    \"quantity\": 10\n  }\n  ```\n  - **Erro:**\n    - **Status:** `404 Not Found`\n    - **Body:** Produto não encontrado.\n\n---\n\n### 4. **Atualizar Produto**\n\n- **Método:** `PUT`\n- **Rota:** `/product/{id}`\n- **Descrição:** Atualiza os detalhes de um produto específico.\n- **Parâmetros de Rota:**\n  - `id` (obrigatório): O ID do produto a ser atualizado.\n- **Request Body:**\n  ```json\n  {\n    \"name\": \"nome atualizado\",\n    \"description\": \"descrição atualizada\",\n    \"price\": 250,\n    \"quantity\": 15\n  }\n  ```\n- **Response:**\n  - **Status:** `200 OK`\n  - **Body:** Detalhes do produto atualizado.\n  ```json\n  {\n    \"id\": 1,\n    \"name\": \"nome atualizado\",\n    \"description\": \"descrição atualizada\",\n    \"price\": 250,\n    \"quantity\": 15\n  }\n  ```\n  - **Erro:**\n    - **Status:** `404 Not Found`\n    - **Body:** Produto não encontrado.\n\n---\n\n### 5. **Excluir Produto**\n\n- **Método:** `DELETE`\n- **Rota:** `/product/{id}`\n- **Descrição:** Exclui um produto específico identificado pelo seu ID.\n- **Parâmetros de Rota:**\n  - `id` (obrigatório): O ID do produto a ser excluído.\n- **Response:**\n  - **Status:** `200 OK`\n  - **Body:** Detalhes do produto atualizado.\n  ```json\n  {\n    \"id\": 1,\n    \"name\": \"nome\",\n    \"description\": \"descrição\",\n    \"price\": 250,\n    \"quantity\": 15\n  }\n  ```\n  - **Erro:**\n    - **Status:** `404 Not Found`\n    - **Body:** Produto não encontrado.\n\n---\n\n### Códigos de Status Comuns\n\n- **200 OK:** Requisição bem-sucedida.\n- **201 Created:** Produto criado com sucesso.\n- **204 No Content:** Produto excluído com sucesso.\n- **400 Bad Request:** Erro de validação ou dados inválidos.\n- **404 Not Found:** Produto não encontrado.\n\n---\n\n\nEssa documentação cobre todos os métodos CRUD para a API de produtos.\n\n\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdanielfreitassc%2Fe-commerce","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdanielfreitassc%2Fe-commerce","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdanielfreitassc%2Fe-commerce/lists"}