Skip to main content

Sync filtered commits from private to public repository

Project description

git-sync-filtered

GitHub Repo stars GitHub Actions Workflow Status Supported Python versions GitHub Release License

A thin wrapper around git-filter-repo for syncing filtered commits from a private repository to a public repository.

Overview

git-sync-filtered clones a private repository, filters it to only include specified paths using git-filter-repo, and pushes the result to a public repository's sync branch. This enables maintaining a public subset of a private repository while preserving commit history.

Installation

uv (recommended)

uv tool install git-sync-filtered

pip

pip install git-sync-filtered

uvx (run without installing)

uvx git-sync-filtered \
  --private git@github.com:org/private.git \
  --public git@github.com:org/public.git \
  --keep src \
  --keep docs

GitHub Actions

You can use this workflow to sync from your private repo to a public repo when the private repo receives a push.

In your private repository, create .github/workflows/sync.yaml:

name: Sync to Public Repo

on:
  push:
    branches:
      - main

jobs:
  sync:
    uses: Merge-42/git-sync-filtered/.github/workflows/sync.yaml@v0.1.5
    with:
      private_repo: ${{ github.repositoryUrl }}
      public_repo: git@github.com:org/public.git
      keep: src docs
      merge: true
    secrets:
      GH_TOKEN: ${{ secrets.GH_PAT }}

Required secrets:

  • GH_PAT - A GitHub Personal Access Token with repo scope (for pushing to the public repo)

Available inputs:

Input Description Default
private_repo Private repository URL Required
public_repo Public repository URL Required
keep Space-separated paths to keep -
keep_from_file File containing paths to keep -
sync_branch Sync branch name upstream/sync
main_branch Main branch name main
private_branch Private branch to sync from main
merge Merge into main after sync false
force Force push false
dry_run Dry run mode false

Usage

git-sync-filtered \
  --private git@github.com:org/private.git \
  --public git@github.com:org/public.git \
  --keep src \
  --keep docs

Using a paths file

Create a file with paths to keep (one per line, lines starting with # are comments):

src
docs
README.md
git-sync-filtered \
  --private git@github.com:org/private.git \
  --public git@github.com:org/public.git \
  --keep-from-file paths.txt

Options

Option Description Default
--private Private repo path or URL Required
--public Public repo path or URL Required
--keep Paths to keep (specify multiple) Required
--keep-from-file File containing paths to keep -
--sync-branch Sync branch name upstream/sync
--main-branch Main branch name main
--private-branch Private branch to sync from main
--dry-run Show what would happen without making changes false
--merge Merge into main branch after sync false
--force Force push false

How It Works

  1. Clones the private repository
  2. Runs git-filter-repo to filter to only the specified paths
  3. Pushes filtered commits to the public repository's sync branch
  4. Optionally merges the sync branch into main

The sync branch can then be merged into main manually or with --merge.

Workflow

flowchart LR
    A[Private Repo<br/>private-branch] -->|clone & filter| B[git-sync-filtered]
    B -->|push| C[Public Repo<br/>sync-branch]
    C -->|"merge<br/>(manual or with --merge)"| D[Public Repo<br/>main-branch]

Requirements

  • Python 3.10+
  • git >= 2.36.0

Sponsored by Merge 42

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

git_sync_filtered-0.1.5.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

git_sync_filtered-0.1.5-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file git_sync_filtered-0.1.5.tar.gz.

File metadata

  • Download URL: git_sync_filtered-0.1.5.tar.gz
  • Upload date:
  • Size: 9.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for git_sync_filtered-0.1.5.tar.gz
Algorithm Hash digest
SHA256 854bc2c8e6169505828009dd58875621631f3d9023da312f805910cc7ee83060
MD5 09a8718e11bc892a706c754a7d655a14
BLAKE2b-256 c7696abe9461f83d4ce98a59bfa7340273c3b910f52505c901f026f11e2f0d3f

See more details on using hashes here.

File details

Details for the file git_sync_filtered-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: git_sync_filtered-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for git_sync_filtered-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 7d86c91cf45d4c190e19b7419b064d724646c2fa443f9882f18b612f0b394ba4
MD5 115a713ce1a9c956572ebb965875a11c
BLAKE2b-256 1b17fcd7ce77ba613a27dae98a5d3ca6c1c1098540ed26f63b26d96abf1322f7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page