npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

gitfm

v2.1.1

Published

A CLI App for searching GitHub/GitLab repos, fetching as filesystem and cloning

Downloads

189

Readme

gitFM

gitFM is a command-line tool that can search GitHub/GitLab repositories, retrieve repository file contents and clone them normally or partially depending on your choice directly from the terminal(never leave the terminal). Your best friend for fetching repository as filesystem and easy cloning.

Installation

First, make sure you have Node.js and git pre-installed in your system. Then install gitFM globally by running the following command:

npm install -g gitfm

Usage

Helptexts

Run gitfm --help or gitfm -h or gitfm help to know get the helptext. It will look like this - screenshot of the helptext

To get more info about any individual command of gitfm, run - gitfm help <command-name>. For example, - if you want to know about the clone command in detail, you would run - gitfm help clone.

screenshot of the clone command helptext

[!NOTE] In the helptexts, - an argument enclosed within [] signify that the arg is optional and within <> signify that the arg is mandatory.

Descriptions of the Individual Commands

  • gitfm clone [options] :- This command has four options, - --blobless, --treeless, --shallow and --sparse. When none of them are provided, it proceeds to perform a normal(cloning the whole repository as usual) git clone of the provided repository URL. This command doesn't require any authentication. This is going to be your most helpful/used command of this application (most likely). --shallow option should be used when you want to clone only the latest commit of the repository. --blobless and --treeless options should be used when you want to clone a repository in a blobless or treeless format. The --sparse option should be used when you want to clone only the specified files or directories of the repository. The beauty of this command is that you can run it without installing the CLI (npx gitfm clone <repourl> [options]). For more info about the options, run gitfm clone --help or gitfm help clone.
  • gitfm ghauth [options] :- This command has three options, - --login, --logout and --refresh. When none of them are provided, it will first check if you are already authenticated with GitHub. If you are, it will say so and exit. If you are not, it will ask you to login with your GitHub account(basically, the same as gitfm ghauth --login). If you want to logout, run gitfm ghauth --logout. If you want to refresh your token, run gitfm ghauth --refresh. In case of browser login, a browser window/tab will be automatically opened with the verification URL if and only if your default browser is anything between chrome, edge or firefox. If your default browser is something else, the verification URL will be shown in the console so that you can manually open it in the browser to log in. After a successful login, the token is stored in the $HOME directory of your system in a config file named .gitfmrc.json. Your token is revoked by gitfm while logging out only if it is an oauth token (you authenticated using Browser with passcodes). If it is a PAT, gitfm will just reset the config file. TOKEN WON'T BE DELETED. To delete your token, you should directly do that from your GitHub developer settings. For more info about the options, run gitfm ghauth --help or gitfm help ghauth.
  • gitfm ghprofile :- Shows a minimal view of your GitHub profile. This command takes no arguments. Requires you to be authenticated. If not, it will autostart interactive authentication mode. When authentication process will complete, it will show your profile info.
  • gitfm glauth [options] :- This command also contains 3 options - --login, --logout, --rotate. You can authenticate gitfm with your Gitlab account only using a personal access token. Browser login is not supported and won't be implemented in future. The token is stored in a JSON file(.gl.gitfmrc.json) inside the $HOME directory of your system. For more info, run - gitfm glauth -h or gitfm help glauth.
  • gitfm icl [options] :- This command has three options - --gh, --gl and --unauthenticated. When none of them are provided, it will do nothing.. If you want to interactively search and clone a GitHub repository, run gitfm icl --gh. If you want to interactively search and clone a GitLab repository, run gitfm icl --gl. If you want to run the legacy version of the GitHub repo interactive clone command(without partial cloning support but doesn't require authentication), run gitfm icl --unauthenticated. For more info about the options, run gitfm icl --help or gitfm help icl.

Feedback

If you encounter any problems or have any suggestions when using gitFM, you are welcome to submit an issue in the GitHub repository.

Star 🌟 This repo

Show some love to this project by starring it. It will help in increasing the visibility of this project and also in motivating me to work on this project more often. More features will be added to this project in the future. :)

License

Internet Standard Consortium License (ISC)