|
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
#nullable disable
using System;
using System.Threading;
using System.Threading.Tasks;
namespace NuGet.Protocol.Plugins
{
/// <summary>
/// Represents a unidirectional communications to a target.
/// </summary>
public interface ISender : IDisposable
{
/// <summary>
/// Closes the connection.
/// </summary>
/// <remarks>This does not call <see cref="IDisposable.Dispose" />.</remarks>
void Close();
/// <summary>
/// Connects.
/// </summary>
/// <exception cref="ObjectDisposedException">Thrown if this object is disposed.</exception>
/// <exception cref="InvalidOperationException">Thrown if this object is closed.</exception>
/// <exception cref="InvalidOperationException">Thrown if this method has already been called.</exception>
void Connect();
/// <summary>
/// Asynchronously sends a message to the target.
/// </summary>
/// <param name="message">The message to send.</param>
/// <param name="cancellationToken">A cancellation token.</param>
/// <returns>A task that represents the asynchronous operation.</returns>
/// <exception cref="ObjectDisposedException">Thrown if this object is disposed.</exception>
/// <exception cref="InvalidOperationException">Thrown if <see cref="Connect" /> has not been called.</exception>
/// <exception cref="ArgumentNullException">Thrown if <paramref name="message" /> is <see langword="null" />.</exception>
/// <exception cref="OperationCanceledException">Thrown if <paramref name="cancellationToken" />
/// is cancelled.</exception>
Task SendAsync(Message message, CancellationToken cancellationToken);
}
}
|