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 🙏

© 2024 – Pkg Stats / Ryan Hefner

nodegit-flow

v2.2.2

Published

nodegit-flow contains gitflow methods that aren't include in the vanilla nodegit package

Downloads

1,211

Readme

nodegit-flow

Adds gitflow methods to the nodegit module.

Installation

npm install --save nodegit-flow

Usage

nodegit-flow is a drop in replacement for nodegit. All methods in nodegit are included in nodegit-flow. You must provide the nodegit module to nodegit-flow.

var nodegit = require('nodegit-flow')(require('nodegit')); // wrap nodegit in git flow methods

You can initialize an instance of nodegit-flow or use its static methods

var flow = nodegit.Flow.init(repo, config);

flow.startRelease('1.0.0'); // Use a flow instance to start a release
nodegit.Flow.startRelease(repo, '1.0.0'); // or the static equivalent

Methods

finishFeature(repository, name, [options])

By default finishFeature will merge the feature branch into the develop branch and delete the feature branch. If successful, finishFeature will resolve with the merge commit. If a merge conflict occurs finishFeature will reject with the index of the conflict.

options Object

  • isRebase Boolean default=false
  • keepBranch Boolean default=false

Example:

NodeGit.Flow.finishFeature(
  repository,
  'my-feature'
)
  .then((mergeCommit) => {
    console.log(mergeCommit.id()); // => the sha of the newly created commit
  });

finishHotfix(repository, name, [options])

By default finishHotfix will merge the hotfix branch into the develop branch and the master branch, create a tag at the merge commit on master, and delete the hotfix branch. If successful, finishHotfix will resolve with the merge commit on develop. If a merge conflict occurs finishHotfix will reject with the index of the conflict.

options Object

  • keepBranch Boolean default=false
  • message String tag annotation default=''

Example:

NodeGit.Flow.finishHotfix(
  repository,
  'my-hotfix'
)
  .then((mergeCommit) => {
    console.log(mergeCommit.id()); // => the sha of the newly created commit
  });

finishRelease(repository, name, [options])

By default finishRelease will merge the release branch into the develop branch and the master branch, create a tag the points to the merge commit on master, and delete the release branch. If successful, finishRelease will resolve with the merge commit. If a merge conflict occurs finishRelease will reject with the index of the conflict.

options Object

  • isRebase Boolean default=false
  • keepBranch Boolean default=false
  • message String tag annotation default=''

Example:

NodeGit.Flow.finishRelease(
  repository,
  'my-release'
)
  .then((mergeCommit) => {
    console.log(mergeCommit.id()); // => the sha of the newly created commit
  });

getConfig(repository)

Retrieves an object that contains the git config values that are relevant to git flow

getConfigDefault()

Returns the following object which is the standard git flow config object

{
  'gitflow.branch.master': 'main',
  'gitflow.branch.develop': 'develop',
  'gitflow.prefix.feature': 'feature/',
  'gitflow.prefix.release': 'release/',
  'gitflow.prefix.hotfix': 'hotfix/',
  'gitflow.prefix.versiontag': ''
}

getConfigRequiredKeys()

Returns the config keys that are required to use nodegit-flow

getDevelopBranch(repository)

Returns the value stored within a repos git config with the key of gitflow.branch.develop

getHotfixPrefix(repository)

Returns the value stored within a repos git config with the key of gitflow.prefix.hotfix

getMasterBranch(repository)

Returns the value stored within a repos git config with the key of gitflow.branch.master

getFeaturePrefix(repository)

Returns the value stored within a repos git config with the key of gitflow.prefix.feature

getReleasePrefix(repository)

Returns the value stored within a repos git config with the key of gitflow.prefix.release

getSupportPrefix(repository)

Returns the value stored within a repos git config with the key of gitflow.prefix.support

getVersionTagPrefix(repository)

Returns the value stored within a repos git config with the key of gitflow.prefix.versiontag

init(repository, config)

Sets the git flow config values for the given repo and returns a new instance of nodegit-flow. This new instance contains all of the static methods within the NodeGit.Flow object but does not require a repository to be passed in when using its methods.

isInitialized(repository)

Resolves to true or false depending on whether the repository has git flow initialized

Example:

NodeGit.Flow.isInitialized(repository)
  .then((isInitialized) => {
    console.log(isInitialized); // => true or false depending the git config of the repo
  });

open(repository)

Resolves to a new instance of nodegit-flow if the repository has git flow initialized, otherwise reject with the reason

Example:

NodeGit.Flow.open(repository)
  .then((flow) => {
    return flow.getMasterBranch();
  })
  .then((masterBranchName) => {
    console.log(masterBranchName); // => main
  });

startFeature(repository, name, [options])

options Object

  • sha String

options is an object with a sha that marks the starting commit of the feature. If no sha is passed in, the feature will start at the develop branch.

The name of the feature branch is the featurePrefix set in the git config appended with the passed in name parameter;

Example:

NodeGit.Flow.startFeature(
  repository,
  'my-feature',
  {sha: 'a7b7a15c94df9528339fd86b9808ec2d9c645705'}
)
  .then((featureBranch) => {
    console.log(featureBranch.shorthand()); // => feature/my-feature
  });

startHotfix(repository, name)

The name of the hotfix branch is the hotfixPrefix set in the git config appended with the passed in name parameter;

Example:

NodeGit.Flow.startHotfix(
  repository,
  '0.1.13'
)
  .then((hotfixBranch) => {
    console.log(hotfixBranch.shorthand()); // => hotfix/0.1.13
  });

startRelease(repository, name [options])

options Object

  • sha String

options is an object with a sha that marks the starting commit of the release. If no sha is passed in, the release will start at the develop branch.

The name of the release branch is the releasePrefix set in the git config appended with the passed in name parameter;

Example:

NodeGit.Flow.startRelease(
  repository,
  '0.2.0'
)
  .then((releaseBranch) => {
    console.log(releaseBranch.shorthand()); // => release/0.2.0
  });

validateConfig(config)

Validates that a config object has all of the required keys for nodegit-flow to work.

Example:

const result = NodeGit.Flow.validateConfig({
  'gitflow.branch.master': 'main',
  'gitflow.branch.develop': 'develop',
  'gitflow.prefix.feature': 'feature/',
  'gitflow.prefix.hotfix': 'hotfix/'
});
console.log(result); // => gitflow config missing key(s): gitflow.prefix.release