EndpointBehaviorElement.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. //-----------------------------------------------------------------------------
  4. namespace System.ServiceModel.Configuration
  5. {
  6. using System;
  7. using System.ServiceModel;
  8. using System.Collections.Generic;
  9. using System.ComponentModel;
  10. using System.Configuration;
  11. using System.Globalization;
  12. using System.Xml;
  13. public partial class EndpointBehaviorElement : NamedServiceModelExtensionCollectionElement<BehaviorExtensionElement>
  14. {
  15. public EndpointBehaviorElement()
  16. : this(null)
  17. {
  18. }
  19. public EndpointBehaviorElement(string name)
  20. : base(ConfigurationStrings.BehaviorExtensions, name)
  21. {
  22. }
  23. // Verify that the behavior being added implements IEndpointBehavior
  24. public override void Add(BehaviorExtensionElement element)
  25. {
  26. // If element is null, let base.Add() throw for consistency reasons
  27. if (null != element)
  28. {
  29. if (element is ClearBehaviorElement || element is RemoveBehaviorElement)
  30. {
  31. base.AddItem(element);
  32. return;
  33. }
  34. if (!typeof(System.ServiceModel.Description.IEndpointBehavior).IsAssignableFrom(element.BehaviorType))
  35. {
  36. #pragma warning disable 56506 //[....]; element.ElementInformation is guaranteed to be non-null(System.Configuration)
  37. throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(SR.GetString(SR.ConfigInvalidEndpointBehaviorType,
  38. element.ConfigurationElementName,
  39. this.Name),
  40. element.ElementInformation.Source,
  41. element.ElementInformation.LineNumber));
  42. #pragma warning restore
  43. }
  44. }
  45. base.Add(element);
  46. }
  47. // Verify that the behavior being added implements IEndpointBehavior
  48. public override bool CanAdd(BehaviorExtensionElement element)
  49. {
  50. // If element is null, let base.CanAdd() throw for consistency reasons
  51. if (null != element)
  52. {
  53. if (element is ClearBehaviorElement || element is RemoveBehaviorElement)
  54. {
  55. return true;
  56. }
  57. if (!typeof(System.ServiceModel.Description.IEndpointBehavior).IsAssignableFrom(element.BehaviorType))
  58. {
  59. #pragma warning disable 56506 //[....]; element.ElementInformation is guaranteed to be non-null(System.Configuration)
  60. throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(SR.GetString(SR.ConfigInvalidEndpointBehaviorType,
  61. element.ConfigurationElementName,
  62. this.Name),
  63. element.ElementInformation.Source,
  64. element.ElementInformation.LineNumber));
  65. #pragma warning restore
  66. }
  67. }
  68. return base.CanAdd(element);
  69. }
  70. }
  71. }