@azure-tools/typespec-ts 0.13.0 → 0.13.1-alpha.20230609.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +37 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/modelUtils.d.ts +2 -0
- package/dist/src/modelUtils.d.ts.map +1 -1
- package/dist/src/modelUtils.js +82 -13
- package/dist/src/modelUtils.js.map +1 -1
- package/dist/src/modular/buildApiIndex.d.ts.map +1 -1
- package/dist/src/modular/buildApiIndex.js +1 -1
- package/dist/src/modular/buildApiIndex.js.map +1 -1
- package/dist/src/modular/buildClassicalClient.d.ts.map +1 -1
- package/dist/src/modular/buildClassicalClient.js +6 -6
- package/dist/src/modular/buildClassicalClient.js.map +1 -1
- package/dist/src/modular/buildClientContext.d.ts.map +1 -1
- package/dist/src/modular/buildClientContext.js +9 -3
- package/dist/src/modular/buildClientContext.js.map +1 -1
- package/dist/src/modular/buildCodeModel.d.ts.map +1 -1
- package/dist/src/modular/buildCodeModel.js +190 -169
- package/dist/src/modular/buildCodeModel.js.map +1 -1
- package/dist/src/modular/buildOperations.d.ts.map +1 -1
- package/dist/src/modular/buildOperations.js +20 -2
- package/dist/src/modular/buildOperations.js.map +1 -1
- package/dist/src/modular/buildRootIndex.js +2 -2
- package/dist/src/modular/buildRootIndex.js.map +1 -1
- package/dist/src/modular/buildSharedTypes.d.ts.map +1 -1
- package/dist/src/modular/buildSharedTypes.js +8 -10
- package/dist/src/modular/buildSharedTypes.js.map +1 -1
- package/dist/src/modular/emitModels.d.ts.map +1 -1
- package/dist/src/modular/emitModels.js +19 -6
- package/dist/src/modular/emitModels.js.map +1 -1
- package/dist/src/modular/helpers/clientHelpers.d.ts.map +1 -1
- package/dist/src/modular/helpers/clientHelpers.js +2 -11
- package/dist/src/modular/helpers/clientHelpers.js.map +1 -1
- package/dist/src/modular/helpers/credentialHelpers.js +1 -1
- package/dist/src/modular/helpers/credentialHelpers.js.map +1 -1
- package/dist/src/modular/helpers/fixmeHelpers.d.ts +2 -0
- package/dist/src/modular/helpers/fixmeHelpers.d.ts.map +1 -0
- package/dist/src/modular/helpers/fixmeHelpers.js +4 -0
- package/dist/src/modular/helpers/fixmeHelpers.js.map +1 -0
- package/dist/src/modular/helpers/namingHelpers.d.ts +10 -1
- package/dist/src/modular/helpers/namingHelpers.d.ts.map +1 -1
- package/dist/src/modular/helpers/namingHelpers.js +20 -0
- package/dist/src/modular/helpers/namingHelpers.js.map +1 -1
- package/dist/src/modular/helpers/operationHelpers.d.ts +2 -0
- package/dist/src/modular/helpers/operationHelpers.d.ts.map +1 -1
- package/dist/src/modular/helpers/operationHelpers.js +117 -35
- package/dist/src/modular/helpers/operationHelpers.js.map +1 -1
- package/dist/src/modular/helpers/parameterHelpers.js +1 -1
- package/dist/src/modular/helpers/parameterHelpers.js.map +1 -1
- package/dist/src/modular/helpers/typeHelpers.d.ts.map +1 -1
- package/dist/src/modular/helpers/typeHelpers.js +31 -12
- package/dist/src/modular/helpers/typeHelpers.js.map +1 -1
- package/dist/src/modular/modularCodeModel.d.ts +2 -1
- package/dist/src/modular/modularCodeModel.d.ts.map +1 -1
- package/dist/src/operationUtil.d.ts +1 -1
- package/dist/src/operationUtil.d.ts.map +1 -1
- package/dist/src/operationUtil.js +21 -3
- package/dist/src/operationUtil.js.map +1 -1
- package/dist/src/transform/transform.d.ts.map +1 -1
- package/dist/src/transform/transform.js +2 -2
- package/dist/src/transform/transform.js.map +1 -1
- package/dist/src/transform/transformApiVersionInfo.js +9 -0
- package/dist/src/transform/transformApiVersionInfo.js.map +1 -1
- package/dist/src/transform/transformHelperFunctionDetails.d.ts.map +1 -1
- package/dist/src/transform/transformHelperFunctionDetails.js +27 -1
- package/dist/src/transform/transformHelperFunctionDetails.js.map +1 -1
- package/dist/src/transform/transformParameters.d.ts +1 -0
- package/dist/src/transform/transformParameters.d.ts.map +1 -1
- package/dist/src/transform/transformParameters.js +36 -35
- package/dist/src/transform/transformParameters.js.map +1 -1
- package/dist/src/transform/transformPaths.d.ts.map +1 -1
- package/dist/src/transform/transformPaths.js +9 -0
- package/dist/src/transform/transformPaths.js.map +1 -1
- package/dist/src/transform/transformResponses.d.ts.map +1 -1
- package/dist/src/transform/transformResponses.js +10 -1
- package/dist/src/transform/transformResponses.js.map +1 -1
- package/dist/src/transform/transformSchemas.d.ts.map +1 -1
- package/dist/src/transform/transformSchemas.js +9 -0
- package/dist/src/transform/transformSchemas.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +20 -15
- package/src/index.ts +47 -2
- package/src/modelUtils.ts +90 -15
- package/src/modular/buildApiIndex.ts +3 -1
- package/src/modular/buildClassicalClient.ts +8 -6
- package/src/modular/buildClientContext.ts +11 -3
- package/src/modular/buildCodeModel.ts +221 -196
- package/src/modular/buildOperations.ts +23 -1
- package/src/modular/buildRootIndex.ts +2 -2
- package/src/modular/buildSharedTypes.ts +8 -10
- package/src/modular/emitModels.ts +14 -0
- package/src/modular/helpers/clientHelpers.ts +3 -13
- package/src/modular/helpers/credentialHelpers.ts +1 -1
- package/src/modular/helpers/fixmeHelpers.ts +3 -0
- package/src/modular/helpers/namingHelpers.ts +35 -1
- package/src/modular/helpers/operationHelpers.ts +173 -66
- package/src/modular/helpers/parameterHelpers.ts +1 -1
- package/src/modular/helpers/typeHelpers.ts +33 -12
- package/src/modular/modularCodeModel.ts +3 -1
- package/src/operationUtil.ts +24 -3
- package/src/transform/transform.ts +4 -1
- package/src/transform/transformApiVersionInfo.ts +8 -0
- package/src/transform/transformHelperFunctionDetails.ts +25 -1
- package/src/transform/transformParameters.ts +52 -41
- package/src/transform/transformPaths.ts +8 -0
- package/src/transform/transformResponses.ts +9 -1
- package/src/transform/transformSchemas.ts +8 -0
- package/.eslintrc.json +0 -23
- package/.prettierignore +0 -1
- package/.prettierrc +0 -7
- package/.rush/temp/operation/build/all.log +0 -1
- package/.rush/temp/operation/build/state.json +0 -3
- package/.rush/temp/package-deps_build.json +0 -442
- package/.rush/temp/shrinkwrap-deps.json +0 -490
- package/CONTRIBUTING.md +0 -137
- package/test/commands/cadl-ranch-list.ts +0 -116
- package/test/commands/check-clean-tree.ts +0 -55
- package/test/commands/childProcessOnExit.ts +0 -16
- package/test/commands/gen-cadl-ranch.ts +0 -25
- package/test/commands/run.ts +0 -31
- package/test/integration/arrayItemTypes.spec.ts +0 -96
- package/test/integration/authApiKey.spec.ts +0 -38
- package/test/integration/authOauth2.spec.ts +0 -65
- package/test/integration/authUnion.spec.ts +0 -72
- package/test/integration/azurecore.spec.ts +0 -170
- package/test/integration/collectionFormat.spec.ts +0 -118
- package/test/integration/dictionary.spec.ts +0 -106
- package/test/integration/extensibleEnums.spec.ts +0 -61
- package/test/integration/fixedEnums.spec.ts +0 -52
- package/test/integration/generated/arrays/itemTypes/src/arrayItemTypesClient.ts +0 -35
- package/test/integration/generated/arrays/itemTypes/src/clientDefinitions.ts +0 -165
- package/test/integration/generated/arrays/itemTypes/src/index.ts +0 -13
- package/test/integration/generated/arrays/itemTypes/src/logger.ts +0 -5
- package/test/integration/generated/arrays/itemTypes/src/models.ts +0 -9
- package/test/integration/generated/arrays/itemTypes/src/outputModels.ts +0 -9
- package/test/integration/generated/arrays/itemTypes/src/parameters.ts +0 -86
- package/test/integration/generated/arrays/itemTypes/src/responses.ts +0 -115
- package/test/integration/generated/arrays/itemTypes/tspconfig.yaml +0 -15
- package/test/integration/generated/authentication/apiKey/.eslintrc.json +0 -11
- package/test/integration/generated/authentication/apiKey/README.md +0 -56
- package/test/integration/generated/authentication/apiKey/api-extractor.json +0 -18
- package/test/integration/generated/authentication/apiKey/karma.conf.js +0 -133
- package/test/integration/generated/authentication/apiKey/package.json +0 -103
- package/test/integration/generated/authentication/apiKey/rollup.config.js +0 -118
- package/test/integration/generated/authentication/apiKey/src/authApiKeyClient.ts +0 -45
- package/test/integration/generated/authentication/apiKey/src/clientDefinitions.ts +0 -33
- package/test/integration/generated/authentication/apiKey/src/index.ts +0 -12
- package/test/integration/generated/authentication/apiKey/src/logger.ts +0 -5
- package/test/integration/generated/authentication/apiKey/src/outputModels.ts +0 -6
- package/test/integration/generated/authentication/apiKey/src/parameters.ts +0 -7
- package/test/integration/generated/authentication/apiKey/src/responses.ts +0 -21
- package/test/integration/generated/authentication/apiKey/test/public/sampleTest.spec.ts +0 -23
- package/test/integration/generated/authentication/apiKey/test/public/utils/env.browser.ts +0 -2
- package/test/integration/generated/authentication/apiKey/test/public/utils/env.ts +0 -6
- package/test/integration/generated/authentication/apiKey/test/public/utils/recordedClient.ts +0 -29
- package/test/integration/generated/authentication/apiKey/tsconfig.json +0 -25
- package/test/integration/generated/authentication/apiKey/tspconfig.yaml +0 -13
- package/test/integration/generated/authentication/oauth2/karma.conf.js +0 -133
- package/test/integration/generated/authentication/oauth2/src/authOauth2Client.ts +0 -45
- package/test/integration/generated/authentication/oauth2/src/clientDefinitions.ts +0 -33
- package/test/integration/generated/authentication/oauth2/src/index.ts +0 -12
- package/test/integration/generated/authentication/oauth2/src/logger.ts +0 -5
- package/test/integration/generated/authentication/oauth2/src/outputModels.ts +0 -6
- package/test/integration/generated/authentication/oauth2/src/parameters.ts +0 -7
- package/test/integration/generated/authentication/oauth2/src/responses.ts +0 -21
- package/test/integration/generated/authentication/oauth2/test/public/sampleTest.spec.ts +0 -23
- package/test/integration/generated/authentication/oauth2/test/public/utils/env.browser.ts +0 -2
- package/test/integration/generated/authentication/oauth2/test/public/utils/env.ts +0 -6
- package/test/integration/generated/authentication/oauth2/test/public/utils/recordedClient.ts +0 -29
- package/test/integration/generated/authentication/oauth2/tspconfig.yaml +0 -15
- package/test/integration/generated/authentication/union/karma.conf.js +0 -133
- package/test/integration/generated/authentication/union/src/authUnionClient.ts +0 -46
- package/test/integration/generated/authentication/union/src/clientDefinitions.ts +0 -27
- package/test/integration/generated/authentication/union/src/index.ts +0 -11
- package/test/integration/generated/authentication/union/src/logger.ts +0 -5
- package/test/integration/generated/authentication/union/src/parameters.ts +0 -7
- package/test/integration/generated/authentication/union/src/responses.ts +0 -14
- package/test/integration/generated/authentication/union/test/public/sampleTest.spec.ts +0 -23
- package/test/integration/generated/authentication/union/test/public/utils/env.browser.ts +0 -2
- package/test/integration/generated/authentication/union/test/public/utils/env.ts +0 -6
- package/test/integration/generated/authentication/union/test/public/utils/recordedClient.ts +0 -29
- package/test/integration/generated/authentication/union/tspconfig.yaml +0 -15
- package/test/integration/generated/azure/core/.eslintrc.json +0 -11
- package/test/integration/generated/azure/core/README.md +0 -56
- package/test/integration/generated/azure/core/api-extractor.json +0 -18
- package/test/integration/generated/azure/core/package.json +0 -81
- package/test/integration/generated/azure/core/rollup.config.js +0 -118
- package/test/integration/generated/azure/core/src/azureCoreClient.ts +0 -35
- package/test/integration/generated/azure/core/src/clientDefinitions.ts +0 -108
- package/test/integration/generated/azure/core/src/index.ts +0 -16
- package/test/integration/generated/azure/core/src/isUnexpected.ts +0 -178
- package/test/integration/generated/azure/core/src/logger.ts +0 -5
- package/test/integration/generated/azure/core/src/models.ts +0 -18
- package/test/integration/generated/azure/core/src/outputModels.ts +0 -38
- package/test/integration/generated/azure/core/src/paginateHelper.ts +0 -204
- package/test/integration/generated/azure/core/src/parameters.ts +0 -68
- package/test/integration/generated/azure/core/src/responses.ts +0 -158
- package/test/integration/generated/azure/core/src/serializeHelper.ts +0 -16
- package/test/integration/generated/azure/core/tsconfig.json +0 -25
- package/test/integration/generated/azure/core/tspconfig.yaml +0 -15
- package/test/integration/generated/azure/core-traits/.eslintrc.json +0 -11
- package/test/integration/generated/azure/core-traits/README.md +0 -56
- package/test/integration/generated/azure/core-traits/api-extractor.json +0 -18
- package/test/integration/generated/azure/core-traits/package.json +0 -80
- package/test/integration/generated/azure/core-traits/rollup.config.js +0 -118
- package/test/integration/generated/azure/core-traits/src/azureCoreTraitsClient.ts +0 -35
- package/test/integration/generated/azure/core-traits/src/clientDefinitions.ts +0 -22
- package/test/integration/generated/azure/core-traits/src/index.ts +0 -13
- package/test/integration/generated/azure/core-traits/src/isUnexpected.ts +0 -97
- package/test/integration/generated/azure/core-traits/src/logger.ts +0 -5
- package/test/integration/generated/azure/core-traits/src/outputModels.ts +0 -25
- package/test/integration/generated/azure/core-traits/src/parameters.ts +0 -26
- package/test/integration/generated/azure/core-traits/src/responses.ts +0 -32
- package/test/integration/generated/azure/core-traits/tsconfig.json +0 -25
- package/test/integration/generated/azure/core-traits/tspconfig.yaml +0 -15
- package/test/integration/generated/dictionary/.eslintrc.json +0 -11
- package/test/integration/generated/dictionary/README.md +0 -56
- package/test/integration/generated/dictionary/api-extractor.json +0 -18
- package/test/integration/generated/dictionary/package.json +0 -80
- package/test/integration/generated/dictionary/rollup.config.js +0 -118
- package/test/integration/generated/dictionary/src/clientDefinitions.ts +0 -180
- package/test/integration/generated/dictionary/src/dictClient.ts +0 -33
- package/test/integration/generated/dictionary/src/index.ts +0 -13
- package/test/integration/generated/dictionary/src/logger.ts +0 -5
- package/test/integration/generated/dictionary/src/models.ts +0 -9
- package/test/integration/generated/dictionary/src/outputModels.ts +0 -9
- package/test/integration/generated/dictionary/src/parameters.ts +0 -94
- package/test/integration/generated/dictionary/src/responses.ts +0 -126
- package/test/integration/generated/dictionary/tsconfig.json +0 -25
- package/test/integration/generated/dictionary/tspconfig.yaml +0 -15
- package/test/integration/generated/enums/extensible/.eslintrc.json +0 -11
- package/test/integration/generated/enums/extensible/README.md +0 -56
- package/test/integration/generated/enums/extensible/api-extractor.json +0 -18
- package/test/integration/generated/enums/extensible/package.json +0 -80
- package/test/integration/generated/enums/extensible/rollup.config.js +0 -118
- package/test/integration/generated/enums/extensible/src/clientDefinitions.ts +0 -45
- package/test/integration/generated/enums/extensible/src/index.ts +0 -11
- package/test/integration/generated/enums/extensible/src/logger.ts +0 -5
- package/test/integration/generated/enums/extensible/src/parameters.ts +0 -23
- package/test/integration/generated/enums/extensible/src/responses.ts +0 -26
- package/test/integration/generated/enums/extensible/src/typeEnumExtensible.ts +0 -35
- package/test/integration/generated/enums/extensible/tsconfig.json +0 -25
- package/test/integration/generated/enums/extensible/tspconfig.yaml +0 -14
- package/test/integration/generated/enums/fixed/.eslintrc.json +0 -11
- package/test/integration/generated/enums/fixed/README.md +0 -56
- package/test/integration/generated/enums/fixed/api-extractor.json +0 -18
- package/test/integration/generated/enums/fixed/package.json +0 -80
- package/test/integration/generated/enums/fixed/rollup.config.js +0 -118
- package/test/integration/generated/enums/fixed/src/clientDefinitions.ts +0 -43
- package/test/integration/generated/enums/fixed/src/index.ts +0 -11
- package/test/integration/generated/enums/fixed/src/logger.ts +0 -5
- package/test/integration/generated/enums/fixed/src/parameters.ts +0 -36
- package/test/integration/generated/enums/fixed/src/responses.ts +0 -27
- package/test/integration/generated/enums/fixed/src/typeEnumFixed.ts +0 -35
- package/test/integration/generated/enums/fixed/tsconfig.json +0 -25
- package/test/integration/generated/enums/fixed/tspconfig.yaml +0 -14
- package/test/integration/generated/hello/.eslintrc.json +0 -11
- package/test/integration/generated/hello/README.md +0 -56
- package/test/integration/generated/hello/api-extractor.json +0 -18
- package/test/integration/generated/hello/package.json +0 -80
- package/test/integration/generated/hello/rollup.config.js +0 -118
- package/test/integration/generated/hello/src/clientDefinitions.ts +0 -19
- package/test/integration/generated/hello/src/hello.ts +0 -29
- package/test/integration/generated/hello/src/index.ts +0 -11
- package/test/integration/generated/hello/src/parameters.ts +0 -6
- package/test/integration/generated/hello/src/responses.ts +0 -10
- package/test/integration/generated/hello/tsconfig.json +0 -25
- package/test/integration/generated/hello/tspconfig.yaml +0 -14
- package/test/integration/generated/internal/src/clientDefinitions.ts +0 -53
- package/test/integration/generated/internal/src/index.ts +0 -12
- package/test/integration/generated/internal/src/internalClient.ts +0 -35
- package/test/integration/generated/internal/src/logger.ts +0 -5
- package/test/integration/generated/internal/src/outputModels.ts +0 -17
- package/test/integration/generated/internal/src/parameters.ts +0 -45
- package/test/integration/generated/internal/src/responses.ts +0 -33
- package/test/integration/generated/internal/tspconfig.yaml +0 -14
- package/test/integration/generated/lro/lroCore/.eslintrc.json +0 -11
- package/test/integration/generated/lro/lroCore/README.md +0 -56
- package/test/integration/generated/lro/lroCore/api-extractor.json +0 -18
- package/test/integration/generated/lro/lroCore/package.json +0 -82
- package/test/integration/generated/lro/lroCore/rollup.config.js +0 -118
- package/test/integration/generated/lro/lroCore/src/clientDefinitions.ts +0 -54
- package/test/integration/generated/lro/lroCore/src/index.ts +0 -15
- package/test/integration/generated/lro/lroCore/src/isUnexpected.ts +0 -135
- package/test/integration/generated/lro/lroCore/src/logger.ts +0 -5
- package/test/integration/generated/lro/lroCore/src/models.ts +0 -8
- package/test/integration/generated/lro/lroCore/src/outputModels.ts +0 -50
- package/test/integration/generated/lro/lroCore/src/parameters.ts +0 -25
- package/test/integration/generated/lro/lroCore/src/pollingHelper.ts +0 -113
- package/test/integration/generated/lro/lroCore/src/responses.ts +0 -109
- package/test/integration/generated/lro/lroCore/src/specsAzureCoreLroStandard.ts +0 -35
- package/test/integration/generated/lro/lroCore/tsconfig.json +0 -25
- package/test/integration/generated/lro/lroCore/tspconfig.yaml +0 -14
- package/test/integration/generated/lro/lroRPC/.eslintrc.json +0 -11
- package/test/integration/generated/lro/lroRPC/README.md +0 -56
- package/test/integration/generated/lro/lroRPC/api-extractor.json +0 -18
- package/test/integration/generated/lro/lroRPC/package.json +0 -82
- package/test/integration/generated/lro/lroRPC/rollup.config.js +0 -118
- package/test/integration/generated/lro/lroRPC/src/clientDefinitions.ts +0 -79
- package/test/integration/generated/lro/lroRPC/src/index.ts +0 -15
- package/test/integration/generated/lro/lroRPC/src/isUnexpected.ts +0 -153
- package/test/integration/generated/lro/lroRPC/src/logger.ts +0 -5
- package/test/integration/generated/lro/lroRPC/src/models.ts +0 -8
- package/test/integration/generated/lro/lroRPC/src/outputModels.ts +0 -40
- package/test/integration/generated/lro/lroRPC/src/parameters.ts +0 -20
- package/test/integration/generated/lro/lroRPC/src/pollingHelper.ts +0 -127
- package/test/integration/generated/lro/lroRPC/src/responses.ts +0 -124
- package/test/integration/generated/lro/lroRPC/src/specsAzureCoreLroRpc.ts +0 -35
- package/test/integration/generated/lro/lroRPC/tsconfig.json +0 -25
- package/test/integration/generated/lro/lroRPC/tspconfig.yaml +0 -14
- package/test/integration/generated/models/inheritance/.eslintrc.json +0 -11
- package/test/integration/generated/models/inheritance/README.md +0 -56
- package/test/integration/generated/models/inheritance/api-extractor.json +0 -18
- package/test/integration/generated/models/inheritance/package.json +0 -80
- package/test/integration/generated/models/inheritance/rollup.config.js +0 -118
- package/test/integration/generated/models/inheritance/src/clientDefinitions.ts +0 -81
- package/test/integration/generated/models/inheritance/src/index.ts +0 -13
- package/test/integration/generated/models/inheritance/src/logger.ts +0 -5
- package/test/integration/generated/models/inheritance/src/models.ts +0 -52
- package/test/integration/generated/models/inheritance/src/outputModels.ts +0 -52
- package/test/integration/generated/models/inheritance/src/parameters.ts +0 -35
- package/test/integration/generated/models/inheritance/src/responses.ts +0 -56
- package/test/integration/generated/models/inheritance/src/typeModelInheritance.ts +0 -35
- package/test/integration/generated/models/inheritance/tsconfig.json +0 -25
- package/test/integration/generated/models/inheritance/tspconfig.yaml +0 -14
- package/test/integration/generated/models/propertyNullable/.eslintrc.json +0 -11
- package/test/integration/generated/models/propertyNullable/README.md +0 -56
- package/test/integration/generated/models/propertyNullable/api-extractor.json +0 -18
- package/test/integration/generated/models/propertyNullable/package.json +0 -80
- package/test/integration/generated/models/propertyNullable/rollup.config.js +0 -118
- package/test/integration/generated/models/propertyNullable/src/clientDefinitions.ts +0 -227
- package/test/integration/generated/models/propertyNullable/src/index.ts +0 -13
- package/test/integration/generated/models/propertyNullable/src/logger.ts +0 -5
- package/test/integration/generated/models/propertyNullable/src/models.ts +0 -56
- package/test/integration/generated/models/propertyNullable/src/outputModels.ts +0 -56
- package/test/integration/generated/models/propertyNullable/src/parameters.ts +0 -197
- package/test/integration/generated/models/propertyNullable/src/responses.ts +0 -144
- package/test/integration/generated/models/propertyNullable/src/typePropertyNullable.ts +0 -35
- package/test/integration/generated/models/propertyNullable/tsconfig.json +0 -25
- package/test/integration/generated/models/propertyNullable/tspconfig.yaml +0 -14
- package/test/integration/generated/models/propertyOptional/.eslintrc.json +0 -11
- package/test/integration/generated/models/propertyOptional/README.md +0 -56
- package/test/integration/generated/models/propertyOptional/api-extractor.json +0 -18
- package/test/integration/generated/models/propertyOptional/package.json +0 -80
- package/test/integration/generated/models/propertyOptional/rollup.config.js +0 -118
- package/test/integration/generated/models/propertyOptional/src/clientDefinitions.ts +0 -263
- package/test/integration/generated/models/propertyOptional/src/index.ts +0 -13
- package/test/integration/generated/models/propertyOptional/src/logger.ts +0 -5
- package/test/integration/generated/models/propertyOptional/src/models.ts +0 -46
- package/test/integration/generated/models/propertyOptional/src/outputModels.ts +0 -46
- package/test/integration/generated/models/propertyOptional/src/parameters.ts +0 -125
- package/test/integration/generated/models/propertyOptional/src/responses.ts +0 -169
- package/test/integration/generated/models/propertyOptional/src/typePropertyOptional.ts +0 -35
- package/test/integration/generated/models/propertyOptional/tsconfig.json +0 -25
- package/test/integration/generated/models/propertyOptional/tspconfig.yaml +0 -14
- package/test/integration/generated/models/propertyTypes/.eslintrc.json +0 -11
- package/test/integration/generated/models/propertyTypes/README.md +0 -56
- package/test/integration/generated/models/propertyTypes/api-extractor.json +0 -18
- package/test/integration/generated/models/propertyTypes/package.json +0 -80
- package/test/integration/generated/models/propertyTypes/rollup.config.js +0 -118
- package/test/integration/generated/models/propertyTypes/src/clientDefinitions.ts +0 -310
- package/test/integration/generated/models/propertyTypes/src/index.ts +0 -13
- package/test/integration/generated/models/propertyTypes/src/logger.ts +0 -5
- package/test/integration/generated/models/propertyTypes/src/models.ts +0 -123
- package/test/integration/generated/models/propertyTypes/src/outputModels.ts +0 -123
- package/test/integration/generated/models/propertyTypes/src/parameters.ts +0 -189
- package/test/integration/generated/models/propertyTypes/src/responses.ts +0 -234
- package/test/integration/generated/models/propertyTypes/src/typePropertyValueTypes.ts +0 -35
- package/test/integration/generated/models/propertyTypes/tsconfig.json +0 -25
- package/test/integration/generated/models/propertyTypes/tspconfig.yaml +0 -14
- package/test/integration/generated/models/usage/.eslintrc.json +0 -11
- package/test/integration/generated/models/usage/README.md +0 -56
- package/test/integration/generated/models/usage/api-extractor.json +0 -18
- package/test/integration/generated/models/usage/package.json +0 -80
- package/test/integration/generated/models/usage/rollup.config.js +0 -118
- package/test/integration/generated/models/usage/src/clientDefinitions.ts +0 -41
- package/test/integration/generated/models/usage/src/index.ts +0 -13
- package/test/integration/generated/models/usage/src/logger.ts +0 -5
- package/test/integration/generated/models/usage/src/models.ts +0 -12
- package/test/integration/generated/models/usage/src/outputModels.ts +0 -12
- package/test/integration/generated/models/usage/src/parameters.ts +0 -19
- package/test/integration/generated/models/usage/src/responses.ts +0 -22
- package/test/integration/generated/models/usage/src/typeModelUsage.ts +0 -35
- package/test/integration/generated/models/usage/tsconfig.json +0 -25
- package/test/integration/generated/models/usage/tspconfig.yaml +0 -14
- package/test/integration/generated/models/visibility/.eslintrc.json +0 -11
- package/test/integration/generated/models/visibility/README.md +0 -56
- package/test/integration/generated/models/visibility/api-extractor.json +0 -18
- package/test/integration/generated/models/visibility/package.json +0 -80
- package/test/integration/generated/models/visibility/rollup.config.js +0 -118
- package/test/integration/generated/models/visibility/src/clientDefinitions.ts +0 -40
- package/test/integration/generated/models/visibility/src/index.ts +0 -13
- package/test/integration/generated/models/visibility/src/logger.ts +0 -5
- package/test/integration/generated/models/visibility/src/models.ts +0 -14
- package/test/integration/generated/models/visibility/src/outputModels.ts +0 -16
- package/test/integration/generated/models/visibility/src/parameters.ts +0 -41
- package/test/integration/generated/models/visibility/src/responses.ts +0 -36
- package/test/integration/generated/models/visibility/src/typeModelVisibility.ts +0 -35
- package/test/integration/generated/models/visibility/tsconfig.json +0 -25
- package/test/integration/generated/models/visibility/tspconfig.yaml +0 -14
- package/test/integration/generated/parameters/collection-format/src/clientDefinitions.ts +0 -63
- package/test/integration/generated/parameters/collection-format/src/collectionFormatClient.ts +0 -35
- package/test/integration/generated/parameters/collection-format/src/index.ts +0 -12
- package/test/integration/generated/parameters/collection-format/src/logger.ts +0 -5
- package/test/integration/generated/parameters/collection-format/src/parameters.ts +0 -71
- package/test/integration/generated/parameters/collection-format/src/responses.ts +0 -34
- package/test/integration/generated/parameters/collection-format/src/serializeHelper.ts +0 -28
- package/test/integration/generated/parameters/collection-format/tspconfig.yaml +0 -14
- package/test/integration/generated/parameters/spread/src/clientDefinitions.ts +0 -61
- package/test/integration/generated/parameters/spread/src/index.ts +0 -12
- package/test/integration/generated/parameters/spread/src/logger.ts +0 -5
- package/test/integration/generated/parameters/spread/src/models.ts +0 -7
- package/test/integration/generated/parameters/spread/src/parameters.ts +0 -61
- package/test/integration/generated/parameters/spread/src/parametersSpread.ts +0 -35
- package/test/integration/generated/parameters/spread/src/responses.ts +0 -25
- package/test/integration/generated/parameters/spread/tspconfig.yaml +0 -12
- package/test/integration/generated/projection/src/clientDefinitions.ts +0 -71
- package/test/integration/generated/projection/src/index.ts +0 -12
- package/test/integration/generated/projection/src/logger.ts +0 -5
- package/test/integration/generated/projection/src/models.ts +0 -22
- package/test/integration/generated/projection/src/parameters.ts +0 -48
- package/test/integration/generated/projection/src/projectionClient.ts +0 -35
- package/test/integration/generated/projection/src/responses.ts +0 -34
- package/test/integration/generated/projection/tspconfig.yaml +0 -14
- package/test/integration/generated/resiliency/srvDriven1/.eslintrc.json +0 -11
- package/test/integration/generated/resiliency/srvDriven1/README.md +0 -56
- package/test/integration/generated/resiliency/srvDriven1/api-extractor.json +0 -18
- package/test/integration/generated/resiliency/srvDriven1/package.json +0 -80
- package/test/integration/generated/resiliency/srvDriven1/rollup.config.js +0 -118
- package/test/integration/generated/resiliency/srvDriven1/src/clientDefinitions.ts +0 -46
- package/test/integration/generated/resiliency/srvDriven1/src/index.ts +0 -11
- package/test/integration/generated/resiliency/srvDriven1/src/logger.ts +0 -5
- package/test/integration/generated/resiliency/srvDriven1/src/parameters.ts +0 -30
- package/test/integration/generated/resiliency/srvDriven1/src/responses.ts +0 -19
- package/test/integration/generated/resiliency/srvDriven1/src/serviceDrivenOldClient.ts +0 -43
- package/test/integration/generated/resiliency/srvDriven1/tsconfig.json +0 -25
- package/test/integration/generated/resiliency/srvDriven1/tspconfig.yaml +0 -15
- package/test/integration/generated/resiliency/srvDriven2/.eslintrc.json +0 -11
- package/test/integration/generated/resiliency/srvDriven2/README.md +0 -65
- package/test/integration/generated/resiliency/srvDriven2/api-extractor.json +0 -18
- package/test/integration/generated/resiliency/srvDriven2/package.json +0 -80
- package/test/integration/generated/resiliency/srvDriven2/rollup.config.js +0 -118
- package/test/integration/generated/resiliency/srvDriven2/src/clientDefinitions.ts +0 -57
- package/test/integration/generated/resiliency/srvDriven2/src/index.ts +0 -11
- package/test/integration/generated/resiliency/srvDriven2/src/logger.ts +0 -5
- package/test/integration/generated/resiliency/srvDriven2/src/parameters.ts +0 -45
- package/test/integration/generated/resiliency/srvDriven2/src/responses.ts +0 -24
- package/test/integration/generated/resiliency/srvDriven2/src/serviceDrivenNewClient.ts +0 -43
- package/test/integration/generated/resiliency/srvDriven2/tsconfig.json +0 -25
- package/test/integration/generated/resiliency/srvDriven2/tspconfig.yaml +0 -15
- package/test/integration/generated/server/path/multiple/src/clientDefinitions.ts +0 -35
- package/test/integration/generated/server/path/multiple/src/index.ts +0 -11
- package/test/integration/generated/server/path/multiple/src/logger.ts +0 -5
- package/test/integration/generated/server/path/multiple/src/multipleParamInServerPathClient.ts +0 -43
- package/test/integration/generated/server/path/multiple/src/parameters.ts +0 -7
- package/test/integration/generated/server/path/multiple/src/responses.ts +0 -14
- package/test/integration/generated/server/path/multiple/tspconfig.yaml +0 -14
- package/test/integration/generated/server/path/single/src/clientDefinitions.ts +0 -19
- package/test/integration/generated/server/path/single/src/index.ts +0 -11
- package/test/integration/generated/server/path/single/src/logger.ts +0 -5
- package/test/integration/generated/server/path/single/src/parameters.ts +0 -6
- package/test/integration/generated/server/path/single/src/responses.ts +0 -9
- package/test/integration/generated/server/path/single/src/singleParamInServerPathClient.ts +0 -38
- package/test/integration/generated/server/path/single/tspconfig.yaml +0 -14
- package/test/integration/generated/specialWords/src/clientDefinitions.ts +0 -61
- package/test/integration/generated/specialWords/src/index.ts +0 -13
- package/test/integration/generated/specialWords/src/logger.ts +0 -5
- package/test/integration/generated/specialWords/src/models.ts +0 -17
- package/test/integration/generated/specialWords/src/outputModels.ts +0 -17
- package/test/integration/generated/specialWords/src/parameters.ts +0 -37
- package/test/integration/generated/specialWords/src/responses.ts +0 -31
- package/test/integration/generated/specialWords/src/specialWordsClient.ts +0 -35
- package/test/integration/generated/specialWords/tspconfig.yaml +0 -14
- package/test/integration/generated/unions/src/clientDefinitions.ts +0 -53
- package/test/integration/generated/unions/src/index.ts +0 -12
- package/test/integration/generated/unions/src/logger.ts +0 -5
- package/test/integration/generated/unions/src/models.ts +0 -27
- package/test/integration/generated/unions/src/parameters.ts +0 -34
- package/test/integration/generated/unions/src/responses.ts +0 -24
- package/test/integration/generated/unions/src/unionsClient.ts +0 -35
- package/test/integration/generated/unions/tspconfig.yaml +0 -14
- package/test/integration/internal.spec.ts +0 -76
- package/test/integration/lroCore.spec.ts +0 -89
- package/test/integration/modelInheritance.spec.ts +0 -192
- package/test/integration/modelPropertyNullable.spec.ts +0 -115
- package/test/integration/modelPropertyOptional.spec.ts +0 -362
- package/test/integration/modelPropertyType.spec.ts +0 -135
- package/test/integration/modelUsage.spec.ts +0 -47
- package/test/integration/projection.spec.ts +0 -102
- package/test/integration/resiliencyDpgCustomization.spec.ts +0 -147
- package/test/integration/server.spec.ts +0 -59
- package/test/integration/specialWords.spec.ts +0 -73
- package/test/integration/spreadParameters.spec.ts +0 -82
- package/test/integration/unions.spec.ts +0 -69
- package/test/tsconfig.json +0 -4
- package/test/unit/apiVersion.spec.ts +0 -400
- package/test/unit/azureCoreOperationsGenerator.spec.ts +0 -71
- package/test/unit/clientDefinitionGenerator.spec.ts +0 -73
- package/test/unit/clientFactoryGenerator.spec.ts +0 -404
- package/test/unit/docsGenerator.spec.ts +0 -201
- package/test/unit/modelsGenerator.spec.ts +0 -1529
- package/test/unit/parametersGenerator.spec.ts +0 -561
- package/test/unit/responsesGenerator.spec.ts +0 -462
- package/test/unit/spreadAndAlias.spec.ts +0 -200
- package/test/unit/util/emitUtil.ts +0 -166
- package/test/unit/util/testUtil.ts +0 -88
- package/test/util/customBearerTokenTestingPolicy.ts +0 -78
- package/test/util/matrix.ts +0 -48
- package/tsconfig.json +0 -36
- package/tsconfig.test.json +0 -7
- package/typespec-ts.build.log +0 -1
|
@@ -2,6 +2,8 @@ import { Project, SourceFile } from "ts-morph";
|
|
|
2
2
|
import { buildType } from "./helpers/typeHelpers.js";
|
|
3
3
|
import {
|
|
4
4
|
getOperationFunction,
|
|
5
|
+
getSendPrivateFunction,
|
|
6
|
+
getDeserializePrivateFunction,
|
|
5
7
|
getOperationOptionsName
|
|
6
8
|
} from "./helpers/operationHelpers.js";
|
|
7
9
|
import { Client, Operation } from "./modularCodeModel.js";
|
|
@@ -30,7 +32,13 @@ export function buildOperationFiles(
|
|
|
30
32
|
operationGroup.operations.forEach((o) => {
|
|
31
33
|
buildOperationOptions(o, operationGroupFile);
|
|
32
34
|
const operationDeclaration = getOperationFunction(o);
|
|
33
|
-
|
|
35
|
+
const sendOperationDeclaration = getSendPrivateFunction(o);
|
|
36
|
+
const deserializeOperationDeclaration = getDeserializePrivateFunction(o);
|
|
37
|
+
operationGroupFile.addFunctions([
|
|
38
|
+
sendOperationDeclaration,
|
|
39
|
+
deserializeOperationDeclaration,
|
|
40
|
+
operationDeclaration
|
|
41
|
+
]);
|
|
34
42
|
});
|
|
35
43
|
|
|
36
44
|
operationGroupFile.addImportDeclarations([
|
|
@@ -40,6 +48,20 @@ export function buildOperationFiles(
|
|
|
40
48
|
}
|
|
41
49
|
]);
|
|
42
50
|
|
|
51
|
+
operationGroupFile.addImportDeclarations([
|
|
52
|
+
{
|
|
53
|
+
moduleSpecifier: "../common/interfaces.js",
|
|
54
|
+
namedImports: ["OperationRawReturnType"]
|
|
55
|
+
}
|
|
56
|
+
]);
|
|
57
|
+
|
|
58
|
+
operationGroupFile.addImportDeclarations([
|
|
59
|
+
{
|
|
60
|
+
moduleSpecifier: "@azure-rest/core-client",
|
|
61
|
+
namedImports: ["StreamableMethod"]
|
|
62
|
+
}
|
|
63
|
+
]);
|
|
64
|
+
|
|
43
65
|
// Import models used from ./models.ts
|
|
44
66
|
importModels(operationGroupFile, project);
|
|
45
67
|
operationGroupFile.fixMissingImports();
|
|
@@ -27,7 +27,7 @@ export function buildRootIndex(
|
|
|
27
27
|
file.addExportDeclarations([
|
|
28
28
|
{
|
|
29
29
|
moduleSpecifier: `./common/interfaces.js`,
|
|
30
|
-
namedExports: [`
|
|
30
|
+
namedExports: [`RequestOptions`]
|
|
31
31
|
}
|
|
32
32
|
]);
|
|
33
33
|
}
|
|
@@ -35,7 +35,7 @@ export function buildRootIndex(
|
|
|
35
35
|
function exportClassicalClient(client: Client, indexFile: SourceFile) {
|
|
36
36
|
const clientName = `${getClientName(client)}Client`;
|
|
37
37
|
indexFile.addExportDeclaration({
|
|
38
|
-
namedExports: [clientName],
|
|
38
|
+
namedExports: [clientName, `${clientName}Options`],
|
|
39
39
|
moduleSpecifier: `./${clientName}.js`
|
|
40
40
|
});
|
|
41
41
|
}
|
|
@@ -1,22 +1,20 @@
|
|
|
1
1
|
import { Project, SourceFile } from "ts-morph";
|
|
2
2
|
|
|
3
|
-
const content = `
|
|
3
|
+
const content = `
|
|
4
4
|
import { RawHttpHeadersInput } from "@azure/core-rest-pipeline";
|
|
5
|
-
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Common options to set on an outgoing operation
|
|
8
|
+
*/
|
|
6
9
|
export interface RequestOptions {
|
|
10
|
+
/**
|
|
11
|
+
* Options to set on an outgoing HTTP request
|
|
12
|
+
*/
|
|
7
13
|
requestOptions?: {
|
|
8
14
|
/**
|
|
9
15
|
* Headers to send along with the request
|
|
10
16
|
*/
|
|
11
17
|
headers?: RawHttpHeadersInput;
|
|
12
|
-
/**
|
|
13
|
-
* Body to send with the request
|
|
14
|
-
*/
|
|
15
|
-
body?: unknown;
|
|
16
|
-
/**
|
|
17
|
-
* Query parameters to send with the request
|
|
18
|
-
*/
|
|
19
|
-
queryParameters?: Record<string, unknown>;
|
|
20
18
|
/** Set to true if the request is sent over HTTP instead of HTTPS */
|
|
21
19
|
allowInsecureConnection?: boolean;
|
|
22
20
|
/** Set to true if you want to skip encoding the path parameters */
|
|
@@ -17,6 +17,16 @@ export function buildModels(
|
|
|
17
17
|
(t) => t.type === "model" || t.type === "enum"
|
|
18
18
|
);
|
|
19
19
|
|
|
20
|
+
for (const model of codeModel.types) {
|
|
21
|
+
if (model.type === "combined" && model.nullable) {
|
|
22
|
+
for (const unionModel of model.types ?? []) {
|
|
23
|
+
if (unionModel.type === "model") {
|
|
24
|
+
models.push(unionModel);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
20
30
|
for (const model of models) {
|
|
21
31
|
const properties = model.properties ?? [];
|
|
22
32
|
const typeMetadata = getType(model);
|
|
@@ -25,6 +35,10 @@ export function buildModels(
|
|
|
25
35
|
typeName = `${typeName}[]`;
|
|
26
36
|
}
|
|
27
37
|
if (model.type === "enum") {
|
|
38
|
+
if (modelsFile.getTypeAlias(model.name!)) {
|
|
39
|
+
// If the enum is already defined, we don't need to do anything
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
28
42
|
modelsFile.addTypeAlias({
|
|
29
43
|
name: model.name!,
|
|
30
44
|
isExported: true,
|
|
@@ -6,22 +6,12 @@ export function getClientParameters(
|
|
|
6
6
|
client: Client
|
|
7
7
|
): OptionalKind<ParameterDeclarationStructure>[] {
|
|
8
8
|
const { name, parameters } = client;
|
|
9
|
-
|
|
9
|
+
const optionsParam = {
|
|
10
10
|
name: "options",
|
|
11
|
-
type: `${name}
|
|
11
|
+
type: `${name}ClientOptions`,
|
|
12
12
|
initializer: "{}"
|
|
13
13
|
};
|
|
14
|
-
|
|
15
|
-
!client.parameters
|
|
16
|
-
.filter((p) => p.implementation === "Client" && !p.isApiVersion)
|
|
17
|
-
.some((p) => p.optional || (!p.optional && p.clientDefaultValue))
|
|
18
|
-
) {
|
|
19
|
-
optionsParam = {
|
|
20
|
-
name: "options",
|
|
21
|
-
type: `ClientOptions`,
|
|
22
|
-
initializer: "{}"
|
|
23
|
-
};
|
|
24
|
-
}
|
|
14
|
+
|
|
25
15
|
const params: OptionalKind<ParameterDeclarationStructure>[] = [
|
|
26
16
|
...parameters
|
|
27
17
|
.filter((p) => p.type.type !== "constant")
|
|
@@ -1,5 +1,39 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { toCamelCase, toPascalCase } from "../../casingUtils.js";
|
|
2
|
+
import { Client, Operation } from "../modularCodeModel.js";
|
|
3
|
+
import { ReservedModelNames, NameType, normalizeName } from "@azure-tools/rlc-common";
|
|
2
4
|
|
|
3
5
|
export function getClientName(client: Client) {
|
|
4
6
|
return client.name.replace(/Client$/, "");
|
|
5
7
|
}
|
|
8
|
+
|
|
9
|
+
export interface GuardedName {
|
|
10
|
+
name: string;
|
|
11
|
+
fixme?: string[];
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function getOperationName(
|
|
15
|
+
operation: Operation,
|
|
16
|
+
options: { casing: "camel" | "pascal" } = { casing: "camel" }
|
|
17
|
+
): GuardedName {
|
|
18
|
+
const casingFn = options.casing === "camel" ? toCamelCase : toPascalCase;
|
|
19
|
+
if (isReservedName(operation.name, NameType.Operation)) {
|
|
20
|
+
return {
|
|
21
|
+
name: normalizeName(operation.name, NameType.Operation, true),
|
|
22
|
+
fixme: [
|
|
23
|
+
`${operation.name} is a reserved word that cannot be used as an operation name. Please add @projectedName(
|
|
24
|
+
"javascript", "<JS-Specific-Name>") to the operation to override the generated name.`
|
|
25
|
+
]
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return {
|
|
30
|
+
name: casingFn(operation.name)
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export function isReservedName(name: string, nameType: NameType): boolean {
|
|
35
|
+
return ReservedModelNames.some(
|
|
36
|
+
(reservedName) =>
|
|
37
|
+
reservedName.name === name && reservedName.reservedFor.includes(nameType)
|
|
38
|
+
);
|
|
39
|
+
}
|
|
@@ -12,85 +12,186 @@ import {
|
|
|
12
12
|
Type
|
|
13
13
|
} from "../modularCodeModel.js";
|
|
14
14
|
import { buildType } from "./typeHelpers.js";
|
|
15
|
+
import { getOperationName } from "./namingHelpers.js";
|
|
16
|
+
import { getFixmeForMultilineDocs } from "./fixmeHelpers.js";
|
|
15
17
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
function getRLCResponseType(operation: Operation) {
|
|
19
|
+
const { name } = getOperationName(operation, { casing: "pascal" });
|
|
20
|
+
const statusCodes: (string | number)[] = Array.from(
|
|
21
|
+
new Set(operation.responses.flatMap((r) => r.statusCodes)).values()
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
statusCodes.push("Default");
|
|
25
|
+
|
|
26
|
+
return statusCodes.map((s) => `${name}${s}Response`).join(" | ");
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export function getSendPrivateFunction(
|
|
20
30
|
operation: Operation
|
|
21
31
|
): OptionalKind<FunctionDeclarationStructure> {
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
let parameters: OptionalKind<ParameterDeclarationStructure>[] = [];
|
|
32
|
+
const parameters = getOperationSignatureParameters(operation);
|
|
33
|
+
const { name } = getOperationName(operation);
|
|
25
34
|
|
|
35
|
+
const functionStatement: OptionalKind<FunctionDeclarationStructure> = {
|
|
36
|
+
isAsync: false,
|
|
37
|
+
isExported: true,
|
|
38
|
+
name: `_${name}Send`,
|
|
39
|
+
parameters,
|
|
40
|
+
returnType: `StreamableMethod<${getRLCResponseType(operation)}>`
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const operationPath = operation.url;
|
|
44
|
+
const operationMethod = operation.method.toLowerCase();
|
|
45
|
+
|
|
46
|
+
const statements: string[] = [];
|
|
47
|
+
statements.push(
|
|
48
|
+
`return context.path("${operationPath}", ${getPathParameters(
|
|
49
|
+
operation
|
|
50
|
+
)}).${operationMethod}({allowInsecureConnection: options.requestOptions?.allowInsecureConnection, skipUrlEncoding: options.requestOptions?.skipUrlEncoding, ${getRequestParameters(
|
|
51
|
+
operation
|
|
52
|
+
)}});`
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
return {
|
|
56
|
+
...functionStatement,
|
|
57
|
+
statements
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export function getDeserializePrivateFunction(
|
|
62
|
+
operation: Operation
|
|
63
|
+
): OptionalKind<FunctionDeclarationStructure> {
|
|
64
|
+
const { name } = getOperationName(operation);
|
|
65
|
+
|
|
66
|
+
const parameters: OptionalKind<ParameterDeclarationStructure>[] = [
|
|
67
|
+
{
|
|
68
|
+
name: "result",
|
|
69
|
+
type: getRLCResponseType(operation)
|
|
70
|
+
}
|
|
71
|
+
];
|
|
72
|
+
|
|
73
|
+
// TODO: Support operation overloads
|
|
74
|
+
const response = operation.responses[0]!;
|
|
75
|
+
const returnType = response?.type?.type
|
|
76
|
+
? buildType(response.type.name, response.type)
|
|
77
|
+
: { name: "", type: "void" };
|
|
78
|
+
|
|
79
|
+
const functionStatement: OptionalKind<FunctionDeclarationStructure> = {
|
|
80
|
+
isAsync: true,
|
|
81
|
+
isExported: true,
|
|
82
|
+
name: `_${name}Deserialize`,
|
|
83
|
+
parameters,
|
|
84
|
+
returnType: `Promise<${returnType.type}>`
|
|
85
|
+
};
|
|
86
|
+
const statements: string[] = [];
|
|
87
|
+
statements.push(`if(isUnexpected(result)){`, "throw result.body", "}");
|
|
88
|
+
|
|
89
|
+
if (response?.type?.type === "any") {
|
|
90
|
+
statements.push(`return result.body`);
|
|
91
|
+
} else if (response?.type?.elementType) {
|
|
92
|
+
statements.push(
|
|
93
|
+
`return ${deserializeResponseValue(response.type, "result.body")}`
|
|
94
|
+
);
|
|
95
|
+
} else if (response?.type?.properties) {
|
|
96
|
+
statements.push(
|
|
97
|
+
`return {`,
|
|
98
|
+
getResponseMapping(response.type.properties ?? []).join(","),
|
|
99
|
+
`}`
|
|
100
|
+
);
|
|
101
|
+
} else if (returnType.type === "void") {
|
|
102
|
+
statements.push(`return;`);
|
|
103
|
+
} else {
|
|
104
|
+
statements.push(`return result.body;`);
|
|
105
|
+
}
|
|
106
|
+
return {
|
|
107
|
+
...functionStatement,
|
|
108
|
+
statements
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
function getOperationSignatureParameters(
|
|
113
|
+
operation: Operation
|
|
114
|
+
): OptionalKind<ParameterDeclarationStructure>[] {
|
|
115
|
+
const optionsType = getOperationOptionsName(operation);
|
|
116
|
+
const parameters: Map<
|
|
117
|
+
string,
|
|
118
|
+
OptionalKind<ParameterDeclarationStructure>
|
|
119
|
+
> = new Map();
|
|
26
120
|
if (operation.bodyParameter?.type.type === "model") {
|
|
27
|
-
|
|
121
|
+
(operation.bodyParameter?.type.properties ?? [])
|
|
28
122
|
.filter((p) => !p.optional)
|
|
29
|
-
.
|
|
123
|
+
.filter((p) => !p.readonly)
|
|
124
|
+
.map((p) => buildType(p.clientName, p.type))
|
|
125
|
+
.forEach((p) => parameters.set(p.name, p));
|
|
30
126
|
} else if (operation.bodyParameter?.type.type === "list") {
|
|
31
127
|
const bodyArray = operation.bodyParameter;
|
|
32
|
-
parameters.
|
|
128
|
+
parameters.set(
|
|
129
|
+
bodyArray.clientName,
|
|
130
|
+
buildType(bodyArray.clientName, bodyArray.type)
|
|
131
|
+
);
|
|
33
132
|
}
|
|
34
133
|
|
|
35
|
-
parameters
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
134
|
+
operation.parameters
|
|
135
|
+
.filter(
|
|
136
|
+
(p) =>
|
|
137
|
+
p.implementation === "Method" &&
|
|
138
|
+
p.type.type !== "constant" &&
|
|
139
|
+
p.clientDefaultValue === undefined &&
|
|
140
|
+
!p.optional
|
|
141
|
+
)
|
|
142
|
+
.map((p) => buildType(p.clientName, p.type))
|
|
143
|
+
.forEach((p) => {
|
|
144
|
+
parameters.set(p.name, p);
|
|
145
|
+
});
|
|
46
146
|
|
|
47
147
|
// Add context as the first parameter
|
|
48
|
-
|
|
148
|
+
const contextParam = { name: "context", type: "Client" };
|
|
49
149
|
|
|
50
150
|
// Add the options parameter
|
|
51
|
-
|
|
151
|
+
const optionsParam = {
|
|
52
152
|
name: "options",
|
|
53
153
|
type: optionsType,
|
|
54
154
|
initializer: "{ requestOptions: {} }"
|
|
55
|
-
}
|
|
155
|
+
};
|
|
156
|
+
|
|
157
|
+
const finalParameters = [contextParam, ...parameters.values(), optionsParam];
|
|
158
|
+
|
|
159
|
+
return finalParameters;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* This operation builds and returns the function declaration for an operation.
|
|
164
|
+
*/
|
|
165
|
+
export function getOperationFunction(
|
|
166
|
+
operation: Operation
|
|
167
|
+
): OptionalKind<FunctionDeclarationStructure> {
|
|
168
|
+
// Extract required parameters
|
|
169
|
+
const parameters: OptionalKind<ParameterDeclarationStructure>[] =
|
|
170
|
+
getOperationSignatureParameters(operation);
|
|
56
171
|
|
|
57
172
|
// TODO: Support operation overloads
|
|
58
173
|
const response = operation.responses[0]!;
|
|
59
|
-
const returnType =
|
|
60
|
-
response
|
|
61
|
-
|
|
62
|
-
: { name: "", type: "void" };
|
|
174
|
+
const returnType = response?.type?.type
|
|
175
|
+
? buildType(response.type.name, response.type)
|
|
176
|
+
: { name: "", type: "void" };
|
|
63
177
|
|
|
178
|
+
const { name, fixme = [] } = getOperationName(operation);
|
|
64
179
|
const functionStatement: OptionalKind<FunctionDeclarationStructure> = {
|
|
65
|
-
docs: [operation.description],
|
|
180
|
+
docs: [operation.description, ...getFixmeForMultilineDocs(fixme)],
|
|
66
181
|
isAsync: true,
|
|
67
182
|
isExported: true,
|
|
68
|
-
name:
|
|
183
|
+
name: name,
|
|
69
184
|
parameters,
|
|
70
185
|
returnType: `Promise<${returnType.type}>`
|
|
71
186
|
};
|
|
72
187
|
|
|
73
|
-
const operationPath = operation.url;
|
|
74
|
-
const operationMethod = operation.method.toLowerCase();
|
|
75
|
-
|
|
76
188
|
const statements: string[] = [];
|
|
77
189
|
statements.push(
|
|
78
|
-
`const result = await
|
|
79
|
-
|
|
80
|
-
|
|
190
|
+
`const result = await _${name}Send(${parameters
|
|
191
|
+
.map((p) => p.name)
|
|
192
|
+
.join(", ")});`
|
|
81
193
|
);
|
|
82
|
-
|
|
83
|
-
statements.push(`if(isUnexpected(result)){`, "throw result.body", "}");
|
|
84
|
-
|
|
85
|
-
if (!response?.type?.properties) {
|
|
86
|
-
statements.push(`return;`);
|
|
87
|
-
} else {
|
|
88
|
-
statements.push(
|
|
89
|
-
`return {`,
|
|
90
|
-
getResponseMapping(response.type.properties ?? []).join(","),
|
|
91
|
-
`}`
|
|
92
|
-
);
|
|
93
|
-
}
|
|
194
|
+
statements.push(`return _${name}Deserialize(result);`);
|
|
94
195
|
return {
|
|
95
196
|
...functionStatement,
|
|
96
197
|
statements
|
|
@@ -140,11 +241,11 @@ function getRequestParameters(operation: Operation): string {
|
|
|
140
241
|
paramStr = `${getContentTypeValue(contentTypeParameter)},`;
|
|
141
242
|
}
|
|
142
243
|
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
",\n"
|
|
146
|
-
|
|
147
|
-
}
|
|
244
|
+
paramStr = `${paramStr}\nheaders: {${
|
|
245
|
+
parametersImplementation.header.length
|
|
246
|
+
? parametersImplementation.header.join(",\n") + ","
|
|
247
|
+
: ""
|
|
248
|
+
} ...options.requestOptions?.headers},`;
|
|
148
249
|
|
|
149
250
|
if (parametersImplementation.query.length) {
|
|
150
251
|
paramStr = `${paramStr}\nqueryParameters: {${parametersImplementation.query.join(
|
|
@@ -273,7 +374,7 @@ function isOptionalWithouDefault(
|
|
|
273
374
|
return Boolean(param.optional && !param.clientDefaultValue);
|
|
274
375
|
}
|
|
275
376
|
function getOptionalWithoutDefault(param: OptionalWithoutDefaultType) {
|
|
276
|
-
return
|
|
377
|
+
return `"${param.restApiName}": options?.${param.clientName}`;
|
|
277
378
|
}
|
|
278
379
|
|
|
279
380
|
type OptionalWithDefaultType = (Parameter | Property) & {
|
|
@@ -341,6 +442,13 @@ function getPathParameters(operation: Operation) {
|
|
|
341
442
|
return pathParams;
|
|
342
443
|
}
|
|
343
444
|
|
|
445
|
+
function getNullableCheck(name: string, type: Type) {
|
|
446
|
+
if (!type.nullable) {
|
|
447
|
+
return "";
|
|
448
|
+
}
|
|
449
|
+
|
|
450
|
+
return `${name} === null ? null :`;
|
|
451
|
+
}
|
|
344
452
|
/**
|
|
345
453
|
* This function helps translating an RLC response to an HLC response,
|
|
346
454
|
* extracting properties from body and headers and building the HLC response object
|
|
@@ -352,19 +460,18 @@ function getResponseMapping(
|
|
|
352
460
|
const props: string[] = [];
|
|
353
461
|
for (const property of properties) {
|
|
354
462
|
// TODO: Do we need to also add headers in the result type?
|
|
463
|
+
const propertyFullName = `${propertyPath}.${property.clientName}`;
|
|
355
464
|
if (property.type.type === "model") {
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
)}}`
|
|
367
|
-
);
|
|
465
|
+
const definition = `"${property.restApiName}": ${getNullableCheck(
|
|
466
|
+
propertyFullName,
|
|
467
|
+
property.type
|
|
468
|
+
)} ${
|
|
469
|
+
!property.optional ? "" : `!${propertyFullName} ? undefined :`
|
|
470
|
+
} {${getResponseMapping(
|
|
471
|
+
property.type.properties ?? [],
|
|
472
|
+
`${propertyPath}.${property.restApiName}${property.optional ? "?" : ""}`
|
|
473
|
+
)}}`;
|
|
474
|
+
props.push(definition);
|
|
368
475
|
} else {
|
|
369
476
|
const dot = propertyPath.endsWith("?") ? "." : "";
|
|
370
477
|
const restValue = `${
|
|
@@ -7,41 +7,52 @@ export interface TypeMetadata {
|
|
|
7
7
|
modifier?: "Array";
|
|
8
8
|
}
|
|
9
9
|
|
|
10
|
+
function getNullableType(name: string, type: Type): string {
|
|
11
|
+
if (type.nullable) {
|
|
12
|
+
return `(${name} | null)`;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
return name;
|
|
16
|
+
}
|
|
17
|
+
|
|
10
18
|
export function getType(type: Type): TypeMetadata {
|
|
11
19
|
switch (type.type) {
|
|
12
20
|
case "Key":
|
|
13
21
|
return {
|
|
14
|
-
name: "
|
|
22
|
+
name: "KeyCredential",
|
|
15
23
|
originModule: "@azure/core-auth",
|
|
16
24
|
isRelative: false
|
|
17
25
|
};
|
|
18
26
|
case "boolean":
|
|
19
|
-
return { name:
|
|
27
|
+
return { name: getNullableType(type.type, type) };
|
|
20
28
|
case "constant": {
|
|
21
29
|
let typeName: string = type.value ?? "undefined";
|
|
22
30
|
if (type.valueType?.type === "string") {
|
|
23
31
|
typeName = type.value ? `"${type.value}"` : "undefined";
|
|
24
32
|
}
|
|
25
|
-
return { name: typeName };
|
|
33
|
+
return { name: getNullableType(typeName, type) };
|
|
26
34
|
}
|
|
27
35
|
case "datetime":
|
|
28
|
-
return { name: "Date" };
|
|
36
|
+
return { name: getNullableType("Date", type) };
|
|
29
37
|
case "enum":
|
|
30
38
|
if (!type.name) {
|
|
31
39
|
throw new Error("Unable to process enum without name");
|
|
32
40
|
}
|
|
33
|
-
return {
|
|
41
|
+
return {
|
|
42
|
+
name: getNullableType(type.name, type),
|
|
43
|
+
originModule: "models.js"
|
|
44
|
+
};
|
|
34
45
|
case "float":
|
|
35
46
|
case "integer":
|
|
36
|
-
return { name: "number" };
|
|
47
|
+
return { name: getNullableType("number", type) };
|
|
37
48
|
case "byte-array":
|
|
38
|
-
return { name: "
|
|
49
|
+
return { name: getNullableType("Uint8Array", type) };
|
|
39
50
|
case "list":
|
|
40
51
|
if (!type.elementType) {
|
|
41
52
|
throw new Error("Unable to process Array with no elementType");
|
|
42
53
|
}
|
|
43
54
|
return {
|
|
44
|
-
name: getType(type.elementType).name,
|
|
55
|
+
name: getNullableType(getType(type.elementType).name, type),
|
|
45
56
|
modifier: "Array",
|
|
46
57
|
originModule:
|
|
47
58
|
type.elementType?.type === "model" ? "models.js" : undefined
|
|
@@ -50,10 +61,13 @@ export function getType(type: Type): TypeMetadata {
|
|
|
50
61
|
if (!type.name) {
|
|
51
62
|
throw new Error("Unable to process model without name");
|
|
52
63
|
}
|
|
53
|
-
return {
|
|
64
|
+
return {
|
|
65
|
+
name: getNullableType(type.name, type),
|
|
66
|
+
originModule: "models.js"
|
|
67
|
+
};
|
|
54
68
|
case "string":
|
|
55
69
|
case "duration":
|
|
56
|
-
return { name: "string" };
|
|
70
|
+
return { name: getNullableType("string", type) };
|
|
57
71
|
case "combined": {
|
|
58
72
|
if (!type.types) {
|
|
59
73
|
throw new Error("Unable to process combined without combinedTypes");
|
|
@@ -64,7 +78,7 @@ export function getType(type: Type): TypeMetadata {
|
|
|
64
78
|
return `${sdkType}`;
|
|
65
79
|
})
|
|
66
80
|
.join(" | ");
|
|
67
|
-
return { name };
|
|
81
|
+
return { name: getNullableType(name, type) };
|
|
68
82
|
}
|
|
69
83
|
case "dict":
|
|
70
84
|
if (!type.elementType) {
|
|
@@ -73,8 +87,15 @@ export function getType(type: Type): TypeMetadata {
|
|
|
73
87
|
return {
|
|
74
88
|
name: `Record<string, ${getTypeName(getType(type.elementType))}>`
|
|
75
89
|
};
|
|
90
|
+
case "any":
|
|
91
|
+
return {
|
|
92
|
+
name: `Record<string, any>`
|
|
93
|
+
};
|
|
76
94
|
default:
|
|
77
|
-
throw new Error(`Unsupported type ${type.type}`);
|
|
95
|
+
// throw new Error(`Unsupported type ${type.type}`);
|
|
96
|
+
return {
|
|
97
|
+
name: `any`
|
|
98
|
+
};
|
|
78
99
|
}
|
|
79
100
|
}
|
|
80
101
|
|
|
@@ -52,6 +52,7 @@ export interface EnumValue {
|
|
|
52
52
|
description: string;
|
|
53
53
|
}
|
|
54
54
|
export interface Type {
|
|
55
|
+
nullable?: boolean;
|
|
55
56
|
name?: string;
|
|
56
57
|
description?: string;
|
|
57
58
|
type:
|
|
@@ -70,7 +71,8 @@ export interface Type {
|
|
|
70
71
|
| "float"
|
|
71
72
|
| "boolean"
|
|
72
73
|
| "dict"
|
|
73
|
-
| "combined"
|
|
74
|
+
| "combined"
|
|
75
|
+
| "any";
|
|
74
76
|
policy?: Policy;
|
|
75
77
|
apiVersions?: any[];
|
|
76
78
|
clientDefaultValue?: any;
|