diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS
new file mode 100644
index 0000000..7f8b6a1
--- /dev/null
+++ b/.github/CODEOWNERS
@@ -0,0 +1,5 @@
+# The releng team is by default the owner of everything.
+* @{{ org }}/eclipsefdn-releng
+
+# Otterdog related configurations are also owned by the security team.
+/otterdog/** @{{ org }}/eclipsefdn-security
diff --git a/.github/dependabot.yml b/.github/dependabot.yml
new file mode 100644
index 0000000..9be4262
--- /dev/null
+++ b/.github/dependabot.yml
@@ -0,0 +1,13 @@
+version: 2
+updates:
+- package-ecosystem: github-actions
+ directory: "/"
+ # We scan and create dependabot PRs against the develop branch only.
+ # Such a branch only exists for the template master at EclipseFdn/.eclipsefdn-template
+ # dependabot shall only update the template master, and changes will be synchronized to
+ # all repos by otterdog using the sync-template operation to avoid having many similar
+ # dependabot PRs for each individual .eclipsefdn repo which we would like to avoid at all costs.
+ target-branch: "develop"
+ schedule:
+ interval: daily
+ open-pull-requests-limit: 10
diff --git a/.github/workflows/build-page.yml b/.github/workflows/build-page.yml
new file mode 100644
index 0000000..563a59c
--- /dev/null
+++ b/.github/workflows/build-page.yml
@@ -0,0 +1,118 @@
+name: Build GH Page
+
+on:
+ workflow_dispatch:
+ push:
+ branches:
+ - 'main'
+ paths:
+ - 'otterdog/*.jsonnet'
+ - 'docs/**'
+ - 'mkdocs.yml'
+ - '.github/workflows/build-page.yml'
+
+concurrency:
+ group: "pages"
+ cancel-in-progress: false
+
+permissions:
+ contents: read
+ pages: write
+ id-token: write
+
+jobs:
+ generate-markdown:
+ # do not run the workflow in the template repo itself
+ if: ${{ !contains (github.repository, '/.eclipsefdn-template') }}
+ runs-on: ubuntu-latest
+ steps:
+ - name: Checkout eclipse-csi/otterdog
+ uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
+ with:
+ repository: eclipse-csi/otterdog
+ path: otterdog
+
+ - name: Checkout EclipseFdn/otterdog-configs
+ uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
+ with:
+ repository: EclipseFdn/otterdog-configs
+ path: otterdog-configs
+
+ # checkout the HEAD ref
+ - name: Checkout HEAD
+ uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
+ with:
+ path: ${{ github.repository_owner }}
+
+ - name: Install jsonnet-bundler
+ run: |
+ go install -a github.com/jsonnet-bundler/jsonnet-bundler/cmd/jb@v0.5.1
+ echo $(go env GOPATH)/bin >> $GITHUB_PATH
+
+ - name: Install poetry
+ run: pipx install poetry
+
+ - name: Setup Python
+ uses: actions/setup-python@f677139bbe7f9c59b41e40162b753c062f5d49a3 # v5.2.0
+ with:
+ python-version: '3.10'
+ cache: 'poetry'
+
+ - name: Install dependencies with poetry
+ run: |
+ poetry install --only=main
+ working-directory: otterdog
+
+ - name: Copy configuration from HEAD ref
+ run: |
+ mkdir -p orgs/${{ github.repository_owner }}
+ cp -r ../${{ github.repository_owner }}/otterdog/* orgs/${{ github.repository_owner }}
+ working-directory: otterdog-configs
+
+ - name: Generate default configuration as markdown
+ run: ../otterdog/otterdog.sh show-default ${{ github.repository_owner }} -c otterdog.json --markdown > default.txt
+ working-directory: otterdog-configs
+
+ - name: Upload generated site content
+ uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4.4.0
+ with:
+ name: generated-site
+ path: |
+ otterdog-configs/default.txt
+ otterdog-configs/orgs/${{ github.repository_owner }}/vendor/otterdog-defaults/*.libsonnet
+
+ build-page:
+ runs-on: ubuntu-latest
+ needs: generate-markdown
+ steps:
+ - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
+ - name: Download generated site content
+ uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
+ with:
+ name: generated-site
+ - shell: bash
+ run: |
+ cat default.txt >> ./docs/playground.md
+ cp orgs/${{ github.repository_owner }}/vendor/otterdog-defaults/*.libsonnet ./docs/jsonnet/
+ - uses: actions/setup-python@f677139bbe7f9c59b41e40162b753c062f5d49a3 # v5.2.0
+ with:
+ python-version: 3.x
+ cache: 'pip'
+ - run: pip install -r requirements.txt
+ - name: Build with Mkdocs
+ run: mkdocs build
+ - name: Setup Pages
+ uses: actions/configure-pages@983d7736d9b0ae728b81ab479565c72886d7745b # v5.0.0
+ - name: Upload artifact
+ uses: actions/upload-pages-artifact@56afc609e74202658d3ffba0e8f6dda462b719fa # v3.0.1
+
+ deploy:
+ environment:
+ name: github-pages
+ url: ${{ steps.deployment.outputs.page_url }}
+ runs-on: ubuntu-latest
+ needs: build-page
+ steps:
+ - name: Deploy to GitHub Pages
+ id: deployment
+ uses: actions/deploy-pages@d6db90164ac5ed86f2b6aed7e0febac5b3c0c03e # v4.0.5
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..9fa84c6
--- /dev/null
+++ b/README.md
@@ -0,0 +1,7 @@
+# Eclipse Foundation Config Repo
+
+Repository to host configurations related to the Eclipse Foundation.
+
+## Self service of your GitHub organization
+
+You can find more information at