//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//------------------------------------------------------------------------------
namespace System.Web.UI.WebControls {
using System;
using System.ComponentModel;
using System.Data;
///
/// Represents a Parameter that gets its value from the application's session state.
///
[
DefaultProperty("SessionField"),
]
public class SessionParameter : Parameter {
///
/// Creates an instance of the SessionParameter class.
///
public SessionParameter() {
}
///
/// Creates an instance of the SessionParameter class with the specified parameter name, and session field.
///
public SessionParameter(string name, string sessionField) : base(name) {
SessionField = sessionField;
}
///
/// Creates an instance of the SessionParameter class with the specified parameter name, database type, and
/// session field.
///
public SessionParameter(string name, DbType dbType, string sessionField)
: base(name, dbType) {
SessionField = sessionField;
}
///
/// Creates an instance of the SessionParameter class with the specified parameter name, type, and session field.
///
public SessionParameter(string name, TypeCode type, string sessionField) : base(name, type) {
SessionField = sessionField;
}
///
/// Used to clone a parameter.
///
protected SessionParameter(SessionParameter original) : base(original) {
SessionField = original.SessionField;
}
///
/// The name of the session variable to get the value from.
///
[
DefaultValue(""),
WebCategory("Parameter"),
WebSysDescription(SR.SessionParameter_SessionField),
]
public string SessionField {
get {
object o = ViewState["SessionField"];
if (o == null)
return String.Empty;
return (string)o;
}
set {
if (SessionField != value) {
ViewState["SessionField"] = value;
OnParameterChanged();
}
}
}
///
/// Creates a new SessionParameter that is a copy of this SessionParameter.
///
protected override Parameter Clone() {
return new SessionParameter(this);
}
///
/// Returns the updated value of the parameter.
///
protected internal override object Evaluate(HttpContext context, Control control) {
if (context == null || context.Session == null) {
return null;
}
return context.Session[SessionField];
}
}
}