Title: Content Version for Git
Author: maksonlee
Published: <strong>June 15, 2026</strong>
Last modified: June 15, 2026

---

Search plugins

![](https://ps.w.org/content-version-for-git/assets/banner-772x250.png?rev=3572320)

![](https://ps.w.org/content-version-for-git/assets/icon.svg?rev=3572320)

# Content Version for Git

 By [maksonlee](https://profiles.wordpress.org/maksonlee/)

[Download](https://downloads.wordpress.org/plugin/content-version-for-git.0.1.4.zip)

 * [Details](https://wordpress.org/plugins/content-version-for-git/#description)
 * [Reviews](https://wordpress.org/plugins/content-version-for-git/#reviews)
 *  [Installation](https://wordpress.org/plugins/content-version-for-git/#installation)
 * [Development](https://wordpress.org/plugins/content-version-for-git/#developers)

 [Support](https://wordpress.org/support/plugin/content-version-for-git/)

## Description

Content Version for Git stores editable WordPress content snapshots in a configured
GitHub repository. It versions posts, pages, terms, and optionally media metadata
and original media files. Editors can preview, diff, and restore previous versions
from the WordPress admin.

The plugin writes and reads Git objects through the GitHub API. It does not keep
a local Git repository and does not call the git CLI.

Features include:

 * Automatic Git versions for normal post and page saves.
 * Side-by-side content diffs and field diffs.
 * Full restore and content-only restore modes.
 * Deleted Resources view for posts, pages, and tracked media.
 * Restore deleted posts/pages as new drafts and deleted media as new attachments.
 * Optional media metadata and file tracking.
 * Manual import of existing posts, pages, and media.
 * Version store dashboard with branch, latest commit, tracked file count, and GitHub
   version store status.
 * Direct GitHub API commits without a local Git worktree.

### External Services

This plugin connects to GitHub when the “Enable GitHub version store” setting is
enabled and a repository URL, branch, and personal access token are configured.

When enabled, the plugin writes Git commits directly to the configured GitHub repository
using the GitHub API. Commit data may include post/page content, metadata, term 
references, media metadata, and media files if media tracking is enabled.

The GitHub version store is disabled by default. No data is sent to GitHub unless
a site administrator enables and configures it. Without the GitHub version store,
this plugin does not keep durable local Git versions. GitHub’s terms and privacy
policy apply:

 * https://docs.github.com/en/site-policy/github-terms/github-terms-of-service
 * https://docs.github.com/en/site-policy/privacy-policies/github-privacy-statement

## Screenshots

[⌊Content Versions Dashboard showing version store status, settings, import controls,
and GitHub version store configuration.⌉⌊Content Versions Dashboard showing version
store status, settings, import controls, and GitHub version store configuration.⌉[

Content Versions Dashboard showing version store status, settings, import controls,
and GitHub version store configuration.

[⌊Content Versions page for a post with preview, diff, and restore actions.⌉⌊Content
Versions page for a post with preview, diff, and restore actions.⌉[

Content Versions page for a post with preview, diff, and restore actions.

[⌊Side-by-side content diff and field diff view.⌉⌊Side-by-side content diff and 
field diff view.⌉[

Side-by-side content diff and field diff view.

[⌊Deleted Resources list with post, page, and media restore options.⌉⌊Deleted Resources
list with post, page, and media restore options.⌉[

Deleted Resources list with post, page, and media restore options.

## Installation

 1. Upload the plugin files to the `/wp-content/plugins/content-version-for-git/` directory,
    or install the plugin through the WordPress plugins screen.
 2. Activate the plugin through the Plugins screen in WordPress.
 3. Open Content Versions > Dashboard.
 4. Configure the GitHub version store and media tracking.
 5. Use Import Existing Content if you want to add existing posts, pages, and media
    to GitHub.

## FAQ

### Where are Git versions stored?

GitHub is the version store. The plugin reads and writes versions through the GitHub
API without a local Git repository.

### Does this replace WordPress revisions?

No. It adds a Git-backed version history for selected WordPress resources.

### Does the GitHub version store run by default?

No. The GitHub version store is disabled until an administrator enables it and provides
a repository URL, branch, and token. Without GitHub configured, versions are not
durably stored and the plugin does not keep a local Git repository.

### What happens if GitHub API writes fail?

The version is not stored. Configure GitHub before relying on the plugin for durable
version history.

### Are media files stored in Git?

Only when media tracking is enabled. In that mode, referenced media metadata and
files are committed directly to GitHub.

## Reviews

There are no reviews for this plugin.

## Contributors & Developers

“Content Version for Git” is open source software. The following people have contributed
to this plugin.

Contributors

 *   [ maksonlee ](https://profiles.wordpress.org/maksonlee/)

[Translate “Content Version for Git” into your language.](https://translate.wordpress.org/projects/wp-plugins/content-version-for-git)

### Interested in development?

[Browse the code](https://plugins.trac.wordpress.org/browser/content-version-for-git/),
check out the [SVN repository](https://plugins.svn.wordpress.org/content-version-for-git/),
or subscribe to the [development log](https://plugins.trac.wordpress.org/log/content-version-for-git/)
by [RSS](https://plugins.trac.wordpress.org/log/content-version-for-git/?limit=100&mode=stop_on_copy&format=rss).

## Changelog

#### 0.1.4

 * Clarified that GitHub is the required durable version store.
 * Renamed GitHub-related UI wording to GitHub version store.

#### 0.1.3

 * Tightened restore permissions for full Git version restores.
 * Replaced trusted output wrappers with late escaping for generated admin HTML.
 * Removed runtime shell diff generation from the diff view.

#### 0.1.2

 * Renamed the plugin and package slug for WordPress.org resubmission.

#### 0.1.1

 * Addressed WordPress.org review feedback for asset enqueuing, filesystem locations,
   and plugin metadata.

#### 0.1.0

 * Initial public release candidate.
 * Added Git-backed versions for posts, pages, terms, and optional media resources.
 * Added preview, diff, full restore, and content-only restore.
 * Added Deleted Resources and restore-as-new flows.
 * Added import existing content controls.
 * Added GitHub version store settings.

## Meta

 *  Version **0.1.4**
 *  Last updated **11 hours ago**
 *  Active installations **Fewer than 10**
 *  WordPress version ** 6.0 or higher **
 *  Tested up to **7.0**
 *  PHP version ** 7.4 or higher **
 * Tags
 * [content](https://wordpress.org/plugins/tags/content/)[git](https://wordpress.org/plugins/tags/git/)
   [Github](https://wordpress.org/plugins/tags/github/)[revisions](https://wordpress.org/plugins/tags/revisions/)
   [version control](https://wordpress.org/plugins/tags/version-control/)
 *  [Advanced View](https://wordpress.org/plugins/content-version-for-git/advanced/)

## Ratings

No reviews have been submitted yet.

[Your review](https://wordpress.org/support/plugin/content-version-for-git/reviews/#new-post)

[See all reviews](https://wordpress.org/support/plugin/content-version-for-git/reviews/)

## Contributors

 *   [ maksonlee ](https://profiles.wordpress.org/maksonlee/)

## Support

Got something to say? Need help?

 [View support forum](https://wordpress.org/support/plugin/content-version-for-git/)