From 18e49c04c2d3644aa1dc296f0a6b6aeebd5f8be4 Mon Sep 17 00:00:00 2001 From: trwalke Date: Wed, 30 Oct 2024 18:29:11 -0700 Subject: [PATCH 1/5] Consolidating statics --- .../Default.cs | 94 ++++++------------- .../ReferenceTokens.cs | 25 ++--- 2 files changed, 37 insertions(+), 82 deletions(-) diff --git a/test/Microsoft.IdentityModel.TestUtils/Default.cs b/test/Microsoft.IdentityModel.TestUtils/Default.cs index 0080ecdc2c..0805a1ab89 100644 --- a/test/Microsoft.IdentityModel.TestUtils/Default.cs +++ b/test/Microsoft.IdentityModel.TestUtils/Default.cs @@ -8,6 +8,7 @@ using System.Security.Claims; using System.Security.Cryptography; using System.Security.Cryptography.X509Certificates; +using System.Xml.Linq; using Microsoft.IdentityModel.Tokens; using Microsoft.IdentityModel.Tokens.Json; using Microsoft.IdentityModel.Tokens.Saml; @@ -398,38 +399,6 @@ public static string AadPayloadString }.ToString(); } - public static string PayloadString - { - get => new JObject() - { - { JwtRegisteredClaimNames.Aud, Audience }, - { JwtRegisteredClaimNames.Azp, Azp }, - { JwtRegisteredClaimNames.Email, "Bob@contoso.com" }, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, - { JwtRegisteredClaimNames.GivenName, "Bob" }, - { JwtRegisteredClaimNames.Iss, Issuer }, - { JwtRegisteredClaimNames.Iat, EpochTime.GetIntDate(IssueInstant).ToString() }, - { JwtRegisteredClaimNames.Jti, Jti }, - { JwtRegisteredClaimNames.Nbf, EpochTime.GetIntDate(NotBefore).ToString()}, - }.ToString(Formatting.None); - } - - public static string PayloadStringMultipleAudiences - { - get => new JObject() - { - { JwtRegisteredClaimNames.Aud, JArray.FromObject(Audiences) }, - { JwtRegisteredClaimNames.Azp, Azp }, - { JwtRegisteredClaimNames.Email, "Bob@contoso.com" }, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, - { JwtRegisteredClaimNames.GivenName, "Bob" }, - { JwtRegisteredClaimNames.Iss, Issuer }, - { JwtRegisteredClaimNames.Iat, EpochTime.GetIntDate(IssueInstant).ToString() }, - { JwtRegisteredClaimNames.Jti, Jti }, - { JwtRegisteredClaimNames.Nbf, EpochTime.GetIntDate(NotBefore).ToString()}, - }.ToString(Formatting.None); - } - public static List PayloadClaims { get => new List() @@ -484,24 +453,7 @@ public static List PayloadJsonClaims public static Dictionary PayloadJsonDictionary { - get => new Dictionary() - { - { JwtRegisteredClaimNames.Aud, Audience }, - { JwtRegisteredClaimNames.Iss, Issuer }, - { "ClaimValueTypes.String", "ClaimValueTypes.String.Value" }, - { "ClaimValueTypes.Boolean.true", true }, - { "ClaimValueTypes.Boolean.false", false }, - { "ClaimValueTypes.Double", 123.4 }, - { "ClaimValueTypes.DateTime.IS8061", DateTime.TryParse("2019-11-15T14:31:21.6101326Z", out DateTime dateTimeValue1) ? dateTimeValue1.ToUniversalTime() : new DateTime()}, - { "ClaimValueTypes.DateTime", DateTime.TryParse("2019-11-15", out DateTime dateTimeValue2) ? dateTimeValue2 : new DateTime()}, - { "ClaimValueTypes.JsonClaimValueTypes.Json1", JObject.Parse(@"{""jsonProperty1"":""jsonvalue1""}") }, - { "ClaimValueTypes.JsonClaimValueTypes.Json2", JObject.Parse(@"{""jsonProperty2"":""jsonvalue2""}") }, - { "ClaimValueTypes.JsonClaimValueTypes.JsonNull", "" }, - { "ClaimValueTypes.JsonClaimValueTypes.JsonArray1", JArray.Parse(@"[1,2,3]") }, - { "ClaimValueTypes.JsonClaimValueTypes.JsonArray2", JArray.Parse(@"[1,""2"",3]") }, - { "ClaimValueTypes.JsonClaimValueTypes.Integer1", 1 }, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() } - }; + get => PayloadJsonClaims.ToDictionary(x => x.Type, x => (object)x.Value); } public static ClaimsIdentity PayloadClaimsIdentity @@ -509,9 +461,9 @@ public static ClaimsIdentity PayloadClaimsIdentity get => new CaseSensitiveClaimsIdentity(PayloadClaims, "AuthenticationTypes.Federation"); } - public static Dictionary PayloadDictionary + public static JObject PayloadAsJObject { - get => new Dictionary() + get => new JObject() { { JwtRegisteredClaimNames.Aud, Audience }, { JwtRegisteredClaimNames.Azp, Azp }, @@ -525,11 +477,21 @@ public static Dictionary PayloadDictionary }; } - public static Dictionary PayloadDictionaryMultipleAudiences + public static string PayloadString + { + get => PayloadAsJObject.ToString(Formatting.None); + } + + public static Dictionary PayloadDictionary + { + get => PayloadAsJObject.ToObject>(); + } + + public static JObject PayloadAsJObjectMultipleAudiences { - get => new Dictionary() + get => new JObject() { - { JwtRegisteredClaimNames.Aud, JsonSerializerPrimitives.CreateJsonElement(Default.Audiences) }, + { JwtRegisteredClaimNames.Aud, JArray.FromObject(Audiences) }, { JwtRegisteredClaimNames.Azp, Azp }, { JwtRegisteredClaimNames.Email, "Bob@contoso.com" }, { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, @@ -541,6 +503,16 @@ public static Dictionary PayloadDictionaryMultipleAudiences }; } + public static string PayloadStringMultipleAudiences + { + get => PayloadAsJObjectMultipleAudiences.ToString(Formatting.None); + } + + public static Dictionary PayloadDictionaryMultipleAudiences + { + get => PayloadAsJObjectMultipleAudiences.ToObject>(); + } + public static Dictionary RemoveClaim(this Dictionary payloadClaims, string claimName) { payloadClaims.Remove(claimName); @@ -862,17 +834,7 @@ public static List SamlClaims /// public static Dictionary SamlClaimsDictionary { - get => new Dictionary() - { - { ClaimTypes.Country, "USA"}, - { ClaimTypes.NameIdentifier, "Bob" }, - { ClaimTypes.Email, "Bob@contoso.com" }, - { ClaimTypes.GivenName, "Bob" }, - { ClaimTypes.HomePhone, "555.1212" }, - { ClaimTypes.Role, new List{"Developer", "Sales" } }, - { ClaimTypes.StreetAddress, "123AnyWhereStreet\r\nSomeTown/r/nUSA" }, - { ClaimsIdentity.DefaultNameClaimType, "Jean-S�bastien" } - }; + get => SamlClaims.ToDictionary(x => x.Type, x => (object)x.Value); } /// diff --git a/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs b/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs index 4baa159ad7..52b1d217bf 100644 --- a/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs +++ b/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs @@ -373,16 +373,13 @@ public static string SamlToken_Formated // { "int", 123 }. public static string JWSWithSingleAdditionalHeaderClaim = "eyJhbGciOiJSUzI1NiIsImtpZCI6Ikpzb25XZWJLZXlSc2FfMjA0OCIsInR5cCI6IkpXVCIsImludCI6MTIzfQ.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTQ4OTc3NTYxNyIsIm5iZiI6IjE0ODk3NzU2MTciLCJleHAiOiIyNTM0MDIzMDA3OTkifQ.DhPiCtD9HWTjG5LDCW8YxSaBXffmPosGnnKINuey6ec50Yf72SzBnMDVZ4Cw9S_SyqSRIxVs0x87g0ZUP8fytUxr_D7ksf0cBI9tqh2MgoAZ2lY8T8oflfIBaTLraZHRmjRCMZGdOLmGj__xqM7mmD0Y1grwAkQgMCLlze2qgCXmym_8jAWfSLQcNc-XNUaDZBlbgebic7TZ0INa93QcJvm_ov6t_rg90Y0l4xCxL_VOdXctdbc5D87bEaaAdqThfVMA1325JZdS_CBWVelLf5zZYPldVDxnD9l93Fy0gqWTWJ0QxMP-BDMgXbQQdUDoSC5HrxXU2JRXnF8V_V4G2g"; - // This token is unsigned and includes one additional header claim: // { "int", 123 }. public static string UnsignedJWSWithSingleAdditionalHeaderClaim = "eyJhbGciOiJub25lIiwidHlwIjoiSldUIiwiaW50IjoxMjN9.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTQ4OTc3NTYxNyIsIm5iZiI6IjE0ODk3NzU2MTciLCJleHAiOiIyNTM0MDIzMDA3OTkifQ."; - // the following values are separate from the one in Default.cs, so we can change the Defaults - // Do not change any of these values either adding new values or order or the tests will break. - public static Dictionary PayloadDictionary + public static JObject PayloadAsJObject { - get => new Dictionary() + get => new JObject() { { JwtRegisteredClaimNames.Email, "Bob@contoso.com" }, { JwtRegisteredClaimNames.GivenName, "Bob" }, @@ -390,22 +387,18 @@ public static Dictionary PayloadDictionary { JwtRegisteredClaimNames.Aud, Audience }, { JwtRegisteredClaimNames.Iat, EpochTime.GetIntDate(IssueInstant).ToString() }, { JwtRegisteredClaimNames.Nbf, EpochTime.GetIntDate(NotBefore).ToString()}, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() } + { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, }; } public static string PayloadString { - get => new JObject() - { - { JwtRegisteredClaimNames.Email, "Bob@contoso.com" }, - { JwtRegisteredClaimNames.GivenName, "Bob" }, - { JwtRegisteredClaimNames.Iss, Issuer }, - { JwtRegisteredClaimNames.Aud, Audience }, - { JwtRegisteredClaimNames.Iat, EpochTime.GetIntDate(IssueInstant).ToString() }, - { JwtRegisteredClaimNames.Nbf, EpochTime.GetIntDate(NotBefore).ToString()}, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, - }.ToString(Formatting.None); + get => PayloadAsJObject.ToString(Formatting.None); + } + + public static Dictionary PayloadDictionary + { + get => PayloadAsJObject.ToObject>(); } public static string Audience From 0f819a140cd2afc3f1258ca68163bfbed78dc49f Mon Sep 17 00:00:00 2001 From: trwalke Date: Wed, 30 Oct 2024 19:16:39 -0700 Subject: [PATCH 2/5] clean up --- test/Microsoft.IdentityModel.TestUtils/Default.cs | 2 -- 1 file changed, 2 deletions(-) diff --git a/test/Microsoft.IdentityModel.TestUtils/Default.cs b/test/Microsoft.IdentityModel.TestUtils/Default.cs index 0805a1ab89..4a6bdb8210 100644 --- a/test/Microsoft.IdentityModel.TestUtils/Default.cs +++ b/test/Microsoft.IdentityModel.TestUtils/Default.cs @@ -8,9 +8,7 @@ using System.Security.Claims; using System.Security.Cryptography; using System.Security.Cryptography.X509Certificates; -using System.Xml.Linq; using Microsoft.IdentityModel.Tokens; -using Microsoft.IdentityModel.Tokens.Json; using Microsoft.IdentityModel.Tokens.Saml; using Microsoft.IdentityModel.Tokens.Saml2; using Microsoft.IdentityModel.Xml; From 3e0b85ac0c4706d7478152aa426f442f65964a17 Mon Sep 17 00:00:00 2001 From: trwalke Date: Wed, 30 Oct 2024 23:30:40 -0700 Subject: [PATCH 3/5] Test Update --- .../Default.cs | 29 ++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/test/Microsoft.IdentityModel.TestUtils/Default.cs b/test/Microsoft.IdentityModel.TestUtils/Default.cs index 4a6bdb8210..fae32a4119 100644 --- a/test/Microsoft.IdentityModel.TestUtils/Default.cs +++ b/test/Microsoft.IdentityModel.TestUtils/Default.cs @@ -829,10 +829,37 @@ public static List SamlClaims /// /// SamlClaims require the ability to split into name / namespace + /// The claims are added as a list /// public static Dictionary SamlClaimsDictionary { - get => SamlClaims.ToDictionary(x => x.Type, x => (object)x.Value); + get + { + Dictionary dictionary = new Dictionary(); + + foreach (Claim claim in SamlClaims) + { + if (dictionary.ContainsKey(claim.Type)) + { + if (claim.Type == ClaimTypes.Role) + { + ((List)dictionary[claim.Type]).Add(claim.Value); + } + } + else + { + if (claim.Type == ClaimTypes.Role) + { + dictionary[claim.Type] = new List { claim.Value }; + } + else + { + dictionary[claim.Type] = claim.Value; + } + } + } + return dictionary; + } } /// From 0fd8f4308cf170a97eafec1af138fc78a58a12fb Mon Sep 17 00:00:00 2001 From: Travis Walker Date: Thu, 31 Oct 2024 18:00:03 -0700 Subject: [PATCH 4/5] Update test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs --- test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs b/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs index 52b1d217bf..eb0fd7a2ce 100644 --- a/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs +++ b/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs @@ -387,7 +387,7 @@ public static JObject PayloadAsJObject { JwtRegisteredClaimNames.Aud, Audience }, { JwtRegisteredClaimNames.Iat, EpochTime.GetIntDate(IssueInstant).ToString() }, { JwtRegisteredClaimNames.Nbf, EpochTime.GetIntDate(NotBefore).ToString()}, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, + { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() } }; } From 376c1ce0b4dde75e54b2bd2935d224d2e1bee716 Mon Sep 17 00:00:00 2001 From: trwalke Date: Fri, 1 Nov 2024 11:16:16 -0700 Subject: [PATCH 5/5] Update --- test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs b/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs index eb0fd7a2ce..52b1d217bf 100644 --- a/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs +++ b/test/Microsoft.IdentityModel.TestUtils/ReferenceTokens.cs @@ -387,7 +387,7 @@ public static JObject PayloadAsJObject { JwtRegisteredClaimNames.Aud, Audience }, { JwtRegisteredClaimNames.Iat, EpochTime.GetIntDate(IssueInstant).ToString() }, { JwtRegisteredClaimNames.Nbf, EpochTime.GetIntDate(NotBefore).ToString()}, - { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() } + { JwtRegisteredClaimNames.Exp, EpochTime.GetIntDate(Expires).ToString() }, }; }