Node AMD builder
This project aims at providing a NodeJS service to build bundles out of AMD projects in a git repository. This was developed to help jQuery Mobile build the bundle builder. Initial checkout as well as workspace creation have to be done manually.
API v1
/v1/{project}/{repo}
Fetch the latest version of the repo from the default remote.
/v1/{project}/{repo}/{ref}
Force checkout the ref into the {project}/{ref}/{repo} workspace if it exists.
/v1/dependencies/{project}/{repo}/{ref}
Traces 1st level dependencies.
URL arguments are:
-
baseUrl
: The baseUrl for module name to file resolution -
names
: An optional comma separated list of modules to include in the dependency map. If it's not specified, the service will compute the dependency map for all the .js files in thebaseUrl
directory.
/v1/bundle/{project}/{repo}/{ref}/{name}?
name
is the name of the file generated it defaults to repo
.js
-
name
has extension .js (default) calls require.js to build the js bundle -
name
has extension .css will resolve css dependencies through the//css:
metadata and return a css bundle -
name
has extension .zip will do all of the above in both optimize and non-optimized and return a zip file with 4 files in it
Builds a bundle for this repository's ref
URL arguments are:
-
baseUrl
: The baseUrl for module name to file resolution -
include
: A comma separated list of modules to include in the bundle -
exclude
: A comma separated list of modules to exclude from the bundle -
optimize
: true or false
Setup an instance for your project
- Clone a bare repo of your project:
mkdir <basedir>/repos
cd <basedir>/repos
git clone --bare git://github.com/yourname/yourproject.git
- Now create the staging directory:
mkdir <basedir>/staging
-
Install the dependencies with
npm install
-
Start the service:
node server.js -r <basedir>/repos -s <basedir>/staging
- Add a post_receive hook to the your GitHub repo pointing at
http://instance:3000/post_receive
License
Copyright (c) 2012, Ghislain Seguin (MIT License)