#How to contribute
Before contributing to Huboard, please:
- Read and sign the Contributor License Agreement
Ways to contribute:
- The easiest way you can contribute by simply using huboard and adding issues. Find bugs or think of cool features, let me know by submitting issues
- Take a look at the open issues. Anything is fair game, pick one and send me a pull request.
- I've added a label called
Please contribute
, these are features/defects that are lower priority but would still be a great addition to the product
Add labels to your repository with the following pattern
Where:
'#' == index of column
'Title' == column header
Example:
0 - Backlog
1 - Ready
2 - Working
3 - Done
The number represents the index of the column and the will be the column header
Huboard now provides the ability to override some global default settings with labels
defaults = {
:show_all => true # show all open issues, including issues with no labels
}
To override add labels to your repository with the following patterm
@huboard:
yaml
Example:
@huboard: :show_all: false
See issue #89
Add labels to your repository with the following pattern
Link <=> username/repo
Example:
Link <=> rauhryan/ghee
For help distiguishing cards add a custom color to label and huboard will add a border to issues belonging to the linked board
Note: linked boards will aggregate milestone and label together. Milestones are aggregated by the title and must be exactly the same in order to work. Labels are aggregated by the label's name the labels name and color must match in order to work.
gem install bundler
bundle install
Go to https://github.com/settings/applications and register your application to get the application keys needed for OAuth.
- URL: Pow:
http://huboard.dev
, Rack:http://localhost:9292
- Callback: Pow:
http://huboard.dev/auth/github/callback
, Rack:http://localhost:9292/auth/github/callback
cp .settings.sample .settings
Edit .settings
to set the Client ID and Client Secret provided by
Github when you registered the application.
Install Pow from pow.cx
Configure your app for pow:
cd ~/.pow
ln -s /path/to/huboard
Sinatra doesn't automatically reload changes to your app, so tell Pow to restart on every request:
cd /path/to/huboard
mkdir tmp
touch tmp/always_restart.txt
cp .rvmrc.sample .rvmrc
Edit .rvmrc
to specify your ruby version/gemset
bundle exec shotgun -p 9292
or
bundle exec rackup config.ru
Please use the latest stable tag if you are hosting your own instance of huboard.
huboard.com is fully operational and free. If you feel the need to host your own instance please use the latest stable tag. The master branch doesn't always reflect the deployed version on huboard.com and very difficult to support and troubleshoot if you run into any issues.
Sign up on Heroku if you don't have an account, and install the heroku gem:
gem install heroku
Clone Huboard:
git clone https://github.com/rauhryan/huboard.git
cd huboard
Bundle:
bundle install
Create the app:
heroku apps:create ---stack cedar
or, if you'd prefer to name your app yourself:
heroku apps:create <your-app-name> --stack cedar
Go to https://github.com/settings/applications and register your application to get the application keys needed for OAuth.
- URL:
http://<your-app-name>.herokuapp.com
- Callback:
http://<your-app-name>.herokuapp.com/auth/github/callback
Now you'll need to setup some environment variables on Heroku.
Customize your values and run the following from your project root:
heroku config:add \
GITHUB_CLIENT_ID='<your-github-oauth-client>' \
GITHUB_SECRET='<your-github-oauth-secret>' \
SECRET_KEY='<your-random-secret-key>' \
SESSION_SECRET='<your-complex-session-secret>' \
TEAM_ID='<your-github-team-id>'
Note: I know this is crap, trust me I will fix it.
Before deploying there are a few step you need to do manually to prepare the assets for production. Will will need node.js installed as well as the requirejs, uglify-js (v1.x) and lazy npm packages.
npm install requirejs uglify-js@1 lazy
Predeployment (if you've changed any js or css files) run the following rake tasks in this exact order
rake rjs
rake js
rake css
Commit the changes and
git push heroku master
The MIT License (MIT) Copyright (c) 2012-2013 Ryan Rauh
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.