Compare commits
2 commits
| Author | SHA1 | Date | |
|---|---|---|---|
| bc8def927d | |||
| f478e1c114 |
3 changed files with 125 additions and 55 deletions
29
.forgejo/workflows/cleanup.yaml
Normal file
29
.forgejo/workflows/cleanup.yaml
Normal file
|
|
@ -0,0 +1,29 @@
|
|||
on:
|
||||
pull_request:
|
||||
types:
|
||||
- closed
|
||||
|
||||
env:
|
||||
TZ: Europe/Berlin
|
||||
DEPLOY_TARGET_BASE: c3vocdocs-website-deploy@public-web-static-intern.hamburg.ccc.de
|
||||
STAGING_BASE_PATH: https://staging.docs.c3voc.de/av
|
||||
STAGING_DEPLOY_PATH: /var/www/staging.docs.c3voc.de/av/
|
||||
|
||||
jobs:
|
||||
cleanup-staging:
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: code.forgejo.org/oci/node:22-bookworm
|
||||
steps:
|
||||
- name: Pipeline info PR
|
||||
run: |
|
||||
echo "Run triggered by ${{ github.event_name }} (${{ github.event.action }}) on ref ${{ github.ref_name }}"
|
||||
|
||||
- name: Staging Deployment - Prepare keys
|
||||
run: |
|
||||
echo "${{ secrets.SSH_DEPLOY_KEY }}" > deploykey.priv
|
||||
chmod 400 deploykey.priv
|
||||
echo "${{ secrets.SSH_KNOWN_HOSTS_FILE }}" > ./known_hosts
|
||||
- name: Staging Deployment - Remove PR from staging
|
||||
run: |
|
||||
ssh -i deploykey.priv -o 'UserKnownHostsFile ./known_hosts' ${{ env.DEPLOY_TARGET_BASE }} -t "rm -r ${{ env.STAGING_DEPLOY_PATH }}/pr${{ github.event.pull_request.number }}/"
|
||||
80
.forgejo/workflows/deploy.yaml
Normal file
80
.forgejo/workflows/deploy.yaml
Normal file
|
|
@ -0,0 +1,80 @@
|
|||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
pull_request:
|
||||
|
||||
env:
|
||||
TZ: Europe/Berlin
|
||||
DEPLOY_TARGET_BASE: c3vocdocs-website-deploy@public-web-static-intern.hamburg.ccc.de
|
||||
PROD_BASE_PATH: https://docs.c3voc.de/av
|
||||
PROD_DEPLOY_PATH: /var/www/docs.c3voc.de/av/
|
||||
STAGING_BASE_PATH: https://staging.docs.c3voc.de/av
|
||||
STAGING_DEPLOY_PATH: /var/www/staging.docs.c3voc.de/av/
|
||||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: python:3.13-trixie
|
||||
steps:
|
||||
- name: Pipeline info
|
||||
run: |
|
||||
echo "Run triggered by ${{ github.event_name }} (${{ github.event.action }}) on ref ${{ github.ref_name }}"
|
||||
|
||||
- name: Bootstrap CI Tools
|
||||
run: |
|
||||
apt update
|
||||
apt -y install nodejs git rsync openssh-client
|
||||
pip install --upgrade pip
|
||||
|
||||
- uses: actions/checkout@v6
|
||||
with:
|
||||
fetch-depth: 0 # pull full history for page lastmod by git commit date
|
||||
|
||||
- name: Install Python packages
|
||||
run: |
|
||||
pip install -r requirements.txt
|
||||
|
||||
- name: Build website - prod
|
||||
run: |
|
||||
mkdocs build
|
||||
|
||||
- name: Build website - staging
|
||||
if: github.ref_name != 'main'
|
||||
run: |
|
||||
sed -i "s#site_url: ${{ env.PROD_BASE_PATH }}/'#site_url: ${{ env.STAGING_BASE_PATH }}/pr${{ github.event.pull_request.number }}/#" mkdocs.yml
|
||||
mkdocs build
|
||||
|
||||
- name: Deploy - Prepare keys
|
||||
if: github.event_name == 'push' || github.event_name == 'pull_request' || github.event_name == 'schedule'
|
||||
run: |
|
||||
echo "${{ secrets.SSH_DEPLOY_KEY }}" > deploykey.priv
|
||||
chmod 400 deploykey.priv
|
||||
echo "${{ secrets.SSH_KNOWN_HOSTS_FILE }}" > ./known_hosts
|
||||
|
||||
- name: Deploy - Upload PR to staging
|
||||
if: github.event_name == 'pull_request'
|
||||
run: |
|
||||
echo "Deploying to ${{ env.STAGING_BASE_PATH }}/pr${{ github.event.pull_request.number }}"
|
||||
rsync -v -r --delete -e "ssh -i deploykey.priv -o 'UserKnownHostsFile ./known_hosts'" site/ ${{ env.DEPLOY_TARGET_BASE }}:${{ env.STAGING_DEPLOY_PATH }}/pr${{ github.event.pull_request.number }}/
|
||||
- name: Deploy - Add comment to PR with staging URL
|
||||
if: github.event_name == 'pull_request' && github.event.action == 'opened'
|
||||
run: |
|
||||
curl \
|
||||
-X POST \
|
||||
${{ github.event.pull_request.base.repo.url }}/issues/${{ github.event.pull_request.number }}/comments \
|
||||
-H "Content-Type: application/json" \
|
||||
-H "Authorization: token $GITHUB_TOKEN" \
|
||||
--data '{ "body": "You can view your changes at ${{ env.STAGING_BASE_PATH }}/pr${{ github.event.pull_request.number }}/" }'
|
||||
|
||||
- name: Deploy - Upload to prod
|
||||
if: (github.event_name == 'push' || github.event_name == 'schedule') && github.ref_name == 'main'
|
||||
run: |
|
||||
rsync -v -r --delete -e "ssh -i deploykey.priv -o 'UserKnownHostsFile ./known_hosts'" site/ ${{ env.DEPLOY_TARGET_BASE }}:${{ env.PROD_DEPLOY_PATH }}
|
||||
|
||||
- uses: actions/upload-artifact@v3
|
||||
if: github.event_name == 'pull_request'
|
||||
with:
|
||||
name: website-build
|
||||
path: public/
|
||||
|
|
@ -2,69 +2,30 @@
|
|||
title: Cabling
|
||||
---
|
||||
|
||||
Please also see the [Buildup Plan](buildup.md) for detailed instructions and what to consider when setting up a lecture room.
|
||||
|
||||
The 2 main components of the lecture hall setup are the lectern module on the stage and the FOH module and camera at some "front of house" location.
|
||||
They are connected by: 1 SDI cable and 1 ethernet cable.
|
||||
Depending on the location of the audio inputs to the hall, one or two XLR cables may also be laid to the stage or some other location in the hall.
|
||||
Considerations regarding network connection can be found in the [Network Setup](#network-setup) chapter.
|
||||
|
||||
This cabling diagram contains all connections between modules and devices (but not the inner workings of the modules): 
|
||||
|
||||
## Network Setup
|
||||
|
||||
A VOC lecture hall setup needs some internal VOC network (commonly named VOC-VLAN, even though it may not always be a VLAN technically) and a way to have internet access.
|
||||
Depending on the number of rooms and the network provided by the location or event there are multiple ways to connect rooms.
|
||||
This needs to be designed by the VOC responsible person.
|
||||
|
||||
The easiest setup is a single room (or multiple fully independent rooms).
|
||||
Since the Lectern and FOH modules both have network ports for public and VOC network and a VLAN trunk between them, it doesn't matter where the public network is connected.
|
||||
|
||||
### Recommended Single-Room Network Setup
|
||||
|
||||
- Put the WRT router near the FOH module
|
||||
- If the room's public network (uplink) is located at the stage:
|
||||
* Connect the public network (uplink) to the "public" port of the lectern module
|
||||
* Connect the WAN port of the WRT to some "public" port of the FOH module's network switch
|
||||
- If the room's public network (uplink) is located near the FOH:
|
||||
* Connect the WAN port of the WRT to the public network (uplink)
|
||||
- Connect one LAN port of the WRT to some "VOC" port of the FOH module's network switch
|
||||
- Power on the WRT router
|
||||
|
||||
See <https://c3voc.de/wiki/hardware:wrts> how to enable DHCP in the VOC-(V)LAN if needed.
|
||||
|
||||
### Multi-Room Network Setup
|
||||
|
||||
Ideally there's a private VLAN between all rooms which can be used to interconnect all room setups and the office.
|
||||
In that case, each hall setup just needs to be connected to the venue VLAN with one "VOC" port (either at the lectern or at the FOH module -- whatever is more convenient).
|
||||
|
||||
When the server case is used, the router VM will provide uplink to the whole VOC network.
|
||||
If not, deploy one WRT router in a lecture hall or the VOC office providing a connection between public and VOC network.
|
||||
(Remember to enable all hall networks which are reachable via this router so that the remote access VPN works. TODO: Where is this documented?)
|
||||
Simplified cabling diagram: 
|
||||
|
||||
## FOH Module
|
||||
|
||||

|
||||
|
||||
See the netbox for detailed port configuration:
|
||||
[Case 1](https://netbox.c3voc.de/dcim/devices/19/interfaces/),
|
||||
[Case 2](https://netbox.c3voc.de/dcim/devices/25/interfaces/),
|
||||
[Case 3](https://netbox.c3voc.de/dcim/devices/26/interfaces/),
|
||||
[Case 4](https://netbox.c3voc.de/dcim/devices/27/interfaces/),
|
||||
[Case 5](https://netbox.c3voc.de/dcim/devices/28/interfaces/),
|
||||
[Case 6](https://netbox.c3voc.de/dcim/devices/29/interfaces/)
|
||||
|
||||
- [Case 1](https://netbox.c3voc.de/dcim/devices/19/interfaces/)
|
||||
- [Case 2](https://netbox.c3voc.de/dcim/devices/25/interfaces/)
|
||||
- [Case 3](https://netbox.c3voc.de/dcim/devices/26/interfaces/)
|
||||
- [Case 4](https://netbox.c3voc.de/dcim/devices/27/interfaces/)
|
||||
- [Case 5](https://netbox.c3voc.de/dcim/devices/28/interfaces/)
|
||||
- [Case 6](https://netbox.c3voc.de/dcim/devices/29/interfaces/)
|
||||
|
||||
## Lectern Module
|
||||
|
||||

|
||||

|
||||
<!-- TODO: Lectern Front -->
|
||||
|
||||
Use ethernet connections at the front unless a fiber trunk is needed via the SFP slots.
|
||||
See the netbox for detailed port configuration:
|
||||
|
||||
Otherwise see the netbox for detailed port configuration:
|
||||
[Case 1](https://netbox.c3voc.de/dcim/devices/30/interfaces/),
|
||||
[Case 2](https://netbox.c3voc.de/dcim/devices/31/interfaces/),
|
||||
[Case 3](https://netbox.c3voc.de/dcim/devices/32/interfaces/),
|
||||
[Case 4](https://netbox.c3voc.de/dcim/devices/33/interfaces/),
|
||||
[Case 5](https://netbox.c3voc.de/dcim/devices/34/interfaces/),
|
||||
[Case 6](https://netbox.c3voc.de/dcim/devices/35/interfaces/)
|
||||
- [Case 1](https://netbox.c3voc.de/dcim/devices/30/interfaces/)
|
||||
- [Case 2](https://netbox.c3voc.de/dcim/devices/31/interfaces/)
|
||||
- [Case 3](https://netbox.c3voc.de/dcim/devices/32/interfaces/)
|
||||
- [Case 4](https://netbox.c3voc.de/dcim/devices/33/interfaces/)
|
||||
- [Case 5](https://netbox.c3voc.de/dcim/devices/34/interfaces/)
|
||||
- [Case 6](https://netbox.c3voc.de/dcim/devices/35/interfaces/)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue