12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- const _ = require('lodash')
- const graphHelper = require('../../helpers/graph')
- /* global WIKI */
- module.exports = {
- Query: {
- async logging() { return {} }
- },
- Mutation: {
- async logging() { return {} }
- },
- Subscription: {
- loggingLiveTrail: {
- subscribe: () => WIKI.GQLEmitter.asyncIterator('livetrail')
- }
- },
- LoggingQuery: {
- async loggers(obj, args, context, info) {
- let loggers = await WIKI.models.loggers.getLoggers()
- loggers = loggers.map(logger => {
- const loggerInfo = _.find(WIKI.data.loggers, ['key', logger.key]) || {}
- return {
- ...loggerInfo,
- ...logger,
- config: _.sortBy(_.transform(logger.config, (res, value, key) => {
- const configData = _.get(loggerInfo.props, key, {})
- res.push({
- key,
- value: JSON.stringify({
- ...configData,
- value
- })
- })
- }, []), 'key')
- }
- })
- // if (args.filter) { loggers = graphHelper.filter(loggers, args.filter) }
- if (args.orderBy) { loggers = _.sortBy(loggers, [args.orderBy]) }
- return loggers
- }
- },
- LoggingMutation: {
- async updateLoggers(obj, args, context) {
- try {
- for (let logger of args.loggers) {
- await WIKI.models.loggers.query().patch({
- isEnabled: logger.isEnabled,
- level: logger.level,
- config: _.reduce(logger.config, (result, value, key) => {
- _.set(result, `${value.key}`, value.value)
- return result
- }, {})
- }).where('key', logger.key)
- }
- return {
- responseResult: graphHelper.generateSuccess('Loggers updated successfully')
- }
- } catch (err) {
- return graphHelper.generateError(err)
- }
- }
- }
- }
|