• Overall the plugin does what I need, however, because you cannot adjust the name of the image, facebook refuses to refresh the image. Here is the metatag:

    <meta property="og:image" content="https://thebluethingy.com/social-image.jpg/">

    It would help if we had the option of changing the filename from “social-image.jpg” to anything else. I changed the image and facebook will not release it’s cached “social-image.jpg”.

    For now, I ended up adjusting the following line in branded-social-images\lib\class.og-image-plugin.php myself.

    const BSI_IMAGE_NAME = 'social-image';

    Thanks for the effort.

    • This topic was modified 1 year, 1 month ago by jglazer63.
    • This topic was modified 1 year, 1 month ago by jglazer63.
    • This topic was modified 1 year, 1 month ago by jglazer63.
Viewing 5 replies - 1 through 5 (of 5 total)
  • Hi @jglazer63

    The caching at Facebook is indeed a great annoyance.

    Changing the file-name will not help you. Well, it would, but it’s not an easy thing to do; The filename is not a filename per-sé, it could also be ‘hello-world’ or ‘19234o8734’. The URL used for the images is a URL-endpoint and those are static as they are saved in the WordPress Rewrite Rules. If you change it now to ‘social-image-2’, all the other cached URLs no longer work. What would be needed is a dynamic URL.

    This cannot be achieved using WordPress’ add_rewrite_endpoint function. This does not mean it cannot be done, there are ways to make a dynamic endpoint, namely using custom rewrite rules, but I’d rather stick to WordPress functionality to keep the plugin understandable for other developers.

    There is an alternative, and, as it turns out, your question has been asked before; https://www.ads-software.com/support/topic/request-add-timestamps-or-random-string-to-image-urls/

    With an MU-Plugin or an addition to the functions.php of your theme, you can Implement a filter like this:

    add_filter('bsi_image_url', function($url) { return add_query_arg('_', time(), $url); });

    This will add a URL parameter with the timestamp to the image URL, which most probably will solve the caching issue. This is not the default plugin behaviour as it will essentially disable caching entirely.

    As to your remark on the trailing slash being a problem; well, it’s not. It never has been and because the plugin uses default WordPress functionality, it never will be. As indicated above, the filename is not a real filename. it’s just an endpoint identifier, it could be anything. But, in true WordPress fashion, the trailing slash is unavoidable.

    Using the bsi_image_url filter, you can remove the trailing slash (combined with adding the cachebuster parameter);

    add_filter('bsi_image_url', function($url) { return add_query_arg('_', time(), untrailingslashit($url) ); });

    (or just the slash removal)

    add_filter('bsi_image_url', function($url) { return untrailingslashit($url); });

    These URLs without trailing slash will work, but because of WordPress requiring the trailing slash, this will result in a redirect to the same URL _with_ a trailing slash. Your URLs may look better in the webpage source HTML, but the performance will be worse because of the inevitable redirect.

    Using a completely custom endpoint handling it is possible to remove the trailing slash entirely, but then we run the risk of breaking in a future WordPress update, so I choose to stay 100% WordPress compatible, consequence being that the annoying trailing slash will stay. Unfortunately.

    Thread Starter jglazer63

    (@jglazer63)

    Actually changing the filename is all you need to expose. Allowing us to adjust the filename as we wish would eliminate the cache issue. All you need is to expose this variable:

    const BSI_IMAGE_NAME = 'social-image';

    I changed this line to:

    const BSI_IMAGE_NAME = 'social-image1';

    For example and it cleared up my issue instantly. It’s a one-time or two-time change as we get the image right. If this could be put into your UI as “defaultImageName” and allow us to change it, all would be fine.

    As I said, I made this adjustment so now I am fine. The plugin works as expected and all is good. Just offering this as a suggestion.

    I know, and I also explained why that is NOT a smart thing to do. Because all cached urls (at third parties) for the old name (without the 1) are broken.

    But, glad it works for you. Enjoy!

    Please mark the topic as resolved at your convenience.

    Thread Starter jglazer63

    (@jglazer63)

    Would it be possible to adjust for this feature anyhow? I am a web developer since 1997 and am familiar with the cache structure. I am concerned that if you come out with any updates it will overwrite my fix. It does work and should be at least an easy fix for everyone having this issue.

    Very sorry, but I will not implement this change as it will cause more problems than it solves.

    Yes, it will work for new images, new instances, but — for example — when a page is cached and points to …/social-image.jpg as the image and you changed the config to …/social-image2.jpg, now that cached page points to a non-working image URL.

    We had this problem already when we added the option to change output format (png versus jpg).

    My recommendation to use a cache-buster parameter stands.

    add_filter('bsi_image_url', function($url) { return add_query_arg('_', time(), $url ); });

    I do appreciate the feedback, but I have to look at the bigger picture.

Viewing 5 replies - 1 through 5 (of 5 total)
  • The topic ‘Adjustable image name’ is closed to new replies.