lbry.tech/app/views/api.js

198 lines
4.9 KiB
JavaScript
Raw Normal View History

2018-08-28 18:57:18 -05:00
"use strict";
2018-10-01 15:47:10 -05:00
2018-11-30 14:46:22 -06:00
// I M P O R T S
2018-10-01 15:47:10 -05:00
2018-08-29 11:58:55 -05:00
import asyncHtml from "choo-async/html";
2018-08-28 18:57:18 -05:00
import dedent from "dedent";
2019-01-08 11:25:34 -06:00
import got from "got";
2018-10-01 15:47:10 -05:00
2018-10-10 12:56:35 -05:00
// U T I L S
2018-08-28 18:57:18 -05:00
2018-11-30 14:46:22 -06:00
import headerBlockchain from "../components/api/header-blockchain";
import headerSdk from "../components/api/header-sdk";
import redirects from "../data/redirects.json";
const blockchainApi = "https://cdn.jsdelivr.net/gh/lbryio/lbrycrd@master/contrib/devtools/generated/api_v1.json";
2019-01-08 11:25:34 -06:00
const cache = new Map();
2018-12-12 12:32:05 -06:00
const sdkApi = "https://cdn.jsdelivr.net/gh/lbryio/lbry@master/docs/api.json";
2018-10-01 15:47:10 -05:00
// E X P O R T
2018-08-28 18:57:18 -05:00
2018-11-30 14:46:22 -06:00
export default async(state) => {
// How to set custom metadata for this page
// state.lbry = {
// description: "This is the API page for LBRY.tech",
// "og:image": "/assets/media/images/carlsagan2.jpg",
// "og:image:height": 300,
// "og:image:width": 400
// };
try {
const apiResponse = await parseApiFile(state.params.wildcard);
return asyncHtml`
<div class="__slate">
<aside class="api__toc">
<div class="api__toc__search">
<input class="api__toc__search__field" id="input-search" placeholder="Search" type="search"/>
<div class="api__toc__search__clear" id="clear-search" title="Clear search query">&times;</div>
<ul class="api__toc__search__results"></ul>
</div>
<ul class="api__toc__items" id="toc" role="navigation">${createApiSidebar(apiResponse)}</ul>
</aside>
<section class="api__content">
${createApiHeader(state.params.wildcard)}
<div class="api__documentation" id="toc-content">
${createApiContent(apiResponse)}
</div>
</section>
</div>
<script src="/assets/scripts/plugins/jets.js"></script>
<script src="/assets/scripts/api.js"></script>
`;
}
2019-01-08 11:25:34 -06:00
catch(error) {
2018-10-06 15:53:01 -05:00
const redirectUrl = redirects[state.href];
2018-08-28 18:57:18 -05:00
2018-10-06 15:53:01 -05:00
return asyncHtml`
2018-10-06 15:59:46 -05:00
<article class="page" itemtype="http://schema.org/BlogPosting">
<header class="page__header">
<div class="page__header-wrap">
<div class="inner-wrap">
<h1 class="page__header__title" itemprop="name headline">404</h1>
</div>
2018-10-01 15:47:10 -05:00
</div>
2018-10-06 15:59:46 -05:00
</header>
2018-08-28 18:57:18 -05:00
2018-10-06 15:59:46 -05:00
<section class="page__content page__markup" itemprop="articleBody">
<div class="inner-wrap">
<p>Redirecting you to <strong>${redirectUrl}</strong></p>
</div>
</section>
</article>
<script>
setTimeout(() => {
window.location.href = "${redirectUrl}";
}, 2000);
</script>
`;
2018-11-30 14:46:22 -06:00
}
};
2018-09-30 13:34:29 -04:00
2018-08-28 18:57:18 -05:00
2018-10-01 15:47:10 -05:00
// H E L P E R S
2018-10-01 00:40:24 -04:00
2018-08-28 18:57:18 -05:00
function createApiContent(apiDetails) {
const apiContent = [];
for (const apiDetail of apiDetails) {
let apiDetailsReturns = "";
2018-10-06 15:53:01 -05:00
2018-11-30 14:46:22 -06:00
if (apiDetail.returns)
apiDetailsReturns = JSON.parse(JSON.stringify(apiDetail.returns));
2018-08-28 18:57:18 -05:00
apiContent.push(`
<div class="api__content__body">
<h2 id="${apiDetail.name}">${apiDetail.name}</h2>
<p>${apiDetail.description}</p>
${apiDetail.arguments.length ? `<h3>Arguments</h3><ul class="api__content__body__arguments">${renderArguments(apiDetail.arguments).join("")}</ul>` : ""}
<h3>Returns</h3>
<pre><code>${dedent(apiDetailsReturns)}</code></pre>
</div>
<div class="api__content__example">
<pre><code>// example(s) for ${apiDetail.name} to come later</code></pre>
</div>
`);
}
return apiContent;
}
2018-10-01 15:47:10 -05:00
function createApiHeader(slug) {
switch(slug) {
case "blockchain":
return headerBlockchain();
case "sdk":
return headerSdk();
default:
break;
}
}
2018-08-28 18:57:18 -05:00
function createApiSidebar(apiDetails) {
const apiSidebar = [];
for (const apiDetail of apiDetails) {
apiSidebar.push(`
<li class="api__toc__item">
<a href="#${apiDetail.name}" title="Go to ${apiDetail.name} section">
${apiDetail.name}
</a>
</li>
`);
}
return apiSidebar;
}
2019-01-08 11:25:34 -06:00
async function parseApiFile(urlSlug) {
2018-08-28 18:57:18 -05:00
let apiFileLink;
2018-10-01 15:47:10 -05:00
switch(true) {
case (urlSlug === "blockchain"):
2018-12-12 12:32:05 -06:00
apiFileLink = blockchainApi;
2018-10-01 15:47:10 -05:00
break;
2018-08-28 18:57:18 -05:00
2018-10-01 15:47:10 -05:00
case (urlSlug === "sdk"):
2018-12-12 12:32:05 -06:00
apiFileLink = sdkApi;
2018-10-01 15:47:10 -05:00
break;
default:
break;
}
2018-08-28 18:57:18 -05:00
2019-01-08 11:25:34 -06:00
if (!apiFileLink)
return Promise.reject(new Error("Failed to fetch API docs"));
const response = await got(apiFileLink, { cache: cache, json: true });
try {
return response.body;
} catch(error) {
return "Issue loading API documentation";
}
2018-08-28 18:57:18 -05:00
}
function renderArguments(args) {
const argumentContent = [];
for (const arg of args) {
argumentContent.push(`
<li class="api__content__body__argument">
<div class="left">
<strong>${arg.name}</strong><br/>
${arg.is_required === true ? "" : "<span>optional</span>" }<span>${arg.type}</span>
</div>
<div class="right">${typeof arg.description === "string" ? arg.description.replace(/</g, "&lt;").replace(/>/g, "&gt;") : ""}</div>
</li>
`);
}
return argumentContent;
}