Security upgrades
This commit is contained in:
52
node_modules/jss/src/utils/createGenerateId.js
generated
vendored
Normal file
52
node_modules/jss/src/utils/createGenerateId.js
generated
vendored
Normal file
@@ -0,0 +1,52 @@
|
||||
/* @flow */
|
||||
import warning from 'tiny-warning'
|
||||
import type {Rule} from '../types'
|
||||
import StyleSheet from '../StyleSheet'
|
||||
import moduleId from './moduleId'
|
||||
|
||||
const maxRules = 1e10
|
||||
|
||||
export type CreateGenerateIdOptions = {|
|
||||
minify: boolean
|
||||
|}
|
||||
export type GenerateId = (rule: Rule, sheet?: StyleSheet) => string
|
||||
|
||||
export type CreateGenerateId = (options: CreateGenerateIdOptions) => GenerateId
|
||||
|
||||
/**
|
||||
* Returns a function which generates unique class names based on counters.
|
||||
* When new generator function is created, rule counter is reseted.
|
||||
* We need to reset the rule counter for SSR for each request.
|
||||
*/
|
||||
const createGenerateId: CreateGenerateId = (options = {}) => {
|
||||
let ruleCounter = 0
|
||||
|
||||
return (rule: Rule, sheet?: StyleSheet): string => {
|
||||
ruleCounter += 1
|
||||
|
||||
if (ruleCounter > maxRules) {
|
||||
warning(false, `[JSS] You might have a memory leak. Rule counter is at ${ruleCounter}.`)
|
||||
}
|
||||
|
||||
let jssId = ''
|
||||
let prefix = ''
|
||||
|
||||
if (sheet) {
|
||||
if (sheet.options.classNamePrefix) {
|
||||
prefix = sheet.options.classNamePrefix
|
||||
}
|
||||
if (sheet.options.jss.id != null) {
|
||||
jssId = String(sheet.options.jss.id)
|
||||
}
|
||||
}
|
||||
|
||||
if (options.minify) {
|
||||
// Using "c" because a number can't be the first char in a class name.
|
||||
return `${prefix || 'c'}${moduleId}${jssId}${ruleCounter}`
|
||||
}
|
||||
|
||||
return `${prefix + rule.key}-${moduleId}${jssId ? `-${jssId}` : ''}-${ruleCounter}`
|
||||
}
|
||||
}
|
||||
|
||||
export default createGenerateId
|
||||
Reference in New Issue
Block a user