Title: Smart Media Replacement
Author: Troy Chaplin
Published: <strong>November 17, 2025</strong>
Last modified: May 15, 2026

---

Search plugins

![](https://ps.w.org/smart-media-replacement/assets/banner-772x250.png?rev=3397667)

![](https://ps.w.org/smart-media-replacement/assets/icon-256x256.png?rev=3397667)

# Smart Media Replacement

 By [Troy Chaplin](https://profiles.wordpress.org/areziaal/)

[Download](https://downloads.wordpress.org/plugin/smart-media-replacement.1.2.1.zip)

 * [Details](https://test.wordpress.org/plugins/smart-media-replacement/#description)
 * [Reviews](https://test.wordpress.org/plugins/smart-media-replacement/#reviews)
 *  [Installation](https://test.wordpress.org/plugins/smart-media-replacement/#installation)
 * [Development](https://test.wordpress.org/plugins/smart-media-replacement/#developers)

 [Support](https://wordpress.org/support/plugin/smart-media-replacement/)

## Description

Ever updated a PDF and realized half your site links to the old version? Or replaced
a hero image and watched your carefully-tuned page layout collapse? Smart Media 
Replacement solves both problems — and adds a safety net you’ll wish you had earlier.

**Replace the file, keep the URL.** When you swap an attachment with this plugin,
the file’s URL never changes. Every existing link, every email that points to it,
every page that embeds it, every SEO ranking — all of it keeps working. No 404s,
no broken references, no scrambling to update old content.

**Full revision history, one-click restore.** Every replacement automatically snapshots
the previous version. Made a mistake? Roll back instantly. Want to see what the 
file looked like three months ago? Download it. Each revision is timestamped, attributed
to the user who made it, and can carry an optional note describing what changed.

**Works where you work.** Replace from the Media Library, or from inside any block’s
Replace toolbar in the block editor — image, cover, video, audio, file, gallery,
and more. The editor refreshes in place, no page reload, no lost work.

**Safe by default.** The plugin validates filenames, file types, and image dimensions
to keep your URLs intact and your layouts unbroken. WordPress’s auto-scaled images
are handled transparently. Revisions land in a database table that’s self-healing
on every admin load, and the plugin’s settings page gives you control over how many
revisions to keep, how long to retain them, and which file types are tracked.

#### Use cases

 * **Monthly reports and newsletters** — Update PDFs linked from past emails without
   breaking any of those links.
 * **Brand refreshes** — Replace logos, headers, and brand imagery once; everywhere
   they’re used updates automatically.
 * **Legal documents** — Keep current versions of terms of service, privacy policy,
   and contracts live, with older versions preserved as revisions for compliance.
 * **Image updates** — Refresh product photos, blog hero images, and marketing assets
   without breaking responsive sizes or SEO.
 * **Typo fixes in published assets** — Fix errors in infographics, downloadable
   guides, or e-books without scrambling to update references across your site.
 * **Versioned downloads** — White papers, e-books, technical docs that need to 
   stay at a stable URL while preserving older versions on demand.

#### Features

**Replacement and URL preservation**

 * Replace any media file while keeping its URL, ID, and metadata intact
 * Existing internal and external links keep working — no 404s, no SEO impact
 * Automatic regeneration of image size variants (thumbnails, medium, large, etc.)
 * Transparent handling of WordPress’s `-scaled` large images

**Revision history**

 * Every replacement automatically snapshots the previous file
 * Major/minor version numbering (e.g. v1.0  v1.1  v2.0)
 * Optional replacement note per revision, attributed to the user
 * One-click restore of any past version
 * Download individual revisions, or download a ZIP archive of an attachment’s full
   history
 * Configurable: maximum revisions per file, age-based retention with daily cleanup,
   per-file-type opt-in

**Block editor integration**

 * “Update existing file” in every block’s Replace toolbar dropdown (image, cover,
   video, audio, file, gallery, media-text, post-featured-image)
 * In-place editor refresh after replacement — no page reload, no lost work
 * Accessibility-friendly notifications via WordPress’s native screen reader announcements

**Validation safeguards**

 * Filename matching to keep URLs stable
 * Image dimension matching to prevent layout breakage
 * MIME-type matching to prevent file corruption
 * Clear, actionable error messages when something doesn’t match

**Built-in admin**

 * Settings page at Media  Replacement Settings
 * Storage stats: total revisions, total disk usage, database table status
 * Optional deactivation cleanup (files and/or database)

**Multisite-ready**

 * Network-activate only on multisite — one consistent configuration across every
   site
 * Settings live at Network Admin  Settings  Media Replacement and apply network-
   wide
 * Revisions are stored per-site under each site’s uploads directory; metadata lives
   in a single shared network table
 * Daily retention cleanup runs across every site in the network
 * Automatic row and file cleanup when a site is deleted
 * Single-site installs work exactly as before — settings and storage stay per-site,
   no network behavior involved

**WP-CLI**

 * `wp smr db check` — verify the revisions table exists (non-zero exit code if 
   missing, safe for CI pipelines)
 * `wp smr db repair` — recreate the table if missing; idempotent, safe to run when
   the table already exists
 * `wp smr db status` — revision counts and storage usage; `--network` for a per-
   site breakdown on multisite
 * `wp smr db cleanup` — delete expired revisions immediately, with `--dry-run` 
   to preview and `--network` for all sites

**Other**

 * Self-healing database table via configurable scheduled check (hourly, daily, 
   weekly, or disabled); use `wp smr db repair` for on-demand recovery
 * Developer hooks throughout for custom integrations

#### Privacy

This plugin is fully self-contained and respects your privacy:

 * Does not collect or transmit any user data
 * Does not use cookies or third-party tracking
 * Only processes files locally on your server
 * Does not communicate with external services or APIs

### Usage

#### From the Media Library

 1. Navigate to the WordPress Media Library
 2. Open the file you want to replace (click on it, or use the row actions in list 
    view)
 3. Click **Replace File**
 4. Choose your new file — if revisions are enabled, you’ll be prompted for an optional
    note and version type (minor/major)
 5. The replacement happens immediately, preserving the file’s URL

#### From the block editor

 1. Click on any media block (image, cover, video, audio, file, gallery, etc.)
 2. Open the **Replace** toolbar dropdown
 3. Choose **Update existing file**
 4. Pick your new file — the editor refreshes in place

#### Viewing and managing revisions

 * In the Media Library list view, the **Revisions** row action opens the full revision
   history for that file
 * On the attachment edit screen, the **View Revisions** button opens the same panel
 * From either, you can download any past version individually or as a ZIP, and 
   restore any revision with one click

## Screenshots

 * [[
 * Update an inserted image straight from the block toolbar — no page reload, no
   lost work.
 * [[
 * Pick a replacement file and add an optional note describing what changed.
 * [[
 * Replacements are validated against the original — file type, filename, and image
   dimensions — so URLs stay stable and layouts stay intact.
 * [[
 * Replace files or view revisions directly from the Media Library row actions.
 * [[
 * Same replacement flow from the attachment edit screen, with the optional replacement
   note.
 * [[
 * Browse, restore, or download past versions — or grab the full history as a ZIP—
   all from one panel.
 * [[
 * Configure revision retention, file-type tracking, comment requirements, and deactivation
   cleanup from one settings page.

## Installation

 1. Install from the WordPress plugin directory, or upload the `smart-media-replacement`
    folder to `/wp-content/plugins/`
 2. Activate through the Plugins menu in WordPress
 3. (Optional) Visit Media  Replacement Settings to configure revision history behavior

#### Multisite

On WordPress multisite the plugin is network-activate only — activate it once from
Network Admin  Plugins, then configure it at Network Admin  Settings  Media Replacement.
The settings you choose apply to every site on the network. There is no per-site
settings page on multisite.

## FAQ

### Will my existing links still work after I replace a file?

Yes — that’s the whole point. The replacement keeps the file’s URL and ID unchanged,
so every existing link, embed, share, and SEO reference continues to work normally.

### Can I undo a replacement if something goes wrong?

Yes. As long as revisions are enabled for the file type, every replacement preserves
the previous version. Open the file’s revision history and click **Restore** on 
any past version. The current file is also snapshotted before the restore, so nothing
is lost.

### Does this work in the block editor?

Yes. Every block that has a Replace toolbar — image, cover, video, audio, file, 
gallery, media-text, post-featured-image — gets an **Update existing file** option
in the Replace dropdown. The editor refreshes in place after replacement, so you
don’t lose unsaved work.

### What happens to image thumbnail variants after replacement?

WordPress regenerates all configured image sizes (thumbnail, medium, large, etc.)
automatically. Their URLs stay stable too, so responsive images and srcset attributes
continue working.

### Can I download a previous version of a file?

Yes. Each revision has its own Download button. You can also download a ZIP archive
containing every revision for a file at once.

### Why must my replacement file have the same name as the original?

That’s how WordPress serves files — the URL contains the filename. Matching the 
original filename is what keeps your existing links intact. The plugin shows you
the exact filename to use if there’s a mismatch.

### Why must image dimensions match?

Different dimensions can break responsive layouts, hero image sizing, and carefully-
tuned cropping across your site. Enforcing identical dimensions protects against
unexpected layout shifts. Developers can disable this per-attachment with the `smart_media_replacement_enforce_dimensions`
filter if needed.

### Can I replace a JPG with a PNG?

No. The replacement file must be the same MIME type as the original. Mixing file
types can break image processing, browser display, and SEO. If you need to change
formats, upload as a new image.

### What if my image was scaled by WordPress?

If WordPress automatically created a `-scaled` variant (typical for uploads over
2560px), upload your replacement with the **original** filename — without the `-
scaled` suffix. The plugin handles the scaling and regenerates all variants automatically.
If you upload with the wrong filename, the error message will tell you exactly what
name to use.

### I have revisions enabled but I don’t see any history. Why?

Revisions are created on **replacement**, not on the original upload — so a brand-
new attachment shows no history until you’ve replaced it at least once. Also check
Media  Replacement Settings: the “Enable Revisions For” option lets you scope revisions
to documents only, images only, or all file types. If your attachment’s type isn’t
covered, no revisions will be tracked.

### Is there a WP-CLI interface?

Yes. The plugin ships with `wp smr db check`, `wp smr db repair`, `wp smr db status`,
and `wp smr db cleanup`. These are useful in deployment pipelines, after database
restores, and on large multisite networks where you want to run retention cleanup
on a real system cron instead of relying on WP-Cron. All commands support `--network`
and `--site-id=<id>` on multisite; `wp smr db cleanup` also accepts `--dry-run` 
and `--yes`.

### Do I need special permissions?

Yes — you need the `edit_post` capability for the specific attachment. This matches
WordPress’s standard media editing permission model.

## Reviews

There are no reviews for this plugin.

## Contributors & Developers

“Smart Media Replacement” is open source software. The following people have contributed
to this plugin.

Contributors

 *   [ Troy Chaplin ](https://profiles.wordpress.org/areziaal/)

[Translate “Smart Media Replacement” into your language.](https://translate.wordpress.org/projects/wp-plugins/smart-media-replacement)

### Interested in development?

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

## Changelog

#### What’s new in 1.2.0

Multisite behavior is now consistent and centrally managed.

 * **Network-activate only on multisite.** WordPress no longer exposes a per-site
   activation link — a super admin network-activates the plugin once.
 * **Network-wide settings.** All configuration lives at Network Admin  Settings
   Media Replacement and applies to every site on the network. The per-site settings
   page is no longer registered on multisite.
 * **Retention cron is network-aware.** The daily cleanup iterates every site so
   retention applies across the entire network, not just the main site.
 * **Plugin “Settings” shortcut on the Plugins screen** points to the correct admin(
   network or site) in both contexts.

**Upgrading on multisite:** per-site settings stored under v1.1.x are not carried
forward to the network store. After upgrading, a super admin should visit Network
Admin  Settings  Media Replacement once and confirm the values. Single-site installs
are unaffected.

#### What’s new in 1.1.1

A major feature release. Revision history, block editor integration, and a handful
of reliability improvements for managed hosts.

**New features**

 * **Revision history.** Every replacement now snapshots the previous file, tracked
   with major/minor versioning and an optional note. Restore any past version with
   one click.
 * **Block editor integration.** “Update existing file” now appears in every block’s
   Replace toolbar — image, cover, video, audio, file, gallery, and more. The editor
   refreshes in place, no page reload, no lost work.
 * **Download past versions.** Save any individual revision, or grab a ZIP archive
   of an attachment’s full history.
 * **Settings page.** Control which file types get revisions, how many to keep, 
   how long to retain them, the default version-bump behavior, and whether replacement
   notes are required.
 * **Multisite support.** Per-site revision storage and settings, automatic cleanup
   on site deletion, defaults seeded for new sites.

**Reliability improvements**

 * Replacements now work on managed hosts where strict file ownership previously
   caused 500 errors during the upload step.
 * Files are no longer at risk during a failed replacement — the new file is placed
   before the old one is cleaned up.
 * Smoother restore: no more duplicate confirmations or accidental double-rollbacks.
 * Failed uploads (wrong dimensions, wrong file type) no longer leave behind orphan
   revisions.
 * The revisions database table is now self-healed on every admin load — recovers
   automatically from DB resets without needing a deactivate/reactivate.

**Security hardening**

 * Path-traversal protection on revision file lookups.
 * Directory listing prevention on the revisions storage folder.
 * Stricter input validation on version-type parameters.

[View all version changes](https://github.com/troychaplin/smart-media-replacement/blob/main/CHANGELOG.md)

#### 1.0.0

 * Initial release
 * Replace media files while maintaining URLs
 * Filename validation to prevent URL changes
 * Image dimension enforcement to prevent layout issues
 * WordPress scaled image handling
 * File type validation for consistency
 * AJAX-based replacement with error handling
 * Developer hooks for customization

## Meta

 *  Version **1.2.1**
 *  Last updated **7 hours ago**
 *  Active installations **Fewer than 10**
 *  WordPress version ** 6.6 or higher **
 *  Tested up to **7.0**
 *  PHP version ** 7.4 or higher **
 *  Language
 * [English (US)](https://wordpress.org/plugins/smart-media-replacement/)
 * Tags
 * [attachment](https://test.wordpress.org/plugins/tags/attachment/)[media](https://test.wordpress.org/plugins/tags/media/)
   [pdf](https://test.wordpress.org/plugins/tags/pdf/)[replace](https://test.wordpress.org/plugins/tags/replace/)
   [revisions](https://test.wordpress.org/plugins/tags/revisions/)
 *  [Advanced View](https://test.wordpress.org/plugins/smart-media-replacement/advanced/)

## Ratings

No reviews have been submitted yet.

[Your review](https://wordpress.org/support/plugin/smart-media-replacement/reviews/#new-post)

[See all reviews](https://wordpress.org/support/plugin/smart-media-replacement/reviews/)

## Contributors

 *   [ Troy Chaplin ](https://profiles.wordpress.org/areziaal/)

## Support

Got something to say? Need help?

 [View support forum](https://wordpress.org/support/plugin/smart-media-replacement/)