The ChurchTools-API Client is a PHP-based wrapper for the ChurchTools API and has been tested with ChurchTools version 3.104.3.
Note
Version 2 has been launched, featuring a restructured code base and numerous new features. If you're upgrading from version 1 to 2, please consult the Upgrade Guide.
Go to the project-root and install ChurchTools-API via composer:
composer require 5pm-hdh/churchtools-api
Load all dependency packages into the PHP project using the following code:
<?php
include_once 'vendor/autoload.php';
Before you can start to request data from the API you need to configure the CT-Client (ChurchTools client) with
the CTConfig
-interface:
use \CTApi\CTConfig;
//set the url of your ChurchTools application api
//important! ApiUrl must end with Top-Level-Domain. No paths allowed!
CTConfig::setApiUrl("https://example.church.tools");
//authenticates the application and load the api-key into the config
CTConfig::authWithCredentials(
"[email protected]",
"myPassword1234"
);
// Multi-factor authentication:
CTConfig::authWithCredentials(
"[email protected]",
"myPassword1234",
"291521"
);
For more information visit the CTConfig documentation From now on all features of the ChurchTools-API are available.
The whole ChurchTools-API client is build on top of the Requests and Models. Requests provide an interface to specify your api call by adding filtering, pagination and sorting. Models represent the data, that the Requests retrieve. More informations can be found in the documentation:
All APIs with examples:
- Person-API
- Group-API
- Calendar-API
- Resource- and Bookings-API
- PublicGroup-API
- Event-API
- Song-API
- Service-API
- Absence-API
- Wiki-API
- Permission-API
- File-API
- Search-API
- DB-Fields
- Tags-API
The following brief examples demonstrate the capabilities of the ChurchTools-API client and provide a general overview of its potential uses:
use CTApi\Models\Groups\Person\PersonRequest;
$myself = PersonRequest::whoami();
echo "Hello ".$myself->getLastName() . $myself->getFirstName();
// Retrieve all Persons
$allPersons = PersonRequest::all();
// Filter Data with Where-Clause
$teenager = PersonRequest::where('birthday_before', '2007-01-01')
->where('birthday_after', '2003-01-01')
->orderBy('birthday')
->get();
foreach($teenager as $teenPerson){
echo "Hello Teenager with E-Mail: ".$teenPerson->getEmail();
}
// Get specific Person
$personA = PersonRequest::find(21); // returns "null" if id is invalid
$personB = PersonRequest::findOrFail(22); // throws exception if id is invalid
use CTApi\Models\Events\Event\EventAgendaRequest;use CTApi\Models\Events\Event\EventRequest;
// Retrieve all events
$allEvents = EventRequest::all();
// Get specific Event
$event = EventRequest::find(21); // returns "null" if id is invalid
$event = EventRequest::findOrFail(22); // throws exception if id is invalid
// Filter events in period
$christmasServices = EventRequest::where('from', '2020-12-24')
->where('to', '2020-12-26')
->orderBy('id')
->get();
$christmasService = $christmasServices[0];
// get the Agenda with event id...
$eventId = $christmasServices->getId();
$agenda = EventAgendaRequest::fromEvent($eventId)->get();
// ...or direct on event-Model
$agenda = $event->requestAgenda();
// Use Songs-API
$songsOnChristmas = $agenda->getSongs();
foreach($songsOnChristmas as $song){
echo $song->getTitle() . " - (Key: " .$song->getKey() . ")";
}
use CTApi\Models\Wiki\WikiCategory\WikiCategoryRequest;
$wikiCategory = WikiCategoryRequest::find(21);
$rootNodeWiki = $wikiCategory->requestWikiPageTree();
echo "<h1>Table of content:</h1>";
echo "<ul class='first-level'>";
// First Level
foreach($rootNodeWiki->getChildNodes() as $node){
echo "<li>";
echo $node->getWikiPage()->getTitle();
echo "<ul class='second-level'>";
foreach($node->getChildNodes() as $nodeSecondLevel){
echo "<li>";
echo $nodeSecondLevel->getWikiPage()->getTitle();
echo "</li>";
}
echo "</ul>";
echo "</li>";
}
echo "</ul>";
Result:
<h1>Table of content:</h1>
<ul class="first-level">
<li>
Instruments
<ul class="second-level">
<li>Piano</li>
<li>Guitar</li>
</ul>
</li>
<li>
Chordsheets
</li>
<li>
Groups
<ul class="second-level">
<li>Worship-Teams</li>
<li>Service-Teams</li>
</ul>
</li>
</ul>
We welcome your support and contributions to this project.
The CTLog provides a facade to log Informations. By default it logs all important infos, warnings and errors in the
log-file: churchtools-api.log
. The creation of a logfile can be enabled and disabled with the method:
use CTApi\CTLog;
CTLog::enableFileLog( false ); //disable logfile
CTLog::enableFileLog(); // enable logfile
By default, the console will display all logs of Error, Critical, Alert, and Emergency levels. If you wish to display additional log levels on the console, you may use the CTConfig-Debug option or set it directly in the CTLog facade:
CTConfig::enableDebug();
//or use CTLog facade
CTLog::setConsoleLogLevelDebug();
CTLog::enableConsoleLog();
To log a message, use the getLog-method:
use CTApi\CTLog;
CTLog::getLog()->debug("Hello World!");
CTLog::getLog()->error("Error accourd here!");
Further information on CTLog-Page:
The API-Wrapper provides custom exceptions. More on this page: Error-Handling
To access the unit tests, navigate to the "tests/unit" directory. You may use the standard PHPUnit\Framework\TestCase to test small sections of code, or use TestCaseHttpMocked to simulate an HTTP request.
For integration tests, requests are sent directly to a ChurchTools instance. The "integration-test-data.json" file contains all available test data scenarios. All integration tests are automatically executed via Github Actions.
The Doc-Generator parses all documentation files and runs the PHP code examples to verify their validity. For additional information, please refer to this page: Doc-Generator
This project is licensed under MIT-License feel free to use it or to contribute.
To provide you with an idea of the ChurchTools-API Client's potential uses, here are a few examples. If you're working on a project too, please consider contributing and adding it to this list:
Administration Tools:
- ChurchTools-CLI by @5pm-HDH: With the ChurchTools-CLI-Tool, you can access data from your ChurchTools application instance directly through a CLI application, using simple commands that are easy to learn. The tool is compatible with cmd on Windows, terminal on Mac, and bash on Linux.
- ChurchTools GroupMeetings by @a-schild: Create ical feed from group meetings
- ChurchTools PDF Calendar by @a-schild: Generate PDF month calendars from churchtools
- ECGPB Member List Administration by @stollr: This application is written for the christian church Evangeliums-Christengemeinde e.V. and its main purpose is the administration of its members and to generate a printable member list.
Wordpress Plugins:
- ChurchTools WP Calendarsync by @a-schild: This wordpress plugin does take the events from the churchtools calendar and imports them as events in wordpress.
- Wordpress Plugin für ChurchTools Anmeldungen by @5pm-HDH: Mit diesem Wordpress-Plugin kannst du das von ChurchTools zur Verfügung gestellte iFrame für die Anmeldungen ersetzen durch einen eigenen Template-basierten Ansatz.
Other Applications:
- FreeScout Module by @churcholution: Login to FreeScout with ChurchTools credentials and manage permissions based on group/role memberships.