Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nowisesys/uup-ews
Microsoft Exchange Web Service (EWS) Library
https://github.com/nowisesys/uup-ews
ews exchange exchange-web-services
Last synced: 1 day ago
JSON representation
Microsoft Exchange Web Service (EWS) Library
- Host: GitHub
- URL: https://github.com/nowisesys/uup-ews
- Owner: nowisesys
- License: apache-2.0
- Created: 2019-01-23T22:21:22.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-10-15T02:58:50.000Z (about 5 years ago)
- Last Synced: 2024-04-18T17:28:34.129Z (7 months ago)
- Topics: ews, exchange, exchange-web-services
- Language: PHP
- Size: 242 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## 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 Excahnge server.This project is not really maintained (missing usecase) and has only been tested
agains Exchange 2013, but made available in hope of being useful for someone!### Notice:
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:
```bash
for f in services.wsdl messages.xsd types.xsd; do \
curl -v --ntlm --user [email protected] \
https://server.example.com/ews/$f > config/$f
done
```Append service definition at end of config/services.wsdl. Replace server.example.com
with the actual exchange server to provide default host:```xml
```### Update PHP classes:
1. Use the bundled script to generate PHP classes from WSDL. Requires suggested
composer package wsdl2phpgenerator to be installed first:```bash
composer require wsdl2phpgenerator/wsdl2phpgenerator
php bin/generate.php
```2. Download the CLI version of wsdl2phpgenerator, then generate the PHP classes
from the WSDL file in the config directory:```bash
php ~/wsdl2phpgenerator.phar -i config/services.wsdl \
-o source/UUP/Exchange/Types -n "UUP\\Exchange\\Types" \
--noIncludes --constructorNull --createAccessors
```See documentation of wsdl2phpgenerator for more information:
* https://github.com/wsdl2phpgenerator/wsdl2phpgenerator
* https://github.com/wsdl2phpgenerator/wsdl2phpgenerator-cli### Test:
A simple PHP script for testing connection and basic CRUD operations for calendar
events can be found in the bin directory:```bash
php bin/client.php [email protected] --pass=secret \
--host=exchange.example.com \
--find --start="2015-11-25" --end="2015-12-01"
``````bash
php bin/client.php [email protected] --pass=secret \
--host=exchange.example.com \
--add --start="2015-11-25" --end="2015-12-01" \
--title="TEST" --body="Some text..."
``````bash
php bin/client.php [email protected] --pass=secret \
--host=exchange.example.com \
--delete --id="AABCurZhAAA="
```### Reference:
How to: [Create appointments and meetings by using EWS in Exchange 2013](https://msdn.microsoft.com/EN-US/library/office/dn495611%28v=exchg.150%29.aspx)