alncris2/laravel-procedure

Procedure versioning and execution support for Laravel projects.

Maintainers

Package info

github.com/Alncris2/laravel-procedure

pkg:composer/alncris2/laravel-procedure

Statistics

Installs: 3

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v0.2.0 2026-04-15 22:57 UTC

This package is auto-updated.

Last update: 2026-05-15 23:08:58 UTC


README

Versionamento e aplicação de stored procedures para projetos Laravel, com snapshots automáticos em disco e histórico em banco.

  • Laravel 5.8+ / PHP 7.1.3+
  • Usa sempre a connection default do Laravel (config('database.default'))
  • Estrutura por grupo: database/procedures/{grupo}/{PROCEDURE}/current.sql + versions/NNN_label.sql
  • current.sql é a fonte viva editada pelo dev; os snapshots em versions/ são gerados automaticamente

Instalação

composer require alncris2/laravel-procedure

Publicar config e migration (tudo de uma vez):

php artisan vendor:publish --tag=procedure
php artisan migrate

Ou separadamente, se preferir:

php artisan vendor:publish --tag=procedure-config
php artisan vendor:publish --tag=procedure-migrations

Uso

Criar uma procedure

php artisan procedure:make atendimento PRC_BUSCAR_ATENDIMENTOS

Gera:

database/procedures/atendimento/PRC_BUSCAR_ATENDIMENTOS/
  current.sql
  versions/

O current.sql vem com um template compatível com o driver detectado (oracle, mysql, pgsql, sqlsrv).

Editar

Abra e edite current.sql. Nunca edite os arquivos em versions/ — eles são snapshots congelados.

Ver status

php artisan procedure:status
php artisan procedure:status --group=atendimento
php artisan procedure:status --changed

Estados possíveis: SYNCED, CHANGED, PENDING, FAILED, UNTRACKED.

Aplicar

php artisan procedure:apply
php artisan procedure:apply --only=PRC_BUSCAR_ATENDIMENTOS --message="corrige filtro de status"
php artisan procedure:apply --group=atendimento

O apply:

  1. Detecta o que mudou comparando o checksum do current.sql com a versão marcada como is_current no banco.
  2. Cria automaticamente um snapshot em versions/NNN_slug.sql (se snapshot_on_apply estiver habilitado).
  3. Executa o SQL com DB::connection()->unprepared(...).
  4. Registra o histórico em procedure_versions.

Dump (importar procedures do banco)

Para trazer procedures já existentes no banco para dentro do projeto:

# Sem --group: infere grupos automaticamente em modo dry-run
php artisan procedure:dump

# Efetiva a proposta do auto-group
php artisan procedure:dump --apply

# Grupo explícito (comportamento clássico)
php artisan procedure:dump --group=atendimento
php artisan procedure:dump --group=atendimento --only=PRC_BUSCAR_ATENDIMENTOS
php artisan procedure:dump --group=atendimento --owner=MYSCHEMA          # Oracle
php artisan procedure:dump --group=imported --no-register                # não grava linha em procedure_versions

# Forçar uma estratégia específica de auto-group
php artisan procedure:dump --apply --strategy=prefix   # cascade|prefix|tables|schema

Auto-group (quando --group é omitido)

O grupo de destino de cada procedure é inferido por uma cascata determinística (sem APIs externas, sem dependências de ML):

  1. Prefixo do nomeSP_INV_*, PRC_FIN_*, UpdateCustomer → agrupa pelo token de domínio, pulando prefixos de tipo (sp_, prc_, etc.).
  2. Tabelas referenciadas — parse leve de FROM/JOIN/UPDATE/INSERT INTO/DELETE FROM/MERGE INTO; procedures que compartilham tabelas caem no mesmo grupo, nomeado pela tabela mais frequente.
  3. Owner/schema do banco como fallback.
  4. ungrouped como último recurso.

Sem --apply, o comando apenas imprime a proposta (tabela procedure | grupo proposto | estratégia | tabelas-chave) sem gravar nada. Com --apply, efetiva.

Configurável em config/procedure.php no bloco auto_group (veja abaixo).

Comportamento por procedure

  • Procedure nova no projeto (primeira importação) → grava current.sql e uma baseline silenciosa em procedure_versions com label dump_import. Nenhum arquivo é criado em versions/status já fica SYNCED.
  • Existe e banco == disco → resultado synced, nenhuma escrita.
  • Existe e diverge → sobrescreve current.sql e cria snapshot físico versions/NNN_dump_sync.sql como uma versão real do histórico.

Dessa forma versions/ só registra mudanças reais vindas do banco; a primeira importação não polui o diretório. Rollback sobre uma baseline sem snapshot físico retorna mensagem explicativa.

Suporta Oracle (USER_SOURCE / ALL_SOURCE) e MySQL (SHOW CREATE PROCEDURE).

Rollback

php artisan procedure:rollback --only=PRC_BUSCAR_ATENDIMENTOS
php artisan procedure:rollback --only=PRC_BUSCAR_ATENDIMENTOS --to-version=1
php artisan procedure:rollback --group=atendimento

Reaplica o snapshot alvo completo (full-state) e marca o is_current no registro correspondente.

Configuração

config/procedure.php:

return [
    'base_path' => database_path('procedures'),
    'history_table' => 'procedure_versions',
    'snapshot_on_apply' => true,
    'default_snapshot_message' => 'auto_snapshot',
    'version_padding' => 3,
    'sql' => [
        'strip_trailing_oracle_slash' => true,
        'remove_mysql_delimiter' => true,
    ],
    'auto_group' => [
        'min_cluster_size' => 2,
        'prefix_separator' => '_',
        'noise_prefixes' => ['sp', 'usp', 'prc', 'proc', 'fn', 'fnc', 'p'],
        'noise_tables' => ['dual'],
        'fallback' => 'ungrouped',
    ],
];

Tabela de histórico

procedure_versions:

Coluna Descrição
group_name, procedure_name Localização lógica
version_number, version_label, file_name, file_path Rastreabilidade do snapshot
checksum sha256 do conteúdo aplicado
execution_status success ou failed
execution_time_ms, error_message Métricas/erro da execução
applied_at, rolled_back_at Auditoria
is_current Flag da versão atualmente ativa

Filosofia

  • Full-state, não patch: cada snapshot contém o SQL completo da procedure.
  • Idempotência no DDL: escreva CREATE OR REPLACE / DROP ... IF EXISTS conforme o driver.
  • Uma fonte viva: current.sql é o único arquivo editável; o resto é histórico.

Licença

MIT