-
Notifications
You must be signed in to change notification settings - Fork 418
/
IResourceBuilder.cs
38 lines (33 loc) · 1.87 KB
/
IResourceBuilder.cs
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
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
namespace Aspire.Hosting.ApplicationModel;
/// <summary>
/// Defines a builder for creating resources of type <typeparamref name="T"/>.
/// </summary>
/// <typeparam name="T">The type of resource to build.</typeparam>
public interface IResourceBuilder<out T> where T : IResource
{
/// <summary>
/// Gets the distributed application builder associated with this resource builder.
/// </summary>
IDistributedApplicationBuilder ApplicationBuilder { get; }
/// <summary>
/// Gets the resource of type <typeparamref name="T"/> that is being built.
/// </summary>
T Resource { get; }
/// <summary>
/// Adds an annotation to the resource being built.
/// </summary>
/// <typeparam name="TAnnotation">The type of the annotation to add.</typeparam>
/// <param name="behavior">The behavior to use when adding the annotation.</param>
/// <returns>The resource builder instance.</returns>
IResourceBuilder<T> WithAnnotation<TAnnotation>(ResourceAnnotationMutationBehavior behavior = ResourceAnnotationMutationBehavior.Append) where TAnnotation : IResourceAnnotation, new() => WithAnnotation(new TAnnotation(), behavior);
/// <summary>
/// Adds an annotation to the resource being built.
/// </summary>
/// <typeparam name="TAnnotation">The type of the annotation to add.</typeparam>
/// <param name="annotation">The annotation to add.</param>
/// <param name="behavior">The behavior to use when adding the annotation.</param>
/// <returns>The resource builder instance.</returns>
IResourceBuilder<T> WithAnnotation<TAnnotation>(TAnnotation annotation, ResourceAnnotationMutationBehavior behavior = ResourceAnnotationMutationBehavior.Append) where TAnnotation : IResourceAnnotation;
}