1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- const _ = require('lodash')
- const fs = require('fs')
- // const gqlTools = require('graphql-tools')
- const path = require('path')
- const autoload = require('auto-load')
- const PubSub = require('graphql-subscriptions').PubSub
- const { LEVEL, MESSAGE } = require('triple-beam')
- const Transport = require('winston-transport')
- const { createRateLimitTypeDef } = require('graphql-rate-limit-directive')
- // const { GraphQLUpload } = require('graphql-upload')
- /* global WIKI */
- WIKI.logger.info(`Loading GraphQL Schema...`)
- // Init Subscription PubSub
- WIKI.GQLEmitter = new PubSub()
- // Schemas
- let typeDefs = [createRateLimitTypeDef()]
- 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
- let resolvers = {
- // Upload: GraphQLUpload
- }
- const resolversObj = _.values(autoload(path.join(WIKI.SERVERPATH, 'graph/resolvers')))
- resolversObj.forEach(resolver => {
- _.merge(resolvers, resolver)
- })
- // Directives
- let schemaDirectives = {
- ...autoload(path.join(WIKI.SERVERPATH, 'graph/directives'))
- }
- // Live Trail Logger (admin)
- 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)
- }
- }
- WIKI.logger.add(new LiveTrailLogger({}))
- WIKI.logger.info(`GraphQL Schema: [ OK ]`)
- module.exports = {
- typeDefs,
- resolvers,
- schemaDirectives
- }
|