# msgraph-sdk-java **Repository Path**: droideep/msgraph-sdk-java ## Basic Information - **Project Name**: msgraph-sdk-java - **Description**: No description available - **Primary Language**: Java - **License**: MIT - **Default Branch**: bugfix/content-type-header-casing - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2021-06-30 - **Last Updated**: 2021-06-30 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Microsoft Graph SDK for Java [![Download](https://api.bintray.com/packages/microsoftgraph/Maven/microsoft-graph/images/download.svg)](https://bintray.com/microsoftgraph/Maven/microsoft-graph/_latestVersion) Get started with the Microsoft Graph SDK for Java by integrating the [Microsoft Graph API](https://developer.microsoft.com/en-us/graph/get-started/java) into your Java application! > **Note:** this SDK allows you to build applications using the [v1.0](https://docs.microsoft.com/en-us/graph/use-the-api#version) of Microsoft Graph. If you want to try the latest Microsoft Graph APIs under beta, use our [beta SDK](https://github.com/microsoftgraph/msgraph-beta-sdk-java) instead. ## 1. Installation ### 1.1 Install via Gradle Add the repository and a compile dependency for `microsoft-graph` to your project's `build.gradle`: ```gradle repositories { jcenter() } dependencies { // Include the sdk as a dependency implementation 'com.microsoft.graph:microsoft-graph:2.6.0' } ``` ### 1.2 Install via Maven Add the dependency in `dependencies` in pom.xml ```xml com.microsoft.graph microsoft-graph 2.6.0 ``` ### 1.3 Enable ProGuard (Android) The nature of the Graph API is such that the SDK needs quite a large set of classes to describe its functionality. You need to ensure that [ProGuard](https://developer.android.com/studio/build/shrink-code.html) is enabled on your project. Otherwise, you will incur long build times for functionality that is not necessarily relevant to your particular application. If you are still hitting the 64K method limit, you can also enable [multidexing](https://developer.android.com/studio/build/multidex.html). Checkout the [recommended rules](./docs/proguard-rules.txt). ## 2. Getting started ### 2.1 Register your application Register your application by following the steps at [Register your app with the Azure AD v2.0 endpoint](https://developer.microsoft.com/en-us/graph/docs/concepts/auth_register_app_v2). ### 2.2 Create an IAuthenticationProvider object An instance of the **GraphServiceClient** class handles building requests, sending them to the Microsoft Graph API, and processing the responses. To create a new instance of this class, you need to provide an instance of `IAuthenticationProvider`, which can authenticate requests to Microsoft Graph. For an example of authentication in a Java desktop client or server application, see the [Preview msgraph-sdk-java-auth](https://github.com/microsoftgraph/msgraph-sdk-java-auth) and for an Android application see [Preview msgraph-sdk-android-auth](https://github.com/microsoftgraph/msgraph-sdk-android-auth). ### 2.3 Get a GraphServiceClient object After you have set the correct application ID and URL, you must get a **GraphServiceClient** object to make requests against the service. The SDK stores the account information for you, but when a user signs in for the first time, it invokes the UI to get the user's account information. ```java IGraphServiceClient graphClient = GraphServiceClient .builder() .authenticationProvider(authenticationProvider) .buildClient(); ``` ## 3. Make requests against the service After you have a GraphServiceClient that is authenticated, you can begin making calls against the service. The requests against the service look like our [REST API](https://developer.microsoft.com/en-us/graph/docs/concepts/overview). ### 3.1 Get the user's drive To retrieve the user's drive: ```java graphClient .me() .drive() .buildRequest() .get(new ICallback() { @Override public void success(final Drive result) { System.out.println("Found Drive " + result.id); } ... // Handle failure case }); ``` ## 4. Documentation For more detailed documentation, see: * [Overview](https://docs.microsoft.com/graph/overview) * [Collections](https://docs.microsoft.com/graph/sdks/paging) * [Making requests](https://docs.microsoft.com/graph/sdks/create-requests) * [Known issues](https://github.com/MicrosoftGraph/msgraph-sdk-java/issues) * [Contributions](https://github.com/microsoftgraph/msgraph-sdk-java/blob/master/CONTRIBUTING.md) ## 5. Issues For known issues, see [issues](https://github.com/MicrosoftGraph/msgraph-sdk-java/issues). ## 6. Contributions The Microsoft Graph SDK is open for contribution. To contribute to this project, see [Contributing](https://github.com/microsoftgraph/msgraph-sdk-java/blob/master/CONTRIBUTING.md). ## 7. Supported Java versions The Microsoft Graph SDK for Java library is supported at runtime for Java 7+ and [Android API revision 15](http://source.android.com/source/build-numbers.html) and greater. ## 8. License Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the [MIT license](LICENSE). ## 9. Third-party notices [Third-party notices](THIRD%20PARTY%20NOTICES)