Embed Privacy


Lënda e trupëzuar nga sajte të jashtëm, të tillë si YouTube ose Twitter ngarkohet menjëherë sapo vizitorët hyjnë në sajtin tuaj. Këtë çështje e zgjidh Privatësi Trupëzimesh duke parandaluar ngarkimin e kësaj lënde, deri sa vizitori të vendosë të lejojë ose jo ngarkimin e lëndës së jashtme.
Por Privatësi Trupëzimesh s’mbron thjesht privatësinë e vizitorëve tuaj, ajo e bën edhe sajtin të ngarkohet më shpejt.

Krejt trupëzimet do të zëvendësohen nga shënime, të gatshme për t’u aplikuar stilizim sipas dëshirës tuaj. Me vetëm nja dy rreshta CSS.

By clicking on the placeholder the respective content will then be loaded.

Note: This plugins requires the PHP extension “Document Object Model” (php-dom).

Foto ekrani

  • Add embeds using the classic editor or the block editor’s embed blocks.
  • Embed Privacy will add an overlay to supported embeds automatically.
  • You can customize the overlays for each service individually.
  • Embed Privacy can deliver embedded Tweets locally without 3rd party scripts or tracking.


  1. Ngarkojini kartelat e shtojcës te drejtoria /wp-content/plugins/embed-privacy, ose instalojeni shtojcën drejtpërsëdrejti nga skena e shtojcave WordPress.
  2. Aktivizojeni shtojcën përmes menusë ‘Shtojca’ te WordPress-i.
  3. Lënda e trupëzuar do të zëvendësohet vetvetiu me një shënim dhe mund të ngarkohet nëse duan vizitorët. S’ka rregullimet të tjera.
  4. To allow users to opt-out of embed providers that they set to always active, place the shortcode [embed_privacy_opt_out] into your privacy policy.


A ua pengon Privatësi Trupëzimesh shërbimeve të jashtme të ndjekin mua/vizitorët e mi?

Po. Për sa kohë që nuk zgjidhni të ngarkohet lëndë e jashtme, ju/vizitorët tuaj s’gjurmohen dot nga këto shërbime.

A e bën Privatësi Trupëzimesh trupëzimin e lëndës miqësor ndaj privatësisë?

The embedding process itself will be privacy-friendly with Embed Privacy. That means, that no third-party embed provider can track users without their explicit consent by clicking on the overlay to allow the embed to be loaded. However, to make sure everything is fine you need to expand your privacy policy for each embed provider you’re using or you want to use because you need to specify, where data will be sent to and what happens to them.

A e mbulon shtojca Privatësi Trupëzimesh përpunuesin Gutenberg?

Patjetër! Na pëlqejmë të luajmë me përpunuesin e ri të WordPress-it dhe e kemi hartuar Privatësinë e Trupëzimeve me Gutenberg-n në mendje, shtojca do të punojë pavarësisht nga përpunuesi që përdorni.

Cilat trupëzime mbulohen hëpërhë?

We currently support all oEmbed providers known to WordPress core by default. Want to know about them? Here you go:

  • Amazon Kindle
  • Anghami
  • Animoto
  • Cloudup
  • DailyMotion
  • Facebook
  • Flickr
  • Funny Or Die
  • Imgur
  • Instagram
  • Issuu
  • Kickstarter
  • Meetup
  • Mixcloud
  • Photobucket
  • Pocket Casts
  • Polldaddy.com
  • Reddit
  • ReverbNation
  • Scribd
  • Sketchfab
  • SlideShare
  • SmugMug
  • SoundCloud
  • Speaker Deck
  • Spotify
  • TikTok
  • TED
  • Tumblr
  • Twitter
  • VideoPress
  • Vimeo
  • WordPress.org
  • WordPress.tv
  • YouTube

We also support Google Maps via iframe and the plugins Maps Marker, Maps Marker Pro and Shortcodes Ultimate.

Since version 1.2.0, you can also add custom embed providers by going to Settings > Embed Privacy > Manage embeds. Here you can also modify any existing embed provider, change its logo, add a background image, change the text displaying on the embed or disable the embed provider entirely.

Can Embed Privacy automatically download thumbnails of the embedded content?

Yes! Since version 1.5.0, Embed Privacy supports downloading and displaying thumbnails in posts for SlideShare, Vimeo and YouTube as background of Embed Privacy’s overlay.

Developers: How to use Embed Privacy’s methods for custom content?

Since version 1.1.0 you can now use our mechanism for content we don’t support in our plugin. You can do it the following way:

 * Replace specific content with the Embed Privacy overlay of type 'google-maps'.
 * @param   string      $content The content to replace
 * @return  string The updated content
function prefix_replace_content_with_overlay( $content ) {
    // check for Embed Privacy
    if ( ! class_exists( 'epiphyt\Embed_Privacy\Embed_Privacy' ) ) {
        return $content;

    // get Embed Privacy instance
    $embed_privacy = epiphyt\Embed_Privacy\Embed_Privacy::get_instance();

    // check if provider is always active; if so, just return the content
    if ( ! $embed_privacy->is_always_active_provider( 'google-maps' ) ) {
        // replace the content with the overlay
        $content = $embed_privacy->get_output_template( 'Google Maps', 'google-maps', $content );
        // enqueue assets

    return $content;

Can users opt-out of already opted in embed providers?

Yes! You can use the shortcode [embed_privacy_opt_out] to add a list of embed providers anywhere you want (recommendation: add it to your privacy policy) to allow your users to opt-out.

What parameters can be used in the shortcode?

The shortcode [embed_privacy_opt_out] can be used to let users opt-out of embed providers that have been set to be always active by the user. It can have the following attributes:

headline – Add a custom headline (default: Embed providers)

[embed_privacy_opt_out headline="My custom headline"]

subline – Add a custom subline (default: Enable or disable embed providers globally. By enabling a provider, its embedded content will be displayed directly on every page without asking you anymore.)

[embed_privacy_opt_out subline="My custom subline"]

show_all – Whether to show all available embed providers or just the ones the user opted in (default: false)

[embed_privacy_opt_out show_all="1"]

You can also combine all of these attributes:

[embed_privacy_opt_out headline="My custom headline" subline="My custom subline" show_all="1"]

Is this plugin compatible with my caching plugin?

If you’re using a caching plugin, make sure you enable the “JavaScript detection for active providers” in Settings > Embed Privacy > JavaScript detection. Then, the plugin is fully compatible with your caching plugin.

How can Embed Privacy be extended?

Check out our documentation: https://epiph.yt/en/embed-privacy/documentation/

Kush jeni?

Jemi Epiphyt, dyqani juaj miqësor për shtojca WordPress, nga jugu i Gjermanisë.

How can I report security bugs?

You can report security bugs through the Patchstack Vulnerability Disclosure Program. The Patchstack team help validate, triage and handle any security vulnerabilities. Report a security vulnerability.


13 Shkurt, 2024
Does what it is supposed to do and – from own experience – if you cant figure it out yourself (custom Regex or whatever) the support is splendid and fast (in my case the author replied in two minutes).
13 Gusht, 2023
A perfect solution which works literally with all kinds of embedded content and can even be extended in the backend. I also like the possibility to use preview images which are cached, so visitors have a glimpse what they could see without compromising their privacy. Good work!
29 Qershor, 2023
Ein ganz tolles Plugin, leicht zu installieren und um iFrames DSGVO-konform in die Wordpress Seite einzubetten perfekt! Vielen Dank!
24 Prill, 2023
Especially love the “local tweets” feature where tweets are embedded locally as text without any connection to Twitter, and no privacy overlay is required.
Lexojini krejt 20 shqyrtimet

Kontribues & Zhvillues

“Embed Privacy” është software me burim të hapur. Në këtë shtojcë kanë dhënë ndihmesë personat vijues.


“Embed Privacy” është përkthyer në 4 gjuhë. Faleminderit përkthyesve për ndihmesën e tyre.

Përkthejeni “Embed Privacy” në gjuhën tuaj.

Ju intereson zhvillimi?

Shfletoni kodin, shkarkoni depon SVN, ose pajtohuni përmes RSS-je te regjistri i zhvillimeve.

Regjistër ndryshimesh


  • Fixed an error while uninstalling the plugin
  • Fixed aspect ratio of embeds embedded via Divi
  • Fixed spelling of “SlideShare”


  • Added support for thumbnails for WordPress TV
  • Added filter to filter embed arguments
  • Added filter to ignore certain embeds
  • Improved style generation to improve performance and fix HTML validation
  • Improved script loading by using defer attributes
  • Fixed certain fields deleted after changing embed provider to draft
  • Fixed URL encoding after replacements


  • Fixed the output of the opt-out shortcode (thanks wpdabh for reporting)


  • Added support for Anghami
  • Added filter to prevent thumbnail orphan deletion
  • Added check for PHP DOM extension
  • Improved loading embed providers


  • Improved compatibility with Advanced Custom Fields
  • Fixed compatibility with PHP 8.2
  • Fixed a potential PHP warning if a post does not exist while checking permissions
  • Fixed functionality of the opt-out shortcode if the current website uses a non-standard port
  • Fixed replacing only the necessary part of embedded contents for custom embeds
  • Fixed replacing all occurrences of a custom embed in the current content
  • Fixed multiple unnecessary database queries in migration before the actual check whether a migration is necessary
  • Fixed downloading the thumbnail multiple times when the same embed is embedded multiple times
  • Fixed deleted thumbnails if they are only in content of Advanced Custom Fields
  • Fixed a potential security issue regarding disclosing absolute paths in thumbnail URLs (special thanks to @kraftner)
  • Fixed aspect ratio generation if width or height contains a percentage sign
  • Fixed thumbnail positioning (it’s now horizontally and vertically centered)
  • Fixed HTML output of the opt-out shortcode


  • Fixed getting the URL of video shortcodes properly to not block content from the same (sub)domain


  • Improved Google Maps height in Kadence Blocks
  • Fixed a JavaScript error if jQuery is not initialized
  • Fixed potential PHP warning regarding an undefined variable
  • Fixed potential PHP warning regarding an undefined hostname while retrieving the embed URL


  • Added support for crowdsignal.net
  • Added support for classic video shortcode/widget
  • Added support for SlideShare thumbnails (thanks to @Lazza)
  • Added support for custom thumbnail generation via filter
  • Fixed hiding thumbnails after embedded content has been enabled
  • Fixed aspect ratio for embeds without proper dimension information


  • Fixed aspect ratio for non-default content width themes
  • Fixed handling of the % character


  • Fixed aspect ratio for many oEmbeds


  • Fixed replacing some oEmbeds
  • Fixed potential problems while retrieving a single embed provider
  • Fixed deleting post metadata of embed providers while editing them via WP-CLI


  • Restore displaying YouTube thumbnails


  • Updated required WordPress version to 5.0
  • Fixed text links to youtube.com
  • Fixed Twitter embeds


  • Added automatic detection of aspect ratio if given by the embed
  • Added ability to work with HTML of regular oEmbed providers
  • Added filter to ignore shortcodes (see documentation)
  • Added matching links to the new documentation at https://epiph.yt/en/embed-privacy/documentation/
  • Improved handling of matching non-standard elements (embed, iframe, object, see documentation)
  • Fixed Google Maps regex pattern after installation
  • Fixed behavior of the opt-out shortcode with enabled page caching
  • Fixed line-height of custom embeds in Elementor
  • General code improvements


  • Fixed storing and displaying video thumbnails from Vimeo that are embedded using the domain player.vimeo.com
  • Fixed unnecessary line breaks within the classic editor
  • Fixed displaying the overlay if an embed of a known embed provider followed an embed of an unknown embed provider
  • Fixed uninstallation issues


  • Added support for embed provider Pocket Casts
  • Added support for Maps Marker and Maps Marker Pro
  • Added support for Google Maps in Shortcodes Ultimate
  • Added support to automatically download and display a thumbnail of the embed for Vimeo and YouTube (only in posts)
  • Added support to re-initiate the database migration and display an error message if it has been failed at least three times
  • Added support for Polylang and Polylang Pro
  • Added a new filter to allow stopping Embed Privacy from handling unknown embeds
  • Added option to disable the direct link in the overlay
  • Updated logos for Reddit, SmugMug and SoundCloud for better readability
  • Use the plugin version as parameter for assets to allow better caching and prevent problems with some setups
  • General code improvements
  • Fixed a JavaScript error


  • Fixed an issue with always active providers being cached by page caching plugins
  • Fixed printing inline JavaScript only once


  • Fixed displaying embeds on mobile devices while using Divi
  • Fixed the output of assets
  • Improved regular expression for Google Maps


  • Fixed an issue where JavaScript assets may be missing for the opt-out shortcode


  • Fixed an issue with always enable an unknown embed provider
  • Fixed issues with missing JavaScript for Facebook embed of Jetpack


  • Fixed a potential encoding issue
  • Fixed issues with Facebook embed of Jetpack
  • Fixed issues with registering assets


  • Fixed a problem that prevents embed fields from being stored


  • Fixed an expired link during plugin activation and creating a new embed provider


  • Fixed invalid HTML by changing the accessibility behavior (it’s now a separate button)
  • Fixed potential empty link titles in other locales then English
  • Fixed potential unwanted URL encoding in the content after Embed Privacy replaced an embed


  • Added support for Pinterest and Wolfram Cloud
  • Improved migrations to fix duplicate providers or performance problems in multisite installations
  • Embeds can now be enabled via keyboard
  • Added a link to the original content on the bottom right overlay corner
  • Added support for caching the opt-out shortcode
  • Clicking on the “always enable content of X” enables all embeds of this provider on the current page immediately
  • Improved markup of local tweets
  • Added additional class to checkbox paragraph, thanks to @florianbrinkmann
  • System providers cannot be deleted anymore
  • Fixed oEmbed provider name if the provider is unknown
  • Fix enqueuing assets for unknown embed providers


  • Fixed enabling multiple YouTube videos in Elementor
  • Fixed displaying content if the page contains an always active provider


  • Fixed functionality in Elementor
  • Fixed custom embed provider output
  • Fixed replacing content in shortcodes multiple times
  • Fixed checking for theme/template


  • Fixed deleted meta fields if you put an embed provider in trash and restore it afterwards
  • Fixed Embed Privacy sometimes trying to replace an embed twice
  • Fixed an error that may occur if Embed Privacy tries to replace an embed that doesn’t need to be replaced
  • Fixed checking for local domain if WordPress itself is located in a sub-domain
  • Fixed always enable YouTube within Divi
  • Fixed overlay line height in Divi


  • Improved mobile design for responsive embeds
  • Fixed centering for non-responsive embeds
  • Fixed disabled embed content from preventing interactions with the text below the overlay


  • Fixed general activation error


  • Fixed a fatal error on uninstallation on non-multisite
  • Fixed activating via WP-CLI
  • Fixed deleting an option on uninstallation


  • Added local tweets without overlay
  • Added option to preserve data on uninstall
  • Added compatibility with theme Astra
  • Added filter embed_privacy_markup for filtering the whole markup of an embed overlay
  • Added proper support for embeds on the current domain
  • Added support for embeds on other elements than embed, iframe and object
  • Enqueue assets only if needed
  • Removed images from media (which had been added in version 1.2.0) and use fallback images for default embed providers
  • Improved regular expression for Google Maps
  • Improved texts for clarity
  • Fixed visibility of custom post type
  • Fixed network-wide activation
  • Fixed clearing oEmbed cache


  • Added a check if a migration is already running
  • Fixed a bug where the page markup could be changed unexpectedly
  • <object> elements are now replaced correctly
  • Added a missing textdomain to a string
  • Excluded local embeds (with the same domain)
  • Fixed Amazon Kindle regex being too greedy


  • Fixed a bug where the page markup could be changed unexpectedly
  • Fixed a warning if an embed provider has no regular expressions
  • Improved migrations of embed provider metadata to make sure they have been added to the database


  • Added support for managing embeds (add/remove/edit/disable)
  • Added support for caching plugins by adding a JavaScript detection for always active embed providers
  • Added CSS classes that indicate the current state of the embed (is-disabled/is-enabled)
  • Added shortcode [embed_privacy_opt_out] to allow users to opt-out/in
  • Fixed responsive design if the embed added an own width


  • U ndryshua emër furnizuesi nga Polldaddy në Crowdsignal
  • U hoq furnizuesi Hulu


  • U ndreq një ndryshim i mundshëm te emri i klasës së përdorur të furnizuesit të trupëzimit në HTML dhe CSS


  • U hoq furnizuesi CollegeHumor
  • U ndreq një e metë te shtimi i vetvetishëm i paragrafëve


  • U shtua mundësia për të lejuar krejt trupëzimet nga një furnizues
  • U shtua furnizuesi TikTok, sjellë për herë të parë me WordPress 5.4
  • U shtua mbulim për iframes nga Google Maps
  • U shtua URL rewrite te youtube-nocookie.com
  • U shtua mundësi për të ruajtur përzgjedhje përdoruesi për furnizues trupëzimi
  • U shtua stemë furnizuesi te vendmbajtësi ynë
  • U shtua mundësi për filtrim markup-in tonë për vendmbajtëse
  • U shtua mbulim për klasat Gutenberg ‘alignwide’ dhe ‘alignfull’
  • U shtua mbulim për përdorim të mekanizmit tonë embedding overlay nga zhvillues të jashtëm
  • U përmirësua markup-i ynë për vendmbajtëse, për të qenë faktikisht semantik
  • U ndryshuan klasat .embed- në .embed-privacy-
  • U ndreqën disa furnizues trupëzimesh që përdorin z-index të përshtatur, çka sjell që lënda e trupëzuar të jetë mbi shtresën përsipër
  • U ndreqën gabime shkrimi


  • Përmirësim i përputhshmërisë me Autoptimize
  • Përmirësim i përputhshmërisë me AMP
  • Fix issue with SlideShare causing wrong (generic) placeholders


  • Ndreqje mbulimi të PHP 5.6


  • Hedhje fillestare në qarkullim