Skip to content

Framework for building elegant comand-line tools with Node.js & TypeScript.

License

Notifications You must be signed in to change notification settings

joggrdocs/sarge

Folders and files

NameName
Last commit message
Last commit date

Latest commit

9495466 · Feb 21, 2025

History

7 Commits
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Feb 21, 2025
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024
Nov 28, 2024

Repository files navigation

🪖 sarge

Framework for building elegant command-line tools with Node.js & TypeScript.

Features

  • 🔄 Auto-loading: Automatically load commands from a directory and subdirectories.
  • 📝 Configuration-based API: Define a command and options using a simple configuration object.
  • 🟦 Typed: Written in TypeScript, so you get full type-checking and intellisense support.
  • ⚙️ Extensible: Easily extend the framework using the underlying commander library.

Installation

npm

npm install sarge-cli

yarn

yarn add sarge-cli

Usage

This is a simple example of how to use sarge to build a CLI tool, that includes:

  • Pre-configured authentication using a custom provider.
  • Auto-loading of commands from a directory.
  • Accessing the ProgramContext object in a command action.

src/main.ts

import sarge from 'sarge-cli';
import pluginRequest from '@sarge-cli/plugin-request';
import pluginAuth from '@sarge-cli/plugin-auth';
import pluginConfig from '@sarge-cli/plugin-config';

import { customProvider } from './auth-provider';

const program = sarge({
  name: 'my-cli',
  version: '1.0.0',
  description: 'My awesome CLI tool',
  
  // Auto-load commands from the `commands` directory OR specify a custom directory '/my-commands'
  autoload: true,

  // Register plugins to extend the CLI functionality 
  // and add custom implementations if needed
  plugins: [
    pluginAuth(),
    pluginRequest(),
    pluginConfig({
      files: [
        '.myclirc',
        '.myclirc.json',
        '.myclirc.yaml',
        'my-cli.config.js',
        'my-cli.config.ts',
        'random-my-cli.json',
      ],
    })
  ],
});

// returns a standard Commander object that you can use with the underlying Commander API
program.help('my-cli [command] [options]');

// parse the command-line arguments (the same as `commander.parse`)
program.parse(process.argv);

src/commands/hello.ts

import { defineCommand } from 'sarge-cli';

export default defineCommand({
  name: 'hello',
  description: 'Say hello to the world',
  options: [
    {
      name: 'name',
      shortName: 'n',
      description: 'Your name',
    },
  ],
  preAction: async (ctx) => {
    await ctx.auth.check();
  },
  action: async (ctx, { options }) => {
    ctx.loader.start('Loading...');

    const user = await ctx.request.api.post('/users/search', { name: options.name });
    const other = await ctx.request.other.get('/other');

    ctx.console.log(`Hello, ${user.fullName || 'world'}!`);
    ctx.loader.success('You said hello!');
  },
});

Test running the command

sarge-cli run hello --name John OR my-cli hello -n John

License

Licensed under MIT.



⚡️ Want to sign up for Joggr?

You can sign up for free at our website: https://joggr.io
(or click button below 👇)

Sign up


About

Framework for building elegant comand-line tools with Node.js & TypeScript.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published