Download the PHP package the-provost/laravel-summdb without Composer
On this page you can find all versions of the php package the-provost/laravel-summdb. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download the-provost/laravel-summdb
More information about the-provost/laravel-summdb
Files in the-provost/laravel-summdb
Package laravel-summdb
Short Description A tool to summarize Laravel database structure from migration files
License MIT
Informations about the package laravel-summdb
Laravel SummDB - DB Summarizer
This tool analyzes Laravel migration files and generates a summary of the database structure, including an Entity-Relationship Diagram (ERD) using Mermaid.js syntax.
NPM
COMPOSER
Package Name
The name of the package on the github repo is a portmanteau of 'Summed Up' to denote a summing up of the DB of the app.
The npm package name however is a clear and understandable 'laravel-db-summary'.
Installation
NPM:
You can install Laravel DB Summarizer globally using npm:
Or use it directly with npx:
COMPOSER:
You can install the package via Composer:
Usage
NPM:
There are two ways to use Laravel DB Summarizer:
-
Interactive Mode: Run the tool without any arguments, and it will prompt you for the Laravel project path:
- Command Line Mode: Provide the path to your Laravel project as an argument:
COMPOSER
After installation, you can use the Laravel SummDB command:
This command will analyze your Laravel migration files and generate a summary.
Output
The script generates three files in a 'db-summary' directory:
text-summary.txt
: A text summary of each table, its columns, and foreign key relationships.erd.mmd
: Mermaid.js ERD code that can be visualized using tools like the Mermaid Live Editor.erd.png
: A PNG image of the Entity-Relationship Diagram (requires Mermaid CLI to be installed).
If you don't have Mermaid CLI installed, you can still use the erd.mmd
file to generate the diagram online.
Requirements
- Node.js (version 12.0.0 or higher)
- A Laravel project with migration files
Documentation
For detailed documentation, please refer to:
- npm Package README
- Composer Package README
Development
To contribute or modify the tool:
- Clone the repository:
Navigate to the desired package directory (js/ or php/) and follow the development instructions in the respective README.
Configuration
COMPOSER:
You can publish the configuration file with:
This will publish a laravel-summdb.php
file in your config directory.
Integrating with CI/CD Pipeline
NPM:
To include Laravel DB Summarizer as part of your CI/CD pipeline, follow these steps:
-
Install Laravel DB Summarizer in your CI environment: Add this to your CI configuration file (e.g.,
.gitlab-ci.yml
,.github/workflows/main.yml
): -
Run Laravel DB Summarizer: Add a step in your CI pipeline to run the tool:
-
Archive the generated files: Configure your CI to archive the
db-summary
directory as an artifact. For example, in GitLab CI: -
Optional: Generate PNG in CI: If you want to generate the PNG in your CI pipeline, ensure Mermaid CLI is installed:
-
Example GitLab CI configuration:
- Example GitHub Actions workflow:
COMPOSER:
To include Laravel SummDB as part of your Laravel CI/CD pipeline, you can add the command to your build process. For example, in GitLab CI:
By following these steps, you'll ensure that every build of your Laravel application includes an up-to-date database summary and ERD.
Note
This script parses migration files statically and may not capture all complex scenarios or dynamic schema modifications. It's designed as a quick summary tool and may not reflect the exact state of a database that has undergone manual modifications or complex migrations.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Issues
If you find a bug or have a suggestion, please file an issue on the GitHub repository.
Credits
Laravel SummDB makes use of the following open-source packages:
- Mermaid.js for ERD generation