Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / ServiceModel / System / ServiceModel / ServiceSecurityContext.cs / 1 / ServiceSecurityContext.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace System.ServiceModel { using System; using System.ServiceModel.Channels; using System.ServiceModel.Security; using System.IdentityModel.Claims; using System.IdentityModel.Policy; using System.IdentityModel.Tokens; using System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Security.Principal; public class ServiceSecurityContext { static ServiceSecurityContext anonymous; ReadOnlyCollectionauthorizationPolicies; AuthorizationContext authorizationContext; IIdentity primaryIdentity; Claim identityClaim; WindowsIdentity windowsIdentity; // Perf: delay created authorizationContext using forward chain. public ServiceSecurityContext(ReadOnlyCollection authorizationPolicies) { if (authorizationPolicies == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("authorizationPolicies"); } this.authorizationContext = null; this.authorizationPolicies = authorizationPolicies; } public ServiceSecurityContext(AuthorizationContext authorizationContext) : this(authorizationContext, EmptyReadOnlyCollection .Instance) { } public ServiceSecurityContext(AuthorizationContext authorizationContext, ReadOnlyCollection authorizationPolicies) { if (authorizationContext == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("authorizationContext"); } if (authorizationPolicies == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("authorizationPolicies"); } this.authorizationContext = authorizationContext; this.authorizationPolicies = authorizationPolicies; } public static ServiceSecurityContext Anonymous { get { if (anonymous == null) { anonymous = new ServiceSecurityContext(EmptyReadOnlyCollection .Instance); } return anonymous; } } public static ServiceSecurityContext Current { get { ServiceSecurityContext result = null; OperationContext operationContext = OperationContext.Current; if (operationContext != null) { MessageProperties properties = operationContext.IncomingMessageProperties; if (properties != null) { SecurityMessageProperty security = properties.Security; if (security != null) { result = security.ServiceSecurityContext; } } } return result; } } public bool IsAnonymous { get { return this == Anonymous || this.IdentityClaim == null; } } internal Claim IdentityClaim { get { if (this.identityClaim == null) { this.identityClaim = SecurityUtils.GetPrimaryIdentityClaim(this.AuthorizationContext); } return this.identityClaim; } } public IIdentity PrimaryIdentity { get { if (this.primaryIdentity == null) { IIdentity primaryIdentity = null; IList identities = GetIdentities(); // Multiple Identities is treated as anonymous if (identities != null && identities.Count == 1) { primaryIdentity = identities[0]; } this.primaryIdentity = primaryIdentity ?? SecurityUtils.AnonymousIdentity; } return this.primaryIdentity; } } public WindowsIdentity WindowsIdentity { get { if (this.windowsIdentity == null) { WindowsIdentity windowsIdentity = null; IList identities = GetIdentities(); if (identities != null) { for (int i = 0; i < identities.Count; ++i) { WindowsIdentity identity = identities[i] as WindowsIdentity; if (identity != null) { // Multiple Identities is treated as anonymous if (windowsIdentity != null) { windowsIdentity = WindowsIdentity.GetAnonymous(); break; } windowsIdentity = identity; } } } this.windowsIdentity = windowsIdentity ?? WindowsIdentity.GetAnonymous(); } return this.windowsIdentity; } } public ReadOnlyCollection AuthorizationPolicies { get { return this.authorizationPolicies; } } public AuthorizationContext AuthorizationContext { get { if (this.authorizationContext == null) { this.authorizationContext = AuthorizationContext.CreateDefaultAuthorizationContext(this.authorizationPolicies); } return this.authorizationContext; } } IList GetIdentities() { object identities; AuthorizationContext authContext = this.AuthorizationContext; if (authContext != null && authContext.Properties.TryGetValue(SecurityUtils.Identities, out identities)) { return identities as IList ; } return null; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SmtpDigestAuthenticationModule.cs
- shaper.cs
- NegotiateStream.cs
- FunctionCommandText.cs
- AccessDataSource.cs
- GroupItem.cs
- DecoratedNameAttribute.cs
- TypeResolvingOptions.cs
- SelectingProviderEventArgs.cs
- HyperLinkField.cs
- TracedNativeMethods.cs
- TripleDESCryptoServiceProvider.cs
- ExpressionStringBuilder.cs
- CachedCompositeFamily.cs
- WebPartManagerInternals.cs
- FusionWrap.cs
- RtfNavigator.cs
- MetadataPropertyCollection.cs
- FormsAuthenticationTicket.cs
- FrameworkElementFactoryMarkupObject.cs
- HwndSourceKeyboardInputSite.cs
- NamespaceInfo.cs
- BindingExpressionUncommonField.cs
- ObjectStateEntryDbUpdatableDataRecord.cs
- TableHeaderCell.cs
- TreeViewImageIndexConverter.cs
- Semaphore.cs
- DrawTreeNodeEventArgs.cs
- ExpressionBindingCollection.cs
- WaitHandleCannotBeOpenedException.cs
- ContractListAdapter.cs
- ResourceReader.cs
- TransformerConfigurationWizardBase.cs
- Translator.cs
- Light.cs
- CodeExporter.cs
- XslCompiledTransform.cs
- SocketInformation.cs
- ByteStack.cs
- DataGridColumnHeaderAutomationPeer.cs
- SharedRuntimeState.cs
- TagElement.cs
- Bookmark.cs
- DataSourceControlBuilder.cs
- LookupBindingPropertiesAttribute.cs
- UpdateInfo.cs
- StrokeNodeOperations2.cs
- BookmarkTable.cs
- RequestDescription.cs
- ProxyWebPartConnectionCollection.cs
- ConfigurationSettings.cs
- GetWinFXPath.cs
- HtmlInputImage.cs
- DataGridViewLinkColumn.cs
- GiveFeedbackEvent.cs
- XmlDocumentFragment.cs
- BlockCollection.cs
- BamlBinaryReader.cs
- Point3DCollection.cs
- RenderContext.cs
- SqlVisitor.cs
- XLinq.cs
- WsatAdminException.cs
- Int16AnimationUsingKeyFrames.cs
- XamlBrushSerializer.cs
- OdbcPermission.cs
- UnregisterInfo.cs
- DataGridItemEventArgs.cs
- HwndSourceParameters.cs
- ToolStripProfessionalLowResolutionRenderer.cs
- EntityRecordInfo.cs
- BamlTreeMap.cs
- ApplicationSecurityManager.cs
- ToolStripDropTargetManager.cs
- InputMethodStateTypeInfo.cs
- QueryContinueDragEvent.cs
- TextServicesCompartment.cs
- TextTreeTextBlock.cs
- SafeFileHandle.cs
- XmlTextReaderImplHelpers.cs
- CallSiteBinder.cs
- Constant.cs
- GridViewDeleteEventArgs.cs
- NameSpaceExtractor.cs
- SyndicationSerializer.cs
- ListBase.cs
- XmlSchemaComplexType.cs
- StateDesigner.LayoutSelectionGlyph.cs
- AutomationPatternInfo.cs
- SimpleRecyclingCache.cs
- Timer.cs
- TailCallAnalyzer.cs
- SyndicationSerializer.cs
- XmlChoiceIdentifierAttribute.cs
- ServiceDescriptionSerializer.cs
- ObjectComplexPropertyMapping.cs
- DefaultPrintController.cs
- DocumentReference.cs
- Hex.cs
- Matrix3D.cs