UrlTracker.Core
9.0.0-beta0005
See the version list below for details.
dotnet add package UrlTracker.Core --version 9.0.0-beta0005
NuGet\Install-Package UrlTracker.Core -Version 9.0.0-beta0005
<PackageReference Include="UrlTracker.Core" Version="9.0.0-beta0005" />
paket add UrlTracker.Core --version 9.0.0-beta0005
#r "nuget: UrlTracker.Core, 9.0.0-beta0005"
// Install UrlTracker.Core as a Cake Addin #addin nuget:?package=UrlTracker.Core&version=9.0.0-beta0005&prerelease // Install UrlTracker.Core as a Cake Tool #tool nuget:?package=UrlTracker.Core&version=9.0.0-beta0005&prerelease
<h3 align="center"> <img height="100" src="docs/assets/infocaster_nuget_yellow.svg"> </h3>
<h1 align="center"> URL Tracker
</h1>
This project is a continuation of the original URL Tracker, created by Kipusoep.
The URL Tracker makes url management easy. Your visitors will no longer be lost on your website as the URL Tracker watches how your website changes. Page moved or renamed? No problem! The URL Tracker knows this and directs your visitors to the right page. Not only does this provide a nice experience for your visitors, it also helps you maintain your rightful spot at the top in Google (and other search engines). The URL Tracker puts you in control by giving you the means to manage your own redirects. It can be as simple as a redirect from a url to an umbraco page, but you can make it as sophisticated as you like using Regular Expressions. The URL Tracker is an essential tool for content editors who want to migrate to a new Umbraco website, so they can guide their users to the right place.
Requirements
The URL Tracker is guaranteed to work with SQL Server databases. The URL Tracker does not work with SQL Compact Edition databases.
Getting Started
The URL Tracker is available via NuGet. Visit the URL Tracker on NuGet for instructions on how to install the URL Tracker package in your website.
Once installed, you'll have to actually use it in your request pipeline (Often found in the file Startup.cs
). For the best performance, you should insert the UrlTracker as high in the pipeline as possible. The UrlTracker requires an instantiated umbraco context, so make sure it is inserted after the umbraco context is initialized. We recommend that you insert the UrlTracker like this:
app.UseUmbraco()
.WithMiddleware(u =>
{
u.UseBackOffice();
u.UseWebsite();
// Insert behind 'UseWebsite' to ensure the existance of an UmbracoContext
u.UseUrlTracker();
})
Now build your project and you should be ready to make your visitors happy!
Configuration
The URL Tracker has several configurable properties that can be changed in appsettings.json:
{
"UrlTracker": {
"IsDisabled": false,
"IsTrackingDisabled": false,
"LoggingEnabled": false,
"IsNotFoundTrackingDisabled": false,
"AppendPortNumber": false,
"HasDomainOnChildNode": false,
"CacheRegexRedirects": true,
"InterceptSlidingCacheMinutes": 2880,
"MaxCachedIntercepts": 5000,
"EnableInterceptCaching": true
}
}
- Is disabled | Set this value to
true
to completely disable the URL Tracker. The URL Tracker will not intercept any requests nor track any content updates - Is tracking disabled | Set this value to
true
to disable tracking of content changes. The URL Tracker will not automatically create redirects when content is updated - Is not found tracking disabled | Set this value to
true
to disable tracking of Not Found responses. - Enable logging | Set this value to
true
to allow the URL Tracker to write logs to the Umbraco native logger. Most logs from the URL Tracker are written at Debug or Verbose level. - Append port number | Set this value to
true
to add a port number behind the host component of a redirect url. This setting is ignored when the application is hosted on the default port 80. - Has domain on child node | Set this value to
true
if your website has domains configured on pages that are not in the root of the website. - Cache regex redirects | Set this value to
false
to disable caching of regex redirects. By default, all regex redirects are cached in memory to improve performance. - Intercept sliding cache minutes | Set this value to the time in minutes that all redirects should be cached. By default, all redirects are cached for 2 days. Set to
null
to cache indefinitely. - Max cached intercepts | Set this value to the amount of intercepts that should be cached by the UrlTracker. This not only includes redirects, but also 200 OK responses, 410 GONE responses and 404 NOT FOUND responses.
- Enable intercept caching | Set this value to
false
to completely disable redirect caching.
Contributing
The URL Tracker is open for contributions. If you want to contribute to the source code, please check out our guide to contributing.
Many people have already contributed to this awesome project:
<a href="https://github.com/Infocaster/UrlTracker/graphs/contributors"> <img src="https://contrib.rocks/image?repo=Infocaster/UrlTracker" /> </a>
Made with contributors-img.
Credits
Credits from the original developer:
- InfoCaster | Being able to combine 'work' with package development and thanks to colleagues for inspiration.
- Richard Soeteman | Richard came up with the idea for a package which keeps track of URLs of umbraco nodes.
- The uComponents project | For inspiring me to create a single-assembly package solution. <a href="https://infocaster.net"> <img align="right" height="200" src="docs/assets/Infocaster_Corner.png"> </a>
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net5.0
- Microsoft.Extensions.Caching.Memory (>= 5.0.0)
- Scrutor (>= 4.0.0)
- Umbraco.Cms.Infrastructure (>= 9.2.0)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on UrlTracker.Core:
Package | Downloads |
---|---|
UrlTracker
The URL Tracker makes url management easy. Your visitors will no longer be lost on your website as the URL Tracker watches how your website changes. Page moved or renamed? No problem! The URL Tracker knows this and directs your visitors to the right page. Not only does this provide a nice experience for your visitors, it also helps you maintain your rightful spot at the top in Google (and other search engines). The URL Tracker puts you in control by giving you the means to manage your own redirects. It can be as simple as a redirect from a url to an umbraco page, but you can make it as sophisticated as you like using Regular Expressions. The URL Tracker is an essential tool for content editors who want to migrate to a new Umbraco website, so they can guide their users to the right place. For all versions of Umbraco 9 and up, match the major version of the URL Tracker with the major version of Umbraco. Use v5.x for umbraco 8, use v3.15 for umbraco 7. |
|
UrlTracker.Web
This package contains the web services for the URL Tracker. Useful for package development. |
|
UrlTracker.Middleware
This package contains middleware to perform redirects and to register client errors with the URL Tracker |
|
UrlTracker.Core.Caching.Memory
This package contains an in-memory cache layer for the core services of the URL Tracker |
|
UrlTracker.Backoffice.Notifications
This package contains notification handlers for the URL Tracker to handle Umbraco content notifications |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
13.2.0 | 2,738 | 10/4/2024 |
13.2.0-beta0001 | 177 | 9/10/2024 |
13.2.0-alpha0009 | 174 | 8/16/2024 |
13.2.0-alpha0008 | 1,029 | 6/19/2024 |
13.2.0-alpha0007 | 155 | 6/14/2024 |
13.2.0-alpha0006 | 153 | 6/14/2024 |
13.2.0-alpha0005 | 139 | 6/13/2024 |
13.2.0-alpha0004 | 259 | 6/6/2024 |
13.2.0-alpha0003 | 265 | 5/28/2024 |
13.2.0-alpha0002 | 153 | 5/24/2024 |
13.2.0-alpha0001 | 149 | 5/24/2024 |
13.1.0 | 15,300 | 4/11/2024 |
13.1.0-beta0003 | 163 | 3/12/2024 |
13.1.0-beta0002 | 154 | 2/16/2024 |
13.1.0-beta0001 | 145 | 2/16/2024 |
13.0.1-beta0001 | 159 | 1/16/2024 |
13.0.0 | 9,422 | 12/14/2023 |
13.0.0-beta0001 | 172 | 12/13/2023 |
12.0.4-beta0001 | 157 | 1/16/2024 |
12.0.3 | 3,656 | 12/11/2023 |
12.0.2 | 2,187 | 10/27/2023 |
12.0.0 | 5,072 | 7/4/2023 |
11.2.0 | 1,210 | 12/12/2023 |
11.1.2 | 354 | 10/27/2023 |
11.1.0 | 2,849 | 8/2/2023 |
11.1.0-beta0001 | 203 | 7/24/2023 |
11.0.1 | 9,241 | 12/7/2022 |
11.0.1-beta0001 | 201 | 12/7/2022 |
11.0.0 | 1,447 | 12/1/2022 |
11.0.0-beta0002 | 218 | 11/22/2022 |
11.0.0-beta0001 | 291 | 10/23/2022 |
10.5.0-alpha0009 | 236 | 8/16/2024 |
10.5.0-alpha0008 | 208 | 6/14/2024 |
10.5.0-alpha0007 | 201 | 6/14/2024 |
10.5.0-alpha0005 | 176 | 6/6/2024 |
10.5.0-alpha0004 | 206 | 6/3/2024 |
10.5.0-alpha0003 | 199 | 5/28/2024 |
10.5.0-alpha0002 | 199 | 5/24/2024 |
10.5.0-alpha0001 | 197 | 5/24/2024 |
10.5.0-alpha-6 | 227 | 6/13/2024 |
10.4.0 | 1,479 | 4/11/2024 |
10.4.0-beta0002 | 196 | 3/12/2024 |
10.4.0-beta0001 | 192 | 2/16/2024 |
10.3.5 | 1,998 | 2/14/2024 |
10.3.5-beta0001 | 193 | 1/16/2024 |
10.3.4-beta0002 | 210 | 1/12/2024 |
10.3.4-beta0001 | 206 | 1/8/2024 |
10.3.3 | 2,615 | 12/12/2023 |
10.3.2-beta0001 | 307 | 12/1/2023 |
10.3.1 | 1,690 | 10/27/2023 |
10.3.1-beta0001 | 187 | 10/17/2023 |
10.3.0 | 19,283 | 5/26/2023 |
10.3.0-beta0002 | 230 | 5/19/2023 |
10.3.0-beta0001 | 213 | 5/16/2023 |
10.2.1 | 14,924 | 12/7/2022 |
10.2.1-beta0001 | 225 | 12/7/2022 |
10.2.0 | 5,941 | 10/19/2022 |
10.2.0-beta0002 | 322 | 10/8/2022 |
10.2.0-beta0001 | 250 | 10/8/2022 |
10.1.1 | 2,482 | 9/15/2022 |
10.1.1-beta0001 | 1,230 | 8/30/2022 |
10.1.0 | 3,761 | 8/13/2022 |
10.1.0-beta0003 | 167 | 8/12/2022 |
10.1.0-beta0002 | 240 | 8/11/2022 |
10.1.0-beta0001 | 169 | 8/9/2022 |
10.0.2 | 4,806 | 7/20/2022 |
10.0.2-beta0001 | 196 | 7/7/2022 |
10.0.1 | 724 | 7/2/2022 |
10.0.0 | 1,450 | 6/16/2022 |
10.0.0-beta0002 | 185 | 6/13/2022 |
10.0.0-beta0001 | 177 | 5/14/2022 |
9.1.2 | 894 | 12/7/2022 |
9.1.2-beta0001 | 202 | 12/7/2022 |
9.1.1 | 910 | 9/17/2022 |
9.1.0 | 753 | 8/18/2022 |
9.1.0-beta0001 | 179 | 8/13/2022 |
9.1.0-alpha0002 | 196 | 6/14/2022 |
9.0.2 | 1,651 | 7/2/2022 |
9.0.2-beta0003 | 190 | 7/1/2022 |
9.0.2-beta0002 | 180 | 7/1/2022 |
9.0.2-beta0001 | 184 | 6/24/2022 |
9.0.1 | 854 | 6/15/2022 |
9.0.1-beta0002 | 195 | 6/11/2022 |
9.0.1-beta0001 | 187 | 6/8/2022 |
9.0.0 | 2,975 | 4/26/2022 |
9.0.0-beta0007 | 175 | 4/25/2022 |
9.0.0-beta0006 | 184 | 4/18/2022 |
9.0.0-beta0005 | 184 | 4/13/2022 |
9.0.0-beta0004 | 180 | 3/31/2022 |
9.0.0-beta0003 | 252 | 3/25/2022 |
First release for Umbraco 9