Skip to content

Commit fa0b8a5

Browse files
committed
chore(codegen): use pagination factory in ddb document client
1 parent 6bf32b1 commit fa0b8a5

File tree

1 file changed

+14
-79
lines changed

1 file changed

+14
-79
lines changed

codegen/smithy-aws-typescript-codegen/src/main/java/software/amazon/smithy/aws/typescript/codegen/DocumentClientPaginationGenerator.java

Lines changed: 14 additions & 79 deletions
Original file line numberDiff line numberDiff line change
@@ -17,13 +17,9 @@
1717

1818
import java.nio.file.Path;
1919
import java.nio.file.Paths;
20-
import java.util.Optional;
21-
import software.amazon.smithy.codegen.core.CodegenException;
2220
import software.amazon.smithy.codegen.core.Symbol;
2321
import software.amazon.smithy.codegen.core.SymbolProvider;
2422
import software.amazon.smithy.model.Model;
25-
import software.amazon.smithy.model.knowledge.PaginatedIndex;
26-
import software.amazon.smithy.model.knowledge.PaginationInfo;
2723
import software.amazon.smithy.model.shapes.OperationShape;
2824
import software.amazon.smithy.model.shapes.ServiceShape;
2925
import software.amazon.smithy.typescript.codegen.TypeScriptDependency;
@@ -36,14 +32,13 @@ final class DocumentClientPaginationGenerator implements Runnable {
3632
static final String PAGINATION_FOLDER = "pagination";
3733

3834
private final TypeScriptWriter writer;
39-
private final PaginationInfo paginatedInfo;
4035

4136
private final String operationTypeName;
4237
private final String inputTypeName;
4338
private final String outputTypeName;
4439

4540
private final String operationName;
46-
private final String methodName;
41+
4742
private final String paginationType;
4843

4944
DocumentClientPaginationGenerator(
@@ -65,14 +60,7 @@ final class DocumentClientPaginationGenerator implements Runnable {
6560

6661
// e.g. listObjects
6762
this.operationName = operationTypeName.replace("Command", "");
68-
this.methodName = Character.toLowerCase(operationName.charAt(0)) + operationName.substring(1);
6963
this.paginationType = DocumentClientUtils.CLIENT_FULL_NAME + "PaginationConfiguration";
70-
71-
PaginatedIndex paginatedIndex = PaginatedIndex.of(model);
72-
Optional<PaginationInfo> paginationInfo = paginatedIndex.getPaginationInfo(service, operation);
73-
this.paginatedInfo = paginationInfo.orElseThrow(() -> {
74-
return new CodegenException("Expected Paginator to have pagination information.");
75-
});
7664
}
7765

7866
@Override
@@ -90,13 +78,13 @@ public void run() {
9078

9179
// Import Pagination types
9280
writer.addImport("Paginator", "Paginator", TypeScriptDependency.SMITHY_TYPES);
81+
writer.addImport("createPaginator", "createPaginator", TypeScriptDependency.SMITHY_CORE);
9382
writer.addRelativeImport(paginationType, paginationType,
9483
Paths.get(".", getInterfaceFilelocation().replace(".ts", "")));
9584

9685
writer.writeDocs("@public");
9786
writer.write("export { Paginator }");
9887

99-
writeCommandRequest();
10088
writePager();
10189
}
10290

@@ -134,71 +122,18 @@ static void generateServicePaginationInterfaces(TypeScriptWriter writer) {
134122
});
135123
}
136124

137-
private String destructurePath(String path) {
138-
return "." + path.replace(".", "!.");
139-
}
140-
141125
private void writePager() {
142-
String inputTokenName = paginatedInfo.getPaginatedTrait().getInputToken().get();
143-
String outputTokenName = paginatedInfo.getPaginatedTrait().getOutputToken().get();
144-
145-
writer.writeDocs("@public\n\n"
146-
+ String.format("@param %s - {@link %s}%n", inputTypeName, inputTypeName)
147-
+ String.format("@returns {@link %s}%n", outputTypeName)
148-
);
149-
writer.openBlock(
150-
"export async function* paginate$L(config: $L, input: $L, ...additionalArguments: any): Paginator<$L>{",
151-
"}", operationName, paginationType, inputTypeName, outputTypeName, () -> {
152-
String destructuredInputTokenName = destructurePath(inputTokenName);
153-
writer.write("// ToDo: replace with actual type instead of typeof input$L", destructuredInputTokenName);
154-
writer.write("let token: typeof input$L | undefined = config.startingToken || undefined;",
155-
destructuredInputTokenName);
156-
157-
writer.write("let hasNext = true;");
158-
writer.write("let page: $L;", outputTypeName);
159-
writer.openBlock("while (hasNext) {", "}", () -> {
160-
writer.write("input$L = token;", destructuredInputTokenName);
161-
162-
if (paginatedInfo.getPageSizeMember().isPresent()) {
163-
String pageSize = paginatedInfo.getPageSizeMember().get().getMemberName();
164-
writer.write("input[$S] = config.pageSize;", pageSize);
165-
}
166-
167-
writer.openBlock("if (config.client instanceof $L) {", "}", DocumentClientUtils.CLIENT_NAME,
168-
() -> {
169-
writer.write(
170-
"page = await makePagedClientRequest(config.client, input, ...additionalArguments);");
171-
}
172-
);
173-
writer.openBlock("else {", "}", () -> {
174-
writer.write("throw new Error(\"Invalid client, expected $L | $L\");",
175-
DocumentClientUtils.CLIENT_FULL_NAME, DocumentClientUtils.CLIENT_NAME);
176-
});
177-
178-
writer.write("yield page;");
179-
writer.write("token = page$L;", destructurePath(outputTokenName));
180-
181-
writer.write("hasNext = !!(token);");
182-
});
183-
184-
writer.write("// @ts-ignore");
185-
writer.write("return undefined;");
186-
});
187-
}
188-
189-
190-
/**
191-
* Paginated command that calls CommandClient().send({...}) under the hood. This is meant for client side (browser)
192-
* environments and does not generally expose the entire service.
193-
*/
194-
private void writeCommandRequest() {
195-
writer.writeDocs("@internal");
196-
writer.openBlock(
197-
"const makePagedClientRequest = async (client: $L, input: $L, ...args: any): Promise<$L> => {",
198-
"}", DocumentClientUtils.CLIENT_NAME, inputTypeName,
199-
outputTypeName, () -> {
200-
writer.write("// @ts-ignore");
201-
writer.write("return await client.send(new $L(input), ...args);", operationTypeName);
202-
});
126+
writer.writeDocs("@public");
127+
writer.write("""
128+
export const paginate$1L: (
129+
config: $2L,
130+
input: $3L,
131+
...additionalArguments: any
132+
) => Paginator<$4L> = createPaginator<
133+
$2L,
134+
$3L,
135+
$4L
136+
>(DynamoDBDocumentClient, $1LCommand, "ExclusiveStartKey", "LastEvaluatedKey", "Limit");
137+
""", operationName, paginationType, inputTypeName, outputTypeName);
203138
}
204139
}

0 commit comments

Comments
 (0)