index.js 1.68 KB
Newer Older
1 2
const _ = require('lodash')
const fs = require('fs')
3
// const gqlTools = require('graphql-tools')
4 5
const path = require('path')
const autoload = require('auto-load')
6
const PubSub = require('graphql-subscriptions').PubSub
7 8
const { LEVEL, MESSAGE } = require('triple-beam')
const Transport = require('winston-transport')
Nick's avatar
Nick committed
9
const { createRateLimitTypeDef } = require('graphql-rate-limit-directive')
10
// const { GraphQLUpload } = require('graphql-upload')
11 12 13 14 15

/* global WIKI */

WIKI.logger.info(`Loading GraphQL Schema...`)

16 17 18 19
// Init Subscription PubSub

WIKI.GQLEmitter = new PubSub()

20 21
// Schemas

22
let typeDefs = [createRateLimitTypeDef()]
23 24 25 26 27 28 29
let schemas = fs.readdirSync(path.join(WIKI.SERVERPATH, 'graph/schemas'))
schemas.forEach(schema => {
  typeDefs.push(fs.readFileSync(path.join(WIKI.SERVERPATH, `graph/schemas/${schema}`), 'utf8'))
})

// Resolvers

30
let resolvers = {
31
  // Upload: GraphQLUpload
32
}
33 34 35 36 37
const resolversObj = _.values(autoload(path.join(WIKI.SERVERPATH, 'graph/resolvers')))
resolversObj.forEach(resolver => {
  _.merge(resolvers, resolver)
})

38 39
// Directives

40
let schemaDirectives = {
Nick's avatar
Nick committed
41
  ...autoload(path.join(WIKI.SERVERPATH, 'graph/directives'))
42
}
43

44 45
// Live Trail Logger (admin)

46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
class LiveTrailLogger extends Transport {
  constructor(opts) {
    super(opts)

    this.name = 'liveTrailLogger'
    this.level = 'debug'
  }

  log (info, callback = () => {}) {
    WIKI.GQLEmitter.publish('livetrail', {
      loggingLiveTrail: {
        timestamp: new Date(),
        level: info[LEVEL],
        output: info[MESSAGE]
      }
    })
    callback(null, true)
  }
64 65 66
}

WIKI.logger.add(new LiveTrailLogger({}))
67 68 69

WIKI.logger.info(`GraphQL Schema: [ OK ]`)

70 71
module.exports = {
  typeDefs,
72 73
  resolvers,
  schemaDirectives
74
}