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 resolutionnames
: 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 the baseUrl
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 bundlename
has extension .css will resolve css dependencies through the //css:
metadata and return a css bundlename
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 resolutioninclude
: A comma separated list of modules to include in the bundleexclude
: A comma separated list of modules to exclude from the bundleoptimize
: 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)