Merge branch 'fix-config-value-type' into 'master'

Fix config value type

See merge request pleroma/admin-fe!31
This commit is contained in:
Angelina Filippova 2019-08-21 11:37:55 +00:00
commit 5670be0e3a
2 changed files with 51 additions and 15 deletions

View file

@ -12,9 +12,8 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
### Fixed ### Fixed
- fixes inputs for renders_errors and rewrite_policy settings - converts maps and structs to JS objects, not array of tuples when wrapping config
- removes unnecessary computed properties - changes type of IP value from string to number
- enables source maps for production build
## [1.0.1] - 2019-08-15 ## [1.0.1] - 2019-08-15

View file

@ -1,4 +1,7 @@
const nonAtomsTuples = ['replace', 'match_actor', ':replace', ':match_actor'] const nonAtomsTuples = ['replace', ':replace']
const nonAtomsObjects = ['match_actor', ':match_actor']
const objects = ['digest', 'pleroma_fe', 'masto_fe', 'poll_limits']
const objectParents = ['mascots']
const groups = { const groups = {
'cors_plug': [ 'cors_plug': [
'credentials', 'credentials',
@ -146,16 +149,23 @@ export const wrapConfig = settings => {
} else if (key === ':rate_limit') { } else if (key === ':rate_limit') {
return [...acc, { 'tuple': [`:${settingName}`, data] }] return [...acc, { 'tuple': [`:${settingName}`, data] }]
} else if (settingName === 'ip') { } else if (settingName === 'ip') {
const ip = data.split('.') const ip = data.split('.').map(s => parseInt(s, 10))
return [...acc, { 'tuple': [`:${settingName}`, { 'tuple': ip }] }] return [...acc, { 'tuple': [`:${settingName}`, { 'tuple': ip }] }]
} else if (!Array.isArray(data) && typeof data === 'object') { } else if (Array.isArray(data) || typeof data !== 'object') {
return nonAtomsTuples.includes(settingName) return key === ':mrf_user_allowlist'
? [...acc, { 'tuple': [`:${settingName}`, wrapNonAtomsTuples(data)] }] ? [...acc, { 'tuple': [`${settingName}`, data] }]
: [...acc, { 'tuple': [`:${settingName}`, wrapNestedTuples(data)] }] : [...acc, { 'tuple': [`:${settingName}`, data] }]
} else if (nonAtomsObjects.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapNonAtomsObjects(data)] }]
} else if (objectParents.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapNestedObjects(data)] }]
} else if (objects.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapObjects(data)] }]
} else if (nonAtomsTuples.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapNonAtomsTuples(data)] }]
} else {
return [...acc, { 'tuple': [`:${settingName}`, wrapNestedTuples(data)] }]
} }
return key === ':mrf_user_allowlist'
? [...acc, { 'tuple': [`${settingName}`, settings[config][settingName]] }]
: [...acc, { 'tuple': [`:${settingName}`, settings[config][settingName]] }]
}, []) }, [])
return { group, key, value } return { group, key, value }
}) })
@ -167,12 +177,21 @@ const wrapNestedTuples = setting => {
if (data === null || data === '') { if (data === null || data === '') {
return acc return acc
} else if (settingName === 'ip') { } else if (settingName === 'ip') {
const ip = data.split('.') const ip = data.split('.').map(s => parseInt(s, 10))
return [...acc, { 'tuple': [`:${settingName}`, { 'tuple': ip }] }] return [...acc, { 'tuple': [`:${settingName}`, { 'tuple': ip }] }]
} else if (!Array.isArray(data) && typeof data === 'object') { } else if (Array.isArray(data) || typeof data !== 'object') {
return [...acc, { 'tuple': [`:${settingName}`, data] }]
} else if (nonAtomsObjects.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapNonAtomsObjects(data)] }]
} else if (objectParents.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapNestedObjects(data)] }]
} else if (objects.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapObjects(data)] }]
} else if (nonAtomsTuples.includes(settingName)) {
return [...acc, { 'tuple': [`:${settingName}`, wrapNonAtomsTuples(data)] }]
} else {
return [...acc, { 'tuple': [`:${settingName}`, wrapNestedTuples(data)] }] return [...acc, { 'tuple': [`:${settingName}`, wrapNestedTuples(data)] }]
} }
return [...acc, { 'tuple': [`:${settingName}`, setting[settingName]] }]
}, []) }, [])
} }
@ -182,6 +201,24 @@ const wrapNonAtomsTuples = setting => {
}, []) }, [])
} }
const wrapNestedObjects = setting => {
return Object.keys(setting).reduce((acc, settingName) => {
return [...acc, { 'tuple': [`:${settingName}`, wrapObjects(setting[settingName])] }]
}, [])
}
const wrapNonAtomsObjects = setting => {
return Object.keys(setting).reduce((acc, settingName) => {
return { ...acc, [`${settingName}`]: setting[settingName] }
}, {})
}
const wrapObjects = setting => {
return Object.keys(setting).reduce((acc, settingName) => {
return { ...acc, [`:${settingName}`]: setting[settingName] }
}, {})
}
const getGroup = key => { const getGroup = key => {
return Object.keys(groups).find(i => groups[i].includes(key)) return Object.keys(groups).find(i => groups[i].includes(key))
} }