Umbraco.DevTools.Logger 1.0.0-beta

Additional Details

This was a hack project for Umbraco logging before structured logging with Serilog & the built in log viewer

This is a prerelease version of Umbraco.DevTools.Logger.
dotnet add package Umbraco.DevTools.Logger --version 1.0.0-beta                
NuGet\Install-Package Umbraco.DevTools.Logger -Version 1.0.0-beta                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Umbraco.DevTools.Logger" Version="1.0.0-beta" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Umbraco.DevTools.Logger --version 1.0.0-beta                
#r "nuget: Umbraco.DevTools.Logger, 1.0.0-beta"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Umbraco.DevTools.Logger as a Cake Addin
#addin nuget:?package=Umbraco.DevTools.Logger&version=1.0.0-beta&prerelease

// Install Umbraco.DevTools.Logger as a Cake Tool
#tool nuget:?package=Umbraco.DevTools.Logger&version=1.0.0-beta&prerelease                

Umbraco Dev Tools

A Chrome Extension to view live logs from an Umbraco Website. WIth future plans to see more detailed view/report of MiniProfiler results, along with a few other useful tools to add to your toolkit.

Screenshot of Umbraco Developer Tools

Why build this?

I personally always wanted to build a Chrome Extension and learn something a bit new, but I find sometime trawling through large or long logfiles hard & cumbersome. So I thought it would be a nicer debugging experience that you open a Chrome Developer Tools and see logs in realtime whilst you perform the set of actions that is casuing an error or irregularity. With seeing logs in realtime you will be able to pinpoint the problem a lot quicker.

Requirements for usage

Due to some underlying OWIN MiddleWare startup code for Umbraco that I need to hook into, this now requires a minimum of at least 7.5 beta 2 and the associated Chrome Extension from the Chrome Store - https://chrome.google.com/webstore/detail/umbraco-developer-tools/gjcgemjmhmgcmioedcghnemmadcimjia

Projects

An overview of what makes up this project

  • Umbraco.DevTools.Chrome This is the code for the Chrome Extension itself which is made up of client side assets, that includes the logging extension that connects to the Logger SignalR Hub, along with the Mini Profiler results viewer

  • Umbraco.DevTools.TestSite This contains a sample Umbraco website allowing us to test and set debug points in the main C# project

  • Umbraco.DevTools.Logger This contains the code for Log4Net appender and the SignalR hub that pushes Log4Net log messages to our Chrome extension

Setup & Configuration

The Nuget package & Umbraco zip should handle this for you automatically. You may use the following below as reference:

SignalR Setup

To ensure the SignalR hub is registered and picks up the custom SignalR Authorize attribute to determine if you have logged into Umbraco, we need to tell Umbraco what OWIN startup class we want to use, by modifying the web.config of your Umbraco site to the following

<add key="owin:appStartup" value="UmbracoDevToolsLoggerOwinStartup" />

Log4Net Configuration

Add the following to your Log4Net config inside the <root> element

<appender-ref ref="ChromeDevToolsAppender" />

Next add a new appender element to the file as follows:

<appender name="ChromeDevToolsAppender" type="Umbraco.DevTools.Logger.Appender.SignalrLogAppender,Umbraco.DevTools.Logger">
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date [P%property{processId}/D%property{appDomainId}/T%thread] %-5level %logger - %message%newline" />
  </layout>
</appender>
Product Compatible and additional computed target framework versions.
.NET Framework net is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.