Source code | Package (Maven) | Product documentation | Samples
- Added support for loading Feature Variants from Azure App Configuration. #38293
- Added support for Azure App Configuration Snapshots. Snapshots can be loaded by setting
spring.cloud.azure.appconfiguration.stores[0].snapshot-name
to the snapshot name. Snapshots can be created using the Azure CLI or the Azure Portal. See here for more information on snapshots. #7598 - Added support for trimming prefixes from keys,the default value is the key-filter when key-filter is used. The configuration is
spring.cloud.azure.appconfiguration.stores[0].trim-key-prefix
andspring.cloud.azure.appconfiguration.stores[0].trim-key-prefixes
.
- Added support for Azure App Configuration Snapshots. Snapshots can be loaded by setting
spring.cloud.azure.appconfiguration.stores[0].snapshot-name
to the snapshot name. Snapshots can be created using the Azure CLI or the Azure Portal. See here for more information on snapshots. #7598 - Added support for trimming prefixes from keys,the default value is the key-filter when key-filter is used. The configuration is
spring.cloud.azure.appconfiguration.stores[0].trim-key-prefix
andspring.cloud.azure.appconfiguration.stores[0].trim-key-prefixes
.
- Fixed a bug where Web Hook authorization was validated incorrectly, resulting in an Unauthorized error #37141.
- Fixed a bug where Web Hook authorization was validated incorrectly, resulting in an Unauthorized error#37141.
- Fixed a bug where where credentials from Azure Spring global properties were being ignored #34694.
- Fixed a bug where a
NullPointerException
exception was thrown when Azure App Configuration returned an Exception #35086.
- Fixed a bug where where credentials from Azure Spring global properties were being ignored #34694.
- Fixed a bug where a
NullPointerException
exception was thrown when Azure App Configuration returned an Exception #35086.
- Added support for Azure Spring common configuration properties.
- Added failover support for App Configuration stores with geo-replication enabled. Configuration is done through the
spring.cloud.azure.appconfiguration.stores[0].endpoints
property orspring.cloud.azure.appconfiguration.stores[0].connection-strings
, where a list of endpoints/connection-strings can be provided. The endpoints/connection-strings will be attempted to connect in priority order. - Feature Flags can now be selected using a key and label filter, instead of just a label filter. The configurations are now
spring.cloud.azure.appconfiguration.stores[0].feature-flags.selects[0].key-filter
andspring.cloud.azure.appconfiguration.stores[0].feature-flags.selects[0].label-filter
.
- Libraries and namespaces have been renamed to
spring-cloud-azure-appconfiguration-config
andcom.azure.spring.cloud.appconfiguration.config
. - Renamed
ConfigurationClientBuilderSetup
toConfigurationClientCustomizer
. - Renamed
SecretClientBuilderSetup
toSecretClientCustomizer
. - Removed
AppConfigurationCredentialProvider
andKeyVaultCredentialProvider
, instead you can use Azure Spring common configuration properties or modify the credentials usingConfigurationClientCustomizer
/SecretClientCustomizer
. - Feature Flags are now merged when loaded from multiple stores, if duplicate keys are found the highest priority store wins.
- Updated to newer versions of dependencies. Spring Boot 2.4.3 and Spring Cloud 3.0.1.
- Updated to newer versions of dependencies. Spring Boot 2.3.5.RELEASE and Spring Cloud 2.2.5.RELEASE.
- Should not be used, released with incorrect version of Spring Boot.
- Fixed the bug where setting
spring.cloud.azure.appconfiguration.enabled
to false while usingspring-cloud-azure-appconfiguration-config-web
, resulted in an error on startup. #332 - Fixed the bug where a 400 Error would be returned from App Configuration when multiple labels and profiles are used at the same time. #675
- Fixed the bug where the configuration cannot be refreshed successfully when this library is used in a Java 11 container running with more than 2 CPUs.
-
Introduced new interfaces, which allow users to customize client builders for connecting to App Configuration and Key Vault. See this document for more details and examples. #656
ConfigurationClientBuilderSetup
SecretClientBuilderSetup
-
When fail-fast is disabled, an application may only load configuration under one context but not the other from an App Configuration store. The bug is fixed so either all configuration is loaded successfully or nothing is loaded to ensure the consistency of configuration in the application.
-
Fixed the bug that more than necessary requests may be made for configuration change detection especially when an App Configuration store has many keys or many change revisions. #672
-
Fixed the bug that
%00
was not working when it's used to indicate keys with no labels explicitly. Changed to use\0
to indicate keys with no labels to be consistent with the service. For example, a property setting below means loading keys with no labels and then overwritten by keys with labeldev
. #655spring.cloud.azure.appconfiguration.stores[0].label = \0,dev
- Fixed the bug that caused the configurations to refresh extra times when the config store didn't use feature flags. #298
- Updated to version 1.3.0 of the Azure Core library fixing compatibility with some other Azure libraries. #659
- Fixed the bug where the number of labels that could be used was maxed at 5.
- Reduced the number of requests made when using multiple labels.
- Credentials for authentication can now be provided in code via
AppConfigurationCredentialProvider
andKeyVaultCredentialProvider
.- This method allows for different authentication methods/credentials to be used when connecting with multiple App Configuration instances or Key Vaults.
- The
spring.cloud.azure.appconfiguration.stores[0].fail-fast
setting has been updated to be per store.- Previously this setting controlled the error handling for all App Configuration instances, now this setting allows for different error handling to be configured per App Configuration instance.
- The error handling specified by fail-fast is now limited to when settings are loaded on application startup. This setting does not affect error handling for configuration refresh. However, if there is an error loading from the App Configuration instance on startup and fail-fast is false for that instance, it will not be included in refresh attempts.
- Failed refreshes will now be automatically retried, if not completely successful.
- spring-cloud-azure-appconfiguration-config has been split into two packages: spring-cloud-azure-appconfiguration-config and spring-cloud-azure-appconfiguration-config-web. The web provider take on the spring-web dependency used for automated refresh. In the spring-cloud-azure-appconfiguration-config provider, refresh needs to be manually triggered.
- To continue using automated refresh, the "spring-cloud-azure-appconfiguration-config" dependency should be updated to "spring-cloud-azure-appconfiguration-config-web".
AppConfigurationRefresh
'srefreshConfigurations()
can be called to check if the settings for each App Configuration instance are up to date and, if the cache has expired, trigger a refresh event.
- Added Support for Spring Boot 2.2.x Hoxton with version 1.2.1. Spring Boot 2.1.x Greenwich is still supported with 1.1.1.
-
The property below has been removed as the timer-based configuration watch has been deprecated.
spring.cloud.azure.appconfiguration.watch.enabled
-
The configuration is refreshed based on application activities.
- The configuration is cached and the default cache expiration time is 30 seconds. The configuration won't be refreshed until the cache expiration time window is reached. This value can be modified, see example below.
spring.cloud.azure.appconfiguration.cache-expiration = 60
- In a web application, this library will signal configuration refresh automatically as long as there are incoming requests to the application. This is done by listening for servlet requests.
-
Fixed the bug that configuration refresh occurred multiple times unnecessarily when an application loads configuration from more than one App Configuration store.
-
Fixed the bug that failed configuration refresh may not be reattempted.
-
The property below has been removed as the object ID is not needed for managed identity authentication.
spring.cloud.azure.appconfiguration.managed-identity.object-id
-
With the generic AAD support by the App Configuration, the property name has been renamed to endpoint.
Before
spring.cloud.azure.appconfiguration.stores[0].name={my-configstore-name}
After
spring.cloud.azure.appconfiguration.stores[0].endpoint= https://{my-configstore-name}.azconfig.io
-
Users can now implement
AppConfigCredentialProvider
and/orKeyBaultCredentialProvider
to use any of theTokenCredential
access types that are supported by [Azure Identity][token_credentials] to authenticate with App Configuration or Key Vault respectively. Please see Starter for more details. -
System-assigned managed identity does not needs client id to be set.
- A new sample has been added showing how to convert an application to use App Configuration with Key Vault References. There is also a completed version to show how the code should now look.
-
Updated managed identity support for both system-assigned managed identity and user-assigned managed identity.
Before
The managed identity is assigned Contributor role to the App Configuration instance.
After
-
The system-assigned managed identity also requires the client-id to be set in addition to the config store name, for example,
spring.cloud.azure.appconfiguration.managed-identity.client-id=[client id] spring.cloud.azure.appconfiguration.stores[0].name=[config store name]
-
The managed identity should be assigned App Configuration Data Reader role to the App Configuration instance.
-
-
To prevent unintentional results, an IllegalArgumentException exception will be thrown if both
spring.cloud.azure.appconfiguration.stores[0].name
andspring.cloud.azure.appconfiguration.stores[0].connection-string
are provided.
- Switched to using Azure SDK.
- Added support for using Key Vault References.
- Auto retry on failure of up to 12 times in a 60 second window.
- Now watch only checks for updates when a ServletRequestHandlerEvent is triggered and a update hasn't been happened in the refresh window.
- Added Feature Management Support.