fetch-graph-locale.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. require('../core/worker')
  2. const _ = require('lodash')
  3. const { createApolloFetch } = require('apollo-fetch')
  4. /* global WIKI */
  5. WIKI.redis = require('../core/redis').init()
  6. WIKI.db = require('../core/db').init()
  7. const apollo = createApolloFetch({
  8. uri: 'https://graph.requarks.io'
  9. })
  10. module.exports = async (job) => {
  11. WIKI.logger.info(`Fetching locale ${job.data.locale} from Graph endpoint...`)
  12. try {
  13. const respStrings = await apollo({
  14. query: `query ($code: String!) {
  15. localization {
  16. strings(code: $code) {
  17. key
  18. value
  19. }
  20. }
  21. }`,
  22. variables: {
  23. code: job.data.locale
  24. }
  25. })
  26. const strings = _.get(respStrings, 'data.localization.strings', [])
  27. let lcObj = {}
  28. _.forEach(strings, row => {
  29. if (_.includes(row.key, '::')) { return }
  30. _.set(lcObj, row.key.replace(':', '.'), row.value)
  31. })
  32. const locales = await WIKI.redis.get('locales')
  33. if (locales) {
  34. const currentLocale = _.find(JSON.parse(locales), ['code', job.data.locale]) || {}
  35. await WIKI.db.Locale.upsert({
  36. code: job.data.locale,
  37. strings: lcObj,
  38. isRTL: currentLocale.isRTL,
  39. name: currentLocale.name,
  40. nativeName: currentLocale.nativeName
  41. })
  42. } else {
  43. throw new Error('Failed to fetch cached locales list! Restart server to resolve this issue.')
  44. }
  45. WIKI.logger.info(`Fetching locale ${job.data.locale} from Graph endpoint: [ COMPLETED ]`)
  46. } catch (err) {
  47. WIKI.logger.error(`Fetching locale ${job.data.locale} from Graph endpoint: [ FAILED ]`)
  48. WIKI.logger.error(err.message)
  49. }
  50. }