An API client package for the Events Force API. For reference to what kind of data you can pass to the API methods refer to the general API documentation. To get a client slug / client account string see here
- PHP >= 5.5.0
- Guzzle
composer require jbarnard/efapiphp
Note: The follow examples all use the apiexample credentials as shown here
// Define a new client, passing in the client slug and api key
$client = new \EventsForce\Client('apiexample', '035E0A65508A4D8FAB63A983F36ACCAC');
Now you are ready to use specific resources and methods The resources are split as shown on the api docs E.g to access events get all you would do the following:
$stream = $client->events->getAll();
The response is a \Psr\Http\Message\StreamInterface
#####Get all - /events.json#####
$client->events->getAll();
#####Get single - /events/{event_id}.json
$client->events->get(2); // where 2 is the event id
#####Get all attendees for an event - /events/{event_id}/attendees.json##### Available parameters:
- lastModifiedAfter
- paymentStatus
- category
- registrationStatus
$client->attendees
->setEvent(2)
->getAll();
// Or you can also pass arguments where it is a key value array as below
$arguments = [
'lastModifiedAfter' => '2016-04-07 19:43:26', // date('Y-m-d H:i:s');
'paymentStatus' => 'paid',
'category' => 'Attendee',
'registrationStatus' => 'complete'
];
$client->attendees
->getAll($arguments);
// this will return a stream for only attendees who have paid, are an Attendee, they have completed their registration and they were last modified after 2016-04-07 19:43:26
// also notice we didn't run 'setEvent' again, this is because until you set an event again it will use the previously set one
// nb: attempting to get a resource which depends on an id prior to setting it will throw an exception
$client->attendees
->setEvent(1)
->get(103);
#####Update an attendee - /events/{event_id}/attendees/{attendee_id}.json?_HttpMethod=PATCH##### Needs testing with a full access api, not just the example
$client->attendees
->setEvent(1)
->update(103, [
'customData' => [
[
'key' => 'Receive Newsletter',
'value' => 'false',
],
[
'key' => 'CRM ID',
'value' => '123456'
]
]
]);
#####Authenticate an attendee - /events/{event_id}/attendees/authenticate.json##### The value required for userID depends on the attendeeIDMode set for the event.
$client->attendees
->setEvent(1)
->auth('[email protected]', 'DWS7C6Z');
#####Get all sessions for an event - /events/{event_id}/sessions.json#####
$client->sessions
->setEvent(3)
->getAll();
#####Get a single session for an event - /events/{event_id}/sessions/{session_id}.json#####
$client->sessions
->setEvent(3)
->get(17);
#####Get a single person - /people/{person_id}.json#####
$client->people
->get(99);
#####Get all invoices - /invoices.json##### Can have an optional invoiceNumberAfter parameter which will return the items with id's from that point, defaults to 0
$client->invoices
->getAll();
// or with parameter
$client->invoices
->getAll(1);
#####Get a single invoice - /invoices/{invoice_number}.json#####
$client->invoices
->get(1);
#####Update an invoice - /invoices/{invoice_number}.json?_HttpMethod=PATCH##### Needs testing with a full access api, not just the example
$client->invoices
->update(1, [
'externalInvoiceReference' => 'EF123456'
]);
// Because EventsForce have only opened one field to be updated on an invoice this method has a helper as below:
$client->invoices
->updateExternalRef(1, 'EF123456');
#####Get all payments for an invoice - /invoices/{invoice_number}/payments.json#####
$client->payments
->setInvoice(2)
->getAll();
#####Post a payment against an invoice /invoices/{invoice_number}/payments.json##### Needs testing with a full access api, not just the example
$client->payments
->setInvoice(2)
->setPostDefault('currencyCode', 'GBP') // you can use setPostDefault to set a default payment parameter, this allows you to set default then post multiple payments using similar details
->setPostDefault('comment', 'Made by My Application') // set a default comment for all future payments
->post(['amount' => 29.99]); // post one payment
$client->payments
->post(['amount' => 27.79]); // post another
#####Get a single payment for an invoice - /invoices/{invoice_number}/payments/{payment_id}.json#####
$client->payments
->setInvoice(2)
->get(2);
The methods return a response object - http://guzzle3.readthedocs.org/http-client/response.html You can get the body of the response by calling:
$body = $response->getBody();
You can also get the status code:
$status_code = $response->getStatusCode();
There are other helpers that can be seen here: http://guzzle3.readthedocs.org/http-client/response.html
Example JSON output:
{
"responseCode": 200,
"systemErrorCode": "",
"systemErrorMessage": "",
"userErrorMessage": "",
"itemCount": 2,
"data": [
{
"detailsURL": "https://www.eventsforce.net/apiexample/api/v2/events/1.json",
"eventID": 1,
"eventName": "Test API event",
"eventStatus": "notlive",
"eventStartDateTime": "2014-01-23T09:00:00Z",
"eventEndDateTime": "2014-01-23T17:00:00Z",
"venueName": ""
},
{
"detailsURL": "https://www.eventsforce.net/apiexample/api/v2/events/2.json",
"eventID": 2,
"eventName": "Test API event with payment",
"eventStatus": "notlive",
"eventStartDateTime": "2014-01-23T09:00:00Z",
"eventEndDateTime": "2014-01-23T17:00:00Z",
"venueName": ""
}
]
}
Found in CONTRIBUTING.md
Found in LICENSE file