/* eslint-disable no-console */ const path = require('path') const { createFilePath } = require('gatsby-source-filesystem') const Swagger = require('swagger-client') exports.onCreateNode = ({ node, getNode, actions }) => { const { createNodeField } = actions if (node.internal.type === 'MarkdownRemark') { const fileNode = getNode(node.parent) const parsedFilePath = path.parse(fileNode.relativePath) let slug = createFilePath({ node, getNode, basePath: 'content' }) let section = parsedFilePath.dir if (node.frontmatter.slug) { ;({ slug } = node.frontmatter) } if (node.frontmatter.section) { ;({ section } = node.frontmatter) } createNodeField({ node, name: 'slug', value: slug }) createNodeField({ node, name: 'section', value: section }) } } // https://github.com/swagger-api/swagger-js const getSpec = async () => { const spec = await Swagger( 'http://petstore.swagger.io/v2/swagger.json' ).then(client => { return client.spec // The resolved spec // client.originalSpec // In case you need it // client.errors // Any resolver errors // Tags interface // client.apis.pet.addPet({id: 1, name: "bobby"}).then(...) // TryItOut Executor, with the `spec` already provided // client.execute({operationId: 'addPet', parameters: {id: 1, name: "bobby") }).then(...) }) return spec } exports.createPages = ({ graphql, actions }) => { const { createPage } = actions return new Promise((resolve, reject) => { resolve( graphql( ` query { allMarkdownRemark( filter: { fileAbsolutePath: { regex: "/content/" } } ) { edges { node { fields { slug section } } } } devOceanDocs: allMarkdownRemark( filter: { fileAbsolutePath: { regex: "/dev-ocean/doc/" } } ) { edges { node { fields { slug section } frontmatter { slug title description section } } } } } ` ).then(async result => { if (result.errors) { console.log(result.errors) reject(result.errors) } const docTemplate = path.resolve('./src/templates/Doc.jsx') const posts = result.data.allMarkdownRemark.edges // // Create Doc pages // posts.forEach(post => { createPage({ path: `${post.node.fields.slug}`, component: docTemplate, context: { slug: post.node.fields.slug, section: post.node.fields.section } }) }) // // Create pages from dev-ocean contents // const postsDevOcean = result.data.devOceanDocs.edges postsDevOcean // only grab files with required frontmatter defined .filter( post => post.node.frontmatter && post.node.frontmatter.slug && post.node.frontmatter.title && post.node.frontmatter.description && post.node.frontmatter.section ) .forEach(post => { createPage({ path: `${post.node.fields.slug}`, component: docTemplate, context: { slug: post.node.fields.slug, section: post.node.fields.section } }) }) // // Create pages from swagger json files // const apiSwaggerTemplate = path.resolve( './src/templates/ApiSwagger.jsx' ) const petStoreSlug = '/api/petstore/' try { const spec = await getSpec() createPage({ path: petStoreSlug, component: apiSwaggerTemplate, context: { slug: petStoreSlug, api: spec } }) } catch (error) { console.log(error) } const aquariusSpecs = require('./data/aquarius.json') const aquariusSlug = '/api/aquarius/' createPage({ path: aquariusSlug, component: apiSwaggerTemplate, context: { slug: aquariusSlug, api: aquariusSpecs } }) const brizoSpecs = require('./data/brizo.json') const brizoSlug = '/api/brizo/' createPage({ path: brizoSlug, component: apiSwaggerTemplate, context: { slug: brizoSlug, api: brizoSpecs } }) resolve() }) ) }) }