Files
SPT-Server-Build/Core/Utils/TimeUtil.cs
T

201 lines
6.5 KiB
C#

using Core.Annotations;
namespace Core.Utils;
[Injectable(InjectionType.Singleton)]
public class TimeUtil
{
public const int OneHourAsSeconds = 3600;
/// <summary>
/// Formats the time part of a date as a UTC string.
/// </summary>
/// <param name="dateTime">The date to format in UTC.</param>
/// <returns>The formatted time as 'HH-MM-SS'.</returns>
public string FormatTime(DateTimeOffset dateTime)
{
var hour = Pad(dateTime.ToUniversalTime().Hour);
var minute = Pad(dateTime.ToUniversalTime().Minute);
var second = Pad(dateTime.ToUniversalTime().Second);
return $"{hour}-{minute}-{second}";
}
/// <summary>
/// Formats the date part of a date as a UTC string.
/// </summary>
/// <param name="dateTime">The date to format in UTC.</param>
/// <returns>The formatted date as 'YYYY-MM-DD'.</returns>
public string FormatDate(DateTimeOffset dateTime)
{
var day = Pad(dateTime.ToUniversalTime().Day);
var month = Pad(dateTime.ToUniversalTime().Month);
var year = Pad(dateTime.ToUniversalTime().Year);
return $"{year}-{month}-{day}";
}
/// <summary>
/// Gets the current date as a formatted UTC string.
/// </summary>
/// <returns>The current date as 'YYYY-MM-DD'.</returns>
public string GetDate()
{
return FormatDate(DateTimeOffset.UtcNow);
}
/// <summary>
/// Gets the current time as a formatted UTC string.
/// </summary>
/// <returns>The current time as 'HH-MM-SS'.</returns>
public string GetTime()
{
return FormatTime(DateTimeOffset.UtcNow);
}
/// <summary>
/// Gets the current timestamp in seconds in UTC.
/// </summary>
/// <returns>The current timestamp in seconds since the Unix epoch in UTC.</returns>
public long GetTimeStamp()
{
return DateTimeOffset.Now.ToUnixTimeSeconds();
}
/// <summary>
/// Gets the start of day timestamp for the given date
/// </summary>
/// <param name="dateTime">datetime to get the time stamp for, if null it uses current date.</param>
/// <returns>Unix epoch for the start of day of the calculated date</returns>
public long GetStartOfDayTimeStamp(long? timestamp)
{
DateTime now = timestamp.HasValue
? DateTimeOffset.FromUnixTimeMilliseconds(timestamp.Value).DateTime
: DateTime.Now;
DateTime startOfDay = new DateTime(now.Year, now.Month, now.Day, 0, 0, 0);
return ((DateTimeOffset)startOfDay).ToUnixTimeMilliseconds();
}
/// <summary>
/// Get timestamp of today + passed in day count
/// </summary>
/// <param name="daysFromNow">Days from now</param>
/// <returns></returns>
public long GetTimeStampFromNowDays(int daysFromNow)
{
return DateTimeOffset.UtcNow.AddDays(daysFromNow).ToUnixTimeSeconds();
}
/// <summary>
/// Get timestamp of today + passed in hour count
/// </summary>
/// <param name="hoursFromNow"></param>
/// <returns></returns>
public long GetTimeStampFromNowHours(int hoursFromNow)
{
return DateTimeOffset.UtcNow.AddHours(hoursFromNow).ToUnixTimeSeconds();
}
/// <summary>
/// Gets the current time in UTC in a format suitable for mail in EFT.
/// </summary>
/// <returns>The current time as 'HH:MM' in UTC.</returns>
/// GetTimeMailFormat
public string GetTimeMailFormat()
{
return DateTimeOffset.UtcNow.ToString("HH:mm");
}
/// <summary>
/// Gets the current date in UTC in a format suitable for emails in EFT.
/// </summary>
/// <returns>The current date as 'DD.MM.YYYY' in UTC.</returns>
public string GetDateMailFormat()
{
return DateTimeOffset.UtcNow.ToString("dd.MM.yyyy");
}
/// <summary>
/// Converts a number of hours into seconds.
/// </summary>
/// <param name="hours">The number of hours to convert.</param>
/// <returns>The equivalent number of seconds.</returns>
public int GetHoursAsSeconds(int hours)
{
return OneHourAsSeconds * hours;
}
/// <summary>
/// Gets the time stamp of the start of the next hour in UTC
/// </summary>
/// <returns>Time stamp of the next hour in unix time seconds</returns>
public long GetTimeStampOfNextHour()
{
DateTime now = DateTime.Now;
TimeSpan timeUntilNextHour = TimeSpan.FromMinutes(60 - now.Minute)
.Subtract(TimeSpan.FromSeconds(now.Second))
.Subtract(TimeSpan.FromMilliseconds(now.Millisecond));
var time = ((DateTimeOffset)now.Add(timeUntilNextHour)).ToUnixTimeSeconds();
return time;
}
/// <summary>
/// Returns the current days timestamp at 00:00
/// e.g. current time: 13th March 14:22 will return 13th March 00:00
/// </summary>
/// <returns>Timestamp</returns>
public long GetTodayMidnightTimeStamp()
{
DateTime now = DateTime.Now;
int hours = now.Hour;
int minutes = now.Minute;
// If minutes greater than 0, subtract 1 hour
if (minutes > 0)
{
hours--;
}
// Create a new DateTime with the last full hour, 0 minutes, and 0 seconds
DateTime lastFullHour = new DateTime(now.Year, now.Month, now.Day, hours, 0, 0);
return ((DateTimeOffset)lastFullHour).ToUnixTimeMilliseconds();
}
/// <summary>
/// Pads a number with a leading zero if it is less than 10.
/// </summary>
/// <param name="number">The number to pad.</param>
/// <returns>The padded number as a string.</returns>
private static string Pad(int number)
{
return number.ToString().PadLeft(2, '0');
}
/// <summary>
/// Takes a timestamp and converts to its date with Epoch
/// </summary>
/// <param name="timeStamp"></param>
/// <returns></returns>
public DateTime GetDateTimeFromTimeStamp(long timeStamp)
{
return DateTimeOffset.FromUnixTimeMilliseconds(timeStamp).DateTime;
}
/// <summary>
/// Takes a date and gets difference between Epoch time and time provided resulting in a timestamp (date defaults to utcnow)
/// This attempts to mimic gettime() in js
/// </summary>
/// <param name="date"></param>
/// <returns></returns>
public long GetTimeStampFromEpoch(DateTime? date = null)
{
var dateToCompare = date ?? DateTime.UtcNow;
return (long)(dateToCompare - DateTime.UnixEpoch).TotalMilliseconds;
}
}