forked from QuantConnect/Lean
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathValidate.cs
More file actions
108 lines (97 loc) · 4.16 KB
/
Validate.cs
File metadata and controls
108 lines (97 loc) · 4.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
* QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
* Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System.Globalization;
using System.Text.RegularExpressions;
namespace QuantConnect.Util
{
/// <summary>
/// Provides methods for validating strings following a certain format, such as an email address
/// </summary>
public static class Validate
{
/// <summary>
/// Validates the provided email address
/// </summary>
/// <remarks>
/// Implementation taken from msdn (with slight refactoring for readability and C#6 compliance):
/// https://docs.microsoft.com/en-us/dotnet/standard/base-types/how-to-verify-that-strings-are-in-valid-email-format
/// </remarks>
/// <param name="emailAddress">The email address to be validated</param>
/// <returns>True if the provided email address is valid</returns>
public static bool EmailAddress(string emailAddress)
{
if (emailAddress == null)
{
return true;
}
if (string.IsNullOrWhiteSpace(emailAddress))
{
return false;
}
emailAddress = NormalizeEmailAddressDomainName(emailAddress);
if (emailAddress == null)
{
// an error occurred during domain name normalization
return false;
}
try
{
return RegularExpression.Email.IsMatch(emailAddress);
}
catch
{
return false;
}
}
private static string NormalizeEmailAddressDomainName(string emailAddress)
{
try
{
// Normalize the domain
emailAddress = RegularExpression.EmailDomainName.Replace(emailAddress, match =>
{
// Use IdnMapping class to convert Unicode domain names.
var idn = new IdnMapping();
// Pull out and process domain name (throws ArgumentException on invalid)
var domainName = idn.GetAscii(match.Groups[2].Value);
return match.Groups[1].Value + domainName;
});
}
catch
{
return null;
}
return emailAddress;
}
/// <summary>
/// Provides static storage of compiled regular expressions to preclude parsing on each invocation
/// </summary>
public static class RegularExpression
{
/// <summary>
/// Matches the domain name in an email address ignored@[domain.com]
/// Pattern sourced via msdn:
/// https://docs.microsoft.com/en-us/dotnet/standard/base-types/how-to-verify-that-strings-are-in-valid-email-format
/// </summary>
public static readonly Regex EmailDomainName = new Regex(@"(@)(.+)$", RegexOptions.Compiled);
/// <summary>
/// Matches a valid email address address@sub.domain.com
/// Pattern sourced via msdn:
/// https://docs.microsoft.com/en-us/dotnet/standard/base-types/how-to-verify-that-strings-are-in-valid-email-format
/// </summary>
public static readonly Regex Email = new Regex(@"^(?("")("".+?(?<!\\)""@)|(([0-9a-z]((\.(?!\.))|[-!#\$%&'\*\+/=\?\^`\{\}\|~\w])*)(?<=[0-9a-z])@))(?(\[)(\[(\d{1,3}\.){3}\d{1,3}\])|(([0-9a-z][-0-9a-z]*[0-9a-z]*\.)+[a-z0-9][\-a-z0-9]{0,22}[a-z0-9]))$", RegexOptions.IgnoreCase | RegexOptions.Compiled);
}
}
}