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
- CompoundFileStreamReference.cs
- DefinitionBase.cs
- XmlEncApr2001.cs
- SelectionWordBreaker.cs
- TextProperties.cs
- SqlOuterApplyReducer.cs
- QilFactory.cs
- AdCreatedEventArgs.cs
- StylusPointPropertyInfo.cs
- XamlRtfConverter.cs
- ObjectSpanRewriter.cs
- LinkLabel.cs
- ReferencedAssemblyResolver.cs
- Command.cs
- DiffuseMaterial.cs
- XmlSchemaInfo.cs
- listviewsubitemcollectioneditor.cs
- PrimitiveXmlSerializers.cs
- CollectionBase.cs
- SpeechAudioFormatInfo.cs
- SolidColorBrush.cs
- XsdBuildProvider.cs
- GeometryModel3D.cs
- ApplyImportsAction.cs
- LinqDataSourceDisposeEventArgs.cs
- LongValidatorAttribute.cs
- SymbolEqualComparer.cs
- RegexWriter.cs
- CompilerGeneratedAttribute.cs
- ScrollChrome.cs
- CachingHintValidation.cs
- PersistencePipeline.cs
- NotImplementedException.cs
- PeerInvitationResponse.cs
- IndexerNameAttribute.cs
- SoapSchemaImporter.cs
- DefaultSection.cs
- SelectionChangedEventArgs.cs
- FormsAuthenticationTicket.cs
- RijndaelManagedTransform.cs
- QuaternionValueSerializer.cs
- TextTreePropertyUndoUnit.cs
- DashStyles.cs
- Rfc2898DeriveBytes.cs
- DictionaryMarkupSerializer.cs
- DynamicValidatorEventArgs.cs
- SystemMulticastIPAddressInformation.cs
- ErrorRuntimeConfig.cs
- SrgsElementList.cs
- TextClipboardData.cs
- ScriptResourceInfo.cs
- BooleanKeyFrameCollection.cs
- ToolStrip.cs
- CSharpCodeProvider.cs
- Type.cs
- TextRangeSerialization.cs
- NumericUpDown.cs
- CAGDesigner.cs
- XmlAtomicValue.cs
- InterleavedZipPartStream.cs
- WindowsTitleBar.cs
- WebScriptEnablingBehavior.cs
- ReaderWriterLock.cs
- GridEntry.cs
- DataViewSetting.cs
- DefaultDialogButtons.cs
- CategoryNameCollection.cs
- SecurityUtils.cs
- ExceptionUtility.cs
- CfgParser.cs
- InvokeGenerator.cs
- TableLayout.cs
- DesignerUtility.cs
- ThemeableAttribute.cs
- MimeMultiPart.cs
- MULTI_QI.cs
- ToolTipAutomationPeer.cs
- WebCodeGenerator.cs
- WebPartEditVerb.cs
- UntypedNullExpression.cs
- ConfigXmlWhitespace.cs
- SafeSecurityHelper.cs
- GeneralTransform3DGroup.cs
- SqlError.cs
- MailFileEditor.cs
- ByValueEqualityComparer.cs
- EncoderReplacementFallback.cs
- diagnosticsswitches.cs
- WebService.cs
- AsyncContentLoadedEventArgs.cs
- Matrix3DValueSerializer.cs
- BlurBitmapEffect.cs
- ChildTable.cs
- ObjectDataSourceEventArgs.cs
- IWorkflowDebuggerService.cs
- NameValuePermission.cs
- PackWebResponse.cs
- ElementHostAutomationPeer.cs
- PerformanceCounterPermissionEntryCollection.cs
- Decoder.cs