RubyEvents.org (formerly RubyVideo.dev), inspired by pyvideo.org, is designed to index all Ruby-related events and videos from conferences and meetups around the world. At the time of writing, the project has 6000+ videos indexed from 200+ events and 3000+ speakers.
Technically the project is built using the latest Ruby and Rails goodies such as Hotwire, Solid Queue, Solid Cache.
For the front end part we use Vite, Tailwind with daisyUI components and Stimulus.
It is deployed on an Hetzner VPS with Kamal using SQLite as the main database.
For compatible browsers it tries to demonstrate some of the possibilities of Page View Transition API.
This project is open source, and contributions are greatly appreciated. One of the most direct ways to contribute at this time is by adding more content.
We also have a page on the deployed site that has up-to-date information with the remaining known TODOs. Check out the "Getting Started: Ways to Contribute" page on RubyEvents.org and feel free to start working on any of the remaining TODOs. Any help is greatly appreciated.
For more information on contributing conference data, please visit this page.
We have tried to make the setup process as simple as possible so that in a few commands you can have the project with real data running locally.
- Ruby 3.4.1
- Node.js 20.11.0
To prepare your database and seed content, run:
bin/setup
You can manually seed content by running:
bin/rails db:seed
You can use the .env.sample
file as a guide for the environment variables required for the project. However, there are currently no environment variables necessary for simple app exploration.
The following command will start Rails, SolidQueue and Vite (for CSS and JS).
bin/dev
The CI performs these checks:
- erblint
- standardrb
- standard (js)
- prettier (yaml)
Before committing your code you can run bin/lint
to detect and potentially autocorrect lint errors.
To follow Tailwind CSS's recommended order of classes, you can use Prettier along with the prettier-plugin-tailwindcss, both of which are included as devDependencies. This formating is not yet enforced by the CI.
Please note that this project is released with a Contributor Code of Conduct. By participating in this project, you agree to abide by its terms. More details can be found in the Code of Conduct document.
Thank you Appsignal for providing the APM tool that helps us monitor the application.
RubyEvents.org is open source and available under the MIT License. For more information, please see the License file.