Info |
---|
Deze pagina is nog niet af! |
...
Met behulp van de cloudplan webservice kunt u gegevens uit cloudplan ophalen en wegschrijven. De webservice wisselt gegevens uit via SOAP en XML. Hierbij valt te denken aan o.a.:
- projectgegevens
- personeelgegevens
- relatiegegevens
- planning
Wat u precies kunt aanroepen van de webservice is te zien op de overzichtspagina van de webservice, beschikbaar op https://api.cloudplan.nl/v1/. Gegevens naar Cloudplan sturen kunt u doen mbv een 'Push' en ophalen met een 'Get'. Hiervoor dient u wel een authenticatietoken mee te sturen. Deze kunt u opvragen in de authenticatie webservice mbv uw gebruikersnaam en wachtwoord.
2. Voorbeeld
Om het voorbeeld uit te kunnen voeren heeft u een gebruikersnaam & wachtwoord nodig voor de webservice. Neem hiervoor contact op met Planning.nl
Klik hieronder om het voorbeeld, geschreven in powershell, te downloaden en te bekijken.
In de voorbeelden kunt u zien hoe:
- de authenticatie werkt en hoe u een authenticatietoken ophaalt
- alle personeelsleden uit Cloudplan ophaalt
- een nieuw personeelslid toevoegt
- gegevens van een bestaand personeelslid wijzigt
3. SoapUI
Op de overzichtspagina is ook een link naar de WSDL te vinden die u nodig heeft als u wilt experimenteren met bijvoorbeeld SoapUI. Iedere service heeft zijn eigen WSDL. Voor de authenticatieservice is dit bijvoorbeeld https://api.cloudplan.nl/v1/authentication?wsdl
SoapUI kan automatisch voorbeeldrequests voor u genereren aan de hand van de WSDL, en kunt u op eenvoudige wijze experimenteren. De open source versie is gratis en beschikbaar op https://www.soapui.org/open-source.html
4. Structuur
4.1 Requests (informatie opvragen)
De request voor het opvragen van informatie bestaat uit de authenticatie token en één of meerdere matchers.
4.2 Matchers
Elke matcher heeft een attribuut allowMultiple. Als deze is ingesteld op false, maar de matcher levert wel meerdere resultaten op, dan zal er een foutmelding worden teruggestuurd.
Binnen een matcher zijn diverse elementen beschikbaar om op te zoeken. Sommige elementen hoeven niet gespecificeerd te worden. Deze zijn te herkennen aan het Optional commentaar boven de tag. Vanwege de structuur van Cloudplan kan het ook mogelijk zijn dat één van twee elementen gespecificeerd moet worden. Dit is te herkennen aan het You have a CHOICE of the next 2 items at this level commentaar boven de tag.
4.3 Foutmeldingen
Als een bepaalde matcher tot een fout leidt, wordt er een error teruggestuurd. Binnen deze error is de matcher gespecificeerd samen met de melding.
Error
4.4 ResourceClass
Om bij resources onderscheid te kunnen maken tussen de verschillende types, moet de ResourceClass worden opgegeven. De mogelijke waarden zijn:
- PERSONNEL
- ENTITY1
- ENTITY2
4.5 ResourceSymbol
Resources bevatten een veld voor een symbool. Voor meer informatie zie de stamgegevens voor personeel en entiteiten. De mogelijke waarden zijn:
- NONE
- CIRCLE
- RIGHT
- LEFT
- UP
- DOWN
- SQUARE
- STAR
- SPADE
- CLUB
- HEART
- DIAMOND
- TELEPHONE
- SUN
- CLOUD
- UMBRELLA
4.6 Datum matcher
Een datum matcher bestaat uit een operator en een datum. Als er een datetime type gevraagd wordt, maar er is alleen een datum opgegeven, dan wordt de tijd op 00:00:00 gezet. De mogelijke operatoren zijn:
- EQUALS_TIME
- EQUALS_DATE
- AFTER_OR_EQUAL_TIME
- AFTER_OR_EQUAL_DATE
- AFTER_TIME
- AFTER_DATE
- BEFORE_OR_EQUAL_TIME
- BEFORE_OR_EQUAL_DATE
- BEFORE_TIME
- BEFORE_DATE
5. Foutafhandeling
Als de server niet bereikbaar is of als deze de opgestuurde informatie niet kan verwerken, kunt u verschillende antwoorden verwachten.
- Een socket timeout als de webserver om welke reden dan ook niet reageert
- Een HTTP 404 error (Page not found), als de webservice bv tijdelijk offline is voor onderhoud
- Een HTTP 500 error (Internal Server Error). Dit kan voorkomen als er op de server een fout optreedt bij het verwerken van de opgestuurde gegevens.
Soap faults (bijvoorbeeld als er syntax fouten zitten in de opgestuurde XML):
Soap fault: unmarshalling error
...
<error> blok in de response, bijvoorbeeld als de authenticatie token verlopen
...
of als een loginpoging is mislukt
...
Of als het toevoegen van gegevens mislukt, bijvoorbeeld als je niet genoeg gegevens aanlevert voor bij het opslaan (Push) van een project.
...
Child pages | ||
---|---|---|
|