glaucojrcarvalho / sql-console
Browser SQL console for Laravel with safe-guarded execution and multi-connection support.
Package info
github.com/glaucojrcarvalho/laravel-sql-console
pkg:composer/glaucojrcarvalho/sql-console
Requires
- php: ^8.2
- illuminate/http: ^10.0|^11.0|^12.0
- illuminate/routing: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
- illuminate/view: ^10.0|^11.0|^12.0
README
glaucojrcarvalho/sql-console is a browser SQL console package for Laravel with safety guardrails.
Features
- Single SQL statement per execution
- JSON bindings support (
:namedplaceholders) - Multi-connection support (MySQL, Oracle, and others you configure)
- Read/write statement control
- Optional write confirmation checkbox
- Optional role restriction
- Standalone UI or embedded in your own app layout
Requirements
- PHP 8.2+
- Laravel 10, 11 or 12
Installation
Option 1: Packagist (recommended after publish)
composer require glaucojrcarvalho/sql-console:^1.1 php artisan vendor:publish --tag=sql-console-config
Option 2: Directly from GitHub
composer config repositories.glaucojrcarvalho-sql-console vcs https://github.com/glaucojrcarvalho/laravel-sql-console.git composer require glaucojrcarvalho/sql-console:^1.1 php artisan vendor:publish --tag=sql-console-config
Option 3: Local path (development)
Add to your project composer.json:
{
"repositories": [
{
"type": "path",
"url": "../packages/sql-console",
"options": { "symlink": true }
}
],
"require": {
"glaucojrcarvalho/sql-console": "*"
}
}
Then:
composer update glaucojrcarvalho/sql-console --ignore-platform-reqs php artisan vendor:publish --tag=sql-console-config
Routes
GET /admin/sql-console(admin.sql.console.index)POST /admin/sql-console/run(admin.sql.console.run)
Configuration
Published file: config/sql-console.php
return [ 'route_prefix' => 'admin/sql-console', 'middleware' => ['web', 'auth'], 'layout' => null, // ex: 'template.main' 'authorization_mode' => 'role', // role | allowlist | any_auth 'manager_role_id' => env('SQL_CONSOLE_MANAGER_ROLE_ID'), 'role_field' => 'role_id', 'allowlist' => [ 'table' => 'sql_console_allowed_users', 'user_identifier_field' => 'id', 'user_identifier_column' => 'user_identifier', 'active_column' => 'is_active', 'can_write_column' => 'can_write', ], 'connections' => [ 'mysql' => 'MySQL', 'oracle' => 'Oracle', ], 'max_rows' => 200, 'require_write_confirmation' => true, ];
Notes:
authorization_mode=roleusesmanager_role_id.authorization_mode=allowlistuses a DB table to decide who can access and write.authorization_mode=any_authallows any authenticated user.- Keep this route protected in production.
Optional Allowlist Table
If you want per-user permissions (recommended for production/shared environments):
php artisan vendor:publish --tag=sql-console-migrations php artisan migrate
Then insert allowed users in sql_console_allowed_users:
user_identifier: matches your auth user field (defaultusers.id)is_active: true/falsecan_write: true/false
Example:
INSERT INTO sql_console_allowed_users (user_identifier, is_active, can_write, created_at, updated_at) VALUES ('1', 1, 0, NOW(), NOW());
Manage Allowlist via Artisan (No Workbench)
Allow user (read-only):
php artisan sql-console:allow 1
Allow user with write permission:
php artisan sql-console:allow 1 --write
Revoke user (set inactive):
php artisan sql-console:revoke 1
Revoke user and delete row:
php artisan sql-console:revoke 1 --delete
Security Notes
- This tool is intentionally restricted to one SQL statement at a time.
- DDL/admin keywords are blocked by default (
drop,truncate,alter, etc.). - Use least-privilege database credentials for any connection exposed here.
- Prefer
authorization_mode=allowlistin production to explicitly control users and write access.
Release Flow
- Push package to
main - Create a semantic tag (example:
v1.0.0) - Register/update repository on Packagist
- For each new release, push a new tag (
v1.0.1,v1.1.0, etc.)
Release Notes
- Do not define
versionincomposer.json. - Package versions are controlled by Git tags (
v1.1.3,v1.1.4, ...). - After pushing a new tag, trigger update on Packagist.
Troubleshooting Packagist
If Packagist shows:
tag (...) does not match version (...) in composer.json
it means old tags were created when a fixed version field existed in composer.json.
Fix:
- Ensure
composer.jsonhas noversionfield. - Commit and push.
- Create a new tag (do not reuse old tags).
- Update the package on Packagist.