diff --git a/src/Scaler.Demo/OrderGenerator/Keda.CosmosDb.Scaler.Demo.OrderGenerator.csproj b/src/Scaler.Demo/OrderGenerator/Keda.CosmosDb.Scaler.Demo.OrderGenerator.csproj index 0cbfce7..4bb7efb 100644 --- a/src/Scaler.Demo/OrderGenerator/Keda.CosmosDb.Scaler.Demo.OrderGenerator.csproj +++ b/src/Scaler.Demo/OrderGenerator/Keda.CosmosDb.Scaler.Demo.OrderGenerator.csproj @@ -6,6 +6,7 @@ + diff --git a/src/Scaler.Demo/OrderGenerator/Program.cs b/src/Scaler.Demo/OrderGenerator/Program.cs index 875094b..77bfac5 100644 --- a/src/Scaler.Demo/OrderGenerator/Program.cs +++ b/src/Scaler.Demo/OrderGenerator/Program.cs @@ -1,6 +1,7 @@ using System; using System.Linq; using System.Threading.Tasks; +using Azure.Identity; using Bogus; using Bogus.DataSets; using Keda.CosmosDb.Scaler.Demo.Shared; @@ -85,7 +86,11 @@ private static bool ReadIsSingleArticle() private static async Task CreateOrdersAsync(int count, bool isSingleArticle) { - Container container = new CosmosClient(_cosmosDbConfig.Connection) + using var cosmosClient = _cosmosDbConfig.Connection.Contains("AccountKey") + ? new CosmosClient(_cosmosDbConfig.Connection, new CosmosClientOptions { ConnectionMode = ConnectionMode.Gateway }) + : new CosmosClient(_cosmosDbConfig.Connection, new DefaultAzureCredential(), new CosmosClientOptions { ConnectionMode = ConnectionMode.Direct }); + + Container container = cosmosClient .GetContainer(_cosmosDbConfig.DatabaseId, _cosmosDbConfig.ContainerId); int remainingCount = count; diff --git a/src/Scaler/Keda.CosmosDb.Scaler.csproj b/src/Scaler/Keda.CosmosDb.Scaler.csproj index 9c9c6e8..5ce777f 100644 --- a/src/Scaler/Keda.CosmosDb.Scaler.csproj +++ b/src/Scaler/Keda.CosmosDb.Scaler.csproj @@ -9,6 +9,7 @@ + diff --git a/src/Scaler/Services/CosmosDbFactory.cs b/src/Scaler/Services/CosmosDbFactory.cs index 25cf364..249c361 100644 --- a/src/Scaler/Services/CosmosDbFactory.cs +++ b/src/Scaler/Services/CosmosDbFactory.cs @@ -1,4 +1,5 @@ using System.Collections.Concurrent; +using Azure.Identity; using Microsoft.Azure.Cosmos; namespace Keda.CosmosDb.Scaler @@ -9,14 +10,13 @@ internal sealed class CosmosDbFactory // maintain a single instance of CosmosClient per lifetime of the application. private readonly ConcurrentDictionary _cosmosClientCache = new(); - public CosmosClient GetCosmosClient(string connection) - { - return _cosmosClientCache.GetOrAdd(connection, CreateCosmosClient); - } + public CosmosClient GetCosmosClient(string connection) => + _cosmosClientCache.GetOrAdd(connection, CreateCosmosClient); + + private CosmosClient CreateCosmosClient(string connection) => + connection.Contains("Accountkey") ? + new CosmosClient(connection, new CosmosClientOptions { ConnectionMode = ConnectionMode.Gateway }) : + new CosmosClient(connection, new DefaultAzureCredential(), new CosmosClientOptions { ConnectionMode = ConnectionMode.Direct }); - private CosmosClient CreateCosmosClient(string connection) - { - return new CosmosClient(connection, new CosmosClientOptions { ConnectionMode = ConnectionMode.Gateway }); - } } } diff --git a/src/Scaler/Services/CosmosDbMetricProvider.cs b/src/Scaler/Services/CosmosDbMetricProvider.cs index 61242dc..db9cd85 100644 --- a/src/Scaler/Services/CosmosDbMetricProvider.cs +++ b/src/Scaler/Services/CosmosDbMetricProvider.cs @@ -3,6 +3,7 @@ using System.Net; using System.Net.Http; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Azure.Cosmos; using Microsoft.Extensions.Logging;