mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
Merge pull request #2299 from overleaf/as-cleanup-express-locals
Clean up express locals GitOrigin-RevId: f57e7c57913cbf894a365c5ae9dd2810245a01ae
This commit is contained in:
parent
42589f39a8
commit
4f637f14b5
6 changed files with 94 additions and 219 deletions
|
@ -82,7 +82,8 @@ module.exports = {
|
||||||
inviterName: invite.inviterName,
|
inviterName: invite.inviterName,
|
||||||
inviteToken: invite.token,
|
inviteToken: invite.token,
|
||||||
hasIndividualRecurlySubscription,
|
hasIndividualRecurlySubscription,
|
||||||
appName: settings.appName
|
appName: settings.appName,
|
||||||
|
expired: req.query.expired
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,45 +1,23 @@
|
||||||
/* eslint-disable
|
|
||||||
camelcase,
|
|
||||||
handle-callback-err,
|
|
||||||
max-len,
|
|
||||||
new-cap,
|
|
||||||
no-new-require,
|
|
||||||
no-unused-vars,
|
|
||||||
no-useless-escape,
|
|
||||||
*/
|
|
||||||
// TODO: This file was created by bulk-decaffeinate.
|
|
||||||
// Fix any style issues and re-enable lint.
|
|
||||||
/*
|
|
||||||
* decaffeinate suggestions:
|
|
||||||
* DS101: Remove unnecessary use of Array.from
|
|
||||||
* DS102: Remove unnecessary code created because of implicit returns
|
|
||||||
* DS103: Rewrite code to no longer use __guard__
|
|
||||||
* DS205: Consider reworking code to avoid use of IIFEs
|
|
||||||
* DS207: Consider shorter variations of null checks
|
|
||||||
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
||||||
*/
|
|
||||||
const logger = require('logger-sharelatex')
|
const logger = require('logger-sharelatex')
|
||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const crypto = require('crypto')
|
const crypto = require('crypto')
|
||||||
const Settings = require('settings-sharelatex')
|
const Settings = require('settings-sharelatex')
|
||||||
const SubscriptionFormatters = require('../Features/Subscription/SubscriptionFormatters')
|
|
||||||
const querystring = require('querystring')
|
const querystring = require('querystring')
|
||||||
const SystemMessageManager = require('../Features/SystemMessages/SystemMessageManager')
|
const _ = require('lodash')
|
||||||
const AuthenticationController = require('../Features/Authentication/AuthenticationController')
|
|
||||||
const _ = require('underscore')
|
|
||||||
const async = require('async')
|
|
||||||
let Modules = require('./Modules')
|
|
||||||
const Url = require('url')
|
const Url = require('url')
|
||||||
const PackageVersions = require('./PackageVersions')
|
const NodeHtmlEncoder = require('node-html-encoder').Encoder
|
||||||
const htmlEncoder = new require('node-html-encoder').Encoder('numerical')
|
|
||||||
const hashedFiles = {}
|
|
||||||
const Path = require('path')
|
const Path = require('path')
|
||||||
const Features = require('./Features')
|
|
||||||
Modules = require('./Modules')
|
|
||||||
const moment = require('moment')
|
const moment = require('moment')
|
||||||
const lodash = require('lodash')
|
|
||||||
const chokidar = require('chokidar')
|
const chokidar = require('chokidar')
|
||||||
|
|
||||||
|
const Features = require('./Features')
|
||||||
|
const AuthenticationController = require('../Features/Authentication/AuthenticationController')
|
||||||
|
const PackageVersions = require('./PackageVersions')
|
||||||
|
const SystemMessageManager = require('../Features/SystemMessages/SystemMessageManager')
|
||||||
|
const Modules = require('./Modules')
|
||||||
|
|
||||||
|
const htmlEncoder = new NodeHtmlEncoder('numerical')
|
||||||
|
|
||||||
const jsPath = Settings.useMinifiedJs ? '/minjs/' : '/js/'
|
const jsPath = Settings.useMinifiedJs ? '/minjs/' : '/js/'
|
||||||
|
|
||||||
const webpackManifestPath = Path.join(
|
const webpackManifestPath = Path.join(
|
||||||
|
@ -67,7 +45,7 @@ if (['development', 'test'].includes(process.env.NODE_ENV)) {
|
||||||
webpackManifest = require(webpackManifestPath)
|
webpackManifest = require(webpackManifestPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
const getFileContent = function(filePath) {
|
function getFileContent(filePath) {
|
||||||
filePath = Path.join(__dirname, '../../../', `public${filePath}`)
|
filePath = Path.join(__dirname, '../../../', `public${filePath}`)
|
||||||
const exists = fs.existsSync(filePath)
|
const exists = fs.existsSync(filePath)
|
||||||
if (exists) {
|
if (exists) {
|
||||||
|
@ -85,12 +63,12 @@ const pathList = [
|
||||||
'/stylesheets/ieee-style.css',
|
'/stylesheets/ieee-style.css',
|
||||||
'/stylesheets/sl-style.css'
|
'/stylesheets/sl-style.css'
|
||||||
]
|
]
|
||||||
|
const hashedFiles = {}
|
||||||
if (!Settings.useMinifiedJs) {
|
if (!Settings.useMinifiedJs) {
|
||||||
logger.log('not using minified JS, not hashing static files')
|
logger.log('not using minified JS, not hashing static files')
|
||||||
} else {
|
} else {
|
||||||
logger.log('Generating file hashes...')
|
logger.log('Generating file hashes...')
|
||||||
for (let path of Array.from(pathList)) {
|
for (let path of pathList) {
|
||||||
const content = getFileContent(path)
|
const content = getFileContent(path)
|
||||||
const hash = crypto
|
const hash = crypto
|
||||||
.createHash('md5')
|
.createHash('md5')
|
||||||
|
@ -112,31 +90,22 @@ if (!Settings.useMinifiedJs) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const cdnAvailable = Settings.cdn && Settings.cdn.web && !!Settings.cdn.web.host
|
module.exports = function(webRouter, privateApiRouter, publicApiRouter) {
|
||||||
|
|
||||||
const darkCdnAvailable =
|
|
||||||
Settings.cdn && Settings.cdn.web && !!Settings.cdn.web.darkHost
|
|
||||||
|
|
||||||
module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.session = req.session
|
res.locals.session = req.session
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
const addSetContentDisposition = function(req, res, next) {
|
function addSetContentDisposition(req, res, next) {
|
||||||
res.setContentDisposition = function(type, opts) {
|
res.setContentDisposition = function(type, opts) {
|
||||||
const directives = (() => {
|
const directives = _.map(
|
||||||
const result = []
|
opts,
|
||||||
for (let k in opts) {
|
(v, k) => `${k}="${encodeURIComponent(v)}"`
|
||||||
const v = opts[k]
|
)
|
||||||
result.push(`${k}=\"${encodeURIComponent(v)}\"`)
|
|
||||||
}
|
|
||||||
return result
|
|
||||||
})()
|
|
||||||
const contentDispositionValue = `${type}; ${directives.join('; ')}`
|
const contentDispositionValue = `${type}; ${directives.join('; ')}`
|
||||||
return res.setHeader('Content-Disposition', contentDispositionValue)
|
res.setHeader('Content-Disposition', contentDispositionValue)
|
||||||
}
|
}
|
||||||
return next()
|
next()
|
||||||
}
|
}
|
||||||
webRouter.use(addSetContentDisposition)
|
webRouter.use(addSetContentDisposition)
|
||||||
privateApiRouter.use(addSetContentDisposition)
|
privateApiRouter.use(addSetContentDisposition)
|
||||||
|
@ -148,50 +117,31 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
res.locals.externalAuthenticationSystemUsed =
|
res.locals.externalAuthenticationSystemUsed =
|
||||||
Features.externalAuthenticationSystemUsed
|
Features.externalAuthenticationSystemUsed
|
||||||
req.hasFeature = res.locals.hasFeature = Features.hasFeature
|
req.hasFeature = res.locals.hasFeature = Features.hasFeature
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
let staticFilesBase
|
let staticFilesBase
|
||||||
const cdnBlocked = req.query.nocdn === 'true' || req.session.cdnBlocked
|
|
||||||
const user_id = AuthenticationController.getLoggedInUserId(req)
|
|
||||||
|
|
||||||
|
const cdnAvailable =
|
||||||
|
Settings.cdn && Settings.cdn.web && !!Settings.cdn.web.host
|
||||||
|
const cdnBlocked = req.query.nocdn === 'true' || req.session.cdnBlocked
|
||||||
|
const userId = AuthenticationController.getLoggedInUserId(req)
|
||||||
if (cdnBlocked && req.session.cdnBlocked == null) {
|
if (cdnBlocked && req.session.cdnBlocked == null) {
|
||||||
logger.log(
|
logger.log(
|
||||||
{ user_id, ip: req != null ? req.ip : undefined },
|
{ user_id: userId, ip: req != null ? req.ip : undefined },
|
||||||
'cdnBlocked for user, not using it and turning it off for future requets'
|
'cdnBlocked for user, not using it and turning it off for future requets'
|
||||||
)
|
)
|
||||||
req.session.cdnBlocked = true
|
req.session.cdnBlocked = true
|
||||||
}
|
}
|
||||||
|
const host = req.headers && req.headers.host
|
||||||
const isDark =
|
const isSmoke = host.slice(0, 5).toLowerCase() === 'smoke'
|
||||||
__guard__(
|
if (cdnAvailable && !isSmoke && !cdnBlocked) {
|
||||||
__guard__(req.headers != null ? req.headers.host : undefined, x3 =>
|
|
||||||
x3.slice(0, 7)
|
|
||||||
),
|
|
||||||
x2 => x2.toLowerCase().indexOf('dark')
|
|
||||||
) !== -1
|
|
||||||
const isSmoke =
|
|
||||||
__guard__(
|
|
||||||
__guard__(req.headers != null ? req.headers.host : undefined, x5 =>
|
|
||||||
x5.slice(0, 5)
|
|
||||||
),
|
|
||||||
x4 => x4.toLowerCase()
|
|
||||||
) === 'smoke'
|
|
||||||
const isLive = !isDark && !isSmoke
|
|
||||||
|
|
||||||
if (cdnAvailable && isLive && !cdnBlocked) {
|
|
||||||
staticFilesBase = Settings.cdn.web.host
|
staticFilesBase = Settings.cdn.web.host
|
||||||
} else if (darkCdnAvailable && isDark) {
|
|
||||||
staticFilesBase = Settings.cdn.web.darkHost
|
|
||||||
} else {
|
} else {
|
||||||
staticFilesBase = ''
|
staticFilesBase = ''
|
||||||
}
|
}
|
||||||
|
|
||||||
res.locals.lib = PackageVersions.lib
|
|
||||||
|
|
||||||
res.locals.moment = moment
|
|
||||||
|
|
||||||
res.locals.buildJsPath = function(jsFile, opts = {}) {
|
res.locals.buildJsPath = function(jsFile, opts = {}) {
|
||||||
// Resolve path from webpack manifest file
|
// Resolve path from webpack manifest file
|
||||||
let path = webpackManifest[jsFile]
|
let path = webpackManifest[jsFile]
|
||||||
|
@ -217,6 +167,10 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
qs: { config: 'TeX-AMS_HTML,Safe' }
|
qs: { config: 'TeX-AMS_HTML,Safe' }
|
||||||
})
|
})
|
||||||
|
|
||||||
|
res.locals.lib = PackageVersions.lib
|
||||||
|
|
||||||
|
res.locals.moment = moment
|
||||||
|
|
||||||
const IEEE_BRAND_ID = 15
|
const IEEE_BRAND_ID = 15
|
||||||
res.locals.isIEEE = brandVariation =>
|
res.locals.isIEEE = brandVariation =>
|
||||||
(brandVariation != null ? brandVariation.brand_id : undefined) ===
|
(brandVariation != null ? brandVariation.brand_id : undefined) ===
|
||||||
|
@ -260,12 +214,7 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
return Url.resolve(staticFilesBase, path)
|
return Url.resolve(staticFilesBase, path)
|
||||||
}
|
}
|
||||||
|
|
||||||
return next()
|
next()
|
||||||
})
|
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
|
||||||
res.locals.settings = Settings
|
|
||||||
return next()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
|
@ -293,13 +242,17 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
}
|
}
|
||||||
return string.charAt(0).toUpperCase() + string.slice(1)
|
return string.charAt(0).toUpperCase() + string.slice(1)
|
||||||
}
|
}
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.getSiteHost = () =>
|
const subdomain = _.find(
|
||||||
Settings.siteUrl.substring(Settings.siteUrl.indexOf('//') + 2)
|
Settings.i18n.subdomainLang,
|
||||||
return next()
|
subdomain => subdomain.lngCode === req.showUserOtherLng && !subdomain.hide
|
||||||
|
)
|
||||||
|
res.locals.recomendSubdomain = subdomain
|
||||||
|
res.locals.currentLngCode = req.lng
|
||||||
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
|
@ -308,35 +261,23 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
const email = (user != null ? user.email : undefined) || ''
|
const email = (user != null ? user.email : undefined) || ''
|
||||||
return email
|
return email
|
||||||
}
|
}
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.StringHelper = require('../Features/Helpers/StringHelper')
|
res.locals.StringHelper = require('../Features/Helpers/StringHelper')
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.formatProjectPublicAccessLevel = function(privilegeLevel) {
|
res.locals.buildReferalUrl = function(referalMedium) {
|
||||||
const formatedPrivileges = {
|
|
||||||
private: 'Private',
|
|
||||||
readOnly: 'Public: Read Only',
|
|
||||||
readAndWrite: 'Public: Read and Write'
|
|
||||||
}
|
|
||||||
return formatedPrivileges[privilegeLevel] || 'Private'
|
|
||||||
}
|
|
||||||
return next()
|
|
||||||
})
|
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
|
||||||
res.locals.buildReferalUrl = function(referal_medium) {
|
|
||||||
let url = Settings.siteUrl
|
let url = Settings.siteUrl
|
||||||
const currentUser = AuthenticationController.getSessionUser(req)
|
const currentUser = AuthenticationController.getSessionUser(req)
|
||||||
if (
|
if (
|
||||||
currentUser != null &&
|
currentUser != null &&
|
||||||
(currentUser != null ? currentUser.referal_id : undefined) != null
|
(currentUser != null ? currentUser.referal_id : undefined) != null
|
||||||
) {
|
) {
|
||||||
url += `?r=${currentUser.referal_id}&rm=${referal_medium}&rs=b` // Referal source = bonus
|
url += `?r=${currentUser.referal_id}&rm=${referalMedium}&rs=b` // Referal source = bonus
|
||||||
}
|
}
|
||||||
return url
|
return url
|
||||||
}
|
}
|
||||||
|
@ -349,47 +290,23 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
return currentUser.referal_id
|
return currentUser.referal_id
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
res.locals.getReferalTagLine = function() {
|
next()
|
||||||
const tagLines = [
|
|
||||||
'Roar!',
|
|
||||||
'Shout about us!',
|
|
||||||
'Please recommend us',
|
|
||||||
'Tell the world!',
|
|
||||||
'Thanks for using ShareLaTeX'
|
|
||||||
]
|
|
||||||
return tagLines[Math.floor(Math.random() * tagLines.length)]
|
|
||||||
}
|
|
||||||
res.locals.getRedirAsQueryString = function() {
|
|
||||||
if (req.query.redir != null) {
|
|
||||||
return `?${querystring.stringify({ redir: req.query.redir })}`
|
|
||||||
}
|
|
||||||
return ''
|
|
||||||
}
|
|
||||||
|
|
||||||
res.locals.getLoggedInUserId = () =>
|
|
||||||
AuthenticationController.getLoggedInUserId(req)
|
|
||||||
res.locals.isUserLoggedIn = () =>
|
|
||||||
AuthenticationController.isUserLoggedIn(req)
|
|
||||||
res.locals.getSessionUser = () =>
|
|
||||||
AuthenticationController.getSessionUser(req)
|
|
||||||
|
|
||||||
return next()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.csrfToken = req != null ? req.csrfToken() : undefined
|
res.locals.csrfToken = req != null ? req.csrfToken() : undefined
|
||||||
return next()
|
next()
|
||||||
|
})
|
||||||
|
|
||||||
|
webRouter.use(function(req, res, next) {
|
||||||
|
res.locals.gaToken = Settings.analytics && Settings.analytics.ga.token
|
||||||
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.getReqQueryParam = field =>
|
res.locals.getReqQueryParam = field =>
|
||||||
req.query != null ? req.query[field] : undefined
|
req.query != null ? req.query[field] : undefined
|
||||||
return next()
|
next()
|
||||||
})
|
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
|
||||||
res.locals.formatPrice = SubscriptionFormatters.formatPrice
|
|
||||||
return next()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
|
@ -400,97 +317,67 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
first_name: currentUser.first_name,
|
first_name: currentUser.first_name,
|
||||||
last_name: currentUser.last_name
|
last_name: currentUser.last_name
|
||||||
}
|
}
|
||||||
if (req.session.justRegistered) {
|
|
||||||
res.locals.justRegistered = true
|
|
||||||
delete req.session.justRegistered
|
|
||||||
}
|
|
||||||
if (req.session.justLoggedIn) {
|
|
||||||
res.locals.justLoggedIn = true
|
|
||||||
delete req.session.justLoggedIn
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
res.locals.gaToken = Settings.analytics && Settings.analytics.ga.token
|
next()
|
||||||
res.locals.tenderUrl = Settings.tenderUrl
|
|
||||||
return next()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
if (req.query != null && req.query.scribtex_path != null) {
|
res.locals.getLoggedInUserId = () =>
|
||||||
res.locals.lookingForScribtex = true
|
AuthenticationController.getLoggedInUserId(req)
|
||||||
res.locals.scribtexPath = req.query.scribtex_path
|
res.locals.getSessionUser = () =>
|
||||||
}
|
AuthenticationController.getSessionUser(req)
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
// Clone the nav settings so they can be modified for each request
|
// Clone the nav settings so they can be modified for each request
|
||||||
res.locals.nav = {}
|
res.locals.nav = {}
|
||||||
for (let key in Settings.nav) {
|
for (let key in Settings.nav) {
|
||||||
const value = Settings.nav[key]
|
|
||||||
res.locals.nav[key] = _.clone(Settings.nav[key])
|
res.locals.nav[key] = _.clone(Settings.nav[key])
|
||||||
}
|
}
|
||||||
res.locals.templates = Settings.templateLinks
|
res.locals.templates = Settings.templateLinks
|
||||||
if (res.locals.nav.header) {
|
next()
|
||||||
console.error(
|
|
||||||
{},
|
|
||||||
'The `nav.header` setting is no longer supported, use `nav.header_extras` instead'
|
|
||||||
)
|
|
||||||
}
|
|
||||||
return next()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use((req, res, next) =>
|
webRouter.use((req, res, next) =>
|
||||||
SystemMessageManager.getMessages(function(error, messages) {
|
SystemMessageManager.getMessages(function(error, messages) {
|
||||||
|
if (error) {
|
||||||
|
return next(error)
|
||||||
|
}
|
||||||
if (messages == null) {
|
if (messages == null) {
|
||||||
messages = []
|
messages = []
|
||||||
}
|
}
|
||||||
res.locals.systemMessages = messages
|
res.locals.systemMessages = messages
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
|
||||||
res.locals.query = req.query
|
|
||||||
return next()
|
|
||||||
})
|
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
|
||||||
const subdomain = _.find(
|
|
||||||
Settings.i18n.subdomainLang,
|
|
||||||
subdomain => subdomain.lngCode === req.showUserOtherLng && !subdomain.hide
|
|
||||||
)
|
|
||||||
res.locals.recomendSubdomain = subdomain
|
|
||||||
res.locals.currentLngCode = req.lng
|
|
||||||
return next()
|
|
||||||
})
|
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
if (Settings.reloadModuleViewsOnEachRequest) {
|
if (Settings.reloadModuleViewsOnEachRequest) {
|
||||||
Modules.loadViewIncludes()
|
Modules.loadViewIncludes()
|
||||||
}
|
}
|
||||||
res.locals.moduleIncludes = Modules.moduleIncludes
|
res.locals.moduleIncludes = Modules.moduleIncludes
|
||||||
res.locals.moduleIncludesAvailable = Modules.moduleIncludesAvailable
|
res.locals.moduleIncludesAvailable = Modules.moduleIncludesAvailable
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
const isSl = Settings.brandPrefix === 'sl-'
|
|
||||||
res.locals.uiConfig = {
|
res.locals.uiConfig = {
|
||||||
defaultResizerSizeOpen: isSl ? 24 : 7,
|
defaultResizerSizeOpen: 7,
|
||||||
defaultResizerSizeClosed: isSl ? 24 : 7,
|
defaultResizerSizeClosed: 7,
|
||||||
eastResizerCursor: isSl ? null : 'ew-resize',
|
eastResizerCursor: 'ew-resize',
|
||||||
westResizerCursor: isSl ? null : 'ew-resize',
|
westResizerCursor: 'ew-resize',
|
||||||
chatResizerSizeOpen: isSl ? 12 : 7,
|
chatResizerSizeOpen: 7,
|
||||||
chatResizerSizeClosed: 0,
|
chatResizerSizeClosed: 0,
|
||||||
chatMessageBorderSaturation: isSl ? '70%' : '85%',
|
chatMessageBorderSaturation: '85%',
|
||||||
chatMessageBorderLightness: isSl ? '70%' : '40%',
|
chatMessageBorderLightness: '40%',
|
||||||
chatMessageBgSaturation: isSl ? '60%' : '85%',
|
chatMessageBgSaturation: '85%',
|
||||||
chatMessageBgLightness: isSl ? '97%' : '40%',
|
chatMessageBgLightness: '40%',
|
||||||
defaultFontFamily: isSl ? 'monaco' : 'lucida',
|
defaultFontFamily: 'lucida',
|
||||||
defaultLineHeight: isSl ? 'compact' : 'normal',
|
defaultLineHeight: 'normal',
|
||||||
renderAnnouncements: isSl
|
renderAnnouncements: false
|
||||||
}
|
}
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
|
@ -509,16 +396,21 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
return webRouter.use(function(req, res, next) {
|
webRouter.use(function(req, res, next) {
|
||||||
|
res.locals.settings = Settings
|
||||||
|
next()
|
||||||
|
})
|
||||||
|
|
||||||
|
webRouter.use(function(req, res, next) {
|
||||||
res.locals.ExposedSettings = {
|
res.locals.ExposedSettings = {
|
||||||
isOverleaf: Settings.overleaf != null,
|
isOverleaf: Settings.overleaf != null,
|
||||||
appName: Settings.appName,
|
appName: Settings.appName,
|
||||||
hasSamlBeta: req.session.samlBeta,
|
hasSamlBeta: req.session.samlBeta,
|
||||||
hasSamlFeature: Features.hasFeature('saml'),
|
hasSamlFeature: Features.hasFeature('saml'),
|
||||||
samlInitPath: lodash.get(Settings, ['saml', 'ukamf', 'initPath']),
|
samlInitPath: _.get(Settings, ['saml', 'ukamf', 'initPath']),
|
||||||
siteUrl: Settings.siteUrl,
|
siteUrl: Settings.siteUrl,
|
||||||
recaptchaSiteKeyV3:
|
recaptchaSiteKeyV3:
|
||||||
Settings.recaptcha != null ? Settings.recaptcha.siteKeyV3 : undefined,
|
Settings.recaptcha != null ? Settings.recaptcha.siteKeyV3 : undefined,
|
||||||
|
@ -526,12 +418,6 @@ module.exports = function(app, webRouter, privateApiRouter, publicApiRouter) {
|
||||||
Settings.recaptcha != null ? Settings.recaptcha.disabled : undefined,
|
Settings.recaptcha != null ? Settings.recaptcha.disabled : undefined,
|
||||||
validRootDocExtensions: Settings.validRootDocExtensions
|
validRootDocExtensions: Settings.validRootDocExtensions
|
||||||
}
|
}
|
||||||
return next()
|
next()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
function __guard__(value, transform) {
|
|
||||||
return typeof value !== 'undefined' && value !== null
|
|
||||||
? transform(value)
|
|
||||||
: undefined
|
|
||||||
}
|
|
||||||
|
|
|
@ -163,7 +163,7 @@ webRouter.use(function(req, res, next) {
|
||||||
})
|
})
|
||||||
|
|
||||||
webRouter.use(ReferalConnect.use)
|
webRouter.use(ReferalConnect.use)
|
||||||
expressLocals(app, webRouter, privateApiRouter, publicApiRouter)
|
expressLocals(webRouter, privateApiRouter, publicApiRouter)
|
||||||
|
|
||||||
if (app.get('env') === 'production') {
|
if (app.get('env') === 'production') {
|
||||||
logger.info('Production Enviroment')
|
logger.info('Production Enviroment')
|
||||||
|
|
|
@ -107,10 +107,6 @@ html(
|
||||||
- if(typeof(suppressFooter) == "undefined")
|
- if(typeof(suppressFooter) == "undefined")
|
||||||
include layout/footer
|
include layout/footer
|
||||||
|
|
||||||
- if (typeof(lookingForScribtex) != "undefined" && lookingForScribtex)
|
|
||||||
span(ng-controller="ScribtexPopupController")
|
|
||||||
include scribtex-modal
|
|
||||||
|
|
||||||
!= moduleIncludes("contactModal", locals)
|
!= moduleIncludes("contactModal", locals)
|
||||||
include v1-tooltip
|
include v1-tooltip
|
||||||
|
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
script(type='text/ng-template', id='scribtexModalTemplate')
|
|
||||||
.modal-header
|
|
||||||
h3 Looking for ScribTeX?
|
|
||||||
.modal-body
|
|
||||||
p ScribTeX has moved to <strong>https://scribtex.sharelatex.com</strong>. Please update your bookmarks.
|
|
||||||
p(style="text-align: center") You can find the page you were looking for here:
|
|
||||||
p(style="text-align: center")
|
|
||||||
a(href="https://scribtex.sharelatex.com"+scribtexPath, style="font-size: 16px", ng-non-bindable) https://scribtex.sharelatex.com#{scribtexPath}
|
|
|
@ -11,7 +11,7 @@ block content
|
||||||
.container
|
.container
|
||||||
.row
|
.row
|
||||||
.col-md-8.col-md-offset-2
|
.col-md-8.col-md-offset-2
|
||||||
-if (query.expired)
|
-if (expired)
|
||||||
.alert.alert-warning #{translate("email_link_expired")}
|
.alert.alert-warning #{translate("email_link_expired")}
|
||||||
|
|
||||||
.row.row-spaced
|
.row.row-spaced
|
||||||
|
|
Loading…
Reference in a new issue