2018-11-28 12:19:11 +01:00
|
|
|
/* eslint-disable no-console */
|
|
|
|
|
2018-11-07 16:13:20 +01:00
|
|
|
const path = require('path')
|
|
|
|
const { createFilePath } = require('gatsby-source-filesystem')
|
2018-11-28 12:19:11 +01:00
|
|
|
const Swagger = require('swagger-client')
|
2018-11-29 10:47:42 +01:00
|
|
|
const { redirects } = require('./config')
|
2018-11-07 12:24:53 +01:00
|
|
|
|
2018-11-07 16:13:20 +01:00
|
|
|
exports.onCreateNode = ({ node, getNode, actions }) => {
|
|
|
|
const { createNodeField } = actions
|
|
|
|
|
2018-11-08 16:03:16 +01:00
|
|
|
if (node.internal.type === 'MarkdownRemark') {
|
2018-11-07 16:13:20 +01:00
|
|
|
const fileNode = getNode(node.parent)
|
|
|
|
const parsedFilePath = path.parse(fileNode.relativePath)
|
2018-11-14 15:17:19 +01:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
2018-11-07 16:13:20 +01:00
|
|
|
|
|
|
|
createNodeField({
|
|
|
|
node,
|
|
|
|
name: 'slug',
|
|
|
|
value: slug
|
|
|
|
})
|
|
|
|
|
|
|
|
createNodeField({
|
|
|
|
node,
|
|
|
|
name: 'section',
|
|
|
|
value: section
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.createPages = ({ graphql, actions }) => {
|
2018-11-29 10:47:42 +01:00
|
|
|
const { createPage, createRedirect } = actions
|
2018-11-07 16:13:20 +01:00
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
resolve(
|
|
|
|
graphql(
|
|
|
|
`
|
2018-11-27 13:54:00 +01:00
|
|
|
query {
|
2018-11-09 22:10:35 +01:00
|
|
|
allMarkdownRemark(
|
|
|
|
filter: { fileAbsolutePath: { regex: "/content/" } }
|
|
|
|
) {
|
2018-11-07 16:13:20 +01:00
|
|
|
edges {
|
|
|
|
node {
|
|
|
|
fields {
|
|
|
|
slug
|
|
|
|
section
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-11-14 13:00:32 +01:00
|
|
|
|
2018-11-16 14:52:42 +01:00
|
|
|
devOceanDocs: allMarkdownRemark(
|
2018-11-14 15:17:19 +01:00
|
|
|
filter: {
|
2018-11-15 14:46:20 +01:00
|
|
|
fileAbsolutePath: { regex: "/dev-ocean/doc/" }
|
2018-11-14 15:17:19 +01:00
|
|
|
}
|
|
|
|
) {
|
|
|
|
edges {
|
|
|
|
node {
|
|
|
|
fields {
|
|
|
|
slug
|
|
|
|
section
|
2018-11-14 13:00:32 +01:00
|
|
|
}
|
2018-11-14 17:02:31 +01:00
|
|
|
frontmatter {
|
|
|
|
slug
|
|
|
|
title
|
|
|
|
description
|
|
|
|
section
|
|
|
|
}
|
2018-11-14 13:00:32 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-11-07 16:13:20 +01:00
|
|
|
}
|
|
|
|
`
|
2018-11-28 12:19:11 +01:00
|
|
|
).then(async result => {
|
2018-11-07 16:13:20 +01:00
|
|
|
if (result.errors) {
|
|
|
|
console.log(result.errors)
|
|
|
|
reject(result.errors)
|
|
|
|
}
|
|
|
|
|
|
|
|
const docTemplate = path.resolve('./src/templates/Doc.jsx')
|
2018-11-14 13:00:32 +01:00
|
|
|
const posts = result.data.allMarkdownRemark.edges
|
2018-11-07 16:13:20 +01:00
|
|
|
|
2018-11-28 12:19:11 +01:00
|
|
|
//
|
2018-11-07 16:13:20 +01:00
|
|
|
// Create Doc pages
|
2018-11-28 12:19:11 +01:00
|
|
|
//
|
2018-11-07 16:13:20 +01:00
|
|
|
posts.forEach(post => {
|
|
|
|
createPage({
|
|
|
|
path: `${post.node.fields.slug}`,
|
|
|
|
component: docTemplate,
|
|
|
|
context: {
|
|
|
|
slug: post.node.fields.slug,
|
|
|
|
section: post.node.fields.section
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2018-11-28 12:19:11 +01:00
|
|
|
//
|
2018-11-16 14:52:42 +01:00
|
|
|
// Create pages from dev-ocean contents
|
2018-11-28 12:19:11 +01:00
|
|
|
//
|
2018-11-16 14:52:42 +01:00
|
|
|
const postsDevOcean = result.data.devOceanDocs.edges
|
2018-11-14 13:00:32 +01:00
|
|
|
|
2018-11-16 14:52:42 +01:00
|
|
|
postsDevOcean
|
2018-11-14 17:02:31 +01:00
|
|
|
// only grab files with required frontmatter defined
|
|
|
|
.filter(
|
|
|
|
post =>
|
2018-11-16 14:52:42 +01:00
|
|
|
post.node.frontmatter &&
|
2018-11-14 17:02:31 +01:00
|
|
|
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
|
|
|
|
}
|
|
|
|
})
|
2018-11-14 15:17:19 +01:00
|
|
|
})
|
|
|
|
|
2018-11-28 12:19:11 +01:00
|
|
|
//
|
2018-11-27 12:01:44 +01:00
|
|
|
// Create pages from swagger json files
|
2018-11-28 12:19:11 +01:00
|
|
|
//
|
2019-04-17 12:44:51 +02:00
|
|
|
const swaggerComponents = ['aquarius', 'brizo']
|
2018-11-27 12:01:44 +01:00
|
|
|
const apiSwaggerTemplate = path.resolve(
|
2019-01-22 22:06:06 +01:00
|
|
|
'./src/templates/Swagger/index.jsx'
|
2018-11-27 12:01:44 +01:00
|
|
|
)
|
|
|
|
|
2019-04-17 12:44:51 +02:00
|
|
|
// https://github.com/swagger-api/swagger-js
|
|
|
|
const fetchSwaggerSpec = async name => {
|
|
|
|
try {
|
|
|
|
const client = await Swagger(
|
|
|
|
`https://nginx-${name}.dev-ocean.com/spec`
|
|
|
|
)
|
|
|
|
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(...)
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const getSlug = name => {
|
2019-03-29 12:14:44 +01:00
|
|
|
const slug = `/references/${name}/`
|
2019-04-17 12:44:51 +02:00
|
|
|
return slug
|
|
|
|
}
|
2019-03-29 12:14:44 +01:00
|
|
|
|
2019-04-17 12:44:51 +02:00
|
|
|
const specAquarius = await fetchSwaggerSpec(
|
|
|
|
swaggerComponents[0]
|
|
|
|
)
|
|
|
|
const slugAquarius = getSlug(swaggerComponents[0])
|
|
|
|
|
|
|
|
createPage({
|
|
|
|
path: slugAquarius,
|
|
|
|
component: apiSwaggerTemplate,
|
|
|
|
context: {
|
|
|
|
slug: slugAquarius,
|
2019-04-17 13:36:30 +02:00
|
|
|
name: swaggerComponents[0],
|
2019-04-17 12:44:51 +02:00
|
|
|
api: specAquarius
|
|
|
|
}
|
2019-03-29 12:14:44 +01:00
|
|
|
})
|
|
|
|
|
2019-04-17 12:44:51 +02:00
|
|
|
const specBrizo = await fetchSwaggerSpec(swaggerComponents[1])
|
|
|
|
const slugBrizo = getSlug(swaggerComponents[1])
|
|
|
|
|
|
|
|
createPage({
|
|
|
|
path: slugBrizo,
|
|
|
|
component: apiSwaggerTemplate,
|
|
|
|
context: {
|
|
|
|
slug: slugBrizo,
|
2019-04-17 13:36:30 +02:00
|
|
|
name: swaggerComponents[1],
|
2019-04-17 12:44:51 +02:00
|
|
|
api: specBrizo
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
// Swagger Pet Store example
|
2018-11-29 22:43:10 +01:00
|
|
|
const petStoreSlug = '/references/petstore/'
|
2018-11-27 12:01:44 +01:00
|
|
|
|
2018-11-28 12:19:11 +01:00
|
|
|
try {
|
2019-04-17 12:44:51 +02:00
|
|
|
const client = await Swagger(
|
|
|
|
`http://petstore.swagger.io/v2/swagger.json`
|
|
|
|
)
|
2018-11-27 13:54:00 +01:00
|
|
|
|
2018-11-28 12:19:11 +01:00
|
|
|
createPage({
|
2018-11-28 13:20:03 +01:00
|
|
|
path: petStoreSlug,
|
2018-11-28 12:19:11 +01:00
|
|
|
component: apiSwaggerTemplate,
|
|
|
|
context: {
|
2018-11-28 13:20:03 +01:00
|
|
|
slug: petStoreSlug,
|
2019-04-17 12:44:51 +02:00
|
|
|
api: client.spec
|
2018-11-28 12:19:11 +01:00
|
|
|
}
|
|
|
|
})
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error)
|
|
|
|
}
|
2018-11-27 13:54:00 +01:00
|
|
|
|
2019-01-18 17:35:04 +01:00
|
|
|
//
|
|
|
|
// Create pages from TypeDoc json files
|
|
|
|
//
|
2019-01-22 10:44:58 +01:00
|
|
|
const typeDocSpecs = ['./data/squid-js.json']
|
2019-01-18 17:35:04 +01:00
|
|
|
const typedocTemplate = path.resolve(
|
2019-01-22 22:06:06 +01:00
|
|
|
'./src/templates/Typedoc/index.jsx'
|
2019-01-18 17:35:04 +01:00
|
|
|
)
|
|
|
|
|
2019-01-22 10:44:58 +01:00
|
|
|
typeDocSpecs.forEach(spec => {
|
|
|
|
const typedoc = require(spec) // eslint-disable-line
|
2019-01-18 17:35:04 +01:00
|
|
|
|
2019-01-22 10:44:58 +01:00
|
|
|
const name = path
|
|
|
|
.basename(spec)
|
|
|
|
.split('.json')
|
|
|
|
.join('')
|
|
|
|
|
|
|
|
const slug = `/references/${name}/`
|
|
|
|
|
|
|
|
createPage({
|
|
|
|
path: slug,
|
|
|
|
component: typedocTemplate,
|
|
|
|
context: {
|
|
|
|
slug,
|
|
|
|
typedoc,
|
|
|
|
// TODO: defining these classes for inclusion
|
|
|
|
// needs to be handled somewhere else to keep
|
|
|
|
// it generic for all TypeDoc specs
|
|
|
|
classes: [
|
|
|
|
'ocean/Ocean',
|
2019-01-28 11:48:07 +01:00
|
|
|
'ocean/OceanAccounts',
|
|
|
|
'ocean/OceanAssets',
|
|
|
|
'ocean/OceanAgreements',
|
2019-01-22 10:44:58 +01:00
|
|
|
'ocean/Account',
|
2019-01-22 16:48:15 +01:00
|
|
|
'ocean/DID',
|
|
|
|
'ocean/ServiceAgreements/ServiceAgreement',
|
2019-01-22 10:44:58 +01:00
|
|
|
'ddo/DDO',
|
2019-01-22 16:48:15 +01:00
|
|
|
'ddo/Service',
|
|
|
|
'aquarius/AquariusProvider',
|
|
|
|
'aquarius/Aquarius',
|
|
|
|
'aquarius/query/SearchQuery',
|
|
|
|
'brizo/BrizoProvider',
|
|
|
|
'brizo/Brizo',
|
|
|
|
'keeper/Keeper',
|
|
|
|
'keeper/Web3Provider',
|
2019-01-29 11:39:15 +01:00
|
|
|
'secretstore/SecretStoreProvider',
|
|
|
|
'models/Config',
|
|
|
|
'models/Balance'
|
2019-01-22 10:44:58 +01:00
|
|
|
]
|
|
|
|
}
|
|
|
|
})
|
2019-01-18 17:35:04 +01:00
|
|
|
})
|
|
|
|
|
2018-11-29 10:53:35 +01:00
|
|
|
//
|
|
|
|
// create redirects
|
|
|
|
//
|
|
|
|
redirects.forEach(({ from, to }) => {
|
|
|
|
createRedirect({
|
|
|
|
fromPath: from,
|
|
|
|
redirectInBrowser: true,
|
|
|
|
toPath: to
|
|
|
|
})
|
|
|
|
|
|
|
|
console.log('Create redirect: ' + from + ' --> ' + to)
|
2018-11-28 13:20:03 +01:00
|
|
|
})
|
2018-11-27 12:01:44 +01:00
|
|
|
|
2018-11-07 16:13:20 +01:00
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|