forked from AkkomaGang/admin-fe
Merge branch 'fix-config-value-type' into 'master'
Fix config value type See merge request pleroma/admin-fe!31
This commit is contained in:
commit
5670be0e3a
2 changed files with 51 additions and 15 deletions
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue