2019-03-12 22:07:57 +00:00
|
|
|
/**
|
|
|
|
* @license
|
|
|
|
* Copyright 2019 Balena Ltd.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2017-12-21 17:40:13 +00:00
|
|
|
import * as path from 'path';
|
2019-04-18 15:49:17 +00:00
|
|
|
import { getCapitanoDoc } from './capitanodoc';
|
2020-09-04 14:34:34 +00:00
|
|
|
import { Category, Document, OclifCommand } from './doc-types';
|
2017-12-21 17:40:13 +00:00
|
|
|
import * as markdown from './markdown';
|
2020-09-04 14:34:34 +00:00
|
|
|
import { stripIndent } from '../../lib/utils/lazy';
|
2017-12-21 17:40:13 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
/**
|
|
|
|
* Generates the markdown document (as a string) for the CLI documentation
|
|
|
|
* page on the web: https://www.balena.io/docs/reference/cli/
|
|
|
|
*/
|
|
|
|
export async function renderMarkdown(): Promise<string> {
|
|
|
|
const capitanodoc = await getCapitanoDoc();
|
|
|
|
const result: Document = {
|
|
|
|
title: capitanodoc.title,
|
|
|
|
introduction: capitanodoc.introduction,
|
|
|
|
categories: [],
|
2019-03-12 22:07:57 +00:00
|
|
|
};
|
2017-12-21 17:40:13 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
for (const commandCategory of capitanodoc.categories) {
|
|
|
|
const category: Category = {
|
|
|
|
title: commandCategory.title,
|
|
|
|
commands: [],
|
|
|
|
};
|
2017-12-21 17:40:13 +00:00
|
|
|
|
2019-04-02 11:26:21 +00:00
|
|
|
for (const jsFilename of commandCategory.files) {
|
2020-09-04 14:34:34 +00:00
|
|
|
category.commands.push(...importOclifCommands(jsFilename));
|
2017-12-21 17:40:13 +00:00
|
|
|
}
|
2019-04-18 15:49:17 +00:00
|
|
|
result.categories.push(category);
|
2017-12-21 17:40:13 +00:00
|
|
|
}
|
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
return markdown.render(result);
|
|
|
|
}
|
|
|
|
|
2020-09-04 14:34:34 +00:00
|
|
|
// Help is now managed via a plugin
|
|
|
|
// This fake command allows capitanodoc to include help in docs
|
|
|
|
class FakeHelpCommand {
|
|
|
|
description = stripIndent`
|
2020-09-08 11:23:39 +00:00
|
|
|
List balena commands, or get detailed help for a specific command.
|
2019-04-02 11:26:21 +00:00
|
|
|
|
2020-09-08 11:23:39 +00:00
|
|
|
List balena commands, or get detailed help for a specific command.
|
2020-09-04 14:34:34 +00:00
|
|
|
`;
|
|
|
|
|
|
|
|
examples = [
|
|
|
|
'$ balena help',
|
|
|
|
'$ balena help apps',
|
|
|
|
'$ balena help os download',
|
|
|
|
];
|
|
|
|
|
|
|
|
args = [
|
|
|
|
{
|
|
|
|
name: 'command',
|
|
|
|
description: 'command to show help for',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
usage = 'help [command]';
|
|
|
|
|
|
|
|
flags = {
|
|
|
|
verbose: {
|
|
|
|
description: 'show additional commands',
|
|
|
|
char: '-v',
|
|
|
|
},
|
|
|
|
};
|
2019-04-02 11:26:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function importOclifCommands(jsFilename: string): OclifCommand[] {
|
2020-03-25 17:07:17 +00:00
|
|
|
// TODO: Currently oclif commands with no `usage` overridden will cause
|
|
|
|
// an error when parsed. This should be improved so that `usage` does not have
|
|
|
|
// to be overridden if not necessary.
|
2020-09-04 14:34:34 +00:00
|
|
|
|
|
|
|
const command: OclifCommand =
|
|
|
|
jsFilename === 'help'
|
|
|
|
? ((new FakeHelpCommand() as unknown) as OclifCommand)
|
|
|
|
: (require(path.join(process.cwd(), jsFilename)).default as OclifCommand);
|
|
|
|
|
2019-04-02 11:26:21 +00:00
|
|
|
return [command];
|
|
|
|
}
|
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
/**
|
|
|
|
* Print the CLI docs markdown to stdout.
|
|
|
|
* See package.json for how the output is redirected to a file.
|
|
|
|
*/
|
2019-04-29 15:33:09 +00:00
|
|
|
async function printMarkdown() {
|
|
|
|
try {
|
|
|
|
console.log(await renderMarkdown());
|
|
|
|
} catch (error) {
|
|
|
|
console.error(error);
|
|
|
|
process.exit(1);
|
|
|
|
}
|
2017-12-21 17:40:13 +00:00
|
|
|
}
|
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
printMarkdown();
|