forked from Ruderverein-Donau-Linz/rowt
60 lines
2.3 KiB
Markdown
60 lines
2.3 KiB
Markdown
# Database
|
|
|
|
Since the database stabilized quite well over the last months/years, hopefully it will not change that much in the future.
|
|
Thus, here is the current (October '24) model and the reasoning behind it:
|
|
|
|
## User
|
|
data:image/s3,"s3://crabby-images/59ef2/59ef27bfa8589894ac9f5c414f9c28d6b1630eb2" alt=""
|
|
|
|
- All user-relevant fields are stored in `User`.
|
|
- `Role` (and its associative table `UserRole`) map current roles the user has. This is used for e.g. permissions (`Vorstand`, `Admin`, `cox`, ... roles) and fee calculation (`Donau Linz`, `scheckbuch`, `Rennjugend`).
|
|
- `Family` specifies, well, a family. Currently only used for fee calculation.
|
|
- `cluster` in `Role` groups roles together. There is a db check to only allow for at most 1 role of the same cluster (e.g. either `cox` or `bootsfuehrer`, but not both).
|
|
|
|
## Planned rowing adventures :-)
|
|
data:image/s3,"s3://crabby-images/f6788/f6788890c73d2d23dcf7ef60d86843387f8f4079" alt=""
|
|
|
|
There are 2 main types:
|
|
|
|
1. **Trips:** Trips can be created by every cox. They are "simple", every-day trips.
|
|
2. **Events:** Events can be created by everyone who has the `manage_events` role. They are used if multiple coxes are needed, e.g. for "Fetzenfahrt", "Anrudern", .... Additionally, events are shown in public calendar (e.g. on the website).
|
|
|
|
`TripDetails` extracts the common data for both Trips and Events.
|
|
Rower can register using the `UserTrip` table.
|
|
This table expects either...
|
|
|
|
- a `user_id`, if a person who has an account registers to the trip/event
|
|
- a `user_note`, if the cox of a trip, or a `manage_events` user of an event wants to add a guest which has no account
|
|
|
|
## Logbook
|
|
data:image/s3,"s3://crabby-images/bd4ab/bd4ab6f98610e1c3caaee1563bf6f47d2092867d" alt=""
|
|
|
|
If `arrival` is NULL, the boat is assumed to still be on the water.
|
|
There are a few `LogbookType`s:
|
|
|
|
- `Wanderfahrt`: Used to check if a user has accomplished their `Fahrtenabzeichen` in the current year.
|
|
- `Regatta`
|
|
|
|
If the number of users entered is less than the boat's maximum capacity, the remaining spaces will be automatically assigned to guests.
|
|
|
|
## Boat
|
|
data:image/s3,"s3://crabby-images/13ef0/13ef09aa19471b734db97cda2867ad3ccd9b6597" alt=""
|
|
|
|
## Trailer
|
|
data:image/s3,"s3://crabby-images/a2213/a2213ee7750cce598e67736a8bf3b17ff4512789" alt=""
|
|
|
|
## Fetching
|
|
data:image/s3,"s3://crabby-images/e03ee/e03ee1a5b986afb8a7feab1c2e2676c0c1000130" alt=""
|
|
|
|
This tables are used to automatically fetch data (every hour). Currently we have:
|
|
|
|
- `Waterlevel` which fetches the current waterlevel in Linz from hydro (with their explicit permission :-))
|
|
- `Weather` weather data from *Open Weather*
|
|
|
|
## Misc
|
|
data:image/s3,"s3://crabby-images/cb234/cb2348c823591fbbe56da162661e2000d4a97f7e" alt=""
|
|
|
|
- **Log:** Logs "interesting" activities, to be viewed in the web ui
|
|
- **Notification**
|
|
- **Distance:** Default distances of certain common targets
|