From f7ada5532b4513085a4604fb85fd6160c5af71ec Mon Sep 17 00:00:00 2001 From: George Fu Date: Thu, 19 Dec 2024 15:29:26 +0000 Subject: [PATCH 1/2] fix for operationContextParam codegen --- .changeset/thick-socks-cross.md | 5 +++++ build.gradle.kts | 7 +++++++ .../src/adaptors/getEndpointFromInstructions.ts | 3 +++ packages/middleware-endpoint/src/types.ts | 11 ++++++++++- .../smithy/typescript/codegen/CommandGenerator.java | 2 +- .../codegen/endpointsV2/RuleSetParameterFinder.java | 11 ++++++----- .../typescript/codegen/CommandGeneratorTest.java | 12 ++++++------ 7 files changed, 38 insertions(+), 13 deletions(-) create mode 100644 .changeset/thick-socks-cross.md diff --git a/.changeset/thick-socks-cross.md b/.changeset/thick-socks-cross.md new file mode 100644 index 00000000000..eb4a892be34 --- /dev/null +++ b/.changeset/thick-socks-cross.md @@ -0,0 +1,5 @@ +--- +"@smithy/middleware-endpoint": patch +--- + +fix for operation context params diff --git a/build.gradle.kts b/build.gradle.kts index 2ec48135745..018590c1375 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -198,6 +198,13 @@ subprojects { exceptionFormat = org.gradle.api.tasks.testing.logging.TestExceptionFormat.FULL } } + } else { + tasks.test { + testLogging { + events("failed") + exceptionFormat = org.gradle.api.tasks.testing.logging.TestExceptionFormat.FULL + } + } } /* diff --git a/packages/middleware-endpoint/src/adaptors/getEndpointFromInstructions.ts b/packages/middleware-endpoint/src/adaptors/getEndpointFromInstructions.ts index e1a862c70c7..d6d241ecfdb 100644 --- a/packages/middleware-endpoint/src/adaptors/getEndpointFromInstructions.ts +++ b/packages/middleware-endpoint/src/adaptors/getEndpointFromInstructions.ts @@ -92,6 +92,9 @@ export const resolveParams = async < case "builtInParams": endpointParams[name] = await createConfigValueProvider(instruction.name, name, clientConfig)(); break; + case "operationContextParams": + endpointParams[name] = instruction.get(commandInput); + break; default: throw new Error("Unrecognized endpoint parameter instruction: " + JSON.stringify(instruction)); } diff --git a/packages/middleware-endpoint/src/types.ts b/packages/middleware-endpoint/src/types.ts index 54951699b59..bbf45493911 100644 --- a/packages/middleware-endpoint/src/types.ts +++ b/packages/middleware-endpoint/src/types.ts @@ -6,7 +6,8 @@ export interface EndpointParameterInstructions { | BuiltInParamInstruction | ClientContextParamInstruction | StaticContextParamInstruction - | ContextParamInstruction; + | ContextParamInstruction + | OperationContextParamInstruction; } /** @@ -40,3 +41,11 @@ export interface ContextParamInstruction { type: "contextParams"; name: string; // The input structure's member name that has contextParams trait } + +/** + * @internal + */ +export interface OperationContextParamInstruction { + type: "operationContextParams"; + get(input: any): any; +} diff --git a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java index d72698e1969..83e740ec0c0 100644 --- a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java +++ b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java @@ -344,7 +344,7 @@ private void generateEndpointParameterInstructionProvider() { operationContextParamValues.forEach((name, jmesPathForInputInJs) -> { writer.write( """ - $L: { type: \"operationContextParams\", name: $L }, + $L: { type: \"operationContextParams\", get: (input: any) => $L }, """, name, jmesPathForInputInJs); }); diff --git a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java index db0a35dbcff..8825f2e7ae2 100644 --- a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java +++ b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java @@ -275,14 +275,14 @@ public Map getOperationContextParamValues(OperationShape operati if (trait.isPresent()) { trait.get().getParameters().forEach((name, definition) -> { String separator = "."; - String value = "this" + separator + "input"; + String value = "input"; String path = definition.getPath(); // Split JMESPath expression string on separator and add JavaScript equivalent. for (String part : path.split("[" + separator + "]")) { if (value.endsWith(")")) { // The value is an object, which needs to run on map. - value += ".map(obj => obj"; + value += ".map((obj: any) => obj"; } // Process keys https://jmespath.org/specification.html#keys @@ -303,7 +303,7 @@ public Map getOperationContextParamValues(OperationShape operati if (part.endsWith("[*]")) { // Get key to run hash wildcard on. String key = part.substring(0, part.length() - 3); - value = value + separator + key + separator + "map(obj => obj"; + value = value + separator + key + separator + "map((obj: any) => obj"; continue; } @@ -312,8 +312,9 @@ public Map getOperationContextParamValues(OperationShape operati } // Remove no-op map, if it exists. - if (value.endsWith(separator + "map(obj => obj")) { - value = value.substring(0, value.length() - 15); + final String noOpMap = "map((obj: any) => obj"; + if (value.endsWith(separator + noOpMap)) { + value = value.substring(0, value.length() - noOpMap.length() - separator.length()); } // Close all open brackets. diff --git a/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java b/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java index 9289684b4a1..85557fffcdb 100644 --- a/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java +++ b/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java @@ -39,12 +39,12 @@ public void writesOperationContextParamValues() { testCommmandCodegen( "endpointsV2/endpoints-operation-context-params.smithy", new String[] { - "opContextParamIdentifier: { type: \"operationContextParams\", name: this.input.fooString }", - "opContextParamSubExpression: { type: \"operationContextParams\", name: this.input.fooObj.bar }", - "opContextParamWildcardExpressionList: { type: \"operationContextParams\", name: this.input.fooList }", - "opContextParamWildcardExpressionListObj: { type: \"operationContextParams\", name: this.input.fooListObj.map(obj => obj.key) }", - "opContextParamWildcardExpressionHash: { type: \"operationContextParams\", name: Object.values(this.input.fooObjObj).map(obj => obj.bar) }", - "opContextParamKeys: { type: \"operationContextParams\", name: Object.keys(this.input.fooKeys) }", + "opContextParamIdentifier: { type: \"operationContextParams\", get: (input: any) => input.fooString }", + "opContextParamSubExpression: { type: \"operationContextParams\", get: (input: any) => input.fooObj.bar }", + "opContextParamWildcardExpressionList: { type: \"operationContextParams\", get: (input: any) => input.fooList }", + "opContextParamWildcardExpressionListObj: { type: \"operationContextParams\", get: (input: any) => input.fooListObj.map((obj: any) => obj.key) }", + "opContextParamWildcardExpressionHash: { type: \"operationContextParams\", get: (input: any) => Object.values(input.fooObjObj).map((obj: any) => obj.bar) }", + "opContextParamKeys: { type: \"operationContextParams\", get: (input: any) => Object.keys(input.fooKeys) }", } ); } From 3b3ba7433d427adbbc8fd54e6f3ad80a41ab7c7b Mon Sep 17 00:00:00 2001 From: George Fu Date: Thu, 19 Dec 2024 15:53:59 +0000 Subject: [PATCH 2/2] no-throw on invoking operationContextParams getter --- .../smithy/typescript/codegen/CommandGenerator.java | 2 +- .../codegen/endpointsV2/RuleSetParameterFinder.java | 6 +++--- .../typescript/codegen/CommandGeneratorTest.java | 12 ++++++------ 3 files changed, 10 insertions(+), 10 deletions(-) diff --git a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java index 83e740ec0c0..38968e2fdd4 100644 --- a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java +++ b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/CommandGenerator.java @@ -344,7 +344,7 @@ private void generateEndpointParameterInstructionProvider() { operationContextParamValues.forEach((name, jmesPathForInputInJs) -> { writer.write( """ - $L: { type: \"operationContextParams\", get: (input: any) => $L }, + $L: { type: \"operationContextParams\", get: (input?: any) => $L }, """, name, jmesPathForInputInJs); }); diff --git a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java index 8825f2e7ae2..ffb84fd27d5 100644 --- a/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java +++ b/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/endpointsV2/RuleSetParameterFinder.java @@ -274,7 +274,7 @@ public Map getOperationContextParamValues(OperationShape operati Optional trait = operation.getTrait(OperationContextParamsTrait.class); if (trait.isPresent()) { trait.get().getParameters().forEach((name, definition) -> { - String separator = "."; + String separator = "?."; String value = "input"; String path = definition.getPath(); @@ -289,13 +289,13 @@ public Map getOperationContextParamValues(OperationShape operati if (part.startsWith("keys(")) { // Get provided object for which keys are to be extracted. String object = part.substring(5, part.length() - 1); - value = "Object.keys(" + value + separator + object + ")"; + value = "Object.keys(" + value + separator + object + " ?? {})"; continue; } // Process list wildcard expression https://jmespath.org/specification.html#wildcard-expressions if (part.equals("*") || part.equals("[*]")) { - value = "Object.values(" + value + ")"; + value = "Object.values(" + value + " ?? {})"; continue; } diff --git a/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java b/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java index 85557fffcdb..e9f8c24ab6b 100644 --- a/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java +++ b/smithy-typescript-codegen/src/test/java/software/amazon/smithy/typescript/codegen/CommandGeneratorTest.java @@ -39,12 +39,12 @@ public void writesOperationContextParamValues() { testCommmandCodegen( "endpointsV2/endpoints-operation-context-params.smithy", new String[] { - "opContextParamIdentifier: { type: \"operationContextParams\", get: (input: any) => input.fooString }", - "opContextParamSubExpression: { type: \"operationContextParams\", get: (input: any) => input.fooObj.bar }", - "opContextParamWildcardExpressionList: { type: \"operationContextParams\", get: (input: any) => input.fooList }", - "opContextParamWildcardExpressionListObj: { type: \"operationContextParams\", get: (input: any) => input.fooListObj.map((obj: any) => obj.key) }", - "opContextParamWildcardExpressionHash: { type: \"operationContextParams\", get: (input: any) => Object.values(input.fooObjObj).map((obj: any) => obj.bar) }", - "opContextParamKeys: { type: \"operationContextParams\", get: (input: any) => Object.keys(input.fooKeys) }", + "opContextParamIdentifier: { type: \"operationContextParams\", get: (input?: any) => input?.fooString }", + "opContextParamSubExpression: { type: \"operationContextParams\", get: (input?: any) => input?.fooObj?.bar }", + "opContextParamWildcardExpressionList: { type: \"operationContextParams\", get: (input?: any) => input?.fooList }", + "opContextParamWildcardExpressionListObj: { type: \"operationContextParams\", get: (input?: any) => input?.fooListObj?.map((obj: any) => obj?.key) }", + "opContextParamWildcardExpressionHash: { type: \"operationContextParams\", get: (input?: any) => Object.values(input?.fooObjObj ?? {}).map((obj: any) => obj?.bar) }", + "opContextParamKeys: { type: \"operationContextParams\", get: (input?: any) => Object.keys(input?.fooKeys ?? {}) }", } ); }