@shpiga/githubdownload
v1.6.1
Published
Easily download Github repos without any external dependencies such as Git, Tar, Unzip, etc.
Downloads
2
Maintainers
Readme
⚠️ THIS IS A FORK
This package is a fork of the public NPM github-download.
It was created to address security issues, fix bugs and add new functionality. While I'm not the author, I would be happy to resolve some issues and accept PR's.
All rights reserved by jprichardson and licensed under MIT.
Node.js - github-download
Easily download Github repos without any external dependencies such as Git, Tar, Unzip, etc.
Why?
I really like the concept of managing user defined projects, repos, file structures (package management) on Github like the way that Component does package management. I have a package management system Rock that I use to create skeleton/templates of projects. I wanted Rock to use Github as a package management system. I also didn't want any dependencies amongst any 3rd party programs like Git, Tar, or Unzip. Pure Node.js JavaScript is what I wanted.
Installation
npm install @shpiga/githubdownload
Usage
ghdownload(params, dir)
Downloads the latest copy of some Github reference (branch, tag, or commit), or the master
branch by default (specifically the master
branch, it does not honor Github's default branch configuration). This will still work even if the Github API limit has been reached.
- params: Can either be:
- a Github URL string such as:
https://github.com/jprichardson/node-vcsurl.git
[email protected]:jprichardson/node-vcsurl.git
git://github.com/jprichardson/node-vcsurl.git
- and even including a reference, e.g.
https://github.com/jprichardson/node-vcsurl.git#master
- or an object like so:
{user: 'jprichardson', repo: 'vcsurl', ref: 'master'}
- a Github URL string such as:
- dir: The output directory. Uses the current working directory if nothing is specified.
Returns a GithubDownloader object that emits events on dir
, file
, and end
.
Example:
var ghdownload = require('@shpiga/githubdownload')
, exec = require('exec')
ghdownload({user: 'jprichardson', repo: 'node-batchflow', ref: 'master'}, process.cwd())
.on('dir', function(dir) {
console.log(dir)
})
.on('file', function(file) {
console.log(file)
})
.on('zip', function(zipUrl) { //only emitted if Github API limit is reached and the zip file is downloaded
console.log(zipUrl)
})
.on('error', function(err) {
console.error(err)
})
.on('end', function() {
exec('tree', function(err, stdout, sderr) {
console.log(stdout)
})
})
Outputs:
.
├── CHANGELOG.md
├── LICENSE
├── README.md
├── lib
│ └── batchflow.js
├── package.json
└── test
├── batchflow-par-array.test.js
├── batchflow-par-limit.test.js
├── batchflow-par-object.test.js
├── batchflow-seq-array.test.js
├── batchflow-seq-object.test.js
├── batchflow.test.js
├── mocha.opts
└── resources
3 directories, 12 files
License
(MIT License)
Copyright 2013-2016, JP Richardson [email protected]