本文整理汇总了C#中IdentityProvider类的典型用法代码示例。如果您正苦于以下问题:C# IdentityProvider类的具体用法?C# IdentityProvider怎么用?C# IdentityProvider使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
IdentityProvider类属于命名空间,在下文中一共展示了IdentityProvider类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: IdentityProvider_CreateAuthenticateRequest_Destination
public void IdentityProvider_CreateAuthenticateRequest_Destination()
{
string idpUri = "http://idp.example.com/";
var ip = new IdentityProvider(new Uri(idpUri));
var r = ip.CreateAuthenticateRequest(null);
r.ToXElement().Attribute("Destination").Should().NotBeNull()
.And.Subject.Value.Should().Be(idpUri);
}
示例2: IdentityProviderDictionary_Add
public void IdentityProviderDictionary_Add()
{
var subject = new IdentityProviderDictionary();
var entityId = new EntityId("http://idp.example.com");
var idp = new IdentityProvider(entityId, StubFactory.CreateSPOptions());
subject.Add(idp);
subject[entityId].Should().BeSameAs(idp);
}
示例3: Add
/// <summary>
/// Add an identity provider to the collection..
/// </summary>
/// <param name="idp">Identity provider to add.</param>
public void Add(IdentityProvider idp)
{
if(idp == null)
{
throw new ArgumentNullException("idp");
}
lock(dictionary)
{
dictionary.Add(idp.EntityId, idp);
}
}
示例4: IdentityProvider_CreateAuthenticateRequest_DestinationInXml
public void IdentityProvider_CreateAuthenticateRequest_DestinationInXml()
{
string idpUri = "http://idp.example.com/";
var subject = new IdentityProvider(
new EntityId(idpUri),
Options.FromConfiguration.SPOptions)
{
SingleSignOnServiceUrl = new Uri(idpUri)
};
var r = subject.CreateAuthenticateRequest(null, StubFactory.CreateAuthServicesUrls());
r.ToXElement().Attribute("Destination").Should().NotBeNull()
.And.Subject.Value.Should().Be(idpUri);
}
示例5: IdentityProvider_Ctor_HandlesConfiguredCertificateWhenReadingMetadata
public void IdentityProvider_Ctor_HandlesConfiguredCertificateWhenReadingMetadata()
{
var config = CreateConfig();
config.LoadMetadata = true;
config.EntityId = "http://localhost:13428/idpMetadataNoCertificate";
var subject = new IdentityProvider(config, Options.FromConfiguration.SPOptions);
// Check that metadata was read and overrides configured values.
subject.Binding.Should().Be(Saml2BindingType.HttpRedirect);
subject.SigningKeys.Single().ShouldBeEquivalentTo(
new X509RawDataKeyIdentifierClause(SignedXmlHelper.TestCert));
}
示例6: IdentityProvider_Ctor_DisableOutboundLogoutRequest
public void IdentityProvider_Ctor_DisableOutboundLogoutRequest()
{
var config = CreateConfig();
config.DisableOutboundLogoutRequests = true;
var subject = new IdentityProvider(config, StubFactory.CreateSPOptions());
subject.DisableOutboundLogoutRequests.Should().BeTrue();
}
示例7: IdentityProvider_ReadMetadata_Nullcheck
public void IdentityProvider_ReadMetadata_Nullcheck()
{
var subject = new IdentityProvider(
new EntityId("http://idp.example.com"),
StubFactory.CreateSPOptions());
Action a = () => subject.ReadMetadata(null);
a.ShouldThrow<ArgumentNullException>().And.ParamName.Should().Be("metadata");
}
示例8: IdentityProvider_MetadataValidUntil_CalculatedFromCacheDuration
public void IdentityProvider_MetadataValidUntil_CalculatedFromCacheDuration()
{
var config = CreateConfig();
config.LoadMetadata = true;
config.EntityId = "http://localhost:13428/idpMetadataNoCertificate";
var subject = new IdentityProvider(config, Options.FromConfiguration.SPOptions);
var expectedValidUntil = DateTime.UtcNow.AddMinutes(15);
// Comparison on the second is more than enough if we're adding 15 minutes.
subject.MetadataValidUntil.Should().BeCloseTo(expectedValidUntil, 1000);
}
示例9: IdentityProvider_MetadataValidUntil_NullOnConfigured
public void IdentityProvider_MetadataValidUntil_NullOnConfigured()
{
string idpUri = "http://idp.example.com/";
var subject = new IdentityProvider(
new EntityId(idpUri),
Options.FromConfiguration.SPOptions);
subject.MetadataValidUntil.Should().NotHaveValue();
}
示例10: IdentityProvider_Ctor_UseMetadataLocationUrl
public void IdentityProvider_Ctor_UseMetadataLocationUrl()
{
var config = CreateConfig();
config.LoadMetadata = true;
config.MetadataLocation = "http://localhost:13428/idpMetadataDifferentEntityId";
config.EntityId = "some-idp";
var subject = new IdentityProvider(config, Options.FromConfiguration.SPOptions);
subject.Binding.Should().Be(Saml2BindingType.HttpRedirect);
subject.SingleSignOnServiceUrl.Should().Be("http://idp.example.com/SsoService");
}
示例11: IdentityProvider_MetadataLocation_ThrowsWhenEntitiesDescriptorFoundAndNotAllowedByConfig
public void IdentityProvider_MetadataLocation_ThrowsWhenEntitiesDescriptorFoundAndNotAllowedByConfig()
{
var spOptions = StubFactory.CreateSPOptions();
spOptions.Compatibility.UnpackEntitiesDescriptorInIdentityProviderMetadata.Should().BeFalse();
var subject = new IdentityProvider(
new EntityId("http://idp.example.com"),
spOptions);
Action a = () => subject.MetadataLocation = "~/Metadata/SingleIdpInEntitiesDescriptor.xml";
a.ShouldThrow<InvalidOperationException>();
}
示例12: TryGetValue
/// <summary>
/// Try to get the value of an idp with a given entity id.
/// </summary>
/// <param name="idpEntityId">Entity id to search for.</param>
/// <param name="idp">The idp, if found.</param>
/// <returns>True if an idp with the given entity id was found.</returns>
public bool TryGetValue(EntityId idpEntityId, out IdentityProvider idp)
{
lock (dictionary)
{
return dictionary.TryGetValue(idpEntityId, out idp);
}
}
示例13: IdentityProvider_Ctor_LogoutBindingDefaultsToBinding
public void IdentityProvider_Ctor_LogoutBindingDefaultsToBinding()
{
var config = CreateConfig();
var subject = new IdentityProvider(config, StubFactory.CreateSPOptions());
subject.Binding.Should().Be(Saml2BindingType.HttpPost);
subject.SingleLogoutServiceBinding.Should().Be(Saml2BindingType.HttpPost);
}
示例14: Saml2Response_GetClaims_CorrectSignedResponseMessageSecondaryKey
public void Saml2Response_GetClaims_CorrectSignedResponseMessageSecondaryKey()
{
var response =
@"<?xml version=""1.0"" encoding=""UTF-8""?>
<saml2p:Response xmlns:saml2p=""urn:oasis:names:tc:SAML:2.0:protocol""
xmlns:saml2=""urn:oasis:names:tc:SAML:2.0:assertion""
ID = """ + MethodBase.GetCurrentMethod().Name + @""" Version=""2.0"" IssueInstant=""2013-01-01T00:00:00Z"">
<saml2:Issuer>https://twokeys.example.com</saml2:Issuer>
<saml2p:Status>
<saml2p:StatusCode Value=""urn:oasis:names:tc:SAML:2.0:status:Success"" />
</saml2p:Status>
<saml2:Assertion xmlns:saml2=""urn:oasis:names:tc:SAML:2.0:assertion""
Version=""2.0"" ID=""" + MethodBase.GetCurrentMethod().Name + @"_Assertion1""
IssueInstant=""2013-09-25T00:00:00Z"">
<saml2:Issuer>https://twokeys.example.com</saml2:Issuer>
<saml2:Subject>
<saml2:NameID>SomeUser</saml2:NameID>
<saml2:SubjectConfirmation Method=""urn:oasis:names:tc:SAML:2.0:cm:bearer"" />
</saml2:Subject>
<saml2:Conditions NotOnOrAfter=""2100-01-01T00:00:00Z"" />
</saml2:Assertion>
</saml2p:Response>";
var signedResponse = SignedXmlHelper.SignXml(response);
var options = StubFactory.CreateOptions();
var idp = new IdentityProvider(
new EntityId("https://twokeys.example.com"), options.SPOptions)
{
AllowUnsolicitedAuthnResponse = true
};
idp.SigningKeys.AddConfiguredKey(SignedXmlHelper.TestKey2);
idp.SigningKeys.AddConfiguredKey(SignedXmlHelper.TestKey);
options.IdentityProviders.Add(idp);
Action a = () => Saml2Response.Read(signedResponse).GetClaims(options);
a.ShouldNotThrow();
}
示例15: send_requestAccountPasswordReset
public void send_requestAccountPasswordReset(IdentityProvider provider, string identifier, string locale)
#endif
{
oprot_.WriteMessageBegin(new TMessage("requestAccountPasswordReset", TMessageType.Call, seqid_));
requestAccountPasswordReset_args args = new requestAccountPasswordReset_args();
args.Provider = provider;
args.Identifier = identifier;
args.Locale = locale;
args.Write(oprot_);
oprot_.WriteMessageEnd();
#if SILVERLIGHT
return oprot_.Transport.BeginFlush(callback, state);
#else
oprot_.Transport.Flush();
#endif
}