Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Storage identity remove resource manager provider #15837

Closed
Changes from 6 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
03f8ab4
In progress
mnriem Aug 5, 2020
7266ac5
Throw an exception when configuration is incomplete
mnriem Aug 6, 2020
0de9b40
Added class level JavaDoc
mnriem Aug 6, 2020
3964b68
Resolve POM conflict
mnriem Aug 6, 2020
9fb49ba
Added unit tests
mnriem Aug 6, 2020
9acd2b9
Merge branch 'credential-helper' of https://github.com/mnriem/azure-s…
yevster Aug 12, 2020
bedcf50
Changing the Identity Helper into a builder
yevster Aug 13, 2020
9ad8a79
Adding storage resource sample, autoconfiguration for blob storage wi…
yevster Aug 15, 2020
f9adbe0
Attempting to generate an endpoint string
yevster Aug 17, 2020
9cac0d3
Provisional workaround for using IdentityToken in Shared service conn…
yevster Aug 21, 2020
c2bbb46
Merge branch 'master' into storage-identity
yevster Aug 22, 2020
41f32fa
In progress
mnriem Aug 5, 2020
8c1297b
Throw an exception when configuration is incomplete
mnriem Aug 6, 2020
f0322af
Added class level JavaDoc
mnriem Aug 6, 2020
8a6385c
Resolve POM conflict
mnriem Aug 6, 2020
9305ee1
Added unit tests
mnriem Aug 6, 2020
92fd3dd
Changing the Identity Helper into a builder
yevster Aug 13, 2020
06d8aa9
Adding storage resource sample, autoconfiguration for blob storage wi…
yevster Aug 15, 2020
723e463
Attempting to generate an endpoint string
yevster Aug 17, 2020
62c5533
Provisional workaround for using IdentityToken in Shared service conn…
yevster Aug 21, 2020
b96c739
Merge branch 'storage-identity' of github.com:yevster/azure-sdk-for-j…
yevster Sep 14, 2020
3f7e8ac
XML syntax fix
yevster Sep 14, 2020
670e4a2
Storage resource demo works
yevster Sep 17, 2020
cfef365
Removing tight Resource Manager Provider coupling
yevster Sep 30, 2020
f7f9414
Merge branch 'master' into storage-identity-remove-resource-manager-p…
yevster Oct 2, 2020
9662b85
Fixing autoconfiguration for legacy resource management to not kick i…
yevster Oct 3, 2020
6f780a9
Merge branch 'master' into storage-identity-remove-resource-manager-p…
yevster Oct 8, 2020
ef3f807
Resource demo works with file legacy file credentail'
yevster Oct 15, 2020
525c5b4
Resource sample works with environment parameters
yevster Oct 15, 2020
7d7adb1
Removing debugging code
yevster Oct 15, 2020
80a9e20
Fixing SPEL expression to omit legacy auto-config when using Spring e…
yevster Oct 15, 2020
9277d71
checkstyle appeasement
yevster Oct 17, 2020
e4608d5
Checktyle appeasement, version fixing
yevster Oct 19, 2020
42d5e50
Adding mock token credentail to Actuator test config to ward off unea…
yevster Oct 20, 2020
29beabc
Adding mock token credentail to Actuator test config to ward off unea…
yevster Oct 21, 2020
969353e
Removing topic manager dependency from queue autoconfig
yevster Oct 22, 2020
bbc811e
Fixing autoconfig dependencies for Topic binders
yevster Oct 22, 2020
01b1378
Fixing startup failure when namespace is provided instead of connection
yevster Oct 28, 2020
cc74b40
Updating to incorporate upstream library signature changes
yevster Oct 28, 2020
cdb5ed4
Merge branch 'master' into storage-identity-remove-resource-manager-p…
saragluna Oct 28, 2020
bccd6e2
include version tag should be on the same line
saragluna Oct 28, 2020
9a206f1
Spring Cloud Stream - Event Hub binder demo now works
yevster Oct 28, 2020
f19af87
merging with master
yevster Oct 29, 2020
7bec935
Fixing build failures
yevster Oct 29, 2020
456d383
Preventing reliance on resource management bean when resource group
yevster Oct 30, 2020
9b1792b
Merge branch 'master' into storage-identity-remove-resource-manager-p…
yevster Oct 30, 2020
fcb8bc8
Fixing NPE in auto-configuration
yevster Oct 30, 2020
a6cfcfe
Fixing NPE in auto-configuration
yevster Oct 30, 2020
8277c89
Fixing package names broken in merge
yevster Oct 30, 2020
005e67f
Checkstyle appeasement
yevster Oct 30, 2020
552af0c
Checkstyle appeasement
yevster Oct 30, 2020
2456b26
Merge branch 'context-config-npe-fix' into storage-identity-remove-re…
yevster Oct 30, 2020
8558375
Eliminating ServiceBus ARM dependency when not pulled in thorugh sett…
yevster Oct 31, 2020
dde0594
Deleting duplicate sample
yevster Oct 31, 2020
2a7d5a3
Removing module for superfluous storage resource demeo
yevster Nov 2, 2020
5531c84
Fixing parent pom of identity library
yevster Nov 2, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
69 changes: 69 additions & 0 deletions sdk/spring/azure-identity-spring-library/pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.azure</groupId>
<artifactId>azure-spring-boot-service</artifactId>
<version>1.0.0</version>
</parent>
<artifactId>azure-identity-spring-library</artifactId>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggest change the artifact id to azure-identity-spring

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@mnriem, any objection to eliminating the Spring Environment identity library entirely and moving this functionality to the azure-spring-cloud-context module?

<version>1.0.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>Azure Identity Spring Integration Library</name>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>3.0.0-M5</version>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>com.azure</groupId>
<artifactId>azure-identity</artifactId>
<version>1.0.9</version>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-api</artifactId>
<version>5.6.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-params</artifactId>
<version>5.6.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-engine</artifactId>
<version>5.6.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<scope>test</scope>
<version>4.13</version>
</dependency>
</dependencies>
</project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,184 @@
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.microsoft.azure.identity.spring;

import com.azure.core.credential.TokenCredential;
import com.azure.identity.ClientCertificateCredentialBuilder;
import com.azure.identity.ClientSecretCredentialBuilder;
import com.azure.identity.DefaultAzureCredentialBuilder;
import java.util.HashMap;
import org.springframework.core.env.Environment;
import org.springframework.stereotype.Component;

/**
* A helper class to deal with credentials in a Spring environment.
*
* <p>
* This helper class makes it possible to configure credentials to be used
* within a Spring context.
* </p>
*
* <table>
* <tr>
* <th>Property Tuples</th>
* <th>Description</th>
* </tr>
* <tr>
* <td>
* azure.credential.(name.)tenantId <br>
* azure.credential.(name.)clientId <br>
* azure.credential.(name.)clientSecret
* </td>
* <td>
* the Azure Tenant ID <br>
* the Client ID <br>
* the Client Certificate <br>
* </td>
* </tr>
* <tr>
* <td>
* azure.credential.(name.)tenantId <br>
* azure.credential.(name.)clientId <br>
* azure.credential.(name.)clientCertificate
* </td>
* <td>
* the Azure Tenant ID <br>
* the Client ID <br>
* the path to the PEM client certificate
* </td>
* </tr>
* </table>
*
* where name is the <code>name</code> of the credential. Note if
* <code>name</code> is entirely omitted it is taken to be the default
* credential. Note if the default credential is omitted it is configure to use
* AzureDefaultCredential which allows for the use a Managed Identity (if it is
* present).
*
* @author manfred.riem@microsoft.com
*/
@Component
public class AzureIdentitySpringHelper {

/**
* Defines the AZURE_CREDENTIAL_PREFIX.
*/
private static final String AZURE_CREDENTIAL_PREFIX = "azure.credential.";

/**
* Stores the named credentials.
*/
private final HashMap<String, TokenCredential> credentials;

/**
* Constructor.
*/
public AzureIdentitySpringHelper() {
credentials = new HashMap<>();
credentials.put("", new DefaultAzureCredentialBuilder().build());
}

/**
* Add a named credential.
*
* @param name the name.
* @param credential the credential.
*/
public void addNamedCredential(String name, TokenCredential credential) {
credentials.put(name, credential);
}

/**
* Get the default Azure credential.
*
* @return the default Azure credential
*/
public TokenCredential getDefaultCredential() {
return credentials.get("");
}

/**
* Get the named credential.
*
* @param name the name.
* @return the named credential, or null if not found.
*/
public TokenCredential getNamedCredential(String name) {
return credentials.get(name);
}

/**
* Populate from Environment.
*
* @param environment the environment.
*/
public void populate(Environment environment) {
populateNamedCredential(environment, "");
String credentialNamesKey = AZURE_CREDENTIAL_PREFIX + "names";
if (environment.containsProperty(credentialNamesKey)) {
String[] credentialNames = environment.getProperty(credentialNamesKey).split(",");
for(int i=0; i<credentialNames.length; i++) {
populateNamedCredential(environment, credentialNames[i]);
}
}
}

/**
* Populate a named credential.
*
* @param environment the environment
* @param name the name.
*/
private void populateNamedCredential(Environment environment, String name) {
String standardizedName = name;

if (!standardizedName.equals("") && !standardizedName.endsWith(".")) {
standardizedName = standardizedName + ".";
}

String tenantIdKey = AZURE_CREDENTIAL_PREFIX + standardizedName + "tenantId";
String clientIdKey = AZURE_CREDENTIAL_PREFIX + standardizedName + "clientId";
String clientSecretKey = AZURE_CREDENTIAL_PREFIX + standardizedName + "clientSecret";

String tenantId = environment.getProperty(tenantIdKey);
String clientId = environment.getProperty(clientIdKey);
String clientSecret = environment.getProperty(clientSecretKey);

if (tenantId != null && clientId != null && clientSecret != null) {
TokenCredential credential = new ClientSecretCredentialBuilder()
.tenantId(tenantId)
.clientId(clientId)
.clientSecret(clientSecret)
.build();
credentials.put(name, credential);
return;
}

String clientCertificateKey = AZURE_CREDENTIAL_PREFIX + standardizedName + "clientCertificate";
String clientCertificatePath = environment.getProperty(clientCertificateKey);

if (tenantId != null && clientId != null && clientCertificatePath != null) {
TokenCredential credential = new ClientCertificateCredentialBuilder()
.tenantId(tenantId)
.clientId(clientId)
.pemCertificate(clientCertificatePath)
.build();
credentials.put(name, credential);
return;
}

if (!name.equals("")) {
throw new RuntimeException("Configuration for azure.credential." + name + " is incomplete");
}
}

/**
* Remove the named credential.
*
* @param name the name.
* @return the removed named credential, or null if not found.
*/
public TokenCredential removeNamedCredential(String name) {
return credentials.remove(name);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.microsoft.azure.identity.spring;

import com.azure.identity.ClientSecretCredential;
import com.azure.identity.DefaultAzureCredential;
import com.azure.identity.DefaultAzureCredentialBuilder;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertNull;
import static org.junit.jupiter.api.Assertions.assertTrue;
import static org.junit.jupiter.api.Assertions.fail;
import org.junit.jupiter.api.Test;
import org.springframework.core.env.StandardEnvironment;

/**
* The unit tests for the AzureIdentitySpringHelper class.
*
* @author manfred.riem@microsoft.com
*/
public class AzureIdentitySpringHelperTest {

/**
* Test addNamedCredential method.
*/
@Test
public void testAddNamedCredential() {
DefaultAzureCredential credential = new DefaultAzureCredentialBuilder().build();
AzureIdentitySpringHelper helper = new AzureIdentitySpringHelper();
helper.addNamedCredential("cred1", credential);
assertNotNull(helper.getNamedCredential("cred1"));
helper.removeNamedCredential("cred1");
assertNull(helper.getNamedCredential("cred1"));
}

/**
* Test getDefaultCredential method.
*/
@Test
public void testGetDefaultCredential() {
AzureIdentitySpringHelper helper = new AzureIdentitySpringHelper();
assertNotNull(helper.getDefaultCredential());
}

/**
* Test populate method.
*/
@Test
public void testPopulate() {
System.setProperty("azure.credential.names", "");
System.setProperty("azure.credential.tenantId", "tenantId");
System.setProperty("azure.credential.clientId", "clientId");
System.setProperty("azure.credential.clientSecret", "clientSecret");
StandardEnvironment environment = new StandardEnvironment();
AzureIdentitySpringHelper helper = new AzureIdentitySpringHelper();
helper.populate(environment);
assertNotNull(helper.getDefaultCredential());
assertTrue(helper.getDefaultCredential() instanceof ClientSecretCredential);
}

/**
* Test populate method.
*/
@Test
public void testPopulate2() {
System.setProperty("azure.credential.names", "myname");
System.setProperty("azure.credential.myname.tenantId", "tenantId");
System.setProperty("azure.credential.myname.clientId", "clientId");
System.setProperty("azure.credential.myname.clientSecret", "clientSecret");
StandardEnvironment environment = new StandardEnvironment();
AzureIdentitySpringHelper helper = new AzureIdentitySpringHelper();
helper.populate(environment);
assertNotNull(helper.getNamedCredential("myname"));
assertTrue(helper.getNamedCredential("myname") instanceof ClientSecretCredential);
}

/**
* Test populate method.
*/
@Test
public void testPopulate3() {
System.setProperty("azure.credential.names", "myname2");
System.setProperty("azure.credential.myname2.tenantId", "tenantId");
System.setProperty("azure.credential.myname2.clientSecret", "clientSecret");
StandardEnvironment environment = new StandardEnvironment();
AzureIdentitySpringHelper helper = new AzureIdentitySpringHelper();
try {
helper.populate(environment);
fail();
} catch(RuntimeException re) {
}
}
}
1 change: 1 addition & 0 deletions sdk/spring/pom.xml
Original file line number Diff line number Diff line change
@@ -9,6 +9,7 @@
<packaging>pom</packaging>
<version>1.0.0</version><!-- Need not change for every release-->
<modules>
<module>azure-identity-spring-library</module>
<module>azure-spring-boot</module>
<module>azure-spring-boot-starter</module>
<module>azure-spring-boot-starter-active-directory</module>