Skip to content
This repository has been archived by the owner on Jan 22, 2025. It is now read-only.

Running Better Meetings - How to Facilitate at W3C #109

Running Better Meetings - How to Facilitate at W3C

Running Better Meetings - How to Facilitate at W3C #109

name: Validate breakout session issue and update calendar
on:
issues:
# Details for types below can be found at:
# https://docs.github.com/en/webhooks-and-events/webhooks/webhook-events-and-payloads?actionType=edited#issues
types:
# Job triggered when an issue is created or re-opened
- opened
- reopened
# or gets "edited" (title or body updated)
- edited
jobs:
validate-session:
name: Validate breakout session
runs-on: ubuntu-latest
# We're only interested in "session" issues
if: ${{ contains(github.event.issue.labels.*.name, 'session') }}
steps:
- name: Setup node.js
uses: actions/setup-node@v3
with:
node-version: 18
- name: Checkout latest version of release script
uses: actions/checkout@v3
with:
ref: main
# Note: no "package-lock.json" and no "npm ci" on purpose to retrieve
# latest version of w3c/tpac-breakouts tools (which are unversioned)
- name: Install dependencies
run: npm install
- name: Add issue to TPAC breakout session project
if: ${{ github.event.action == 'opened' || github.event.action == 'reopened' }}
uses: actions/[email protected]
with:
# Note: This isn't really necessary since we already made sure that
# issue is a "session" issue
labeled: session
# URL of the annual TPAC XXXX breakout project.
# The PROJECT_OWNER and PROJECT_NUMBER variables must be defined on
# the repository. PROJECT_OWNER_TYPE needs to be set to "user" if
# project belongs to a user. It may be omitted otherwise (or set to
# 'org"').
project-url: https://github.com/${{vars.PROJECT_OWNER_TYPE || 'org'}}s/${{vars.PROJECT_OWNER || 'w3c'}}/projects/${{vars.PROJECT_NUMBER}}
# A valid Personal Access Token (classic version) with project scope
# (and public_repo scope so that labels may be updated) needs to be
# added as secret to the repo, because the action uses the GraphQL
# API under the hoods.
github-token: ${{ secrets.GRAPHQL_TOKEN }}
- name: Add thank you comment with links to documentation
if: ${{ github.event.action == 'opened' }}
run: gh issue comment "$NUMBER" --body-file "$BODY_FILE"
env:
GITHUB_TOKEN: ${{ secrets.GRAPHQL_TOKEN }}
GH_REPO: ${{ github.repository }}
NUMBER: ${{ github.event.issue.number }}
BODY_FILE: .github/session-created.md
- name: Dump changes to local file
run: echo '${{ toJSON(github.event.issue.changes || '{}') }}' > changes.json
shell: bash
- name: Validate session and update issue labels accordingly
run: npx validate-session ${{ github.event.issue.number }} changes.json
env:
# See above for PROJECT_XX variables
PROJECT_OWNER: ${{ vars.PROJECT_OWNER_TYPE || 'organization' }}/${{ vars.PROJECT_OWNER || 'w3c' }}
PROJECT_NUMBER: ${{ vars.PROJECT_NUMBER }}
# Same valid Personal Access Token (classic version) as above, with
# project and public_repo scope.
GRAPHQL_TOKEN: ${{ secrets.GRAPHQL_TOKEN }}
# Mapping between chair GitHub identities and W3C IDs must be stored
# in a variable. Structure is a JSON object with identities as keys.
CHAIR_W3CID: ${{ vars.CHAIR_W3CID }}
- name: Create/Update calendar entry
run: npx update-calendar ${{ github.event.issue.number }} quiet
env:
# See above for PROJECT_XX variables
PROJECT_OWNER: ${{ vars.PROJECT_OWNER_TYPE || 'organization' }}/${{ vars.PROJECT_OWNER || 'w3c' }}
PROJECT_NUMBER: ${{ vars.PROJECT_NUMBER }}
# Same valid Personal Access Token (classic version) as above, with
# project and public_repo scope.
GRAPHQL_TOKEN: ${{ secrets.GRAPHQL_TOKEN }}
# Information about the team user on behalf of which the updates to
# the calendar will be made. The password must obviously be stored
# as a secret!
W3C_LOGIN: ${{ vars.W3C_LOGIN }}
W3C_PASSWORD: ${{ secrets.W3C_PASSWORD }}
# Mapping between rooms and Zoom meetings must be stored in a variable
# (so that it does not get published). Structure is a JSON object
# with room names as keys.
ROOM_ZOOM: ${{ vars.ROOM_ZOOM }}
# Mapping between chair GitHub identities and W3C IDs must be stored
# in a variable. Structure is a JSON object with identities as keys.
CHAIR_W3CID: ${{ vars.CHAIR_W3CID }}