What is git-url-parse?
The git-url-parse npm package is a utility for parsing Git URLs and extracting useful information from them. It supports various Git URL formats and provides methods to manipulate and retrieve different parts of the URL.
What are git-url-parse's main functionalities?
Parsing a Git URL
This feature allows you to parse a Git URL and get an object containing various parts of the URL such as the protocol, source, owner, name, and more.
const gitUrlParse = require('git-url-parse');
const parsed = gitUrlParse('https://github.com/IonicaBizau/git-url-parse.git');
console.log(parsed);
Extracting the owner and name
This feature allows you to extract specific parts of the Git URL, such as the owner and repository name.
const gitUrlParse = require('git-url-parse');
const parsed = gitUrlParse('https://github.com/IonicaBizau/git-url-parse.git');
console.log(parsed.owner); // 'IonicaBizau'
console.log(parsed.name); // 'git-url-parse'
Converting to a different URL format
This feature allows you to convert a Git URL from one format to another, such as from HTTPS to SSH.
const gitUrlParse = require('git-url-parse');
const parsed = gitUrlParse('https://github.com/IonicaBizau/git-url-parse.git');
const sshUrl = parsed.toString('ssh');
console.log(sshUrl); // 'git@github.com:IonicaBizau/git-url-parse.git'
Other packages similar to git-url-parse
parse-github-url
The parse-github-url package is a utility for parsing GitHub URLs specifically. It extracts information such as the owner, repository name, and branch. Compared to git-url-parse, it is more focused on GitHub URLs and may not support other Git hosting services.
git-url
The git-url package provides similar functionality for parsing and manipulating Git URLs. It offers methods to extract parts of the URL and convert between different URL formats. It is comparable to git-url-parse in terms of functionality but may have different API design and usage patterns.
url-parse
The url-parse package is a more general-purpose URL parsing library that can handle various types of URLs, not just Git URLs. While it can be used to parse Git URLs, it does not provide Git-specific methods and properties like git-url-parse does.
git-url-parse
A high level git url parser for common git providers.
:cloud: Installation
npm install --save git-url-parse
yarn add git-url-parse
:clipboard: Example
const GitUrlParse = require("git-url-parse");
console.log(GitUrlParse("git@github.com:IonicaBizau/node-git-url-parse.git"));
console.log(GitUrlParse("https://github.com/IonicaBizau/node-git-url-parse.git"));
console.log(GitUrlParse("https://github.com/IonicaBizau/git-url-parse/blob/master/test/index.js"));
console.log(GitUrlParse("https://github.com/IonicaBizau/node-git-url-parse.git").toString("ssh"));
console.log(GitUrlParse("git@github.com:IonicaBizau/node-git-url-parse.git").toString("https"));
:question: Get Help
There are few ways to get help:
- Please post questions on Stack Overflow. You can open issues with questions, as long you add a link to your Stack Overflow question.
- For bug reports and feature requests, open issues. :bug:
- For direct and quick help, you can use Codementor. :rocket:
:memo: Documentation
gitUrlParse(url, refs)
Parses a Git url.
Params
- String
url
: The Git url to parse. - Array
refs
: An array of strings representing the refs. This is helpful in the context of the URLs that contain branches with slashes.
If user wants to identify the branch, he should pass all branch names
of the project as part of refs parameter
Return
- GitUrl The
GitUrl
object containing: protocols
(Array): An array with the url protocols (usually it has one element).port
(null|Number): The domain port.resource
(String): The url domain (including subdomains).user
(String): The authentication user (usually for ssh urls).pathname
(String): The url pathname.hash
(String): The url hash.search
(String): The url querystring value.href
(String): The input url.protocol
(String): The git url protocol.token
(String): The oauth token (could appear in the https urls).source
(String): The Git provider (e.g. "github.com"
).owner
(String): The repository owner.name
(String): The repository name.ref
(String): The repository ref (e.g., "master" or "dev").filepath
(String): A filepath relative to the repository root.filepathtype
(String): The type of filepath in the url ("blob" or "tree").full_name
(String): The owner and name values in the owner/name
format.toString
(Function): A function to stringify the parsed url into another url type.organization
(String): The organization the owner belongs to. This is CloudForge specific.git_suffix
(Boolean): Whether to add the .git
suffix or not.
stringify(obj, type)
Stringifies a GitUrl
object.
Params
- GitUrl
obj
: The parsed Git url object. - String
type
: The type of the stringified url (default obj.protocol
).
Return
- String The stringified url.
:yum: How to contribute
Have an idea? Found a bug? See how to contribute.
:sparkling_heart: Support my projects
I open-source almost everything I can, and I try to reply to everyone needing help using these projects. Obviously,
this takes time. You can integrate and use these projects in your applications for free! You can even change the source code and redistribute (even resell it).
However, if you get some profit from this or just want to encourage me to continue creating stuff, there are few ways you can do it:
-
Starring and sharing the projects you like :rocket:
-
—I love books! I will remember you after years if you buy me one. :grin: :book:
-
—You can make one-time donations via PayPal. I'll probably buy a coffee tea. :tea:
-
—Set up a recurring monthly donation and you will get interesting news about what I'm doing (things that I don't share with everyone).
-
Bitcoin—You can send me bitcoins at this address (or scanning the code below): 1P9BRsmazNQcuyTxEqveUsnf5CERdq35V6
Thanks! :heart:
:dizzy: Where is this library used?
If you are using this library in one of your projects, add it in this list. :sparkles:
@0x-lerna-fork/github-client
@1coin178/github-compare
@_nomtek/react-native-shimmer-animation
@akemona-org/strapi-generate-new
@amiruldev/wajs
@anakz/backstage-plugin-library-check-backend
@antv/gatsby-theme-antv
@appirio/appirio
@appworks/project-utils
@arcanis/sherlock
@atomist/automation-client
@atomist/automation-client-ext-raven
@atomist/cli
@atomist/sdm-pack-analysis
@atomist/skill
@atomist/uhura
@axetroy/gpm
@backstage-community/plugin-github-actions
@backstage/backend-common
@backstage/backend-defaults
@backstage/cli
@backstage/integration
@backstage/plugin-catalog-backend
@backstage/plugin-catalog-backend-module-github
@backstage/plugin-catalog-import
@backstage/plugin-github-actions
@backstage/plugin-scaffolder
@backstage/plugin-scaffolder-backend-module-confluence-to-markdown
@backstage/plugin-techdocs
@backstage/plugin-techdocs-module-addons-contrib
@backstage/plugin-techdocs-node
@belt/repo
@blackglory/git-list
@blakvghost/ui-pro
@brainfried/github-books
@brantalikp/rn-resize
@brisk-docs/gatsby-generator
@brisk-docs/website
@buschtoens/documentation
@cilyn/bitbucket
@ckatzorke/renovate
@cliz/gpm
@corelmax/react-native-my2c2p-sdk
@cs6/react-native-test-native-view-library
@csmith/release-it
@dandean/storybook-deployer
@deskbtm/workspace-tools
@dfatwork-pkgs/backstage-cli
@dougkulak/semantic-release-gh-pages-plugin
@dtwo/telemetry
@eat-fish/changelog
@emedvedev/renovate
@enkeledi/react-native-week-month-date-picker
@era-ci/utils
@erquhart/lerna-github-client
@esops/publish-github-pages
@eteg/nextra-theme-docs
@facadecompany/ignition-ui
@feizheng/next-git-url
@felipesimmi/react-native-datalogic-module
@flxbl-io/sfp
@focusworkstemp/project-utils
@form8ion/lift
@gasket/plugin-metrics
@geut/chan-parser
@geut/git-compare-template
@geut/git-url-parse
@git-stack/hemera-plugin
@git-stack/server-core
@guardian/cdk
@hawkingnetwork/react-native-tab-view
@hbglobal/react-native-actions-shortcuts
@hemith/react-native-tnk
@hugomrdias/documentation
@hygiene/plugin-github-url
@iceworks/project-utils
@infinitecsolutions/storybook-deployer
@janus-idp/backstage-plugin-topology
@jaredpalmer/workspace-tools
@jswork/next-git-url
@jswork/topics2keywords
@kadira/storybook-deployer
@kevinbds/techdocs-common
@koumoul/gh-pages-multi
@larose/git-backup
@lehuyaa/my-assets
@lerna-lite/version
@lerna-test-v1/markdown
@lerna/create
@lerna/github-client
@lerna/legacy-package-management
@log4brains/core
@madm4ttus3r/l4bcore
@merna/github-client
@micro-app/shared-utils
@microservices/cli
@mmomtchev/documentation
@mongchhi/plugin-blocks
@monokle/synchronizer
@narfeta/catalog-backend
@navabi/react-native-ssl-pinning
@npm_fluentco/adflow-react-native-sdk
@nuxt/telemetry
@nuxt/ui-pro
@nuxthq/studio
@oumi/block-sdk
@oumi/cli-ui
@pageshare/cli
@parallelnft/web3modal
@pipelinedoc/cli
@plone/scripts
@pmworks/project-utils
@positionex/position-sdk
@praella/localisationist
@pubbo/github-client
@pubgcorp/semantic-release-gitlabmonorepo
@pvdlg/semantic-release
@pvm/core
@qiwi/semantic-release-gh-pages-plugin
@qoopido/lerna.version
@radjs/block-sdk
@rdfrontier/plugin-mobile
@react-18-pdf/root
@rianfowler/backstage-backend-common
@roadiehq/backstage-plugin-github-insights
@rocali/apollo
@s-ui/mono
@s-ui/ssr
@s-ui/studio
@safaricom/strapi
@safely-project/safely-ts
@salla.sa/cli
@sanity/pkg-utils
@sanv/apify-shared
@scafflater/scafflater
@secustor/backstage-plugin-renovate-common
@servable/manifest
@servable/tools
@shopgate/pwa-releaser
@sidghimire/react-native-mapbox-navigation
@speakeasy-sdks/nextra-theme-docs
@spotify/backstage-plugin-soundcheck-backend-module-gitlab
@spryker-lerna/github-client
@ssaitho/nextra-theme-docs
@stackbit/cms-git
@stackbit/dev-common
@status-im/react-native-transparent-video
@stepsec/release
@storybook/storybook-deployer
@strapi/pack-up
@strapi/strapi
@tahul/ui-fix
@taingo97/react-native-rsa-expo
@taingo97/react-native-sunmi-printer
@taingo97/react-native-telpo-printer
@tasenor/common-node
@theowenyoung/gatsby-source-git
@tmplr/node
@toanz/strapi-generate-new
@umijs/block-sdk
@unibtc/release-it
@useoptic/optic
@vamsikc/plugin-catalog
@veecode-platform/plugin-github-actions
@visulima/nextra-theme-docs
@voodeng/uppacks
@vrabbi/plugin-scaffolder
@vrabbi/plugin-scaffolder-backend
@wetrial/block-sdk
@whhjdi/nextra-theme-docs
@wolfy1339/gatsby-source-git
@x-team/strapi-generate-new
@xdn/cli
@xyz/create-package
@yarnpkg/plugin-git
@zeplin/cli
anakketiga
anaklanangtea
anakwadontea
apify-shared
apollo
archlibrary
auto-changelog-vsts
autorelease-setup
belt-repo
biometric-st
bitbucket-pullr
changelog.md
checkbox-component
clipped
codesandbox-theme-docs
common-boilerplate
complan
configorama
copy-github-directory
cover-builder
create-apex-js-app
create-minimal-monorepo
cz-conventional-changelog-befe
datoit-generate-new
debone
def-core
development-efficiency
docula-ui
docula-ui-express
documentation
documentation-custom-markdown
dsm-vercel-submodules
dx-scanner
ewizard-cli
fluent.adflow.reactnativesdk-alpha
flutter-boot
fmsl
fotingo
framework_test_library_sixdee
fster
ftl-renovate
gatsby-source-git
gatsby-source-git-remotes
gatsby-source-npmjs
gatsby-theme-cone
gatsby-theme-nestx
gatsby-theme-zh
gaurav-react-native-loop
gcpayz-block-sdk
generate-github-directory
generator-openapi-repo
gerimismalamsenin
ghseek
git-issues
git-observer
git-origin-check
git-service-node
git-source
git-url-promise
git-yoink
gitbook-start-iaas-bbdd-alex-moi
gitbook-start-iaas-ull-es-merquililycony
gitbook-start-plugin-iaas-ull-es-noejaco2017
gitc
github-action-readme
github-assistant
github-publish-npm
gitlab-ci-variables-cli
gtni
harry-reporter
hzero-block-sdk
jrennsoh88-react-native-scroll-indicator
jsnix
kef-core
khaled-salem-custom-components
konfig-release-it
konitor
kuqoi-git
l-other-data
laborious
lambda-service
lcov-server
lerna
lime-cli
manage-dependency
mangudinlagirajin
mdnext-loader
miguelcostero-ng2-toasty
native-apple-login
native-kakao-login
nextra-theme-docs
nextra-theme-docs-mdxcomponents
nextra-theme-infp
ng-apollo
nmrium-cli
notch-ui-ultra
npm_one_1_2_3
npm_qwerty
octokit-downloader
omg
open-pull-request
package-health-checker
package-json-from-git
patchanon-cli
patepangdeui
pbc
pileuleuyantea
pr-changelog-gen
pr-log
pree
prep-barv11
project-wajs-dv
publish-version
pupils-generate-new
pyreswap-sdk
qts-fission
quick-release
quinntainer
rdmobile
reablocks-docs-theme
react-native-android-native-view
react-native-android-video-player-view
react-native-animate-text
react-native-arunjeyam1987
react-native-arunmeena1987
react-native-awesome-module-two
react-native-azure-communication-services
react-native-basic-app
react-native-basic-screen
react-native-biometric-authenticate
react-native-bleccs-components
react-native-bubble-chart
react-native-build-vesion-getter
react-native-check-component
react-native-components-design
react-native-contact-list
react-native-cplus
react-native-create-video-thumbnail
react-native-custom-poccomponent
react-native-dhp-printer
react-native-fedlight-dsm
react-native-flyy
react-native-ghn-ekyc
react-native-innity-remaster
react-native-input-library
react-native-is7
react-native-kakao-maps
react-native-klarify-ios
react-native-klc
react-native-library-testing-422522
react-native-login-demo-test
react-native-manh-test
react-native-module-for-testing
react-native-multi-bluetooth-printer
react-native-multiplier-component
react-native-multiplier-demo
react-native-multiplier2
react-native-multiply
react-native-multiselector
react-native-my-first-try-arun-ramya
react-native-nice-learning
react-native-paynow-generator
react-native-payu-payment-testing
react-native-progress-arrow
react-native-rabbitmq-all
react-native-reanimated-sortable-list
react-native-rom-components
react-native-sandycomponent
react-native-savczuk-feature-library
react-native-shared-gesture
react-native-test-comlibrary
react-native-ticker-tape
react-native-tone-framework
react-native-tones
react-native-uvc-camera-android
react-native-withframework-check
react-native-ytximkit
redhatinsights-plugin-scaffolder-backend
refinejs-repo
release-it
release-it-http
remax-stats
renovate
renovate-csm
repom
rn-adyen-dropin
rn-check-btn
rn_unique_device_id
scaffolder-core
sedanbosok
semantic-release-github-milestones
semantic-release-gitmoji
semantic-release-squash3
sherry-utils
simple-github-release
snipx
spk
storybook-deployer
strapi-generate-new
stylelint-formatter-utils
sync-repos
tanyao
tegit
tehmusimhujan
template-typescript-node-package
test-library-123
testarmada-midway
tldw
todo2issue
tooling-personal
toxics-rpc
umi-build-dev
vision-camera-plugin-face-detector
vuepress-plugin-remote-url
wiby
winx-form-winx
workspace-tools
wsj.gatsby-source-git
:scroll: License
MIT © Ionică Bizău