2018-04-29 21:55:36 +00:00
|
|
|
require('../core/worker')
|
|
|
|
const _ = require('lodash')
|
|
|
|
const { createApolloFetch } = require('apollo-fetch')
|
|
|
|
|
|
|
|
/* global WIKI */
|
|
|
|
|
|
|
|
WIKI.redis = require('../core/redis').init()
|
2018-05-06 20:19:37 +00:00
|
|
|
WIKI.db = require('../core/db').init()
|
|
|
|
|
2018-04-29 21:55:36 +00:00
|
|
|
module.exports = async (job) => {
|
|
|
|
WIKI.logger.info('Syncing locales with Graph endpoint...')
|
|
|
|
|
|
|
|
try {
|
2018-05-28 18:46:55 +00:00
|
|
|
await WIKI.configSvc.loadFromDb()
|
|
|
|
const apollo = createApolloFetch({
|
|
|
|
uri: WIKI.config.graphEndpoint
|
|
|
|
})
|
2018-05-06 20:19:37 +00:00
|
|
|
|
|
|
|
// -> Fetch locales list
|
|
|
|
|
|
|
|
const respList = await apollo({
|
2018-04-29 21:55:36 +00:00
|
|
|
query: `{
|
|
|
|
localization {
|
|
|
|
locales {
|
|
|
|
code
|
|
|
|
name
|
|
|
|
nativeName
|
|
|
|
isRTL
|
|
|
|
createdAt
|
|
|
|
updatedAt
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}`
|
|
|
|
})
|
2018-05-06 20:19:37 +00:00
|
|
|
const locales = _.sortBy(_.get(respList, 'data.localization.locales', []), 'name').map(lc => ({...lc, isInstalled: (lc.code === 'en')}))
|
2018-04-29 21:55:36 +00:00
|
|
|
WIKI.redis.set('locales', JSON.stringify(locales))
|
2018-05-28 23:36:35 +00:00
|
|
|
const currentLocale = _.find(locales, ['code', WIKI.config.lang.code])
|
2018-05-06 20:19:37 +00:00
|
|
|
|
|
|
|
// -> Download locale strings
|
|
|
|
|
2018-05-28 23:36:35 +00:00
|
|
|
if (WIKI.config.langAutoUpdate) {
|
2018-05-06 20:19:37 +00:00
|
|
|
const respStrings = await apollo({
|
2018-05-07 03:21:48 +00:00
|
|
|
query: `query ($code: String!) {
|
2018-05-06 20:19:37 +00:00
|
|
|
localization {
|
2018-05-07 03:21:48 +00:00
|
|
|
strings(code: $code) {
|
2018-05-06 20:19:37 +00:00
|
|
|
key
|
|
|
|
value
|
|
|
|
}
|
|
|
|
}
|
2018-05-07 03:21:48 +00:00
|
|
|
}`,
|
|
|
|
variables: {
|
2018-05-28 23:36:35 +00:00
|
|
|
code: WIKI.config.lang.code
|
2018-05-07 03:21:48 +00:00
|
|
|
}
|
2018-05-06 20:19:37 +00:00
|
|
|
})
|
|
|
|
const strings = _.get(respStrings, 'data.localization.strings', [])
|
|
|
|
let lcObj = {}
|
|
|
|
_.forEach(strings, row => {
|
|
|
|
if (_.includes(row.key, '::')) { return }
|
|
|
|
_.set(lcObj, row.key.replace(':', '.'), row.value)
|
|
|
|
})
|
|
|
|
|
2018-05-19 20:40:07 +00:00
|
|
|
await WIKI.db.locales.query().update({
|
2018-05-28 23:36:35 +00:00
|
|
|
code: WIKI.config.lang.code,
|
2018-05-06 20:19:37 +00:00
|
|
|
strings: lcObj,
|
|
|
|
isRTL: currentLocale.isRTL,
|
|
|
|
name: currentLocale.name,
|
|
|
|
nativeName: currentLocale.nativeName
|
2018-05-28 23:36:35 +00:00
|
|
|
}).where('code', WIKI.config.lang.code)
|
2018-05-06 20:19:37 +00:00
|
|
|
}
|
2018-04-29 21:55:36 +00:00
|
|
|
|
|
|
|
WIKI.logger.info('Syncing locales with Graph endpoint: [ COMPLETED ]')
|
|
|
|
} catch (err) {
|
|
|
|
WIKI.logger.error('Syncing locales with Graph endpoint: [ FAILED ]')
|
|
|
|
WIKI.logger.error(err.message)
|
|
|
|
}
|
|
|
|
}
|