⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 exceptionlogcontroller.cs

📁 SharpNuke源代码
💻 CS
字号:
using System;

using DotNetNuke.Services.Exceptions;

//
// DotNetNuke -  http://www.dotnetnuke.com
// Copyright (c) 2002-2005
// by Shaun Walker ( sales@perpetualmotion.ca ) of Perpetual Motion Interactive Systems Inc. ( http://www.perpetualmotion.ca )
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
// documentation files (the "Software"), to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and
// to permit persons to whom the Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all copies or substantial portions
// of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
// TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
// CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//

namespace DotNetNuke.Services.Log.EventLog
{
	public class ExceptionLogController : LogController
	{
		
		//TODO @SV move public class leve enums to namespace level
		public enum ExceptionLogType
		{
			GENERAL_EXCEPTION,
			MODULE_LOAD_EXCEPTION,
			PAGE_LOAD_EXCEPTION,
			SCHEDULER_EXCEPTION
		}
		
		public void AddLog (Exception exception)
		{
			AddLog(exception, ExceptionLogType.GENERAL_EXCEPTION);
		}
		//TODO @SV use type reflection instead of name reflection?!
		public void AddLog (Exceptions.BasePortalException basePortalException)
		{
			if (basePortalException.GetType().Name == "ModuleLoadException")
			{
				AddLog(basePortalException, ExceptionLogType.MODULE_LOAD_EXCEPTION);
			}
			else if (basePortalException.GetType().Name == "PageLoadException")
			{
				AddLog(basePortalException, ExceptionLogType.PAGE_LOAD_EXCEPTION);
			}
			else if (basePortalException.GetType().Name == "SchedulerException")
			{
				AddLog(basePortalException, ExceptionLogType.SCHEDULER_EXCEPTION);
			}
			else
			{
				AddLog(basePortalException, ExceptionLogType.GENERAL_EXCEPTION);
			}
		}
		
		public void AddLog (Exception exception, ExceptionLogType logType)
		{
			
			LogController logController = new LogController();
			LogInfo logInfo = new LogInfo();
			logInfo.LogTypeKey = logType.ToString();
			if (logType == ExceptionLogType.MODULE_LOAD_EXCEPTION)
			{
				//Add ModuleLoadException Properties
				Exceptions.ModuleLoadException moduleLoadException = ((Exceptions.ModuleLoadException) exception);
				logInfo.LogProperties.Add(new LogDetailInfo("ModuleId", moduleLoadException.ModuleId.ToString()));
				logInfo.LogProperties.Add(new LogDetailInfo("ModuleDefId", moduleLoadException.ModuleDefId.ToString()));
				logInfo.LogProperties.Add(new LogDetailInfo("FriendlyName", moduleLoadException.FriendlyName));
				logInfo.LogProperties.Add(new LogDetailInfo("ModuleControlSource", moduleLoadException.ModuleControlSource));
			}
			
			//Add BasePortalException Properties
			Exceptions.BasePortalException basePortalException = new Exceptions.BasePortalException(exception.ToString(), exception);
			logInfo.LogProperties.Add(new LogDetailInfo("AssemblyVersion", basePortalException.AssemblyVersion));
			logInfo.LogProperties.Add(new LogDetailInfo("Method", basePortalException.Method));
			logInfo.LogProperties.Add(new LogDetailInfo("FileName", basePortalException.FileName));
			logInfo.LogProperties.Add(new LogDetailInfo("FileLineNumber", basePortalException.FileLineNumber.ToString()));
			logInfo.LogProperties.Add(new LogDetailInfo("FileColumnNumber", basePortalException.FileColumnNumber.ToString()));
			logInfo.LogProperties.Add(new LogDetailInfo("PortalID", basePortalException.PortalID.ToString()));
			logInfo.LogProperties.Add(new LogDetailInfo("PortalName", basePortalException.PortalName));
			logInfo.LogProperties.Add(new LogDetailInfo("UserID", basePortalException.UserID.ToString()));
			logInfo.LogProperties.Add(new LogDetailInfo("UserName", basePortalException.UserName));
			logInfo.LogProperties.Add(new LogDetailInfo("ActiveTabID", basePortalException.ActiveTabID.ToString()));
			logInfo.LogProperties.Add(new LogDetailInfo("ActiveTabName", basePortalException.ActiveTabName));
			logInfo.LogProperties.Add(new LogDetailInfo("AbsoluteURL", basePortalException.AbsoluteURL));
			logInfo.LogProperties.Add(new LogDetailInfo("AbsoluteURLReferrer", basePortalException.AbsoluteURLReferrer));
			logInfo.LogProperties.Add(new LogDetailInfo("ExceptionGUID", basePortalException.ExceptionGUID));
			logInfo.LogProperties.Add(new LogDetailInfo("DefaultDataProvider", basePortalException.DefaultDataProvider));
			logInfo.LogProperties.Add(new LogDetailInfo("InnerException", basePortalException.InnerException.Message));
			logInfo.LogProperties.Add(new LogDetailInfo("Message", basePortalException.Message));
			logInfo.LogProperties.Add(new LogDetailInfo("StackTrace", basePortalException.StackTrace));
			logInfo.LogProperties.Add(new LogDetailInfo("Source", basePortalException.Source));
			
			logInfo.LogPortalID = basePortalException.PortalID;
			
			logController.AddLog(logInfo);
		}
		
	}
	
}






⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -