vented / enhance-api-laravel
An Enhance API SDK tailored for usage within Laravel
Fund package maintenance!
Vented Labs
Requires
- php: ^8.3
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- guzzlehttp/guzzle: ^7.3
- guzzlehttp/psr7: ^1.7 || ^2.0
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0.0||^9.0.0||^8.22.0
- pestphp/pest: ^2.0||^3.0
- pestphp/pest-plugin-arch: ^2.5||^3.0
- pestphp/pest-plugin-laravel: ^2.0||^3.0
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
- spatie/laravel-ray: ^1.35
This package is auto-updated.
Last update: 2025-08-16 18:21:08 UTC
README
An Enhance API SDK tailored for usage within Laravel applications. This package provides a clean, Laravel-friendly wrapper around the auto-generated Enhance API client, making it easy to integrate Enhance's hosting management capabilities into your Laravel projects.
Installation
You can install the package via composer:
composer require vented/enhance-api-laravel
You can publish the config file with:
php artisan vendor:publish --tag="enhance-config"
Configuration
Set your Enhance API credentials in your .env
file:
ENHANCE_API_URL=https://your-enhance-api-endpoint.com ENHANCE_API_TOKEN=your-api-token-here ENHANCE_API_ORGANIZATION=your-default-org-id
This is the contents of the published config file:
return [ 'base_url' => env('ENHANCE_API_URL', ''), 'api_key' => env('ENHANCE_API_TOKEN'), 'default_organization' => env('ENHANCE_API_ORGANIZATION', ''), 'timeout' => env('ENHANCE_API_TIMEOUT', 30), 'retry' => [ 'times' => env('ENHANCE_API_RETRY_TIMES', 3), 'sleep' => env('ENHANCE_API_RETRY_SLEEP', 1000), ], ];
Usage
Via Facade
use Vented\EnhanceApiLaravel\Facades\Enhance; // Get all organizations $orgs = Enhance::orgs()->getAllOrgs(); // Get websites $websites = Enhance::websites()->getWebsites(); // Get domains $domains = Enhance::domains()->getDomains(); // Manage servers $servers = Enhance::servers()->getServers();
Via Service Container
use Vented\EnhanceApiLaravel\EnhanceApiLaravel; class YourController extends Controller { public function __construct( private EnhanceApiLaravel $enhance ) {} public function index() { $websites = $this->enhance->websites()->getWebsites(); $domains = $this->enhance->domains()->getDomains(); return view('dashboard', compact('websites', 'domains')); } }
Available API Endpoints
The SDK provides access to all Enhance API endpoints:
- Apps:
Enhance::apps()
- Application management - Backups:
Enhance::backups()
- Backup operations - Customers:
Enhance::customers()
- Customer management - DNS:
Enhance::dns()
- DNS record management - Domains:
Enhance::domains()
- Domain operations - Emails:
Enhance::emails()
- Email account management - MySQL:
Enhance::mysql()
- Database management - Organizations:
Enhance::orgs()
- Organization management - Servers:
Enhance::servers()
- Server management - Websites:
Enhance::websites()
- Website management - WordPress:
Enhance::wordpress()
- WordPress-specific operations - And many more...
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.