Skip to content

tryfabric/notion-github-action

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

Notion x GitHub Action

Code Style: Google

Connect your GitHub issues to a Notion database.

Like this GitHub Action? Give us a ⭐️ and follow us on Twitter for more drops 🪂.


Quick Start

  1. Create a new internal Notion integration and note the value of the Internal Integration Token.
  2. In your GitHub repository, go to Settings > Secrets, and add a New repository secret. Set the Name to NOTION_TOKEN and the Value to the Internal Integration Token you created in the previous step.
  3. Set up your Notion Database. Use this template and duplicate it to your workspace. Screen Shot 2021-06-14 at 11 37 51 AM
  4. In your Notion Database page's Share menu, add the Notion integration you created as a member with the Can edit privilege. You may have to type your integration's name in the Invite field. Screen Shot 2021-06-14 at 11 41 25 AM
  5. Find the ID of your Database by copying the link to it. The link will have the format
https://www.notion.so/abc?v=123

where abc is the database id.

  1. Add the Database's ID as a repository secret for your GitHub repository. Set the Name to NOTION_DATABASE and the Value to the id of your Database.

  2. In your GitHub repository, create a GitHub workflow file at the path .github/workflows/issues-notion-sync.yml.

name: Notion Sync

on:
  workflow_dispatch:
  issues:
    types:
      [
        opened,
        edited,
        labeled,
        unlabeled,
        assigned,
        unassigned,
        milestoned,
        demilestoned,
        reopened,
        closed,
      ]

jobs:
  notion_job:
    runs-on: ubuntu-latest
    name: Add GitHub Issues to Notion
    steps:
      - name: Add GitHub Issues to Notion
        uses: tryfabric/notion-github-action@v1
        with:
          notion-token: ${{ secrets.NOTION_TOKEN }}
          notion-db: ${{ secrets.NOTION_DATABASE }}
  1. (Optional) If your Github repository has any preexisting issues that you would like to sync to your new Notion Database you can trigger a manual workflow. Make sure your organization's default GITHUB_TOKEN has read and write permissions then follow these intructions to run the Notion Job workflow.

Note: The manual workflow will only work on Notion Databases created from the templated linked above.

Using release-it

  1. Locally, on master (make sure it's up to date), execute GITHUB_TOKEN=<TOKEN> release-it. (Alternatively, set GITHUB_TOKEN as a system environment variable)
  2. Follow the interactive prompts, selecting Yes for all options.
  3. When selecting the increment, choose patch when the release is only bug fixes. For new features, choose minor. For major changes, choose major.

Release-It will then automatically generate a GitHub release with the changelog inside.


Built with 💙 by the team behind Fabric.