mirror of
https://github.com/oceanprotocol/docs.git
synced 2024-11-26 19:49:26 +01:00
308 lines
8.1 KiB
JavaScript
Executable File
308 lines
8.1 KiB
JavaScript
Executable File
/* eslint-disable no-console */
|
|
|
|
const path = require('path')
|
|
const { createFilePath } = require('gatsby-source-filesystem')
|
|
const Swagger = require('swagger-client')
|
|
const { redirects } = require('./config')
|
|
|
|
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
|
|
})
|
|
}
|
|
}
|
|
|
|
exports.createPages = ({ graphql, actions }) => {
|
|
const { createPage, createRedirect } = actions
|
|
|
|
return new Promise((resolve, reject) => {
|
|
resolve(
|
|
graphql(
|
|
`
|
|
query {
|
|
allMarkdownRemark(
|
|
filter: { fileAbsolutePath: { regex: "/content/" } }
|
|
) {
|
|
edges {
|
|
node {
|
|
fields {
|
|
slug
|
|
section
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
allRepoMarkdown: allMarkdownRemark(
|
|
filter: { fileAbsolutePath: { regex: "/markdowns/markdowns/" } }
|
|
) {
|
|
edges {
|
|
node {
|
|
id
|
|
html
|
|
htmlAst
|
|
tableOfContents
|
|
frontmatter {
|
|
slug
|
|
source
|
|
title
|
|
app
|
|
module
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
oceanJs: github {
|
|
repository(name: "ocean.js", owner: "oceanprotocol") {
|
|
name
|
|
releases(
|
|
first: 30
|
|
orderBy: { field: CREATED_AT, direction: DESC }
|
|
) {
|
|
edges {
|
|
node {
|
|
isPrerelease
|
|
isDraft
|
|
releaseAssets(first: 1, name: "lib.json") {
|
|
edges {
|
|
node {
|
|
name
|
|
downloadUrl
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
`
|
|
).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
|
|
}
|
|
})
|
|
})
|
|
|
|
// API: brizo, aquarius
|
|
await createSwaggerPages(createPage)
|
|
|
|
// API: ocean.js
|
|
const lastRelease = result.data.oceanJs.repository.releases.edges.filter(
|
|
({ node }) => !node.isPrerelease && !node.isDraft
|
|
)[0].node.releaseAssets.edges[0].node
|
|
|
|
await createTypeDocPage(
|
|
createPage,
|
|
result.data.oceanJs.repository.name,
|
|
lastRelease.downloadUrl
|
|
)
|
|
|
|
//
|
|
// create redirects
|
|
//
|
|
redirects.forEach(({ from, to }) => {
|
|
createRedirect({
|
|
fromPath: from,
|
|
redirectInBrowser: true,
|
|
toPath: to
|
|
})
|
|
|
|
console.log('Create redirect: ' + from + ' --> ' + to)
|
|
})
|
|
|
|
const markdowns = result.data.allRepoMarkdown.edges
|
|
const oceanPyList = filterMarkdownList(markdowns, 'ocean.py')
|
|
const aquariusList = filterMarkdownList(markdowns, 'aquarius')
|
|
const providerList = filterMarkdownList(markdowns, 'provider')
|
|
|
|
await createReadTheDocsPage(createPage, 'ocean-py', oceanPyList)
|
|
await createReadTheDocsPage(createPage, 'aquarius', aquariusList)
|
|
await createReadTheDocsPage(createPage, 'provider', providerList)
|
|
|
|
resolve()
|
|
})
|
|
)
|
|
})
|
|
}
|
|
|
|
//
|
|
// Create pages from TypeDoc json files
|
|
//
|
|
const createTypeDocPage = async (createPage, name, downloadUrl) => {
|
|
try {
|
|
const typedoc = await fetch(downloadUrl)
|
|
const typedocTemplate = path.resolve('./src/templates/Typedoc/index.jsx')
|
|
const slug = `/references/${name}/`
|
|
|
|
createPage({
|
|
path: slug,
|
|
component: typedocTemplate,
|
|
context: {
|
|
slug,
|
|
typedoc: await typedoc.json(),
|
|
// We define the classes here so the data object passed as page context
|
|
// is as small as possible.
|
|
// Caveat: no live update during development when these values are changed.
|
|
//
|
|
// TODO: defining these classes for inclusion
|
|
// needs to be handled somewhere else to keep
|
|
// it generic for all TypeDoc specs
|
|
classes: [
|
|
'ocean/Ocean',
|
|
'ocean/Account',
|
|
'ocean/Assets',
|
|
'ocean/Compute',
|
|
'ocean/Versions',
|
|
'ocean/DID',
|
|
'ddo/DDO',
|
|
'metadatacache/MetadataCache',
|
|
'metadatacache/OnChainMetaDataCache',
|
|
'provider/Provider',
|
|
'datatokens/Datatokens',
|
|
'datatokens/Network',
|
|
'datatokens/Web3Provider',
|
|
'balancer/OceanPool',
|
|
'balancer/Pool',
|
|
'balancer/PoolFactory',
|
|
'exchange/FixedRateExchange',
|
|
'models/Config',
|
|
'utils/ConfigHelper',
|
|
'utils/GasUtils',
|
|
'ocean/utils/OceanUtils',
|
|
'ocean/utils/WebServiceConnector',
|
|
'utils/Logger'
|
|
]
|
|
}
|
|
})
|
|
} catch (error) {
|
|
console.log(error.message)
|
|
}
|
|
}
|
|
|
|
//
|
|
// Create pages from swagger json files
|
|
//
|
|
// https://github.com/swagger-api/swagger-js
|
|
const fetchSwaggerSpec = async (component) => {
|
|
try {
|
|
const client = await Swagger(
|
|
`https://${component}.mainnet.oceanprotocol.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.error(error.message)
|
|
}
|
|
}
|
|
|
|
const createSwaggerPages = async (createPage) => {
|
|
const swaggerComponents = ['aquarius', 'provider']
|
|
const apiSwaggerTemplate = path.resolve('./src/templates/Swagger/index.jsx')
|
|
|
|
const getSlug = (name) => `/references/${name}/`
|
|
|
|
for (const component of swaggerComponents) {
|
|
const slug = getSlug(component)
|
|
|
|
createPage({
|
|
path: slug,
|
|
component: apiSwaggerTemplate,
|
|
context: {
|
|
slug,
|
|
name: component,
|
|
api: await fetchSwaggerSpec(component)
|
|
}
|
|
})
|
|
}
|
|
|
|
// Swagger Pet Store example
|
|
const petStoreSlug = '/references/petstore/'
|
|
|
|
try {
|
|
const client = await Swagger(`http://petstore.swagger.io/v2/swagger.json`)
|
|
|
|
createPage({
|
|
path: petStoreSlug,
|
|
component: apiSwaggerTemplate,
|
|
context: {
|
|
slug: petStoreSlug,
|
|
api: client.spec
|
|
}
|
|
})
|
|
} catch (error) {
|
|
console.error(error.message)
|
|
}
|
|
}
|
|
|
|
const createReadTheDocsPage = async (createPage, name, list) => {
|
|
const markdownListTemplate = path.resolve(
|
|
'./src/templates/Markdown/MarkdownList.jsx'
|
|
)
|
|
createPage({
|
|
path: `/read-the-docs/${name}`,
|
|
matchPath: `/read-the-docs/${name}/*`,
|
|
component: markdownListTemplate,
|
|
context: {
|
|
markdownList: list,
|
|
name: name,
|
|
baseUrl: `/read-the-docs/${name}`
|
|
}
|
|
})
|
|
}
|
|
|
|
const filterMarkdownList = (markdownList, string) => {
|
|
return markdownList.filter(({ node }) => node.frontmatter.app === string)
|
|
}
|