You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
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 }
|