paricafe/src/server/web/docs.ts

108 lines
2.6 KiB
TypeScript
Raw Normal View History

2017-12-16 10:41:22 -06:00
/**
2018-04-12 16:06:18 -05:00
* Docs
2017-12-16 10:41:22 -06:00
*/
2018-07-06 06:27:48 -05:00
import * as fs from 'fs';
import * as path from 'path';
import * as showdown from 'showdown';
2018-07-16 11:11:36 -05:00
import 'showdown-highlightjs-extension';
2018-04-12 22:05:24 -05:00
import ms = require('ms');
2018-04-12 16:06:18 -05:00
import * as Router from 'koa-router';
import * as send from 'koa-send';
2018-07-06 06:27:48 -05:00
import * as glob from 'glob';
2018-07-05 12:58:29 -05:00
import config from '../../config';
2018-07-07 13:13:20 -05:00
import { licenseHtml } from '../../misc/license';
import { copyright } from '../../const.json';
import * as locales from '../../../locales';
import * as nestedProperty from 'nested-property';
2017-12-16 10:41:22 -06:00
2019-02-02 01:16:31 -06:00
function getLang(lang: string): string {
if (['en-US', 'ja-JP'].includes(lang)) {
return lang;
} else {
return 'en-US';
}
}
2018-07-06 06:27:48 -05:00
async function genVars(lang: string): Promise<{ [key: string]: any }> {
const vars = {} as { [key: string]: any };
vars['lang'] = lang;
2018-07-15 05:35:20 -05:00
const cwd = path.resolve(__dirname + '/../../../') + '/';
2018-07-15 05:29:15 -05:00
2018-07-15 08:00:05 -05:00
const docs = glob.sync(`src/docs/**/*.${lang}.md`, { cwd });
2018-07-06 06:27:48 -05:00
vars['docs'] = {};
for (const x of docs) {
const [, name] = x.match(/docs\/(.+?)\.(.+?)\.md$/)!;
2018-07-06 06:27:48 -05:00
if (vars['docs'][name] == null) {
vars['docs'][name] = {
name,
title: {}
};
}
vars['docs'][name]['title'][lang] = fs.readFileSync(cwd + x, 'utf-8').match(/^# (.+?)\r?\n/)![1];
}
2018-07-06 06:27:48 -05:00
vars['kebab'] = (string: string) => string.replace(/([a-z])([A-Z])/g, '$1-$2').replace(/\s+/g, '-').toLowerCase();
vars['config'] = config;
vars['copyright'] = copyright;
2018-07-06 06:27:48 -05:00
vars['license'] = licenseHtml;
2018-11-09 07:02:48 -06:00
vars['i18n'] = (key: string) => nestedProperty.get(locales[lang], key);
2018-07-06 06:27:48 -05:00
return vars;
}
2018-04-12 16:06:18 -05:00
const router = new Router();
2017-12-16 10:41:22 -06:00
2018-04-12 22:05:24 -05:00
router.get('/assets/*', async ctx => {
2019-01-22 06:42:05 -06:00
await send(ctx as any, ctx.params[0], {
root: `${__dirname}/../../docs/assets/`,
2018-09-19 00:22:46 -05:00
maxage: ms('1 days')
2018-04-12 22:05:24 -05:00
});
2018-04-12 16:06:18 -05:00
});
2017-12-16 10:41:22 -06:00
2018-07-06 09:52:47 -05:00
router.get('/*/*', async ctx => {
2019-02-02 01:16:31 -06:00
const lang = getLang(ctx.params[0]);
2018-07-06 09:52:47 -05:00
const doc = ctx.params[1];
2018-07-15 05:05:19 -05:00
showdown.extension('urlExtension', () => ({
type: 'output',
regex: /%URL%/g,
replace: config.url
}));
2018-10-29 05:11:01 -05:00
showdown.extension('wsUrlExtension', () => ({
type: 'output',
regex: /%WS_URL%/g,
2019-02-23 21:53:22 -06:00
replace: config.wsUrl
2018-10-29 05:11:01 -05:00
}));
2018-07-15 05:05:19 -05:00
showdown.extension('apiUrlExtension', () => ({
type: 'output',
regex: /%API_URL%/g,
2019-02-23 21:53:22 -06:00
replace: config.apiUrl
2018-07-15 05:05:19 -05:00
}));
const conv = new showdown.Converter({
tables: true,
2018-07-16 11:11:36 -05:00
extensions: ['urlExtension', 'apiUrlExtension', 'highlightjs']
2018-07-15 05:05:19 -05:00
});
const md = fs.readFileSync(`${__dirname}/../../../src/docs/${doc}.${lang}.md`, 'utf8');
await ctx.render('../../../../src/docs/article', Object.assign({
2018-07-30 02:24:46 -05:00
id: doc,
2018-07-15 07:48:57 -05:00
html: conv.makeHtml(md),
title: md.match(/^# (.+?)\r?\n/)![1],
2018-07-16 13:57:34 -05:00
src: `https://github.com/syuilo/misskey/tree/master/src/docs/${doc}.${lang}.md`
}, await genVars(lang)));
2018-11-19 14:29:51 -06:00
ctx.set('Cache-Control', 'public, max-age=300');
2018-07-06 09:52:47 -05:00
});
2018-04-12 22:05:24 -05:00
export default router;