Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/presttec/laravel-whmcs


https://github.com/presttec/laravel-whmcs

Last synced: about 1 month ago
JSON representation

Awesome Lists containing this project

README

        

Laravel WHMCS
======

[![Latest Stable Version](https://poser.pugx.org/presttec/laravel-whmcs/v/stable)](https://packagist.org/packages/presttec/laravel-whmcs)
[![Total Downloads](https://poser.pugx.org/presttec/laravel-whmcs/downloads)](https://packagist.org/packages/presttec/laravel-whmcs)
[![License](https://poser.pugx.org/presttec/laravel-whmcs/license)](https://packagist.org/packages/presttec/laravel-whmcs)

An interface for interaction with the WHMCS API in Laravel.

## Installation

Install the package through [Composer](http://getcomposer.org/). Run the Composer require command from the Terminal:

```bash
composer require presttec/laravel-whmcs
```

Package will be installed automaticlly through composer package discovery. If not, then you need to register
the `PrestTEC\Whmcs\WhmcsService` service provider in your config/app.php.

Optionally, you can add the alias if you prefer to use the Facade

```php
'Whmcs' => PrestTEC\Whmcs\Facades\Whmcs::class
```

## Configuration

To get started, you'll need to publish all vendor assets.

```bash
php artisan vendor:publish --provider=PrestTEC\Whmcs\WhmcsServiceProvider
```

Then open `config\whmcs.php` to fill your WHMCS api credentials in

Now you can use the WHMCS API in your Laravel project.

### Lumen

Copy the config file from the package to your projects config directory:

```bash
cp vendor/presttec/laravel-whmcs/config/whmcs.php config/whmcs.php
```

Then open `config\whmcs.php` to fill your WHMCS api credentials in.

To finish this, register the config file and the service provider in `bootstrap/app.php`:

```php
$app->configure('whmcs');
$app->register(PrestTEC\Whmcs\WhmcsServiceProvider::class);
```

Now you can use the WHMCS API in your Lumen project.

## Basic Usage

You can call your WHMCS API directly by calling the `\WHMCS::{WHMCSAPIFUNCTION}` facade.

If you prefer dependency injection, you can inject the manager like this:

```php
use PrestTEC\Whmcs\WhmcsManager;

class WhmcsController extends Controller
{
private $whmcsManager;

public function __construct(WhmcsManager $whmcsManager)
{
$this->whmcsManager = $whmcsManager;
}

public function index()
{
$this->whmcsManager->execute('GetInvoice', ['invoiceid' => '1337']);
}
}
```
**Hint**: The execute command will also support your self-created WHMCS api commands.

### Examples

Obtain a list of client purchased products:

```php
\Whmcs::GetClientsProducts([
'clientid' => '12345'
]);
```

Retrieve a specific invoice:

```php
\Whmcs::GetInvoice([
'invoiceid' => '1337'
]);
```

## Support

[Please open an issue in github](https://github.com/presttec/laravel-whmcs/issues)

## License

This package is released under the MIT License. See the bundled
[LICENSE](https://github.com/presttec/laravel-whmcs/blob/master/LICENSE.md) file for details.

Contributing to Laravel Whmcs
------------------------

If you find a bug or want to add a feature to Laravel Whmcs, great! In order to make it easier and quicker for me to verify and merge changes in, it would be amazing if you could follow these few basic steps:

1. Fork the project.
2. **Branch out into a new branch. `git checkout -b name_of_new_feature_or_bug`**
3. Make your feature addition or bug fix.
4. **Add tests for it. This is important so I don’t break it in a future version unintentionally.**
5. Commit.
6. Send me a pull request!