Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hackmdio/hackmd-cli
The HackMD/CodiMD Command Line Tool
https://github.com/hackmdio/hackmd-cli
cli codimd oclif typescript
Last synced: 8 days ago
JSON representation
The HackMD/CodiMD Command Line Tool
- Host: GitHub
- URL: https://github.com/hackmdio/hackmd-cli
- Owner: hackmdio
- License: mit
- Created: 2019-08-03T06:11:15.000Z (over 5 years ago)
- Default Branch: develop
- Last Pushed: 2023-09-27T23:19:09.000Z (over 1 year ago)
- Last Synced: 2025-01-02T10:15:48.492Z (9 days ago)
- Topics: cli, codimd, oclif, typescript
- Language: TypeScript
- Homepage: https://github.com/hackmdio/hackmd-cli
- Size: 1.05 MB
- Stars: 115
- Watchers: 9
- Forks: 11
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# hackmd-cli - The HackMD Command Line Tool
[![oclif](https://img.shields.io/badge/cli-oclif-brightgreen.svg)](https://oclif.io)
[![Version](https://img.shields.io/npm/v/@hackmd/hackmd-cli.svg)](https://npmjs.org/package/@hackmd/hackmd-cli)
[![Downloads/week](https://img.shields.io/npm/dw/@hackmd/hackmd-cli.svg)](https://npmjs.org/package/@hackmd/hackmd-cli)
[![License](https://img.shields.io/npm/l/@hackmd/hackmd-cli.svg)](https://github.com/hackmdio/hackmd-cli/blob/master/package.json)* [Usage](#usage)
* [Commands](#commands)
* [Configuration](#configuration)
* [License](#license)## v2 notice
`hackmd-cli` v2 now only supports the official HackMD instance([hackmd.io](https://hackmd.io)) and HackMD EE instances after version `1.38.1`. CodiMD is not supported anymore. If you want to use the CLI tools with CodiMD, please check out the [`v1.x` README](https://github.com/hackmdio/hackmd-cli/tree/v1.2.0) and follow the instruction there.
### Migrating from v1.x
1. If you are using the CLI with CodiMD, please follow the [`v1.x` README](https://github.com/hackmdio/hackmd-cli/tree/v1.2.0)
2. If you are using the CLI with HackMD([hackmd.io](https://hackmd.io)) or HackMD EE(Enterprise Edition) instances:
* **You're using the JSON file-based config**: Remove `~/.hackmd/config.json` and start over again. You can start with [configuration](#configuration) section.
* **You're using environment variable based config**: `HMD_CLI_SERVER_URL` has been replaced with `HMD_API_ENDPOINT_URL`. And `HMD_API_ENDPOINT_URL` may vary depending on your instance. Please check contact your instance admin to get the correct `HMD_API_ENDPOINT_URL`. For generating access token, please check the [configuration](#configuration) section. You'll need to set the `HMD_API_ACCESS_TOKEN` environment variable.## Usage
```sh-session
$ npm install -g @hackmd/hackmd-cli
$ hackmd-cli COMMAND
running command...
$ hackmd-cli (--version|-v)
@hackmd/hackmd-cli/2.3.2 darwin-arm64 node-v18.14.2
$ hackmd-cli --help [COMMAND]
USAGE
$ hackmd-cli COMMAND
...
```## Configuration
### Set access token
Access token should be set before using `hackmd-cli`. It can be created by landing [hackmd.io](https://hackmd.io) -> [Setting](https://hackmd.io/settings#api) -> [API](https://hackmd.io/settings#api) -> Create API token. Copy the token and set it as config variable. For more details, please follow the tutorial: [How to issue an API token](https://hackmd.io/@hackmd-api/developer-portal/https%3A%2F%2Fhackmd.io%2F%40hackmd-api%2Fhow-to-issue-an-api-token).
#### Example:
Set the access token by `login` command. By doing so, the access token will be saved in `~/.hackmd/config.json`.
```sh-session
$ hackmd-cli login
Enter your access token: My_ACCESS_TOKEN
```Or you don't want to keep the credentials in one file, you can set it through environment variable:
```bash
export HMD_API_ACCESS_TOKEN=MY_ACCESS_TOKEN
```Or you can write the configuration file manually. Edit `~/.hackmd/config.json` with the following content:
```json
{
"accessToken": "MY_ACCESS_TOKEN"
}
```### Specify HackMD API endpoint manually (optional)
`hackmd-cli` operates on the official HackMD API endpoint (`https://api.hackmd.io/v1`) by default. If you want to use `hackmd-cli` with a custom [HackMD EE](https://hackmd.io/enterprise) instance, you will need to configure the API endpoint by either environment variable or JSON configuration manually.
#### Example:
Set environment variable in your shell profile:
```bash
export HMD_API_ENDPOINT_URL=https://my.hackmd-ee.api.endpoint
```Or in JSON file (`~/.hackmd/config.json`):
```json
{
"hackmdAPIEndpointURL": "https://my.hackmd-ee.api.endpoint"
}
```### Configuration Reference
All available configurations are listed in the table below.
| Config key | Environment Variable | Data Type | Example Value | Description |
| ---------------------- | :--------------------- | ---------- | --------------------------------------- | --------------------------- |
| `hackmdAPIEndpointURL` | `HMD_API_ENDPOINT_URL` | *`string`* | `https://api.hackmd.io/v1` | HackMD EE API endpoint URL |
| `accessToken` | `HMD_API_ACCESS_TOKEN` | *`string`* | `UFHR12H7FSEF3ADFY3N9YNRN2E49VGR212NBF` | Token to access HackMD APIs |## Commands
* [`hackmd-cli autocomplete [SHELL]`](#hackmd-cli-autocomplete-shell)
* [`hackmd-cli export`](#hackmd-cli-export)
* [`hackmd-cli help [COMMANDS]`](#hackmd-cli-help-commands)
* [`hackmd-cli history`](#hackmd-cli-history)
* [`hackmd-cli login`](#hackmd-cli-login)
* [`hackmd-cli logout`](#hackmd-cli-logout)
* [`hackmd-cli notes`](#hackmd-cli-notes)
* [`hackmd-cli notes create`](#hackmd-cli-notes-create)
* [`hackmd-cli notes delete`](#hackmd-cli-notes-delete)
* [`hackmd-cli notes update`](#hackmd-cli-notes-update)
* [`hackmd-cli team-notes`](#hackmd-cli-team-notes)
* [`hackmd-cli team-notes create`](#hackmd-cli-team-notes-create)
* [`hackmd-cli team-notes delete`](#hackmd-cli-team-notes-delete)
* [`hackmd-cli team-notes update`](#hackmd-cli-team-notes-update)
* [`hackmd-cli teams`](#hackmd-cli-teams)
* [`hackmd-cli version`](#hackmd-cli-version)
* [`hackmd-cli whoami`](#hackmd-cli-whoami)## `hackmd-cli autocomplete [SHELL]`
display autocomplete installation instructions
```
USAGE
$ hackmd-cli autocomplete [SHELL] [-r]ARGUMENTS
SHELL shell typeFLAGS
-r, --refresh-cache Refresh cache (ignores displaying instructions)DESCRIPTION
display autocomplete installation instructionsEXAMPLES
$ hackmd-cli autocomplete$ hackmd-cli autocomplete bash
$ hackmd-cli autocomplete fish
$ hackmd-cli autocomplete zsh
$ hackmd-cli autocomplete --refresh-cache
```_See code: [@hackmd/oclif-plugin-autocomplete](https://github.com/oclif/plugin-autocomplete/blob/v2.1.9-fish/src/commands/autocomplete/index.ts)_
## `hackmd-cli export`
Export note content
```
USAGE
$ hackmd-cli export [-h] [--noteId ]FLAGS
-h, --help Show CLI help.
--noteId= HackMD note idDESCRIPTION
Export note contentEXAMPLES
$ hackmd-cli export --noteId=kNFWV5E-Qz-QP7u6XnNvyQ
# A note to be exported
```_See code: [src/commands/export.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/export.ts)_
## `hackmd-cli help [COMMANDS]`
Display help for hackmd-cli.
```
USAGE
$ hackmd-cli help [COMMANDS] [-n]ARGUMENTS
COMMANDS Command to show help for.FLAGS
-n, --nested-commands Include all nested commands in the output.DESCRIPTION
Display help for hackmd-cli.
```_See code: [@oclif/plugin-help](https://github.com/oclif/plugin-help/blob/v5.2.9/src/commands/help.ts)_
## `hackmd-cli history`
List user browse history
```
USAGE
$ hackmd-cli history [-h] [--columns | -x] [--sort ] [--filter ] [--output
csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--output= output in a more machine friendly format
--sort= property to sort by (prepend '-' for descending)DESCRIPTION
List user browse historyEXAMPLES
$ hackmd-cli history
ID Title User Path Team Path
────────────────────── ──────────────────────────────── ────────────────────── ────────
raUuSTetT5uQbqQfLnz9lA CLI test note gvfz2UB5THiKABQJQnLs6Q null
BnC6gN0_TfStV2KKmPPXeg Welcome to your team's workspace null CLI-test
```_See code: [src/commands/history.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/history.ts)_
## `hackmd-cli login`
Login to HackMD server from CLI
```
USAGE
$ hackmd-cli login [-h]FLAGS
-h, --help Show CLI help.DESCRIPTION
Login to HackMD server from CLIEXAMPLES
$ hackmd-cli login
Enter your access token: MY_ACCESS_TOKEN
Login successfully
```_See code: [src/commands/login.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/login.ts)_
## `hackmd-cli logout`
Login to HackMD server from CLI
```
USAGE
$ hackmd-cli logout [-h]FLAGS
-h, --help Show CLI help.DESCRIPTION
Login to HackMD server from CLIEXAMPLES
$ hackmd-cli logout
You've logged out successfully
```_See code: [src/commands/logout.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/logout.ts)_
## `hackmd-cli notes`
HackMD notes commands
```
USAGE
$ hackmd-cli notes [-h] [--noteId ] [--columns | -x] [--sort ] [--filter ]
[--output csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--noteId= HackMD note id
--output= output in a more machine friendly format
--sort= property to sort by (prepend '-' for descending)DESCRIPTION
HackMD notes commandsEXAMPLES
$ hackmd-cli notes
ID Title User Path Team Path
────────────────────── ──────────────────────────────── ────────────────────── ────────
raUuSTetT5uQbqQfLnz9lA CLI test note gvfz2UB5THiKABQJQnLs6Q null
```_See code: [src/commands/notes/index.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/notes/index.ts)_
## `hackmd-cli notes create`
Create a note
```
USAGE
$ hackmd-cli notes create [-h] [--title ] [--content ] [--readPermission ]
[--writePermission ] [--commentPermission ] [-e] [--columns | -x] [--sort ] [--filter
] [--output csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-e, --editor create note with $EDITOR
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--commentPermission= set comment permission: disabled, forbidden, owners, signed_in_users, everyone
--content= new note content
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--output= output in a more machine friendly format
--readPermission= set note permission: owner, signed_in, guest
--sort= property to sort by (prepend '-' for descending)
--title= new note title
--writePermission= set note permission: owner, signed_in, guestDESCRIPTION
Create a noteEXAMPLES
notes create --content='# A new note' --readPermission=owner --writePermission=owner --commentPermission=disabledID Title User Path Team Path
────────────────────── ──────────────────────────────── ────────────────────── ────────
raUuSTetT5uQbqQfLnz9lA A new note gvfz2UB5THiKABQJQnLs6Q nullOr you can pipe content via Unix pipeline:
cat README.md | hackmd-cli notes create
```## `hackmd-cli notes delete`
Delete a note
```
USAGE
$ hackmd-cli notes delete [-h] [--noteId ]FLAGS
-h, --help Show CLI help.
--noteId= HackMD note idDESCRIPTION
Delete a noteEXAMPLES
$ hackmd-cli notes delete --noteId=WNkLM6gkS0Cg2cQ8rv7bYA
```## `hackmd-cli notes update`
Update note content
```
USAGE
$ hackmd-cli notes update [-h] [--noteId ] [--content ]FLAGS
-h, --help Show CLI help.
--content= new note content
--noteId= HackMD note idDESCRIPTION
Update note contentEXAMPLES
$ hackmd-cli notes update --noteId=WNkLM6gkS0Cg2cQ8rv7bYA --content='# A new title'
```## `hackmd-cli team-notes`
HackMD team-notes commands
```
USAGE
$ hackmd-cli team-notes [-h] [--teamPath ] [--columns | -x] [--sort ] [--filter ]
[--output csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--output= output in a more machine friendly format
--sort= property to sort by (prepend '-' for descending)
--teamPath= HackMD team pathDESCRIPTION
HackMD team-notes commandsEXAMPLES
$ hackmd-cli team-notes --teamPath=CLI-test
ID Title User path Team path
────────────────────── ──────────────────────────────── ──────── ────────
WNkLM6gkS0Cg2cQ8rv7bYA a team note null CLI-test
BnC6gN0_TfStV2KKmPPXeg Welcome to your team's workspace null CLI-test
```_See code: [src/commands/team-notes/index.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/team-notes/index.ts)_
## `hackmd-cli team-notes create`
Create a team note
```
USAGE
$ hackmd-cli team-notes create [-h] [--teamPath ] [--title ] [--content ] [--readPermission
] [--writePermission ] [--commentPermission ] [-e] [--columns | -x] [--sort ]
[--filter ] [--output csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-e, --editor create note with $EDITOR
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--commentPermission= set comment permission: disabled, forbidden, owners, signed_in_users, everyone
--content= new note content
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--output= output in a more machine friendly format
--readPermission= set note permission: owner, signed_in, guest
--sort= property to sort by (prepend '-' for descending)
--teamPath= HackMD team path
--title= new note title
--writePermission= set note permission: owner, signed_in, guestDESCRIPTION
Create a team noteEXAMPLES
team-notes:create --teamPath=CLI-test --content='# A new note' --readPermission=owner --writePermission=owner --commentPermission=disabled
ID Title User Path Team Path
────────────────────── ──────────────────────────────── ────────────────────── ────────
raUuSTetT5uQbqQfLnz9lA A new note gvfz2UB5THiKABQJQnLs6Q nullOr you can pipe content via Unix pipeline:
cat README.md | hackmd-cli notes create --teamPath=CLI-test
```## `hackmd-cli team-notes delete`
Delete a team note
```
USAGE
$ hackmd-cli team-notes delete [-h] [--teamPath ] [--noteId ]FLAGS
-h, --help Show CLI help.
--noteId= HackMD note id
--teamPath= HackMD team pathDESCRIPTION
Delete a team noteEXAMPLES
$ hackmd-cli team-notes delete --teamPath=CLI-test --noteId=WNkLM6gkS0Cg2cQ8rv7bYA
```## `hackmd-cli team-notes update`
Update team note content
```
USAGE
$ hackmd-cli team-notes update [-h] [--teamPath ] [--noteId ] [--content ]FLAGS
-h, --help Show CLI help.
--content= new note content
--noteId= HackMD note id
--teamPath= HackMD team pathDESCRIPTION
Update team note contentEXAMPLES
$ hackmd-cli team-notes update --teamPath=CLI-test --noteId=WNkLM6gkS0Cg2cQ8rv7bYA --content='# A new title'
```## `hackmd-cli teams`
List teams
```
USAGE
$ hackmd-cli teams [-h] [--columns | -x] [--sort ] [--filter ] [--output
csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--output= output in a more machine friendly format
--sort= property to sort by (prepend '-' for descending)DESCRIPTION
List teamsEXAMPLES
$ hackmd-cli teams
ID Name Path Owner ID
──────────────────────────────────── ───────────── ──────── ────────────────────────────────────
f76308a6-d77a-41f6-86d0-8ada426a6fb4 CLI test team CLI-test 82f7f3d9-4079-4c78-8a00-14094272ece9
```_See code: [src/commands/teams.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/teams.ts)_
## `hackmd-cli version`
```
USAGE
$ hackmd-cli version [--json] [--verbose]FLAGS
--verbose Show additional information about the CLI.GLOBAL FLAGS
--json Format output as json.FLAG DESCRIPTIONS
--verbose Show additional information about the CLI.Additionally shows the architecture, node version, operating system, and versions of plugins that the CLI is using.
```_See code: [@oclif/plugin-version](https://github.com/oclif/plugin-version/blob/v1.3.3/src/commands/version.ts)_
## `hackmd-cli whoami`
Show current user information
```
USAGE
$ hackmd-cli whoami [-h] [--columns | -x] [--sort ] [--filter ] [--output
csv|json|yaml | | [--csv | --no-truncate]] [--no-header | ]FLAGS
-h, --help Show CLI help.
-x, --extended show extra columns
--columns= only show provided columns (comma-separated)
--csv output is csv format [alias: --output=csv]
--filter= filter property by partial string matching, ex: name=foo
--no-header hide table header from output
--no-truncate do not truncate output to fit screen
--output= output in a more machine friendly format
--sort= property to sort by (prepend '-' for descending)DESCRIPTION
Show current user informationEXAMPLES
$ hackmd-cli whoami
ID Name Email User path
──────────────────────────────────── ────────────── ───── ──────────────────────
82f7f3d9-4079-4c78-8a00-14094272ece9 Ming-Hsiu Tsai null gvfz2UB5THiKABQJQnLs6Q
```_See code: [src/commands/whoami.ts](https://github.com/hackmdio/hackmd-cli/blob/v2.3.2/src/commands/whoami.ts)_
## License
MIT