1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
//------------------------------------------------------------------------------
// <copyright file="CallbackValidatorAttribute.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
//------------------------------------------------------------------------------
using System;
using System.Configuration.Internal;
using System.Collections;
using System.Collections.Specialized;
using System.Collections.Generic;
using System.IO;
using System.Reflection;
using System.Security.Permissions;
using System.Xml;
using System.Globalization;
using System.ComponentModel;
using System.Security;
using System.Text;
namespace System.Configuration {
[AttributeUsage(AttributeTargets.Property)]
public sealed class CallbackValidatorAttribute : ConfigurationValidatorAttribute {
private Type _type = null;
private String _callbackMethodName = String.Empty;
private ValidatorCallback _callbackMethod;
public override ConfigurationValidatorBase ValidatorInstance {
get {
if (_callbackMethod == null) {
if (_type == null) {
throw new ArgumentNullException("Type");
}
if (!String.IsNullOrEmpty(_callbackMethodName)) {
MethodInfo methodInfo = _type.GetMethod(_callbackMethodName, BindingFlags.Public | BindingFlags.Static);
if (methodInfo != null) {
ParameterInfo[] parameters = methodInfo.GetParameters();
if ((parameters.Length == 1) && (parameters[0].ParameterType == typeof(Object))) {
// The security here depends on nobody changing the type or callback method once the declaring type has been
// set. This currently isn't an issue since the attribute is instantiated then the declaring type is set without
// user code having gotten a chance to run in between. But if the behavior of PropertyInfo.GetAttributes ever
// changes such that it returns cached attribute instances rather than new instances every time, this assumption is void.
_callbackMethod = (ValidatorCallback)TypeUtil.CreateDelegateRestricted(_declaringType, typeof(ValidatorCallback), methodInfo);
}
}
}
}
if (_callbackMethod == null) {
throw new System.ArgumentException(SR.GetString(SR.Validator_method_not_found, _callbackMethodName));
}
return new CallbackValidator(_callbackMethod);
}
}
public CallbackValidatorAttribute() {
}
public Type Type {
get {
return _type;
}
set {
_type = value;
_callbackMethod = null;
}
}
public String CallbackMethodName {
get {
return _callbackMethodName;
}
set {
_callbackMethodName = value;
_callbackMethod = null;
}
}
}
}
|