1. hosted-git-info
Provides metadata and conversions from repository urls for GitHub, Bitbucket and GitLab
hosted-git-info
Package: hosted-git-info
Created by: npm
Last modified: Wed, 13 Sep 2023 14:45:43 GMT
Version: 7.0.1
License: ISC
Downloads: 211,596,954
Repository: https://github.com/npm/hosted-git-info

Install

npm install hosted-git-info
yarn add hosted-git-info

hosted-git-info

This will let you identify and transform various git hosts URLs between
protocols. It also can tell you what the URL is for the raw path for
particular file for direct access without git.

Example

 const hostedGitInfo = require("hosted-git-info")
const info = hostedGitInfo.fromUrl("[email protected]:npm/hosted-git-info.git", opts)
/* info looks like:
{
  type: "github",
  domain: "github.com",
  user: "npm",
  project: "hosted-git-info"
}
*/

If the URL can't be matched with a git host, null will be returned. We
can match git, ssh and https urls. Additionally, we can match ssh connect
strings ([email protected]:npm/hosted-git-info) and shortcuts (eg,
github:npm/hosted-git-info). GitHub specifically, is detected in the case
of a third, unprefixed, form: npm/hosted-git-info.

If it does match, the returned object has properties of:

  • info.type -- The short name of the service
  • info.domain -- The domain for git protocol use
  • info.user -- The name of the user/org on the git host
  • info.project -- The name of the project on the git host

Version Contract

The major version will be bumped any time…

  • The constructor stops accepting URLs that it previously accepted.
  • A method is removed.
  • A method can no longer accept the number and type of arguments it previously accepted.
  • A method can return a different type than it currently returns.

Implications:

  • I do not consider the specific format of the urls returned from, say
    .https() to be a part of the contract. The contract is that it will
    return a string that can be used to fetch the repo via HTTPS. But what
    that string looks like, specifically, can change.
  • Dropping support for a hosted git provider would constitute a breaking
    change.

Usage

const info = hostedGitInfo.fromUrl(gitSpecifier[, options])

  • gitSpecifer is a URL of a git repository or a SCP-style specifier of one.
  • options is an optional object. It can have the following properties:
    • noCommittish — If true then committishes won't be included in generated URLs.
    • noGitPlus — If true then git+ won't be prefixed on URLs.

Methods

All of the methods take the same options as the fromUrl factory. Options
provided to a method override those provided to the constructor.

  • info.file(path, opts)

Given the path of a file relative to the repository, returns a URL for
directly fetching it from the githost. If no committish was set then
HEAD will be used as the default.

For example hostedGitInfo.fromUrl("[email protected]:npm/hosted-git-info.git#v1.0.0").file("package.json")
would return https://raw.githubusercontent.com/npm/hosted-git-info/v1.0.0/package.json

  • info.shortcut(opts)

eg, github:npm/hosted-git-info

  • info.browse(path, fragment, opts)

eg, https://github.com/npm/hosted-git-info/tree/v1.2.0,
https://github.com/npm/hosted-git-info/tree/v1.2.0/package.json,
https://github.com/npm/hosted-git-info/tree/v1.2.0/README.md#supported-hosts

  • info.bugs(opts)

eg, https://github.com/npm/hosted-git-info/issues

  • info.docs(opts)

eg, https://github.com/npm/hosted-git-info/tree/v1.2.0#readme

  • info.https(opts)

eg, git+https://github.com/npm/hosted-git-info.git

  • info.sshurl(opts)

eg, git+ssh://[email protected]/npm/hosted-git-info.git

  • info.ssh(opts)

eg, [email protected]:npm/hosted-git-info.git

  • info.path(opts)

eg, npm/hosted-git-info

  • info.tarball(opts)

eg, https://github.com/npm/hosted-git-info/archive/v1.2.0.tar.gz

  • info.getDefaultRepresentation()

Returns the default output type. The default output type is based on the
string you passed in to be parsed

  • info.toString(opts)

Uses the getDefaultRepresentation to call one of the other methods to get a URL for
this resource. As such hostedGitInfo.fromUrl(url).toString() will give
you a normalized version of the URL that still uses the same protocol.

Shortcuts will still be returned as shortcuts, but the special case github
form of org/project will be normalized to github:org/project.

SSH connect strings will be normalized into git+ssh URLs.

Supported hosts

Currently this supports GitHub (including Gists), Bitbucket, GitLab and Sourcehut.
Pull requests for additional hosts welcome.

Dependencies

RELATED POST

10 Must-Know Windows Shortcuts That Will Save You Time

10 Must-Know Windows Shortcuts That Will Save You Time

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Navigating AWS Networking: Essential Hacks for Smooth Operation

Navigating AWS Networking: Essential Hacks for Smooth Operation

Achieving Stunning Visuals with Unity's Global Illumination

Achieving Stunning Visuals with Unity's Global Illumination

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code