To install the microsoft-graph-core
library with Composer, either run composer require microsoft/microsoft-graph-core
, or edit your composer.json
file:
{
"require": {
// x-release-please-start-version
"microsoft/microsoft-graph-core": "^2.2.1"
// x-release-please-end
}
}
Register your application to use the Microsoft Graph API by following the steps at Register an application with the Microsoft Identity platform.
The Microsoft Graph Core SDK for PHP does not include any default authentication implementations. The thephpleague/oauth2-client
library will handle the OAuth2 flow for you and provide a usable token for querying the Graph.
To authenticate as an application, please see this guide to configure the right permissions.
You can use the Guzzle HTTP client, which comes preinstalled with this library, to get an access token like this:
$tokenRequestContext = new ClientCredentialContext(
'tenantId',
'clientId',
'clientSecret'
);
// requests using https://graph.microsoft.com/.default scopes by default
$tokenProvider = new GraphPhpLeagueAccessTokenProvider($tokenRequestContext);
$token = $tokenProvider->getAuthorizationTokenAsync(GraphConstants::REST_ENDPOINT)->wait();
You can create a Guzzle HTTP client object pre-configured for use with the Graph API using our GraphClientFactory
. The GraphClientFactory
sets some Guzzle config defaults such as connection and request timeouts, and the base_uri
to your preferred National Cloud endpoint.
In the near future, the GraphClientFactory
will provide some default middleware to use with the Graph API such as retry handlers.
use Microsoft\Graph\Core\GraphClientFactory;
$guzzleConfig = [
// your preferred guzzle config
];
$httpClient = GraphClientFactory::createWithConfig($guzzleConfig);
The following is an example that shows how to call Microsoft Graph.
use Microsoft\Graph\Core\GraphClientFactory;
class UsageExample
{
public function run()
{
$accessToken = 'xxx';
$config = [
'headers' => [
'Authorization' => $accessToken
]
];
$httpClient = GraphClientFactory::createWithConfig($config);
$response = $httpClient->get("/v1.0/me");
$currentUser = json_decode($response->getBody());
echo "Hello, I am {$currentUser['givenName']}";
}
}
We provide Microsoft Graph models for easy serialization and deserialization.
If you would like to leverage the models we provide, please take a look at the Microsoft Graph PHP SDK and for beta models - the Microsoft Graph Beta PHP SDK.
Run
vendor/bin/phpunit
from the base directory.
This SDK has an XDebug run configuration that attaches the debugger to VS Code so that you can debug tests.
- Install the PHP Debug extension into Visual Studio Code.
- From the root of this repo, using PowerShell, run
php .\tests\GetPhpInfo.php | clip
from the repo root. This will copy PHP configuration information into the clipboard which we will use in the next step. - Paste your clipboard into the XDebug Installation Wizard and select Analyse my phpinfo() output.
- Follow the generated instructions for installing XDebug. Note that the
/ext
directory is located in your PHP directory. - Add the following info to your php.ini file:
[XDebug]
xdebug.remote_enable = 1
xdebug.remote_autostart = 1
Now you can hit a Visual Studio Code breakpoint in a test. Try this:
- Add a breakpoint to
testCreateWithConfigCreatesClient
in .\tests\Http\GraphClientFactoryTest.php. - Run the Listen for XDebug configuration in VS Code.
- Run
.\vendor\bin\phpunit --filter testCreateWithConfigCreatesClient
from the PowerShell terminal to run the test and hit the breakpoint.
View or log issues on the Issues tab in the repo.
Please read our Contributing guidelines carefully for advice on how to contribute to this repo.
Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the MIT license.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.