From 6350c39aaaa6011f56745d4f4a30cc0aa7d858d4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=90=AC=E9=9B=A8=E5=A3=B0?= Date: Thu, 26 May 2022 17:53:00 +0800 Subject: [PATCH] feat(Storage.Aliyun): Added AddAliyunStorage (#69) * feat(Storage.Aliyun): Added AddAliyunStorage * chore: Optimize AddAliyunStorage * test(Storage.Aliyun): Handling unit tests --- .../ServiceCollectionExtensions.cs | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/src/Storage/Masa.Contrib.Storage.ObjectStorage.Aliyun/ServiceCollectionExtensions.cs b/src/Storage/Masa.Contrib.Storage.ObjectStorage.Aliyun/ServiceCollectionExtensions.cs index 1532d2372..594d4e0fc 100644 --- a/src/Storage/Masa.Contrib.Storage.ObjectStorage.Aliyun/ServiceCollectionExtensions.cs +++ b/src/Storage/Masa.Contrib.Storage.ObjectStorage.Aliyun/ServiceCollectionExtensions.cs @@ -41,7 +41,7 @@ public static IServiceCollection AddAliyunStorage(this IServiceCollection servic return services.AddAliyunStorage(() => options); } - public static IServiceCollection AddAliyunStorage(this IServiceCollection services, Func func) + public static IServiceCollection AddAliyunStorage(this IServiceCollection services, Func func) { ArgumentNullException.ThrowIfNull(func, nameof(func)); @@ -49,16 +49,23 @@ public static IServiceCollection AddAliyunStorage(this IServiceCollection servic services.TryAddSingleton(); services.TryAddSingleton(serviceProvider => new DefaultCredentialProvider( GetOssClientFactory(serviceProvider), - func.Invoke(), + func.Invoke(serviceProvider), GetMemoryCache(serviceProvider), GetDefaultCredentialProviderLogger(serviceProvider))); services.TryAddSingleton(serviceProvider => new Client( GetCredentialProvider(serviceProvider), - func.Invoke(), + func.Invoke(serviceProvider), GetClientLogger(serviceProvider))); return services; } + public static IServiceCollection AddAliyunStorage(this IServiceCollection services, Func func) + { + ArgumentNullException.ThrowIfNull(func, nameof(func)); + + return services.AddAliyunStorage(_ => func.Invoke()); + } + private static IServiceCollection AddAliyunStorageDepend(this IServiceCollection services) { services.AddMemoryCache(); @@ -113,7 +120,8 @@ private static void CheckAliYunStorageOptions(AliyunStorageOptions options) ArgumentNullException.ThrowIfNull(options, nameof(options)); if (options.AccessKeyId == null && options.AccessKeySecret == null) - throw new ArgumentException($"{nameof(options.AccessKeyId)}, {nameof(options.AccessKeySecret)} are required and cannot be empty"); + throw new ArgumentException( + $"{nameof(options.AccessKeyId)}, {nameof(options.AccessKeySecret)} are required and cannot be empty"); ObjectStorageExtensions.CheckNullOrEmptyAndReturnValue(options.AccessKeyId, nameof(options.AccessKeyId)); ObjectStorageExtensions.CheckNullOrEmptyAndReturnValue(options.AccessKeySecret, nameof(options.AccessKeySecret));