2004 lines
48 KiB
YAML
2004 lines
48 KiB
YAML
---
|
|
# Types:
|
|
# - Nativ datatypes: string, number, boolean, JSON
|
|
# - HTMLStrict: A string with HTML content.
|
|
# - HTMLPermissive: A string with HTML content (with video tags).
|
|
# - float: Numbers that are expected to be non-integer. Formatted as in rfc7159.
|
|
# - decimal(X): Decimal values represented as a string with X decimal places.
|
|
# At the moment we support only X == 6.
|
|
# - timestamp: Datetime as a unix timestamp. Why a number? This enables queries
|
|
# in the DB. And we do not need more precision than 1 second.
|
|
# - <T>[]: This indicates and arbitrary array of the given type. At the moment
|
|
# we support only some types. You can add JSON Schema properties for items
|
|
# using the extra property `items`
|
|
# Relations:
|
|
# - We have the following types: `relation`, `relation-list`, `generic-relation`
|
|
# and `generic-relation-list`.
|
|
# - Non-generic relations: The simple syntax for such a field
|
|
# `to: <collection>/<field>`. This is a reference to a collection. The reverse
|
|
# relation field in this collection is <field>. E. g. in a motion the field
|
|
# `category_id` links to one category where the field `motion_ids` contains the
|
|
# motion id. The simple notation for the field is `motion_category/motion_ids`.
|
|
# The reverse field has type `relation-list` and is related back to
|
|
# `motion/category_id`. The type indicates that there are many
|
|
# motion ids.
|
|
# - Generic relations: The difference to non-generic relations is that you have a
|
|
# list of possible collections. Therefor we split the simple notation up to the
|
|
# properties `collection` and `field`.
|
|
# - on_delete: This fields determines what should happen with the foreign model if
|
|
# this model gets deleted. Possible values are:
|
|
# - SET_NULL (default): delete the id from the foreign key
|
|
# - PROTECT: if the foreign key is not empty, throw an error instead of
|
|
# deleting the object
|
|
# - CASCADE: also delete all models in this foreign key
|
|
# Structured fields:
|
|
# - There are template fields (see autoupdate service interface) with a `$` as
|
|
# the placeholder. We have three different types: `template`,
|
|
# `structured-relation` and `structured-tag`.
|
|
# - The type `template` describes a structured field for the given model. The
|
|
# property `replacement` describes the meaning of the template. The property
|
|
# `fields` contains the definition for all the fields that come from the template
|
|
# field.
|
|
# - The type `structured-relation` describes the content of a related field as a
|
|
# structured field (with properties `name`, `replacement` and `through`).
|
|
# - The type `structured-tag` describes the content of a related field as a
|
|
# structured field where the template is filled with arbitrary strings instead of
|
|
# instance ids.
|
|
# JSON Schema Properties:
|
|
# - You can add JSON Schema properties like `enum` and `description` to the fields.
|
|
|
|
organisation:
|
|
id: number
|
|
name: string
|
|
description: HTMLStrict
|
|
|
|
# Settings (configurable by the client)
|
|
legal_notice: string
|
|
privacy_policy: string
|
|
login_text: string
|
|
theme: string
|
|
custom_translations: JSON
|
|
reset_password_verbose_errors: boolean
|
|
|
|
# Configuration (only for the server owner)
|
|
enable_electronic_voting:
|
|
type: boolean
|
|
read_only: true
|
|
|
|
committee_ids:
|
|
type: relation-list
|
|
to: committee/organisation_id
|
|
role_ids:
|
|
type: relation-list
|
|
to: role/organisation_id
|
|
superadmin_role_id:
|
|
type: relation
|
|
to: role/superadmin_role_for_organisation_id
|
|
resource_ids:
|
|
type: relation-list
|
|
to: resource/organisation_id
|
|
|
|
user:
|
|
id: number
|
|
username: string
|
|
title: string
|
|
first_name: string
|
|
last_name: string
|
|
is_active: boolean
|
|
is_committee: boolean
|
|
password: string
|
|
default_password: string
|
|
about_me: HTMLStrict
|
|
gender: string
|
|
comment: HTMLStrict
|
|
number: string
|
|
structure_level: string
|
|
email: string
|
|
last_email_send: string
|
|
vote_weight: decimal(6)
|
|
is_demo_user:
|
|
type: boolean
|
|
read_only: true
|
|
|
|
role_id:
|
|
type: relation
|
|
to: role/user_ids # Attention: prevent impelenting a "default-role" or let a
|
|
# user create such a role! This would cause the user_ids-array for this
|
|
# role to explode in size. If a user has no role, it should be handles as
|
|
# the user has no permission in the organisation and is a "normal" delegate
|
|
# there. Just a few users (expected <100) should even get a role and all
|
|
# other don't.
|
|
|
|
# Meeting and committee
|
|
is_present_in_meeting_ids:
|
|
type: relation-list
|
|
to: meeting/present_user_ids
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/temporary_user_ids # Temporary users
|
|
guest_meeting_ids:
|
|
type: relation-list
|
|
to: meeting/guest_ids # Guests in meetings
|
|
committee_as_member_ids:
|
|
type: relation-list
|
|
to: committee/member_ids
|
|
committee_as_manager_ids:
|
|
type: relation-list
|
|
to: committee/manager_ids
|
|
|
|
# Projection
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
|
|
# All foreign keys are meeting-specific:
|
|
# - Keys are smaller (Space is in O(n^2) for n keys
|
|
# in the relation), so this saves storagespace
|
|
# - This makes quering things like this possible:
|
|
# "Give me all groups for User X in Meeting Y" without
|
|
# the need to get all groups and filter them for the meeting
|
|
group_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: group/user_ids
|
|
speaker_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: speaker/user_id
|
|
personal_note_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: personal_note/user_id
|
|
on_delete: CASCADE
|
|
supported_motion_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: motion/supporter_ids
|
|
submitted_motion_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: motion_submitter/user_id
|
|
motion_poll_voted_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: motion_poll/voted_ids
|
|
motion_vote_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: motion_vote/user_id
|
|
motion_delegated_vote_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: motion_vote/delegated_user_id
|
|
assignment_candidate_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: assignment_candidate/user_id
|
|
assignment_poll_voted_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: assignment_poll/voted_ids
|
|
assignment_option_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: assignment_option/user_id
|
|
assignment_vote_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: assignment_vote/user_id
|
|
assignment_delegated_vote_$_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to: assignment_vote/delegated_user_id
|
|
vote_delegated_$_to_id:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: vote_delegations_$_from_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
vote_delegations_$_from_ids:
|
|
type: template
|
|
replacement: meeting_id
|
|
fields:
|
|
type: relation-list
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: vote_delegated_$_to_id
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
|
|
role:
|
|
id: number
|
|
name: string
|
|
permissions: string[]
|
|
|
|
organisation_id:
|
|
type: relation
|
|
to: organisation/role_ids
|
|
superadmin_role_for_organisation_id:
|
|
type: relation
|
|
to: organisation/superadmin_role_id
|
|
user_ids:
|
|
type: relation-list
|
|
to: user/role_id
|
|
|
|
# New: Resource
|
|
# Resources are organsation wide "mediafiles", like logos for the organisatio or
|
|
# organisation-wide fonts. Therefore, no permission checks are done and the user
|
|
# must not be logged in to retrieve files. A resource has a token, e.g. `web_header`
|
|
# or `pdf_font_italic`, so the client knowns, where to put the resource.
|
|
resource:
|
|
id: number
|
|
token: string
|
|
filesize: number
|
|
mimetype: string
|
|
|
|
organisation_id:
|
|
type: relation
|
|
to: organisation/resource_ids
|
|
|
|
committee:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
description: HTMLStrict
|
|
|
|
meeting_ids:
|
|
type: relation-list
|
|
to: meeting/committee_id
|
|
on_delete: CASCADE
|
|
template_meeting_id:
|
|
type: relation
|
|
to: meeting/template_for_committee_id
|
|
default_meeting_id:
|
|
type: relation
|
|
to: meeting/default_meeting_for_committee_id
|
|
member_ids:
|
|
type: relation-list
|
|
to: user/committee_as_member_ids
|
|
manager_ids:
|
|
type: relation-list
|
|
to: user/committee_as_manager_ids
|
|
forward_to_committee_ids:
|
|
type: relation-list
|
|
to: committee/receive_forwardings_from_committee_ids
|
|
receive_forwardings_from_committee_ids:
|
|
type: relation-list
|
|
to: committee/forward_to_committee_ids
|
|
organisation_id:
|
|
type: relation
|
|
to: organisation/committee_ids
|
|
required: true
|
|
|
|
meeting:
|
|
id: number
|
|
welcome_title: string
|
|
welcome_text: HTMLPermissive
|
|
|
|
# General
|
|
name:
|
|
type: string
|
|
maxLength: 100
|
|
description:
|
|
type: string
|
|
maxLength: 100
|
|
location: string
|
|
start_time: timestamp
|
|
end_time: timestamp
|
|
|
|
# Configuration (only for the server owner)
|
|
jitsi_domain:
|
|
type: string
|
|
read_only: true
|
|
jitsi_room_name:
|
|
type: string
|
|
read_only: true
|
|
jitsi_room_password:
|
|
type: string
|
|
read_only: true
|
|
|
|
# System
|
|
url_name:
|
|
type: string
|
|
description: For unique urls.
|
|
template_for_committee_id:
|
|
type: relation
|
|
to: committee/template_meeting_id
|
|
enable_anonymous: boolean
|
|
|
|
# Jitsi/Livestream settings
|
|
conference_show: boolean
|
|
conference_auto_connect: boolean
|
|
conference_los_restriction: boolean
|
|
conference_stream_url: string
|
|
conference_stream_poster_url: string
|
|
|
|
# Projector
|
|
projector_default_countdown_time: number
|
|
projector_countdown_warning_time:
|
|
type: number
|
|
minimum: 0
|
|
|
|
# Exports
|
|
export_csv_encoding:
|
|
type: string
|
|
enum:
|
|
- utf-8
|
|
- iso-8859-15
|
|
export_csv_separator: string
|
|
export_pdf_pagenumber_alignment:
|
|
type: string
|
|
enum:
|
|
- left
|
|
- right
|
|
- center
|
|
export_pdf_fontsize:
|
|
type: number
|
|
enum:
|
|
- 10
|
|
- 11
|
|
- 12
|
|
export_pdf_pagesize:
|
|
type: string
|
|
enum:
|
|
- A4
|
|
- A5
|
|
|
|
# Agenda
|
|
agenda_show_subtitles: boolean
|
|
agenda_enable_numbering: boolean
|
|
agenda_number_prefix:
|
|
type: string
|
|
maxLength: 20
|
|
agenda_numeral_system:
|
|
type: string
|
|
enum:
|
|
- arabic
|
|
- roman
|
|
agenda_item_creation:
|
|
type: string
|
|
enum:
|
|
- always
|
|
- never
|
|
- default_yes
|
|
- default_no
|
|
agenda_new_items_default_visibility:
|
|
type: number
|
|
enum:
|
|
- 1
|
|
- 2
|
|
- 3
|
|
agenda_show_internal_items_on_projector: boolean
|
|
|
|
# List of speakers
|
|
list_of_speakers_amount_last_on_projector:
|
|
type: number
|
|
minimum: 0
|
|
list_of_speakers_amount_next_on_projector: boolean
|
|
list_of_speakers_couple_countdown: boolean
|
|
list_of_speakers_show_amount_of_speakers_on_slide: boolean
|
|
list_of_speakers_present_users_only: boolean
|
|
list_of_speakers_show_first_contribution: boolean
|
|
|
|
# Motions
|
|
motions_default_workflow_id:
|
|
type: relation
|
|
to: motion_workflow/default_workflow_meeting_id
|
|
required: true
|
|
motions_default_amendment_workflow_id:
|
|
type: relation
|
|
to: motion_workflow/default_amendment_workflow_meeting_id
|
|
required: true
|
|
motions_default_statute_amendment_workflow_id:
|
|
type: relation
|
|
to: motion_workflow/default_statute_amendment_workflow_meeting_id
|
|
required: true
|
|
motions_preamble: string
|
|
motions_default_line_numbering:
|
|
type: string
|
|
enum:
|
|
- outside
|
|
- inline
|
|
- none
|
|
motions_line_length:
|
|
type: number
|
|
minimium: 40
|
|
motions_reason_required: boolean
|
|
motions_enable_text_on_projector: boolean
|
|
motions_enable_reason_on_projector: boolean
|
|
motions_enable_sidebox_on_projector: boolean
|
|
motions_enable_recommendation_on_projector: boolean
|
|
motions_show_referring_motions: boolean
|
|
motions_show_sequential_number: boolean
|
|
motions_recommendations_by: string
|
|
motions_statute_recommendations_by: string
|
|
motions_recommendation_text_mode:
|
|
type: string
|
|
enum:
|
|
- original
|
|
- changed
|
|
- diff
|
|
- agreed
|
|
motions_default_sorting: string
|
|
motions_number_type:
|
|
type: string
|
|
enum:
|
|
- per_category
|
|
- serially_numbered
|
|
- manually
|
|
motions_number_min_digits: number
|
|
motions_number_with_blank: boolean
|
|
motions_statutes_enabled: boolean
|
|
motions_amendments_enabled: boolean
|
|
motions_amendments_in_main_list: boolean
|
|
motions_amendments_of_amendments: boolean
|
|
motions_amendments_prefix: string
|
|
motions_amendments_text_mode:
|
|
type: string
|
|
enum:
|
|
- freestyle
|
|
- fulltext
|
|
- paragraph
|
|
motions_amendments_multiple_paragraphs: boolean
|
|
motions_supporters_min_amount:
|
|
type: number
|
|
minimum: 0
|
|
motions_supporters_enable_autoremove: boolean
|
|
motions_export_title: string
|
|
motions_export_preamble: string
|
|
motions_export_submitter_recommendation: boolean
|
|
motions_export_follow_recommendation: boolean
|
|
|
|
motion_poll_ballot_paper_selection:
|
|
type: string
|
|
enum:
|
|
- NUMBER_OF_DELEGATES
|
|
- NUMBER_OF_ALL_PARTICIPANTS
|
|
- CUSTOM_NUMBER
|
|
motion_poll_ballot_paper_number: number
|
|
motion_poll_default_type: string
|
|
motion_poll_default_100_percent_base: string
|
|
motion_poll_default_majority_method: string
|
|
motion_poll_default_group_ids:
|
|
type: relation-list
|
|
to: group/used_as_motion_poll_default_id
|
|
|
|
# Users
|
|
users_sort_by:
|
|
type: string
|
|
enum:
|
|
- first_name
|
|
- last_name
|
|
- number
|
|
users_enable_presence_view: boolean
|
|
users_enable_vote_weight: boolean
|
|
users_allow_self_set_present: boolean
|
|
users_pdf_welcometitle: string
|
|
users_pdf_welcometext: string
|
|
users_pdf_url: string
|
|
users_pdf_wlan_ssid: string
|
|
users_pdf_wlan_password: string
|
|
users_pdf_wlan_encryption:
|
|
type: string
|
|
enum:
|
|
- ""
|
|
- WEP
|
|
- WPA
|
|
- nopass
|
|
users_email_sender: string
|
|
users_email_replyto: string
|
|
users_email_subject: string
|
|
users_email_body: string
|
|
|
|
# Assignments
|
|
assignemnts_export_title: string
|
|
assignments_export_preamble: string
|
|
|
|
assignment_poll_ballot_paper_selection:
|
|
type: string
|
|
enum:
|
|
- NUMBER_OF_DELEGATES
|
|
- NUMBER_OF_ALL_PARTICIPANTS
|
|
- CUSTOM_NUMBER
|
|
assignment_poll_ballot_paper_number: number
|
|
assignment_poll_add_candidates_to_list_of_speakers: boolean
|
|
assignment_poll_sort_poll_result_by_votes: boolean
|
|
assignment_poll_default_type: string
|
|
assignment_poll_default_method: string
|
|
assignment_poll_default_100_percent_base: string
|
|
assignment_poll_default_majority_method: string
|
|
assignment_poll_default_group_ids:
|
|
type: relation-list
|
|
to: group/used_as_assignment_poll_default_id
|
|
|
|
projector_ids:
|
|
type: relation-list
|
|
to: projector/meeting_id
|
|
on_delete: CASCADE
|
|
projectiondefault_ids:
|
|
type: relation-list
|
|
to: projectiondefault/meeting_id
|
|
on_delete: CASCADE
|
|
projector_message_ids:
|
|
type: relation-list
|
|
to: projector_message/meeting_id
|
|
on_delete: CASCADE
|
|
projector_countdown_ids:
|
|
type: relation-list
|
|
to: projector_countdown/meeting_id
|
|
on_delete: CASCADE
|
|
tag_ids:
|
|
type: relation-list
|
|
to: tag/meeting_id
|
|
on_delete: CASCADE
|
|
agenda_item_ids:
|
|
type: relation-list
|
|
to: agenda_item/meeting_id
|
|
on_delete: CASCADE
|
|
list_of_speakers_ids:
|
|
type: relation-list
|
|
to: list_of_speakers/meeting_id
|
|
on_delete: CASCADE
|
|
topic_ids:
|
|
type: relation-list
|
|
to: topic/meeting_id
|
|
on_delete: CASCADE
|
|
group_ids:
|
|
type: relation-list
|
|
to: group/meeting_id
|
|
on_delete: CASCADE
|
|
mediafile_ids:
|
|
type: relation-list
|
|
to: mediafile/meeting_id
|
|
on_delete: CASCADE
|
|
motion_ids:
|
|
type: relation-list
|
|
to: motion/meeting_id
|
|
on_delete: CASCADE
|
|
motion_comment_section_ids:
|
|
type: relation-list
|
|
to: motion_comment_section/meeting_id
|
|
on_delete: CASCADE
|
|
motion_category_ids:
|
|
type: relation-list
|
|
to: motion_category/meeting_id
|
|
on_delete: CASCADE
|
|
motion_block_ids:
|
|
type: relation-list
|
|
to: motion_block/meeting_id
|
|
on_delete: CASCADE
|
|
motion_workflow_ids:
|
|
type: relation-list
|
|
to: motion_workflow/meeting_id
|
|
on_delete: CASCADE
|
|
motion_statute_paragraph_ids:
|
|
type: relation-list
|
|
to: motion_statute_paragraph/meeting_id
|
|
on_delete: CASCADE
|
|
motion_poll_ids:
|
|
type: relation-list
|
|
to: motion_poll/meeting_id
|
|
on_delete: CASCADE
|
|
assignment_ids:
|
|
type: relation-list
|
|
to: assignment/meeting_id
|
|
on_delete: CASCADE
|
|
assignment_poll_ids:
|
|
type: relation-list
|
|
to: assignment_poll/meeting_id
|
|
on_delete: CASCADE
|
|
personal_note_ids:
|
|
type: relation-list
|
|
to: personal_note/meeting_id
|
|
on_delete: CASCADE
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/meeting_id
|
|
on_delete: CASCADE
|
|
speaker_ids:
|
|
type: relation-list
|
|
to: speaker/meeting_id
|
|
on_delete: CASCADE
|
|
motion_option_ids:
|
|
type: relation-list
|
|
to: motion_option/meeting_id
|
|
on_delete: CASCADE
|
|
motion_vote_ids:
|
|
type: relation-list
|
|
to: motion_vote/meeting_id
|
|
on_delete: CASCADE
|
|
motion_comment_ids:
|
|
type: relation-list
|
|
to: motion_comment/meeting_id
|
|
on_delete: CASCADE
|
|
motion_submitter_ids:
|
|
type: relation-list
|
|
to: motion_submitter/meeting_id
|
|
on_delete: CASCADE
|
|
motion_change_recommendation_ids:
|
|
type: relation-list
|
|
to: motion_change_recommendation/meeting_id
|
|
on_delete: CASCADE
|
|
motion_state_ids:
|
|
type: relation-list
|
|
to: motion_state/meeting_id
|
|
on_delete: CASCADE
|
|
assignment_candidate_ids:
|
|
type: relation-list
|
|
to: assignment_candidate/meeting_id
|
|
on_delete: CASCADE
|
|
assignment_option_ids:
|
|
type: relation-list
|
|
to: assignment_option/meeting_id
|
|
on_delete: CASCADE
|
|
assignment_vote_ids:
|
|
type: relation-list
|
|
to: assignment_vote/meeting_id
|
|
on_delete: CASCADE
|
|
|
|
# Logos and Fonts
|
|
logo_$_id:
|
|
type: template
|
|
replacement: location
|
|
fields:
|
|
type: relation
|
|
to:
|
|
collection: mediafile
|
|
field:
|
|
name: used_as_logo_$_in_meeting_id
|
|
type: structured-tag
|
|
replacement: location
|
|
font_$_id:
|
|
type: template
|
|
replacement: location
|
|
fields:
|
|
type: relation
|
|
to:
|
|
collection: mediafile
|
|
field:
|
|
name: used_as_font_$_in_meeting_id
|
|
type: structured-tag
|
|
replacement: location
|
|
# Examples:
|
|
# logo_web_header: Mediafile;
|
|
# font_italic_pdf: Mediafile;
|
|
# The client can define these resources. There is no need
|
|
# to have whitelist/blacklist on the server. The places must
|
|
# be checked: They must match `[a-z]([a-z_]*[a-z])?` and must
|
|
# not be longer than 32 characters.
|
|
|
|
# Other relations
|
|
committee_id:
|
|
type: relation
|
|
to: committee/meeting_ids
|
|
required: true
|
|
default_meeting_for_committee_id:
|
|
type: relation
|
|
to: committee/default_meeting_id
|
|
present_user_ids:
|
|
type: relation-list
|
|
to: user/is_present_in_meeting_ids
|
|
temporary_user_ids:
|
|
type: relation-list
|
|
to: user/meeting_id
|
|
guest_ids:
|
|
type: relation-list
|
|
to: user/guest_meeting_ids
|
|
user_ids:
|
|
type: number[]
|
|
decription: Calculated. All ids from temporary_user_ids, guest_ids and all users assigned to groups.
|
|
read_only: true
|
|
reference_projector_id:
|
|
type: relation
|
|
to: projector/used_as_reference_projector_meeting_id
|
|
|
|
default_group_id:
|
|
type: relation
|
|
to: group/default_group_for_meeting_id
|
|
required: true
|
|
superadmin_group_id:
|
|
type: relation
|
|
to: group/superadmin_group_for_meeting_id
|
|
|
|
group:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
permissions: string[]
|
|
|
|
user_ids:
|
|
type: relation-list
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: group_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
default_group_for_meeting_id:
|
|
type: relation
|
|
to: meeting/default_group_id
|
|
superadmin_group_for_meeting_id:
|
|
type: relation
|
|
to: meeting/superadmin_group_id
|
|
mediafile_access_group_ids:
|
|
type: relation-list
|
|
to: mediafile/access_group_ids
|
|
equal_fields: meeting_id
|
|
mediafile_inherited_access_group_ids:
|
|
type: relation-list
|
|
to: mediafile/inherited_access_group_ids
|
|
description: Calculated field.
|
|
read_only: true
|
|
read_comment_section_ids:
|
|
type: relation-list
|
|
to: motion_comment_section/read_group_ids
|
|
equal_fields: meeting_id
|
|
write_comment_section_ids:
|
|
type: relation-list
|
|
to: motion_comment_section/write_group_ids
|
|
equal_fields: meeting_id
|
|
motion_poll_ids:
|
|
type: relation-list
|
|
to: motion_poll/entitled_group_ids
|
|
equal_fields: meeting_id
|
|
assignment_poll_ids:
|
|
type: relation-list
|
|
to: assignment_poll/entitled_group_ids
|
|
equal_fields: meeting_id
|
|
used_as_motion_poll_default_id:
|
|
type: relation
|
|
to: meeting/motion_poll_default_group_ids
|
|
used_as_assignment_poll_default_id:
|
|
type: relation
|
|
to: meeting/assignment_poll_default_group_ids
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/group_ids
|
|
required: true
|
|
|
|
personal_note:
|
|
id: number
|
|
note: HTMLStrict
|
|
star: boolean
|
|
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: personal_note_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
content_object_id:
|
|
type: generic-relation
|
|
to:
|
|
collection:
|
|
- motion
|
|
field: personal_note_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/personal_note_ids
|
|
required: true
|
|
|
|
tag:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
|
|
tagged_ids:
|
|
type: generic-relation-list
|
|
to:
|
|
collection:
|
|
- agenda_item
|
|
- assignment
|
|
- motion
|
|
- topic
|
|
field: tag_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/tag_ids
|
|
required: true
|
|
|
|
agenda_item:
|
|
id: number
|
|
item_number: string
|
|
comment: string
|
|
closed: boolean
|
|
type:
|
|
type: number
|
|
enum:
|
|
- 1
|
|
- 2
|
|
- 3
|
|
default: 1
|
|
duration:
|
|
type: number
|
|
description: Given in seconds
|
|
minimum: 0
|
|
is_internal:
|
|
type: boolean
|
|
description: Calculated by the server
|
|
read_only: true
|
|
is_hidden:
|
|
type: boolean
|
|
description: Calculated by the server
|
|
read_only: true
|
|
level:
|
|
type: number
|
|
description: Calculated by the server
|
|
read_only: true
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
|
|
content_object_id:
|
|
type: generic-relation
|
|
to:
|
|
collection:
|
|
- motion
|
|
- motion_block
|
|
- assignment
|
|
- topic
|
|
field: agenda_item_id
|
|
required: true
|
|
equal_fields: meeting_id
|
|
parent_id:
|
|
type: relation
|
|
to: agenda_item/child_ids
|
|
equal_fields: meeting_id
|
|
child_ids:
|
|
type: relation-list
|
|
to: agenda_item/parent_id
|
|
equal_fields: meeting_id
|
|
tag_ids:
|
|
type: relation-list
|
|
to: tag/tagged_ids
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/agenda_item_ids
|
|
required: true
|
|
|
|
list_of_speakers:
|
|
id: number
|
|
closed: boolean
|
|
|
|
content_object_id:
|
|
type: generic-relation
|
|
to:
|
|
collection:
|
|
- motion
|
|
- motion_block
|
|
- assignment
|
|
- topic
|
|
- mediafile
|
|
field: list_of_speakers_id
|
|
required: true
|
|
equal_fields: meeting_id
|
|
speaker_ids:
|
|
type: relation-list
|
|
to: speaker/list_of_speakers_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/list_of_speakers_ids
|
|
required: true
|
|
|
|
speaker:
|
|
id: number
|
|
begin_time:
|
|
type: timestamp
|
|
read_only: true
|
|
end_time:
|
|
type: timestamp
|
|
read_only: true
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
marked: boolean
|
|
|
|
list_of_speakers_id:
|
|
type: relation
|
|
to: list_of_speakers/speaker_ids
|
|
required: true
|
|
equal_fields: meeting_id
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: speaker_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
required: true
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/speaker_ids
|
|
required: true
|
|
|
|
topic:
|
|
id: number
|
|
title:
|
|
type: string
|
|
required: true
|
|
text: HTMLPermissive
|
|
|
|
attachment_ids:
|
|
type: relation-list
|
|
to: mediafile/attachment_ids
|
|
equal_fields: meeting_id
|
|
agenda_item_id:
|
|
type: relation
|
|
to: agenda_item/content_object_id
|
|
required: true
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
list_of_speakers_id:
|
|
type: relation
|
|
to: list_of_speakers/content_object_id
|
|
required: true
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
tag_ids:
|
|
type: relation-list
|
|
to: tag/tagged_ids
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/topic_ids
|
|
required: true
|
|
|
|
motion:
|
|
id: number
|
|
number: string
|
|
sequential_number:
|
|
type: number
|
|
description: The (positive) serial number of this motion. This number is auto-generated and read-only.
|
|
read_only: true
|
|
title:
|
|
type: string
|
|
required: true
|
|
text: HTMLStrict
|
|
amendment_paragraph_$:
|
|
type: template
|
|
replacement: paragraph_number
|
|
fields: HTMLStrict
|
|
modified_final_version: HTMLStrict
|
|
reason: HTMLStrict
|
|
category_weight:
|
|
type: number
|
|
default: 10000
|
|
state_extension: string
|
|
recommendation_extension: string
|
|
sort_weight:
|
|
type: number
|
|
default: 10000
|
|
created:
|
|
type: timestamp
|
|
read_only: true
|
|
last_modified:
|
|
type: timestamp
|
|
read_only: true
|
|
|
|
lead_motion_id:
|
|
type: relation
|
|
to: motion/amendment_ids
|
|
equal_fields: meeting_id
|
|
amendment_ids:
|
|
type: relation-list
|
|
to: motion/lead_motion_id
|
|
equal_fields: meeting_id
|
|
sort_parent_id:
|
|
type: relation
|
|
to: motion/sort_child_ids
|
|
equal_fields: meeting_id
|
|
sort_child_ids:
|
|
type: relation-list
|
|
to: motion/sort_parent_id
|
|
equal_fields: meeting_id
|
|
origin_id:
|
|
type: relation
|
|
to: motion/derived_motion_ids # Note: The related motions may not be in the same meeting
|
|
derived_motion_ids:
|
|
type: relation-list
|
|
to: motion/origin_id # Note: The related motions may not be in the same meeting
|
|
forwarding_tree_motion_ids: number[] # Calculated: All children (derived_motion_ids), grand children, ... and all parents (origin_id).
|
|
state_id:
|
|
type: relation
|
|
to: motion_state/motion_ids
|
|
required: true
|
|
equal_fields: meeting_id
|
|
recommendation_id:
|
|
type: relation
|
|
to: motion_state/motion_recommendation_ids
|
|
equal_fields: meeting_id
|
|
recommendation_extension_reference_ids:
|
|
type: generic-relation-list
|
|
to:
|
|
collection:
|
|
- motion
|
|
field: referenced_in_motion_recommendation_extension_ids
|
|
equal_fields: meeting_id
|
|
referenced_in_motion_recommendation_extension_ids:
|
|
type: relation-list
|
|
to: motion/recommendation_extension_reference_ids
|
|
equal_fields: meeting_id
|
|
category_id:
|
|
type: relation
|
|
to: motion_category/motion_ids
|
|
equal_fields: meeting_id
|
|
block_id:
|
|
type: relation
|
|
to: motion_block/motion_ids
|
|
equal_fields: meeting_id
|
|
submitter_ids:
|
|
type: relation-list
|
|
to: motion_submitter/motion_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
supporter_ids:
|
|
type: relation-list
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: supported_motion_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
equal_fields: meeting_id
|
|
poll_ids:
|
|
type: relation-list
|
|
to: motion_poll/motion_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
change_recommendation_ids:
|
|
type: relation-list
|
|
to: motion_change_recommendation/motion_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
statute_paragraph_id:
|
|
type: relation
|
|
to: motion_statute_paragraph/motion_ids
|
|
equal_fields: meeting_id
|
|
comment_ids:
|
|
type: relation-list
|
|
to: motion_comment/motion_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
agenda_item_id:
|
|
type: relation
|
|
to: agenda_item/content_object_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
list_of_speakers_id:
|
|
type: relation
|
|
to: list_of_speakers/content_object_id
|
|
required: true
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
tag_ids:
|
|
type: relation-list
|
|
to: tag/tagged_ids
|
|
equal_fields: meeting_id
|
|
attachment_ids:
|
|
type: relation-list
|
|
to: mediafile/attachment_ids
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
personal_note_ids:
|
|
type: relation-list
|
|
to: personal_note/content_object_id
|
|
equal_fields: meeting_id
|
|
on_delete: CASCADE
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_ids
|
|
required: true
|
|
|
|
motion_submitter:
|
|
id: number
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: submitted_motion_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
motion_id:
|
|
type: relation
|
|
to: motion/submitter_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_submitter_ids
|
|
required: true
|
|
|
|
motion_comment:
|
|
id: number
|
|
comment: HTMLStrict
|
|
|
|
motion_id:
|
|
type: relation
|
|
to: motion/comment_ids
|
|
required: true
|
|
equal_fields: meeting_id
|
|
section_id:
|
|
type: relation
|
|
to: motion_comment_section/comment_ids
|
|
required: true
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_comment_ids
|
|
required: true
|
|
|
|
motion_comment_section:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
|
|
comment_ids:
|
|
type: relation-list
|
|
to: motion_comment/section_id
|
|
on_delete: PROTECT
|
|
equal_fields: meeting_id
|
|
read_group_ids:
|
|
type: relation-list
|
|
to: group/read_comment_section_ids
|
|
equal_fields: meeting_id
|
|
write_group_ids:
|
|
type: relation-list
|
|
to: group/write_comment_section_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_comment_section_ids
|
|
required: true
|
|
|
|
motion_category:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
prefix:
|
|
type: string
|
|
required: true
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
level:
|
|
type: number
|
|
description: Calculated field.
|
|
read_only: true
|
|
|
|
parent_id:
|
|
type: relation
|
|
to: motion_category/child_ids
|
|
equal_fields: meeting_id
|
|
child_ids:
|
|
type: relation-list
|
|
to: motion_category/parent_id
|
|
equal_fields: meeting_id
|
|
motion_ids:
|
|
type: relation-list
|
|
to: motion/category_id
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_category_ids
|
|
required: true
|
|
|
|
motion_block:
|
|
id: number
|
|
title:
|
|
type: string
|
|
required: true
|
|
internal: boolean
|
|
|
|
motion_ids:
|
|
type: relation-list
|
|
to: motion/block_id
|
|
equal_fields: meeting_id
|
|
agenda_item_id:
|
|
type: relation
|
|
to: agenda_item/content_object_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
list_of_speakers_id:
|
|
type: relation
|
|
to: list_of_speakers/content_object_id
|
|
required: true
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_block_ids
|
|
required: true
|
|
|
|
motion_change_recommendation:
|
|
id: number
|
|
rejected: boolean
|
|
internal: boolean
|
|
type:
|
|
type: number
|
|
enum:
|
|
- 0
|
|
- 1
|
|
- 2
|
|
- 3
|
|
default: 0
|
|
other_description: string
|
|
line_from:
|
|
type: number
|
|
minimum: 0
|
|
line_to:
|
|
type: number
|
|
minimum: 0
|
|
text: HTMLStrict
|
|
creation_time:
|
|
type: timestamp
|
|
read_only: true
|
|
|
|
motion_id:
|
|
type: relation
|
|
to: motion/change_recommendation_ids
|
|
required: true
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_change_recommendation_ids
|
|
required: true
|
|
|
|
motion_state:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
recommendation_label: string
|
|
css_class:
|
|
type: string
|
|
enum:
|
|
- grey
|
|
- red
|
|
- green
|
|
- lightblue
|
|
- yellow
|
|
restrictions:
|
|
type: string[]
|
|
items:
|
|
enum:
|
|
- motions.can_see_internal
|
|
- motions.can_manage_metadata
|
|
- motions.can_manage
|
|
- is_submitter
|
|
allow_support: boolean
|
|
allow_create_poll: boolean
|
|
allow_submitter_edit: boolean
|
|
set_number: boolean
|
|
show_state_extension_field: boolean
|
|
merge_amendment_into_final:
|
|
type: number
|
|
default: 0
|
|
enum:
|
|
- -1
|
|
- 0
|
|
- 1
|
|
show_recommendation_extension_field: boolean
|
|
|
|
next_state_ids:
|
|
type: relation-list
|
|
to: motion_state/previous_state_ids
|
|
equal_fields:
|
|
- meeting_id
|
|
- workflow_id
|
|
previous_state_ids:
|
|
type: relation-list
|
|
to: motion_state/next_state_ids
|
|
equal_fields:
|
|
- meeting_id
|
|
- workflow_id
|
|
motion_ids:
|
|
type: relation-list
|
|
to: motion/state_id
|
|
on_delete: PROTECT
|
|
equal_fields: meeting_id
|
|
motion_recommendation_ids:
|
|
type: relation-list
|
|
to: motion/recommendation_id
|
|
equal_fields: meeting_id
|
|
workflow_id:
|
|
type: relation
|
|
to: motion_workflow/state_ids
|
|
required: true
|
|
equal_fields: meeting_id
|
|
first_state_of_workflow_id:
|
|
type: relation
|
|
to: motion_workflow/first_state_id
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_state_ids
|
|
required: true
|
|
|
|
motion_workflow:
|
|
id: number
|
|
name:
|
|
type: string
|
|
required: true
|
|
|
|
state_ids:
|
|
type: relation-list
|
|
to: motion_state/workflow_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
first_state_id:
|
|
type: relation
|
|
to: motion_state/first_state_of_workflow_id
|
|
required: true
|
|
equal_fields: meeting_id
|
|
default_workflow_meeting_id:
|
|
type: relation
|
|
to: meeting/motions_default_workflow_id
|
|
default_amendment_workflow_meeting_id:
|
|
type: relation
|
|
to: meeting/motions_default_amendment_workflow_id
|
|
default_statute_amendment_workflow_meeting_id:
|
|
type: relation
|
|
to: meeting/motions_default_statute_amendment_workflow_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_workflow_ids
|
|
required: true
|
|
|
|
motion_statute_paragraph:
|
|
id: number
|
|
title:
|
|
type: string
|
|
required: true
|
|
text: HTMLStrict
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
|
|
motion_ids:
|
|
type: relation-list
|
|
to: motion/statute_paragraph_id
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_statute_paragraph_ids
|
|
required: true
|
|
|
|
motion_poll:
|
|
id: number
|
|
pollmethod: string
|
|
state: number
|
|
type: string
|
|
title: string
|
|
onehundred_percent_base: string
|
|
majority_method: string
|
|
votesvalid: decimal(6)
|
|
votesinvalid: decimal(6)
|
|
votescast: decimal(6)
|
|
user_has_voted: boolean # This is user specific and set during restriction
|
|
|
|
motion_id:
|
|
type: relation
|
|
to: motion/poll_ids
|
|
equal_fields: meeting_id
|
|
option_ids:
|
|
type: relation-list
|
|
to: motion_option/poll_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
voted_ids:
|
|
type: relation-list
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: motion_poll_voted_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
entitled_group_ids:
|
|
type: relation-list
|
|
to: group/motion_poll_ids
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_poll_ids
|
|
|
|
motion_option:
|
|
id: number
|
|
yes: decimal(6)
|
|
no: decimal(6)
|
|
abstain: decimal(6)
|
|
|
|
poll_id:
|
|
type: relation
|
|
to: motion_poll/option_ids
|
|
equal_fields: meeting_id
|
|
vote_ids:
|
|
type: relation-list
|
|
to: motion_vote/option_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_option_ids
|
|
required: true
|
|
|
|
motion_vote:
|
|
id: number
|
|
weight: decimal(6)
|
|
value: string
|
|
|
|
option_id:
|
|
type: relation
|
|
to: motion_option/vote_ids
|
|
equal_fields: meeting_id
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: motion_vote_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
delegated_user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: motion_delegated_vote_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/motion_vote_ids
|
|
required: true
|
|
|
|
assignment:
|
|
id: number
|
|
title:
|
|
type: string
|
|
required: true
|
|
description: HTMLStrict
|
|
open_posts:
|
|
type: number
|
|
minimum: 0
|
|
default: 0
|
|
phase:
|
|
type: number
|
|
enum:
|
|
- 0
|
|
- 1
|
|
- 2
|
|
default: 0
|
|
default_poll_description: string
|
|
number_poll_candidates: boolean
|
|
|
|
candidate_ids:
|
|
type: relation-list
|
|
to: assignment_candidate/assignment_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
poll_ids:
|
|
type: relation-list
|
|
to: assignment_poll/assignment_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
agenda_item_id:
|
|
type: relation
|
|
to: agenda_item/content_object_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
list_of_speakers_id:
|
|
type: relation
|
|
to: list_of_speakers/content_object_id
|
|
required: true
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
tag_ids:
|
|
type: relation-list
|
|
to: tag/tagged_ids
|
|
equal_fields: meeting_id
|
|
attachment_ids:
|
|
type: relation-list
|
|
to: mediafile/attachment_ids
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/assignment_ids
|
|
required: true
|
|
|
|
assignment_candidate:
|
|
id: number
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
|
|
assignment_id:
|
|
type: relation
|
|
to: assignment/candidate_ids
|
|
equal_fields: meeting_id
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: assignment_candidate_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/assignment_candidate_ids
|
|
required: true
|
|
|
|
assignment_poll:
|
|
id: number
|
|
description: string
|
|
pollmethod: string
|
|
votes_amount: number
|
|
allow_multiple_votes_per_candidate: boolean
|
|
global_abstain: boolean
|
|
global_no: boolean
|
|
amount_global_abstain: decimal(6)
|
|
amount_global_no: decimal(6)
|
|
state: number
|
|
title: string
|
|
type: string
|
|
onehundred_percent_base: string
|
|
majority_method: string
|
|
votescast: decimal(6)
|
|
votesinvalid: decimal(6)
|
|
votesvalid: decimal(6)
|
|
user_has_voted: boolean # This is user specific and set during restriction
|
|
|
|
assignment_id:
|
|
type: relation
|
|
to: assignment/poll_ids
|
|
equal_fields: meeting_id
|
|
voted_ids:
|
|
type: relation-list
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: assignment_poll_voted_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
entitled_group_ids:
|
|
type: relation-list
|
|
to: group/assignment_poll_ids
|
|
equal_fields: meeting_id
|
|
option_ids:
|
|
type: relation-list
|
|
to: assignment_option/poll_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/assignment_poll_ids
|
|
|
|
assignment_option:
|
|
id: number
|
|
yes: decimal(6)
|
|
no: decimal(6)
|
|
abstain: decimal(6)
|
|
weight:
|
|
type: number
|
|
default: 10000
|
|
|
|
poll_id:
|
|
type: relation
|
|
to: assignment_poll/option_ids
|
|
equal_fields: meeting_id
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: assignment_option_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
vote_ids:
|
|
type: relation-list
|
|
to: assignment_vote/option_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/assignment_option_ids
|
|
required: true
|
|
|
|
assignment_vote:
|
|
id: number
|
|
value: string
|
|
weight: decimal(6)
|
|
|
|
option_id:
|
|
type: relation
|
|
to: assignment_option/vote_ids
|
|
equal_fields: meeting_id
|
|
user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: assignment_vote_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
delegated_user_id:
|
|
type: relation
|
|
to:
|
|
collection: user
|
|
field:
|
|
name: assignment_delegated_vote_$_ids
|
|
type: structured-relation
|
|
replacement: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/assignment_vote_ids
|
|
required: true
|
|
|
|
# Mediafiles are delivered by the mediafile server with the URL
|
|
# `<media-prefix>/media/<meeting_id>/path`
|
|
mediafile:
|
|
id: number
|
|
title:
|
|
type: string
|
|
description: Title and parent_id must be unique.
|
|
is_directory: boolean
|
|
filesize:
|
|
type: number
|
|
description: In bytes, not the human readable format anymore.
|
|
read_only: true
|
|
filename:
|
|
type: string
|
|
descriptin: The uploaded filename. Will be used for downloading. Only writeable on create.
|
|
required: true
|
|
mimetype: string
|
|
pdf_information: JSON
|
|
create_timestamp: timestamp
|
|
has_inherited_access_groups:
|
|
type: boolean
|
|
description: Calculated field.
|
|
read_only: true
|
|
|
|
inherited_access_group_ids:
|
|
type: relation-list
|
|
to: group/mediafile_inherited_access_group_ids
|
|
description: Calculated field.
|
|
read_only: true
|
|
access_group_ids:
|
|
type: relation-list
|
|
to: group/mediafile_access_group_ids
|
|
equal_fields: meeting_id
|
|
parent_id:
|
|
type: relation
|
|
to: mediafile/child_ids
|
|
equal_fields: meeting_id
|
|
child_ids:
|
|
type: relation-list
|
|
to: mediafile/parent_id
|
|
equal_fields: meeting_id
|
|
list_of_speakers_id:
|
|
type: relation
|
|
to: list_of_speakers/content_object_id
|
|
required: true
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
attachment_ids:
|
|
type: generic-relation-list
|
|
to:
|
|
collection:
|
|
- motion
|
|
- topic
|
|
- assignment
|
|
field: attachment_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/mediafile_ids
|
|
required: true
|
|
|
|
# Reverse relations for meetings, if a mediafile is used as a special resource
|
|
used_as_logo_$_in_meeting_id:
|
|
type: template
|
|
replacement: location
|
|
fields:
|
|
type: relation
|
|
to:
|
|
collection: meeting
|
|
field:
|
|
name: logo_$_id
|
|
type: structured-tag
|
|
replacement: location
|
|
used_as_font_$_in_meeting_id:
|
|
type: template
|
|
replacement: location
|
|
fields:
|
|
type: relation
|
|
to:
|
|
collection: meeting
|
|
field:
|
|
name: font_$_id
|
|
type: structured-tag
|
|
replacement: location
|
|
|
|
projector:
|
|
id: number
|
|
name: string
|
|
scale: number
|
|
scroll: number
|
|
width: number
|
|
aspect_ratio_numerator: number
|
|
aspect_ratio_denominator: number
|
|
color: string
|
|
background_color: string
|
|
header_background_color: string
|
|
header_font_color: string
|
|
header_h1_color: string
|
|
chyron_background_color: string
|
|
chyron_font_color: string
|
|
show_header_footer: boolean
|
|
show_title: boolean
|
|
show_logo: boolean
|
|
|
|
current_projection_ids:
|
|
type: relation-list
|
|
to: projection/current_projector_id
|
|
on_delete: CASCADE
|
|
equal_fields: meeting_id
|
|
# A relation to the currently projected elements to get a direct link, if
|
|
# the element is projected.
|
|
current_element_ids:
|
|
type: generic-relation-list
|
|
to:
|
|
collection:
|
|
- motion
|
|
- mediafile
|
|
- list_of_speakers
|
|
- motion_block
|
|
- assignment
|
|
- agenda_item
|
|
- topic
|
|
- user
|
|
- assignment_poll
|
|
- motion_poll
|
|
- projector_message
|
|
- projector_countdown
|
|
field: current_projector_ids
|
|
equal_fields: meeting_id
|
|
preview_projection_ids:
|
|
type: relation-list
|
|
to: projection/preview_projector_id
|
|
equal_fields: meeting_id
|
|
history_projection_ids:
|
|
type: relation-list
|
|
to: projection/history_projector_id
|
|
equal_fields: meeting_id
|
|
used_as_reference_projector_meeting_id:
|
|
type: relation
|
|
to: meeting/reference_projector_id
|
|
projectiondefault_ids:
|
|
type: relation-list
|
|
to: projectiondefault/projector_id
|
|
on_delete: PROTECT
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/projector_ids
|
|
|
|
# A projection is a M2M model between an element that is assigned to a
|
|
# projector. This element can either be the current one projected, in the
|
|
# preview, or in the history, but not more than one once. A projection is
|
|
# projector-specific, meaning that once a projection is created for a projector
|
|
# and element, these references will not change.
|
|
projection:
|
|
id: number
|
|
options: JSON
|
|
|
|
current_projector_id:
|
|
type: relation
|
|
to: projector/current_projection_ids
|
|
equal_fields: meeting_id
|
|
preview_projector_id:
|
|
type: relation
|
|
to: projector/preview_projection_ids
|
|
equal_fields: meeting_id
|
|
history_projector_id:
|
|
type: relation
|
|
to: projector/history_projection_ids
|
|
equal_fields: meeting_id
|
|
element_id:
|
|
type: generic-relation
|
|
to:
|
|
collection:
|
|
- motion
|
|
- mediafile
|
|
- list_of_speakers
|
|
- motion_block
|
|
- assignment
|
|
- agenda_item
|
|
- topic
|
|
- user
|
|
- assignment_poll
|
|
- motion_poll
|
|
- projector_message
|
|
- projector_countdown
|
|
field: projection_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/projection_ids
|
|
required: true
|
|
|
|
projectiondefault:
|
|
id: number
|
|
name: string
|
|
display_name: string
|
|
|
|
projector_id:
|
|
type: relation
|
|
to: projector/projectiondefault_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/projectiondefault_ids
|
|
|
|
projector_message:
|
|
id: number
|
|
message: HTMLStrict
|
|
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/projector_message_ids
|
|
|
|
projector_countdown:
|
|
id: number
|
|
title: string
|
|
description: string
|
|
default_time: number
|
|
countdown_time: number # float?
|
|
running: boolean
|
|
|
|
projection_ids:
|
|
type: relation-list
|
|
to: projection/element_id
|
|
equal_fields: meeting_id
|
|
current_projector_ids:
|
|
type: relation-list
|
|
to: projector/current_element_ids
|
|
equal_fields: meeting_id
|
|
meeting_id:
|
|
type: relation
|
|
to: meeting/projector_countdown_ids
|