CloudFront
CloudFront control plane — distributions, invalidations, web ACL/alias association, tags. Full DistributionConfig round-trip with ETag/If-Match concurrency.
fakecloud implements CloudFront's REST-XML control plane focused on the operations real applications and Terraform stacks rely on: distribution lifecycle, invalidations, alias and web ACL association, tags, the full policy resource surface (OAC + Cache/OriginRequest/ResponseHeaders/ContinuousDeployment), CloudFront Functions, public keys + key groups, key value stores, legacy origin access identities, per-distribution monitoring subscriptions, the legacy RTMP streaming distributions, field-level encryption configs + profiles, realtime log configs, VPC origins, anycast IP lists, trust stores, resource policies, connection groups, domain association + DNS verification, managed certificate details, and the promote-staging distribution swap. 147 operations.
Status: Batches 1-6b shipped, plus ConnectionFunctions, DistributionTenants, and real boa_engine-backed TestFunction / TestConnectionFunction execution. 147 of 147 operations.
Supported today
- Distributions —
CreateDistribution,CreateDistributionWithTags,GetDistribution,GetDistributionConfig,UpdateDistribution,DeleteDistribution,ListDistributions,CopyDistribution. ReturnsETagheaders;UpdateDistributionandDeleteDistributionenforceIf-Match. - Distributions-by-X listings —
ListDistributionsByCachePolicyId,ListDistributionsByOriginRequestPolicyId,ListDistributionsByResponseHeadersPolicyId,ListDistributionsByKeyGroup,ListDistributionsByWebACLId,ListDistributionsByVpcOriginId,ListDistributionsByAnycastIpListId,ListDistributionsByConnectionMode,ListDistributionsByConnectionFunction,ListDistributionsByOwnedResource,ListDistributionsByTrustStore,ListDistributionsByRealtimeLogConfig. - Invalidations —
CreateInvalidation(returnsCompletedimmediately for deterministic tests),GetInvalidation,ListInvalidations. - Tags —
TagResource,UntagResource,ListTagsForResourcekeyed by distribution ARN. - Aliases / Web ACL —
AssociateAlias,ListConflictingAliases,AssociateDistributionWebACL,DisassociateDistributionWebACL. - Origin Access Control —
CreateOriginAccessControl,GetOriginAccessControl,GetOriginAccessControlConfig,UpdateOriginAccessControl,DeleteOriginAccessControl,ListOriginAccessControls. Full ETag/If-Match concurrency. - Cache Policy —
CreateCachePolicy,GetCachePolicy,GetCachePolicyConfig,UpdateCachePolicy,DeleteCachePolicy,ListCachePolicieswith?Type=managed|custom. AWS-managedManaged-CachingOptimized,Managed-CachingDisabled,Managed-CachingOptimizedForUncompressedObjects,Managed-Elemental*are pre-seeded by their well-known IDs and rejectUpdate/Delete. - Origin Request Policy —
CreateOriginRequestPolicy,GetOriginRequestPolicy,GetOriginRequestPolicyConfig,UpdateOriginRequestPolicy,DeleteOriginRequestPolicy,ListOriginRequestPolicies. ManagedManaged-CORS-S3Origin,Managed-CORS-CustomOrigin,Managed-AllViewer,Managed-UserAgentRefererHeaders,Managed-AllViewerExceptHostHeaderpre-seeded. - Response Headers Policy —
CreateResponseHeadersPolicy,GetResponseHeadersPolicy,GetResponseHeadersPolicyConfig,UpdateResponseHeadersPolicy,DeleteResponseHeadersPolicy,ListResponseHeadersPolicies. ManagedManaged-SimpleCORS,Managed-CORS-With-Preflight,Managed-SecurityHeadersPolicypre-seeded. - Continuous Deployment Policy —
CreateContinuousDeploymentPolicy,GetContinuousDeploymentPolicy,GetContinuousDeploymentPolicyConfig,UpdateContinuousDeploymentPolicy,DeleteContinuousDeploymentPolicy,ListContinuousDeploymentPolicies. - CloudFront Functions —
CreateFunction,DescribeFunction,GetFunction(returns raw source bytes),UpdateFunction,DeleteFunction,ListFunctions,PublishFunction(DEVELOPMENT -> LIVE),TestFunction.TestFunctionexecutes the user'sfunction handler(event) { ... }against the suppliedEventObjectvia an embeddedboa_engineJavaScript runtime: the handler return value is JSON-encoded into<FunctionOutput>, thrown errors land in<FunctionErrorMessage>, andconsole.log/console.errorlines are captured into<FunctionExecutionLogs>.<ComputeUtilization>reports a 0..=100 share of the per-request CPU budget on success and saturates past 100 on failure.Stage(DEVELOPMENT | LIVE) picks which version's source to run: DEVELOPMENT is the latest CreateFunction / UpdateFunction body, LIVE is the snapshot frozen at the most recent PublishFunction call (so post-publish updates don't leak into the published behaviour). Execution is capped by boa's loop-iteration and recursion limits plus a 250ms wall-clock guard (looser than AWS's ~1ms production budget so CI runners with noisy neighbours don't false-alarm; tests rely on the cap to killwhile(1){}). - Connection Functions —
CreateConnectionFunction,DescribeConnectionFunction,GetConnectionFunction(raw source),UpdateConnectionFunction,DeleteConnectionFunction,ListConnectionFunctions,PublishConnectionFunction,TestConnectionFunction.TestConnectionFunctionruns the sameboa_engineruntime against the suppliedConnectionObjectand emits the parallel<ConnectionFunctionOutput>/<ConnectionFunctionErrorMessage>/<ConnectionFunctionExecutionLogs>/<ComputeUtilization>shape, with the same DEVELOPMENT-vs-LIVE stage selection asTestFunction. - Public Keys + Key Groups — full CRUD with
CallerReferenceimmutability on update. - Key Value Stores —
CreateKeyValueStore(with optionalImportSource),DescribeKeyValueStore,UpdateKeyValueStore,DeleteKeyValueStore,ListKeyValueStores. - Legacy Origin Access Identities —
CreateCloudFrontOriginAccessIdentity,Get,GetConfig,Update,Delete,List. - Monitoring Subscriptions —
CreateMonitoringSubscription,GetMonitoringSubscription,DeleteMonitoringSubscriptionkeyed by distribution id. - Streaming Distributions (legacy RTMP) —
CreateStreamingDistribution,CreateStreamingDistributionWithTags,GetStreamingDistribution,GetStreamingDistributionConfig,UpdateStreamingDistribution,DeleteStreamingDistribution,ListStreamingDistributions. ETag/If-Match concurrency.DeleteStreamingDistributionenforces the AWS rule that the distribution must beEnabled = falsebefore deletion (StreamingDistributionNotDisabled). - Field-Level Encryption —
CreateFieldLevelEncryptionConfig,GetFieldLevelEncryption,GetFieldLevelEncryptionConfig,UpdateFieldLevelEncryptionConfig,DeleteFieldLevelEncryptionConfig,ListFieldLevelEncryptionConfigs. ETag/If-Match concurrency,CallerReferenceimmutability on update, duplicateCallerReferencerejected withFieldLevelEncryptionConfigAlreadyExists. - Field-Level Encryption Profiles —
CreateFieldLevelEncryptionProfile,GetFieldLevelEncryptionProfile,GetFieldLevelEncryptionProfileConfig,UpdateFieldLevelEncryptionProfile,DeleteFieldLevelEncryptionProfile,ListFieldLevelEncryptionProfiles. Same concurrency + idempotency model as FLE configs. - Realtime Log Configs —
CreateRealtimeLogConfig,GetRealtimeLogConfig(byNameorARN),UpdateRealtimeLogConfig,DeleteRealtimeLogConfig(byNameorARN),ListRealtimeLogConfigs. Endpoint round-trip preservesKinesisStreamConfigRoleARN/StreamARNexactly. - VPC Origins —
CreateVpcOrigin,GetVpcOrigin,UpdateVpcOrigin,DeleteVpcOrigin,ListVpcOrigins. ETag/If-Match concurrency, duplicateNamerejected withEntityAlreadyExists.DeleteVpcOriginreturns the deleted resource andETag. Status seeded asDeployedimmediately for deterministic tests. - Anycast IP Lists —
CreateAnycastIpList,GetAnycastIpList,UpdateAnycastIpList,DeleteAnycastIpList,ListAnycastIpLists.IpCountvalidated to AWS allowed values (3 or 21). Synthesized deterministicAnycastIpspayload returned on every read. - Trust Stores —
CreateTrustStore,GetTrustStore(byidentifier),UpdateTrustStore,DeleteTrustStore,ListTrustStores. ETag/If-Match concurrency.UpdateTrustStoreaccepts thehttpPayloadCaCertificatesBundleSourcebody shape AWS uses (no name). - Resource Policies —
PutResourcePolicy,GetResourcePolicy,DeleteResourcePolicy. Policy documents are stored verbatim per resource ARN and round-tripped on get. - Connection Groups —
CreateConnectionGroup,GetConnectionGroup,GetConnectionGroupByRoutingEndpoint,UpdateConnectionGroup,DeleteConnectionGroup,ListConnectionGroups. ETag/If-Match concurrency. Routing endpoint synthesized as<id>.cloudfront.net.Deleteenforces the AWS rule that the group must beEnabled = falsefirst (ResourceInUse). DuplicateNamerejected withEntityAlreadyExists. - Domain ops —
ListDomainConflicts(returns empty conflicts in fakecloud since there is no global DNS namespace),UpdateDomainAssociation(round-tripsDomain+ targetDistributionId/DistributionTenantId),VerifyDnsConfiguration(returns a deterministicvalid-configurationstatus). - Managed Certificate Details —
GetManagedCertificateDetailsreturns a synthesized ACM certificate ARN +issuedstatus keyed by the supplied identifier. - Promote-staging —
UpdateDistributionWithStagingConfigswaps the distribution'sETagagainst the configuredStagingDistributionIdand rejects unknown staging ids withNoSuchDistribution. - Distribution Tenants —
CreateDistributionTenant,GetDistributionTenant,GetDistributionTenantByDomain,UpdateDistributionTenant,DeleteDistributionTenant,ListDistributionTenants,ListDistributionTenantsByCustomization,VerifyDnsConfiguration(tenant-scoped). ETag/If-Match concurrency, per-tenantCustomizations(web ACL, certificate, geo restrictions, origin overrides) round-trip element-for-element, duplicateNamerejected withEntityAlreadyExists.
Concurrency semantics
CloudFront's ETag model is preserved. Every successful Create/Get/Update returns the current ETag header, and UpdateDistribution/DeleteDistribution reject requests whose If-Match does not match the in-memory revision with 412 PreconditionFailed. DeleteDistribution also enforces the AWS rule that the distribution must be Enabled = false before deletion (DistributionNotDisabled).
DistributionConfig round-trip
DistributionConfig is parsed into typed Rust structs that cover the full standard surface — origins (S3, custom, VPC, OAC fields), cache behaviors (forwarded values, allowed methods, cached methods, function associations, lambda function associations, gRPC config), custom error responses, viewer certificates, geo restrictions, logging config, origin groups, tenant config — and is serialized back element-for-element. GetDistributionConfig returns exactly what CreateDistribution/UpdateDistribution accepted.
Idempotency
CreateDistribution rejects a second call with the same CallerReference with DistributionAlreadyExists (matches AWS).
Smoke test
fakecloud &
# Create a distribution
DIST=$(aws --endpoint-url http://localhost:4566 cloudfront create-distribution \
--distribution-config '{
"CallerReference": "smoke-1",
"Comment": "smoke",
"Enabled": true,
"Origins": {
"Quantity": 1,
"Items": [
{ "Id": "primary", "DomainName": "origin.example.com",
"CustomOriginConfig": { "HTTPPort": 80, "HTTPSPort": 443, "OriginProtocolPolicy": "https-only" } }
]
},
"DefaultCacheBehavior": {
"TargetOriginId": "primary",
"ViewerProtocolPolicy": "redirect-to-https",
"MinTTL": 0
}
}')
ID=$(echo "$DIST" | jq -r '.Distribution.Id')
# Invalidate something
aws --endpoint-url http://localhost:4566 cloudfront create-invalidation \
--distribution-id "$ID" \
--invalidation-batch '{"Paths":{"Quantity":1,"Items":["/*"]},"CallerReference":"inv-1"}'
# List
aws --endpoint-url http://localhost:4566 cloudfront list-invalidations --distribution-id "$ID"Admin endpoints
POST /_fakecloud/cloudfront/distributions/{id}/status— flip a stored distribution's reportedStatus(e.g. betweenInProgressandDeployed) without waiting on the auto-deploy tick. Body:{"status": "Deployed"}. Returns204 No Contenton success and404 Not Foundfor an unknown id. Useful for tests that assert behavior gated on the post-deploy status.
Caveats
There is no edge data plane: requests against a CloudFront distribution domain are not actually proxied to origins. Use ELBv2's in-process data plane for HTTP request matching tests today.