gatsby
Version:
Blazing fast modern site generator for React
89 lines (73 loc) • 2.2 kB
JavaScript
/* global plugins */
// During bootstrap, we write requires at top of this file which looks like:
// var plugins = [
// {
// plugin: require("/path/to/plugin1/gatsby-ssr.js"),
// options: { ... },
// },
// {
// plugin: require("/path/to/plugin2/gatsby-ssr.js"),
// options: { ... },
// },
// ]
const apis = require(`./api-ssr-docs`)
function augmentErrorWithPlugin(plugin, err) {
if (plugin.name !== `default-site-plugin`) {
// default-site-plugin is user code and will print proper stack trace,
// so no point in annotating error message pointing out which plugin is root of the problem
err.message += ` (from plugin: ${plugin.name})`
}
throw err
}
export function apiRunner(api, args, defaultReturn, argTransform) {
if (!apis[api]) {
console.log(`This API doesn't exist`, api)
}
const results = []
plugins.forEach(plugin => {
const apiFn = plugin.plugin[api]
if (!apiFn) {
return
}
try {
const result = apiFn(args, plugin.options)
if (result && argTransform) {
args = argTransform({ args, result })
}
// This if case keeps behaviour as before, we should allow undefined here as the api is defined
// TODO V4
if (typeof result !== `undefined`) {
results.push(result)
}
} catch (e) {
augmentErrorWithPlugin(plugin, e)
}
})
return results.length ? results : [defaultReturn]
}
export async function apiRunnerAsync(api, args, defaultReturn, argTransform) {
if (!apis[api]) {
console.log(`This API doesn't exist`, api)
}
const results = []
for (const plugin of plugins) {
const apiFn = plugin.plugin[api]
if (!apiFn) {
continue
}
try {
const result = await apiFn(args, plugin.options)
if (result && argTransform) {
args = argTransform({ args, result })
}
// This if case keeps behaviour as before, we should allow undefined here as the api is defined
// TODO V4
if (typeof result !== `undefined`) {
results.push(result)
}
} catch (e) {
augmentErrorWithPlugin(plugin, e)
}
}
return results.length ? results : [defaultReturn]
}