// ========================================================================
// 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 ItemAuditInfoEvent(object sender);
    /// 
    ///	ItemAuditInfo Generated by MyGeneration using the CSLA Object Mapping template
    /// 
    [Serializable()]
    [TypeConverter(typeof(ItemAuditInfoConverter))]
    public partial class ItemAuditInfo : ReadOnlyBase, IDisposable
    {
        public event ItemAuditInfoEvent 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(ItemAuditInfo itemAuditInfo)
        {
            if (!_CacheList.Contains(itemAuditInfo)) _CacheList.Add(itemAuditInfo); // In AddToCache
        }
        protected static void RemoveFromCache(ItemAuditInfo itemAuditInfo)
        {
            while (_CacheList.Contains(itemAuditInfo)) _CacheList.Remove(itemAuditInfo); // In RemoveFromCache
        }
        private static Dictionary> _CacheByPrimaryKey = new Dictionary>();
        private static void ConvertListToDictionary()
        {
            while (_CacheList.Count > 0) // Move ItemAuditInfo(s) from temporary _CacheList to _CacheByPrimaryKey
            {
                ItemAuditInfo tmp = _CacheList[0]; // Get the first ItemAuditInfo
                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 ItemAuditInfo
            }
        }
        internal static void AddList(ItemAuditInfoList lst)
        {
            foreach (ItemAuditInfo item in lst) AddToCache(item);
        }
        protected static ItemAuditInfo 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 ItemAudit _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 _ItemID;
        public int ItemID
        {
            [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
            get
            {
                return _ItemID;
            }
        }
        private int? _PreviousID;
        public int? PreviousID
        {
            [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
            get
            {
                return _PreviousID;
            }
        }
        private int _ContentID;
        public int ContentID
        {
            [System.Runtime.CompilerServices.MethodImpl(System.Runtime.CompilerServices.MethodImplOptions.NoInlining)]
            get
            {
                return _ContentID;
            }
        }
        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 ItemAuditInfo.ToString function as necessary
        /// 
        /// Overrides Base ToString
        /// 
        /// A string representation of current ItemAuditInfo
        //public override string ToString()
        //{
        //  return base.ToString();
        //}
        // CSLATODO: Check ItemAuditInfo.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 ItemAuditInfo
        protected override object GetIdValue()
        {
            return MyItemAuditInfoUnique; // Absolutely Unique ID
        }
        #endregion
        #region Factory Methods
        private static int _ItemAuditInfoUnique = 0;
        private static int ItemAuditInfoUnique
        { get { return ++_ItemAuditInfoUnique; } }
        private int _MyItemAuditInfoUnique = ItemAuditInfoUnique;
        public int MyItemAuditInfoUnique // Absolutely Unique ID - Info
        { get { return _MyItemAuditInfoUnique; } }
        protected ItemAuditInfo()
        {/* 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; } }
        ~ItemAuditInfo()
        {
            _CountFinalized++;
        }
        public void Dispose()
        {
            if (_Disposed) return;
            _CountDisposed++;
            _Disposed = true;
            RemoveFromCache(this);
            if (!_CacheByPrimaryKey.ContainsKey(AuditID.ToString())) return;
            List listItemAuditInfo = _CacheByPrimaryKey[AuditID.ToString()]; // Get the list of items
            while (listItemAuditInfo.Contains(this)) listItemAuditInfo.Remove(this); // Remove the item from the list
            if (listItemAuditInfo.Count == 0) // If there are no items left in the list
                _CacheByPrimaryKey.Remove(AuditID.ToString()); // remove the list
        }
        public virtual ItemAudit Get()
        {
            return _Editable = ItemAudit.Get(_AuditID);
        }
        public static void Refresh(ItemAudit tmp)
        {
            string key = tmp.AuditID.ToString();
            ConvertListToDictionary();
            if (_CacheByPrimaryKey.ContainsKey(key))
                foreach (ItemAuditInfo tmpInfo in _CacheByPrimaryKey[key])
                    tmpInfo.RefreshFields(tmp);
        }
        protected virtual void RefreshFields(ItemAudit tmp)
        {
            _ItemID = tmp.ItemID;
            _PreviousID = tmp.PreviousID;
            _ContentID = tmp.ContentID;
            _DTS = tmp.DTS;
            _UserID = tmp.UserID;
            _DeleteStatus = tmp.DeleteStatus;
            _ItemAuditInfoExtension.Refresh(this);
            OnChange();// raise an event
        }
        public static ItemAuditInfo Get(long auditID)
        {
            //if (!CanGetObject())
            //  throw new System.Security.SecurityException("User not authorized to view a ItemAudit");
            try
            {
                ItemAuditInfo tmp = GetCachedByPrimaryKey(auditID);
                if (tmp == null)
                {
                    tmp = DataPortal.Fetch(new PKCriteria(auditID));
                    AddToCache(tmp);
                }
                if (tmp.ErrorMessage == "No Record Found")
                {
                    tmp.Dispose(); // Clean-up ItemAuditInfo
                    tmp = null;
                }
                return tmp;
            }
            catch (Exception ex)
            {
                throw new DbCslaException("Error on ItemAuditInfo.Get", ex);
            }
        }
        #endregion
        #region Data Access Portal
        internal ItemAuditInfo(SafeDataReader dr)
        {
            if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] ItemAuditInfo.Constructor", GetHashCode());
            try
            {
                ReadData(dr);
            }
            catch (Exception ex)
            {
                if (_MyLog.IsErrorEnabled) _MyLog.Error("ItemAuditInfo.Constructor", ex);
                throw new DbCslaException("ItemAuditInfo.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}] ItemAuditInfo.ReadData", GetHashCode());
            try
            {
                _AuditID = dr.GetInt64("AuditID");
                _ItemID = dr.GetInt32("ItemID");
                _PreviousID = (int?)dr.GetValue("PreviousID");
                _ContentID = dr.GetInt32("ContentID");
                _DTS = dr.GetDateTime("DTS");
                _UserID = dr.GetString("UserID");
                _DeleteStatus = dr.GetInt32("DeleteStatus");
            }
            catch (Exception ex)
            {
                if (_MyLog.IsErrorEnabled) _MyLog.Error("ItemAuditInfo.ReadData", ex);
                _ErrorMessage = ex.Message;
                throw new DbCslaException("ItemAuditInfo.ReadData", ex);
            }
        }
        private void DataPortal_Fetch(PKCriteria criteria)
        {
            if (_MyLog.IsDebugEnabled) _MyLog.DebugFormat("[{0}] ItemAuditInfo.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 = "getItemAudit";
                        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("ItemAuditInfo.DataPortal_Fetch", ex);
                _ErrorMessage = ex.Message;
                throw new DbCslaException("ItemAuditInfo.DataPortal_Fetch", ex);
            }
        }
        #endregion
        // Standard Refresh
        #region extension
        ItemAuditInfoExtension _ItemAuditInfoExtension = new ItemAuditInfoExtension();
        [Serializable()]
        partial class ItemAuditInfoExtension : extensionBase { }
        [Serializable()]
        class extensionBase
        {
            // Default Refresh
            public virtual void Refresh(ItemAuditInfo tmp) { }
        }
        #endregion
    } // Class
    #region Converter
    internal class ItemAuditInfoConverter : ExpandableObjectConverter
    {
        public override object ConvertTo(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value, Type destType)
        {
            if (destType == typeof(string) && value is ItemAuditInfo)
            {
                // Return the ToString value
                return ((ItemAuditInfo)value).ToString();
            }
            return base.ConvertTo(context, culture, value, destType);
        }
    }
    #endregion
} // Namespace