laravel-chronicle/kms-aws
Composer 安装命令:
composer require laravel-chronicle/kms-aws
包简介
AWS KMS signing adapter for the Chronicle audit ledger - remote sign, local verify.
README 文档
README
AWS KMS signing adapter for the Chronicle audit ledger.
Signs Chronicle checkpoints and exports via AWS KMS (ECDSA P-256). Verification is always offline — no AWS API call needed — using a cached public key.
Installation
composer require laravel-chronicle/kms-aws
The package auto-discovers its service provider via Laravel's package discovery.
Requirements
- PHP 8.2+
ext-openssllaravel-chronicle/core^1.10- AWS SDK for PHP ^3.0
AWS Setup
Create a KMS key
Create an asymmetric KMS key with:
- Key type: Asymmetric
- Key spec: ECC_NIST_P256
- Key usage: SIGN_VERIFY
Required IAM actions
Attach the following IAM policy to the role that runs your application:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"kms:Sign",
"kms:DescribeKey"
],
"Resource": "arn:aws:kms:REGION:ACCOUNT_ID:key/KEY_ID"
}
]
}
kms:GetPublicKey is not required at runtime — the public key is cached in your
application config and never fetched from KMS during verification.
Retrieve and cache the public key
Retrieve your KMS key's public key once and store it in your config:
aws kms get-public-key \ --key-id arn:aws:kms:REGION:ACCOUNT_ID:key/KEY_ID \ --query 'PublicKey' --output text | base64 -d | \ openssl pkey -pubin -inform DER -outform PEM
This outputs a PEM string like:
-----BEGIN PUBLIC KEY-----
MFkwEwYH...
-----END PUBLIC KEY-----
Store this as the public_key in your Chronicle signing config (see below).
Configuration
Register the KMS key in config/chronicle.php under signing.keys:
use Chronicle\KmsAws\AwsKmsSigningProvider; 'signing' => [ 'active' => env('CHRONICLE_ACTIVE_KEY', 'kms-production'), 'keys' => [ 'kms-production' => [ 'provider' => AwsKmsSigningProvider::class, 'algorithm' => 'ecdsa-p256', 'key_arn' => env('CHRONICLE_KMS_KEY_ARN'), 'public_key' => env('CHRONICLE_KMS_PUBLIC_KEY'), // PEM string ], ], ],
Set the corresponding environment variables:
AWS_DEFAULT_REGION=eu-west-1 CHRONICLE_ACTIVE_KEY=kms-production CHRONICLE_KMS_KEY_ARN=arn:aws:kms:eu-west-1:123456789012:key/your-key-id CHRONICLE_KMS_PUBLIC_KEY="-----BEGIN PUBLIC KEY----- MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAE... -----END PUBLIC KEY----- "
How it works
| Operation | Where it runs |
|---|---|
sign() |
Remote — calls KMS Sign API with MessageType: DIGEST |
verify() |
Local — openssl_verify against the cached PEM public key |
The private key never leaves AWS KMS. Verification is offline and instant.
Key rotation
Chronicle's key rotation works identically for KMS-backed keys. Retire the old key by
keeping only its public_key in the ring (omit key_arn), then add the new KMS key as
active. Historic checkpoints and exports continue to verify offline against the retained
public key.
Example two-key ring after rotation:
'signing' => [ 'active' => 'kms-2026', 'keys' => [ // Retired — switch to EcdsaSigningProvider (from core) for verify-only mode. // AwsKmsSigningProvider requires key_arn and cannot be verify-only. 'kms-2025' => [ 'provider' => \Chronicle\Signing\EcdsaSigningProvider::class, 'algorithm' => 'ecdsa-p256', 'public_key' => env('CHRONICLE_KMS_2025_PUBLIC_KEY'), ], // Active 'kms-2026' => [ 'provider' => AwsKmsSigningProvider::class, 'algorithm' => 'ecdsa-p256', 'key_arn' => env('CHRONICLE_KMS_KEY_ARN'), 'public_key' => env('CHRONICLE_KMS_PUBLIC_KEY'), ], ], ],
Note:
AwsKmsSigningProviderrequireskey_arnat construction — it cannot be used as a verify-only provider. For retired KMS keys, switch the entry toChronicle\Signing\EcdsaSigningProvider(from core) with onlypublic_keyset, as shown above. Core'sEcdsaSigningProviderhandles the local-verify-only case.
KEK encryption provider (crypto-shredding)
Chronicle v1.12 can encrypt PII payload fields under a per-subject DEK, wrapping those DEKs under a Key Encryption Key (KEK). This package can hold the KEK in AWS KMS so wrapped DEKs are protected outside the application.
Point chronicle.encryption.kek at the KMS provider:
// config/chronicle.php use Chronicle\KmsAws\KmsKeyEncryptionProvider; 'encryption' => [ 'enabled' => true, 'kek' => [ 'provider' => KmsKeyEncryptionProvider::class, 'key' => env('CHRONICLE_KMS_KEK_ARN'), // KMS key ARN/id for Encrypt/Decrypt 'id' => env('CHRONICLE_KMS_KEK_ID'), // kekId recorded per subject key ], ],
Required IAM actions on the KEK: kms:Encrypt, kms:Decrypt. The KmsClient is
resolved from the container (region from AWS_DEFAULT_REGION), so no extra wiring
is needed beyond installing this package.
License
MIT
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-06-04