API via PHP getCalendarEvents -
-
Hallo Zusammen,
leider komme ich mit dem API-Zugriff auf die Kalender nicht weiter (Der "öffentlicher Benutzer" darf alle Kalender ansehen):Meine Testausgabe (die nicht funktioniert):
http://www.coc-ek.de/churchtools/calenderEvents.php// PHP START
include_once('helper.php');
// Get Calendar events. Make sure the calendar is available for public user
// otherwise login before
$url = 'https://coc-ek.churchtools.de/index.php?q=churchcal/ajax';
$data = array('func' => 'getCalendarEvents',
'category_ids' => [1,2,3],
'from' => 0,
'to' => '10');
$result = sendRequest($url, $data);
if ($result->status == "fail") {
echo $result->data;
return;
}echo " Ausgabe: ";
print_r($result->data);
echo "";// PHP ENDE
Beim Ausführen kommt immer "There is an error: Parameter func not defined!".
Habe den PHP-Code von GitHub: https://github.com/churchtools/ctapidemo
Wo finde ich die IDs der verschiedenen Kalender?
Vielen Dank im Voraus!
-
Hallo @samdre,
das liegt daran, dass die API-Zugriffe nur noch über "coc-ek.church.tools funktionieren. Das wurde mal umgestellt, aber anscheinend im Beispiel-Code nicht nachgezogen.
Im Beispiel-Code ist auch die Angabe der "category_ids" falsch (zumindest funktioniert es bei mir so nicht), richtig müssen die so angegeben werden
'category_ids[]' = '1', 'category_ids[]' = '2', 'category_ids[]' = '3',
Dieser Code sollte dann also funktionieren:
include_once('helper.php'); // Get Calendar events. Make sure the calendar is available for public user // otherwise login before $url = 'https://coc-ek.church.tools/index.php?q=churchcal/ajax'; $data = array('func' => 'getCalendarEvents', 'category_ids[]' => '1', 'category_ids[]' => '2', 'category_ids[]' => '3', 'from' => 0, 'to' => '10'); $result = sendRequest($url, $data); if ($result->status == "fail") { echo $result->data; return; } echo " Ausgabe: "; print_r($result->data); echo "";
Die Id eines Kalenders findest du z.B. in den Einstellungen für den jeweiligen Kalender oder man kann sie auch aus der ical-URL herauslesen.
PS: Ich finde es deutlich einfacher, die API-Aufrufe erstmal mit Postman zu testen, es geht schneller und man sieht auch gleich, was man da zurückbekommt.
-
Hallo @hallo144,
1000-Dank für die ausführliche Antwort!
Habe das Ganze jetzt mal mit Postman aufgerufen, dort funktioniert es wunderbar.
Wenn ich es per PHP-Skript (siehe unten) aufrufe kommt folgender Fehler:There is an error: No category_ids given!
// PHP START
include_once('helper.php');
// Get Calendar events. Make sure the calendar is available for public user
// otherwise login before
$url = 'https://coc-ek.church.tools/index.php?q=churchcal/ajax';
$data = array('func' => 'getCalendarEvents',
'category_ids[]' => '2',
'from' => 0,
'to' => '10');
$result = sendRequest($url, $data);
if ($result->status == "fail") {
echo $result->data;
return;
}echo " Ausgabe: ";
print_r($result->data);
echo "";// PHP ENDE
Meine angepasste Ausgabedatei: http://www.coc-ek.de/churchtools/calenderEvents.php
Habe URL ("church.tools" statt "churchtools.de") und Übergabe der category_ids[] (einzeln) wie in deinem Beispiel angepasst.
Muss in "helper.php" noch eine Anpassung vorgenommen werden? Ist eine besonderer Header für die PHP-Datei notwendig?
Vielen Dank für Hilfe...
-
@samdre Also bei mir funktioniert dein Code.
Die ganze Datei schaut bei mir so aus:
< ?php //(< das Leerzeichen zwischen < und ? natürlich weglassen, dass Forum stellt das sonst nur nicht richtig da) include_once('helper.php'); // Get Calendar events. Make sure the calendar is available for public user // otherwise login before $url = 'https://coc-ek.church.tools/index.php?q=churchcal/ajax'; $data = array('func' => 'getCalendarEvents', 'category_ids[]' => '2', 'from' => 0, 'to' => '10'); $result = sendRequest($url, $data); if ($result->status == "fail") { echo $result->data; return; } echo " Ausgabe: "; print_r($result->data); echo ""; ?>
In der helper.php habe ich nur den öffnenden PHP Tag angepasst ("php" statt "<?"), da xampp das sonst nicht als php Code erkennt. Aber das ist bei dir nicht der Fehler.
-
@hallo144
wenn ich das Skript lokal (xampp) ausführe funktioniert der Code auch. Nur, wenn ich ihn via Hostingpaket aufrufe (http://www.coc-ek.de/churchtools/calenderEvents.php) offensichtlich nicht... Oder kann es sein, dass die Server-IP/-URL geblockt wird? -
@samdre Interessant
Ich denke, dass ist ein Fall für den Support deines Hosting-Anbieters und vielleicht auch den Churchtools-Support.Ich habe es gerade mal auf den Webspace meiner Gemeinde geschoben und da geht es: http://herzogenaurach.feg.de/test/cal.php
Wäre schön, wenn du mal berichtest, was da rausgekommen ist.
-
@hallo144,
1000 Dank. Also, ich vermute, dass unser Hostingpaket durch meine Tests gesperrt wurde (zuviele Aufrufe?). Arbeite jetzt erstmal lokal weiter und berichte dann... Vielen Dank schonmal für die tolle Unterstützung. -
Da es bei Anderen funktioniert, muss es irgendwas mit dem Server zu tun haben. Welche PHP-Version benutzt eurer Provider? Das kann man z.B. auch in ChurchTools unter "über" nachlesen. Bei Hosting Kunden sieht das so aus:
-
Danke euch beiden!
Habe es Mittlerweile mit der Klasse "HTTPRequest" (Quelle: http://php.net/manual/de/function.fopen.php - 3. Kommentar) zum Laufen bekommen. Bei HostEurope scheint der API-Zugriff wie unter https://github.com/churchtools/ctapidemo NICHT zu funktionieren trotz PHP-allow_url_fopen = On. Leider hat mich das mehrere Stunden gekostet
Ich übergebe folgende URL:
https://xxxxxx.church.tools/index.php?q=churchcal/ajax&func=getCalendarEvents&category_ids[]=1&category_ids[]=2&from=0&to=10Usage:
// PHP START
$r = new HTTPRequest($url);
$data=$r->DownloadToString();
$result=json_decode($data);
// PHP ENDEHoffe, das hilft jmd anderem.
-
@samdre
Jetzt scheinst du aber alle Daten als get-Parameter zu übergeben.Solange du über die API nur Daten abfragst, ist das erstmal nicht so kritisch, aber Änderungen solltest du so aber am besten nicht durchführen.
Und auf keinen Fall nen Login durchführen, email und Passwort stehen dann im Klartext im Server-Log und auch jeder auf der Strecke kann dann die Daten mitschneiden (trotz https), und kennt dann deine Zugangsdaten.
Über den Parameter
resource $context
müsstest du die Abfrage-Parameter aber auch als POST übergeben können. -
Habe jetzt nochmal alles erklärt und den Code zur Verfügung gestellt:
http://www.samdre.de/2018/02/05/churchtools-gemeindekalender-via-api-zugriff-holen-sortieren-und-darstellen/ -
Hallo @samdre
Leider funktioniert der Link zu deiner Website nicht mehr. Könntest du uns hier trotzdem deinen Code noch zugänglich machen und zur Verfügung stellen? -
@lmmb
Danke für deinen Hinweis. Der Code ist leider nicht mehr aktuell. Die API wurde angepasst (nur noch POST-Zugriffe), habe aber eine funktionierende Version erstellt, die ich zur Verfügung stellen kann. Schreib mir einfach eine Nachricht an info[~ä#t]dredesign.de (Betreff: ChurchCal), dann können alles abstimmen.