{"id":17673306,"url":"https://github.com/saorcampos/sistema-estoque","last_synced_at":"2026-05-09T00:35:43.713Z","repository":{"id":258593691,"uuid":"852949169","full_name":"SaorCampos/Sistema-estoque","owner":"SaorCampos","description":"Um CRUD em arquitetura hexagonal, injeção de dependências e gerenciamento de perfil e permissões com token JWT.","archived":false,"fork":false,"pushed_at":"2024-11-13T12:19:37.000Z","size":304,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-02-05T17:30:58.446Z","etag":null,"topics":["data-transfer-object","dependency-injection","hexagonal-architecture","jwt-authentication","laravel","php8","postgresql"],"latest_commit_sha":null,"homepage":"","language":"PHP","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/SaorCampos.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-09-05T17:56:12.000Z","updated_at":"2024-12-13T13:52:15.000Z","dependencies_parsed_at":"2024-12-12T00:31:11.054Z","dependency_job_id":"9a5c515e-9985-4c0b-895b-112fc56b776b","html_url":"https://github.com/SaorCampos/Sistema-estoque","commit_stats":{"total_commits":29,"total_committers":1,"mean_commits":29.0,"dds":0.0,"last_synced_commit":"2ff77dc9aa70c3330446d6cffb1b7eba1d518b1c"},"previous_names":["saorcampos/sistema-estoque"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SaorCampos%2FSistema-estoque","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SaorCampos%2FSistema-estoque/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SaorCampos%2FSistema-estoque/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SaorCampos%2FSistema-estoque/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/SaorCampos","download_url":"https://codeload.github.com/SaorCampos/Sistema-estoque/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":246342824,"owners_count":20761939,"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":["data-transfer-object","dependency-injection","hexagonal-architecture","jwt-authentication","laravel","php8","postgresql"],"created_at":"2024-10-24T05:13:55.680Z","updated_at":"2026-05-09T00:35:43.676Z","avatar_url":"https://github.com/SaorCampos.png","language":"PHP","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Sistema Estoque\n\nO Sistema de Estoque é um CRUD construído em PHP 8 e Laravel, estruturado em arquitetura hexagonal. O projeto implementa injeção de dependência, autenticação JWT e gerenciamento de perfis e permissões para controle de acesso.\n\n## Tecnologias e Requisitos:\n* Linguagem: PHP 8+\n* Gerenciador de pacotes: Composer\n* Framework: Laravel\n* Banco de Dados: PostgreSQL\n* Autenticação: JWT (JSON Web Token)\n\n## Instalação\nPara instalar o projeto, siga os passos abaixo:\n\n1. Clone o repositório\n```bash\nhttps://github.com/SaorCampos/Sistema-estoque.git\ncd Sistema-estoque\n```\n2. Instale as dependências:\n```bash\ncomposer install\n```\n3. Crie o arquivo de ambiente:\n```bash\ncp .env.example .env\n```\n4. Configure as variáveis de ambiente: Defina as credenciais de banco de dados, informações JWT e outras variáveis em ``.env`` exemplo:\n```\nDB_CONNECTION=pgsql\nDB_HOST=127.0.0.1\nDB_PORT=5432\nDB_DATABASE=sistema_estoque\nDB_USERNAME=root\nDB_PASSWORD=password\n```\n5. Após configurar o .env, execute os comandos abaixo para criar as chaves do projeto e JWT:\n```bash\nphp artisan key:generate\nphp artisan jwt:secret\n```\n6. Após criar as chaves, execute o comando abaixo para criar as tabelas no banco de dados:\n```bash\nphp artisan migrate --seed\n```\nAssim estara criado um usuario com \n```\nlogin: Admin\nsenha: 123456\n```\n## Executando o servidor\nInicie o servidor com o comando:\n```bash\nphp artisan serve\n```\nA aplicação estará disponível em ``http://localhost:8000``.\n\nAssim você podera usar progamas como Insomnia ou Postman para testar a Api do projeto.\n\n## Autenticação e Controle de Acesso\nO sistema usa JWT para autenticação. Após o login, um token JWT é gerado, garantindo o acesso de acordo com o perfil e as permissões do usuário.\n## Estrutura Hexagonal\nA arquitetura hexagonal permite fácil manutenção e testes isolados, organizando as responsabilidades em domínios específicos e facilitando a injeção de dependências.\n## Testes\nExecute os testes para validar as funcionalidades:\n\n* Testes dos enpoints:\n```bash\nphp artisan test tests/Feature/\n```\n* Testes das camadas de Repository:\n```bash\nphp artisan test tests/Unit/Repositories\n```\n* Testes das camadas de Service:\n```bash\nphp artisan test tests/Unit/Services\n```\n# Funcionalidades\n1. Gestão de Movimentações de Estoque:\n* Entradas: Registrar a entrada de itens no estoque com quantidade, nota fiscal, fornecedor, e data de movimentação.\n* Saídas: Registrar a saída de itens, incluindo número de controle, destino e data.\n2. Autenticação e Controle de Acesso:\n* JWT: Controle de autenticação com token JWT.\n* Perfis e Permissões: Controle granular para diferentes níveis de acesso.\n3. Histórico e Auditoria:\n* Registra atualizações de cada entrada e saída para garantir a rastreabilidade.\n\n# Regras de Negócio\n1. Unicidade da Nota Fiscal e Número de Controle de Saída: Cada entrada de estoque deve ter uma nota fiscal única e cada saída seu número de controle.\n\n2. Validação de Quantidade: Verifica se há quantidade suficiente antes de permitir uma saída.\n\n3. Controle de Acesso: Usuários precisam ter as permissões adequadas para manipular dados de estoque.\n\n# Estrutura da Arquitetura Hexagonal\nA arquitetura do projeto é dividida em camadas, garantindo separação de responsabilidades e facilitando testes e manutenção:\n\n1. Camada de Aplicação:\n* Gerencia regras de negócio e lógica de controle.\n* Inclui ``controllers``, ``services``, e ``use cases`` que interagem com as demais camadas.\n\n2. Camada de Domínio:\n* Contém as entidades e lógica de domínio central do sistema.\n* Define as regras de negócio e contratos de interface ``Services``.\n\n3. Camada de Infraestrutura:\n* Concentra as interações com o banco de dados e recursos externos.\n* Inclui repositórios e implementações de interfaces para persistência, como o ``MovimentosRepository``.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsaorcampos%2Fsistema-estoque","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsaorcampos%2Fsistema-estoque","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsaorcampos%2Fsistema-estoque/lists"}