Skip to content

Latest commit

 

History

History
176 lines (133 loc) · 4.48 KB

README.md

File metadata and controls

176 lines (133 loc) · 4.48 KB

micro

Micro is a simple open-source shell which allows you to use bash-esque commands to interact with your Mega cloud account.

Xzibit: Yo dawg, I heard you like shell, so I put a shell in your shell so you can shell while you shell

Note: This project is not affiliated with Mega.

Installation

Download the latest micro release from the releases page or build source by running dotnet build (Requires at least .NET 7).

Usage

To start Micro, simply run the micro command:

micro

Authentication

Note: micro does not (yet) support two-factor authentication.

micro stores your authentication details locally and reuses them between sessions. To log out of micro, use:

μ:/> exit --logout 

OR locate and delete the ./config.json file on your computer.

Screenshot of micro starting up

Available Commands

After starting Micro, you will be presented with the command prompt symbol μ:/>. From here, you can enter various commands to interact with your MEGA cloud storage.

Screenshot of micro's command prompt

The following commands are available in Micro:

  • cd: Change the current working directory.
  • clear: Clear the screen.
  • exit: Quit micro and optionally delete authentication details.
  • get: Download a file from MEGA to the local machine.
  • ls: List the contents of the current directory.
  • mkdir: Create a new directory on MEGA.
  • mv: Move a file or directory to another location on MEGA.
  • pwd: Print the current working directory.
  • put: Upload a file from the local machine to MEGA.
  • rm: Remove files or directories from MEGA.
  • stat: Display status information for a file or directory on MEGA.
  • touch: Create an empty file on MEGA.
  • whoami: Display the current MEGA username.

Note: The following commands are currently a work in progress and not fully implemented:

  • cat: View a file's contents on MEGA.
  • chat: Interact with MEGA chat services.
  • cp: Copy files or directories on MEGA.
  • edit: Use an editor to edit files on MEGA.
  • find: Find files or directories on MEGA.
  • rename: Rename files or directories on MEGA.

Usage Examples

  • Change the current working directory:

    μ:/> cd /my_folder
  • List the contents of the current directory:

    μ:/my_folder> ls
  • Download a file from MEGA to the local machine:

    μ:/my_folder> get file.txt
  • Create a new directory on MEGA:

    μ:/my_folder> mkdir new_directory
  • Move a file or directory to another location on MEGA:

    μ:/my_folder> mv file.txt /other_folder
  • Print the current working directory:

    μ:/my_folder> pwd
  • Upload a file from the local machine to MEGA:

    μ:/my_folder> put local_file.txt
  • Remove files or directories from MEGA:

    μ:/my_folder> rm file.txt
  • Display status information for a file or directory on MEGA:

    μ:/my_folder> stat file.txt
  • Create an empty file on MEGA:

    μ:/my_folder> touch new_file.txt
  • Display the current MEGA username:

    μ:/> whoami

Help and Version

To display help information or check the version of Micro, you can use the following commands:

  • Display general help information:

    μ:/> help
  • Display help information on a specific command:

    μ:/> ls --help
  • Check the version of Micro:

    μ:/> version

Features

  • '.' and '..' navigation
  • Command history
  • Command completion
  • Command aliases
  • Character escaping
  • File globbing
  • File search
  • 2FA

Caveats

In order to keep the command parser simple, some caveats are in place:

  • Lines with whitespace MUST be quoted with double quotes.
  • Quoted lines MUST always use double quotes.
  • Single quotes and backticks inside double quotes are allowed.
  • Double quotes inside double quotes are not supported (yet).
  • The path separator is /.
  • MEGA allows files to have duplicate names, which means navigating directories with duplicate names may require manual selection of the correct path.
  • MEGA allows slashes in node names, which may result in issues with the cd command and create directories when downloading.