mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-29 23:04:15 -05:00
Merge pull request #5558 from overleaf/jpa-ta-canonical-url-tag
[web] add a canonical tag to gallery/learn/blog GitOrigin-RevId: c6b9e84a0dbf04e44dbc507ae5dbf9ef2d95b8cc
This commit is contained in:
parent
c5778fdd05
commit
aa846a6af2
2 changed files with 18 additions and 0 deletions
|
@ -1,6 +1,19 @@
|
|||
const Settings = require('@overleaf/settings')
|
||||
const { URL } = require('url')
|
||||
|
||||
const PROTO = new URL(Settings.siteUrl).protocol
|
||||
|
||||
function getCanonicalURL(req, url) {
|
||||
const origin = `${PROTO}//${req.headers.host}`
|
||||
url = new URL(url || req.originalUrl, origin)
|
||||
if (url.pathname.endsWith('/')) {
|
||||
url.pathname = url.pathname.replace(/\/+$/, '')
|
||||
}
|
||||
url.search = ''
|
||||
url.hash = ''
|
||||
return url.href
|
||||
}
|
||||
|
||||
function getSafeRedirectPath(value) {
|
||||
const baseURL = Settings.siteUrl // base URL is required to construct URL from path
|
||||
const url = new URL(value, baseURL)
|
||||
|
@ -12,6 +25,7 @@ function getSafeRedirectPath(value) {
|
|||
}
|
||||
|
||||
const UrlHelper = {
|
||||
getCanonicalURL,
|
||||
getSafeRedirectPath,
|
||||
wrapUrlWithProxy(url) {
|
||||
// TODO: Consider what to do for Community and Enterprise edition?
|
||||
|
|
|
@ -113,3 +113,7 @@ link(rel="icon", href="/favicon.ico")
|
|||
link(rel="icon", sizes="192x192", href="/touch-icon-192x192.png")
|
||||
link(rel="apple-touch-icon-precomposed", href="/apple-touch-icon-precomposed.png")
|
||||
link(rel="mask-icon", href="/mask-favicon.svg", color="#138A07")
|
||||
|
||||
//- Canonical Tag for SEO
|
||||
if (metadata && metadata.canonicalURL)
|
||||
link(rel="canonical" href=metadata.canonicalURL)
|
||||
|
|
Loading…
Reference in a new issue