This package in a work in progress, it is based on the code YM-API.
This package implements a PHP wrapper to work with http://www.yourmembership.com/company/api-reference/
Require this package with composer by adding the following to your composer file:
"require": {
"coolcodemy/yourmembership-laravel-api": "^0.0.1"
},
Then run composer update
to download the package.
Or use
composer require coolcodemy/yourmembership-laravel-api
After updating composer, add the service provider to the providers
array in config/app.php
CoolCodeMY\YourMembershipLaravelAPI\YourMembershipServiceProvider::class,
Publish the config for the package
php artisan vendor:publish --provider="CoolCodeMY\YourMembershipLaravelAPI\YourMembershipServiceProvider"
Fill in your API_KEY, SECRET_API_KEY and SA_PASSCODE inside config/yourmembership-laravel-api.php
.
<?php
...
use CoolCodeMY\YourMembershipLaravelAPI\YMLA;
class YourController extends Controller {
public function index(YMLA $ymla)
{
// Array results
$result = $ymla->call('Auth.Authenticate', [
'Username' => '[email protected]',
'Password' => 'password',
])->toArray();
// JSON/Object result
$result = $ymla->call('Auth.Authenticate', [
'Username' => '[email protected]',
'Password' => 'password',
])->toJson();
// XML result
$result = $ymla->call('Auth.Authenticate', [
'Username' => '[email protected]',
'Password' => 'password',
])->toXML();
}
...
}
You don't need to generate session for authentication as this package will do it for you. The SessionID is saved inside Laravel cache for 15 minutes.
This will return the results as XML and set the return header to XML for the browser to properly print valid XML.
...
$result = $ymla->call('Auth.Authenticate', [
'Username' => '[email protected]',
'Password' => 'password',
])->toXML();
return response()->xml($result);
...