@autorest/typescript 6.0.0-beta.7 → 6.0.0-rc.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/README.md +42 -5
- package/dist/{src/generators/static/README.md.hbs → hlcREADME.md.hbs} +41 -5
- package/dist/hlcSamples.ts.hbs +49 -0
- package/dist/karma.conf.js.hbs +126 -0
- package/dist/paginateHelper.ts.hbs +208 -0
- package/dist/pollingHelper.ts.hbs +72 -0
- package/dist/rlcEnv.ts.hbs +3 -0
- package/dist/rlcREADME.md.hbs +71 -0
- package/dist/rlcRecordedClient.ts.hbs +26 -0
- package/dist/rlcSampleTest.spec.ts.hbs +20 -0
- package/dist/rlcSamples.ts.hbs +28 -0
- package/dist/sampleEnv.hbs +4 -0
- package/dist/sampleTest.ts.hbs +32 -0
- package/dist/samples.ts.hbs +0 -0
- package/dist/src/autorestSession.d.ts +18 -6
- package/dist/src/autorestSession.d.ts.map +1 -1
- package/dist/src/autorestSession.js +3 -9
- package/dist/src/autorestSession.js.map +1 -1
- package/dist/src/conflictResolver.d.ts +3 -0
- package/dist/src/conflictResolver.d.ts.map +1 -0
- package/dist/src/conflictResolver.js +43 -0
- package/dist/src/conflictResolver.js.map +1 -0
- package/dist/src/generators/LROGenerator.d.ts.map +1 -1
- package/dist/src/generators/LROGenerator.js +5 -13
- package/dist/src/generators/LROGenerator.js.map +1 -1
- package/dist/src/generators/clientFileGenerator.d.ts.map +1 -1
- package/dist/src/generators/clientFileGenerator.js +303 -61
- package/dist/src/generators/clientFileGenerator.js.map +1 -1
- package/dist/src/generators/indexGenerator.d.ts +1 -1
- package/dist/src/generators/indexGenerator.d.ts.map +1 -1
- package/dist/src/generators/indexGenerator.js +143 -11
- package/dist/src/generators/indexGenerator.js.map +1 -1
- package/dist/src/generators/mappersGenerator.d.ts.map +1 -1
- package/dist/src/generators/mappersGenerator.js +93 -19
- package/dist/src/generators/mappersGenerator.js.map +1 -1
- package/dist/src/generators/modelsGenerator.d.ts.map +1 -1
- package/dist/src/generators/modelsGenerator.js +81 -82
- package/dist/src/generators/modelsGenerator.js.map +1 -1
- package/dist/src/generators/operationGenerator.d.ts.map +1 -1
- package/dist/src/generators/operationGenerator.js +92 -125
- package/dist/src/generators/operationGenerator.js.map +1 -1
- package/dist/src/generators/operationInterfaceGenerator.js +20 -20
- package/dist/src/generators/operationInterfaceGenerator.js.map +1 -1
- package/dist/src/generators/parametersGenerator.d.ts.map +1 -1
- package/dist/src/generators/parametersGenerator.js +7 -8
- package/dist/src/generators/parametersGenerator.js.map +1 -1
- package/dist/src/generators/samples/hlcSampleGenerator.d.ts +13 -0
- package/dist/src/generators/samples/hlcSampleGenerator.d.ts.map +1 -0
- package/dist/src/generators/samples/hlcSampleGenerator.js +43 -0
- package/dist/src/generators/samples/hlcSampleGenerator.js.map +1 -0
- package/dist/src/generators/samples/hlcSamples.ts.hbs +49 -0
- package/dist/src/generators/samples/rlcSampleGenerator.d.ts +4 -0
- package/dist/src/generators/samples/rlcSampleGenerator.d.ts.map +1 -0
- package/dist/src/generators/samples/rlcSampleGenerator.js +64 -0
- package/dist/src/generators/samples/rlcSampleGenerator.js.map +1 -0
- package/dist/src/generators/samples/rlcSamples.ts.hbs +28 -0
- package/dist/src/generators/samples/sampleEnv.hbs +4 -0
- package/dist/src/generators/samples/sampleEnvGenerator.d.ts +3 -0
- package/dist/src/generators/samples/sampleEnvGenerator.d.ts.map +1 -0
- package/dist/src/generators/samples/sampleEnvGenerator.js +17 -0
- package/dist/src/generators/samples/sampleEnvGenerator.js.map +1 -0
- package/dist/src/generators/static/apiExtractorConfig.js +3 -3
- package/dist/src/generators/static/apiExtractorConfig.js.map +1 -1
- package/dist/src/generators/static/esLintConfigGenerator.d.ts +3 -0
- package/dist/src/generators/static/esLintConfigGenerator.d.ts.map +1 -0
- package/dist/src/generators/static/esLintConfigGenerator.js +26 -0
- package/dist/src/generators/static/esLintConfigGenerator.js.map +1 -0
- package/{src/generators/static/README.md.hbs → dist/src/generators/static/hlcREADME.md.hbs} +41 -5
- package/dist/src/generators/static/karma.conf.js.hbs +126 -0
- package/dist/src/generators/static/karmaConfigFileGenerator.d.ts +3 -0
- package/dist/src/generators/static/karmaConfigFileGenerator.d.ts.map +1 -0
- package/dist/src/generators/static/karmaConfigFileGenerator.js +23 -0
- package/dist/src/generators/static/karmaConfigFileGenerator.js.map +1 -0
- package/dist/src/generators/static/licenseFileGenerator.js +1 -1
- package/dist/src/generators/static/licenseFileGenerator.js.map +1 -1
- package/dist/src/generators/static/packageFileGenerator.d.ts.map +1 -1
- package/dist/src/generators/static/packageFileGenerator.js +267 -79
- package/dist/src/generators/static/packageFileGenerator.js.map +1 -1
- package/dist/src/generators/static/readmeFileGenerator.d.ts +2 -2
- package/dist/src/generators/static/readmeFileGenerator.d.ts.map +1 -1
- package/dist/src/generators/static/readmeFileGenerator.js +54 -26
- package/dist/src/generators/static/readmeFileGenerator.js.map +1 -1
- package/dist/src/generators/static/rlcREADME.md.hbs +71 -0
- package/dist/src/generators/static/rollupConfigFileGenerator.d.ts.map +1 -1
- package/dist/src/generators/static/rollupConfigFileGenerator.js +12 -71
- package/dist/src/generators/static/rollupConfigFileGenerator.js.map +1 -1
- package/dist/src/generators/static/tsConfigFileGenerator.d.ts.map +1 -1
- package/dist/src/generators/static/tsConfigFileGenerator.js +47 -20
- package/dist/src/generators/static/tsConfigFileGenerator.js.map +1 -1
- package/dist/src/generators/test/envBrowserFileGenerator.d.ts +3 -0
- package/dist/src/generators/test/envBrowserFileGenerator.d.ts.map +1 -0
- package/dist/src/generators/test/envBrowserFileGenerator.js +15 -0
- package/dist/src/generators/test/envBrowserFileGenerator.js.map +1 -0
- package/dist/src/generators/test/envFileGenerator.d.ts +3 -0
- package/dist/src/generators/test/envFileGenerator.d.ts.map +1 -0
- package/dist/src/generators/test/envFileGenerator.js +23 -0
- package/dist/src/generators/test/envFileGenerator.js.map +1 -0
- package/dist/src/generators/test/recordedClientFileGenerator.d.ts +3 -0
- package/dist/src/generators/test/recordedClientFileGenerator.d.ts.map +1 -0
- package/dist/src/generators/test/recordedClientFileGenerator.js +23 -0
- package/dist/src/generators/test/recordedClientFileGenerator.js.map +1 -0
- package/dist/src/generators/test/rlcEnv.ts.hbs +3 -0
- package/dist/src/generators/test/rlcRecordedClient.ts.hbs +26 -0
- package/dist/src/generators/test/rlcSampleTest.spec.ts.hbs +20 -0
- package/dist/src/generators/test/sampleTest.ts.hbs +32 -0
- package/dist/src/generators/test/sampleTestGenerator.d.ts +3 -0
- package/dist/src/generators/test/sampleTestGenerator.d.ts.map +1 -0
- package/dist/src/generators/test/sampleTestGenerator.js +34 -0
- package/dist/src/generators/test/sampleTestGenerator.js.map +1 -0
- package/dist/src/generators/tracingFileGenerator.d.ts.map +1 -1
- package/dist/src/generators/tracingFileGenerator.js +7 -21
- package/dist/src/generators/tracingFileGenerator.js.map +1 -1
- package/dist/src/generators/utils/docsUtils.js +2 -2
- package/dist/src/generators/utils/docsUtils.js.map +1 -1
- package/dist/src/generators/utils/operationsUtils.js +1 -1
- package/dist/src/generators/utils/operationsUtils.js.map +1 -1
- package/dist/src/generators/utils/pagingOperations.d.ts +5 -0
- package/dist/src/generators/utils/pagingOperations.d.ts.map +1 -1
- package/dist/src/generators/utils/pagingOperations.js +15 -15
- package/dist/src/generators/utils/pagingOperations.js.map +1 -1
- package/dist/src/generators/utils/parameterUtils.js +9 -9
- package/dist/src/generators/utils/parameterUtils.js.map +1 -1
- package/dist/src/generators/utils/responseTypeUtils.js +2 -2
- package/dist/src/generators/utils/responseTypeUtils.js.map +1 -1
- package/dist/src/generators/utils/tracingUtils.d.ts.map +1 -1
- package/dist/src/generators/utils/tracingUtils.js +2 -6
- package/dist/src/generators/utils/tracingUtils.js.map +1 -1
- package/dist/src/lroImpl.d.ts +16 -0
- package/dist/src/lroImpl.d.ts.map +1 -0
- package/dist/src/lroImpl.js +45 -0
- package/dist/src/lroImpl.js.map +1 -0
- package/dist/src/main.d.ts +2 -2
- package/dist/src/main.d.ts.map +1 -1
- package/dist/src/main.js +8 -8
- package/dist/src/main.js.map +1 -1
- package/dist/src/models/clientDetails.d.ts +10 -1
- package/dist/src/models/clientDetails.d.ts.map +1 -1
- package/dist/src/models/modelDetails.d.ts +2 -2
- package/dist/src/models/modelDetails.d.ts.map +1 -1
- package/dist/src/models/operationDetails.d.ts +1 -0
- package/dist/src/models/operationDetails.d.ts.map +1 -1
- package/dist/src/models/sampleDetails.d.ts +22 -0
- package/dist/src/models/sampleDetails.d.ts.map +1 -0
- package/dist/src/models/sampleDetails.js +3 -0
- package/dist/src/models/sampleDetails.js.map +1 -0
- package/dist/src/restLevelClient/generateClient.d.ts +1 -1
- package/dist/src/restLevelClient/generateClient.d.ts.map +1 -1
- package/dist/src/restLevelClient/generateClient.js +108 -167
- package/dist/src/restLevelClient/generateClient.js.map +1 -1
- package/dist/src/restLevelClient/generateClientDefinition.d.ts +6 -0
- package/dist/src/restLevelClient/generateClientDefinition.d.ts.map +1 -0
- package/dist/src/restLevelClient/generateClientDefinition.js +261 -0
- package/dist/src/restLevelClient/generateClientDefinition.js.map +1 -0
- package/dist/src/restLevelClient/generateIsUnexpectedHelper.d.ts +8 -0
- package/dist/src/restLevelClient/generateIsUnexpectedHelper.d.ts.map +1 -0
- package/dist/src/restLevelClient/generateIsUnexpectedHelper.js +204 -0
- package/dist/src/restLevelClient/generateIsUnexpectedHelper.js.map +1 -0
- package/dist/src/restLevelClient/generateMethodShortcuts.d.ts +8 -0
- package/dist/src/restLevelClient/generateMethodShortcuts.d.ts.map +1 -0
- package/dist/src/restLevelClient/generateMethodShortcuts.js +70 -0
- package/dist/src/restLevelClient/generateMethodShortcuts.js.map +1 -0
- package/dist/src/restLevelClient/generateObjectTypes.d.ts +3 -3
- package/dist/src/restLevelClient/generateObjectTypes.d.ts.map +1 -1
- package/dist/src/restLevelClient/generateObjectTypes.js +43 -31
- package/dist/src/restLevelClient/generateObjectTypes.js.map +1 -1
- package/dist/src/restLevelClient/generatePagingHelper.d.ts +3 -0
- package/dist/src/restLevelClient/generatePagingHelper.d.ts.map +1 -0
- package/dist/src/restLevelClient/generatePagingHelper.js +54 -0
- package/dist/src/restLevelClient/generatePagingHelper.js.map +1 -0
- package/dist/src/restLevelClient/generateParameterTypes.d.ts.map +1 -1
- package/dist/src/restLevelClient/generateParameterTypes.js +247 -43
- package/dist/src/restLevelClient/generateParameterTypes.js.map +1 -1
- package/dist/src/restLevelClient/generatePollingHelper.d.ts +3 -0
- package/dist/src/restLevelClient/generatePollingHelper.d.ts.map +1 -0
- package/dist/src/restLevelClient/generatePollingHelper.js +20 -0
- package/dist/src/restLevelClient/generatePollingHelper.js.map +1 -0
- package/dist/src/restLevelClient/generateResponseTypes.d.ts.map +1 -1
- package/dist/src/restLevelClient/generateResponseTypes.js +45 -29
- package/dist/src/restLevelClient/generateResponseTypes.js.map +1 -1
- package/dist/src/restLevelClient/generateRestLevel.d.ts.map +1 -1
- package/dist/src/restLevelClient/generateRestLevel.js +64 -15
- package/dist/src/restLevelClient/generateRestLevel.js.map +1 -1
- package/dist/src/restLevelClient/generateSchemaTypes.d.ts.map +1 -1
- package/dist/src/restLevelClient/generateSchemaTypes.js +29 -7
- package/dist/src/restLevelClient/generateSchemaTypes.js.map +1 -1
- package/dist/src/restLevelClient/generateTopLevelIndexFile.d.ts +4 -0
- package/dist/src/restLevelClient/generateTopLevelIndexFile.d.ts.map +1 -0
- package/dist/src/restLevelClient/generateTopLevelIndexFile.js +37 -0
- package/dist/src/restLevelClient/generateTopLevelIndexFile.js.map +1 -0
- package/dist/src/restLevelClient/getPropertySignature.d.ts +3 -2
- package/dist/src/restLevelClient/getPropertySignature.d.ts.map +1 -1
- package/dist/src/restLevelClient/getPropertySignature.js +23 -7
- package/dist/src/restLevelClient/getPropertySignature.js.map +1 -1
- package/dist/src/restLevelClient/helpers/hasPollingOperations.d.ts +4 -0
- package/dist/src/restLevelClient/helpers/hasPollingOperations.d.ts.map +1 -0
- package/dist/src/restLevelClient/helpers/hasPollingOperations.js +12 -0
- package/dist/src/restLevelClient/helpers/hasPollingOperations.js.map +1 -0
- package/dist/src/restLevelClient/helpers/modelHelpers.d.ts +4 -0
- package/dist/src/restLevelClient/helpers/modelHelpers.d.ts.map +1 -0
- package/dist/src/restLevelClient/helpers/modelHelpers.js +19 -0
- package/dist/src/restLevelClient/helpers/modelHelpers.js.map +1 -0
- package/dist/src/restLevelClient/helpers/operationHelpers.d.ts +10 -0
- package/dist/src/restLevelClient/helpers/operationHelpers.d.ts.map +1 -0
- package/dist/src/restLevelClient/helpers/operationHelpers.js +64 -0
- package/dist/src/restLevelClient/helpers/operationHelpers.js.map +1 -0
- package/dist/src/restLevelClient/interfaces.d.ts +33 -0
- package/dist/src/restLevelClient/interfaces.d.ts.map +1 -0
- package/dist/src/restLevelClient/interfaces.js +3 -0
- package/dist/src/restLevelClient/interfaces.js.map +1 -0
- package/dist/src/restLevelClient/mutateCodeModel.js +2 -2
- package/dist/src/restLevelClient/mutateCodeModel.js.map +1 -1
- package/dist/src/restLevelClient/operationHelpers.d.ts +4 -0
- package/dist/src/restLevelClient/operationHelpers.d.ts.map +1 -1
- package/dist/src/restLevelClient/operationHelpers.js +21 -10
- package/dist/src/restLevelClient/operationHelpers.js.map +1 -1
- package/dist/src/restLevelClient/paginateHelper.ts.hbs +208 -0
- package/dist/src/restLevelClient/pollingHelper.ts.hbs +72 -0
- package/dist/src/restLevelClient/samples/generateSamples.d.ts +23 -0
- package/dist/src/restLevelClient/samples/generateSamples.d.ts.map +1 -0
- package/dist/src/restLevelClient/samples/generateSamples.js +3 -0
- package/dist/src/restLevelClient/samples/generateSamples.js.map +1 -0
- package/dist/src/restLevelClient/samples/samples.ts.hbs +0 -0
- package/dist/src/restLevelClient/schemaHelpers.d.ts +12 -2
- package/dist/src/restLevelClient/schemaHelpers.d.ts.map +1 -1
- package/dist/src/restLevelClient/schemaHelpers.js +48 -14
- package/dist/src/restLevelClient/schemaHelpers.js.map +1 -1
- package/dist/src/transforms/extensions.js +10 -10
- package/dist/src/transforms/extensions.js.map +1 -1
- package/dist/src/transforms/groupTransforms.js +2 -2
- package/dist/src/transforms/groupTransforms.js.map +1 -1
- package/dist/src/transforms/mapperTransforms.d.ts +1 -1
- package/dist/src/transforms/mapperTransforms.d.ts.map +1 -1
- package/dist/src/transforms/mapperTransforms.js +30 -27
- package/dist/src/transforms/mapperTransforms.js.map +1 -1
- package/dist/src/transforms/objectTransforms.d.ts.map +1 -1
- package/dist/src/transforms/objectTransforms.js +42 -26
- package/dist/src/transforms/objectTransforms.js.map +1 -1
- package/dist/src/transforms/operationTransforms.d.ts.map +1 -1
- package/dist/src/transforms/operationTransforms.js +29 -26
- package/dist/src/transforms/operationTransforms.js.map +1 -1
- package/dist/src/transforms/optionsTransforms.js +1 -1
- package/dist/src/transforms/optionsTransforms.js.map +1 -1
- package/dist/src/transforms/parameterTransforms.d.ts.map +1 -1
- package/dist/src/transforms/parameterTransforms.js +43 -27
- package/dist/src/transforms/parameterTransforms.js.map +1 -1
- package/dist/src/transforms/samplesTransforms.d.ts +7 -0
- package/dist/src/transforms/samplesTransforms.d.ts.map +1 -0
- package/dist/src/transforms/samplesTransforms.js +293 -0
- package/dist/src/transforms/samplesTransforms.js.map +1 -0
- package/dist/src/transforms/transforms.d.ts +1 -2
- package/dist/src/transforms/transforms.d.ts.map +1 -1
- package/dist/src/transforms/transforms.js +26 -24
- package/dist/src/transforms/transforms.js.map +1 -1
- package/dist/src/transforms/urlTransforms.js +3 -3
- package/dist/src/transforms/urlTransforms.js.map +1 -1
- package/dist/src/typescriptGenerator.d.ts +2 -2
- package/dist/src/typescriptGenerator.d.ts.map +1 -1
- package/dist/src/typescriptGenerator.js +46 -40
- package/dist/src/typescriptGenerator.js.map +1 -1
- package/dist/src/utils/autorestOptions.d.ts +2 -2
- package/dist/src/utils/autorestOptions.d.ts.map +1 -1
- package/dist/src/utils/autorestOptions.js +148 -61
- package/dist/src/utils/autorestOptions.js.map +1 -1
- package/dist/src/utils/cloneOperation.js +2 -2
- package/dist/src/utils/cloneOperation.js.map +1 -1
- package/dist/src/utils/copyFiles.d.ts +2 -0
- package/dist/src/utils/copyFiles.d.ts.map +1 -0
- package/dist/src/utils/copyFiles.js +33 -0
- package/dist/src/utils/copyFiles.js.map +1 -0
- package/dist/src/utils/extractHeaders.js +4 -4
- package/dist/src/utils/extractHeaders.js.map +1 -1
- package/dist/src/utils/extractPaginationDetails.d.ts +5 -1
- package/dist/src/utils/extractPaginationDetails.d.ts.map +1 -1
- package/dist/src/utils/extractPaginationDetails.js +23 -10
- package/dist/src/utils/extractPaginationDetails.js.map +1 -1
- package/dist/src/utils/headersToSchema.js +1 -1
- package/dist/src/utils/headersToSchema.js.map +1 -1
- package/dist/src/utils/logger.js +1 -1
- package/dist/src/utils/logger.js.map +1 -1
- package/dist/src/utils/nameUtils.d.ts +6 -2
- package/dist/src/utils/nameUtils.d.ts.map +1 -1
- package/dist/src/utils/nameUtils.js +13 -8
- package/dist/src/utils/nameUtils.js.map +1 -1
- package/dist/src/utils/schemaHelpers.d.ts +6 -1
- package/dist/src/utils/schemaHelpers.d.ts.map +1 -1
- package/dist/src/utils/schemaHelpers.js +50 -7
- package/dist/src/utils/schemaHelpers.js.map +1 -1
- package/dist/src/utils/sortObjectSchemasHierarchically.js +1 -1
- package/dist/src/utils/sortObjectSchemasHierarchically.js.map +1 -1
- package/dist/src/utils/valueHelpers.d.ts.map +1 -1
- package/dist/src/utils/valueHelpers.js +2 -1
- package/dist/src/utils/valueHelpers.js.map +1 -1
- package/package.json +59 -39
- package/src/autorestSession.ts +26 -18
- package/src/conflictResolver.ts +61 -0
- package/src/generators/LROGenerator.ts +2 -16
- package/src/generators/clientFileGenerator.ts +400 -50
- package/src/generators/indexGenerator.ts +166 -14
- package/src/generators/mappersGenerator.ts +108 -8
- package/src/generators/modelsGenerator.ts +101 -98
- package/src/generators/operationGenerator.ts +63 -122
- package/src/generators/parametersGenerator.ts +2 -3
- package/src/generators/samples/hlcSampleGenerator.ts +50 -0
- package/src/generators/samples/hlcSamples.ts.hbs +49 -0
- package/src/generators/samples/rlcSampleGenerator.ts +72 -0
- package/src/generators/samples/rlcSamples.ts.hbs +28 -0
- package/src/generators/samples/sampleEnv.hbs +4 -0
- package/src/generators/samples/sampleEnvGenerator.ts +14 -0
- package/src/generators/static/apiExtractorConfig.ts +3 -3
- package/src/generators/static/esLintConfigGenerator.ts +24 -0
- package/src/generators/static/hlcREADME.md.hbs +144 -0
- package/src/generators/static/karma.conf.js.hbs +126 -0
- package/src/generators/static/karmaConfigFileGenerator.ts +20 -0
- package/src/generators/static/packageFileGenerator.ts +305 -82
- package/src/generators/static/readmeFileGenerator.ts +85 -42
- package/src/generators/static/rlcREADME.md.hbs +71 -0
- package/src/generators/static/rollupConfigFileGenerator.ts +13 -71
- package/src/generators/static/tsConfigFileGenerator.ts +55 -21
- package/src/generators/test/envBrowserFileGenerator.ts +14 -0
- package/src/generators/test/envFileGenerator.ts +22 -0
- package/src/generators/test/recordedClientFileGenerator.ts +22 -0
- package/src/generators/test/rlcEnv.ts.hbs +3 -0
- package/src/generators/test/rlcRecordedClient.ts.hbs +26 -0
- package/src/generators/test/rlcSampleTest.spec.ts.hbs +20 -0
- package/src/generators/test/sampleTest.ts.hbs +32 -0
- package/src/generators/test/sampleTestGenerator.ts +32 -0
- package/src/generators/tracingFileGenerator.ts +6 -24
- package/src/generators/utils/pagingOperations.ts +1 -2
- package/src/generators/utils/tracingUtils.ts +1 -5
- package/src/lroImpl.ts +26 -0
- package/src/main.ts +8 -5
- package/src/models/clientDetails.ts +11 -1
- package/src/models/modelDetails.ts +2 -2
- package/src/models/operationDetails.ts +1 -0
- package/src/models/sampleDetails.ts +22 -0
- package/src/restLevelClient/generateClient.ts +134 -244
- package/src/restLevelClient/generateClientDefinition.ts +386 -0
- package/src/restLevelClient/generateIsUnexpectedHelper.ts +224 -0
- package/src/restLevelClient/generateMethodShortcuts.ts +121 -0
- package/src/restLevelClient/generateObjectTypes.ts +62 -21
- package/src/restLevelClient/generatePagingHelper.ts +69 -0
- package/src/restLevelClient/generateParameterTypes.ts +377 -55
- package/src/restLevelClient/generatePollingHelper.ts +19 -0
- package/src/restLevelClient/generateResponseTypes.ts +53 -22
- package/src/restLevelClient/generateRestLevel.ts +65 -8
- package/src/restLevelClient/generateSchemaTypes.ts +43 -8
- package/src/restLevelClient/generateTopLevelIndexFile.ts +37 -0
- package/src/restLevelClient/getPropertySignature.ts +31 -6
- package/src/restLevelClient/helpers/hasPollingOperations.ts +15 -0
- package/src/restLevelClient/helpers/modelHelpers.ts +15 -0
- package/src/restLevelClient/helpers/operationHelpers.ts +93 -0
- package/src/restLevelClient/interfaces.ts +39 -0
- package/src/restLevelClient/operationHelpers.ts +23 -9
- package/src/restLevelClient/paginateHelper.ts.hbs +208 -0
- package/src/restLevelClient/pollingHelper.ts.hbs +72 -0
- package/src/restLevelClient/samples/generateSamples.ts +23 -0
- package/src/restLevelClient/samples/samples.ts.hbs +0 -0
- package/src/restLevelClient/schemaHelpers.ts +51 -9
- package/src/transforms/mapperTransforms.ts +12 -6
- package/src/transforms/objectTransforms.ts +26 -6
- package/src/transforms/operationTransforms.ts +6 -1
- package/src/transforms/parameterTransforms.ts +26 -7
- package/src/transforms/samplesTransforms.ts +349 -0
- package/src/transforms/transforms.ts +14 -9
- package/src/typescriptGenerator.ts +41 -45
- package/src/utils/autorestOptions.ts +203 -86
- package/src/utils/copyFiles.ts +36 -0
- package/src/utils/extractPaginationDetails.ts +19 -1
- package/src/utils/nameUtils.ts +18 -9
- package/src/utils/schemaHelpers.ts +51 -4
- package/src/utils/valueHelpers.ts +1 -0
- package/CHANGELOG.md +0 -44
- package/dist/src/coreClientLro.d.ts +0 -26
- package/dist/src/coreClientLro.d.ts.map +0 -1
- package/dist/src/coreClientLro.js +0 -207
- package/dist/src/coreClientLro.js.map +0 -1
- package/dist/src/coreHttpLro.d.ts +0 -26
- package/dist/src/coreHttpLro.d.ts.map +0 -1
- package/dist/src/coreHttpLro.js +0 -186
- package/dist/src/coreHttpLro.js.map +0 -1
- package/dist/src/generators/clientContextFileGenerator.d.ts +0 -5
- package/dist/src/generators/clientContextFileGenerator.d.ts.map +0 -1
- package/dist/src/generators/clientContextFileGenerator.js +0 -263
- package/dist/src/generators/clientContextFileGenerator.js.map +0 -1
- package/dist/src/lro/azureAsyncPolling.d.ts +0 -3
- package/dist/src/lro/azureAsyncPolling.d.ts.map +0 -1
- package/dist/src/lro/azureAsyncPolling.js +0 -71
- package/dist/src/lro/azureAsyncPolling.js.map +0 -1
- package/dist/src/lro/bodyPolling.d.ts +0 -8
- package/dist/src/lro/bodyPolling.d.ts.map +0 -1
- package/dist/src/lro/bodyPolling.js +0 -34
- package/dist/src/lro/bodyPolling.js.map +0 -1
- package/dist/src/lro/index.d.ts +0 -4
- package/dist/src/lro/index.d.ts.map +0 -1
- package/dist/src/lro/index.js +0 -10
- package/dist/src/lro/index.js.map +0 -1
- package/dist/src/lro/locationPolling.d.ts +0 -3
- package/dist/src/lro/locationPolling.d.ts.map +0 -1
- package/dist/src/lro/locationPolling.js +0 -18
- package/dist/src/lro/locationPolling.js.map +0 -1
- package/dist/src/lro/lroEngine.d.ts +0 -14
- package/dist/src/lro/lroEngine.d.ts.map +0 -1
- package/dist/src/lro/lroEngine.js +0 -38
- package/dist/src/lro/lroEngine.js.map +0 -1
- package/dist/src/lro/models.d.ts +0 -138
- package/dist/src/lro/models.d.ts.map +0 -1
- package/dist/src/lro/models.js +0 -12
- package/dist/src/lro/models.js.map +0 -1
- package/dist/src/lro/operation.d.ts +0 -36
- package/dist/src/lro/operation.d.ts.map +0 -1
- package/dist/src/lro/operation.js +0 -89
- package/dist/src/lro/operation.js.map +0 -1
- package/dist/src/lro/passthrough.d.ts +0 -3
- package/dist/src/lro/passthrough.d.ts.map +0 -1
- package/dist/src/lro/passthrough.js +0 -14
- package/dist/src/lro/passthrough.js.map +0 -1
- package/dist/src/lro/requestUtils.d.ts +0 -16
- package/dist/src/lro/requestUtils.d.ts.map +0 -1
- package/dist/src/lro/requestUtils.js +0 -76
- package/dist/src/lro/requestUtils.js.map +0 -1
- package/dist/src/lro/stateMachine.d.ts +0 -18
- package/dist/src/lro/stateMachine.d.ts.map +0 -1
- package/dist/src/lro/stateMachine.js +0 -90
- package/dist/src/lro/stateMachine.js.map +0 -1
- package/src/coreClientLro.ts +0 -315
- package/src/coreHttpLro.ts +0 -268
- package/src/generators/clientContextFileGenerator.ts +0 -405
- package/src/lro/azureAsyncPolling.ts +0 -82
- package/src/lro/bodyPolling.ts +0 -34
- package/src/lro/index.ts +0 -18
- package/src/lro/locationPolling.ts +0 -20
- package/src/lro/lroEngine.ts +0 -53
- package/src/lro/models.ts +0 -165
- package/src/lro/operation.ts +0 -112
- package/src/lro/passthrough.ts +0 -15
- package/src/lro/requestUtils.ts +0 -94
- package/src/lro/stateMachine.ts +0 -108
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getPagedAsyncIterator,
|
|
3
|
+
PagedAsyncIterableIterator,
|
|
4
|
+
PagedResult
|
|
5
|
+
} from "@azure/core-paging";
|
|
6
|
+
import {
|
|
7
|
+
Client,
|
|
8
|
+
createRestError,
|
|
9
|
+
PathUncheckedResponse
|
|
10
|
+
} from "@azure-rest/core-client";
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Helper type to extract the type of an array
|
|
14
|
+
*/
|
|
15
|
+
export type GetArrayType<T> = T extends Array<infer TData> ? TData : never;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* The type of a custom function that defines how to get a page and a link to the next one if any.
|
|
19
|
+
*/
|
|
20
|
+
export type GetPage<TPage> = (
|
|
21
|
+
pageLink: string,
|
|
22
|
+
maxPageSize?: number
|
|
23
|
+
) => Promise<{
|
|
24
|
+
page: TPage;
|
|
25
|
+
nextPageLink?: string;
|
|
26
|
+
}>;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Options for the paging helper
|
|
30
|
+
*/
|
|
31
|
+
export interface PagingOptions<TResponse> {
|
|
32
|
+
/**
|
|
33
|
+
* Custom function to extract pagination details for crating the PagedAsyncIterableIterator
|
|
34
|
+
*/
|
|
35
|
+
customGetPage?: GetPage<PaginateReturn<TResponse>[]>
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Helper type to infer the Type of the paged elements from the response type
|
|
40
|
+
* This type is generated based on the swagger information for x-ms-pageable
|
|
41
|
+
* specifically on the itemName property which indicates the property of the response
|
|
42
|
+
* where the page items are found. The default value is `value`.
|
|
43
|
+
* This type will allow us to provide strongly typed Iterator based on the response we get as second parameter
|
|
44
|
+
*/
|
|
45
|
+
export type PaginateReturn<TResult> = TResult extends {{#each itemNames}}
|
|
46
|
+
{
|
|
47
|
+
|
|
48
|
+
body: { {{this}}?: infer TPage }
|
|
49
|
+
|
|
50
|
+
} {{#if @last }}{{else}} | {{/if}}
|
|
51
|
+
{{/each}}
|
|
52
|
+
? GetArrayType<TPage>
|
|
53
|
+
: Array<unknown>;
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Helper to paginate results from an initial response that follows the specification of Autorest `x-ms-pageable` extension
|
|
57
|
+
* @param client - Client to use for sending the next page requests
|
|
58
|
+
* @param initialResponse - Initial response containing the nextLink and current page of elements
|
|
59
|
+
* @param customGetPage - Optional - Function to define how to extract the page and next link to be used to paginate the results
|
|
60
|
+
* @returns - PagedAsyncIterableIterator to iterate the elements
|
|
61
|
+
*/
|
|
62
|
+
export function paginate<TResponse extends PathUncheckedResponse>(
|
|
63
|
+
client: Client,
|
|
64
|
+
initialResponse: TResponse,
|
|
65
|
+
options: PagingOptions<TResponse> = {}
|
|
66
|
+
): PagedAsyncIterableIterator<PaginateReturn<TResponse>> {
|
|
67
|
+
// Extract element type from initial response
|
|
68
|
+
type TElement = PaginateReturn<TResponse>;
|
|
69
|
+
let firstRun = true;
|
|
70
|
+
{{#if isComplexPaging}}
|
|
71
|
+
// We need to check the response for success before trying to inspect it looking for
|
|
72
|
+
// the properties to use for nextLink and itemName
|
|
73
|
+
checkPagingRequest(initialResponse);
|
|
74
|
+
const { itemName, nextLinkName } = getPaginationProperties(initialResponse);
|
|
75
|
+
{{else}}
|
|
76
|
+
const itemName = {{ quoteWrap itemNames }};
|
|
77
|
+
const nextLinkName = {{quoteWrap nextLinkNames}};
|
|
78
|
+
{{/if}}
|
|
79
|
+
const { customGetPage } = options;
|
|
80
|
+
const pagedResult: PagedResult<TElement[]> = {
|
|
81
|
+
firstPageLink: "",
|
|
82
|
+
getPage:
|
|
83
|
+
typeof customGetPage === "function"
|
|
84
|
+
? customGetPage
|
|
85
|
+
: async (pageLink: string) => {
|
|
86
|
+
const result = firstRun
|
|
87
|
+
? initialResponse
|
|
88
|
+
: await client.pathUnchecked(pageLink).get();
|
|
89
|
+
firstRun = false;
|
|
90
|
+
checkPagingRequest(result);
|
|
91
|
+
const nextLink = getNextLink(result.body, nextLinkName);
|
|
92
|
+
const values = getElements<TElement>(result.body, itemName);
|
|
93
|
+
return {
|
|
94
|
+
page: values,
|
|
95
|
+
nextPageLink: nextLink
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
return getPagedAsyncIterator(pagedResult);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Gets for the value of nextLink in the body
|
|
105
|
+
*/
|
|
106
|
+
function getNextLink(body: unknown, nextLinkName?: string): string | undefined {
|
|
107
|
+
if (!nextLinkName) {
|
|
108
|
+
return undefined;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
const nextLink = (body as Record<string, unknown>)[nextLinkName];
|
|
112
|
+
|
|
113
|
+
if (typeof nextLink !== "string" && typeof nextLink !== "undefined") {
|
|
114
|
+
throw new Error(
|
|
115
|
+
`Body Property ${nextLinkName} should be a string or undefined`
|
|
116
|
+
);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
return nextLink;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Gets the elements of the current request in the body.
|
|
124
|
+
*/
|
|
125
|
+
function getElements<T = unknown>(body: unknown, itemName: string): T[] {
|
|
126
|
+
const value = (body as Record<string, unknown>)[itemName] as T[];
|
|
127
|
+
|
|
128
|
+
// value has to be an array according to the x-ms-pageable extension.
|
|
129
|
+
// The fact that this must be an array is used above to calculate the
|
|
130
|
+
// type of elements in the page in PaginateReturn
|
|
131
|
+
if (!Array.isArray(value)) {
|
|
132
|
+
throw new Error(
|
|
133
|
+
`Couldn't paginate response\n Body doesn't contain an array property with name: ${itemName}`
|
|
134
|
+
);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
return value ?? [];
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
/**
|
|
141
|
+
* Checks if a request failed
|
|
142
|
+
*/
|
|
143
|
+
function checkPagingRequest(response: PathUncheckedResponse): void {
|
|
144
|
+
const Http2xxStatusCodes = [
|
|
145
|
+
"200",
|
|
146
|
+
"201",
|
|
147
|
+
"202",
|
|
148
|
+
"203",
|
|
149
|
+
"204",
|
|
150
|
+
"205",
|
|
151
|
+
"206",
|
|
152
|
+
"207",
|
|
153
|
+
"208",
|
|
154
|
+
"226"
|
|
155
|
+
];
|
|
156
|
+
if (!Http2xxStatusCodes.includes(response.status)) {
|
|
157
|
+
throw createRestError(
|
|
158
|
+
`Pagination failed with unexpected statusCode ${response.status}`,
|
|
159
|
+
response
|
|
160
|
+
);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
{{#if isComplexPaging}}
|
|
165
|
+
/**
|
|
166
|
+
* Extracts the itemName and nextLinkName from the initial response to use them for pagination
|
|
167
|
+
*/
|
|
168
|
+
function getPaginationProperties(initialResponse: PathUncheckedResponse) {
|
|
169
|
+
// Build a set with the passed custom nextLinkNames
|
|
170
|
+
const nextLinkNames = new Set([{{ quoteWrap nextLinkNames }}]);
|
|
171
|
+
|
|
172
|
+
// Build a set with the passed custom set of itemNames
|
|
173
|
+
const itemNames = new Set([{{ quoteWrap itemNames }}]);
|
|
174
|
+
|
|
175
|
+
let nextLinkName: string | undefined;
|
|
176
|
+
let itemName: string | undefined;
|
|
177
|
+
|
|
178
|
+
for (const name of nextLinkNames) {
|
|
179
|
+
const nextLink = (initialResponse.body as Record<string, unknown>)[
|
|
180
|
+
name
|
|
181
|
+
] as string;
|
|
182
|
+
if (nextLink) {
|
|
183
|
+
nextLinkName = name;
|
|
184
|
+
break;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
for (const name of itemNames) {
|
|
189
|
+
const item = (initialResponse.body as Record<string, unknown>)[
|
|
190
|
+
name
|
|
191
|
+
] as string;
|
|
192
|
+
if (item) {
|
|
193
|
+
itemName = name;
|
|
194
|
+
break;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
if (!itemName) {
|
|
199
|
+
throw new Error(
|
|
200
|
+
`Couldn't paginate response\n Body doesn't contain an array property with name: ${[
|
|
201
|
+
...itemNames
|
|
202
|
+
].join(" OR ")}`
|
|
203
|
+
);
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
return { itemName, nextLinkName };
|
|
207
|
+
}
|
|
208
|
+
{{/if}}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { Client, HttpResponse } from "@azure-rest/core-client";
|
|
2
|
+
import {
|
|
3
|
+
LongRunningOperation,
|
|
4
|
+
LroEngine,
|
|
5
|
+
LroEngineOptions,
|
|
6
|
+
LroResponse,
|
|
7
|
+
PollerLike,
|
|
8
|
+
PollOperationState
|
|
9
|
+
} from "@azure/core-lro";
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Helper function that builds a Poller object to help polling a long running operation.
|
|
13
|
+
* @param client - Client to use for sending the request to get additional pages.
|
|
14
|
+
* @param initialResponse - The initial response.
|
|
15
|
+
* @param options - Options to set a resume state or custom polling interval.
|
|
16
|
+
* @returns - A poller object to poll for operation state updates and eventually get the final response.
|
|
17
|
+
*/
|
|
18
|
+
export function getLongRunningPoller<TResult extends HttpResponse>(
|
|
19
|
+
client: Client,
|
|
20
|
+
initialResponse: TResult,
|
|
21
|
+
options: LroEngineOptions<TResult, PollOperationState<TResult>> = {}
|
|
22
|
+
): PollerLike<PollOperationState<TResult>, TResult> {
|
|
23
|
+
const poller: LongRunningOperation<TResult> = {
|
|
24
|
+
requestMethod: initialResponse.request.method,
|
|
25
|
+
requestPath: initialResponse.request.url,
|
|
26
|
+
sendInitialRequest: async () => {
|
|
27
|
+
// In the case of Rest Clients we are building the LRO poller object from a response that's the reason
|
|
28
|
+
// we are not triggering the initial request here, just extracting the information from the
|
|
29
|
+
// response we were provided.
|
|
30
|
+
return getLroResponse(initialResponse);
|
|
31
|
+
},
|
|
32
|
+
sendPollRequest: async path => {
|
|
33
|
+
// This is the callback that is going to be called to poll the service
|
|
34
|
+
// to get the latest status. We use the client provided and the polling path
|
|
35
|
+
// which is an opaque URL provided by caller, the service sends this in one of the following headers: operation-location, azure-asyncoperation or location
|
|
36
|
+
// depending on the lro pattern that the service implements. If non is provided we default to the initial path.
|
|
37
|
+
const response = await client
|
|
38
|
+
.pathUnchecked(path ?? initialResponse.request.url)
|
|
39
|
+
.get();
|
|
40
|
+
const lroResponse = getLroResponse(response as TResult);
|
|
41
|
+
lroResponse.rawResponse.headers["x-ms-original-url"] =
|
|
42
|
+
initialResponse.request.url;
|
|
43
|
+
return lroResponse;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
return new LroEngine(poller, options);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Converts a Rest Client response to a response that the LRO engine knows about
|
|
52
|
+
* @param response - a rest client http response
|
|
53
|
+
* @returns - An LRO response that the LRO engine can work with
|
|
54
|
+
*/
|
|
55
|
+
function getLroResponse<TResult extends HttpResponse>(
|
|
56
|
+
response: TResult
|
|
57
|
+
): LroResponse<TResult> {
|
|
58
|
+
if (Number.isNaN(response.status)) {
|
|
59
|
+
throw new TypeError(
|
|
60
|
+
`Status code of the response is not a number. Value: ${response.status}`
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return {
|
|
65
|
+
flatResponse: response,
|
|
66
|
+
rawResponse: {
|
|
67
|
+
...response,
|
|
68
|
+
statusCode: Number.parseInt(response.status),
|
|
69
|
+
body: response.body
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export interface SampleGroup {
|
|
2
|
+
sampleFileName: string,
|
|
3
|
+
clientFactoryFuncName: string;
|
|
4
|
+
clientClassName: string,
|
|
5
|
+
clientPackageName: string,
|
|
6
|
+
samples: SampleDetails[],
|
|
7
|
+
importedTypes?: string[],
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export interface SampleDetails {
|
|
11
|
+
sampleFunctionName: string,
|
|
12
|
+
clientParameterNames: string,
|
|
13
|
+
methodParameterNames: string,
|
|
14
|
+
clientParamAssignments: string[],
|
|
15
|
+
methodParamAssignments: string[],
|
|
16
|
+
originalFileLocation?: string,
|
|
17
|
+
operationName: string,
|
|
18
|
+
isTopLevel: boolean,
|
|
19
|
+
isPaging: boolean,
|
|
20
|
+
operationGroupName: string,
|
|
21
|
+
operationDescription: string,
|
|
22
|
+
clientClassName: string,
|
|
23
|
+
}
|
|
File without changes
|
|
@@ -8,6 +8,7 @@ import {
|
|
|
8
8
|
ObjectSchema,
|
|
9
9
|
PrimitiveSchema,
|
|
10
10
|
Schema,
|
|
11
|
+
SchemaContext,
|
|
11
12
|
SchemaType
|
|
12
13
|
} from "@autorest/codemodel";
|
|
13
14
|
import { getLanguageMetadata } from "../utils/languageHelpers";
|
|
@@ -20,15 +21,20 @@ import { NameType, normalizeName } from "../utils/nameUtils";
|
|
|
20
21
|
*/
|
|
21
22
|
export function getElementType(
|
|
22
23
|
schema: Schema,
|
|
24
|
+
schemaUsage: SchemaContext[],
|
|
23
25
|
importedModels = new Set<string>()
|
|
24
26
|
): string {
|
|
25
27
|
if (isArraySchema(schema)) {
|
|
26
28
|
// Recursively find out the type for the elements in the array.
|
|
27
|
-
return `Array<${getElementType(
|
|
29
|
+
return `Array<${getElementType(
|
|
30
|
+
schema.elementType,
|
|
31
|
+
schemaUsage,
|
|
32
|
+
importedModels
|
|
33
|
+
)}>`;
|
|
28
34
|
}
|
|
29
35
|
|
|
30
36
|
if (isPrimitiveSchema(schema)) {
|
|
31
|
-
return `${primitiveSchemaToType(schema)}`;
|
|
37
|
+
return `${primitiveSchemaToType(schema, schemaUsage)}`;
|
|
32
38
|
}
|
|
33
39
|
|
|
34
40
|
if (isAnyObjectSchema(schema)) {
|
|
@@ -36,7 +42,11 @@ export function getElementType(
|
|
|
36
42
|
}
|
|
37
43
|
|
|
38
44
|
if (isObjectSchema(schema)) {
|
|
39
|
-
const
|
|
45
|
+
const nameSuffix = schemaUsage.includes(SchemaContext.Output)
|
|
46
|
+
? "Output"
|
|
47
|
+
: "";
|
|
48
|
+
const schemaInfo = getObjectInfo(schema);
|
|
49
|
+
const name = `${schemaInfo.name}${nameSuffix}`;
|
|
40
50
|
importedModels.add(name);
|
|
41
51
|
return `${name}`;
|
|
42
52
|
}
|
|
@@ -44,6 +54,7 @@ export function getElementType(
|
|
|
44
54
|
if (isDictionarySchema(schema)) {
|
|
45
55
|
return `Record<string, ${getElementType(
|
|
46
56
|
schema.elementType,
|
|
57
|
+
schemaUsage,
|
|
47
58
|
importedModels
|
|
48
59
|
)}>`;
|
|
49
60
|
}
|
|
@@ -84,7 +95,10 @@ function isPrimitiveSchema(schema: Schema): boolean {
|
|
|
84
95
|
* @param schema - Schema to generate a type for
|
|
85
96
|
* @returns a string with the Typescript type to generate for the given schema
|
|
86
97
|
*/
|
|
87
|
-
function primitiveSchemaToType(
|
|
98
|
+
export function primitiveSchemaToType(
|
|
99
|
+
schema: PrimitiveSchema,
|
|
100
|
+
schemaUse: SchemaContext[]
|
|
101
|
+
): string {
|
|
88
102
|
switch (schema.type) {
|
|
89
103
|
case SchemaType.Any:
|
|
90
104
|
return "any";
|
|
@@ -94,10 +108,12 @@ function primitiveSchemaToType(schema: PrimitiveSchema): string {
|
|
|
94
108
|
case SchemaType.Date:
|
|
95
109
|
case SchemaType.Time:
|
|
96
110
|
case SchemaType.DateTime:
|
|
97
|
-
return
|
|
111
|
+
return schemaUse.includes(SchemaContext.Output)
|
|
112
|
+
? "string"
|
|
113
|
+
: "Date | string";
|
|
98
114
|
case SchemaType.Char:
|
|
99
115
|
return "string";
|
|
100
|
-
case SchemaType.
|
|
116
|
+
case SchemaType.ByteArray:
|
|
101
117
|
case SchemaType.Duration:
|
|
102
118
|
case SchemaType.Credential:
|
|
103
119
|
case SchemaType.UnixTime:
|
|
@@ -105,10 +121,12 @@ function primitiveSchemaToType(schema: PrimitiveSchema): string {
|
|
|
105
121
|
case SchemaType.Uuid:
|
|
106
122
|
case SchemaType.String:
|
|
107
123
|
return "string";
|
|
124
|
+
case SchemaType.Binary:
|
|
125
|
+
return schemaUse.includes(SchemaContext.Output)
|
|
126
|
+
? "Uint8Array"
|
|
127
|
+
: "string | Uint8Array | ReadableStream<Uint8Array> | NodeJS.ReadableStream";
|
|
108
128
|
case SchemaType.Boolean:
|
|
109
129
|
return "boolean";
|
|
110
|
-
case SchemaType.ByteArray:
|
|
111
|
-
return "Uint8Array";
|
|
112
130
|
case SchemaType.Choice:
|
|
113
131
|
case SchemaType.SealedChoice:
|
|
114
132
|
return (schema as ChoiceSchema).choices
|
|
@@ -116,7 +134,11 @@ function primitiveSchemaToType(schema: PrimitiveSchema): string {
|
|
|
116
134
|
.join(" | ");
|
|
117
135
|
case SchemaType.Constant:
|
|
118
136
|
const value = (schema as ConstantSchema).value.value;
|
|
119
|
-
return typeof value === "string"
|
|
137
|
+
return typeof value === "string"
|
|
138
|
+
? (schema as ConstantSchema)?.valueType?.type === SchemaType.DateTime
|
|
139
|
+
? `"${new Date(`${value}`).toISOString()}"`
|
|
140
|
+
: `"${value}"`
|
|
141
|
+
: value;
|
|
120
142
|
}
|
|
121
143
|
|
|
122
144
|
throw new Error(`Unknown primitive schema ${schema.type}`);
|
|
@@ -152,3 +174,23 @@ export function isDictionarySchema(schema: Schema): schema is DictionarySchema {
|
|
|
152
174
|
export function isConstantSchema(schema: Schema): schema is ConstantSchema {
|
|
153
175
|
return schema.type === SchemaType.Constant;
|
|
154
176
|
}
|
|
177
|
+
|
|
178
|
+
/**
|
|
179
|
+
* Gets additional documentation for a given schema
|
|
180
|
+
*/
|
|
181
|
+
export function getFormatDocs(schema: Schema) {
|
|
182
|
+
switch (schema.type) {
|
|
183
|
+
case SchemaType.ByteArray:
|
|
184
|
+
return "Value may contain base64 encoded characters";
|
|
185
|
+
case SchemaType.Binary:
|
|
186
|
+
return "Value may contain any sequence of octets";
|
|
187
|
+
case SchemaType.Credential:
|
|
188
|
+
return "Value may contain a password";
|
|
189
|
+
case SchemaType.Uuid:
|
|
190
|
+
return "Value may contain a UUID";
|
|
191
|
+
case SchemaType.Uri:
|
|
192
|
+
return "Value may contain a URL";
|
|
193
|
+
default:
|
|
194
|
+
return undefined;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
@@ -175,6 +175,7 @@ function buildMapper(
|
|
|
175
175
|
const serializedName =
|
|
176
176
|
getDiscriminatorValue(schema) ||
|
|
177
177
|
options.serializedName ||
|
|
178
|
+
(schema as ObjectSchema).discriminator && !isUberParent(schema as ObjectSchema) && getLanguageMetadata(schema.language).name ||
|
|
178
179
|
// Fallback to name only for XML schemas since they need a name, otherwise don't
|
|
179
180
|
(options.hasXmlMetadata && getLanguageMetadata(schema.language).name);
|
|
180
181
|
|
|
@@ -220,7 +221,7 @@ function buildMapper(
|
|
|
220
221
|
return {
|
|
221
222
|
...{ type: mappeType },
|
|
222
223
|
...(serializedName && { serializedName }),
|
|
223
|
-
...(
|
|
224
|
+
...(schema.defaultValue !== undefined && {
|
|
224
225
|
defaultValue: schema.defaultValue
|
|
225
226
|
}),
|
|
226
227
|
...(required && { required }),
|
|
@@ -362,7 +363,10 @@ function transformObjectMapper(pipelineValue: PipelineValue) {
|
|
|
362
363
|
uberParent,
|
|
363
364
|
polymorphicDiscriminator: {
|
|
364
365
|
serializedName: discriminator!.property.serializedName,
|
|
365
|
-
clientName:
|
|
366
|
+
clientName: normalizeName(
|
|
367
|
+
discriminator!.property.language.default.name,
|
|
368
|
+
NameType.Property
|
|
369
|
+
)
|
|
366
370
|
}
|
|
367
371
|
}),
|
|
368
372
|
...(additionalProperties && { additionalProperties })
|
|
@@ -385,7 +389,9 @@ function transformDictionaryMapper(pipelineValue: PipelineValue) {
|
|
|
385
389
|
}
|
|
386
390
|
let dictionarySchema = schema as DictionarySchema | AnyObjectSchema;
|
|
387
391
|
|
|
388
|
-
const elementSchema = isDictionarySchema(dictionarySchema)
|
|
392
|
+
const elementSchema = isDictionarySchema(dictionarySchema)
|
|
393
|
+
? dictionarySchema.elementType
|
|
394
|
+
: new AnySchema("Schema for AnyObject type");
|
|
389
395
|
const mapper = buildMapper(
|
|
390
396
|
schema,
|
|
391
397
|
{ name: MapperType.Dictionary, value: getMapperOrRef(elementSchema) },
|
|
@@ -400,11 +406,11 @@ function transformDictionaryMapper(pipelineValue: PipelineValue) {
|
|
|
400
406
|
}
|
|
401
407
|
|
|
402
408
|
function isDictionarySchema(schema: Schema): schema is DictionarySchema {
|
|
403
|
-
return schema.type === SchemaType.Dictionary
|
|
409
|
+
return schema.type === SchemaType.Dictionary;
|
|
404
410
|
}
|
|
405
411
|
|
|
406
412
|
function isAnyObjectSchema(schema: Schema): schema is AnyObjectSchema {
|
|
407
|
-
return schema.type === SchemaType.AnyObject
|
|
413
|
+
return schema.type === SchemaType.AnyObject;
|
|
408
414
|
}
|
|
409
415
|
|
|
410
416
|
function transformArrayMapper(pipelineValue: PipelineValue) {
|
|
@@ -688,7 +694,7 @@ function processProperties(
|
|
|
688
694
|
const propName = getLanguageMetadata(prop.language).name;
|
|
689
695
|
const name = normalizeName(
|
|
690
696
|
propName,
|
|
691
|
-
NameType.Property,
|
|
697
|
+
prop.language.default.isTopLevelParameter? NameType.Parameter: NameType.Property,
|
|
692
698
|
true /** shouldGuard */
|
|
693
699
|
);
|
|
694
700
|
modelProperties[name] = getMapperOrRef(prop.schema, serializedName, {
|
|
@@ -6,7 +6,8 @@ import {
|
|
|
6
6
|
ObjectSchema,
|
|
7
7
|
ComplexSchema,
|
|
8
8
|
Property,
|
|
9
|
-
GroupProperty
|
|
9
|
+
GroupProperty,
|
|
10
|
+
Language
|
|
10
11
|
} from "@autorest/codemodel";
|
|
11
12
|
import {
|
|
12
13
|
ObjectDetails,
|
|
@@ -58,7 +59,7 @@ export function transformObject(
|
|
|
58
59
|
hasAdditionalProperties: false,
|
|
59
60
|
kind,
|
|
60
61
|
name,
|
|
61
|
-
serializedName: metadata
|
|
62
|
+
serializedName: getObjectSerializedName(metadata, kind),
|
|
62
63
|
description: metadata.description || undefined,
|
|
63
64
|
schema,
|
|
64
65
|
properties: schema.properties
|
|
@@ -69,6 +70,14 @@ export function transformObject(
|
|
|
69
70
|
return getAdditionalObjectDetails(objectDetails, uberParents);
|
|
70
71
|
}
|
|
71
72
|
|
|
73
|
+
function getObjectSerializedName(metadata: Language, kind: ObjectKind) {
|
|
74
|
+
return metadata.serializedName
|
|
75
|
+
? metadata.serializedName
|
|
76
|
+
: kind === ObjectKind.Polymorphic
|
|
77
|
+
? metadata.name
|
|
78
|
+
: undefined;
|
|
79
|
+
}
|
|
80
|
+
|
|
72
81
|
export function transformProperty({
|
|
73
82
|
language,
|
|
74
83
|
schema,
|
|
@@ -92,12 +101,14 @@ export function transformProperty({
|
|
|
92
101
|
return {
|
|
93
102
|
name: normalizeName(
|
|
94
103
|
metadata.name,
|
|
95
|
-
NameType.Property,
|
|
104
|
+
metadata.isTopLevelParameter ? NameType.Parameter : NameType.Property,
|
|
96
105
|
true /** shouldGuard */
|
|
97
106
|
),
|
|
98
107
|
description,
|
|
99
108
|
serializedName: serializedName,
|
|
100
|
-
type: typeName
|
|
109
|
+
type: typeName.startsWith("$DO_NOT_NORMALIZE$")
|
|
110
|
+
? typeName.replace("$DO_NOT_NORMALIZE$", "")
|
|
111
|
+
: typeName,
|
|
101
112
|
required: !!required,
|
|
102
113
|
readOnly: !!readOnly,
|
|
103
114
|
nullable: !!nullable,
|
|
@@ -287,12 +298,21 @@ function transformPolymorphicObject(
|
|
|
287
298
|
? {}
|
|
288
299
|
: { [`"${discriminatorProperty}"`]: childDiscriminators };
|
|
289
300
|
} else {
|
|
290
|
-
discriminatorPath = `${uberParentName}.${
|
|
301
|
+
discriminatorPath = `${uberParentName}.${
|
|
302
|
+
schema.discriminatorValue
|
|
303
|
+
? schema.discriminatorValue
|
|
304
|
+
: schema.language.default.name
|
|
305
|
+
}`;
|
|
291
306
|
if (uberParent.discriminator) {
|
|
292
307
|
const childDiscriminators = getChildrenDiscriminators(schema);
|
|
293
308
|
discriminatorValues = {
|
|
294
309
|
[getLanguageMetadata(uberParent.discriminator.property.language)
|
|
295
|
-
.name]: [
|
|
310
|
+
.name]: [
|
|
311
|
+
schema.discriminatorValue
|
|
312
|
+
? schema.discriminatorValue
|
|
313
|
+
: schema.language.default.name,
|
|
314
|
+
...childDiscriminators
|
|
315
|
+
]
|
|
296
316
|
};
|
|
297
317
|
}
|
|
298
318
|
}
|
|
@@ -388,7 +388,11 @@ export async function transformOperation(
|
|
|
388
388
|
NameType.Interface,
|
|
389
389
|
true /** shouldGuard */
|
|
390
390
|
);
|
|
391
|
-
|
|
391
|
+
|
|
392
|
+
const typeName =
|
|
393
|
+
normalizedOperationGroupName === clientName
|
|
394
|
+
? `${normalizedOperationName}`
|
|
395
|
+
: `${normalizedOperationGroupName}${normalizedOperationName}`;
|
|
392
396
|
|
|
393
397
|
const typeDetails: TypeDetails = {
|
|
394
398
|
typeName,
|
|
@@ -487,6 +491,7 @@ export async function transformOperationGroup(
|
|
|
487
491
|
return {
|
|
488
492
|
name: operationGroupClassName,
|
|
489
493
|
key: operationGroup.$key,
|
|
494
|
+
originalKey: operationGroup.$key,
|
|
490
495
|
operations,
|
|
491
496
|
isTopLevel,
|
|
492
497
|
mediaTypes
|
|
@@ -28,7 +28,8 @@ import {
|
|
|
28
28
|
import { isEqual, isNil } from "lodash";
|
|
29
29
|
import {
|
|
30
30
|
getTypeForSchema,
|
|
31
|
-
getSchemaTypeDocumentation
|
|
31
|
+
getSchemaTypeDocumentation,
|
|
32
|
+
getSecurityInfoFromModel
|
|
32
33
|
} from "../utils/schemaHelpers";
|
|
33
34
|
import { getStringForValue } from "../utils/valueHelpers";
|
|
34
35
|
import { ClientOptions } from "../models/clientDetails";
|
|
@@ -104,7 +105,7 @@ export function transformParameters(
|
|
|
104
105
|
options: ClientOptions
|
|
105
106
|
): ParameterDetails[] {
|
|
106
107
|
let parameters: ParameterDetails[] = [];
|
|
107
|
-
const { addCredentials } =
|
|
108
|
+
const { addCredentials } = getSecurityInfoFromModel(codeModel.security);
|
|
108
109
|
|
|
109
110
|
const hasXmlMetadata = !!options.mediaTypes?.has(KnownMediaType.Xml);
|
|
110
111
|
extractOperationParameters(codeModel).forEach(p =>
|
|
@@ -147,20 +148,36 @@ const extractOperationParameters = (codeModel: CodeModel) =>
|
|
|
147
148
|
}
|
|
148
149
|
const operationParams: OperationParameterDetails[] = (
|
|
149
150
|
operation.parameters || []
|
|
150
|
-
).map(p =>
|
|
151
|
+
).map(p => {
|
|
152
|
+
if (p.required) {
|
|
153
|
+
p.language.default.isTopLevelParameter = true;
|
|
154
|
+
}
|
|
155
|
+
return {
|
|
156
|
+
parameter: p,
|
|
157
|
+
operationName
|
|
158
|
+
}
|
|
159
|
+
});
|
|
151
160
|
|
|
152
161
|
// Operations may have multiple requests, each with their own set of parameters.
|
|
153
162
|
// This is known to be the case when an operation can consume multiple media types.
|
|
154
163
|
// We need to ensure that the parameters from each request (method overload) is accounted for.
|
|
155
164
|
const requestParams: OperationParameterDetails[] = [];
|
|
156
|
-
requests.
|
|
157
|
-
request.parameters?.
|
|
165
|
+
requests.map(request => {
|
|
166
|
+
request.parameters?.map(parameter => {
|
|
158
167
|
requestParams.push({
|
|
159
168
|
operationName,
|
|
160
169
|
parameter,
|
|
161
170
|
targetMediaType: request.protocol.http?.knownMediaType
|
|
162
171
|
});
|
|
172
|
+
if (parameter.required) {
|
|
173
|
+
if ((parameter as any)['targetProperty'] !== undefined) {
|
|
174
|
+
(parameter as any)['targetProperty'].language.default.isTopLevelParameter = true;
|
|
175
|
+
}
|
|
176
|
+
parameter.language.default.isTopLevelParameter = true;
|
|
177
|
+
}
|
|
178
|
+
return parameter;
|
|
163
179
|
});
|
|
180
|
+
return request;
|
|
164
181
|
});
|
|
165
182
|
return [...operations, ...requestParams, ...operationParams];
|
|
166
183
|
},
|
|
@@ -236,7 +253,9 @@ export function populateOperationParameters(
|
|
|
236
253
|
true /** shouldGuard */
|
|
237
254
|
);
|
|
238
255
|
|
|
239
|
-
const sameNameParams = operationParameters.filter(
|
|
256
|
+
const sameNameParams = operationParameters.filter(
|
|
257
|
+
p => p.name === name || p.nameRef === name
|
|
258
|
+
);
|
|
240
259
|
description += getSchemaTypeDocumentation(parameter.schema);
|
|
241
260
|
const isRequired = getParameterRequired(parameter);
|
|
242
261
|
const isNullable = !!parameter.nullable;
|
|
@@ -329,7 +348,7 @@ function getParameterPath(parameter: Parameter) {
|
|
|
329
348
|
const name = normalizeName(
|
|
330
349
|
metadata.name,
|
|
331
350
|
NameType.Parameter,
|
|
332
|
-
true /** shouldGuard */
|
|
351
|
+
parameter.language.default.isTopLevelParameter ? true: false /** shouldGuard */
|
|
333
352
|
);
|
|
334
353
|
|
|
335
354
|
if (parameter.groupedBy) {
|