Adds a new 'S3-Compatible Storage' provider that works with any
S3-API-compatible object storage service, including MinIO, Ceph,
Cloudflare R2, Backblaze B2, and others.
Changes:
- New provider class: classes/providers/storage/s3-compatible-provider.php
- Provider key: s3compatible
- Reads user-configured endpoint URL from settings
- Uses path-style URL access (required by most S3-compatible services)
- Supports credentials via AS3CF_S3COMPAT_ACCESS_KEY_ID /
AS3CF_S3COMPAT_SECRET_ACCESS_KEY wp-config.php constants
- Disables AWS-specific features (Block Public Access, Object Ownership)
- New provider SVG icons (s3compatible.svg, -link.svg, -round.svg)
- Registered provider in main plugin class with endpoint setting support
- Updated StorageProviderSubPage to show endpoint URL input for S3-compatible
- Built pro settings bundle with rollup (Svelte 4.2.19)
- Added package.json and updated rollup.config.mjs for pro-only builds
52 lines
2.4 KiB
PHP
52 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace DeliciousBrains\WP_Offload_Media\Aws3\Aws\S3\Crypto;
|
|
|
|
use DeliciousBrains\WP_Offload_Media\Aws3\Aws\Crypto\MaterialsProvider;
|
|
use DeliciousBrains\WP_Offload_Media\Aws3\Aws\Crypto\MetadataEnvelope;
|
|
use DeliciousBrains\WP_Offload_Media\Aws3\Aws\Crypto\MetadataStrategyInterface;
|
|
trait CryptoParamsTrait
|
|
{
|
|
protected function getMaterialsProvider(array $args)
|
|
{
|
|
if ($args['@MaterialsProvider'] instanceof MaterialsProvider) {
|
|
return $args['@MaterialsProvider'];
|
|
}
|
|
throw new \InvalidArgumentException('An instance of MaterialsProvider' . ' must be passed in the "MaterialsProvider" field.');
|
|
}
|
|
protected function getInstructionFileSuffix(array $args)
|
|
{
|
|
return !empty($args['@InstructionFileSuffix']) ? $args['@InstructionFileSuffix'] : $this->instructionFileSuffix;
|
|
}
|
|
protected function determineGetObjectStrategy($result, $instructionFileSuffix)
|
|
{
|
|
if (isset($result['Metadata'][MetadataEnvelope::CONTENT_KEY_V2_HEADER])) {
|
|
return new HeadersMetadataStrategy();
|
|
}
|
|
return new InstructionFileMetadataStrategy($this->client, $instructionFileSuffix);
|
|
}
|
|
protected function getMetadataStrategy(array $args, $instructionFileSuffix)
|
|
{
|
|
if (!empty($args['@MetadataStrategy'])) {
|
|
if ($args['@MetadataStrategy'] instanceof MetadataStrategyInterface) {
|
|
return $args['@MetadataStrategy'];
|
|
}
|
|
if (\is_string($args['@MetadataStrategy'])) {
|
|
switch ($args['@MetadataStrategy']) {
|
|
case HeadersMetadataStrategy::class:
|
|
return new HeadersMetadataStrategy();
|
|
case InstructionFileMetadataStrategy::class:
|
|
return new InstructionFileMetadataStrategy($this->client, $instructionFileSuffix);
|
|
default:
|
|
throw new \InvalidArgumentException('Could not match the' . ' specified string in "MetadataStrategy" to a' . ' predefined strategy.');
|
|
}
|
|
} else {
|
|
throw new \InvalidArgumentException('The metadata strategy that' . ' was passed to "MetadataStrategy" was unrecognized.');
|
|
}
|
|
} elseif ($instructionFileSuffix) {
|
|
return new InstructionFileMetadataStrategy($this->client, $instructionFileSuffix);
|
|
}
|
|
return null;
|
|
}
|
|
}
|