|
// 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.Diagnostics;
using System.Globalization;
using Newtonsoft.Json.Linq;
namespace NuGet.Protocol.Plugins
{
internal sealed class ProcessLogMessage : PluginLogMessage
{
private readonly int _processId;
private readonly string _processName;
private readonly DateTime _processStartTime;
internal ProcessLogMessage(DateTimeOffset now)
: base(now)
{
using (var process = Process.GetCurrentProcess())
{
_processId = process.Id;
_processName = process.ProcessName;
_processStartTime = process.StartTime.ToUniversalTime();
}
}
public override string ToString()
{
var message = new JObject(
new JProperty("process ID", _processId),
new JProperty("process name", _processName),
new JProperty("process start time", _processStartTime.ToString("O", CultureInfo.CurrentCulture)));
return ToString("process", message);
}
}
}
|