| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 | using System;
using System.Diagnostics;
using iiie.Logs.DBO;
using Microsoft.Practices.EnterpriseLibrary.Common.Configuration;
using Microsoft.Practices.EnterpriseLibrary.Data;
using Microsoft.Practices.EnterpriseLibrary.Logging;
namespace iiie.Logs.DataAccess
{
    /// <summary>
    /// Logger for OpResult
    /// </summary>
    public static class Logger
    {
        /// <summary>
        /// 
        /// </summary>
        /// <param name="status"></param>
        /// <returns></returns>
        public static TraceEventType ResultStatusToSeverity(ResultStatus status)
        {
            if (status == ResultStatus.DBError)
                return TraceEventType.Critical;
            if (status == ResultStatus.LoginError)
                return TraceEventType.Error;
            if (status == ResultStatus.PermissionError)
                return TraceEventType.Error;
            if (status == ResultStatus.InternalError)
                return TraceEventType.Error;
            if (status == ResultStatus.InputError)
                return TraceEventType.Warning;
            if (status == ResultStatus.NotFound)
                return TraceEventType.Information;
            return TraceEventType.Verbose;
        }
        /// <summary>
        /// Config the logger for database and default settings provider
        /// </summary>
        public static void Config()
        {
            DatabaseFactory.SetDatabaseProviderFactory(new DatabaseProviderFactory());
            IConfigurationSource configurationSource = ConfigurationSourceFactory.Create();
            LogWriterFactory logWriterFactory = new LogWriterFactory(configurationSource);
            Microsoft.Practices.EnterpriseLibrary.Logging.Logger.SetLogWriter(logWriterFactory.Create());
        }
        /// <summary>
        /// Log provided informations
        /// </summary>
        /// <param name="status">The status to be logged</param>
        /// <param name="title">The log title</param>
        /// <param name="message">The log message</param>
        public static void Log(ResultStatus status, string title, string message)
        {
            try
            {
                Microsoft.Practices.EnterpriseLibrary.Logging.Logger.Write(new LogEntry()
                {
                    Title = title,
                    Severity = ResultStatusToSeverity(status),
                    Message = message
                });
            }
            catch (Exception e)
            {
            }
        }
        /// <summary>
        /// Log an exception
        /// </summary>
        /// <param name="e">The exception to be logged</param>
        public static void Log(Exception e)
        {
            LogOpResult(OpResult<int>.Error(ResultStatus.InternalError, e));
        }
        /// <summary>
        /// Log an OpResult
        /// </summary>
        /// <typeparam name="T">User data type</typeparam>
        /// <param name="result">The result to be logged</param>
        /// <returns>The OpResult</returns>
        public static OpResult<T> LogOpResult<T>(OpResult<T> result)
        {
            string message = "Location:\n";
            for (int i = 0; i < result.StackFrames.Length && i < 10; ++i)
            {
                var frame = result.StackFrames[i];
                var method = frame.GetMethod();
                if (method.DeclaringType != null)
                    message += method.DeclaringType.Name + "." + frame.GetMethod().Name + "\n";
            }
            if (result.PrivateDetails != null)
                message += "\nPrivate details:\n" + result.PrivateDetails + "\n";
            if (result.PublicDetails != null)
                message += "\nPublic details:\n" + result.PublicDetails;
            Log(result.Status, result.Status.ToString(), message);
            return result;
        }
        /// <summary>
        /// Create and returns a new OpResult with
        /// PrivateDetails = privateDetails, Data = null, Status = status
        /// If publicDetails == "", privateDetails will be used
        /// Used for all errors (invalid input, ...)
        /// </summary>
        public static OpResult<T> Error<T>(ResultStatus status, string privateDetails, string publicDetails = null)
        {
            return LogOpResult(OpResult<T>.Error(status, privateDetails, publicDetails));
        }
        /// <summary>
        /// Create and returns a new OpResult with
        /// PrivateDetails = e to string, Data = null, Status = status
        /// If publicDetails == "", privateDetails will be used
        /// Used for all errors (invalid input, ...)
        /// </summary>
        public static OpResult<T> Error<T>(ResultStatus status, Exception e, string userDetails = null)
        {
            return LogOpResult(OpResult<T>.Error(status, e, userDetails));
        }
        public static OpResult<T> Log<T>(this OpResult<T> res)
        {
            return LogOpResult(res);
        }
    }
}
 |