Files
computer-playbook/roles/web-app-bigbluebutton/config/main.yml
Kevin Veen-Birkenbach 57d5269b07 CSP (Safari-safe): merge -elem/-attr into base; respect explicit disables; no mirror-back; header only for documents/workers
- Add CSP3 support for style/script: include -elem and -attr directives
- Base (style-src, script-src) now unions elem/attr (CSP2/Safari fallback)
- Respect explicit base disables (e.g. style-src.unsafe-inline: false)
- Hashes only when 'unsafe-inline' absent in the final base tokens
- Nginx: set CSP only for HTML/worker via header_filter_by_lua_block; drop for subresources
- Remove per-location header_filter; keep body_filter only
- Update app role flags to *-attr where appropriate; extend desktop CSS sources
- Add comprehensive unit tests for union/explicit-disable/no-mirror-back

Ref: https://chatgpt.com/share/68f87a0a-cebc-800f-bb3e-8c8ab4dee8ee
2025-10-22 13:53:06 +02:00

42 lines
1.3 KiB
YAML

api_suffix: "/bigbluebutton/"
features:
matomo: true
css: true
desktop: false # Videos can't open in frame due to iframe restrictions
ldap: false
oidc: true
central_database: false # Propably required for backup routines
logout: true
server:
ip6_enabled: false
csp:
flags:
script-src-elem:
unsafe-inline: true
style-src-attr:
unsafe-inline: true
domains:
canonical:
- "meet.{{ PRIMARY_DOMAIN }}"
aliases: []
credentials: {}
docker:
services:
bigbluebutton:
repository: "https://github.com/kevinveenbirkenbach/bigbluebutton-docker.git"
version: "bbb3.0"
recording:
enabled: false # Enable recordings of sessions (deactivated by default because it crashed, also check GDPR comnpliance)
cleanup: true # Auto-Cleanup Recordings
max_age_days: 30 # Cleanup recording after this amount of days
database:
# This is set to true to pass integration test, doesn't have any other function
enabled: true
greenlight:
enabled: true
coturn:
internal: false
collabora:
internal: false