Implement result getter

This commit is contained in:
2025-11-01 19:15:07 +09:00
parent 6fc2db95ec
commit 821eeb41ae
16 changed files with 243 additions and 18 deletions

View File

@ -1,4 +1,5 @@
using Hcs.Service.Async.NsiCommon;
using Hcs.Broker.Api.Request;
using Hcs.Service.Async.NsiCommon;
namespace Hcs.Broker.Api
{
@ -22,7 +23,6 @@ namespace Hcs.Broker.Api
/// <returns>Перечень общесистемных справочников</returns>
Task<NsiListType> ExportNsiListAsync(ListGroup listGroup, CancellationToken token = default);
/// <summary>
/// Запрашивает экспорт данных общесистемного справочника
/// </summary>
@ -31,5 +31,12 @@ namespace Hcs.Broker.Api
/// <param name="token">Токен отмены</param>
/// <returns>Идентификатор сообщения операции экспорта</returns>
Task<string> RequestExportNsiItemAsync(int registryNumber, ListGroup listGroup, CancellationToken token = default);
/// <summary>
/// Возвращает результат экспорта данных общесистемного справочника
/// </summary>
/// <param name="messageGuid">Идентификатор сообщения операции экспорта</param>
/// <returns>Результат запроса</returns>
Task<RequestSingleResult<NsiItemType>> GetExportNsiItemResultAsync(string messageGuid);
}
}

View File

@ -1,4 +1,5 @@
using Hcs.Broker.Api.Request.Exception;
using Hcs.Broker.Api.Request;
using Hcs.Broker.Api.Request.Exception;
using Hcs.Broker.Api.Request.NsiCommon;
using Hcs.Service.Async.NsiCommon;
@ -41,5 +42,12 @@ namespace Hcs.Broker.Api
var request = new ExportNsiItemRequest(client);
return await request.SendAsync(registryNumber, listGroup, token);
}
/// <inheritdoc cref="INsiCommonApi"/>
public async Task<RequestSingleResult<NsiItemType>> GetExportNsiItemResultAsync(string messageGuid)
{
var request = new ExportNsiItemRequest(client);
return await request.GetResultAsync(messageGuid);
}
}
}

View File

@ -5,5 +5,7 @@
string ErrorCode { get; }
string Description { get; }
string StackTrace { get; }
}
}

View File

@ -1,4 +1,5 @@
using Hcs.Broker.Internal;
using Hcs.Broker.Api.Request.Adapter;
using Hcs.Broker.Internal;
using Hcs.Service.Async.NsiCommon;
namespace Hcs.Broker.Api.Request.NsiCommon
@ -36,17 +37,29 @@ namespace Hcs.Broker.Api.Request.NsiCommon
ListGroup = listGroup
};
return await StartSendAsync(request, async asyncClient =>
return await SendAsync(request, async asyncClient =>
{
var response = await asyncClient.exportNsiItemAsync(CreateRequestHeader(), request);
return response.AckRequest.Ack;
}, token);
}
internal async Task<NsiItemType?> GetResultAsync(string messageGuid)
internal async Task<RequestSingleResult<NsiItemType>> GetResultAsync(string messageGuid)
{
var result = await ExecuteGetResultAsync(messageGuid);
return result?.Item as NsiItemType;
if (result == null)
{
return RequestSingleResult<NsiItemType>.CreateNotReady();
}
if (result.Item is NsiItemType nsiItem)
{
return RequestSingleResult<NsiItemType>.CreateSuccessful(nsiItem);
}
else if (result.Item is IErrorMessage errorMessage)
{
return RequestSingleResult<NsiItemType>.CreateFailed(errorMessage);
}
return RequestSingleResult<NsiItemType>.CreateFailed(null);
}
}
}

View File

@ -149,7 +149,7 @@ namespace Hcs.Broker.Api.Request
}
}
protected async Task<string> StartSendAsync(
protected async Task<string> SendAsync(
object request,
Func<TAsyncClient, Task<TAck>> sender,
CancellationToken token)

View File

@ -0,0 +1,43 @@
using Hcs.Broker.Api.Request.Adapter;
namespace Hcs.Broker.Api.Request
{
public class RequestSingleResult<T>
{
public bool Ready { get; set; }
public bool Success { get; set; }
public T? Result { get; set; }
public IErrorMessage? ErrorMessage { get; set; }
public static RequestSingleResult<T> CreateNotReady()
{
return new RequestSingleResult<T>
{
Ready = false
};
}
public static RequestSingleResult<T> CreateSuccessful(T result)
{
return new RequestSingleResult<T>
{
Ready = true,
Success = true,
Result = result
};
}
public static RequestSingleResult<T> CreateFailed(IErrorMessage? errorMessage)
{
return new RequestSingleResult<T>
{
Ready = true,
Success = false,
ErrorMessage = errorMessage
};
}
}
}