@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,121 @@
|
|
|
1
|
+
import { CodeModel, Operation } from "@autorest/codemodel";
|
|
2
|
+
import { OptionalKind, MethodSignatureStructure } from "ts-morph";
|
|
3
|
+
import {
|
|
4
|
+
CasingConvention,
|
|
5
|
+
NameType,
|
|
6
|
+
normalizeName,
|
|
7
|
+
ReservedName
|
|
8
|
+
} from "../utils/nameUtils";
|
|
9
|
+
import { buildMethodDefinitions } from "./helpers/operationHelpers";
|
|
10
|
+
import { PathParameter, Paths } from "./interfaces";
|
|
11
|
+
|
|
12
|
+
export const REST_CLIENT_RESERVED: ReservedName[] = [
|
|
13
|
+
{ name: "path", reservedFor: [NameType.Property, NameType.OperationGroup] },
|
|
14
|
+
{
|
|
15
|
+
name: "pathUnchecked",
|
|
16
|
+
reservedFor: [NameType.Property, NameType.OperationGroup]
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
name: "pipeline",
|
|
20
|
+
reservedFor: [NameType.Property, NameType.OperationGroup]
|
|
21
|
+
}
|
|
22
|
+
];
|
|
23
|
+
export function generateMethodShortcuts(model: CodeModel, paths: Paths) {
|
|
24
|
+
const operationGroups = model.operationGroups;
|
|
25
|
+
let keys: Record<string, OptionalKind<MethodSignatureStructure>[]> = {};
|
|
26
|
+
for (const group of operationGroups) {
|
|
27
|
+
const groupName = normalizeName(
|
|
28
|
+
group.language.default.name,
|
|
29
|
+
NameType.OperationGroup,
|
|
30
|
+
true,
|
|
31
|
+
REST_CLIENT_RESERVED,
|
|
32
|
+
CasingConvention.Camel
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
keys[groupName] = buildOperationDefinitions(group.operations, paths);
|
|
36
|
+
}
|
|
37
|
+
return keys;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export function generateMethodShortcutImplementation(
|
|
41
|
+
model: CodeModel,
|
|
42
|
+
paths: Paths
|
|
43
|
+
) {
|
|
44
|
+
const operationGroups = model.operationGroups;
|
|
45
|
+
let keys: Record<string, string[]> = {};
|
|
46
|
+
for (const group of operationGroups) {
|
|
47
|
+
const groupName = normalizeName(
|
|
48
|
+
group.language.default.name,
|
|
49
|
+
NameType.OperationGroup,
|
|
50
|
+
true,
|
|
51
|
+
REST_CLIENT_RESERVED,
|
|
52
|
+
CasingConvention.Camel
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
keys[groupName] = buildOperationDeclarations(group.operations, paths);
|
|
56
|
+
}
|
|
57
|
+
return keys;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
function buildOperationDeclarations(operations: Operation[], paths: Paths) {
|
|
61
|
+
let ops: string[] = [];
|
|
62
|
+
|
|
63
|
+
for (const operation of operations) {
|
|
64
|
+
const name = normalizeName(
|
|
65
|
+
operation.language.default.name,
|
|
66
|
+
NameType.Property,
|
|
67
|
+
true
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
const path = operation.requests![0].protocol.http?.path;
|
|
71
|
+
const method = operation.requests![0].protocol.http?.method;
|
|
72
|
+
const pathParams = paths[path]?.pathParameters;
|
|
73
|
+
const methodDefinitions = generateOperationDeclaration(
|
|
74
|
+
path,
|
|
75
|
+
name,
|
|
76
|
+
method,
|
|
77
|
+
pathParams
|
|
78
|
+
);
|
|
79
|
+
ops = [...ops, methodDefinitions];
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
return ops;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
function generateOperationDeclaration(
|
|
86
|
+
path: string,
|
|
87
|
+
operationName: string,
|
|
88
|
+
method: string,
|
|
89
|
+
pathParams: PathParameter[] = []
|
|
90
|
+
): string {
|
|
91
|
+
const pathParamNames = `${
|
|
92
|
+
pathParams.length > 0 ? `${pathParams.map(p => p.name)},` : ""
|
|
93
|
+
}`;
|
|
94
|
+
return `"${operationName}": (${pathParamNames} options) => {
|
|
95
|
+
return client.path("${path}", ${pathParamNames}).${method}(options);
|
|
96
|
+
}`;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
function buildOperationDefinitions(operations: Operation[], paths: Paths) {
|
|
100
|
+
let ops: OptionalKind<MethodSignatureStructure>[] = [];
|
|
101
|
+
|
|
102
|
+
for (const operation of operations) {
|
|
103
|
+
const name = normalizeName(
|
|
104
|
+
operation.language.default.name,
|
|
105
|
+
NameType.Property,
|
|
106
|
+
true
|
|
107
|
+
);
|
|
108
|
+
|
|
109
|
+
const path = operation.requests![0].protocol.http?.path;
|
|
110
|
+
const method: string = operation.requests![0].protocol.http?.method;
|
|
111
|
+
const methods = paths[path]?.methods[method];
|
|
112
|
+
const pathParams = paths[path]?.pathParameters;
|
|
113
|
+
const methodDefinitions = buildMethodDefinitions(
|
|
114
|
+
{ [name]: methods },
|
|
115
|
+
pathParams
|
|
116
|
+
);
|
|
117
|
+
ops = [...ops, ...methodDefinitions];
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
return ops;
|
|
121
|
+
}
|
|
@@ -3,12 +3,12 @@ import {
|
|
|
3
3
|
ComplexSchema,
|
|
4
4
|
isObjectSchema,
|
|
5
5
|
ObjectSchema,
|
|
6
|
-
Property
|
|
6
|
+
Property,
|
|
7
|
+
SchemaContext
|
|
7
8
|
} from "@autorest/codemodel";
|
|
8
9
|
import { Channel } from "@autorest/extension-base";
|
|
9
10
|
import {
|
|
10
11
|
InterfaceDeclarationStructure,
|
|
11
|
-
Program,
|
|
12
12
|
PropertySignatureStructure,
|
|
13
13
|
StructureKind,
|
|
14
14
|
TypeAliasDeclarationStructure
|
|
@@ -24,16 +24,20 @@ import { getLanguageMetadata } from "../utils/languageHelpers";
|
|
|
24
24
|
*/
|
|
25
25
|
export function buildObjectInterfaces(
|
|
26
26
|
model: CodeModel,
|
|
27
|
-
importedModels: Set<string
|
|
27
|
+
importedModels: Set<string>,
|
|
28
|
+
schemaUsage: SchemaContext[]
|
|
28
29
|
): InterfaceDeclarationStructure[] {
|
|
29
|
-
const objectSchemas = model.schemas.objects ?? []
|
|
30
|
+
const objectSchemas = (model.schemas.objects ?? []).filter(o =>
|
|
31
|
+
o.usage?.some(u => schemaUsage.includes(u))
|
|
32
|
+
);
|
|
30
33
|
const objectInterfaces: InterfaceDeclarationStructure[] = [];
|
|
31
34
|
|
|
32
35
|
for (const objectSchema of objectSchemas) {
|
|
33
|
-
const baseName = getObjectBaseName(objectSchema);
|
|
36
|
+
const baseName = getObjectBaseName(objectSchema, schemaUsage);
|
|
34
37
|
const interfaceDeclaration = getObjectInterfaceDeclaration(
|
|
35
38
|
baseName,
|
|
36
39
|
objectSchema,
|
|
40
|
+
schemaUsage,
|
|
37
41
|
importedModels
|
|
38
42
|
);
|
|
39
43
|
|
|
@@ -42,13 +46,22 @@ export function buildObjectInterfaces(
|
|
|
42
46
|
return objectInterfaces;
|
|
43
47
|
}
|
|
44
48
|
|
|
45
|
-
export function buildPolymorphicAliases(
|
|
49
|
+
export function buildPolymorphicAliases(
|
|
50
|
+
model: CodeModel,
|
|
51
|
+
schemaUsage: SchemaContext[]
|
|
52
|
+
) {
|
|
46
53
|
// We'll add aliases for polymorphic objects
|
|
47
54
|
const objectAliases: TypeAliasDeclarationStructure[] = [];
|
|
48
|
-
const objectSchemas = model.schemas.objects ?? []
|
|
55
|
+
const objectSchemas = (model.schemas.objects ?? []).filter(o =>
|
|
56
|
+
o.usage?.some(u => schemaUsage.includes(u))
|
|
57
|
+
);
|
|
49
58
|
for (const objectSchema of objectSchemas) {
|
|
50
|
-
const baseName = getObjectBaseName(objectSchema);
|
|
51
|
-
const typeAlias = getPolymorphicTypeAlias(
|
|
59
|
+
const baseName = getObjectBaseName(objectSchema, schemaUsage);
|
|
60
|
+
const typeAlias = getPolymorphicTypeAlias(
|
|
61
|
+
baseName,
|
|
62
|
+
objectSchema,
|
|
63
|
+
schemaUsage
|
|
64
|
+
);
|
|
52
65
|
if (typeAlias) {
|
|
53
66
|
objectAliases.push(typeAlias);
|
|
54
67
|
}
|
|
@@ -60,12 +73,18 @@ export function buildPolymorphicAliases(model: CodeModel) {
|
|
|
60
73
|
/**
|
|
61
74
|
* Gets a base name for an object schema this is tipically used with suffixes when building interface or type names
|
|
62
75
|
*/
|
|
63
|
-
function getObjectBaseName(
|
|
64
|
-
|
|
76
|
+
function getObjectBaseName(
|
|
77
|
+
objectSchema: ObjectSchema,
|
|
78
|
+
schemaUsage: SchemaContext[]
|
|
79
|
+
) {
|
|
80
|
+
const nameSuffix = schemaUsage.includes(SchemaContext.Output) ? "Output" : "";
|
|
81
|
+
const name = normalizeName(
|
|
65
82
|
getLanguageMetadata(objectSchema.language).name,
|
|
66
83
|
NameType.Interface,
|
|
67
84
|
true /** guard name */
|
|
68
85
|
);
|
|
86
|
+
|
|
87
|
+
return `${name}${nameSuffix}`;
|
|
69
88
|
}
|
|
70
89
|
|
|
71
90
|
/**
|
|
@@ -74,7 +93,8 @@ function getObjectBaseName(objectSchema: ObjectSchema) {
|
|
|
74
93
|
*/
|
|
75
94
|
function getPolymorphicTypeAlias(
|
|
76
95
|
baseName: string,
|
|
77
|
-
objectSchema: ObjectSchema
|
|
96
|
+
objectSchema: ObjectSchema,
|
|
97
|
+
schemaUsage: SchemaContext[]
|
|
78
98
|
): TypeAliasDeclarationStructure | undefined {
|
|
79
99
|
if (!isPolymorphicParent(objectSchema)) {
|
|
80
100
|
return undefined;
|
|
@@ -88,13 +108,16 @@ function getPolymorphicTypeAlias(
|
|
|
88
108
|
}
|
|
89
109
|
|
|
90
110
|
for (const child of objectSchema.children?.all ?? []) {
|
|
111
|
+
const nameSuffix = schemaUsage.includes(SchemaContext.Output)
|
|
112
|
+
? "Output"
|
|
113
|
+
: "";
|
|
91
114
|
const name = normalizeName(
|
|
92
115
|
getLanguageMetadata(child.language).name,
|
|
93
116
|
NameType.Interface,
|
|
94
117
|
true /** shouldGuard */
|
|
95
118
|
);
|
|
96
119
|
|
|
97
|
-
unionTypes.push(name);
|
|
120
|
+
unionTypes.push(`${name}${nameSuffix}`);
|
|
98
121
|
}
|
|
99
122
|
|
|
100
123
|
return {
|
|
@@ -112,16 +135,21 @@ function getPolymorphicTypeAlias(
|
|
|
112
135
|
function getObjectInterfaceDeclaration(
|
|
113
136
|
baseName: string,
|
|
114
137
|
objectSchema: ObjectSchema,
|
|
138
|
+
schemaUsage: SchemaContext[],
|
|
115
139
|
importedModels: Set<string>
|
|
116
140
|
): InterfaceDeclarationStructure {
|
|
117
|
-
let interfaceName = baseName
|
|
141
|
+
let interfaceName = `${baseName}`;
|
|
118
142
|
if (isPolymorphicParent(objectSchema)) {
|
|
119
143
|
interfaceName = `${baseName}Base`;
|
|
120
144
|
}
|
|
121
145
|
|
|
122
146
|
const properties = objectSchema.properties ?? [];
|
|
123
147
|
|
|
124
|
-
let propertySignatures = getPropertySignatures(
|
|
148
|
+
let propertySignatures = getPropertySignatures(
|
|
149
|
+
properties,
|
|
150
|
+
schemaUsage,
|
|
151
|
+
importedModels
|
|
152
|
+
);
|
|
125
153
|
|
|
126
154
|
// Add the polymorphic property if exists
|
|
127
155
|
propertySignatures = addDiscriminatorProperty(
|
|
@@ -130,7 +158,7 @@ function getObjectInterfaceDeclaration(
|
|
|
130
158
|
);
|
|
131
159
|
|
|
132
160
|
// Calculate the parents of the current object
|
|
133
|
-
const extendFrom = getImmediateParentsNames(objectSchema);
|
|
161
|
+
const extendFrom = getImmediateParentsNames(objectSchema, schemaUsage);
|
|
134
162
|
|
|
135
163
|
return {
|
|
136
164
|
kind: StructureKind.Interface,
|
|
@@ -222,7 +250,11 @@ function getDiscriminatorPropertyName(objectSchema: ObjectSchema) {
|
|
|
222
250
|
* Calculates the discriminator values that a given object needs
|
|
223
251
|
*/
|
|
224
252
|
function getDiscriminatorValue(objectSchema: ObjectSchema): string | undefined {
|
|
225
|
-
const discriminatorValue = objectSchema.discriminatorValue
|
|
253
|
+
const discriminatorValue = objectSchema.discriminatorValue
|
|
254
|
+
? objectSchema.discriminatorValue
|
|
255
|
+
: objectSchema.discriminator?.property.isDiscriminator
|
|
256
|
+
? objectSchema.language.default.name
|
|
257
|
+
: undefined;
|
|
226
258
|
const children = objectSchema.children?.immediate ?? [];
|
|
227
259
|
|
|
228
260
|
// If the current object has a discriminatorValue but doesn't have any children
|
|
@@ -274,7 +306,10 @@ function getChildDiscriminatorValues(children: ComplexSchema[]): string[] {
|
|
|
274
306
|
/**
|
|
275
307
|
* Gets a list of types a given object may extend from
|
|
276
308
|
*/
|
|
277
|
-
function getImmediateParentsNames(
|
|
309
|
+
function getImmediateParentsNames(
|
|
310
|
+
objectSchema: ObjectSchema,
|
|
311
|
+
shcemaUsage: SchemaContext[]
|
|
312
|
+
): string[] {
|
|
278
313
|
if (!objectSchema.parents?.immediate) {
|
|
279
314
|
return [];
|
|
280
315
|
}
|
|
@@ -291,11 +326,14 @@ function getImmediateParentsNames(objectSchema: ObjectSchema): string[] {
|
|
|
291
326
|
const parents = objectSchema.parents.immediate
|
|
292
327
|
.filter(p => !isDictionarySchema(p))
|
|
293
328
|
.map(parent => {
|
|
294
|
-
const
|
|
329
|
+
const nameSuffix = shcemaUsage.includes(SchemaContext.Output)
|
|
330
|
+
? "Output"
|
|
331
|
+
: "";
|
|
332
|
+
const name = `${normalizeName(
|
|
295
333
|
getLanguageMetadata(parent.language).name,
|
|
296
334
|
NameType.Interface,
|
|
297
335
|
true /** shouldGuard */
|
|
298
|
-
)
|
|
336
|
+
)}${nameSuffix}`;
|
|
299
337
|
|
|
300
338
|
return isObjectSchema(parent) && isPolymorphicParent(parent)
|
|
301
339
|
? `${name}Base`
|
|
@@ -307,7 +345,10 @@ function getImmediateParentsNames(objectSchema: ObjectSchema): string[] {
|
|
|
307
345
|
|
|
308
346
|
function getPropertySignatures(
|
|
309
347
|
properties: Property[],
|
|
348
|
+
schemaUsage: SchemaContext[],
|
|
310
349
|
importedModels: Set<string>
|
|
311
350
|
) {
|
|
312
|
-
return properties.map(p =>
|
|
351
|
+
return properties.map(p =>
|
|
352
|
+
getPropertySignature(p, schemaUsage, importedModels)
|
|
353
|
+
);
|
|
313
354
|
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { readFileSync } from "fs";
|
|
2
|
+
import { getAutorestOptions, getSession } from "../autorestSession";
|
|
3
|
+
import { extractPaginationDetails } from "../utils/extractPaginationDetails";
|
|
4
|
+
import * as path from "path";
|
|
5
|
+
import * as hbs from "handlebars";
|
|
6
|
+
import { Project } from "ts-morph";
|
|
7
|
+
|
|
8
|
+
interface PagingDetails {
|
|
9
|
+
itemNames: string[];
|
|
10
|
+
nextLinkNames: string[];
|
|
11
|
+
isComplexPaging: boolean;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function generatePagingHelper(project: Project) {
|
|
15
|
+
const pagingInfo = getPagingInfo();
|
|
16
|
+
let file: string = "";
|
|
17
|
+
|
|
18
|
+
file = readFileSync(path.join(__dirname, "paginateHelper.ts.hbs"), {
|
|
19
|
+
encoding: "utf-8"
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
hbs.registerHelper("quoteWrap", function(
|
|
23
|
+
value: string | number | boolean | string[]
|
|
24
|
+
) {
|
|
25
|
+
if (Array.isArray(value)) {
|
|
26
|
+
return value.map(element => `"${element}"`).join();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return `"${value}"`;
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
const { srcPath } = getAutorestOptions();
|
|
33
|
+
const readmeFileContents = hbs.compile(file, { noEscape: true });
|
|
34
|
+
project.createSourceFile(
|
|
35
|
+
path.join(srcPath, "paginateHelper.ts"),
|
|
36
|
+
readmeFileContents(pagingInfo),
|
|
37
|
+
{
|
|
38
|
+
overwrite: true
|
|
39
|
+
}
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function getPagingInfo(): PagingDetails {
|
|
44
|
+
const { model } = getSession();
|
|
45
|
+
const nextLinks = new Set<string>();
|
|
46
|
+
const itemNames = new Set<string>();
|
|
47
|
+
// Add default values
|
|
48
|
+
nextLinks.add("nextLink");
|
|
49
|
+
itemNames.add("value");
|
|
50
|
+
for (let operationGroup of model.operationGroups) {
|
|
51
|
+
for (let operation of operationGroup.operations) {
|
|
52
|
+
const paginationDetails = extractPaginationDetails(operation);
|
|
53
|
+
if (paginationDetails) {
|
|
54
|
+
const { nextLinkName, itemName } = paginationDetails;
|
|
55
|
+
nextLinkName && nextLinks.add(`${nextLinkName}`);
|
|
56
|
+
itemName && itemNames.add(`${itemName}`);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// If there are more than one options for nextLink and item names we need to generate a
|
|
62
|
+
// more complex pagination helper.
|
|
63
|
+
const isComplexPaging = nextLinks.size > 1 || itemNames.size > 1;
|
|
64
|
+
return {
|
|
65
|
+
itemNames: [...itemNames],
|
|
66
|
+
nextLinkNames: [...nextLinks],
|
|
67
|
+
isComplexPaging
|
|
68
|
+
};
|
|
69
|
+
}
|