2019-04-25 18:39:16 +01: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-20 22:46:01 +01:00
|
|
|
declare module 'capitano' {
|
|
|
|
export function parse(argv: string[]): Cli;
|
|
|
|
|
|
|
|
export interface Cli {
|
|
|
|
command: string;
|
2023-10-27 10:57:07 -04:00
|
|
|
options: object;
|
2020-04-30 17:22:51 +01:00
|
|
|
global: {
|
|
|
|
help?: boolean;
|
|
|
|
};
|
2017-12-20 22:46:01 +01:00
|
|
|
}
|
|
|
|
|
2017-12-21 18:40:13 +01:00
|
|
|
export interface OptionDefinition {
|
2017-12-20 22:46:01 +01:00
|
|
|
signature: string;
|
2020-04-28 16:52:46 +01:00
|
|
|
description?: string;
|
2017-12-20 22:46:01 +01:00
|
|
|
parameter?: string;
|
2023-10-27 10:57:07 -04:00
|
|
|
// eslint-disable-next-line id-denylist
|
2017-12-20 22:46:01 +01:00
|
|
|
boolean?: boolean;
|
2020-02-10 18:25:15 +00:00
|
|
|
required?: string;
|
2017-12-20 22:46:01 +01:00
|
|
|
alias?: string | string[];
|
|
|
|
}
|
|
|
|
|
2023-10-27 10:57:07 -04:00
|
|
|
export interface CommandDefinition<P = object, O = object> {
|
2017-12-20 22:46:01 +01:00
|
|
|
signature: string;
|
2020-04-30 17:22:51 +01:00
|
|
|
description?: string;
|
|
|
|
help?: string;
|
2019-05-28 17:31:18 +01:00
|
|
|
options?: Partial<OptionDefinition[]>;
|
2020-04-30 17:22:51 +01:00
|
|
|
permission?: string; // This should be 'user' but without full typescript we cannot enforce it
|
2018-05-22 18:12:51 +03:00
|
|
|
root?: boolean;
|
|
|
|
primary?: boolean;
|
2020-04-02 15:26:52 +02:00
|
|
|
hidden?: boolean;
|
2019-05-28 17:31:18 +01:00
|
|
|
action(params: P, options: Partial<O>, done: () => void): void;
|
2017-12-20 22:46:01 +01:00
|
|
|
}
|
|
|
|
|
2017-12-21 18:40:13 +01:00
|
|
|
export interface Command {
|
|
|
|
signature: Signature;
|
|
|
|
options: Option[];
|
|
|
|
isWildcard(): boolean;
|
2020-04-28 16:52:46 +01:00
|
|
|
// You can pass whatever you want into a capitano command and it gets added as a prop
|
|
|
|
[key: string]: any;
|
2017-12-20 22:46:01 +01:00
|
|
|
}
|
|
|
|
|
2017-12-21 18:40:13 +01:00
|
|
|
export interface Signature {
|
|
|
|
hasParameters(): boolean;
|
|
|
|
hasVariadicParameters(): boolean;
|
|
|
|
isWildcard(): boolean;
|
|
|
|
allowsStdin(): boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface Option {
|
|
|
|
signature: Signature;
|
|
|
|
alias: string | string[];
|
2023-10-27 10:57:07 -04:00
|
|
|
// eslint-disable-next-line id-denylist
|
2017-12-21 18:40:13 +01:00
|
|
|
boolean: boolean;
|
|
|
|
parameter: string;
|
|
|
|
required: boolean | string;
|
|
|
|
}
|
|
|
|
|
2020-04-30 17:22:51 +01:00
|
|
|
export function command<P, O>(command: CommandDefinition<P, O>): void;
|
2017-12-20 22:46:01 +01:00
|
|
|
|
|
|
|
export const state: {
|
2018-01-09 16:05:24 +01:00
|
|
|
getMatchCommand: (
|
|
|
|
signature: string,
|
|
|
|
callback: (e: Error, cmd: Command) => void,
|
|
|
|
) => void;
|
2020-04-28 16:52:46 +01:00
|
|
|
commands: Command[];
|
|
|
|
globalOptions: OptionDefinition[];
|
2017-12-20 22:46:01 +01:00
|
|
|
};
|
2020-04-30 17:22:51 +01:00
|
|
|
|
2020-07-01 15:26:40 +01:00
|
|
|
export function run(
|
2020-07-03 10:05:40 +02:00
|
|
|
command: string | string[],
|
2020-07-01 15:26:40 +01:00
|
|
|
callback: (err: Error | null, result: any) => void,
|
|
|
|
): void;
|
2020-04-30 17:22:51 +01:00
|
|
|
export function execute(
|
|
|
|
args: any,
|
2020-07-01 15:26:40 +01:00
|
|
|
callback: (err?: Error, result: any) => void,
|
2020-04-30 17:22:51 +01:00
|
|
|
): void;
|
|
|
|
export function globalOption(option: OptionDefinition): void;
|
|
|
|
export function permission(
|
|
|
|
permissionName: string,
|
|
|
|
callback: (done: () => void) => void,
|
|
|
|
): void;
|
2017-12-20 22:46:01 +01:00
|
|
|
}
|