logging.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. const _ = require('lodash')
  2. const graphHelper = require('../../helpers/graph')
  3. /* global WIKI */
  4. module.exports = {
  5. Query: {
  6. async logging() { return {} }
  7. },
  8. Mutation: {
  9. async logging() { return {} }
  10. },
  11. LoggingQuery: {
  12. async loggers(obj, args, context, info) {
  13. let loggers = await WIKI.models.loggers.getLoggers()
  14. loggers = loggers.map(logger => {
  15. const loggerInfo = _.find(WIKI.data.loggers, ['key', logger.key]) || {}
  16. return {
  17. ...loggerInfo,
  18. ...logger,
  19. config: _.sortBy(_.transform(logger.config, (res, value, key) => {
  20. const configData = _.get(loggerInfo.props, key, {})
  21. res.push({
  22. key,
  23. value: JSON.stringify({
  24. ...configData,
  25. value
  26. })
  27. })
  28. }, []), 'key')
  29. }
  30. })
  31. if (args.filter) { loggers = graphHelper.filter(loggers, args.filter) }
  32. if (args.orderBy) { loggers = graphHelper.orderBy(loggers, args.orderBy) }
  33. return loggers
  34. }
  35. },
  36. LoggingMutation: {
  37. async updateLoggers(obj, args, context) {
  38. try {
  39. for (let logger of args.loggers) {
  40. await WIKI.models.loggers.query().patch({
  41. isEnabled: logger.isEnabled,
  42. level: logger.level,
  43. config: _.reduce(logger.config, (result, value, key) => {
  44. _.set(result, `${value.key}`, value.value)
  45. return result
  46. }, {})
  47. }).where('key', logger.key)
  48. }
  49. return {
  50. responseResult: graphHelper.generateSuccess('Loggers updated successfully')
  51. }
  52. } catch (err) {
  53. return graphHelper.generateError(err)
  54. }
  55. }
  56. }
  57. }