mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-10-25 15:52:29 -04:00
Co-authored-by: DieselTech <30128380+DieselTech@users.noreply.github.com> Co-authored-by: majora2007 <josephmajora@gmail.com>
85 lines
2.7 KiB
C#
85 lines
2.7 KiB
C#
using System;
|
|
using System.Globalization;
|
|
using System.Text.RegularExpressions;
|
|
|
|
namespace API.Extensions;
|
|
#nullable enable
|
|
|
|
public static class StringExtensions
|
|
{
|
|
private static readonly Regex SentenceCaseRegex = new(@"(^[a-z])|\.\s+(.)",
|
|
RegexOptions.ExplicitCapture | RegexOptions.Compiled,
|
|
Services.Tasks.Scanner.Parser.Parser.RegexTimeout);
|
|
|
|
public static string Sanitize(this string input)
|
|
{
|
|
if (string.IsNullOrEmpty(input))
|
|
return string.Empty;
|
|
|
|
// Remove all newline and control characters
|
|
var sanitized = input
|
|
.Replace(Environment.NewLine, string.Empty)
|
|
.Replace("\n", string.Empty)
|
|
.Replace("\r", string.Empty);
|
|
|
|
// Optionally remove other potentially unwanted characters
|
|
sanitized = Regex.Replace(sanitized, @"[^\u0020-\u007E]", string.Empty); // Removes non-printable ASCII
|
|
|
|
return sanitized.Trim(); // Trim any leading/trailing whitespace
|
|
}
|
|
|
|
public static string SentenceCase(this string value)
|
|
{
|
|
return SentenceCaseRegex.Replace(value.ToLower(), s => s.Value.ToUpper());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Apply normalization on the String
|
|
/// </summary>
|
|
/// <param name="value"></param>
|
|
/// <returns></returns>
|
|
public static string ToNormalized(this string? value)
|
|
{
|
|
return string.IsNullOrEmpty(value) ? string.Empty : Services.Tasks.Scanner.Parser.Parser.Normalize(value);
|
|
}
|
|
|
|
public static float AsFloat(this string? value, float defaultValue = 0.0f)
|
|
{
|
|
return string.IsNullOrEmpty(value) ? defaultValue : float.Parse(value, CultureInfo.InvariantCulture);
|
|
}
|
|
|
|
public static double AsDouble(this string? value, double defaultValue = 0.0f)
|
|
{
|
|
return string.IsNullOrEmpty(value) ? defaultValue : double.Parse(value, CultureInfo.InvariantCulture);
|
|
}
|
|
|
|
public static string TrimPrefix(this string? value, string prefix)
|
|
{
|
|
if (string.IsNullOrEmpty(value)) return string.Empty;
|
|
|
|
if (!value.StartsWith(prefix)) return value;
|
|
|
|
return value.Substring(prefix.Length);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Censor the input string by removing all but the first and last char.
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
/// <remarks>If the input is an email (contains @), the domain will remain untouched</remarks>
|
|
public static string Censor(this string? input)
|
|
{
|
|
if (string.IsNullOrWhiteSpace(input)) return input ?? string.Empty;
|
|
|
|
var atIdx = input.IndexOf('@');
|
|
if (atIdx == -1)
|
|
{
|
|
return $"{input[0]}{new string('*', input.Length - 1)}";
|
|
}
|
|
|
|
return input[0] + new string('*', atIdx - 1) + input[atIdx..];
|
|
}
|
|
|
|
}
|