Skip to content
Snippets Groups Projects

Update README

Open Teal requested to merge update-readme into main
4 unresolved threads
1 file
+ 166
56
Compare changes
  • Side-by-side
  • Inline
+ 166
56
# C3Lingo rescheduled
# c3lingo re:scheduled
> Rapid assignment of shifts for chaos events
## Overview
re:scheduled is a web application for managing translation shifts at chaos events. It facilitates the coordination of translation angels, session scheduling, and real-time collaboration during events.
### Features
- **Automatic schedule import** for re:publica, Pretalx/Hub
- **Integrations** with [C3Lingo Filedrop](https://github.com/c3lingo/c3t-drop), [Engelsystem](https://github.com/engelsystem/engelsystem) and more
- **Integrations** with [c3lingo Filedrop](https://github.com/c3lingo/c3t-drop), [Engelsystem](https://github.com/engelsystem/engelsystem) and more
- **Collaborate live** on session changes using websockets
- **One-click assignment** of angels
- **Express interest** (with optional note) for sessions
@@ -19,22 +21,29 @@
- **Manage source and target languages** per angel and per session
- **Dark mode** and (mostly) responsive web app
- **Statistics and leaderboards**
- **Role-based access control** with flexible permissions
- **Admin interface** for managing users, roles, and conferences
- **Import history** with error tracking for conference data
- ... and more 🎁
### Technologies:
### Technologies
- [Ruby on Rails](https://rubyonrails.org/) with [SQLite](https://sqlite.org/) DB
- [Tailwind CSS](https://tailwindcss.com/)
- [Turbo](https://turbo.hotwired.dev/) + [Stimulus](https://stimulus.hotwired.dev/)
- [ActionCables](https://guides.rubyonrails.org/action_cable_overview.html) with [Redis](https://redis.io/) backend
- [ActionCable](https://guides.rubyonrails.org/action_cable_overview.html) with [Redis](https://redis.io/) backend
- [Devise](https://github.com/heartcombo/devise) for authentication
- [SolidQueue](https://github.com/rails/solid_queue) for background jobs
## Getting Started
## Dev environment
### Development Environment
The project comes with a devcontainer for VSCode and compatible editors. Simply open the project folder in Code (or using `devcontainer open <path>`) and after a few seconds, a suitable container should be ready.
Run `bin/dev` in the integrated terminal to start the dev webserver and the tailwind watch job (see `Procfile.dev` for details). Access your local rescheduled at http://127.0.0.1:3000.
Run `bin/dev` in the integrated terminal to start the dev webserver and the tailwind watch job (see `Procfile.dev` for details). Access your local re:scheduled at http://127.0.0.1:3000.
## Secrets
### Secrets Configuration
The application requires some secrets, as of writing these include:
@@ -47,69 +56,151 @@ The application requires some secrets, as of writing these include:
You can supply the secrets by running `rails credentials:edit` or pass them as environment variable in upper case (e.g. `FILEDROP_USER`).
## Preparation for an event
### Helpful Rails Tasks
tbd.
By running `bin/rails <command>` you can trigger some helpful actions, such as:
- talks about seeds
- set "relevant stages"
~~~ruby
relevant = ["Saal 1", "Saal ZIGZAG", "Saal GLITCH", "Stage HUFF", "Stage YELL", "Canceled talk"]
conf=Conference.find_by(slug: "38c3")
conf.relevant_stages=conf.stages.select { |val| relevant.include?(val[:name]) }
~~~
- sort stages
~~~ruby
Stage.where(name: "Saal 1").update(weight: 10)
Stage.where(name: "Saal GLITCH").update(weight: 20)
Stage.where(name: "Saal ZIGZAG").update(weight: 30)
Stage.where(name: "Stage HUFF").update(weight: 40)
Stage.where(name: "Stage YELL").update(weight: 50)
~~~
- `rails c[onsole]`: Start interactive ruby shell
- `rails db`: Start sqlite shell with the currently used DB
- `rails db:prepare`: Create and migrate the database
- `rails db:migrate`: Run pending DB migrations, automatically done by docker image on start
- `rails db:seed` (Re-)import DB seeds from `db/seeds.rb`
- `rails secret` generate a random secret, e.g. for `secret_key_base`
- `rails generate` Powerful tool to generate boilerplate, run it to see list of options
## In production
## Administration
See [rescheduled-deploy](https://git.cccv.de/c3lingo/rescheduled-deploy) for a full docker-compose stack and more explanations.
### User and Role Management
# Colors (darkmode)
The application uses a role-based access control system with the following main roles:
- `admin`: Full system access
- `events_admin`: Can manage conferences and related resources
- `shift_coordinator`: Can manage session assignments
- **text**: text-slate-300
- **text (overlay)**: text-slate-200
- **text light**: text-slate-400
#### Managing Roles through the Admin UI
- **logo**: text-white
- **highlight**: text-red-500
Roles can be managed through the admin interface:
1. Navigate to `/admin/roles` to view all available roles
2. Click on a role to edit its permissions
3. To assign roles to users, navigate to `/admin/users` and edit the user
- **dark background**: bg-zinc-700
- **light background**: bg-gray-900
- **overlay**: bg-gray-600
- **input**: bg-zinc-900
- **shadow**: gray-400
#### Managing Roles with Rake Tasks
## Tips and Tricks
You can also use the following rake tasks to manage user roles from the command line:
### Helpful `rails` tasks
```bash
# View all users with special roles
rake admin:list
By running `bin/rails <command>` you can trigger some helpful actions, such as
# List all events admin users
rake admin:list_events_admins
- `rails c[onsole]`: Start interactive ruby shell
- `rails db`: Start sqlite shell with the currently used DB
- `rails db:migrate`: Run pending DB migrations, automatically done by docker image on start
- `rails db:seed` (Re-)import DB seeds from `db/seeds.rb`
- `rails secret` generate a random secret, e.g. for `secret_key_base`
- `rails generate` Powerful tool to generate boilerplate, run it to see list of options
# Assign roles
rake admin:make_admin[user@example.com]
    • These tasks should really not take email as argument. We currently don't even ask the user for their email during signup (and I don't think we should).

Please register or sign in to reply
rake admin:make_events_admin[user@example.com]
rake admin:make_shift_coordinator[user@example.com]
### In `rails console`
# Remove roles
rake admin:remove_admin[user@example.com]
rake admin:remove_events_admin[user@example.com]
rake admin:remove_shift_coordinator[user@example.com]
```
- Manually trigger sync job
~~~ruby
FetchConferenceDataJob.perform_now("38c3")
~~~
### Conference Management
- Promote user to shiftcoordinator
~~~ruby
User.find_by(name:"username_here").update(shiftcoordinator: true)
~~~
#### Adding a New Conference
Conferences can be added through the admin interface:
1. Navigate to `/admin/conferences`
2. Click on "Add New Conference"
3. Fill in the basic information (name, slug, dates, time zone)
4. Select the appropriate import job class (e.g., Pretalx, re:publica)
5. Provide the required data fields for the selected import method
6. Save the conference to initiate the data import
#### Importing and Updating Conference Data
Conference data can be imported and updated through the admin interface:
1. Navigate to the conference details page in admin
2. Click on "Run Import Again" to start a new import
3. The import process runs in the background with real-time progress tracking
4. View the import history to see past imports and any errors
#### Setting Relevant Stages
The admin interface provides a dedicated page for managing which stages are relevant:
1. Navigate to the conference details page in admin
2. Click on "Manage Relevant Stages"
3. Check the boxes for stages that should be considered relevant
4. Save your selection
#### Prioritizing Stages
You can set the display order of stages through stage weights. Higher weights push stages down in the listing order:
```ruby
Stage.where(name: "Saal 1").update(weight: 10)
Stage.where(name: "Saal GLITCH").update(weight: 20)
Stage.where(name: "Saal ZIGZAG").update(weight: 30)
```
## Daily Operations
### Assignment Management
Assignments can be created and managed through the web interface:
1. Navigate to a session page
2. Click on the "+" button next to an available slot to assign an angel
3. The assignment is created in real-time and visible to all users
### Candidate Management
Angels can express interest in sessions:
1. Navigate to a session page
2. Click on "Express Interest" to mark yourself as a candidate
3. Optionally add a note with additional information
4. Shift coordinators can view and manage candidates from the session page
### Notification System
The system can notify users about important events:
- Assignment notifications
- Schedule changes
- Upcoming session reminders
## Advanced Features
### Integration with External Systems
#### Filedrop Integration
Documents related to sessions can be managed via the Filedrop integration:
1. Navigate to a session's detail page
2. Click on the "Filedrop" tab to see related documents
3. Documents can be uploaded, viewed, and commented on
    • Comment on lines +176 to +179
      Suggested change
      176 Documents related to sessions can be managed via the Filedrop integration:
      177 1. Navigate to a session's detail page
      178 2. Click on the "Filedrop" tab to see related documents
      179 3. Documents can be uploaded, viewed, and commented on
      176 Documents related to sessions can be imported using the Filedrop integration:
      177 1. Sessions with Filedrop activity have a document icon next their title
      178 2. Go to a session's detail page to see related documents and comments
Please register or sign in to reply
#### Engelsystem Integration
Sessions can be synchronized with the Engelsystem:
1. Navigate to a session's detail page
2. Click on "View in Engelsystem" to open the corresponding shift
3. Changes in assignments can be synchronized between systems
    • Comment on lines +184 to +186
      Suggested change
      184 1. Navigate to a session's detail page
      185 2. Click on "View in Engelsystem" to open the corresponding shift
      186 3. Changes in assignments can be synchronized between systems
      184 1. Navigate to a session's detail page
      185 2. Click on "View in Engelsystem" to open the corresponding shift
Please register or sign in to reply
#### Telegram Notifications
    • Just to let you know, there were some very strong opinions before and during 38c3 that we must not even mention telegram.

      This (and the fact that interacting with matrix using matrix-sdk is an absolute nightmare) is why the telegram handle is currently hidden in the app and why I built the rube goldberg notification machine (see deploy)

      rescheduled -> telegram -> tg-relay -> telegram -> matterbridge -> matrix

      (tg-relay is needed because telegram bots can't see messages from other bots, so matterbridge would not pick up messages from rescheduled).

      Not saying we should not document what we have, but just as a head-up I guess...

      Edited by Felix Eckhofer
Please register or sign in to reply
Important events can trigger Telegram notifications:
- Use the notification settings to configure which events trigger notifications
- Group chats can receive consolidated updates
## Deployment
### Production Environment
See [rescheduled-deploy](https://git.cccv.de/c3lingo/rescheduled-deploy) for a full docker-compose stack and more explanations.
### Maintenance Tasks
Some helpful maintenance tasks you can run in the Rails console:
- Reset user password
~~~ruby
@@ -132,6 +223,25 @@ By running `bin/rails <command>` you can trigger some helpful actions, such as
Candidate.includes(:user, :session).where.not(note: [nil, ""]).pluck('sessions.title','users.name', :note)
~~~
## Appendix
### UI Styling Reference
#### Colors (darkmode)
- **text**: text-slate-300
- **text (overlay)**: text-slate-200
- **text light**: text-slate-400
- **logo**: text-white
- **highlight**: text-red-500
- **dark background**: bg-zinc-700
- **light background**: bg-gray-900
- **overlay**: bg-gray-600
- **input**: bg-zinc-900
- **shadow**: gray-400
## License
re:scheduled is licensed under the GNU Affero General Public License, Version 3.
re:scheduled is licensed under the GNU Affero General Public License, Version 3.
\ No newline at end of file
Loading