// ======================================================================== // Copyright 2007 - Volian Enterprises, Inc. All rights reserved. // Volian Enterprises - Proprietary Information - DO NOT COPY OR DISTRIBUTE // ------------------------------------------------------------------------ // $Workfile: $ $Revision: $ // $Author: $ $Date: $ // // $History: $ // ======================================================================== using System; using System.Data; using System.Data.SqlClient; using Csla; using Csla.Data; using System.Configuration; using System.IO; using System.ComponentModel; using System.Collections.Generic; namespace VEPROMS.CSLA.Library { public delegate void EntryAuditInfoEvent(object sender); /// /// EntryAuditInfo Generated by MyGeneration using the CSLA Object Mapping template /// [Serializable()] [TypeConverter(typeof(EntryAuditInfoConverter))] public partial class EntryAuditInfo : ReadOnlyBase, IDisposable { public event EntryAuditInfoEvent Changed; private void OnChange() { if (Changed != null) Changed(this); } #region Log4Net private static readonly log4net.ILog _MyLog = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); #endregion #region Collection private static List _CacheList = new List(); protected static void AddToCache(EntryAuditInfo entryAuditInfo) { if (!_CacheList.Contains(entryAuditInfo)) _CacheList.Add(entryAuditInfo); // In AddToCache } protected static void RemoveFromCache(EntryAuditInfo entryAuditInfo) { while (_CacheList.Contains(entryAuditInfo)) _CacheList.Remove(entryAuditInfo); // In RemoveFromCache } private static Dictionary> _CacheByPrimaryKey = new Dictionary>(); private static void ConvertListToDictionary() { while (_CacheList.Count > 0) // Move EntryAuditInfo(s) from temporary _CacheList to _CacheByPrimaryKey { EntryAuditInfo tmp = _CacheList[0]; // Get the first EntryAuditInfo string pKey = tmp.AuditID.ToString(); if (!_CacheByPrimaryKey.ContainsKey(pKey)) { _CacheByPrimaryKey[pKey] = new List(); // Add new list for PrimaryKey } _CacheByPrimaryKey[pKey].Add(tmp); // Add to Primary Key list _CacheList.RemoveAt(0); // Remove the first EntryAuditInfo } } internal static void AddList(EntryAuditInfoList lst) { foreach (EntryAuditInfo item in lst) AddToCache(item); } protected static EntryAuditInfo GetCachedByPrimaryKey(long auditID) { ConvertListToDictionary(); string key = auditID.ToString(); if (_CacheByPrimaryKey.ContainsKey(key)) return _CacheByPrimaryKey[key][0]; return null; } #endregion #region Business Methods private string _ErrorMessage = string.Empty; public string ErrorMessage { get { return _ErrorMessage; } } protected EntryAudit _Editable; private IVEHasBrokenRules HasBrokenRules { get { IVEHasBrokenRules hasBrokenRules = null; if (_Editable != null) hasBrokenRules = _Editable.HasBrokenRules; return hasBrokenRules; } } private long _AuditID; [System.ComponentModel.DataObjectField(true, true)] public long AuditID { [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)] get { return _AuditID; } } private int _ContentID; public int ContentID { [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)] get { return _ContentID; } } private int _DocID; public int DocID { [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)] get { return _DocID; } } private DateTime _DTS = new DateTime(); public DateTime DTS { [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)] get { return _DTS; } } private string _UserID = string.Empty; public string UserID { [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)] get { return _UserID; } } private int _DeleteStatus; public int DeleteStatus { [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)] get { return _DeleteStatus; } } // CSLATODO: Replace base EntryAuditInfo.ToString function as necessary /// /// Overrides Base ToString /// /// A string representation of current EntryAuditInfo //public override string ToString() //{ // return base.ToString(); //} // CSLATODO: Check EntryAuditInfo.GetIdValue to assure that the ID returned is unique /// /// Overrides Base GetIdValue - Used internally by CSLA to determine equality /// /// A Unique ID for the current EntryAuditInfo protected override object GetIdValue() { return MyEntryAuditInfoUnique; // Absolutely Unique ID } #endregion #region Factory Methods private static int _EntryAuditInfoUnique = 0; private static int EntryAuditInfoUnique { get { return ++_EntryAuditInfoUnique; } } private int _MyEntryAuditInfoUnique = EntryAuditInfoUnique; public int MyEntryAuditInfoUnique // Absolutely Unique ID - Info { get { return _MyEntryAuditInfoUnique; } } protected EntryAuditInfo() {/* require use of factory methods */ AddToCache(this); } private bool _Disposed = false; private static int _CountCreated = 0; private static int _CountDisposed = 0; private static int _CountFinalized = 0; private static int IncrementCountCreated { get { return ++_CountCreated; } } private int _CountWhenCreated = IncrementCountCreated; public static int CountCreated { get { return _CountCreated; } } public static int CountNotDisposed { get { return _CountCreated - _CountDisposed; } } public static int CountNotFinalized { get { return _CountCreated - _CountFinalized; } } ~EntryAuditInfo() { _CountFinalized++; } public void Dispose() { if (_Disposed) return; _CountDisposed++; _Disposed = true; RemoveFromCache(this); if (!_CacheByPrimaryKey.ContainsKey(AuditID.ToString())) return; List listEntryAuditInfo = _CacheByPrimaryKey[AuditID.ToString()]; // Get the list of items while (listEntryAuditInfo.Contains(this)) listEntryAuditInfo.Remove(this); // Remove the item from the list if (listEntryAuditInfo.Count == 0) // If there are no items left in the list _CacheByPrimaryKey.Remove(AuditID.ToString()); // remove the list } public virtual EntryAudit Get() { return _Editable = EntryAudit.Get(_AuditID); } public static void Refresh(EntryAudit tmp) { string key = tmp.AuditID.ToString(); ConvertListToDictionary(); if (_CacheByPrimaryKey.ContainsKey(key)) foreach (EntryAuditInfo tmpInfo in _CacheByPrimaryKey[key]) tmpInfo.RefreshFields(tmp); } protected virtual void RefreshFields(EntryAudit tmp) { _ContentID = tmp.ContentID; _DocID = tmp.DocID; _DTS = tmp.DTS; _UserID = tmp.UserID; _DeleteStatus = tmp.DeleteStatus; _EntryAuditInfoExtension.Refresh(this); OnChange();// raise an event } public static EntryAuditInfo Get(long auditID) { //if (!CanGetObject()) // throw new System.Security.SecurityException("User not authorized to view a EntryAudit"); try { EntryAuditInfo tmp = GetCachedByPrimaryKey(auditID); if (tmp == null) { tmp = DataPortal.Fetch(new PKCriteria(auditID)); AddToCache(tmp); } if (tmp.ErrorMessage == "No Record Found") { tmp.Dispose(); // Clean-up EntryAuditInfo tmp = null; } return tmp; } catch (Exception ex) { throw new DbCslaException("Error on EntryAuditInfo.Get", ex); } } #endregion #region Data Access Portal internal EntryAuditInfo(SafeDataReader dr) { if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] EntryAuditInfo.Constructor", GetHashCode()); try { ReadData(dr); } catch (Exception ex) { if (_MyLog.IsErrorEnabled) _MyLog.Error("EntryAuditInfo.Constructor", ex); throw new DbCslaException("EntryAuditInfo.Constructor", ex); } } [Serializable()] protected class PKCriteria { private long _AuditID; public long AuditID { get { return _AuditID; } } public PKCriteria(long auditID) { _AuditID = auditID; } } private void ReadData(SafeDataReader dr) { if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] EntryAuditInfo.ReadData", GetHashCode()); try { _AuditID = dr.GetInt64("AuditID"); _ContentID = dr.GetInt32("ContentID"); _DocID = dr.GetInt32("DocID"); _DTS = dr.GetDateTime("DTS"); _UserID = dr.GetString("UserID"); _DeleteStatus = dr.GetInt32("DeleteStatus"); } catch (Exception ex) { if (_MyLog.IsErrorEnabled) _MyLog.Error("EntryAuditInfo.ReadData", ex); _ErrorMessage = ex.Message; throw new DbCslaException("EntryAuditInfo.ReadData", ex); } } private void DataPortal_Fetch(PKCriteria criteria) { if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] EntryAuditInfo.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 = "getEntryAudit"; cm.Parameters.AddWithValue("@AuditID", criteria.AuditID); 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("EntryAuditInfo.DataPortal_Fetch", ex); _ErrorMessage = ex.Message; throw new DbCslaException("EntryAuditInfo.DataPortal_Fetch", ex); } } #endregion // Standard Refresh #region extension EntryAuditInfoExtension _EntryAuditInfoExtension = new EntryAuditInfoExtension(); [Serializable()] partial class EntryAuditInfoExtension : extensionBase { } [Serializable()] class extensionBase { // Default Refresh public virtual void Refresh(EntryAuditInfo tmp) { } } #endregion } // Class #region Converter internal class EntryAuditInfoConverter : ExpandableObjectConverter { public override object ConvertTo(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value, Type destType) { if (destType == typeof(string) && value is EntryAuditInfo) { // Return the ToString value return ((EntryAuditInfo)value).ToString(); } return base.ConvertTo(context, culture, value, destType); } } #endregion } // Namespace