Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/4i8/clinei

clinei is a library that provides a command line interface handler to make it easy to build CLI programs.
https://github.com/4i8/clinei

bun cli command command-line command-line-parser command-line-tool deno easy-to-use handler helper nodejs

Last synced: 2 months ago
JSON representation

clinei is a library that provides a command line interface handler to make it easy to build CLI programs.

Awesome Lists containing this project

README

        

# **clinei**







NPM version
NPM downloads
license














# **command-line interface handler**

**clinei is handler to facilitate the building of cli programs with stability and also you can specify the type of entry of each command and customization that helps you write a clean program clinei is not a cli package, it is a package that helps you build a cli package**

## Features

- ✅ **Command**
- ✅ **Option**
- ✅ **Argument**
- ✅ **Help**
- ✅ **Version**
- ✅ **Customization**
- ✅ **Type**
- ✅ **Alias**
- ✅ **Default**
- ✅ **Required**
- ✅ **Description**
- ✅ **Example**

## Support

- ✅ **ECMAScript Modules (ESM)**
- ✅ **CommonJS (CJS)**
- ❌️ **Deno**

## **Map**

- **[Examples](#examples)**
- **[Installation](#installation)**
- [NPM](#npm)
- [yarn](#yarn)
- **[Build](#build)**
- [esm (ECMAScript Modules)](#esmbuild)
- [cjs (CommonJS)](#cjsbuild)
- **[Command](#command)**

- [CommandConfig](#CommandConfig)
- [cmd](#cmd)
- [desc](#desc)
- [options](#CommandConfigoption)
- [usage](#usage)
- [FinalConfiguration](#finallycommandconfig)
- [CommandConfigOption](#CommandConfigoption)
- [name](#name)
- [desc](#desc-1)
- [type](#type)
- [msg](#msg)
- [required](#required)
- [default](#default)
- [Methods](#methods)
- [getOptions()](#getoptions)
- [getArgs()](#getargs)
- [parseArgs()](#parseargs)
- [exist()](#exist)
- [getStructure](#getstructure)
- [printHelp](#printhelp)
- [HelpCommand](#help) (required)
- [Make Cli Global](#globalcli)

#

Examples

#### `index.js`

```js
#!/usr/bin/env node
import { Build } from "clinei";
import path from "path";
import { fileURLToPath } from "url";
const __dirname = path.dirname(fileURLToPath(import.meta.url));
new Build({
path: __dirname + "/commands",
prefix: " real-cli",
});
```

**if You use CommonJS**

```diff
- import
+ require

+ const { Build } = require("clinei");
- import { Build } from "clinei";
- import path from "path";
- import { fileURLToPath } from "url";
- const __dirname = path.dirname(fileURLToPath(import.meta.url));
+ new Build({
+ path: __dirname + "/commands",
+ prefix: " real-cli",
+ });

and
+ module.exports = Command(...);
- export default Command(...);
```

#### `commands/print.js`

```js
import { Command } from "clinei";
export default Command(
{
cmd: "print", //or ["print","--print","-p","myprint"] //with aliases for this command
desc: "Log in and print data in console",
options: [
{
name: ["--username", "-u"], //with aliases
desc: "your real name",
required: true,
},
{
name: "--age", //no aliases
desc: "your real age",
type: "number",
msg: "See the documentation for more information on github",
default: 99,
},
{
name: "--store", //no aliases
desc: "store your data or no (optional)",
},
],
usage: "print pro -u Arth --age=101 --store --skills 1 2 3 4 5 6",
},
({ getOptions, exist, getArgs, parseArgs }) => {
const username = getOptions("--username"); // or -u
const age = getOptions("--age");
const store = exist("--store");
const Skills = parseArgs("--skills"); //or any other key like --
if (getArgs("pro")) {
console.log(
`[${getArgs()[0]}] Hi ,${username} Your Data Enjoy!

[username] ${username}
[age] ${age}
[store] ${store ? "yes store my data" : "No!"}
[skills] ${Skills.join(", ")}
`
);
} else
console.log(
`[noob] Hi ,${username} Your Data Enjoy!

[username] ${username}
[age] ${age}
[store] ${store ? "yes store my data" : "No!"}
[skills] ${Skills.join(", ")}
`
);
}
);
```

#### `commands/help.js`

```js
import { Command } from "clinei";
export default Command(
{
cmd: ["-h", "--help", "help"], // <-- This is the command name like help
desc: "View Commands", // <-- This is the command desc
usage: "help ",
},
({ printHelp, getArgs, getStructure }, focus) => {
console.log(printHelp);
if (
(getArgs()[0] || focus) &&
!getStructure.commands.find(({ cmd }) =>
cmd.find((c) => c === focus || c === getArgs()[0])
)
) {
console.log(`Warn: ${`["${getArgs()[0] || focus}"]`} not found`);
}
}
);
```

**Run**

```bash
node index.js print -u Arth --age 120 --store
```

**OutPut**

```bash
[noob] Hi ,Arth Your Data Enjoy!

[username] Arth
[age] 120
[store] yes store my data
[skills]
```

# Installation

## NPM

```bash
npm i clinei
```

## yarn

```bash
yarn add clinei
```

# Build

**Build is a class that is responsible for building the cli program, it is necessary to pass the path of the commands folder and the prefix of the program**

## We use `real-cli` as an example

esm (ECMAScript Modules)

```js
import { Build } from "clinei";
import path from "path";
import { fileURLToPath } from "url";
const __dirname = path.dirname(fileURLToPath(import.meta.url));
new Build({
path: __dirname + "/",
prefix: "real-cli", //
});
```

cjs (CommonJS)

```js
const { Build } = require("clinei");
new Build({
path: __dirname + "/",
prefix: "real-cli", //
});
```

# Command

`//**/*.js`
**Command() a function that registers the command in the program**

esm (ECMAScript Modules)

```js
import { Command } from "clinei";
export default Command(
{
cmd: [], // or string
desc: "",
usage: "",
options: [],
},
({ }) => {
// code
}
);
```

cjs (CommonJS)

```js
const { Command } = require("clinei");
module.exports = Command(
{
cmd: [], // or string
desc: "",
usage: "",
options: [],
},
({ }) => {
// code
}
);
```

# CommandConfig

```js
{
cmd: [],
desc: "",
usage: "",
options: [...],
}
```

> ## **cmd**

**cmd is the command that will be executed in the program, it can be a string or an array of strings**

### no alias

```bash
$ real-cli print
```

```js
{
cmd: "print",
}
```

### with alias

**-p or --print or print**

```bash
$ real-cli -p
```

```js
{
cmd: ["-p", "--print", "print"],
}
```

> ## **desc**

**desc is the description of the command, it is used in the help command**

```js
{
desc: "Log in and print data in console",
}
```

> ## **options**

**the options of the command, required if the command has options**

**see full documentation of [CommandConfigOption](#CommandConfigoption)**

> ## **usage**

**usage is the usage of the command, it is used in the help command**

```js
{
usage: "print pro -u Arth --age=101 --store --skills 1 2 3 4 5 6",
}
```

> ##

Finally

```js
{
cmd: "print", //or ["print","--print","-p","myprint"] //with aliases for this command
desc: "Log in and print data in console",
options: [
{
name: ["--username", "-u"], //with aliases
desc: "your real name",
required: true,
},
{
name: "--age", //no aliases
desc: "your real age",
type: "number",
msg: "See the documentation for more information on github",
default: 99,
},
{
name: "--store", //no aliases
desc: "store your data or no (optional)",
},
],
usage: "print pro -u Arth --age=101 --store --skills 1 2 3 4 5 6",
}
```

# CommandConfigOption

**ConfigOption is the configuration of the options of the command**

> ## **default value**

```js
{
name: "",// or array
desc: "",
type: "string",
msg: false,
required: false,
default: undefined
}
```

> ## **name**

**name of the option, it can be a string or an array of strings must start with `-` or `--`**

### **no alias**

```js
{
name: "--username",
}
```

```bash
$ real-cli --username Arth
```

### **with alias**

**-u or --username**

```js
{
name: ["-u", "--username"],
}
```

```bash
$ real-cli -u Arth
```

> ## **desc**

**the description of the option, it is used in the help command**

```js
{
desc: "your real name",
}
```

> ## **type**

**the type of the option, it is used to validate the option**

```js
{
type: "string" | "number" | "boolean",
}
```

**Type Test**

```js
{
name: "--age", //no aliases
desc: "your real age",
type: "number",
msg: "See the documentation for more information on github",
default: 99
}
```

**expected number**

```bash
$ real-cli --age nine
```

**OutPut in interface**

```bash
Error: Invalid value for option --age expected number got nine
^
Tip: use real-cli help print to see command options
```

> ## **msg**

**will be displayed if the option is not valid**

```js
{
msg: "See the documentation for more information on github",
}
```

```bash
$ real-cli --age nine
```

**OutPut in interface**

```bash
Error: Invalid value for option --age expected number got nine
^
See the documentation for more information on github

Tip: use real-cli help print to see command options
```

> ## **required**

**required is a boolean that indicates if the option is required**

```js
{
name: ["--username", "-u"], //with aliases
desc: "your real name",
required: true,
}
```

```bash
$ real-cli --age 99
```

**OutPut in interface**

```bash
Missing required option --username,-u

Tip: use real-cli help print to see command options
```

> ## **default**

default is the default value of the option

```js
{
name: "--age", //no aliases
desc: "your real age",
type: "number",
msg: "See the documentation for more information on github",
default: 99
}
```

```bash
$ real-cli
```

```js
getOptions("--age"); // 99
```

# Methods

```js
Command(
{
cmd: [], // or string
desc: "",
usage: "",
options: [],
},
({ getOptions, getArgs, parseArgs, exist, getStructure, printHelp }) => {
// code
}
);
```

> ## **getOptions()**

**returns values of the options passed in the command**

**specify the name of the option to get the value**

```js
getOptions("--username");
// or one of the aliases
getOptions("-u");
```

**all options**

```js
getOptions();
```

> ## **getArgs()**

**returns the arguments passed in the command**

```js
getArgs(); // return array
```

**specify the key to get the arguments**

```js
getArgs("arg1"); // "arg1" || false
```

```bash
$ real-cli print arg1 arg2 arg3
```

**OutPut**
**`getArgs();`**

```js
["arg1", "arg2", "arg3"]; // if the key exists
[]; // if the key does not exist
```

**`getArgs("arg1");`**

```js
"hi"; // if the key exists
false; // if the key does not exist
```

> ## **parseArgs()**

**returns the arguments associated with the key passed in the command**

```bash
-- 1 2 3 4 5
```

**specify the key to get the arguments -- or any other key or string**

```js
parseArgs("--");
```

**OutPut Array**

```js
[1, 2, 3, 4, 5] // if the key exists
[] // if the key does not exist
```

> ## **exist()**

**returns a boolean indicating if the option exists**

```js
exist("--username");
```

**OutPut Boolean**

```js
true; // if the option exists
false; // if the option does not exist
```

> ## **getStructure**

**returns the structure of the commands You can use it to build a custom help instead printHelp()**

```js
getStructure; // return object
```

**OutPut Object**

```js
{
commands: [
{
"cmd": [], // or string
"desc": "",
"usage": "",
"options": [...]
,...
}
];
prefix: string;
//this is the structure of the command that is being executed
this: {
"cmd": [], // or string
"desc": "",
"usage": "",
"options": [...]
}
}
```

> ## **printHelp**

**printHelp is a property
that prints the help of the commands**

```js
printHelp;
```

#

HelpCommand

**HelpCommand is a command that is used to print the help of the commands**

```js
Command(
{
cmd: ["-h", "--help", "help"],
desc: "View Commands",
usage: "help ",
},
({ printHelp }) => {
console.log(printHelp);
}
);
```

```bash
$ real-cli help
```

**OutPut**

```
usage: real-cli help

real-cli -h, --help, help [options] [aliases]
View Commands
real-cli print [options] [aliases]
Log in and print data in console
Options:
--username, -u REQUIRED,STRING
your real name
--age NUMBER
your real age
--store STRING
store your data or no (optional)

```

```bash
$ real-cli help print
```

**OutPut**

```bash
usage: real-cli print pro -u Arth --age=101 --store --skills 1 2 3 4 5 6

real-cli print [options] [aliases]
Log in and print data in console
Options:
--username, -u REQUIRED,STRING
your real name
--age NUMBER
your real age
--store STRING
store your data or no (optional)

```

```js
Command(
{
cmd: ["-h", "--help", "help"], // <-- This is the command name like help
desc: "View Commands", // <-- This is the command desc
usage: "help ",
},
({ printHelp, getArgs, getStructure }, focus) => {
console.log(printHelp);
//focus ->> delete
if (
(getArgs()[0] || focus) &&
!getStructure.commands.find(({ cmd }) =>
cmd.find((c) => c === focus || c === getArgs()[0])
)
) {
console.log(`Warn: ${`["${getArgs()[0] || focus}"]`} not found`);
}
}
);
```

```bash
$ real-cli delete
^^^^^^ ->> focus
```

```bash
$ real-cli help delete
^^^^^^ ->> getArgs()[0]
```

**OutPut**

```bash
usage: real-cli help

real-cli -h, --help, help [options] [aliases]
View Commands
real-cli print [options] [aliases]
Log in and print data in console
Options:
--username, -u REQUIRED,STRING
your real name
--age NUMBER
your real age
--store STRING
store your data or no (optional)

Warn: ["delete"] not found
```

##

Make Cli Global

## Make a global program local use npm

## add this to your `package.json`

```json
{
"bin": {
"real-cli": "index.js"
}
}
```

## run

```bash
$ npm link
```

## or publish and install it globally

### Example with npm

```bash
npm install -g
```

## now you can use your program

```bash
$ real-cli help
```

## Links

- [Github](https://github.com/4i8)

## License

- [Apache-2.0](https://www.apache.org/licenses/LICENSE-2.0)

# clinei is a CLI program builder