cmdrsharp/netbox-laravel

A client for creating/reading from NetBox

1.0.2.0 2021-04-22 13:24 UTC

This package is auto-updated.

Last update: 2024-10-19 02:57:13 UTC


README

This repo contains a client for interacting with the NetBox API - more specifically to be able to treat them more like resources (akin to Laravel models).

Each resource type defines a fillable property which allows mass assignment. Each property is named 1:1 with the NetBox API documentation. Resources also contain helper methods to allow easy lookups.

Current Requirements

  • PHP 7.4 or newer
  • Laravel 7.0 or newer
  • NetBox (2.10 tested)

Installation

Via composer

$ composer require cmdrsharp/netbox-laravel

After installation, publish the configuration file.

php artisan vendor:publish --provider="CmdrSharp\NetBox\NetBoxServiceProvider"

Which will create a netbox.php file in your Laravel config directory which contains keys for the NetBox URL and API Token. It is recommended to simply define these in your .env file. The config file will automatically read from these values.

NETBOX_URL=
NETBOX_API_TOKEN=5672

If you for some reason wish to disable SSL Validation toward the NetBox API, you can override validation in the .env file.

NETBOX_VERIFY_SSL=false

Usage

For creating a new resource, instantiate the correct model and call its create method.

use CmdrSharp\NetBox\Ipam\Prefix;

$prefix = new Prefix([
    'prefix' => '172.16.0.0/24', // Prefixes are specified according to the NetBox API Docs
    'role' => 1, // This is an ID referring to the resource in NetBox
    'site' => 1, // This is an ID referring to the resource in NetBox
    'tenant' => 1, // This is an ID referring to the resource in NetBox
    'vlan' => 1, // This is an ID referring to the resource in NetBox
    'is_pool' => false,
    'description' => 'Cool Network',
    'vrf' => 1, // This is an ID referring to the resource in NetBox
    'status' => 'active'
]);

$prefix->create();
// Returns a Guzzle ResponseInterface with getBody and getStatusCode methods.

For your convenience, each resource also contains named set-methods that cover all fillable properties.

use CmdrSharp\NetBox\Ipam\Prefix;

$prefix = new Prefix();
$prefix->setPrefix('172.16.0.0/24')
        ->setRole(1)
        ->setSite(1)
        ->setTenant(1)
        ->setVlan(1)
        ->setPool(false)
        ->setDescription('Cool Network')
        ->setVrf(1)
        ->setStatus('active')
        ->create();

Example: Get a prefix from the NetBox API

use CmdrSharp\NetBox\Ipam\Prefix;

Prefix::wherePrefix('172.16.0.0/24');
// Returns a Guzzle ResponseInterface with getBody and getStatusCode methods.

Other resources

Developing

When creating new resources, please ensure to follow existing standards to ensure they remain compatible. The fillable array should ideally map 1:1 with the NetBox API Documentation. In cases where this requires special attribute management, we rely on the user knowing this ahead of time for mass assignment, and offer helpers in fluid setters to deal with these scenarios.

Currently, no validation of input should be performed. This is subject to change as we may opt to validate attributes according to NetBox API specs.

Testing

All resources should be covered by tests. Tests should extend the NetBoxTestCase class, which defines config values such as the URL to the NetBox Instance (which can easily be spun up via Docker) and a random API Key which should be created in said NetBox instance.

Versioning

This package follows Explicit Versioning.