Home

Awesome

license

Mersea

Requirements

Setup

rbenv install
gem install bundler

Development

Clone repository.

# Install and configure db
$ bundle install
$ bundle exec rails db:create
$ bundle exec rails db:migrate

# Add static pages
$ bundle exec rails db:seed

# Launch app
$ bundle exec rails s

Increase inotify watchers.

ReCaptcha is disabled in development. Configure key if needed using RECAPTCHA_SECRET_KEY and RECAPTCHA_SITE_KEY.

Create an admin account

Within a Rails console:

bundle exec rails console
Admin.create(name: 'myname', email: 'myemail@email.local', password: 'mypassword')

Admin section is reachable at /admin.

Frontend

To setup frontend, see readme in ./frontend.

Production with Docker

Configure your reCaptcha keys as environment variables

$ cd /path/to/mersea
$ docker-compose up -d

Feel free to modifies the provided docker-compose.yml to your needs.

http://localhost:3000

# mersea_mersea_1 is the container name defined by docker-compose
$ docker exec -it mersea_mersea_1 bundle exec rails c

To set any environment variable in the container, use one or more -e flags:

Datagouv export

# Configure .env file with datagouv credentials
bundle exec rake datagouv

License

MIT. See the LICENSE for more details.

About

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Ensure specs and Rubocop pass
  5. Push to the branch (git push origin my-new-feature)
  6. Create new Pull Request

Special thanks

We would like to thanks the following companies for their open source plans and support

BugsnagThanks to Bugsnag we can monitor and investigate errors on our application
MapboxThank you to Mapbox for their mapping services and tools
BrowserStackThank you to BrowserStack for their testing platform. It allows us to seamlessly test our web application on different devices and browser
Circle-ciThanks to Circleci we can build efficient ci/cd pipelines

Thanks to all the open source tools we are using to make our application (gemfile, package.json)