UUP-EWS - Microsoft Exchange Web Service (EWS) Library
SOAP client library for communication with the EWS. Most code is auto-generated from the WSDL/XSD downloaded from the Exchange server.
This project is not really maintained (missing usecase) and has only been tested against Exchange 2013, but made available in hope of being useful for someone!
The WSDL and XSD-files bundled in config directory might need to be replaced to match the exchange server running in your organization. When updating WSDL, remember to also re-generate the PHP classes in source/UUP/Exchange/Types
Update WSDL/XSD files:
Download service, message and types definitions from the exchange server by running:
curl -v --ntlm --user email@example.com \
https://server.example.com/ews/$f > config/$f \
Append service definition at end of config/services.wsdl. Replace server.example.com with the actual exchange server to provide default host:
<wsdl:service name="ExchangeServices"> <wsdl:port name="ExchangeServicePort" binding="tns:ExchangeServiceBinding"> <soap:address location="https://server.example.com/ews/exchange.asmx" /> </wsdl:port> </wsdl:service>
Update PHP classes:
Use the bundled script to generate PHP classes from WSDL. Requires suggested composer package wsdl2phpgenerator to be installed first:
Download the CLI version of wsdl2phpgenerator, then generate the PHP classes from the WSDL file in the config directory:
-o source/UUP/Exchange/Types -n "UUP\\Exchange\\Types" \
--noIncludes --constructorNull --createAccessors
See documentation of wsdl2phpgenerator for more information:
A simple PHP script for testing connection and basic CRUD operations for calendar events can be found in the bin directory:
--find --start="2015-11-25" --end="2015-12-01"
--add --start="2015-11-25" --end="2015-12-01" \
--title="TEST" --body="Some text..."