diff --git a/README.md b/README.md index cbbd50bc..3e20cf83 100644 --- a/README.md +++ b/README.md @@ -3,9 +3,9 @@ **Contributors:** wpengine, deliciousbrains, ianmjones, eriktorsner, kevinwhoffman, tysonreeder, dalewilliams, lewisia32, mattshaw, aaemnnosttv, a5hleyrich, polevaultweb, bradt, joetan \ **Tags:** uploads, amazon, s3, amazon s3, digitalocean, digitalocean spaces, google cloud storage, gcs, mirror, admin, media, cdn, cloudfront \ **Requires at least:** 5.5 \ -**Tested up to:** 6.4 \ +**Tested up to:** 6.6 \ **Requires PHP:** 7.2 \ -**Stable tag:** 3.2.7 \ +**Stable tag:** 3.2.8 \ **License:** GPLv3 Copies files to Amazon S3, DigitalOcean Spaces or Google Cloud Storage as they are uploaded to the Media Library. Optionally configure Amazon CloudFront or another CDN for faster delivery. @@ -103,6 +103,11 @@ This version requires PHP 5.3.3+ and the Amazon Web Services plugin ## Changelog +### WP Offload Media Lite 3.2.8 - 2024-07-11 + +* Delivery status indicator is now more accurate when Amazon S3 Object Ownership is configured in combination with a delivery provider other than Amazon CloudFront +* Corrupt `_wp_attachment_metadata` no longer causes a fatal error when offloading media + ### WP Offload Media Lite 3.2.7 - 2024-02-13 * New: Amazon S3 regions Canada West (Calgary), Asia Pacific (Melbourne) and Israel (Tel Aviv) are now selectable diff --git a/classes/amazon-s3-and-cloudfront.php b/classes/amazon-s3-and-cloudfront.php index ec5053dd..d26ba5f4 100644 --- a/classes/amazon-s3-and-cloudfront.php +++ b/classes/amazon-s3-and-cloudfront.php @@ -3940,9 +3940,15 @@ public function media_counts( bool $skip_transient = false, bool $force = false, } } + // Let other parts of the plugin add/update the media counts on a per-blog basis. + $attachment_counts = apply_filters( 'as3cf_media_counts_for_blog', $attachment_counts, $blog_id, $table_prefix ); + $this->restore_current_blog(); } + // Let other parts of the plugin add/update the complete media counts. + $attachment_counts = apply_filters( 'as3cf_media_counts', $attachment_counts ); + ksort( $attachment_counts ); // Large site defaults to transient timeout of 5 minutes. diff --git a/classes/as3cf-utils.php b/classes/as3cf-utils.php index e6f74965..5dfb7c3a 100644 --- a/classes/as3cf-utils.php +++ b/classes/as3cf-utils.php @@ -1036,7 +1036,7 @@ private static function is_base64( string $data ): bool { * * @return bool */ - private static function is_json( string $value ): bool { + public static function is_json( string $value ): bool { $is_json = false; if ( 0 < strlen( trim( $value ) ) && ! is_numeric( $value ) && null !== json_decode( $value ) ) { diff --git a/classes/items/media-library-item.php b/classes/items/media-library-item.php index 8dce16a4..b0606f61 100644 --- a/classes/items/media-library-item.php +++ b/classes/items/media-library-item.php @@ -623,7 +623,7 @@ public function update_filesize_after_remove_local( $original_size, $total_size update_post_meta( $this->source_id(), 'as3cf_filesize_total', $total_size ); if ( 0 < $original_size && ( $data = get_post_meta( $this->source_id(), '_wp_attachment_metadata', true ) ) ) { - if ( empty( $data['filesize'] ) ) { + if ( is_array( $data ) && empty( $data['filesize'] ) ) { $data['filesize'] = $original_size; // Update metadata with filesize diff --git a/classes/providers/delivery/delivery-provider.php b/classes/providers/delivery/delivery-provider.php index e446fb26..ff1f0520 100644 --- a/classes/providers/delivery/delivery-provider.php +++ b/classes/providers/delivery/delivery-provider.php @@ -621,12 +621,19 @@ public static function get_cannot_access_private_file_desc( string $error_messag * @return string */ public static function get_unsigned_url_can_access_private_file_desc(): string { - return sprintf( - __( - 'Private media is currently exposed through unsigned URLs. Restore privacy by verifying the configuration of private media settings. Read more', - 'amazon-s3-and-cloudfront' - ), - static::get_provider_service_quick_start_url() + global $as3cf; + + $storage_provider = $as3cf->get_storage_provider(); + + return apply_filters( + 'as3cf_get_unsigned_url_can_access_private_file_desc_' . $storage_provider->get_provider_key_name(), + sprintf( + __( + 'Delivery provider is connected, but private media is currently exposed through unsigned URLs. Restore privacy by verifying the configuration of private media settings. Read more', + 'amazon-s3-and-cloudfront' + ), + static::get_provider_service_quick_start_url() + ) ); } @@ -721,21 +728,6 @@ public function validate_settings( bool $force = false ): AS3CF_Result { ); } - // Object Ownership Policies enabled? - if ( ! static::object_ownership_supported() && $storage_provider->object_ownership_supported() && $storage_provider->object_ownership_enforced( $bucket ) ) { - return new AS3CF_Result( - Validator_Interface::AS3CF_STATUS_MESSAGE_ERROR, - sprintf( - _x( - 'Offloaded media cannot be delivered due to the current Object Ownership configuration. Edit bucket security', - 'Delivery setting notice for issue with Object Ownership enforced on Storage Provider', - 'amazon-s3-and-cloudfront' - ), - '#/storage/security' - ) - ); - } - $delivery_domain_settings = $this->validate_delivery_domain(); if ( Validator_Interface::AS3CF_STATUS_MESSAGE_SUCCESS !== $delivery_domain_settings->get_error_code() ) { return $delivery_domain_settings; diff --git a/classes/providers/storage/aws-provider.php b/classes/providers/storage/aws-provider.php index 6c60876d..ca493517 100644 --- a/classes/providers/storage/aws-provider.php +++ b/classes/providers/storage/aws-provider.php @@ -200,6 +200,47 @@ public function __construct( \AS3CF_Plugin_Base $as3cf ) { if ( ! function_exists( 'idn_to_ascii' ) && ! defined( 'IDNA_DEFAULT' ) ) { define( 'IDNA_DEFAULT', 0 ); } + + add_filter( + 'as3cf_get_unsigned_url_can_access_private_file_desc_aws', + array( $this, 'get_unsigned_url_can_access_private_file_desc' ) + ); + } + + /** + * Optionally modify the description for the "Can access private file" warning from the delivery provider + * validation if OOE is enabled on the current bucket. + * + * @handles as3cf_get_unsigned_url_can_access_private_file_desc_aws + * + * @param string $message + * + * @return string + */ + public function get_unsigned_url_can_access_private_file_desc( $message ): string { + $bucket = $this->as3cf->get_setting( 'bucket' ); + $region = $this->as3cf->get_setting( 'region' ); + + // Return default message if no bucket is defined. + if ( empty( $bucket ) ) { + return $message; + } + + // Ensure we have a valid client. + $this->get_client( array( 'region' => $region ) ); + + // Return default message if OOE not enabled. + if ( ! $this->object_ownership_enforced( $bucket ) ) { + return $message; + } + + return sprintf( + __( + 'Delivery provider is connected, but private media is currently exposed through unsigned URLs. Because Object Ownership is enforced on the bucket, access can only be controlled by editing the Amazon S3 bucket policy or by using a CDN that supports private media. Read more', + 'amazon-s3-and-cloudfront' + ), + static::get_provider_service_quick_start_url() . '#object-ownership' + ); } /** diff --git a/languages/amazon-s3-and-cloudfront-en.pot b/languages/amazon-s3-and-cloudfront-en.pot index b5234849..cc711b3a 100644 --- a/languages/amazon-s3-and-cloudfront-en.pot +++ b/languages/amazon-s3-and-cloudfront-en.pot @@ -2,14 +2,14 @@ # # This file is distributed under the same license as the amazon-s3-and-cloudfront package. msgid "" msgstr "" -"Project-Id-Version: amazon-s3-and-cloudfront 3.2.7\n" +"Project-Id-Version: amazon-s3-and-cloudfront 3.2.8\n" "Report-Msgid-Bugs-To: mailto:nom@deliciousbrains.com\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: 8bit\n" -"POT-Creation-Date: 2024-02-13T11:02:13+00:00\n" +"POT-Creation-Date: 2024-07-11T09:21:29+00:00\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "X-Generator: WP-CLI 2.9.0\n" "X-Domain: amazon-s3-and-cloudfront\n" @@ -41,7 +41,7 @@ msgstr "" #: classes/amazon-s3-and-cloudfront.php:570 #: classes/amazon-s3-and-cloudfront.php:587 -#: classes/amazon-s3-and-cloudfront.php:4632 +#: classes/amazon-s3-and-cloudfront.php:4638 msgid "Unknown" msgstr "" @@ -243,7 +243,7 @@ msgid "No" msgstr "" #: classes/amazon-s3-and-cloudfront.php:2295 -#: classes/amazon-s3-and-cloudfront.php:4184 +#: classes/amazon-s3-and-cloudfront.php:4190 msgctxt "Help icon alt text" msgid "Click to view help doc on our site" msgstr "" @@ -924,47 +924,47 @@ msgstr "" msgid "Missing Table — One or more required database tables are missing, please check the Diagnostic Info in the Support tab for details. %s" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4032 +#: classes/amazon-s3-and-cloudfront.php:4038 msgid "WP Offload Media Activation" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4033 +#: classes/amazon-s3-and-cloudfront.php:4039 msgid "WP Offload Media Lite and WP Offload Media cannot both be active. We've automatically deactivated WP Offload Media Lite." msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4035 +#: classes/amazon-s3-and-cloudfront.php:4041 msgid "WP Offload Media Lite Activation" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4036 +#: classes/amazon-s3-and-cloudfront.php:4042 msgid "WP Offload Media Lite and WP Offload Media cannot both be active. We've automatically deactivated WP Offload Media." msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4101 +#: classes/amazon-s3-and-cloudfront.php:4107 msgid "More info" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4245 +#: classes/amazon-s3-and-cloudfront.php:4251 msgid "WP Offload Media Feature Removed" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4246 +#: classes/amazon-s3-and-cloudfront.php:4252 msgid "You had the \"Always non-SSL\" option selected in your settings, but we've removed this option in version 1.3. We'll now use HTTPS when the request is HTTPS and regular HTTP when the request is HTTP. This should work fine for your site, but please take a poke around and make sure things are working ok. See %s for more details on why we did this and how you can revert back to the old behavior." msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4438 +#: classes/amazon-s3-and-cloudfront.php:4444 msgid "Amazon Web Services Plugin No Longer Required — As of version 1.6 of WP Offload Media, the Amazon Web Services plugin is no longer required. We have removed the dependency by bundling a small portion of the AWS SDK into WP Offload Media. As long as none of your other active plugins or themes depend on the Amazon Web Services plugin, it should be safe to deactivate and delete it. %2$s" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4470 +#: classes/amazon-s3-and-cloudfront.php:4476 msgid "WP Offload Media Settings Moved — You now define your AWS keys for WP Offload Media in the new Settings tab. Saving settings in the form below will have no effect on WP Offload Media. %2$s" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4783 +#: classes/amazon-s3-and-cloudfront.php:4789 msgid "Upgrade to offload %d remaining media item" msgstr "" -#: classes/amazon-s3-and-cloudfront.php:4785 +#: classes/amazon-s3-and-cloudfront.php:4791 msgid "Upgrade to offload %d remaining media items" msgstr "" @@ -1396,37 +1396,32 @@ msgstr "" msgid "Private offloaded media URLs may be broken. %1$s Read more" msgstr "" -#: classes/providers/delivery/delivery-provider.php:625 -msgid "Private media is currently exposed through unsigned URLs. Restore privacy by verifying the configuration of private media settings. Read more" +#: classes/providers/delivery/delivery-provider.php:631 +msgid "Delivery provider is connected, but private media is currently exposed through unsigned URLs. Restore privacy by verifying the configuration of private media settings. Read more" msgstr "" -#: classes/providers/delivery/delivery-provider.php:702 +#: classes/providers/delivery/delivery-provider.php:709 msgid "Delivery of offloaded media cannot be tested until the storage provider is successfully connected. See \"Storage Settings\" for more information." msgstr "" -#: classes/providers/delivery/delivery-provider.php:714 +#: classes/providers/delivery/delivery-provider.php:721 msgctxt "Delivery setting notice for issue with BAPA enabled on Storage Provider" msgid "Offloaded media cannot be delivered because Block All Public Access is enabled. Edit bucket security" msgstr "" -#: classes/providers/delivery/delivery-provider.php:729 -msgctxt "Delivery setting notice for issue with Object Ownership enforced on Storage Provider" -msgid "Offloaded media cannot be delivered due to the current Object Ownership configuration. Edit bucket security" -msgstr "" - -#: classes/providers/delivery/delivery-provider.php:785 +#: classes/providers/delivery/delivery-provider.php:777 msgid "An invalid delivery provider has been defined for the active storage provider. Please use %1$s." msgstr "" -#: classes/providers/delivery/delivery-provider.php:812 +#: classes/providers/delivery/delivery-provider.php:804 msgid "Delivery provider is successfully connected, but offloaded media will not be served until Deliver Offloaded Media is enabled. In the meantime, local media is being served if available." msgstr "" -#: classes/providers/delivery/delivery-provider.php:840 +#: classes/providers/delivery/delivery-provider.php:832 msgid "Offloaded media cannot be delivered from the CDN until a delivery domain is set. Read more" msgstr "" -#: classes/providers/delivery/delivery-provider.php:856 +#: classes/providers/delivery/delivery-provider.php:848 msgid "Offloaded media URLs may be broken due to an invalid delivery domain. %1$s How to set a delivery domain" msgstr "" @@ -1478,72 +1473,76 @@ msgctxt "Default provider console link text" msgid "Provider Console" msgstr "" -#: classes/providers/storage/aws-provider.php:251 +#: classes/providers/storage/aws-provider.php:238 +msgid "Delivery provider is connected, but private media is currently exposed through unsigned URLs. Because Object Ownership is enforced on the bucket, access can only be controlled by editing the Amazon S3 bucket policy or by using a CDN that supports private media. Read more" +msgstr "" + +#: classes/providers/storage/aws-provider.php:292 msgid "Media cannot be offloaded due to an invalid Access Key ID. Update access keys" msgstr "" -#: classes/providers/storage/aws-provider.php:258 +#: classes/providers/storage/aws-provider.php:299 msgid "Media cannot be offloaded due to an invalid Secret Access Key. Update access keys" msgstr "" -#: classes/providers/storage/aws-provider.php:267 +#: classes/providers/storage/aws-provider.php:308 msgid "The bucket name already exists in your account. To confirm you'd like to use it, please select \"Use Existing Bucket\". Alternatively, enter a different bucket name." msgstr "" -#: classes/providers/storage/aws-provider.php:274 +#: classes/providers/storage/aws-provider.php:315 msgid "The bucket name already exists in another account. Please enter a different bucket name." msgstr "" -#: classes/providers/storage/aws-provider.php:282 +#: classes/providers/storage/aws-provider.php:323 #: classes/providers/storage/gcp-provider.php:862 msgid "Media cannot be offloaded because a bucket with the configured name does not exist. Enter a different bucket" msgstr "" -#: classes/providers/storage/aws-provider.php:292 +#: classes/providers/storage/aws-provider.php:333 msgid "Media cannot be offloaded because the bucket name is not valid. Enter a different bucket name." msgstr "" -#: classes/providers/storage/aws-provider.php:914 +#: classes/providers/storage/aws-provider.php:955 msgid "If you're following our documentation on setting up Amazon CloudFront for delivery, you can ignore this warning and continue.
If you're not planning on using Amazon CloudFront for delivery, you need to disable Block All Public Access." msgstr "" -#: classes/providers/storage/aws-provider.php:920 +#: classes/providers/storage/aws-provider.php:961 #: classes/providers/storage/storage-provider.php:792 msgctxt "warning heading" msgid "Block All Public Access is Enabled" msgstr "" -#: classes/providers/storage/aws-provider.php:933 +#: classes/providers/storage/aws-provider.php:974 msgid "Block All Public Access should only been enabled when Amazon CloudFront is configured for delivery." msgstr "" -#: classes/providers/storage/aws-provider.php:959 +#: classes/providers/storage/aws-provider.php:1000 msgid "If you're following our documentation on setting up Amazon CloudFront for delivery, you can ignore this warning and continue. If you're not planning on using Amazon CloudFront for delivery, you need to disable Block All Public Access." msgstr "" -#: classes/providers/storage/aws-provider.php:973 +#: classes/providers/storage/aws-provider.php:1014 msgid "Since you're not using Amazon CloudFront for delivery, we recommend you keep Block All Public Access disabled unless you have a very good reason to enable it." msgstr "" -#: classes/providers/storage/aws-provider.php:996 +#: classes/providers/storage/aws-provider.php:1037 msgid "If you're following our documentation on setting up Amazon CloudFront for delivery, you can ignore this warning and continue.
If you're not planning on using Amazon CloudFront for delivery, you need to turn off Object Ownership enforcement." msgstr "" -#: classes/providers/storage/aws-provider.php:1002 +#: classes/providers/storage/aws-provider.php:1043 #: classes/providers/storage/storage-provider.php:806 msgctxt "warning heading" msgid "Object Ownership is Enforced" msgstr "" -#: classes/providers/storage/aws-provider.php:1015 +#: classes/providers/storage/aws-provider.php:1056 msgid "Object Ownership should only been enforced when Amazon CloudFront is configured for delivery." msgstr "" -#: classes/providers/storage/aws-provider.php:1041 +#: classes/providers/storage/aws-provider.php:1082 msgid "If you're following our documentation on setting up Amazon CloudFront for delivery, you can ignore this warning and continue.
If you're not planning on using Amazon CloudFront for delivery, you need to edit the bucket's Object Ownership setting and enable ACLs or add a Bucket Policy." msgstr "" -#: classes/providers/storage/aws-provider.php:1056 +#: classes/providers/storage/aws-provider.php:1097 msgid "Since you're not using Amazon CloudFront for delivery, we recommend you do not enforce Object Ownership unless you have a very good reason to do so." msgstr "" diff --git a/readme.txt b/readme.txt index 988d7434..b56a4216 100644 --- a/readme.txt +++ b/readme.txt @@ -2,9 +2,9 @@ Contributors: wpengine, deliciousbrains, ianmjones, eriktorsner, kevinwhoffman, tysonreeder, dalewilliams, lewisia32, mattshaw, aaemnnosttv, a5hleyrich, polevaultweb, bradt, joetan Tags: uploads, amazon, s3, amazon s3, digitalocean, digitalocean spaces, google cloud storage, gcs, mirror, admin, media, cdn, cloudfront Requires at least: 5.5 -Tested up to: 6.4 +Tested up to: 6.6 Requires PHP: 7.2 -Stable tag: 3.2.7 +Stable tag: 3.2.8 License: GPLv3 Copies files to Amazon S3, DigitalOcean Spaces or Google Cloud Storage as they are uploaded to the Media Library. Optionally configure Amazon CloudFront or another CDN for faster delivery. @@ -85,6 +85,10 @@ This version requires PHP 5.3.3+ and the Amazon Web Services plugin == Changelog == += WP Offload Media Lite 3.2.8 - 2024-07-11 = +* Delivery status indicator is now more accurate when Amazon S3 Object Ownership is configured in combination with a delivery provider other than Amazon CloudFront +* Corrupt `_wp_attachment_metadata` no longer causes a fatal error when offloading media + = WP Offload Media Lite 3.2.7 - 2024-02-13 = * New: Amazon S3 regions Canada West (Calgary), Asia Pacific (Melbourne) and Israel (Tel Aviv) are now selectable * New: DigitalOcean region Bangalore (BLR1) is now selectable diff --git a/wordpress-s3.php b/wordpress-s3.php index 67ae98b3..740bac17 100644 --- a/wordpress-s3.php +++ b/wordpress-s3.php @@ -4,7 +4,7 @@ Plugin URI: http://wordpress.org/extend/plugins/amazon-s3-and-cloudfront/ Description: Automatically copies media uploads to Amazon S3, DigitalOcean Spaces or Google Cloud Storage for storage and delivery. Optionally configure Amazon CloudFront or another CDN for even faster delivery. Author: Delicious Brains -Version: 3.2.7 +Version: 3.2.8 Author URI: https://deliciousbrains.com/?utm_campaign=WP%2BOffload%2BS3&utm_source=wordpress.org&utm_medium=free%2Bplugin%2Blisting Network: True Text Domain: amazon-s3-and-cloudfront @@ -28,7 +28,7 @@ // phpcs:disable SlevomatCodingStandard.Variables.UnusedVariable -$GLOBALS['aws_meta']['amazon-s3-and-cloudfront']['version'] = '3.2.7'; +$GLOBALS['aws_meta']['amazon-s3-and-cloudfront']['version'] = '3.2.8'; require_once dirname( __FILE__ ) . '/classes/as3cf-compatibility-check.php';