This library allows you to easily make use of the Clubhouse api integrations through one connector.
All you need to do is construct the Connector object with a configuration file. The configuration is done throught yaml and looks like this.
Clubhouse:
api:
uri: 'https://api.clubhouse.io/api/v3/'
token: 'myApiTokenHere'
$connector = new Connector('config.yaml');
The components are accessed through their respective services like this:
$connector->getEpicsService()->list();
This as you probably expects call the list of epics. This will return you a collection on Epic objects.
All the Clubhouse resources will translated into Domain objects per component.
All resource types will have their own Model and when retrieving multiple items, the models will be gathered in IteratorAggregate Collections.
This is done so collections retrieved can be iterated over instantly and data is converted into models, so we can use the data in a more specified way and make better use of the data later on.
So for example:
$epics = $connector->epics()->list();
foreach ($epics as $epic) {
echo $epic->getName();
echo $epic->getCreatedAt()->format('d-m-Y');
}
There will be services created for all components within Clubhouse and subcomponents (labels, categories, comments etc...)
To use a service you'll access it throught the connector as described above.
- Create an Epic
$epic = new Epic();
$epic->setName('My first created Epic')
->setDescription('This is the description for my Epic');
$createdEpic = $connector->epics()->create($epic);
- Update an existing Epic
$existingEpic = $connector->epics()->get(1);
$existingEpic->setName('A new name for this Epic');
$updatedEpic = $connector->epics()->update($existingEpic);
- Delete an Epic
$connector->epics()->delete(1);
- List all Epics
$collection = $connector->epics()->list();
- Epics
- Milestones
- Projects
- Stories
$connector->epics()
$connector->milestones()
$connector->projects()
$connector->stories()
You can add your own logger if you feel the need to catch the logs somewhere :) All you need is a logger which interfaces with PSR-3 logger interface.
When you have that simply construct the connector with it as such:
$logger = new MyOwnPsrLogger();
$connector = new Connector('config.yaml', $logger);
The method and variable names I used in the connector are like getEpicsService()
But to make it a bit more relatable with Clubhouse naming and simply a bit shorter,
I added magic method calls for the services.
So instead of calling $connector->getEpicsService()->list()
You can also call $connector->epics()->list()