From d684615d949ada7cc1d9bd426b108d906ad0d42b Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 07:53:00 -0700 Subject: [PATCH 1/8] chore: remove type assertion in getClientTypeNames --- src/transforms/v2-to-v3/ts-type/getClientTypeNames.ts | 10 ++-------- 1 file changed, 2 insertions(+), 8 deletions(-) diff --git a/src/transforms/v2-to-v3/ts-type/getClientTypeNames.ts b/src/transforms/v2-to-v3/ts-type/getClientTypeNames.ts index bc640dab1..21e1bbcda 100644 --- a/src/transforms/v2-to-v3/ts-type/getClientTypeNames.ts +++ b/src/transforms/v2-to-v3/ts-type/getClientTypeNames.ts @@ -1,10 +1,4 @@ -import type { - Collection, - Identifier, - JSCodeshift, - TSQualifiedName, - TSTypeReference, -} from "jscodeshift"; +import type { Collection, JSCodeshift, TSQualifiedName, TSTypeReference } from "jscodeshift"; import type { ImportSpecifierType } from "../modules"; import { getImportSpecifiers } from "../modules/importModule"; @@ -30,7 +24,7 @@ const getRightIdentifierName = ( .nodes() .map((node) => (node.typeName as TSQualifiedName).right) .filter((node) => node.type === "Identifier") - .map((node) => (node as Identifier).name); + .map((node) => node.name); export const getClientTypeNames = ( j: JSCodeshift, From 6b15b4b605e7d2d201a1bc1aeae7b46e45329917 Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 07:53:31 -0700 Subject: [PATCH 2/8] chore: yarn changeset --- .changeset/itchy-mugs-rest.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/itchy-mugs-rest.md diff --git a/.changeset/itchy-mugs-rest.md b/.changeset/itchy-mugs-rest.md new file mode 100644 index 000000000..8aa4f8041 --- /dev/null +++ b/.changeset/itchy-mugs-rest.md @@ -0,0 +1,5 @@ +--- +"aws-sdk-js-codemod": patch +--- + +Remove type assertions for Identifier From 1c6c3f56f525aec51acf22dc9d2cead8f69c8bda Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 08:02:01 -0700 Subject: [PATCH 3/8] chore: remove type assertion in replaceTSTypeReference --- .../ts-type/replaceTSTypeReference.ts | 28 ++++++++----------- 1 file changed, 11 insertions(+), 17 deletions(-) diff --git a/src/transforms/v2-to-v3/ts-type/replaceTSTypeReference.ts b/src/transforms/v2-to-v3/ts-type/replaceTSTypeReference.ts index ec45bccd6..88208a6b7 100644 --- a/src/transforms/v2-to-v3/ts-type/replaceTSTypeReference.ts +++ b/src/transforms/v2-to-v3/ts-type/replaceTSTypeReference.ts @@ -1,10 +1,4 @@ -import type { - Collection, - Identifier, - JSCodeshift, - TSQualifiedName, - TSTypeReference, -} from "jscodeshift"; +import type { Collection, Identifier, JSCodeshift, TSQualifiedName } from "jscodeshift"; import { DOCUMENT_CLIENT, DYNAMODB, DYNAMODB_DOCUMENT, DYNAMODB_DOCUMENT_CLIENT } from "../config"; import { getClientTypeNames } from "./getClientTypeNames"; @@ -18,12 +12,6 @@ export interface ReplaceTSTypeReferenceOptions { v3ClientName: string; } -const isRightSectionIdentifier = (node: TSTypeReference) => - (node.typeName as TSQualifiedName).right.type === "Identifier"; - -const getRightIdentifierName = (node: TSTypeReference) => - ((node.typeName as TSQualifiedName).right as Identifier).name; - // Replace v2 client type reference with v3 client type reference. export const replaceTSTypeReference = ( j: JSCodeshift, @@ -66,9 +54,12 @@ export const replaceTSTypeReference = ( left: getTSQualifiedNameFromClientName(v2ClientName, v2GlobalName), }, }) - .filter((v2ClientType) => isRightSectionIdentifier(v2ClientType.node)) .replaceWith((v2ClientType) => { - const v2ClientTypeName = getRightIdentifierName(v2ClientType.node); + const tSQualifiedName = v2ClientType.node.typeName as TSQualifiedName; + if (tSQualifiedName.right.type !== "Identifier") { + return v2ClientType; + } + const v2ClientTypeName = tSQualifiedName.right.name; return getV3ClientType(j, { ...clientTypeOptions, v2ClientTypeName }); }); } @@ -81,9 +72,12 @@ export const replaceTSTypeReference = ( .find(j.TSTypeReference, { typeName: { left: getTSQualifiedNameFromClientName(v2ClientLocalName) }, }) - .filter((v2ClientType) => isRightSectionIdentifier(v2ClientType.node)) .replaceWith((v2ClientType) => { - const v2ClientTypeName = getRightIdentifierName(v2ClientType.node); + const tSQualifiedName = v2ClientType.node.typeName as TSQualifiedName; + if (tSQualifiedName.right.type !== "Identifier") { + return v2ClientType; + } + const v2ClientTypeName = tSQualifiedName.right.name; return getV3ClientType(j, { ...clientTypeOptions, v2ClientTypeName }); }); From 8585399225e7cbd9cd183bdcbe47b27ee93b350d Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 08:07:52 -0700 Subject: [PATCH 4/8] chore: remove type assertion in getImportSpecifiers --- .../modules/requireModule/getImportSpecifiers.ts | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/transforms/v2-to-v3/modules/requireModule/getImportSpecifiers.ts b/src/transforms/v2-to-v3/modules/requireModule/getImportSpecifiers.ts index a7de463e1..5148ca87f 100644 --- a/src/transforms/v2-to-v3/modules/requireModule/getImportSpecifiers.ts +++ b/src/transforms/v2-to-v3/modules/requireModule/getImportSpecifiers.ts @@ -1,4 +1,4 @@ -import type { Collection, Identifier, JSCodeshift, ObjectProperty, Property } from "jscodeshift"; +import type { Collection, JSCodeshift, ObjectProperty, Property } from "jscodeshift"; import { OBJECT_PROPERTY_TYPE_LIST } from "../../config"; import type { ImportSpecifierType } from "../types"; import { getRequireDeclarators } from "./getRequireDeclarators"; @@ -37,9 +37,12 @@ export const getImportSpecifiers = ( if (declaratorId.type === "Identifier") { const declaratorIdName = declaratorId.name; - if (declaratorInit?.type === "MemberExpression") { + if ( + declaratorInit?.type === "MemberExpression" && + declaratorInit.property.type === "Identifier" + ) { importSpecifiers.add({ - importedName: (declaratorInit.property as Identifier).name, + importedName: declaratorInit.property.name, localName: declaratorIdName, }); } else { From 1aad3f933af4c957ff0743014ae2924fa5886296 Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 08:08:35 -0700 Subject: [PATCH 5/8] chore: remove type assertion in getRequireDeclaratorsWithProperty --- .../modules/getRequireDeclaratorsWithProperty.ts | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/transforms/v2-to-v3/modules/getRequireDeclaratorsWithProperty.ts b/src/transforms/v2-to-v3/modules/getRequireDeclaratorsWithProperty.ts index 08adb9efc..db25ccbaa 100644 --- a/src/transforms/v2-to-v3/modules/getRequireDeclaratorsWithProperty.ts +++ b/src/transforms/v2-to-v3/modules/getRequireDeclaratorsWithProperty.ts @@ -1,4 +1,4 @@ -import type { Collection, Identifier, JSCodeshift } from "jscodeshift"; +import type { Collection, JSCodeshift } from "jscodeshift"; import { getRequireDeclarators } from "./requireModule"; export interface GetRequireDeclaratorsWithPropertyOptions { @@ -18,8 +18,11 @@ export const getRequireDeclaratorsWithProperty = ( if (declaratorId.type === "Identifier") { const declaratorIdName = declaratorId.name; - if (declaratorInit?.type === "MemberExpression") { - const importedName = (declaratorInit.property as Identifier).name; + if ( + declaratorInit?.type === "MemberExpression" && + declaratorInit.property.type === "Identifier" + ) { + const importedName = declaratorInit.property.name; if (localName === declaratorIdName && identifierName === importedName) { return true; } From b8b6b2b07c44fd3f8a1bbea6c61ffe0f169ba776 Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 08:10:53 -0700 Subject: [PATCH 6/8] chore: remove type assertion in getObjectWithUpdatedAwsConfigKeys --- .../client-instances/getObjectWithUpdatedAwsConfigKeys.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/transforms/v2-to-v3/client-instances/getObjectWithUpdatedAwsConfigKeys.ts b/src/transforms/v2-to-v3/client-instances/getObjectWithUpdatedAwsConfigKeys.ts index ade188c4d..75e241056 100644 --- a/src/transforms/v2-to-v3/client-instances/getObjectWithUpdatedAwsConfigKeys.ts +++ b/src/transforms/v2-to-v3/client-instances/getObjectWithUpdatedAwsConfigKeys.ts @@ -42,7 +42,7 @@ export const getObjectWithUpdatedAwsConfigKeys = ( continue; } - const propertyKeyName = (propertyKey as Identifier).name; + const propertyKeyName = propertyKey.name; if ( !propertiesToUpdate .filter((propertyToUpdate) => OBJECT_PROPERTY_TYPE_LIST.includes(propertyToUpdate.type)) From 92c226a25476d7bba48b092c78df6d9ec955c95d Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 08:12:57 -0700 Subject: [PATCH 7/8] chore: explicitly state right.type as Identifier in getNamesFromTSQualifiedName --- .../v2-to-v3/client-names/getNamesFromTSQualifiedName.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/transforms/v2-to-v3/client-names/getNamesFromTSQualifiedName.ts b/src/transforms/v2-to-v3/client-names/getNamesFromTSQualifiedName.ts index 88c1aefb9..3340aafe4 100644 --- a/src/transforms/v2-to-v3/client-names/getNamesFromTSQualifiedName.ts +++ b/src/transforms/v2-to-v3/client-names/getNamesFromTSQualifiedName.ts @@ -8,6 +8,7 @@ export const getNamesFromTSQualifiedName = ( source .find(j.TSQualifiedName, { left: { name: v2GlobalName }, + right: { type: "Identifier" }, }) .nodes() .map((tsTypeReference) => (tsTypeReference.right as Identifier).name); From c873317b637b88b5109b969106ac327e58575778 Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Sun, 28 Jul 2024 08:14:48 -0700 Subject: [PATCH 8/8] chore: remove type assertion in getGlobalNameFromModule --- src/transforms/v2-to-v3/modules/getGlobalNameFromModule.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/transforms/v2-to-v3/modules/getGlobalNameFromModule.ts b/src/transforms/v2-to-v3/modules/getGlobalNameFromModule.ts index b05c65ff6..f765ee29a 100644 --- a/src/transforms/v2-to-v3/modules/getGlobalNameFromModule.ts +++ b/src/transforms/v2-to-v3/modules/getGlobalNameFromModule.ts @@ -1,4 +1,4 @@ -import type { Collection, Identifier, JSCodeshift } from "jscodeshift"; +import type { Collection, JSCodeshift } from "jscodeshift"; import { PACKAGE_NAME } from "../config"; import { getImportSpecifiers as getImportEqualsSpecifiers } from "../modules/importEqualsModule"; @@ -13,8 +13,8 @@ export const getGlobalNameFromModule = ( .filter((declarator) => declarator.value.id.type === "Identifier") .nodes(); - if (requireIdentifiers.length > 0) { - return (requireIdentifiers[0]?.id as Identifier).name; + if (requireIdentifiers.length > 0 && requireIdentifiers[0].id.type === "Identifier") { + return requireIdentifiers[0].id.name; } const importDefaultSpecifiers = getImportSpecifiers(j, source, PACKAGE_NAME).filter(