The App for Community - https://info.gather.coop
Gather is a Ruby on Rails application with some client-side JavaScript for dynamic view elements. HTML is generally rendered server-side. SCSS is used for styling. No special IDE is required for Ruby on Rails development.
Ruby on Rails applications are best developed and run on Linux, Unix, or Mac OS. Development is also possible, though not recommended, on Windows. See the Rails download page for more information.
To install the software below we recommend the following package managers:
- Mac OS X: Homebrew
- Linux/Unix: bundled package manager (e.g. apt-get, yum)
For both production and development environments:
- Ruby (see .ruby-version file for exact version, rbenv is recommended for Ruby version management)
- Bundler
- Once Ruby is installed, run
gem install bundler
to install.
- Once Ruby is installed, run
- Node.js (see .nvmrc file for exact version, nvm is recommended for Node version management)
- Yarn (
npm install -g yarn
) - PostgreSQL 9.2+ (database)
- Redis 4.0+ (cache, key-value store)
- Elasticsearch 6.2+ (search engine)
- libvips v8.8+ (image manipulation; PNG, JPG, and GIF support needed)
- Mailcatcher for testing email (run
gem install mailcatcher
to install).- Note, this gem is deliberately not in the Gemfile because it is a standalone development tool.
- A Gather OAuth client via the Google API Console.
- Mailman 3 (see instructions below).
Follow these steps to setup a development environment for Gather.
-
Install all above dependencies
- Note: For Elasticsearch, we recommend setting the maximum heap size to 200m unless you have lots of memory on your development machine. To do so, edit the
jvm.options
file. See here for instructions. - For Mailman 3:
- Mailman is only required if you're working on the Mailman API integration. If so... mkdir ../mailman && cd ../mailman python3 -m venv venv source venv/bin/activate pip3 install mailman mailman start curl -v http://restadmin:restpass@localhost:8001/3.1/lists pip3 install postorius hyperkitty whoosh git clone https://github.com/gather-community/mailman-suite.git cd mailman-suite/mailman-suite_project/ git clone https://github.com/gather-community/discoursessoclient.git python3 manage.py migrate python3 manage.py collectstatic python3 manage.py runserver curl -v http://localhost:8000 # To test. Run in a new tab.
- Note: For Elasticsearch, we recommend setting the maximum heap size to 200m unless you have lots of memory on your development machine. To do so, edit the
-
Retrieve project files using Git git clone https://github.com/gather-community/gather.git cd gather
If developing, it's best to work off the development branch:
git checkout develop
The remaining steps should all be done from the project directory.
-
Install gems
- Run
bundle install
to install the required gems.
- Run
-
Set local config
- Copy
config/settings.local.yml.example
toconfig/settings.local.yml
. - Edit
config/settings.local.yml
to fit your environment. Be sure to read all the comments within that file for guidance.
- Copy
-
Create development and test databases and schemas
- Copy
config/database.yml.example
toconfig/database.yml
. - Run
rake db:create
to creategather_development
andgather_test
databases. - Run
rake db:schema:load
to create the schema in both databases.
- Copy
-
Create some fake data and a user so you can sign in
- Run:
rake db:new_cluster ADMIN_FNAME="Your" ADMIN_LNAME="Name" ADMIN_EMAIL="you@example.com" SUPER_ADMIN=y
to add one cluster, one community, and a full complement of fake data. This command will also add a user with superadmin privileges with the Gmail address you entered in
settings.local.yml
.
- Run:
rake db:new_cluster ADMIN_FNAME="Your" ADMIN_LNAME="Name" ADMIN_EMAIL="you@example.com" SUPER_ADMIN=y
to add one cluster, one community, and a full complement of fake data. This command will also add a user with superadmin privileges with the Gmail address you entered in
-
Run the tests
- Run
bundle exec rspec
. - All tests should pass.
- Run
-
Ensure Redis is running.
- If you installed via Homebrew, try
brew services start redis
. - If you are on Linux try
sudo systemctl start redis
orsudo service redis start
.
- If you installed via Homebrew, try
-
Trust the development certificate
- On MacOS you can do
sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain config/ssl/gatherdev.org.crt
. - On other platforms you will need to figure this out. Search for "trust local ssl certificate".
- On MacOS you can do
-
Start the server
- Run
bin/dev
. - Leave this console open.
- Run
-
Start DelayedJob
- Open a new console.
- Go to the project directory.
- Run
bin/delayed_job run
. - The logs for jobs will mostly go to log/development.log. The log/delayed_job.log file is sparse and contains only information about the initialization and resulting state of jobs.
-
Start using the system
- In a browser, go to
https://gatherdev.org:3000
to start Gather. - Click "Sign in with Google" to use Gather as the user you just created.
- Enjoy!
- In a browser, go to
Later, to re-start your development environment, the following should be sufficient:
bundle install
bundle exec rake db:migrate
brew services start redis
And if working with Mailman, in a separate terminal:
cd ../mailman
source venv/bin/activate
mailman start
cd mailman-suite/mailman-suite_project/
python3 manage.py runserver
Caching is off by default in development mode since it can lead to confusing issues where changes to views don't show up.
If you are testing some caching behavior you can enable it temporarily by doing:
CACHE=1 rails server
Linters are strongly recommended for checking your code. The CI system will run linters as well and pull requests won't be approved until all issues are resolved or cancelled by the reviewer. We recommend eslint, rubocop, and scss_lint.
If the Elasticsearch index is returning 403 errors, try the following to reset the index (assumes development environment is where the problem is ocurring):
rails console -e development
Work::Shift.__elasticsearch__.create_index!(force: true)
After re-creating the search index in development mode, if you want to be able to search existing data, you'll need to re-populate the index:
ActsAsTenant.current_tenant = Cluster.find(...)
Work::Shift.find_each { |s| s.__elasticsearch__.index_document }
Most code editors have plugins for linting. They will identify and let you click directly into problematic lines. You are encouraged to try one out!