-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathServiceCollectionExtensions.cs
More file actions
74 lines (66 loc) · 3.18 KB
/
ServiceCollectionExtensions.cs
File metadata and controls
74 lines (66 loc) · 3.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using System.Diagnostics.CodeAnalysis;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Options;
namespace CompactifAI.Client.Extensions;
/// <summary>
/// Extension methods for registering CompactifAI services.
/// </summary>
public static class ServiceCollectionExtensions
{
/// <summary>
/// Adds the CompactifAI client to the service collection.
/// </summary>
/// <param name="services">The service collection.</param>
/// <param name="configureOptions">Action to configure the client options.</param>
/// <returns>The service collection for chaining.</returns>
public static IServiceCollection AddCompactifAI(
this IServiceCollection services,
Action<CompactifAIOptions> configureOptions)
{
services.Configure(configureOptions);
services.AddHttpClient<ICompactifAIClient, CompactifAIClient>((serviceProvider, client) =>
{
var options = serviceProvider.GetRequiredService<IOptions<CompactifAIOptions>>().Value;
client.BaseAddress = new Uri(options.BaseUrl.TrimEnd('/') + "/");
client.Timeout = TimeSpan.FromSeconds(options.TimeoutSeconds);
});
return services;
}
/// <summary>
/// Adds the CompactifAI client to the service collection with a simple API key.
/// </summary>
/// <param name="services">The service collection.</param>
/// <param name="apiKey">The API key.</param>
/// <returns>The service collection for chaining.</returns>
public static IServiceCollection AddCompactifAI(
this IServiceCollection services,
string apiKey)
{
return services.AddCompactifAI(options => options.ApiKey = apiKey);
}
/// <summary>
/// Adds the CompactifAI client to the service collection using configuration binding.
/// </summary>
/// <param name="services">The service collection.</param>
/// <param name="configuration">The configuration section to bind from.</param>
/// <returns>The service collection for chaining.</returns>
/// <remarks>
/// This method uses configuration binding which requires reflection and is not AOT-compatible.
/// For AOT scenarios, use the overload that accepts an Action<CompactifAIOptions>.
/// </remarks>
[RequiresUnreferencedCode("Configuration binding uses reflection. Use the Action<CompactifAIOptions> overload for AOT scenarios.")]
[RequiresDynamicCode("Configuration binding uses reflection. Use the Action<CompactifAIOptions> overload for AOT scenarios.")]
public static IServiceCollection AddCompactifAI(
this IServiceCollection services,
Microsoft.Extensions.Configuration.IConfiguration configuration)
{
services.Configure<CompactifAIOptions>(configuration.GetSection(CompactifAIOptions.SectionName));
services.AddHttpClient<ICompactifAIClient, CompactifAIClient>((serviceProvider, client) =>
{
var options = serviceProvider.GetRequiredService<IOptions<CompactifAIOptions>>().Value;
client.BaseAddress = new Uri(options.BaseUrl.TrimEnd('/') + "/");
client.Timeout = TimeSpan.FromSeconds(options.TimeoutSeconds);
});
return services;
}
}