// Decompiled with JetBrains decompiler // Type: Microsoft.InfoCards.GetBrowserTokenParameters // Assembly: infocard, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 // MVID: ADE0A079-11DB-4A46-8BDE-D2A592CA8DEA // Assembly location: C:\Users\Administrateur\Downloads\Virusshare-00000-msil\Virus.Win32.Expiro.w-67b630ead60119692b9abbdfd8717c96904ef041127c2cae033c86b718eaa61e.exe using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.IdentityModel.Selectors; using System.IdentityModel.Tokens; using System.IO; using System.ServiceModel.Security; using System.ServiceModel.Security.Tokens; using System.Xml; namespace Microsoft.InfoCards { internal class GetBrowserTokenParameters { private GetBrowserTokenEndpoint m_recipient; private GetBrowserTokenEndpoint m_issuer; private Uri m_tokenType; private List<string> m_requiredClaims; private List<string> m_optionalClaims; private int m_flags; private uint m_privacyVersion; private Uri m_privacyUrl; public GetBrowserTokenParameters() { this.m_recipient = new GetBrowserTokenEndpoint(); this.m_issuer = new GetBrowserTokenEndpoint(); this.m_requiredClaims = new List<string>(); this.m_optionalClaims = new List<string>(); } public GetBrowserTokenEndpoint Recipient => this.m_recipient; public GetBrowserTokenEndpoint Issuer => this.m_issuer; public IList<string> RequiredClaims => (IList<string>) this.m_requiredClaims.AsReadOnly(); public IList<string> OptionalClaims => (IList<string>) this.m_optionalClaims.AsReadOnly(); public Uri PrivacyUrl => this.m_privacyUrl; public uint PrivacyVersion => this.m_privacyVersion; public void Load(BinaryReader reader, int paramVersion) { this.m_flags = paramVersion; this.m_recipient.Load(reader, paramVersion); this.m_issuer.Load(reader, paramVersion); string uriString1 = Utility.DeserializeString(reader); if (!string.IsNullOrEmpty(uriString1)) this.m_tokenType = new Uri(uriString1); int num1 = reader.ReadInt32(); for (int index = 0; index < num1; ++index) this.m_requiredClaims.Add(Utility.DeserializeString(reader)); int num2 = reader.ReadInt32(); for (int index = 0; index < num2; ++index) this.m_optionalClaims.Add(Utility.DeserializeString(reader)); this.m_privacyVersion = reader.ReadUInt32(); string uriString2 = Utility.DeserializeString(reader); if (!string.IsNullOrEmpty(uriString2)) this.m_privacyUrl = new Uri(uriString2); else this.m_privacyUrl = (Uri) null; } public CardSpacePolicyElement CreatePolicyElement( ProtocolProfile protocolProfile) { XmlDocument document = new XmlDocument(); XmlElement element = document.CreateElement(protocolProfile.WSTrust.DefaultPrefix, protocolProfile.WSTrust.ClaimsElement, protocolProfile.WSTrust.Namespace); foreach (string requiredClaim in (IEnumerable<string>) this.RequiredClaims) element.AppendChild((XmlNode) GetBrowserTokenParameters.CreateClaimElement(document, requiredClaim, false)); foreach (string optionalClaim in (IEnumerable<string>) this.OptionalClaims) element.AppendChild((XmlNode) GetBrowserTokenParameters.CreateClaimElement(document, optionalClaim, true)); IssuedSecurityTokenParameters securityTokenParameters = new IssuedSecurityTokenParameters(); if ((Uri) null != this.m_tokenType) securityTokenParameters.TokenType = this.m_tokenType.ToString(); securityTokenParameters.AdditionalRequestParameters.Add(element); Collection<XmlElement> requestParameters = securityTokenParameters.CreateRequestParameters(protocolProfile.MsgSecurityVersion, (SecurityTokenSerializer) new WSSecurityTokenSerializer(protocolProfile.MsgSecurityVersion.SecurityVersion, true, (SamlSerializer) null, (SecurityStateEncoder) null, (IEnumerable<Type>) null)); foreach (XmlElement xmlElement in requestParameters) { if (StringComparer.Ordinal.Equals(xmlElement.LocalName, protocolProfile.WSTrust.KeyType) && StringComparer.Ordinal.Equals(xmlElement.NamespaceURI, protocolProfile.WSTrust.Namespace)) { xmlElement.RemoveAll(); xmlElement.AppendChild((XmlNode) xmlElement.OwnerDocument.CreateTextNode(protocolProfile.WSTrust.KeyTypeBearer.OriginalString)); break; } } return new CardSpacePolicyElement(this.m_recipient != null ? this.m_recipient.CreateEndpointAddressXml() : (XmlElement) null, this.m_issuer != null ? this.m_issuer.CreateEndpointAddressXml() : (XmlElement) null, requestParameters, this.m_privacyUrl, Convert.ToInt32(this.m_privacyVersion), false); } private static XmlElement CreateClaimElement( XmlDocument document, string claimUri, bool optional) { XmlElement element = document.CreateElement("wsid", "ClaimType", "http://schemas.xmlsoap.org/ws/2005/05/identity"); element.SetAttribute("Uri", claimUri); if (optional) element.SetAttribute("Optional", "true"); return element; } } }