-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Behaviour Prefixes (for CDK v2 upgrade) #1401
Changes from 3 commits
6b14c30
5a60fe1
0d7f5d8
faa19f8
ace316a
4dc214d
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,8 @@ | ||
import { StaticHosting, StaticHostingProps } from "./lib/static-hosting"; | ||
import { | ||
StaticHosting, | ||
StaticHostingProps, | ||
remapPath, | ||
} from "./lib/static-hosting"; | ||
import { CSP } from "./types/csp"; | ||
|
||
export { StaticHosting, StaticHostingProps, CSP }; | ||
export { StaticHosting, StaticHostingProps, CSP, remapPath }; |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -139,6 +139,16 @@ export interface StaticHostingProps { | |
*/ | ||
enableStaticFileRemap?: boolean; | ||
|
||
/** | ||
* Overrides default behaviour paths with a prefix and takes in options to apply to each static file behaviour | ||
* | ||
* @default true | ||
*/ | ||
defaultBehaviourPrefixes?: { | ||
prefix: string; | ||
behaviourOverride: Partial<BehaviorOptions>; | ||
}[]; | ||
|
||
/** | ||
* Optional additional properties for static file remap behaviours | ||
* | ||
|
@@ -292,7 +302,7 @@ export interface StaticHostingProps { | |
comment?: string; | ||
} | ||
|
||
interface remapPath { | ||
export interface remapPath { | ||
from: string; | ||
to?: string; | ||
behaviour?: Partial<BehaviorOptions>; | ||
|
@@ -537,16 +547,6 @@ export class StaticHosting extends Construct { | |
} | ||
} | ||
|
||
if (enableStaticFileRemap) { | ||
for (const path of this.staticFiles) { | ||
additionalBehaviors[`*.${path}`] = { | ||
origin: s3Origin, | ||
viewerProtocolPolicy: ViewerProtocolPolicy.REDIRECT_TO_HTTPS, | ||
...props.staticFileRemapOptions, | ||
}; | ||
} | ||
} | ||
|
||
// Note: A given path may override if the same path is defined both remapPaths and remapBackendPaths. This is an | ||
// unlikely scenario but worth noting. e.g. `/robots.txt` should be defined in one of the above but not both. | ||
if (props.remapPaths) { | ||
|
@@ -560,6 +560,31 @@ export class StaticHosting extends Construct { | |
} | ||
} | ||
|
||
if (enableStaticFileRemap) { | ||
const staticFileRemapPrefixes = props.defaultBehaviourPrefixes?.map( | ||
prefix => `${prefix.prefix}/` | ||
) || [""]; | ||
TheOrangePuff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
staticFileRemapPrefixes.forEach(prefix => { | ||
this.staticFiles.forEach(path => { | ||
additionalBehaviors[`${prefix}*.${path}`] = { | ||
origin: s3Origin, | ||
viewerProtocolPolicy: ViewerProtocolPolicy.REDIRECT_TO_HTTPS, | ||
}; | ||
}); | ||
}); | ||
} | ||
|
||
props.defaultBehaviourPrefixes?.forEach(prefix => { | ||
TheOrangePuff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
additionalBehaviors[`${prefix.prefix}*`] = { | ||
origin: s3Origin, | ||
viewerProtocolPolicy: ViewerProtocolPolicy.REDIRECT_TO_HTTPS, | ||
edgeLambdas: prefix.behaviourOverride.edgeLambdas, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Instead of just passing the edge lambda you can do this: additionalBehaviors[`${prefix.prefix}*`] = {
origin: s3Origin,
viewerProtocolPolicy: ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
originRequestPolicy: originRequestPolicy,
cachePolicy: originCachePolicy,
responseHeadersPolicy: responseHeadersPolicy,
...prefix.behaviourOverride,
}; Because that will then allow you to override any of the properties if you need There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @finn-holland-aligent this one hasn't been resolved yet |
||
originRequestPolicy: originRequestPolicy, | ||
cachePolicy: originCachePolicy, | ||
responseHeadersPolicy: responseHeadersPolicy, | ||
}; | ||
}); | ||
|
||
if (props.responseHeadersPolicies?.defaultBehaviorResponseHeaderPolicy) { | ||
defaultBehavior.responseHeadersPolicy = | ||
props.responseHeadersPolicies.defaultBehaviorResponseHeaderPolicy; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The options don't apply to the static file behaviour do they?