codeiqbv / laravel-virtualizor
Integration between Laravel and Virtualizro
Fund package maintenance!
CODEIQ
Requires
- php: ^8.0
- illuminate/contracts: ^10.0||^11.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^9.0.0||^8.22.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1
- phpstan/phpstan-phpunit: ^1.3
- spatie/laravel-ray: ^1.35
README
A Laravel package that provides a clean and elegant way to interact with the Virtualizor API. This package offers a fluent interface for both Admin and Enduser APIs, making it easy to manage your Virtualizor infrastructure from your Laravel application.
Features
- ๐ Full support for both Admin and Enduser APIs
- ๐ช Fluent interface with proper type hinting
- ๐ก๏ธ Comprehensive error handling
- ๐ Extensive documentation
- โก Laravel integration with config file and facade
- ๐งช Well tested
Requirements
- PHP 8.0 or higher
- Laravel 10.0 or higher
Installation
You can install the package via composer:
composer require codeiqbv/laravel-virtualizor
Configuration
Publish the config file:
php artisan vendor:publish --tag="virtualizor-config"
Add your credentials to .env
:
VIRTUALIZOR_ADMIN_KEY=your_admin_key VIRTUALIZOR_ADMIN_PASS=your_admin_pass VIRTUALIZOR_ADMIN_IP=your_admin_ip VIRTUALIZOR_ADMIN_PORT=4085 VIRTUALIZOR_ENDUSER_KEY=your_enduser_key VIRTUALIZOR_ENDUSER_PASS=your_enduser_pass VIRTUALIZOR_ENDUSER_IP=your_enduser_ip VIRTUALIZOR_ENDUSER_PORT=4083 VIRTUALIZOR_DEBUG=false
Usage
Admin API
Check our wiki to find out how you do certain calls. It is easy. You can also check the Virtualizor API docs, we covered almost every endpoint and are still working on adding more. In the WIKI directory we try to add documentation as best as we can.
Error Handling
The package throws VirtualizorApiException
for API errors:
use CODEIQ\Virtualizor\Exceptions\VirtualizorApiException; try { $users = VirtualizorAdmin::users()->list(); } catch (VirtualizorApiException $e) { $message = $e->getMessage(); $context = $e->getContext(); // Available when debug is enabled }
License
The MIT License (MIT). Please see License File for more information.