alexacrm / dynamics-webapi-toolkit
Web API toolkit for Microsoft Dynamics 365 and Dynamics CRM
Installs: 234 621
Dependents: 1
Suggesters: 0
Security: 0
Stars: 78
Watchers: 8
Forks: 58
Open Issues: 13
Requires
- php: ^8.0
- alexacrm/strong-serializer: ^2.0
- elao/enum: ^1.6
- guzzlehttp/guzzle: ^6.5 || ^7.0
- psr/cache: ^2.0 || ^3.0
- psr/log: ^2.0 || ^3.0
Requires (Dev)
- phpunit/phpunit: ^8.5.30 || ^9.5
This package is auto-updated.
Last update: 2025-01-03 13:58:15 UTC
README
The Dynamics Web API Toolkit provides an easy-to-use PHP wrapper for the Dynamics 365 Customer Engagement Web API.
Create, read, update and delete CRM records easily via the IOrganizationService - compatible interface, as well as execute Web API actions and functions.
See the tutorial for the sample code to instantiate the connection, create, retrieve, update and delete records.
This toolkit supports only Dynamics 365 Web API. For PHP implementation of the Dynamics 365 SOAP interface, see php-crm-toolkit project.
Features & Limitations
The current release of the library does not support the following features (supported features and scenarios are mentioned along the way):
- Authentication support for IFD and On-Premises (AD) deployments. Support for IFD (Internet Facing Deployment) is on the roadmap, On-Premises deployments (using AD) are under consideration.
- Execute method of IOrganizationService interface is not supported yet. Means for executing functions and actions, both bound and unbound, are provided though.
- Batch requests are not supported yet. That means, associating/disassociating multiple records is executed in multiple separate requests which may affect the performance.
- Organization metadata (entities and attributes, global option sets, etc.) is not supported yet, although can be retrieved manually via the built-in OData helper client or via the HTTP client.
- Most of the record attribute values are returned as-is from Web API. That means, at this point you must expect integers in place of OptionSetValue objects for picklist values, Status/State attributes, booleans for "Two Options" attributes, and floats for decimal and Money attributes. Lookup attribute values are rendered as EntityReference objects. The same applies when you set values in the Entity, including EntityReferences. This is likely to change once organization metadata is integrated into the toolkit.
Getting Started
Prerequisites
The main requirement is PHP 7.4 or later. cURL is recommended but is not required. Composer is required to install the toolkit and its dependencies.
Installing
$ composer require alexacrm/dynamics-webapi-toolkit:dev-master
Consuming
See the Tutorial to learn how to consume the library.
Development
The version compatible with PHP 8.2 and above is now available as v4.x-dev
. Please note that this version is still under development, and its use is at your own risk. You can install it with the following command:
$ composer require alexacrm/dynamics-webapi-toolkit:v4.x-dev
Built With
- David Yack's Xrm.Tools.CRMWebAPI - some code was borrowed as OData helper code
- Guzzle - an extensible PHP HTTP client
Versioning
Toolkit uses SemVer for versioning.
License
This project is licensed under the MIT License - see the LICENSE file for details.