forked from Azure/azure-sdk-for-java
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
CodeGen from PR 12269 in Azure/azure-rest-api-specs
Merge 0ff28dee45f8a6af50dcc364a955ebc9cd6c349a into 0a67711fb20107d551bf87e8ba9b06d07ce654d5
- Loading branch information
SDKAuto
committed
Jan 4, 2021
1 parent
5af23e5
commit c200aab
Showing
42 changed files
with
5,008 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# Release History | ||
|
||
## 1.0.0-beta.1 (2021-01-04) | ||
|
||
- Azure Resource Manager Healthbot client library for Java. This package contains Microsoft Azure SDK for Healthbot Management SDK. Microsoft Healthcare Bot is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs. Package tag package-2020-12-08. For documentation on how to use this package, please see [Azure Management Libraries for Java](https://aka.ms/azsdk/java/mgmt). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
# Azure Resource Manager Healthbot client library for Java | ||
|
||
Azure Resource Manager Healthbot client library for Java. | ||
|
||
This package contains Microsoft Azure SDK for Healthbot Management SDK. Microsoft Healthcare Bot is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs. Package tag package-2020-12-08. For documentation on how to use this package, please see [Azure Management Libraries for Java](https://aka.ms/azsdk/java/mgmt). | ||
|
||
## Getting started | ||
|
||
### Prerequisites | ||
|
||
- [Java Development Kit (JDK)][jdk] with version 8 or above | ||
- [Azure Subscription][azure_subscription] | ||
|
||
### Adding the package to your product | ||
|
||
[//]: # ({x-version-update-start;com.azure.resourcemanager:azure-resourcemanager-healthbot;current}) | ||
```xml | ||
<dependency> | ||
<groupId>com.azure.resourcemanager</groupId> | ||
<artifactId>azure-resourcemanager-healthbot</artifactId> | ||
<version>1.0.0-beta.1</version> | ||
</dependency> | ||
``` | ||
[//]: # ({x-version-update-end}) | ||
|
||
### Include the recommended packages | ||
|
||
Azure Management Libraries require a `TokenCredential` implementation for authentication and an `HttpClient` implementation for HTTP client. | ||
|
||
[Azure Identity][azure_identity] package and [Azure Core Netty HTTP][azure_core_http_netty] package provide the default implementation. | ||
|
||
### Authentication | ||
|
||
By default, Azure Active Directory token authentication depends on correct configure of following environment variables. | ||
|
||
- `AZURE_CLIENT_ID` for Azure client ID. | ||
- `AZURE_TENANT_ID` for Azure tenant ID. | ||
- `AZURE_CLIENT_SECRET` or `AZURE_CLIENT_CERTIFICATE_PATH` for client secret or client certificate. | ||
|
||
In addition, Azure subscription ID can be configured via environment variable `AZURE_SUBSCRIPTION_ID`. | ||
|
||
With above configuration, `azure` client can be authenticated by following code: | ||
|
||
```java | ||
AzureProfile profile = new AzureProfile(AzureEnvironment.AZURE); | ||
TokenCredential credential = new DefaultAzureCredentialBuilder() | ||
.authorityHost(profile.getEnvironment().getActiveDirectoryEndpoint()) | ||
.build(); | ||
HealthbotManager manager = HealthbotManager | ||
.authenticate(credential, profile); | ||
``` | ||
|
||
The sample code assumes global Azure. Please change `AzureEnvironment.AZURE` variable if otherwise. | ||
|
||
See [Authentication][authenticate] for more options. | ||
|
||
## Key concepts | ||
|
||
See [API design][design] for general introduction on design and key concepts on Azure Management Libraries. | ||
|
||
## Examples | ||
|
||
## Troubleshooting | ||
|
||
## Next steps | ||
|
||
## Contributing | ||
|
||
For details on contributing to this repository, see the [contributing guide](https://github.com/Azure/azure-sdk-for-java/blob/master/CONTRIBUTING.md). | ||
|
||
1. Fork it | ||
1. Create your feature branch (`git checkout -b my-new-feature`) | ||
1. Commit your changes (`git commit -am 'Add some feature'`) | ||
1. Push to the branch (`git push origin my-new-feature`) | ||
1. Create new Pull Request | ||
|
||
<!-- LINKS --> | ||
[jdk]: https://docs.microsoft.com/java/azure/jdk/ | ||
[azure_subscription]: https://azure.microsoft.com/free/ | ||
[azure_identity]: https://github.com/Azure/azure-sdk-for-java/blob/master/sdk/identity/azure-identity | ||
[azure_core_http_netty]: https://github.com/Azure/azure-sdk-for-java/blob/master/sdk/core/azure-core-http-netty | ||
[authenticate]: https://github.com/Azure/azure-sdk-for-java/blob/master/sdk/resourcemanager/docs/AUTH.md | ||
[design]: https://github.com/Azure/azure-sdk-for-java/blob/master/sdk/resourcemanager/docs/DESIGN.md |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
<project xmlns="http://maven.apache.org/POM/4.0.0" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> | ||
<modelVersion>4.0.0</modelVersion> | ||
<parent> | ||
<groupId>com.azure</groupId> | ||
<artifactId>azure-client-sdk-parent</artifactId> | ||
<version>1.7.0</version> <!-- {x-version-update;com.azure:azure-client-sdk-parent;current} --> | ||
<relativePath>../../parents/azure-client-sdk-parent</relativePath> | ||
</parent> | ||
|
||
<groupId>com.azure.resourcemanager</groupId> | ||
<artifactId>azure-resourcemanager-healthbot</artifactId> | ||
<version>1.0.0-beta.1</version> <!-- {x-version-update;com.azure.resourcemanager:azure-resourcemanager-healthbot;current} --> | ||
<packaging>jar</packaging> | ||
|
||
<name>Microsoft Azure SDK for Healthbot Management</name> | ||
<description>This package contains Microsoft Azure SDK for Healthbot Management SDK. Microsoft Healthcare Bot is a cloud platform that empowers developers in Healthcare organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help them improve processes and reduce costs. Package tag package-2020-12-08. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt</description> | ||
<url>https://github.com/Azure/azure-sdk-for-java</url> | ||
|
||
<licenses> | ||
<license> | ||
<name>The MIT License (MIT)</name> | ||
<url>http://opensource.org/licenses/MIT</url> | ||
<distribution>repo</distribution> | ||
</license> | ||
</licenses> | ||
|
||
<scm> | ||
<url>https://github.com/Azure/azure-sdk-for-java</url> | ||
<connection>scm:git:git@github.com:Azure/azure-sdk-for-java.git</connection> | ||
<developerConnection>scm:git:git@github.com:Azure/azure-sdk-for-java.git</developerConnection> | ||
<tag>HEAD</tag> | ||
</scm> | ||
<developers> | ||
<developer> | ||
<id>microsoft</id> | ||
<name>Microsoft</name> | ||
</developer> | ||
</developers> | ||
<properties> | ||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> | ||
<legal><![CDATA[[INFO] Any downloads listed may be third party software. Microsoft grants you no rights for third party software.]]></legal> | ||
</properties> | ||
<dependencies> | ||
<dependency> | ||
<groupId>com.azure</groupId> | ||
<artifactId>azure-core-management</artifactId> | ||
<version>1.0.0</version> <!-- {x-version-update;com.azure:azure-core-management;dependency} --> | ||
</dependency> | ||
</dependencies> | ||
<build> | ||
<plugins> | ||
<plugin> | ||
<groupId>org.jacoco</groupId> | ||
<artifactId>jacoco-maven-plugin</artifactId> | ||
<version>0.8.5</version> <!-- {x-version-update;org.jacoco:jacoco-maven-plugin;external_dependency} --> | ||
<configuration> | ||
<skip>true</skip> | ||
</configuration> | ||
</plugin> | ||
</plugins> | ||
</build> | ||
</project> |
216 changes: 216 additions & 0 deletions
216
...manager-healthbot/src/main/java/com/azure/resourcemanager/healthbot/HealthbotManager.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,216 @@ | ||
// Copyright (c) Microsoft Corporation. All rights reserved. | ||
// Licensed under the MIT License. | ||
// Code generated by Microsoft (R) AutoRest Code Generator. | ||
|
||
package com.azure.resourcemanager.healthbot; | ||
|
||
import com.azure.core.credential.TokenCredential; | ||
import com.azure.core.http.HttpClient; | ||
import com.azure.core.http.HttpPipeline; | ||
import com.azure.core.http.HttpPipelineBuilder; | ||
import com.azure.core.http.policy.AddDatePolicy; | ||
import com.azure.core.http.policy.BearerTokenAuthenticationPolicy; | ||
import com.azure.core.http.policy.HttpLogOptions; | ||
import com.azure.core.http.policy.HttpLoggingPolicy; | ||
import com.azure.core.http.policy.HttpPipelinePolicy; | ||
import com.azure.core.http.policy.HttpPolicyProviders; | ||
import com.azure.core.http.policy.RequestIdPolicy; | ||
import com.azure.core.http.policy.RetryPolicy; | ||
import com.azure.core.http.policy.UserAgentPolicy; | ||
import com.azure.core.management.profile.AzureProfile; | ||
import com.azure.core.util.Configuration; | ||
import com.azure.core.util.logging.ClientLogger; | ||
import com.azure.resourcemanager.healthbot.fluent.Healthbot; | ||
import com.azure.resourcemanager.healthbot.implementation.BotsImpl; | ||
import com.azure.resourcemanager.healthbot.implementation.HealthbotBuilder; | ||
import com.azure.resourcemanager.healthbot.implementation.OperationsImpl; | ||
import com.azure.resourcemanager.healthbot.models.Bots; | ||
import com.azure.resourcemanager.healthbot.models.Operations; | ||
import java.time.Duration; | ||
import java.time.temporal.ChronoUnit; | ||
import java.util.ArrayList; | ||
import java.util.List; | ||
import java.util.Objects; | ||
|
||
/** | ||
* Entry point to HealthbotManager. Microsoft Healthcare Bot is a cloud platform that empowers developers in Healthcare | ||
* organizations to build and deploy their compliant, AI-powered virtual health assistants and health bots, that help | ||
* them improve processes and reduce costs. | ||
*/ | ||
public final class HealthbotManager { | ||
private Bots bots; | ||
|
||
private Operations operations; | ||
|
||
private final Healthbot clientObject; | ||
|
||
private HealthbotManager(HttpPipeline httpPipeline, AzureProfile profile, Duration defaultPollInterval) { | ||
Objects.requireNonNull(httpPipeline, "'httpPipeline' cannot be null."); | ||
Objects.requireNonNull(profile, "'profile' cannot be null."); | ||
this.clientObject = | ||
new HealthbotBuilder() | ||
.pipeline(httpPipeline) | ||
.endpoint(profile.getEnvironment().getResourceManagerEndpoint()) | ||
.subscriptionId(profile.getSubscriptionId()) | ||
.defaultPollInterval(defaultPollInterval) | ||
.buildClient(); | ||
} | ||
|
||
/** | ||
* Creates an instance of Healthbot service API entry point. | ||
* | ||
* @param credential the credential to use. | ||
* @param profile the Azure profile for client. | ||
* @return the Healthbot service API instance. | ||
*/ | ||
public static HealthbotManager authenticate(TokenCredential credential, AzureProfile profile) { | ||
Objects.requireNonNull(credential, "'credential' cannot be null."); | ||
Objects.requireNonNull(profile, "'profile' cannot be null."); | ||
return configure().authenticate(credential, profile); | ||
} | ||
|
||
/** | ||
* Gets a Configurable instance that can be used to create HealthbotManager with optional configuration. | ||
* | ||
* @return the Configurable instance allowing configurations. | ||
*/ | ||
public static Configurable configure() { | ||
return new HealthbotManager.Configurable(); | ||
} | ||
|
||
/** The Configurable allowing configurations to be set. */ | ||
public static final class Configurable { | ||
private final ClientLogger logger = new ClientLogger(Configurable.class); | ||
|
||
private HttpClient httpClient; | ||
private HttpLogOptions httpLogOptions; | ||
private final List<HttpPipelinePolicy> policies = new ArrayList<>(); | ||
private RetryPolicy retryPolicy; | ||
private Duration defaultPollInterval; | ||
|
||
private Configurable() { | ||
} | ||
|
||
/** | ||
* Sets the http client. | ||
* | ||
* @param httpClient the HTTP client. | ||
* @return the configurable object itself. | ||
*/ | ||
public Configurable withHttpClient(HttpClient httpClient) { | ||
this.httpClient = Objects.requireNonNull(httpClient, "'httpClient' cannot be null."); | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the logging options to the HTTP pipeline. | ||
* | ||
* @param httpLogOptions the HTTP log options. | ||
* @return the configurable object itself. | ||
*/ | ||
public Configurable withLogOptions(HttpLogOptions httpLogOptions) { | ||
this.httpLogOptions = Objects.requireNonNull(httpLogOptions, "'httpLogOptions' cannot be null."); | ||
return this; | ||
} | ||
|
||
/** | ||
* Adds the pipeline policy to the HTTP pipeline. | ||
* | ||
* @param policy the HTTP pipeline policy. | ||
* @return the configurable object itself. | ||
*/ | ||
public Configurable withPolicy(HttpPipelinePolicy policy) { | ||
this.policies.add(Objects.requireNonNull(policy, "'policy' cannot be null.")); | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the retry policy to the HTTP pipeline. | ||
* | ||
* @param retryPolicy the HTTP pipeline retry policy. | ||
* @return the configurable object itself. | ||
*/ | ||
public Configurable withRetryPolicy(RetryPolicy retryPolicy) { | ||
this.retryPolicy = Objects.requireNonNull(retryPolicy, "'retryPolicy' cannot be null."); | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the default poll interval, used when service does not provide "Retry-After" header. | ||
* | ||
* @param defaultPollInterval the default poll interval. | ||
* @return the configurable object itself. | ||
*/ | ||
public Configurable withDefaultPollInterval(Duration defaultPollInterval) { | ||
this.defaultPollInterval = Objects.requireNonNull(defaultPollInterval, "'retryPolicy' cannot be null."); | ||
if (this.defaultPollInterval.isNegative()) { | ||
throw logger.logExceptionAsError(new IllegalArgumentException("'httpPipeline' cannot be negative")); | ||
} | ||
return this; | ||
} | ||
|
||
/** | ||
* Creates an instance of Healthbot service API entry point. | ||
* | ||
* @param credential the credential to use. | ||
* @param profile the Azure profile for client. | ||
* @return the Healthbot service API instance. | ||
*/ | ||
public HealthbotManager authenticate(TokenCredential credential, AzureProfile profile) { | ||
Objects.requireNonNull(credential, "'credential' cannot be null."); | ||
Objects.requireNonNull(profile, "'profile' cannot be null."); | ||
|
||
if (retryPolicy == null) { | ||
retryPolicy = new RetryPolicy("Retry-After", ChronoUnit.SECONDS); | ||
} | ||
List<HttpPipelinePolicy> policies = new ArrayList<>(); | ||
policies | ||
.add( | ||
new UserAgentPolicy( | ||
null, | ||
"com.azure.resourcemanager.healthbot", | ||
"1.0.0-beta.1", | ||
Configuration.getGlobalConfiguration())); | ||
policies.add(new RequestIdPolicy()); | ||
HttpPolicyProviders.addBeforeRetryPolicies(policies); | ||
policies.add(retryPolicy); | ||
policies.add(new AddDatePolicy()); | ||
policies | ||
.add( | ||
new BearerTokenAuthenticationPolicy( | ||
credential, profile.getEnvironment().getManagementEndpoint() + "/.default")); | ||
HttpPolicyProviders.addAfterRetryPolicies(policies); | ||
policies.add(new HttpLoggingPolicy(httpLogOptions)); | ||
HttpPipeline httpPipeline = | ||
new HttpPipelineBuilder() | ||
.httpClient(httpClient) | ||
.policies(policies.toArray(new HttpPipelinePolicy[0])) | ||
.build(); | ||
return new HealthbotManager(httpPipeline, profile, defaultPollInterval); | ||
} | ||
} | ||
|
||
/** @return Resource collection API of Bots. */ | ||
public Bots bots() { | ||
if (this.bots == null) { | ||
this.bots = new BotsImpl(clientObject.getBots(), this); | ||
} | ||
return bots; | ||
} | ||
|
||
/** @return Resource collection API of Operations. */ | ||
public Operations operations() { | ||
if (this.operations == null) { | ||
this.operations = new OperationsImpl(clientObject.getOperations(), this); | ||
} | ||
return operations; | ||
} | ||
|
||
/** | ||
* @return Wrapped service client Healthbot providing direct access to the underlying auto-generated API | ||
* implementation, based on Azure REST API. | ||
*/ | ||
public Healthbot serviceClient() { | ||
return this.clientObject; | ||
} | ||
} |
Oops, something went wrong.