Skip to content

Commit

Permalink
Deploying version 3.2.8
Browse files Browse the repository at this point in the history
  • Loading branch information
eriktorsner committed Jul 11, 2024
1 parent fb3a2cc commit 28b7e99
Show file tree
Hide file tree
Showing 9 changed files with 120 additions and 73 deletions.
9 changes: 7 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Expand Down Expand Up @@ -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
Expand Down
6 changes: 6 additions & 0 deletions classes/amazon-s3-and-cloudfront.php
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Expand Down
2 changes: 1 addition & 1 deletion classes/as3cf-utils.php
Original file line number Diff line number Diff line change
Expand Up @@ -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 ) ) {
Expand Down
2 changes: 1 addition & 1 deletion classes/items/media-library-item.php
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
34 changes: 13 additions & 21 deletions classes/providers/delivery/delivery-provider.php
Original file line number Diff line number Diff line change
Expand Up @@ -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. <a href="%1$s" target="_blank">Read more</a>',
'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. <a href="%1$s" target="_blank">Read more</a>',
'amazon-s3-and-cloudfront'
),
static::get_provider_service_quick_start_url()
)
);
}

Expand Down Expand Up @@ -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 <strong>Object Ownership</strong> configuration. <a href="%1$s">Edit bucket security</a>',
'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;
Expand Down
41 changes: 41 additions & 0 deletions classes/providers/storage/aws-provider.php
Original file line number Diff line number Diff line change
Expand Up @@ -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. <a href="%1$s" target="_blank">Read more</a>',
'amazon-s3-and-cloudfront'
),
static::get_provider_service_quick_start_url() . '#object-ownership'
);
}

/**
Expand Down
87 changes: 43 additions & 44 deletions languages/amazon-s3-and-cloudfront-en.pot
Original file line number Diff line number Diff line change
Expand Up @@ -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 <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\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"
Expand Down Expand Up @@ -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 ""

Expand Down Expand Up @@ -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 ""
Expand Down Expand Up @@ -924,47 +924,47 @@ msgstr ""
msgid "<strong>Missing Table</strong> &mdash; 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&nbsp;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 "<strong>Amazon Web Services Plugin No Longer Required</strong> &mdash; As of version 1.6 of WP Offload Media, the <a href=\"%1$s\">Amazon Web Services</a> 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 "<strong>WP Offload Media Settings Moved</strong> &mdash; You now define your AWS keys for WP Offload Media in the new <a href=\"%1$s\">Settings tab</a>. 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 ""

Expand Down Expand Up @@ -1396,37 +1396,32 @@ msgstr ""
msgid "Private offloaded media URLs may be broken. %1$s <a href=\"%2$s\" target=\"_blank\">Read more</a>"
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. <a href=\"%1$s\" target=\"_blank\">Read more</a>"
#: 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. <a href=\"%1$s\" target=\"_blank\">Read more</a>"
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 <strong>Block All Public Access</strong> is enabled. <a href=\"%1$s\">Edit bucket security</a>"
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 <strong>Object Ownership</strong> configuration. <a href=\"%1$s\">Edit bucket security</a>"
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 <strong>Deliver Offloaded Media</strong> 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. <a href=\"%1$s\" target=\"_blank\">Read more</a>"
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 <a href=\"%2$s\">How to set a delivery domain</a>"
msgstr ""

Expand Down Expand Up @@ -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. <a href=\"%1$s\" target=\"_blank\">Read more</a>"
msgstr ""

#: classes/providers/storage/aws-provider.php:292
msgid "Media cannot be offloaded due to an invalid Access Key ID. <a href=\"%1$s\">Update access keys</a>"
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. <a href=\"%1$s\">Update access keys</a>"
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. <a href=\"%1$s\">Enter a different bucket</a>"
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. <a href=\"%1$s\">Enter a different bucket name</a>."
msgstr ""

#: classes/providers/storage/aws-provider.php:914
#: classes/providers/storage/aws-provider.php:955
msgid "If you're following our documentation on <a href=\"%1$s\">setting up Amazon CloudFront</a> for delivery, you can ignore this warning and continue.<br> If you're not planning on using Amazon CloudFront for delivery, you need to <a href=\"%2$s\">disable Block All Public Access</a>."
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 <a href=\"%1$s\">setting up Amazon CloudFront</a> for delivery, you can ignore this warning and continue. If you're not planning on using Amazon CloudFront for delivery, you need to <a href=\"%2$s\">disable Block All Public Access</a>."
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 <a href=\"%1$s\">setting up Amazon CloudFront</a> for delivery, you can ignore this warning and continue.<br>If you're not planning on using Amazon CloudFront for delivery, you need to <a href=\"%2$s\">turn off Object Ownership enforcement</a>."
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 <a href=\"%1$s\">setting up Amazon CloudFront</a> for delivery, you can ignore this warning and continue.<br>If you're not planning on using Amazon CloudFront for delivery, you need to edit the bucket's Object Ownership setting and <a href=\"%2$s\">enable ACLs</a> or add a <a href=\"%3$s\">Bucket Policy</a>."
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 ""

Expand Down
Loading

0 comments on commit 28b7e99

Please sign in to comment.