2017 © Pedro PelĂĄez
 

library proxmoxve

A simple PHP 5.5+ Proxmox API client.

image

zzantares/proxmoxve

A simple PHP 5.5+ Proxmox API client.

  • Sunday, July 29, 2018
  • by ZzAntares
  • Repository
  • 11 Watchers
  • 60 Stars
  • 3,221 Installations
  • PHP
  • 5 Dependents
  • 0 Suggesters
  • 31 Forks
  • 3 Open issues
  • 11 Versions
  • 13 % Grown

The README.md

ProxmoxVE API Client

This PHP 5.5+ library allows you to interact with your Proxmox server via API., (*1)

Build Status Latest Stable Version Total Downloads Latest Unstable Version License, (*2)

I'm not actively maintaining this library anymore (I've left PHP behind) but the API is pretty stable, if it doesn't suit your needs take a look at the forks or better yet create a PR to add the things you're missing, if you're interested I can transfer the project to you., (*3)

Looking for a PHP 5.3 library version? Search through the releases one that fits your needs, I recommend using the 2.1.1 version., (*4)

Installation

Recommended installation is using Composer, if you do not have Composer what are you waiting?, (*5)

In the root of your project execute the following:, (*6)

$ composer require zzantares/proxmoxve ~4.0

Or add this to your composer.json file:, (*7)

{
    "require": {
        "zzantares/proxmoxve": "~4.0"
    }
}

Then perform the installation:, (*8)

$ composer install --no-dev

Usage

<?php

// Require the autoloader
require_once 'vendor/autoload.php';

// Use the library namespace
use ProxmoxVE\Proxmox;

// Create your credentials array
$credentials = [
    'hostname' => 'proxmox.server.com',  // Also can be an IP
    'username' => 'root',
    'password' => 'secret',
];

// realm and port defaults to 'pam' and '8006' but you can specify them like so
$credentials = [
    'hostname' => 'proxmox.server.com',
    'username' => 'root',
    'password' => 'secret',
    'realm' => 'pve',
    'port' => '9009',
];

// Then simply pass your credentials when creating the API client object.
$proxmox = new Proxmox($credentials);

$allNodes = $proxmox->get('/nodes');

print_r($allNodes);

Sample output:, (*9)

Array
(
    [data] => Array
        (
            [0] => Array
                (
                    [disk] => 2539465464
                    [cpu] => 0.031314446882002
                    [maxdisk] => 30805066770
                    [maxmem] => 175168446464
                    [node] => mynode1
                    [maxcpu] => 24
                    [level] =>
                    [uptime] => 139376
                    [id] => node/mynode1
                    [type] => node
                    [mem] => 20601992182
                )

        )

)

Using the MailGateway API

This library can be used to communicate with the Proxmox MailGateway API as well, by simply changing the system entry in the credentials array., (*10)

<?php

$credentials = [
    'hostname' => 'proxmox.server.com',  // Also can be an IP
    'username' => 'root',
    'password' => 'secret',
    'system' => 'pmg', // Defaults to 'pve' for the PVE API. Use 'pmg' for the PMG API.
];

Want to know more nifty tricks?

Checkout our wiki., (*11)

Docs

On your proxmox client object you can use get(), create(), set() and delete() functions for all resources specified at PVE2 API Documentation, params are passed as the second parameter in an associative array., (*12)

What resources or paths can I interact with and how?, (*13)

In your proxmox server you can use the pvesh CLI Tool to manage all the pve resources, you can use this library in the exact same way you would use the pvesh tool. For instance you could run pvesh then, as the screen message should say, you can type help [path] [--verbose] to see how you could use a path and what params you should pass to it. Be sure to read about the pvesh CLI Tool at the Proxmox wiki., (*14)

How does the Proxmox API works?, (*15)

Consult the ProxmoxVE API article at the Proxmox wiki., (*16)

I feel you're hiding some cool tricks! I need more docs!, (*17)

See the project's wiki for a more detailed documentation, it's all in there I swear it... I think., (*18)

License

This project is released under the MIT License. See the bundled LICENSE file for details., (*19)

Want to contribute?

Thank you! Take a look at the CONTRIBUTING, you could easily set up a development environment to get you started in no time!, (*20)

The Versions

29/07 2018

dev-master

9999999-dev https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.5+ Proxmox API client.

  Sources   Download

MIT

The Requires

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

29/07 2018

dev-develop

dev-develop https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.5+ Proxmox API client.

  Sources   Download

MIT

The Requires

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

29/07 2018

v4.0.0

4.0.0.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.5+ Proxmox API client.

  Sources   Download

MIT

The Requires

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

11/04 2018

dev-guzzle6

dev-guzzle6 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.5+ Proxmox API client.

  Sources   Download

MIT

The Requires

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

11/08 2014

v3.0.0

3.0.0.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.4+ Proxmox API client.

  Sources   Download

MIT

The Requires

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

13/07 2014

v2.1.1

2.1.1.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.3+ Proxmox API client.

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • lib-curl *

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

09/07 2014

v2.1.0

2.1.0.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.3+ Proxmox API client.

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • lib-curl *

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

03/07 2014

v2.0.0

2.0.0.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.3+ Proxmox API client.

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • lib-curl *

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

01/07 2014

v1.1.1

1.1.1.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.3+ Proxmox API client.

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • lib-curl *

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

30/06 2014

v1.1.0

1.1.0.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.3+ Proxmox API client.

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • lib-curl *

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm

26/06 2014

v1.0.0

1.0.0.0 https://github.com/ZzAntares/ProxmoxVE

A simple PHP 5.3+ Proxmox API client.

  Sources   Download

MIT

The Requires

  • php >=5.3.0
  • lib-curl *

 

The Development Requires

by César Muñoz

api openvz virtualization proxmox kvm