215 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
// ========================================================================
 | 
						|
// Copyright 2006 - Volian Enterprises, Inc. All rights reserved.          
 | 
						|
// Volian Enterprises - Proprietary Information - DO NOT COPY OR DISTRIBUTE
 | 
						|
// ------------------------------------------------------------------------
 | 
						|
// $Workfile: $     $Revision: $                                           
 | 
						|
// $Author: $   $Date: $                                                   
 | 
						|
//                                                                         
 | 
						|
// $History: $                                                             
 | 
						|
// ========================================================================
 | 
						|
 | 
						|
using System;
 | 
						|
using System.Collections.Generic;
 | 
						|
using System.Collections.Specialized;
 | 
						|
using System.Text;
 | 
						|
using System.IO;
 | 
						|
using System.Xml.Serialization;
 | 
						|
using System.Xml;
 | 
						|
using System.Xml.XPath;
 | 
						|
using Csla;
 | 
						|
using Csla.Data;
 | 
						|
using System.Data.SqlClient;
 | 
						|
using System.Data;
 | 
						|
 | 
						|
namespace VEPROMS.CSLA.Library
 | 
						|
{
 | 
						|
	public partial class RODbInfo
 | 
						|
	{
 | 
						|
		#region RODb Config
 | 
						|
		[NonSerialized]
 | 
						|
		private RODbConfig _RODbConfig;
 | 
						|
		public RODbConfig RODbConfig
 | 
						|
		{ get { return (_RODbConfig != null ? _RODbConfig : _RODbConfig = new RODbConfig(this)); } }
 | 
						|
		private void RODbConfigRefresh()
 | 
						|
		{
 | 
						|
			_RODbConfig = null;
 | 
						|
		}
 | 
						|
		#endregion
 | 
						|
		public static RODbInfo GetJustRODB(int rODbID)
 | 
						|
		{
 | 
						|
			//if (!CanGetObject())
 | 
						|
			//  throw new System.Security.SecurityException("User not authorized to view a RODb");
 | 
						|
			try
 | 
						|
			{
 | 
						|
				RODbInfo tmp = GetCachedByPrimaryKey(rODbID);
 | 
						|
				if (tmp == null)
 | 
						|
				{
 | 
						|
					tmp = DataPortal.Fetch<RODbInfo>(new PKCriteriaJustRODB(rODbID));
 | 
						|
					AddToCache(tmp);
 | 
						|
				}
 | 
						|
				if (tmp.ErrorMessage == "No Record Found")
 | 
						|
				{
 | 
						|
					tmp.Dispose(); // Clean-up RODbInfo
 | 
						|
					tmp = null;
 | 
						|
				}
 | 
						|
				return tmp;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("Error on RODbInfo.Get", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		[Serializable()]
 | 
						|
		protected class PKCriteriaJustRODB
 | 
						|
		{
 | 
						|
			private int _RODbID;
 | 
						|
			public int RODbID
 | 
						|
			{ get { return _RODbID; } }
 | 
						|
			public PKCriteriaJustRODB(int rODbID)
 | 
						|
			{
 | 
						|
				_RODbID = rODbID;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(PKCriteriaJustRODB criteria)
 | 
						|
		{
 | 
						|
			if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] RODbInfo.DataPortal_Fetch", GetHashCode());
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					ApplicationContext.LocalContext["cn"] = cn;
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "getJustRODb";
 | 
						|
						cm.Parameters.AddWithValue("@RODbID", criteria.RODbID);
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							if (!dr.Read())
 | 
						|
							{
 | 
						|
								_ErrorMessage = "No Record Found";
 | 
						|
								return;
 | 
						|
							}
 | 
						|
							ReadData(dr);
 | 
						|
						}
 | 
						|
					}
 | 
						|
					// removing of item only needed for local data portal
 | 
						|
					if (ApplicationContext.ExecutionLocation == ApplicationContext.ExecutionLocations.Client)
 | 
						|
						ApplicationContext.LocalContext.Remove("cn");
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				if (_MyLog.IsErrorEnabled) _MyLog.Error("RODbInfo.DataPortal_Fetch", ex);
 | 
						|
				_ErrorMessage = ex.Message;
 | 
						|
				throw new DbCslaException("RODbInfo.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
	}
 | 
						|
	public partial class RODb
 | 
						|
	{
 | 
						|
		public static RODb GetJustRoDb(int rODbID)
 | 
						|
		{
 | 
						|
			if (!CanGetObject())
 | 
						|
				throw new System.Security.SecurityException("User not authorized to view a RODb");
 | 
						|
			try
 | 
						|
			{
 | 
						|
				RODb tmp = DataPortal.Fetch<RODb>(new PKCriteriaJustRoDb(rODbID));
 | 
						|
				if (tmp.ErrorMessage == "No Record Found")
 | 
						|
				{
 | 
						|
					tmp.Dispose(); // Clean-up RODb
 | 
						|
					tmp = null;
 | 
						|
				}
 | 
						|
				return tmp;
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				throw new DbCslaException("Error on RODb.Get", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void DataPortal_Fetch(PKCriteriaJustRoDb criteria)
 | 
						|
		{
 | 
						|
			if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] RODb.DataPortal_Fetch", GetHashCode());
 | 
						|
			try
 | 
						|
			{
 | 
						|
				using (SqlConnection cn = Database.VEPROMS_SqlConnection)
 | 
						|
				{
 | 
						|
					ApplicationContext.LocalContext["cn"] = cn;
 | 
						|
					using (SqlCommand cm = cn.CreateCommand())
 | 
						|
					{
 | 
						|
						cm.CommandType = CommandType.StoredProcedure;
 | 
						|
						cm.CommandText = "getJustRODb";
 | 
						|
						cm.Parameters.AddWithValue("@RODbID", criteria.RODbID);
 | 
						|
						cm.CommandTimeout = Database.DefaultTimeout;
 | 
						|
						using (SafeDataReader dr = new SafeDataReader(cm.ExecuteReader()))
 | 
						|
						{
 | 
						|
							if (!dr.Read())
 | 
						|
							{
 | 
						|
								_ErrorMessage = "No Record Found";
 | 
						|
								return;
 | 
						|
							}
 | 
						|
							ReadData(dr);
 | 
						|
							// Don't load child objects
 | 
						|
							//dr.NextResult();
 | 
						|
							//_RODbROFsts = RODbROFsts.Get(dr);
 | 
						|
							// load child objects
 | 
						|
							//dr.NextResult();
 | 
						|
							//_RODbROImages = RODbROImages.Get(dr);
 | 
						|
							// load child objects
 | 
						|
							//dr.NextResult();
 | 
						|
							//_RODbRoUsages = RODbRoUsages.Get(dr);
 | 
						|
						}
 | 
						|
					}
 | 
						|
					// removing of item only needed for local data portal
 | 
						|
					if (ApplicationContext.ExecutionLocation == ApplicationContext.ExecutionLocations.Client)
 | 
						|
						ApplicationContext.LocalContext.Remove("cn");
 | 
						|
				}
 | 
						|
			}
 | 
						|
			catch (Exception ex)
 | 
						|
			{
 | 
						|
				if (_MyLog.IsErrorEnabled) _MyLog.Error("RODb.DataPortal_Fetch", ex);
 | 
						|
				_ErrorMessage = ex.Message;
 | 
						|
				throw new DbCslaException("RODb.DataPortal_Fetch", ex);
 | 
						|
			}
 | 
						|
		}
 | 
						|
		[Serializable()]
 | 
						|
		protected class PKCriteriaJustRoDb
 | 
						|
		{
 | 
						|
			private int _RODbID;
 | 
						|
			public int RODbID
 | 
						|
			{ get { return _RODbID; } }
 | 
						|
			public PKCriteriaJustRoDb(int rODbID)
 | 
						|
			{
 | 
						|
				_RODbID = rODbID;
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		#region Log4Net
 | 
						|
		private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
 | 
						|
		#endregion
 | 
						|
 | 
						|
		#region RODb Config
 | 
						|
		[NonSerialized]
 | 
						|
		private RODbConfig _RODbConfig;
 | 
						|
		public RODbConfig RODbConfig
 | 
						|
		{
 | 
						|
			get
 | 
						|
			{
 | 
						|
				if (_RODbConfig == null)
 | 
						|
				{
 | 
						|
					_RODbConfig = new RODbConfig(this);
 | 
						|
					_RODbConfig.PropertyChanged += new System.ComponentModel.PropertyChangedEventHandler(_RODbConfig_PropertyChanged);
 | 
						|
				}
 | 
						|
				return _RODbConfig;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		private void _RODbConfig_PropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e)
 | 
						|
		{
 | 
						|
			Config = _RODbConfig.ToString();
 | 
						|
		}
 | 
						|
		#endregion
 | 
						|
	}
 | 
						|
}
 |