-
Notifications
You must be signed in to change notification settings - Fork 753
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Adds IEventLogger to Dependency Injection #4159
Conversation
DNN Platform/DotNetNuke.Abstractions/Logging/ILogTypeConfigInfo.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Abstractions/Logging/ILogTypeConfigInfo.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Abstractions/Logging/LoggingProviderReturnType.cs
Outdated
Show resolved
Hide resolved
Thank you @bdukes and @mitchelsellers for the review on this PR. I am glad to see excitement around this PR.
My intentions with DNN logging is to isolate the IEventLogger from a general ILogger. We have 2 major types of logging in DNN and they serve very different purposes. The Event Logger is a database logger which is designed to log application events as the name suggests. Where the file logger uses log4net to log application errors and exceptions to a file. In modern applications it is best practice to use a file logger for that as database logging will affect database performance and indexes since log tables grow incredibly fast. In my experience from the mobile and desktop world Event Logging is incredibly useful to track feature usage among other things. It isn't really a technique I've seen leveraged as much in the web world but is still applicable. As it stands right now I am not planning to implement the ILogger for the IEventLogger as the API structures are quite different. When you log an event you typically need a couple items
When you use ILogger you are using one of the methods below (this isn't a complete list)
Each of these statements display the log differently in the file. Combining the logging interfacesThe challenge with wrapping the IEventLogger into the ILogger is the interfaces just don't line up. I think it would be more confusing on what the logger is actually doing. If the maintainers think this is the best direction then we can create an AggregateLogger which would use many ILogger to log messages. For example it could invoke both a file log and an event log. I would propose that we have an IEventLogger and an ILogger to handle the different logging scenarios. It may be useful to create an |
@ahoefling 100% agreed here, two separate things! I'm more excited about the second one than this one, but that's incredibly self serving! |
I think @mitchelsellers was just expressing excitement for your statement
I'm not expecting (and I don't think @mitchelsellers is either) that it would be part of the event logger. We've discussed replacing Log4Net with Serilog in #2801, and your issue #3161 documents a path to deprecate |
Thanks @mitchelsellers and @bdukes for the clarification. I wanted to be thorough in my explanation as these are concepts that are often confused when to use them. They both serve very important purposes and want to make sure we are all on the same page. updates are on the way |
I have updated the PR with the changes suggested. If there are no other code changes we need to make can we start looking at the XML comments of the new interfaces in Thanks everyone for all the feedback so far! |
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogConfigService.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogConfigService.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogConfigService.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogConfigService.cs
Outdated
Show resolved
Hide resolved
I think moving "Clear" and "Delete" into a Service interface is a good compromise. Those are needed items, but not every day etc. |
@bdukes thanks for the detailed review, I will go through and make the updates. Based on several discussion threads it appears that we will have a total of 3 different event logging interfaces
With this API structure my question is can we use
|
Absolutely, general exceptions etc. Also even if doing custom types, you would typically at module install (or upgrade) insert your log type using the |
Thanks for the quick response. I'll take this direction as documented in my table above. I'll update this PR later today with changes |
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogConfigService.cs
Outdated
Show resolved
Hide resolved
After reviewing the changes here since this is a lift and shift I don't think we need to add any new unit tests. Just need to ensure the existing tests are still passing. If anyone disagrees, I am more than willing to add unit tests in particular areas |
Works for me |
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogService.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Abstractions/Logging/IEventLogService.cs
Outdated
Show resolved
Hide resolved
@bdukes I think I covered all your comments on the deprecation notices. Can you take a 2nd look to make sure nothing was missed |
DNN Platform/DotNetNuke.Web/InternalServices/EventLogServiceController.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Web/InternalServices/EventLogServiceController.cs
Outdated
Show resolved
Hide resolved
DNN Platform/DotNetNuke.Web/InternalServices/EventLogServiceController.cs
Outdated
Show resolved
Hide resolved
I just ran through a new installation with the PR build and it appears to install without issue. The event logs are being added correctly and it is visible from the persona bar 'Admin Logs' page. I think we are good to go with this 🚀 |
Thank for all the hard work on this one @ahoefling! |
* Changed accessor of ISerialzationManager property to private * Updated startup configuration to use scoped instead of transient. Also updated typo in ISerializationManager registration * Resolves an infinite redirect loop issue Closes dnnsoftware#4157 An infinite redirect loop could occur even in situations where the portal aliasses where setup in canonical mode. Relates to this discussion: dnnsoftware#4137 * Update DNN Platform/Library/Entities/Modules/Settings/SettingsRepository.cs * Properly named CSS class & keeps the other for compatibility for now (dnnsoftware#4160) * Adds IEventLogger to Dependency Injection (dnnsoftware#4159) * Extracted IEventLogger, IEventLogService, and IEventLogConfigService to Abstractions project * Updated ILogProperties to inherit from ICollection<ILogInfoDetail> * Fixed property name casing to match new abstractions standard * Updated new API to return IEnumerable<ILogInfo> instead of ArrayList * IEventLogService implements IEventLogger * Deprecated GetSingleLog and added a new API GetLog * Move AddSettingLog to an extension method Co-authored-by: Brian Dukes <[email protected]> * Adds support for editing the robots.txt on a website (dnnsoftware#4165) * Adds support for editing the robots.txt on a website Resolves dnnsoftware#3103 * Moved robots.txt get/update methods & made private * Applied suggested updates from code review * Swap CodeMirror in SqlConsole for monaco-editor * Issues/fix pr 4165 (dnnsoftware#4172) * Fixes testing issue found in PR dnnsoftware#4165 * Fixing the save method too... * Correctly using Path.Combine * Swap CodeMirror in ConfigConsole for monaco-editor * Fix MSBuild issue with Dnn.PersonaBar.Extensions * Lowercases the meta tag names (dnnsoftware#4176) Resolves dnnsoftware#2547 * Fixes Event Log from Failing Silently during Application Startup (dnnsoftware#4178) * Added try-catch block to prevent event logs from silently failing * Updated exception handling to catch specific exception * Updated DDR Menu to be System (dnnsoftware#4180) * Marked all public WebSlice members as obsolete, Part of solution for dnnsoftware#3703 (dnnsoftware#4182) * Updated the UpdateDatabase procedure to set version numbers (dnnsoftware#4183) * Updated the UpdateDatabase procedure to set version numbers * Fixed typo * Updated order of items for better readability and removed incorrect items. * Updated Converter for TabSettings Display (dnnsoftware#4184) * Parse date with invariant culture to fix non-Gregorian calendar dates… (dnnsoftware#4164) * Parse date with invariant culture to fix non-Gregorian calendar dates issue * review suggestions incorporated. * Enable dependency injection for IServiceRouteMapper (dnnsoftware#4155) * Fixes Social Messaging Ignoring Line Breaks & Copyright Year dnnsoftware#4166 (dnnsoftware#4186) * Adds token support to replace the hard-coded 2013 copyright date * Allows line breaks to be displayed as entered by end-users * Allow line breaks but properly encode all other HTML Resolves dnnsoftware#4166 * Use new MailAttachment class for MailProvider In order to support multiple mail providers, this introduces a new MailAttachment class for use by the MailProvider API. This decoupling from System.Net.Mail.Attachment will give more flexibility when implementing new providers, such as MailKit. * Use ICollection<MailAttachment> instead of List<T> * Updated Release Schedule Documentation (dnnsoftware#4188) * Updated Release Schedule Documentation * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> * Update .github/RELEASE_SCHEDULE.md Co-authored-by: Brian Dukes <[email protected]> * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> * Updated release verbiage * Updated Notes * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> * Update .github/RELEASE_SCHEDULE.md * Update .github/RELEASE_SCHEDULE.md * Update .github/RELEASE_SCHEDULE.md Co-authored-by: David Poindexter <[email protected]> Co-authored-by: Brian Dukes <[email protected]> Co-authored-by: Daniel Valadas <[email protected]> * Updates versions as per release candidate creation * Update bug-report.md * Resolves multiple stylcop warnings in Library and HttpModules projects * child page without a parent should not be validated * UnObsoleted IsHostMenu * Deprecated PortalSettings in WebControlBase * Deprecated PortalSettings in WebControlBase * Disables waring on usage of GetCurrentPortalSettings Co-authored-by: Brian Dukes <[email protected]> * Fix tooltip Sitemap page priority * Cleaned up UserProfileClass - Resolves many stylecop warnings in UserProfile - Makes constants for retrieving profile properties obsolute and re-implements them as private constants - Updated some upstream classes to use IPortalSettings instead of PortalSettings - Implemented automated stylecop fixes on many other files in the same project * Deprecated CheckAuditLevel that takes PortalSettings in favour of new one with IPortalSettings * Update DNN Platform/Library/Services/Tokens/PropertyAccess/IPropertyAccess.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Services/Tokens/PropertyAccess/IPropertyAccess.cs Co-authored-by: Brian Dukes <[email protected]> * Adjusted deprecation comments as suggested * Reset redirect url for redirecting to 'Redirect After Login' page * dnnsoftware#3661 - Addressed review comments * Revert "Merge branch 'bugfix/DNN-44083' of https://github.com/kmuralidaran/Dnn.Platform into bugfix/DNN-44083" This reverts commit 02fb399, reversing changes made to b78f1b8. * Addressed review comments * GetLoginPath() updated to return LocalPath * Updated parameter with LoginTabId instead of TabName * Fixed an issue where the autocomplete on the country/region field would show the Id instead of the name when using the arrow keys to navigate the autocomplete suggestions * Fixed whitespace for consistency Co-authored-by: Brian Dukes <[email protected]> * Fixes an issue where folder search would not work in resrouce manager (dnnsoftware#4202) Closes dnnsoftware#4200 The filtering logic was applied with a null result and removing all the results, I added a check for null which makes the fileting work when the search is used. * copied from GoogleAnalytics Connector * added components from DNN.Services.Analytics * Fixes all warnings in the Console module - Resolves all stylecop warnings in the Console Admin Module - Enables TreatWarningsAsErrors on that project * Removed an unused private variable that was missed * Update DNN Platform/Admin Modules/Dnn.Modules.Console/Components/BusinessController.cs * Remove impractical rule @dnnsoftware/approvers I'm thinking this is a bit overkill, as I can't think of a reason why it would matter who actually clicks the merge button. The important thing is that there are two approvals. Do you all agree? * Resolves 1793 build warnings in Library project (dnnsoftware#4204) * Resolves 1793 build warnings in DotNetNuke.Collections This PR covers pretty much all the Collections folder. I am no expert in this area, so any feedback on the documentation is welcome * Update DNN Platform/Library/Collections/LockingStrategy.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/MonitorLock.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/MonitorLock.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/NaiveLockingList.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/NaiveLockingList.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/SharedList.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/CachedCountryList.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListInfo.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/NavigationManager.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/ServiceScopeContainer.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/ReaderWriterSlimLock.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Collections/SharedDictionary.cs Co-authored-by: Brian Dukes <[email protected]> * Implemented CLSCompliant attribute on DotNetNuke.Abstractions and DotNetNuke.DependencyInjection * Marked IDNNStartup as not CSL Compliant * Update DNN Platform/Library/Services/Journal/JournalControllerImpl.cs Co-authored-by: David Poindexter <[email protected]> * Update DNN Platform/Library/Services/Scheduling/DNNScheduler.cs Co-authored-by: David Poindexter <[email protected]> * Update DNN Platform/Library/Services/Search/Internals/LuceneControllerImpl.cs Co-authored-by: David Poindexter <[email protected]> Co-authored-by: Brian Dukes <[email protected]> Co-authored-by: David Poindexter <[email protected]> * avoid I/O process frequency during export process. Fix dnnsoftware#4217 * Ensure comments are only inserted when necessary Fix dnnsoftware#4219 * Issue-4222 - MembershipModule CurrentCulture fix * Resolves some build warnings in DDRMenu Project * Updated .NET Framework requirement in InstallWizard localization files from 4.0 to 4.7.2. also removed mention of older OS versions from the FileAndFolderPermissionCheckFailed.Text key in the InstallWizard localization files * Moved UserMode from PortalSettings to Personalization class (dnnsoftware#4225) * Moved UserMode from PortalSettings to Personalization class Closes dnnsoftware#4213 I am open to any feedback on this, I do believe this way would not be a breaking change... * Update DNN Platform/Library/Services/Personalization/Personalization.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Services/Personalization/Personalization.cs Co-authored-by: Brian Dukes <[email protected]> * Prevent duplication of code Co-authored-by: Brian Dukes <[email protected]> * Removed finalizer * Prevent breaking change of Controller public Regex * Fixed wrong version in deprecation message * Prevent breaking change on public internal PortalSettings * Addresses concern with disposing page * Addresses concern with PortalSettings cast * Moves things deprecated in v9 to be removed in v11 instead of v10 This moves everything that was marked deprecated in v9.x.x but was slated for removal in v10 to now be removed in v11. * Corrected one that was done by mistake, it was declared in v6 * Addresses breaking change danger on m_supportsIcons * Resolves 101 build warnings on CoreMessaging project (dnnsoftware#4216) * Resolves 101 build warnings on CoreMessaging project - Resolves 101 warnings - Prevents sending detailed errors to frontend - Updates documentation and settings here and there to make it build and correct related documentation - Enabled TreatBuildWarningsAsErrors on project * Resolves a build failure due to deprecated PortalID in PortalInfo * Update DNN Platform/Library/Services/Exceptions/Exceptions.cs Co-authored-by: Brian Dukes <[email protected]> Co-authored-by: Brian Dukes <[email protected]> * Resolved all build warnings in RazorHost project (dnnsoftware#4231) - Resolves all build warnings - Enables Treat Warnings as Errors on project * Resolves some build warnings in the ImportExport project. (dnnsoftware#4211) * Resolves some build warnings in the ImportExport project. Resolves some (I did not count but probably around 100) build warnings in the Import Export library. * fix typo * Brought back 3 removed public methods to prevent creating a breaking change. * Moved depracation removal to v11 Co-authored-by: Brian Dukes <[email protected]> * Resolved all build warnings in Google Analytics Connector (dnnsoftware#4209) - Resolved all build warnings in Google Analytics Connector - Enabled TreatWarningsAsErrors on project * Resolved 249 build warnings in Library project (dnnsoftware#4215) * Resolved 249 build warnings in Library project This PR focuses a bit in the Common.Globals file. I have resolved many build warnings and also deprecated some unused public methods that I believe should have never been made public. All feedback is welcome * Resolves some more warnings in Globals.cs * Removed one wrong todo * Update DNN Platform/DotNetNuke.Abstractions/Application/IApplicationStatusInfo.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Globals.cs Co-authored-by: Brian Dukes <[email protected]> * Addresses PR concerns with v10 vs v11 deprecations * Update DNN Platform/Library/Common/Globals.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Globals.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Globals.cs Co-authored-by: Brian Dukes <[email protected]> * Removed TODO on IsEditMode * Removed stale TODO * Renames some variables for clarity and corrected typos Co-authored-by: Brian Dukes <[email protected]> * Typo fixes * basically working * Resolves some more build warnings on library project (dnnsoftware#4236) * Resolves some more build warnings on library project I would use some advice on correct replacement in EventManager.cs for the deprecated EventLogController.EventLogType and EventLogController.Instance.AddLog call if anyone has some idea on how to refactor that properly. If not, then let's not block this PR for just this and revisit this part later. * Fix usages of obsolete EventLogController.EventLogType * Fix test failures Co-authored-by: Brian Dukes <[email protected]> * Added the page ID to the admin ui page management experience * Removed Module Creator from distribution - Removes the Module Creator admin module from the distribution as per it's move to https://github.com/DNNCommunity/Dnn.ModuleCreator/releases/tag/v9.8.1 - Also reduces build warnings by about 46 * check the module permission to add module. Fix dnnsoftware#4234 * Deprecates IEventLogController in favor of DI Resolves dnnsoftware#4242 The PR: - Deprecates the interface - Deprecates the implementation - The implementation beeing internal and the interface having a warning to not implement by 3rd parties, we can replace it's usage in other downstream classes without too much worry - I did only one usage replacement in RelationshipController as a proof of concept and adjusted the related test on it. - There are many many usages of this in Platform, so if thise PR is ok, we have a plan forward for the other usages, any feedback welcome. * Relaxed compile warnings on Tests projects Tests projects are not consumed by 3rd parties but where contrained to the same stylecop code style rules as the rest of the platform code (like documentation requirements and name styles and whitespace time. Since we are on a hunt to reduce our build warnings, this PR relaxes those rules on the Tests projects for now. I would like to revisit this at a later date and actually correct some of those but for now it removes us 959 warnings quickly. * config sample * package * Removed most warnings * SCAYT language code configuration fixed * Fix DevOps build badge It was pointing to an old build definition * Ensure Localization HTTP Module placement It needs to be right after URL Rewrite (which determines the culture from the URL), and then all modules after it can make use of that culture info * removed installer for PR * Applied suggested changes by @valadas * Fix data reader not getting disposed Fixes dnnsoftware#3840 * Remove deprecation for some DataProvider methods Fixes dnnsoftware#3830 * Remove Localization HTTP module from config It'll get added by 09.08.00.config, having it already in there will create a duplicate * Update DNN Platform/Connectors/GoogleTagManager/GoogleTagManager.config * Run localization after authentication * Simplify cookie setting to avoid duplicate language cookies being set * Add skin/page messages after localization has been set * Added documentation (cherry picked from commit da5d855) * Installs JWT provider by default (dnnsoftware#4276) * Install JWT by default * Resolves multiple stylecop warnings in JWT project. * Ensure optional packages that have already been installed are installed so they get upgraded during DNN's upgrade process * Do not install JWT by default * do not cache output if page is redirected * review suggestions incorporated. * Apply suggestions from code review * Update DNN Platform/HttpModules/OutputCaching/OutputCacheModule.cs * Prevents JWT upgrade to change existing config With the recent change to make optional packages (.resources) upgrade if the package was previously installed, while upgrading the JWT authentication provider, it cause the existing web.config configuration to be reset to the default and that would happen on each upgrade. This PR makes it ignore the node if it is already present from a previous installation. * Implement EnablePopups switch in portal settings PB module * Optimised images with calibre/image-actions * Fixed an issue where new users would have no preferred locale. The user preferred locale is a required field in user profiles. Some change made it that in 9.8.0 this property is null. This PR reverts the behavior so the preferred locale is set on new users. * Fixed an issue where all emails where missing the body While working on the Feedback module the messages where missing their body, then I tried creating new users and those emails where also missing the body. Looks like the CoreMailProvider was missing setting the body to the emails. This PR solves that. * Add Inject module hyperlink and inline editor enabled to personabar site settings module * fixed build error. * Resolves some more build warnings on Library project (dnnsoftware#4243) * Resolves some more build warnings on Library project * Corrected a typo in IGlobals.cs * Update DNN Platform/Library/Common/Lists/CachedCountryList.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Internal/TestableGlobals.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListEntryInfoCollection.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListInfo.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListInfo.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListInfo.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListInfo.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Update DNN Platform/Library/Common/Lists/ListEntryInfoCollection.cs Co-authored-by: Brian Dukes <[email protected]> * Use DI for logging * Update DNN Platform/Library/Common/Lists/ListController.cs Co-authored-by: Brian Dukes <[email protected]> * Fixed tests Co-authored-by: Brian Dukes <[email protected]> * Obsolete the EnableSkinWidgets portal setting and remove it from serialization as this setting is no longer used * To go with last commit * Further removal of EnableSkinWidgets * Tweak to obsolete wording * Update DNN Platform/DotNetNuke.Abstractions/Portals/IPortalSettings.cs Co-authored-by: Mitchel Sellers <[email protected]> * Update DNN Platform/Library/Entities/Portals/PortalSettings.cs Co-authored-by: Mitchel Sellers <[email protected]> * Rolling back changes * More stylecop fixes on DotNetNuke.Web project * More stylcop warnings fixes on library project Mostly documentaiton and formatting. I recommend reviewer while hiding whitespace only changes 😄 * Apply suggestions from code review * Fixes invalid extension error message for 0 errors * Issue-4300 - Password validation lines are fixed * Fix data provider always failing (dnnsoftware#4302) * Ensure no expression-bodies properties in DTO objects * Update bug report template after 9.8.0 release * remove dragover state from element when dragged BETWEEN pages * Fix build error * Fixed AddContentItem to only override the CreatedByUserId if the ContentItem's UserID is >= 0 * Added unit tests * Fixed last unit test * Use YAML for build pipeline * Add triggers config for YAML build * Fix some integration tests (dnnsoftware#4250) * Fix test failures in DotNetNuke.Tests.Data * Fix test failures in Dnn.PersonaBar.Security.Tests * Fix test failures in ExtensionUrlProviderControllerTests * Trying to adjust included branches for azure pipeline * Use latest Cake.Frosting * Fix some build issues * Revert to older version of GitVersion * Show more details from build * Fix bad build number * Move Cake logging to later tasks * Remove tools from NuGet They're already referenced via UseTool in Program.cs * Move some logic out of Context class and into task * Update Cake.NuGet * Move GetFilesByPatterns into this project It came from Dnn.CakeUtils, but wasn't compatible with Cake v1 * Install NuGet as a tool * Fix settings file path * Trying windows-latest vm image * Trying to install .net core 2 sdk before build happens * Trying to preinstall 5.0 SDK * Added build platform x64 Trying solution found in dotnet/msbuild#5134 * Trying to define the buildPlatform variable differently * Trying includePreviousVersions * Use .NET Core 3.1 for build * Fix build platform value * Try using .NET 4.8 for Cake.Frosting * Resolves multple build auto-fixable warnings in solution. This resolves many many many (6227) build warnings across the whole solution by implementing stylecop auto-fixes on some easy to fix warnings. I do recommend reviewers to 'hide whitespace changes' while reviewing as this affects many many many files... The gift that keeps on giving.... * Changed WebConfigurationManager for System.Configuration.ConfigurationManager when reading connection strings and app settings * Trying .Net 5.0.100 instead of 5.0.100-rc.2.20479.15 As recommened in cake-build/cake#2957 (reply in thread) * Removes .Net install from pipeline * Matching build settings for unit tests * Should resolve unit tests not running * Issue-4336 - Umlaut characters in URL cause module setting error (dnnsoftware#4337) * Issue-4336 - Umlaut characters module settings fix * Issue-4336 - UTs provided for AdvancedUrlRewriter * Issue-4336 - Namespace fix * Issue-4336 - Parallel execution UTs are handled * Update BUILD documentation for Cake v1 changes `-Target CreateSettings` and `-Target ResetDevSite` should now be `--target=CreateSettings` and `--target=ResetDevSite`. * Use variable for cake verbosity * Update vsdoc file for jQuery to 3.4.1 * Inherit Monaco font (instead of using Roboto) Fixes dnnsoftware#4344 * Removed elemets and marked obsolete the methods that need to stay due to the public nature of them. * Adjusted project structure and templates to support proper sitemap configuration on new portal creation. (dnnsoftware#4342) * Revert "Simplify cookie setting to avoid duplicate language cookies being set" This reverts commit 2435e14. * Adjusts build to support upgrades from De-Teleriked Dnn (dnnsoftware#4350) Allows upgrading from De-Teleriked 9.8.0 instances without reinstalling Telerik dependent packages. * Don't check user permissions unless there's a user Fixes dnnsoftware#4355 * Fixed for anti-pattern Obsolete * Update DNN Platform/Library/Security/PortalSecurity.cs Co-authored-by: Brian Dukes <[email protected]> * Apply suggestions from code review Code layout fixes Co-authored-by: Brian Dukes <[email protected]> * Resolves a build error from using deprecated enum value. Replaced with WebUtility.HtmlEncode * Fix AssemblyInstaller failing to RemoveBindingRedirect when action="UnRegister" and dll is missing. * Add assertion to test * Clean up warnings Also adjust naming * DNN-42147 Denying permission (dnnsoftware#4364) * Adjust flaky test away from ExpectedException This expresses the intent of the test better (it shows which line it expects to throw), and locally seems to be more reliable * Remove duplicate references Prefer project references to assembly references * Remove more duplicate references * Enable warnings as errors for CountryListBox * Suppress documentation suggestion in test projects * Turn on TreatWarningsAsErrors for test projects Co-authored-by: Andrew Hoefling <[email protected]> Co-authored-by: Daniel Valadas <[email protected]> Co-authored-by: Brian Dukes <[email protected]> Co-authored-by: Will Strohl <[email protected]> Co-authored-by: David Poindexter <[email protected]> Co-authored-by: Mitchel Sellers <[email protected]> Co-authored-by: Tauqeer Haider <[email protected]> Co-authored-by: Mandeep Singh <[email protected]> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: engineering87 <[email protected]> Co-authored-by: Muralidaran Kuppusamy <[email protected]> Co-authored-by: Josh Slaughter <[email protected]> Co-authored-by: Stefan Kamphuis <[email protected]> Co-authored-by: Ben <[email protected]> Co-authored-by: rhaiamz <[email protected]> Co-authored-by: Berk Arslan <[email protected]> Co-authored-by: Kieran Corkin <[email protected]> Co-authored-by: Peter Donker <[email protected]> Co-authored-by: David Rodriguez <[email protected]> Co-authored-by: Robert Dima <[email protected]> Co-authored-by: Mikhail Bigun <[email protected]>
Summary
Extracts a new
IEventLogger
interface from theEventLogController
and registers it with the dependency injection container. This will make it easier for developers to log events with DNN anywhere in the platform.Looking to get feedback before I spend too much time polishing this PR up, I need to look at the following items before merging
Required to Merge