|
// 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.
using System;
using System.Text.Json.Nodes;
using System.Threading.Tasks;
namespace NuGet.Protocol.Plugins
{
internal sealed class TaskLogMessage : PluginLogMessage
{
private readonly int? _currentTaskId;
private readonly MessageMethod _method;
private readonly string _requestId;
private readonly TaskState _state;
private readonly MessageType _type;
internal TaskLogMessage(DateTimeOffset now, string requestId, MessageMethod method, MessageType type, TaskState state)
: base(now)
{
_requestId = requestId;
_method = method;
_type = type;
_state = state;
_currentTaskId = Task.CurrentId;
}
public override string ToString()
{
var message = new JsonObject
{
["request ID"] = _requestId,
["method"] = _method.ToString(),
["type"] = _type.ToString(),
["state"] = _state.ToString(),
};
if (_currentTaskId.HasValue)
{
message["current task ID"] = _currentTaskId.Value;
}
return ToString("task", message);
}
}
}
|