|
|
|
const _ = require('lodash')
|
|
|
|
const { createApolloFetch } = require('apollo-fetch')
|
|
|
|
|
|
|
|
/* global WIKI */
|
|
|
|
|
|
|
|
module.exports = async (localeCode) => {
|
|
|
|
WIKI.logger.info(`Fetching locale ${localeCode} from Graph endpoint...`)
|
|
|
|
|
|
|
|
try {
|
|
|
|
const apollo = createApolloFetch({
|
|
|
|
uri: WIKI.config.graphEndpoint
|
|
|
|
})
|
|
|
|
|
|
|
|
const respStrings = await apollo({
|
|
|
|
query: `query ($code: String!) {
|
|
|
|
localization {
|
|
|
|
strings(code: $code) {
|
|
|
|
key
|
|
|
|
value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}`,
|
|
|
|
variables: {
|
|
|
|
code: localeCode
|
|
|
|
}
|
|
|
|
})
|
|
|
|
const strings = _.get(respStrings, 'data.localization.strings', [])
|
|
|
|
let lcObj = {}
|
|
|
|
_.forEach(strings, row => {
|
|
|
|
if (_.includes(row.key, '::')) { return }
|
|
|
|
if (_.isEmpty(row.value)) {
|
|
|
|
row.value = row.key
|
|
|
|
}
|
|
|
|
_.set(lcObj, row.key.replace(':', '.'), row.value)
|
|
|
|
})
|
|
|
|
|
|
|
|
const locales = await WIKI.cache.get('locales')
|
|
|
|
if (locales) {
|
|
|
|
const currentLocale = _.find(locales, ['code', localeCode]) || {}
|
|
|
|
const existingLocale = await WIKI.models.locales.query().where('code', localeCode).first()
|
|
|
|
if (existingLocale) {
|
|
|
|
await WIKI.models.locales.query().patch({
|
|
|
|
strings: lcObj
|
|
|
|
}).where('code', localeCode)
|
|
|
|
} else {
|
|
|
|
await WIKI.models.locales.query().insert({
|
|
|
|
code: localeCode,
|
|
|
|
strings: lcObj,
|
|
|
|
isRTL: currentLocale.isRTL,
|
|
|
|
name: currentLocale.name,
|
|
|
|
nativeName: currentLocale.nativeName,
|
|
|
|
availability: currentLocale.availability
|
|
|
|
})
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
throw new Error('Failed to fetch cached locales list! Restart server to resolve this issue.')
|
|
|
|
}
|
|
|
|
|
|
|
|
await WIKI.lang.refreshNamespaces()
|
|
|
|
|
|
|
|
WIKI.logger.info(`Fetching locale ${localeCode} from Graph endpoint: [ COMPLETED ]`)
|
|
|
|
} catch (err) {
|
|
|
|
WIKI.logger.error(`Fetching locale ${localeCode} from Graph endpoint: [ FAILED ]`)
|
|
|
|
WIKI.logger.error(err.message)
|
|
|
|
}
|
|
|
|
}
|