This package provides a Zabbix API library for Laravel Framework. It uses the PhpZabbixApi class generated by the https://github.com/confirm/PhpZabbixApi package.
NOTE: This version was tested with Zabbix Server 3.0.* only. Not sure if it works with other versions as well.
To get started, you should add the becker/laravel-zabbix-api Composer dependency to your project:
composer require becker/laravel-zabbix-apiNOTE: You can skip this step if you are using Laravel 5.5 or higher. The package is automatically registered, due to the package auto-discovery feature.
Open up the config/app.phpand register the new Service Provider:
//config/app.php
/*
 * Package Service Providers...
 */
Becker\Zabbix\ZabbixServiceProvider::class,
//...php artisan vendor:publish --tag=zabbixThis will create the config/zabbix.php file.
At your .env file, define the new Zabbix settings:
ZABBIX_HOST=http://your.zabbix.url
ZABBIX_USERNAME=username
ZABBIX_PASSWORD=passwordIMPORTANT: The
ZABBIX_HOSTparameter SHOULD NOT contain any trailing slashes at the end. For a list of all available environment variables, check theconfig/zabbix.phpfile.
//app/Http/Controllers/TestController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
class TestController extends Controller
{
    /**
     * The ZabbixApi instance.
     *
     * @var \Becker\Zabbix\ZabbixApi
     */
    protected $zabbix;
    
    /**
     * Create a new Zabbix API instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->zabbix = app('zabbix');
    }
    /**
     * Get all the Zabbix host groups.
     *
     * @return array
     */
    public function index()
    {
        return $this->zabbix->hostgroupGet([
            'output' => 'extend'
        ]);
        // Or, if you want to use Laravel Collections
        return collect($this->zabbix->hostgroupGet())->map(function ($item) {
            return [
                'name' => strtoupper($item->name)
            ];
        });
    }
}And that's it! 🍻
