@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
|
@@ -1,18 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getStatusCode = exports.responseToSchemaResponse = exports.getResponseTypeName = void 0;
|
|
3
|
+
exports.gerOperationSuccessStatus = exports.getStatusCode = exports.responseToSchemaResponse = exports.getResponseTypeName = void 0;
|
|
4
4
|
const codemodel_1 = require("@autorest/codemodel");
|
|
5
5
|
const languageHelpers_1 = require("../utils/languageHelpers");
|
|
6
6
|
const nameUtils_1 = require("../utils/nameUtils");
|
|
7
7
|
const schemaHelpers_1 = require("../utils/schemaHelpers");
|
|
8
8
|
function getResponseTypeName(operation, response) {
|
|
9
9
|
const statusCode = getStatusCode(response);
|
|
10
|
-
return nameUtils_1.normalizeName(`${languageHelpers_1.getLanguageMetadata(operation.language).name}${statusCode}Response`, nameUtils_1.NameType.Interface);
|
|
10
|
+
return (0, nameUtils_1.normalizeName)(`${(0, languageHelpers_1.getLanguageMetadata)(operation.language).name}${statusCode}Response`, nameUtils_1.NameType.Interface);
|
|
11
11
|
}
|
|
12
12
|
exports.getResponseTypeName = getResponseTypeName;
|
|
13
13
|
function responseToSchemaResponse(response) {
|
|
14
|
-
if (!schemaHelpers_1.isSchemaResponse(response)) {
|
|
15
|
-
|
|
14
|
+
if (!(0, schemaHelpers_1.isSchemaResponse)(response)) {
|
|
15
|
+
let schema = response.binary
|
|
16
|
+
? new codemodel_1.BinarySchema("Binary schema")
|
|
17
|
+
: new codemodel_1.AnyObjectSchema("AnyObject schema");
|
|
18
|
+
return new codemodel_1.SchemaResponse(schema, Object.assign({}, response));
|
|
16
19
|
}
|
|
17
20
|
else {
|
|
18
21
|
return response;
|
|
@@ -31,13 +34,21 @@ function getStatusCode(response) {
|
|
|
31
34
|
// Extracting the status code for the response definition. Eventhough it is represented as an array of status codes
|
|
32
35
|
// in M4, in reality it can only contain a single status code, hence we are always picking the first one.
|
|
33
36
|
let statusCode = (_a = response.protocol.http) === null || _a === void 0 ? void 0 : _a.statusCodes[0];
|
|
34
|
-
// Swagger can define a catch all status code "default" to get any other status code not explicitly defined
|
|
35
|
-
// however default is not a valid HTTP status code. We are setting 500 as a catch all status code instead
|
|
36
|
-
// which is a valid http status
|
|
37
|
-
// if (statusCode === "default") {
|
|
38
|
-
// return `"500"`;
|
|
39
|
-
// }
|
|
40
37
|
return `"${statusCode}"`;
|
|
41
38
|
}
|
|
42
39
|
exports.getStatusCode = getStatusCode;
|
|
40
|
+
/**
|
|
41
|
+
* Extracts all success status codes for a give operation
|
|
42
|
+
*/
|
|
43
|
+
function gerOperationSuccessStatus(operation) {
|
|
44
|
+
var _a, _b;
|
|
45
|
+
const responses = (_a = operation.responses) !== null && _a !== void 0 ? _a : [];
|
|
46
|
+
const status = [];
|
|
47
|
+
for (const response of responses) {
|
|
48
|
+
let statusCode = (_b = response.protocol.http) === null || _b === void 0 ? void 0 : _b.statusCodes[0];
|
|
49
|
+
status.push(statusCode);
|
|
50
|
+
}
|
|
51
|
+
return status;
|
|
52
|
+
}
|
|
53
|
+
exports.gerOperationSuccessStatus = gerOperationSuccessStatus;
|
|
43
54
|
//# sourceMappingURL=operationHelpers.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"operationHelpers.js","sourceRoot":"","sources":["../../../src/restLevelClient/operationHelpers.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"operationHelpers.js","sourceRoot":"","sources":["../../../src/restLevelClient/operationHelpers.ts"],"names":[],"mappings":";;;AAAA,mDAO6B;AAC7B,8DAA+D;AAC/D,kDAA6D;AAC7D,0DAA0D;AAE1D,SAAgB,mBAAmB,CACjC,SAAoB,EACpB,QAAmC;IAEnC,MAAM,UAAU,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC;IAE3C,OAAO,IAAA,yBAAa,EAClB,GAAG,IAAA,qCAAmB,EAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,IAAI,GAAG,UAAU,UAAU,EACtE,oBAAQ,CAAC,SAAS,CACnB,CAAC;AACJ,CAAC;AAVD,kDAUC;AAED,SAAgB,wBAAwB,CAAC,QAAmC;IAC1E,IAAI,CAAC,IAAA,gCAAgB,EAAC,QAAQ,CAAC,EAAE;QAC/B,IAAI,MAAM,GAAY,QAAgB,CAAC,MAAM;YAC3C,CAAC,CAAC,IAAI,wBAAY,CAAC,eAAe,CAAC;YACnC,CAAC,CAAC,IAAI,2BAAe,CAAC,kBAAkB,CAAC,CAAC;QAE5C,OAAO,IAAI,0BAAc,CAAC,MAAM,oBAC3B,QAAQ,EACX,CAAC;KACJ;SAAM;QACL,OAAO,QAAQ,CAAC;KACjB;AACH,CAAC;AAZD,4DAYC;AAED;;;GAGG;AACH,SAAgB,aAAa,CAAC,QAAkB;;IAC9C,IAAI,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,SAAS,EAAE;QACxC,MAAM,IAAI,KAAK,CACb,gHAAgH,CACjH,CAAC;KACH;IAED,mHAAmH;IACnH,yGAAyG;IACzG,IAAI,UAAU,GAAG,MAAA,QAAQ,CAAC,QAAQ,CAAC,IAAI,0CAAE,WAAW,CAAC,CAAC,CAAC,CAAC;IAExD,OAAO,IAAI,UAAU,GAAG,CAAC;AAC3B,CAAC;AAZD,sCAYC;AAED;;GAEG;AACH,SAAgB,yBAAyB,CAAC,SAAoB;;IAC5D,MAAM,SAAS,GAAG,MAAA,SAAS,CAAC,SAAS,mCAAI,EAAE,CAAC;IAC5C,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;QAChC,IAAI,UAAU,GAAG,MAAA,QAAQ,CAAC,QAAQ,CAAC,IAAI,0CAAE,WAAW,CAAC,CAAC,CAAC,CAAC;QACxD,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;KACzB;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAVD,8DAUC"}
|
|
@@ -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
|
+
export interface SampleDetails {
|
|
10
|
+
sampleFunctionName: string;
|
|
11
|
+
clientParameterNames: string;
|
|
12
|
+
methodParameterNames: string;
|
|
13
|
+
clientParamAssignments: string[];
|
|
14
|
+
methodParamAssignments: string[];
|
|
15
|
+
originalFileLocation?: string;
|
|
16
|
+
operationName: string;
|
|
17
|
+
isTopLevel: boolean;
|
|
18
|
+
isPaging: boolean;
|
|
19
|
+
operationGroupName: string;
|
|
20
|
+
operationDescription: string;
|
|
21
|
+
clientClassName: string;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=generateSamples.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generateSamples.d.ts","sourceRoot":"","sources":["../../../../src/restLevelClient/samples/generateSamples.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,OAAO,EAAE,aAAa,EAAE,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,MAAM,WAAW,aAAa;IAC1B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,sBAAsB,EAAE,MAAM,EAAE,CAAC;IACjC,sBAAsB,EAAE,MAAM,EAAE,CAAC;IACjC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,OAAO,CAAC;IAClB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,eAAe,EAAE,MAAM,CAAC;CAC3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generateSamples.js","sourceRoot":"","sources":["../../../../src/restLevelClient/samples/generateSamples.ts"],"names":[],"mappings":""}
|
|
File without changes
|
|
@@ -1,10 +1,20 @@
|
|
|
1
|
-
import { ConstantSchema, DictionarySchema, Schema } from "@autorest/codemodel";
|
|
1
|
+
import { ConstantSchema, DictionarySchema, PrimitiveSchema, Schema, SchemaContext } from "@autorest/codemodel";
|
|
2
2
|
/**
|
|
3
3
|
* Get the Typescript type to generate from an Schema
|
|
4
4
|
* @param schema - Schema to find element type for
|
|
5
5
|
* @param importedModels - Set to track models to import
|
|
6
6
|
*/
|
|
7
|
-
export declare function getElementType(schema: Schema, importedModels?: Set<string>): string;
|
|
7
|
+
export declare function getElementType(schema: Schema, schemaUsage: SchemaContext[], importedModels?: Set<string>): string;
|
|
8
|
+
/**
|
|
9
|
+
* Given a primitive schema, determines the Typescript type to generate
|
|
10
|
+
* @param schema - Schema to generate a type for
|
|
11
|
+
* @returns a string with the Typescript type to generate for the given schema
|
|
12
|
+
*/
|
|
13
|
+
export declare function primitiveSchemaToType(schema: PrimitiveSchema, schemaUse: SchemaContext[]): string;
|
|
8
14
|
export declare function isDictionarySchema(schema: Schema): schema is DictionarySchema;
|
|
9
15
|
export declare function isConstantSchema(schema: Schema): schema is ConstantSchema;
|
|
16
|
+
/**
|
|
17
|
+
* Gets additional documentation for a given schema
|
|
18
|
+
*/
|
|
19
|
+
export declare function getFormatDocs(schema: Schema): "Value may contain base64 encoded characters" | "Value may contain any sequence of octets" | "Value may contain a password" | "Value may contain a UUID" | "Value may contain a URL" | undefined;
|
|
10
20
|
//# sourceMappingURL=schemaHelpers.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schemaHelpers.d.ts","sourceRoot":"","sources":["../../../src/restLevelClient/schemaHelpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,cAAc,EACd,gBAAgB,
|
|
1
|
+
{"version":3,"file":"schemaHelpers.d.ts","sourceRoot":"","sources":["../../../src/restLevelClient/schemaHelpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,cAAc,EACd,gBAAgB,EAGhB,eAAe,EACf,MAAM,EACN,aAAa,EAEd,MAAM,qBAAqB,CAAC;AAI7B;;;;GAIG;AACH,wBAAgB,cAAc,CAC5B,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,aAAa,EAAE,EAC5B,cAAc,cAAoB,GACjC,MAAM,CAqCR;AA8BD;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,eAAe,EACvB,SAAS,EAAE,aAAa,EAAE,GACzB,MAAM,CA4CR;AAyBD,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,IAAI,gBAAgB,CAE7E;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,IAAI,cAAc,CAEzE;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,oMAe3C"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isConstantSchema = exports.isDictionarySchema = exports.getElementType = void 0;
|
|
3
|
+
exports.getFormatDocs = exports.isConstantSchema = exports.isDictionarySchema = exports.primitiveSchemaToType = exports.getElementType = void 0;
|
|
4
4
|
const codemodel_1 = require("@autorest/codemodel");
|
|
5
5
|
const languageHelpers_1 = require("../utils/languageHelpers");
|
|
6
6
|
const nameUtils_1 = require("../utils/nameUtils");
|
|
@@ -9,24 +9,28 @@ const nameUtils_1 = require("../utils/nameUtils");
|
|
|
9
9
|
* @param schema - Schema to find element type for
|
|
10
10
|
* @param importedModels - Set to track models to import
|
|
11
11
|
*/
|
|
12
|
-
function getElementType(schema, importedModels = new Set()) {
|
|
12
|
+
function getElementType(schema, schemaUsage, importedModels = new Set()) {
|
|
13
13
|
if (isArraySchema(schema)) {
|
|
14
14
|
// Recursively find out the type for the elements in the array.
|
|
15
|
-
return `Array<${getElementType(schema.elementType, importedModels)}>`;
|
|
15
|
+
return `Array<${getElementType(schema.elementType, schemaUsage, importedModels)}>`;
|
|
16
16
|
}
|
|
17
17
|
if (isPrimitiveSchema(schema)) {
|
|
18
|
-
return `${primitiveSchemaToType(schema)}`;
|
|
18
|
+
return `${primitiveSchemaToType(schema, schemaUsage)}`;
|
|
19
19
|
}
|
|
20
20
|
if (isAnyObjectSchema(schema)) {
|
|
21
21
|
return `Record<string, unknown>`;
|
|
22
22
|
}
|
|
23
|
-
if (codemodel_1.isObjectSchema(schema)) {
|
|
24
|
-
const
|
|
23
|
+
if ((0, codemodel_1.isObjectSchema)(schema)) {
|
|
24
|
+
const nameSuffix = schemaUsage.includes(codemodel_1.SchemaContext.Output)
|
|
25
|
+
? "Output"
|
|
26
|
+
: "";
|
|
27
|
+
const schemaInfo = getObjectInfo(schema);
|
|
28
|
+
const name = `${schemaInfo.name}${nameSuffix}`;
|
|
25
29
|
importedModels.add(name);
|
|
26
30
|
return `${name}`;
|
|
27
31
|
}
|
|
28
32
|
if (isDictionarySchema(schema)) {
|
|
29
|
-
return `Record<string, ${getElementType(schema.elementType, importedModels)}>`;
|
|
33
|
+
return `Record<string, ${getElementType(schema.elementType, schemaUsage, importedModels)}>`;
|
|
30
34
|
}
|
|
31
35
|
throw new Error(`Don't know how to get type for schema ${schema.type}`);
|
|
32
36
|
}
|
|
@@ -63,7 +67,8 @@ function isPrimitiveSchema(schema) {
|
|
|
63
67
|
* @param schema - Schema to generate a type for
|
|
64
68
|
* @returns a string with the Typescript type to generate for the given schema
|
|
65
69
|
*/
|
|
66
|
-
function primitiveSchemaToType(schema) {
|
|
70
|
+
function primitiveSchemaToType(schema, schemaUse) {
|
|
71
|
+
var _a;
|
|
67
72
|
switch (schema.type) {
|
|
68
73
|
case codemodel_1.SchemaType.Any:
|
|
69
74
|
return "any";
|
|
@@ -73,10 +78,12 @@ function primitiveSchemaToType(schema) {
|
|
|
73
78
|
case codemodel_1.SchemaType.Date:
|
|
74
79
|
case codemodel_1.SchemaType.Time:
|
|
75
80
|
case codemodel_1.SchemaType.DateTime:
|
|
76
|
-
return
|
|
81
|
+
return schemaUse.includes(codemodel_1.SchemaContext.Output)
|
|
82
|
+
? "string"
|
|
83
|
+
: "Date | string";
|
|
77
84
|
case codemodel_1.SchemaType.Char:
|
|
78
85
|
return "string";
|
|
79
|
-
case codemodel_1.SchemaType.
|
|
86
|
+
case codemodel_1.SchemaType.ByteArray:
|
|
80
87
|
case codemodel_1.SchemaType.Duration:
|
|
81
88
|
case codemodel_1.SchemaType.Credential:
|
|
82
89
|
case codemodel_1.SchemaType.UnixTime:
|
|
@@ -84,10 +91,12 @@ function primitiveSchemaToType(schema) {
|
|
|
84
91
|
case codemodel_1.SchemaType.Uuid:
|
|
85
92
|
case codemodel_1.SchemaType.String:
|
|
86
93
|
return "string";
|
|
94
|
+
case codemodel_1.SchemaType.Binary:
|
|
95
|
+
return schemaUse.includes(codemodel_1.SchemaContext.Output)
|
|
96
|
+
? "Uint8Array"
|
|
97
|
+
: "string | Uint8Array | ReadableStream<Uint8Array> | NodeJS.ReadableStream";
|
|
87
98
|
case codemodel_1.SchemaType.Boolean:
|
|
88
99
|
return "boolean";
|
|
89
|
-
case codemodel_1.SchemaType.ByteArray:
|
|
90
|
-
return "Uint8Array";
|
|
91
100
|
case codemodel_1.SchemaType.Choice:
|
|
92
101
|
case codemodel_1.SchemaType.SealedChoice:
|
|
93
102
|
return schema.choices
|
|
@@ -95,16 +104,21 @@ function primitiveSchemaToType(schema) {
|
|
|
95
104
|
.join(" | ");
|
|
96
105
|
case codemodel_1.SchemaType.Constant:
|
|
97
106
|
const value = schema.value.value;
|
|
98
|
-
return typeof value === "string"
|
|
107
|
+
return typeof value === "string"
|
|
108
|
+
? ((_a = schema === null || schema === void 0 ? void 0 : schema.valueType) === null || _a === void 0 ? void 0 : _a.type) === codemodel_1.SchemaType.DateTime
|
|
109
|
+
? `"${new Date(`${value}`).toISOString()}"`
|
|
110
|
+
: `"${value}"`
|
|
111
|
+
: value;
|
|
99
112
|
}
|
|
100
113
|
throw new Error(`Unknown primitive schema ${schema.type}`);
|
|
101
114
|
}
|
|
115
|
+
exports.primitiveSchemaToType = primitiveSchemaToType;
|
|
102
116
|
/**
|
|
103
117
|
* Gets object schema metadata
|
|
104
118
|
* @param schema - Schema definition of an object
|
|
105
119
|
*/
|
|
106
120
|
function getObjectInfo(schema) {
|
|
107
|
-
const name = nameUtils_1.normalizeName(languageHelpers_1.getLanguageMetadata(schema.language).name, nameUtils_1.NameType.Interface, true);
|
|
121
|
+
const name = (0, nameUtils_1.normalizeName)((0, languageHelpers_1.getLanguageMetadata)(schema.language).name, nameUtils_1.NameType.Interface, true);
|
|
108
122
|
return {
|
|
109
123
|
name
|
|
110
124
|
};
|
|
@@ -123,4 +137,24 @@ function isConstantSchema(schema) {
|
|
|
123
137
|
return schema.type === codemodel_1.SchemaType.Constant;
|
|
124
138
|
}
|
|
125
139
|
exports.isConstantSchema = isConstantSchema;
|
|
140
|
+
/**
|
|
141
|
+
* Gets additional documentation for a given schema
|
|
142
|
+
*/
|
|
143
|
+
function getFormatDocs(schema) {
|
|
144
|
+
switch (schema.type) {
|
|
145
|
+
case codemodel_1.SchemaType.ByteArray:
|
|
146
|
+
return "Value may contain base64 encoded characters";
|
|
147
|
+
case codemodel_1.SchemaType.Binary:
|
|
148
|
+
return "Value may contain any sequence of octets";
|
|
149
|
+
case codemodel_1.SchemaType.Credential:
|
|
150
|
+
return "Value may contain a password";
|
|
151
|
+
case codemodel_1.SchemaType.Uuid:
|
|
152
|
+
return "Value may contain a UUID";
|
|
153
|
+
case codemodel_1.SchemaType.Uri:
|
|
154
|
+
return "Value may contain a URL";
|
|
155
|
+
default:
|
|
156
|
+
return undefined;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
exports.getFormatDocs = getFormatDocs;
|
|
126
160
|
//# sourceMappingURL=schemaHelpers.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schemaHelpers.js","sourceRoot":"","sources":["../../../src/restLevelClient/schemaHelpers.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"schemaHelpers.js","sourceRoot":"","sources":["../../../src/restLevelClient/schemaHelpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -57,7 +57,7 @@ function normalizeMultipleContentTypes(codeModel) {
|
|
|
57
57
|
continue;
|
|
58
58
|
}
|
|
59
59
|
for (const parameter of parameters) {
|
|
60
|
-
const parameterMetadata = languageHelpers_1.getLanguageMetadata(parameter.language);
|
|
60
|
+
const parameterMetadata = (0, languageHelpers_1.getLanguageMetadata)(parameter.language);
|
|
61
61
|
if (parameterMetadata.name.toLowerCase() === "contenttype") {
|
|
62
62
|
parameter.required = false;
|
|
63
63
|
}
|
|
@@ -74,11 +74,11 @@ function addPageableMethods(codeModel) {
|
|
|
74
74
|
var _a, _b, _c, _d, _e;
|
|
75
75
|
const operationGroups = codeModel.operationGroups;
|
|
76
76
|
for (const operationGroup of operationGroups) {
|
|
77
|
-
const operationGroupMetadata = languageHelpers_1.getLanguageMetadata(operationGroup.language);
|
|
77
|
+
const operationGroupMetadata = (0, languageHelpers_1.getLanguageMetadata)(operationGroup.language);
|
|
78
78
|
const operations = operationGroup.operations.slice();
|
|
79
79
|
for (const operation of operations) {
|
|
80
|
-
const paginationDetails = extractPaginationDetails_1.extractPaginationDetails(operation);
|
|
81
|
-
const operationMetadata = languageHelpers_1.getLanguageMetadata(operation.language);
|
|
80
|
+
const paginationDetails = (0, extractPaginationDetails_1.extractPaginationDetails)(operation);
|
|
81
|
+
const operationMetadata = (0, languageHelpers_1.getLanguageMetadata)(operation.language);
|
|
82
82
|
const operationName = operationMetadata.name;
|
|
83
83
|
const operationDescription = operationMetadata.description;
|
|
84
84
|
if (!paginationDetails || !paginationDetails.nextLinkName) {
|
|
@@ -95,16 +95,16 @@ function addPageableMethods(codeModel) {
|
|
|
95
95
|
let nextLinkMethod = findOperation(codeModel, (_a = paginationDetails.group) !== null && _a !== void 0 ? _a : operationGroupMetadata.name, nextLinkOperationName);
|
|
96
96
|
if (nextLinkMethod) {
|
|
97
97
|
// The operation to call to get subsequent pages already exists, so we don't need to create it.
|
|
98
|
-
const nextMetadata = languageHelpers_1.getLanguageMetadata(nextLinkMethod.language);
|
|
98
|
+
const nextMetadata = (0, languageHelpers_1.getLanguageMetadata)(nextLinkMethod.language);
|
|
99
99
|
nextMetadata.paging = Object.assign(Object.assign({}, nextMetadata.paging), { isNextLinkMethod: true });
|
|
100
100
|
// Populate original operation metadata
|
|
101
101
|
operationMetadata.paging = Object.assign(Object.assign({}, operationMetadata.paging), { nextLinkOperation: nextLinkMethod, isNextLinkMethod: false });
|
|
102
102
|
continue;
|
|
103
103
|
}
|
|
104
104
|
// The "Next" operation doesn't exist, so we need to create it using current operation as a base.
|
|
105
|
-
nextLinkMethod = cloneOperation_1.cloneOperation(operation, nextLinkOperationName, operationDescription);
|
|
105
|
+
nextLinkMethod = (0, cloneOperation_1.cloneOperation)(operation, nextLinkOperationName, operationDescription);
|
|
106
106
|
// Populate new Next operation metadata
|
|
107
|
-
const nextLinkMethodMetadata = languageHelpers_1.getLanguageMetadata(nextLinkMethod.language);
|
|
107
|
+
const nextLinkMethodMetadata = (0, languageHelpers_1.getLanguageMetadata)(nextLinkMethod.language);
|
|
108
108
|
nextLinkMethodMetadata.paging = Object.assign(Object.assign({}, nextLinkMethodMetadata.paging), { isNextLinkMethod: true });
|
|
109
109
|
// Populate original operation metadata
|
|
110
110
|
operationMetadata.paging = Object.assign(Object.assign({}, operationMetadata.paging), { nextLinkOperation: nextLinkMethod, isNextLinkMethod: false });
|
|
@@ -184,15 +184,15 @@ function inject200Response(nextLinkMethod, isLro) {
|
|
|
184
184
|
if (!successResponse) {
|
|
185
185
|
throw new Error("Expected nextLink of Lro operation to have a success response defined");
|
|
186
186
|
}
|
|
187
|
-
const success200 = lodash_1.cloneDeep(successResponse);
|
|
187
|
+
const success200 = (0, lodash_1.cloneDeep)(successResponse);
|
|
188
188
|
success200.protocol.http.statusCodes = ["200"];
|
|
189
189
|
nextLinkMethod.responses = [...nextLinkMethod.responses, success200];
|
|
190
190
|
}
|
|
191
191
|
}
|
|
192
192
|
function findOperation(codeModel, operationGroupName, operationName) {
|
|
193
|
-
const operationGroup = codeModel.operationGroups.find(og => languageHelpers_1.getLanguageMetadata(og.language).name === operationGroupName);
|
|
193
|
+
const operationGroup = codeModel.operationGroups.find(og => (0, languageHelpers_1.getLanguageMetadata)(og.language).name === operationGroupName);
|
|
194
194
|
return ((operationGroup === null || operationGroup === void 0 ? void 0 : operationGroup.operations) || []).find(operation => {
|
|
195
|
-
const languageMetadata = languageHelpers_1.getLanguageMetadata(operation.language);
|
|
195
|
+
const languageMetadata = (0, languageHelpers_1.getLanguageMetadata)(operation.language);
|
|
196
196
|
return languageMetadata.name === operationName;
|
|
197
197
|
});
|
|
198
198
|
}
|