@microsoft/teamsfx-core 2.0.10-rc.0 → 2.0.10
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/build/common/constants.d.ts +19 -11
- package/build/common/constants.d.ts.map +1 -1
- package/build/common/constants.js +22 -44
- package/build/common/constants.js.map +1 -1
- package/build/common/correlator.d.ts +0 -1
- package/build/common/correlator.d.ts.map +1 -1
- package/build/common/correlator.js +1 -6
- package/build/common/correlator.js.map +1 -1
- package/build/common/deps-checker/checkerFactory.d.ts.map +1 -0
- package/build/common/deps-checker/checkerFactory.js.map +1 -0
- package/build/{component → common}/deps-checker/constant/helpLink.d.ts +3 -0
- package/build/common/deps-checker/constant/helpLink.d.ts.map +1 -0
- package/build/{component → common}/deps-checker/constant/helpLink.js +6 -1
- package/build/common/deps-checker/constant/helpLink.js.map +1 -0
- package/build/common/deps-checker/constant/index.d.ts.map +1 -0
- package/build/common/deps-checker/constant/index.js.map +1 -0
- package/build/common/deps-checker/constant/message.d.ts.map +1 -0
- package/build/common/deps-checker/constant/message.js +45 -0
- package/build/common/deps-checker/constant/message.js.map +1 -0
- package/build/common/deps-checker/constant/telemetry.d.ts.map +1 -0
- package/build/common/deps-checker/constant/telemetry.js.map +1 -0
- package/build/common/deps-checker/coreDepsLoggerAdapter.d.ts.map +1 -0
- package/build/common/deps-checker/coreDepsLoggerAdapter.js.map +1 -0
- package/build/common/deps-checker/coreDepsTelemetryAdapter.d.ts.map +1 -0
- package/build/{component → common}/deps-checker/coreDepsTelemetryAdapter.js +4 -4
- package/build/common/deps-checker/coreDepsTelemetryAdapter.js.map +1 -0
- package/build/common/deps-checker/depsChecker.d.ts.map +1 -0
- package/build/common/deps-checker/depsChecker.js.map +1 -0
- package/build/common/deps-checker/depsError.d.ts.map +1 -0
- package/build/common/deps-checker/depsError.js.map +1 -0
- package/build/common/deps-checker/depsLogger.d.ts.map +1 -0
- package/build/common/deps-checker/depsLogger.js.map +1 -0
- package/build/common/deps-checker/depsManager.d.ts.map +1 -0
- package/build/common/deps-checker/depsManager.js.map +1 -0
- package/build/common/deps-checker/depsTelemetry.d.ts.map +1 -0
- package/build/common/deps-checker/depsTelemetry.js.map +1 -0
- package/build/common/deps-checker/index.d.ts.map +1 -0
- package/build/common/deps-checker/index.js.map +1 -0
- package/build/common/deps-checker/internal/dotnetChecker.d.ts.map +1 -0
- package/build/{component → common}/deps-checker/internal/dotnetChecker.js +14 -14
- package/build/common/deps-checker/internal/dotnetChecker.js.map +1 -0
- package/build/common/deps-checker/internal/funcToolChecker.d.ts.map +1 -0
- package/build/{component → common}/deps-checker/internal/funcToolChecker.js +16 -16
- package/build/common/deps-checker/internal/funcToolChecker.js.map +1 -0
- package/build/common/deps-checker/internal/nodeChecker.d.ts.map +1 -0
- package/build/common/deps-checker/internal/nodeChecker.js.map +1 -0
- package/build/common/deps-checker/internal/testToolChecker.d.ts.map +1 -0
- package/build/{component → common}/deps-checker/internal/testToolChecker.js +22 -22
- package/build/common/deps-checker/internal/testToolChecker.js.map +1 -0
- package/build/common/deps-checker/internal/vxTestAppChecker.d.ts.map +1 -0
- package/build/{component → common}/deps-checker/internal/vxTestAppChecker.js +8 -14
- package/build/common/deps-checker/internal/vxTestAppChecker.js.map +1 -0
- package/build/common/deps-checker/util/cpUtils.d.ts.map +1 -0
- package/build/common/deps-checker/util/cpUtils.js.map +1 -0
- package/build/common/deps-checker/util/downloadHelper.d.ts.map +1 -0
- package/build/common/deps-checker/util/downloadHelper.js.map +1 -0
- package/build/common/deps-checker/util/fileHelper.d.ts.map +1 -0
- package/build/common/deps-checker/util/fileHelper.js.map +1 -0
- package/build/common/deps-checker/util/index.d.ts.map +1 -0
- package/build/common/deps-checker/util/index.js.map +1 -0
- package/build/common/deps-checker/util/progressIndicator.d.ts.map +1 -0
- package/build/common/deps-checker/util/progressIndicator.js.map +1 -0
- package/build/common/deps-checker/util/system.d.ts.map +1 -0
- package/build/common/deps-checker/util/system.js.map +1 -0
- package/build/common/featureFlags.d.ts +22 -61
- package/build/common/featureFlags.d.ts.map +1 -1
- package/build/common/featureFlags.js +70 -91
- package/build/common/featureFlags.js.map +1 -1
- package/build/common/globalState.js +4 -4
- package/build/common/globalState.js.map +1 -1
- package/build/common/jsonUtils.js +10 -10
- package/build/common/jsonUtils.js.map +1 -1
- package/build/common/local/constants.d.ts +185 -0
- package/build/common/local/constants.d.ts.map +1 -0
- package/build/{component → common}/local/constants.js +0 -1
- package/build/common/local/constants.js.map +1 -0
- package/build/common/local/index.d.ts.map +1 -0
- package/build/common/local/index.js.map +1 -0
- package/build/common/local/localCertificateManager.d.ts.map +1 -0
- package/build/{component → common}/local/localCertificateManager.js +11 -13
- package/build/common/local/localCertificateManager.js.map +1 -0
- package/build/common/local/localEnvManager.d.ts.map +1 -0
- package/build/{component → common}/local/localEnvManager.js +2 -2
- package/build/common/local/localEnvManager.js.map +1 -0
- package/build/common/local/localTelemetryReporter.d.ts.map +1 -0
- package/build/{component → common}/local/localTelemetryReporter.js +4 -4
- package/build/common/local/localTelemetryReporter.js.map +1 -0
- package/build/common/local/npmLogHelper.d.ts.map +1 -0
- package/build/common/local/npmLogHelper.js.map +1 -0
- package/build/common/local/packageJsonHelper.d.ts.map +1 -0
- package/build/common/local/packageJsonHelper.js.map +1 -0
- package/build/common/local/portChecker.d.ts.map +1 -0
- package/build/{component → common}/local/portChecker.js +6 -6
- package/build/common/local/portChecker.js.map +1 -0
- package/build/common/local/process.d.ts.map +1 -0
- package/build/common/local/process.js.map +1 -0
- package/build/common/local/taskDefinition.d.ts.map +1 -0
- package/build/{component → common}/local/taskDefinition.js +6 -6
- package/build/common/local/taskDefinition.js.map +1 -0
- package/build/common/localizeUtils.js +3 -3
- package/build/common/localizeUtils.js.map +1 -1
- package/build/common/m365/constants.d.ts +6 -0
- package/build/common/m365/constants.d.ts.map +1 -0
- package/build/{component → common}/m365/constants.js +1 -4
- package/build/common/m365/constants.js.map +1 -0
- package/build/common/m365/errors.d.ts.map +1 -0
- package/build/{component → common}/m365/errors.js +3 -3
- package/build/common/m365/errors.js.map +1 -0
- package/build/common/m365/launchHelper.d.ts +12 -0
- package/build/common/m365/launchHelper.d.ts.map +1 -0
- package/build/{component → common}/m365/launchHelper.js +30 -38
- package/build/common/m365/launchHelper.js.map +1 -0
- package/build/common/m365/packageService.d.ts.map +1 -0
- package/build/{component → common}/m365/packageService.js +28 -28
- package/build/common/m365/packageService.js.map +1 -0
- package/build/common/m365/serviceConstant.d.ts +3 -0
- package/build/common/m365/serviceConstant.d.ts.map +1 -0
- package/build/common/m365/serviceConstant.js +8 -0
- package/build/common/m365/serviceConstant.js.map +1 -0
- package/build/common/projectSettingsHelper.d.ts +0 -5
- package/build/common/projectSettingsHelper.d.ts.map +1 -1
- package/build/common/projectSettingsHelper.js +1 -31
- package/build/common/projectSettingsHelper.js.map +1 -1
- package/build/common/projectSettingsHelperV3.d.ts +2 -0
- package/build/common/projectSettingsHelperV3.d.ts.map +1 -0
- package/build/common/projectSettingsHelperV3.js +15 -0
- package/build/common/projectSettingsHelperV3.js.map +1 -0
- package/build/common/projectTypeChecker.js +3 -3
- package/build/common/projectTypeChecker.js.map +1 -1
- package/build/common/samples.d.ts +1 -6
- package/build/common/samples.d.ts.map +1 -1
- package/build/common/samples.js +7 -7
- package/build/common/samples.js.map +1 -1
- package/build/common/stringUtils.d.ts +5 -11
- package/build/common/stringUtils.d.ts.map +1 -1
- package/build/common/stringUtils.js +101 -71
- package/build/common/stringUtils.js.map +1 -1
- package/build/common/telemetry.d.ts +13 -43
- package/build/common/telemetry.d.ts.map +1 -1
- package/build/common/telemetry.js +74 -97
- package/build/common/telemetry.js.map +1 -1
- package/build/common/templates-config.json +2 -2
- package/build/common/tools.d.ts +32 -2
- package/build/common/tools.d.ts.map +1 -1
- package/build/common/tools.js +250 -17
- package/build/common/tools.js.map +1 -1
- package/build/common/utils.d.ts +3 -5
- package/build/common/utils.d.ts.map +1 -1
- package/build/common/utils.js +12 -40
- package/build/common/utils.js.map +1 -1
- package/build/common/wrappedAxiosClient.d.ts +0 -1
- package/build/common/wrappedAxiosClient.d.ts.map +1 -1
- package/build/common/wrappedAxiosClient.js +34 -64
- package/build/common/wrappedAxiosClient.js.map +1 -1
- package/build/component/configManager/actionInjector.js +2 -2
- package/build/component/configManager/actionInjector.js.map +1 -1
- package/build/component/configManager/lifecycle.js +10 -10
- package/build/component/configManager/lifecycle.js.map +1 -1
- package/build/component/configManager/parser.js +21 -21
- package/build/component/configManager/parser.js.map +1 -1
- package/build/component/configManager/validator.js +2 -2
- package/build/component/configManager/validator.js.map +1 -1
- package/build/component/constant/commonConstant.d.ts +0 -1
- package/build/component/constant/commonConstant.d.ts.map +1 -1
- package/build/component/constant/commonConstant.js +0 -1
- package/build/component/constant/commonConstant.js.map +1 -1
- package/build/component/constants.d.ts +223 -7
- package/build/component/constants.d.ts.map +1 -1
- package/build/component/constants.js +251 -12
- package/build/component/constants.js.map +1 -1
- package/build/component/coordinator/index.d.ts.map +1 -1
- package/build/component/coordinator/index.js +234 -125
- package/build/component/coordinator/index.js.map +1 -1
- package/build/component/coordinator/summary.js +10 -10
- package/build/component/coordinator/summary.js.map +1 -1
- package/build/component/deployUtils.js +4 -4
- package/build/component/deployUtils.js.map +1 -1
- package/build/component/developerPortalScaffoldUtils.d.ts +5 -1
- package/build/component/developerPortalScaffoldUtils.d.ts.map +1 -1
- package/build/component/developerPortalScaffoldUtils.js +94 -78
- package/build/component/developerPortalScaffoldUtils.js.map +1 -1
- package/build/component/driver/aad/create.d.ts.map +1 -1
- package/build/component/driver/aad/create.js +29 -43
- package/build/component/driver/aad/create.js.map +1 -1
- package/build/component/driver/aad/error/aadAppNameTooLongError.js +2 -2
- package/build/component/driver/aad/error/aadAppNameTooLongError.js.map +1 -1
- package/build/component/driver/aad/error/aadManifestError.js +27 -27
- package/build/component/driver/aad/error/aadManifestError.js.map +1 -1
- package/build/component/driver/aad/error/clientSecretNotAllowedError.js +2 -2
- package/build/component/driver/aad/error/clientSecretNotAllowedError.js.map +1 -1
- package/build/component/driver/aad/error/credentialInvalidLifetimeError.js +2 -2
- package/build/component/driver/aad/error/credentialInvalidLifetimeError.js.map +1 -1
- package/build/component/driver/aad/error/invalidFieldInManifestError.js +2 -2
- package/build/component/driver/aad/error/invalidFieldInManifestError.js.map +1 -1
- package/build/component/driver/aad/error/missingEnvError.js +2 -2
- package/build/component/driver/aad/error/missingEnvError.js.map +1 -1
- package/build/component/driver/aad/update.js +16 -16
- package/build/component/driver/aad/update.js.map +1 -1
- package/build/component/driver/aad/utility/aadAppClient.d.ts.map +1 -1
- package/build/component/driver/aad/utility/aadAppClient.js +19 -19
- package/build/component/driver/aad/utility/aadAppClient.js.map +1 -1
- package/build/component/driver/aad/utility/aadManifestHelper.js +3 -3
- package/build/component/driver/aad/utility/aadManifestHelper.js.map +1 -1
- package/build/component/driver/aad/utility/buildAadManifest.d.ts +1 -1
- package/build/component/driver/aad/utility/buildAadManifest.d.ts.map +1 -1
- package/build/component/driver/aad/utility/buildAadManifest.js +13 -13
- package/build/component/driver/aad/utility/buildAadManifest.js.map +1 -1
- package/build/component/driver/aad/utility/constants.d.ts +0 -2
- package/build/component/driver/aad/utility/constants.d.ts.map +1 -1
- package/build/component/driver/aad/utility/constants.js +0 -2
- package/build/component/driver/aad/utility/constants.js.map +1 -1
- package/build/component/driver/add/addWebPart.d.ts +2 -2
- package/build/component/driver/add/addWebPart.d.ts.map +1 -1
- package/build/component/driver/add/addWebPart.js +31 -31
- package/build/component/driver/add/addWebPart.js.map +1 -1
- package/build/component/driver/add/error/noConfigurationError.js +2 -2
- package/build/component/driver/add/error/noConfigurationError.js.map +1 -1
- package/build/component/driver/apiKey/create.d.ts.map +1 -1
- package/build/component/driver/apiKey/create.js +27 -30
- package/build/component/driver/apiKey/create.js.map +1 -1
- package/build/component/driver/apiKey/error/apiKeyClientSecretInvalid.js +2 -2
- package/build/component/driver/apiKey/error/apiKeyClientSecretInvalid.js.map +1 -1
- package/build/component/driver/apiKey/error/apiKeyDomainInvalid.js +2 -2
- package/build/component/driver/apiKey/error/apiKeyDomainInvalid.js.map +1 -1
- package/build/component/driver/apiKey/error/apiKeyFailedToGetDomain.js +2 -2
- package/build/component/driver/apiKey/error/apiKeyFailedToGetDomain.js.map +1 -1
- package/build/component/driver/apiKey/error/apiKeyNameTooLong.js +2 -2
- package/build/component/driver/apiKey/error/apiKeyNameTooLong.js.map +1 -1
- package/build/component/driver/apiKey/update.d.ts +1 -1
- package/build/component/driver/apiKey/update.d.ts.map +1 -1
- package/build/component/driver/apiKey/update.js +27 -27
- package/build/component/driver/apiKey/update.js.map +1 -1
- package/build/component/driver/apiKey/utility/constants.d.ts +1 -1
- package/build/component/driver/apiKey/utility/constants.js +1 -1
- package/build/component/driver/apiKey/utility/utility.js +2 -2
- package/build/component/driver/apiKey/utility/utility.js.map +1 -1
- package/build/component/driver/arm/deploy.js +4 -4
- package/build/component/driver/arm/deploy.js.map +1 -1
- package/build/component/driver/arm/deployImpl.d.ts.map +1 -1
- package/build/component/driver/arm/deployImpl.js +18 -20
- package/build/component/driver/arm/deployImpl.js.map +1 -1
- package/build/component/driver/arm/util/bicepChecker.d.ts.map +1 -1
- package/build/component/driver/arm/util/bicepChecker.js +9 -29
- package/build/component/driver/arm/util/bicepChecker.js.map +1 -1
- package/build/component/driver/arm/util/handleError.js +10 -10
- package/build/component/driver/arm/util/handleError.js.map +1 -1
- package/build/component/driver/arm/validator.js +3 -3
- package/build/component/driver/arm/validator.js.map +1 -1
- package/build/component/driver/botAadApp/create.d.ts.map +1 -1
- package/build/component/driver/botAadApp/create.js +22 -38
- package/build/component/driver/botAadApp/create.js.map +1 -1
- package/build/component/driver/botAadApp/error/unexpectedEmptyBotPasswordError.js +2 -2
- package/build/component/driver/botAadApp/error/unexpectedEmptyBotPasswordError.js.map +1 -1
- package/build/component/driver/botAadApp/utility/constants.d.ts +0 -1
- package/build/component/driver/botAadApp/utility/constants.d.ts.map +1 -1
- package/build/component/driver/botAadApp/utility/constants.js +0 -1
- package/build/component/driver/botAadApp/utility/constants.js.map +1 -1
- package/build/component/driver/botFramework/createOrUpdateBot.js +14 -14
- package/build/component/driver/botFramework/createOrUpdateBot.js.map +1 -1
- package/build/component/driver/botFramework/error/invalidBotIdError.js +2 -2
- package/build/component/driver/botFramework/error/invalidBotIdError.js.map +1 -1
- package/build/component/driver/deploy/azure/azureAppServiceDeployDriver.js +3 -3
- package/build/component/driver/deploy/azure/azureAppServiceDeployDriver.js.map +1 -1
- package/build/component/driver/deploy/azure/azureFunctionDeployDriver.js +3 -3
- package/build/component/driver/deploy/azure/azureFunctionDeployDriver.js.map +1 -1
- package/build/component/driver/deploy/azure/azureStaticWebAppGetDeploymentTokenDriver.d.ts.map +1 -1
- package/build/component/driver/deploy/azure/azureStaticWebAppGetDeploymentTokenDriver.js +10 -16
- package/build/component/driver/deploy/azure/azureStaticWebAppGetDeploymentTokenDriver.js.map +1 -1
- package/build/component/driver/deploy/azure/azureStorageDeployDriver.js +9 -9
- package/build/component/driver/deploy/azure/azureStorageDeployDriver.js.map +1 -1
- package/build/component/driver/deploy/azure/azureStorageStaticWebsiteConfigDriver.js +15 -15
- package/build/component/driver/deploy/azure/azureStorageStaticWebsiteConfigDriver.js.map +1 -1
- package/build/component/driver/deploy/azure/impl/AzureZipDeployImpl.js +7 -7
- package/build/component/driver/deploy/azure/impl/AzureZipDeployImpl.js.map +1 -1
- package/build/component/driver/deploy/azure/impl/azureDeployImpl.d.ts +4 -4
- package/build/component/driver/deploy/azure/impl/azureDeployImpl.d.ts.map +1 -1
- package/build/component/driver/deploy/azure/impl/azureDeployImpl.js +20 -20
- package/build/component/driver/deploy/azure/impl/azureDeployImpl.js.map +1 -1
- package/build/component/driver/deploy/azure/impl/baseDeployImpl.js +11 -11
- package/build/component/driver/deploy/azure/impl/baseDeployImpl.js.map +1 -1
- package/build/component/driver/deploy/spfx/deployDriver.d.ts +1 -1
- package/build/component/driver/deploy/spfx/deployDriver.d.ts.map +1 -1
- package/build/component/driver/deploy/spfx/deployDriver.js +28 -29
- package/build/component/driver/deploy/spfx/deployDriver.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/createAppCatalogFailedError.js +2 -2
- package/build/component/driver/deploy/spfx/error/createAppCatalogFailedError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/getGraphTokenFailedError.js +2 -2
- package/build/component/driver/deploy/spfx/error/getGraphTokenFailedError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/getSPOTokenFailedError.js +2 -2
- package/build/component/driver/deploy/spfx/error/getSPOTokenFailedError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/getTenantFailedError.js +2 -2
- package/build/component/driver/deploy/spfx/error/getTenantFailedError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/insufficientPermissionError.js +2 -2
- package/build/component/driver/deploy/spfx/error/insufficientPermissionError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/noSPPackageError.js +2 -2
- package/build/component/driver/deploy/spfx/error/noSPPackageError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/noValidAppCatelogError.js +2 -2
- package/build/component/driver/deploy/spfx/error/noValidAppCatelogError.js.map +1 -1
- package/build/component/driver/deploy/spfx/error/uploadAppPackageFailedError.js +2 -2
- package/build/component/driver/deploy/spfx/error/uploadAppPackageFailedError.js.map +1 -1
- package/build/component/driver/deploy/spfx/utility/constants.js +5 -5
- package/build/component/driver/deploy/spfx/utility/constants.js.map +1 -1
- package/build/component/driver/devTool/constant.d.ts +8 -8
- package/build/component/driver/devTool/constant.d.ts.map +1 -1
- package/build/component/driver/devTool/constant.js +10 -10
- package/build/component/driver/devTool/constant.js.map +1 -1
- package/build/component/driver/devTool/error/dotnetInstallationUserError.js +4 -4
- package/build/component/driver/devTool/error/dotnetInstallationUserError.js.map +1 -1
- package/build/component/driver/devTool/error/funcInstallationUserError.js +4 -4
- package/build/component/driver/devTool/error/funcInstallationUserError.js.map +1 -1
- package/build/component/driver/devTool/error/testToolInstallationUserError.js +4 -4
- package/build/component/driver/devTool/error/testToolInstallationUserError.js.map +1 -1
- package/build/component/driver/devTool/installDriver.d.ts +1 -1
- package/build/component/driver/devTool/installDriver.d.ts.map +1 -1
- package/build/component/driver/devTool/installDriver.js +12 -12
- package/build/component/driver/devTool/installDriver.js.map +1 -1
- package/build/component/driver/error/outputEnvironmentVariableUndefinedError.js +2 -2
- package/build/component/driver/error/outputEnvironmentVariableUndefinedError.js.map +1 -1
- package/build/component/driver/file/createOrUpdateEnvironmentFile.js +11 -11
- package/build/component/driver/file/createOrUpdateEnvironmentFile.js.map +1 -1
- package/build/component/driver/file/createOrUpdateJsonFile.js +12 -12
- package/build/component/driver/file/createOrUpdateJsonFile.js.map +1 -1
- package/build/component/driver/index.d.ts +0 -1
- package/build/component/driver/index.d.ts.map +1 -1
- package/build/component/driver/index.js +0 -1
- package/build/component/driver/index.js.map +1 -1
- package/build/component/driver/m365/acquire.js +16 -16
- package/build/component/driver/m365/acquire.js.map +1 -1
- package/build/component/driver/middleware/addSWADeployTelemetry.js +7 -7
- package/build/component/driver/middleware/addSWADeployTelemetry.js.map +1 -1
- package/build/component/driver/middleware/addStartAndEndTelemetry.d.ts.map +1 -1
- package/build/component/driver/middleware/addStartAndEndTelemetry.js +3 -3
- package/build/component/driver/middleware/addStartAndEndTelemetry.js.map +1 -1
- package/build/component/driver/oauth/create.d.ts +1 -1
- package/build/component/driver/oauth/create.d.ts.map +1 -1
- package/build/component/driver/oauth/create.js +36 -65
- package/build/component/driver/oauth/create.js.map +1 -1
- package/build/component/driver/oauth/error/oauthAuthInfoInvalid.js +2 -2
- package/build/component/driver/oauth/error/oauthAuthInfoInvalid.js.map +1 -1
- package/build/component/driver/oauth/error/oauthDomainInvalid.js +2 -2
- package/build/component/driver/oauth/error/oauthDomainInvalid.js.map +1 -1
- package/build/component/driver/oauth/error/oauthFailedToGetDomain.js +2 -2
- package/build/component/driver/oauth/error/oauthFailedToGetDomain.js.map +1 -1
- package/build/component/driver/oauth/error/oauthNameTooLong.js +2 -2
- package/build/component/driver/oauth/error/oauthNameTooLong.js.map +1 -1
- package/build/component/driver/oauth/interface/createOauthArgs.d.ts +0 -2
- package/build/component/driver/oauth/interface/createOauthArgs.d.ts.map +1 -1
- package/build/component/driver/oauth/interface/updateOauthArgs.d.ts +0 -1
- package/build/component/driver/oauth/interface/updateOauthArgs.d.ts.map +1 -1
- package/build/component/driver/oauth/update.d.ts +1 -1
- package/build/component/driver/oauth/update.d.ts.map +1 -1
- package/build/component/driver/oauth/update.js +26 -37
- package/build/component/driver/oauth/update.js.map +1 -1
- package/build/component/driver/oauth/utility/constants.d.ts +1 -1
- package/build/component/driver/oauth/utility/constants.js +1 -1
- package/build/component/driver/oauth/utility/utility.js +6 -5
- package/build/component/driver/oauth/utility/utility.js.map +1 -1
- package/build/component/driver/script/baseBuildDriver.js +8 -8
- package/build/component/driver/script/baseBuildDriver.js.map +1 -1
- package/build/component/driver/script/dotnetBuildDriver.js +3 -3
- package/build/component/driver/script/dotnetBuildDriver.js.map +1 -1
- package/build/component/driver/script/npmBuildDriver.js +3 -3
- package/build/component/driver/script/npmBuildDriver.js.map +1 -1
- package/build/component/driver/script/npxBuildDriver.js +5 -5
- package/build/component/driver/script/npxBuildDriver.js.map +1 -1
- package/build/component/driver/script/scriptDriver.d.ts +0 -2
- package/build/component/driver/script/scriptDriver.d.ts.map +1 -1
- package/build/component/driver/script/scriptDriver.js +29 -28
- package/build/component/driver/script/scriptDriver.js.map +1 -1
- package/build/component/driver/teamsApp/appStudio.d.ts +1 -1
- package/build/component/driver/teamsApp/appStudio.d.ts.map +1 -1
- package/build/component/driver/teamsApp/appStudio.js +74 -63
- package/build/component/driver/teamsApp/appStudio.js.map +1 -1
- package/build/component/driver/teamsApp/clients/appStudioClient.d.ts +4 -7
- package/build/component/driver/teamsApp/clients/appStudioClient.d.ts.map +1 -1
- package/build/component/driver/teamsApp/clients/appStudioClient.js +77 -78
- package/build/component/driver/teamsApp/clients/appStudioClient.js.map +1 -1
- package/build/component/driver/teamsApp/configure.d.ts +1 -1
- package/build/component/driver/teamsApp/configure.d.ts.map +1 -1
- package/build/component/driver/teamsApp/configure.js +32 -32
- package/build/component/driver/teamsApp/configure.js.map +1 -1
- package/build/component/driver/teamsApp/constants.d.ts +3 -15
- package/build/component/driver/teamsApp/constants.d.ts.map +1 -1
- package/build/component/driver/teamsApp/constants.js +16 -136
- package/build/component/driver/teamsApp/constants.js.map +1 -1
- package/build/component/driver/teamsApp/copyAppPackageToSPFx.js +8 -8
- package/build/component/driver/teamsApp/copyAppPackageToSPFx.js.map +1 -1
- package/build/component/driver/teamsApp/create.d.ts +2 -2
- package/build/component/driver/teamsApp/create.d.ts.map +1 -1
- package/build/component/driver/teamsApp/create.js +37 -37
- package/build/component/driver/teamsApp/create.js.map +1 -1
- package/build/component/driver/teamsApp/createAppPackage.d.ts +1 -3
- package/build/component/driver/teamsApp/createAppPackage.d.ts.map +1 -1
- package/build/component/driver/teamsApp/createAppPackage.js +68 -84
- package/build/component/driver/teamsApp/createAppPackage.js.map +1 -1
- package/build/component/driver/teamsApp/errors.d.ts +2 -6
- package/build/component/driver/teamsApp/errors.d.ts.map +1 -1
- package/build/component/driver/teamsApp/errors.js +42 -49
- package/build/component/driver/teamsApp/errors.js.map +1 -1
- package/build/component/driver/teamsApp/interfaces/CreateAppPackageArgs.d.ts +2 -6
- package/build/component/driver/teamsApp/interfaces/CreateAppPackageArgs.d.ts.map +1 -1
- package/build/component/driver/teamsApp/interfaces/OauthRegistration.d.ts +0 -2
- package/build/component/driver/teamsApp/interfaces/OauthRegistration.d.ts.map +1 -1
- package/build/component/driver/teamsApp/interfaces/OauthRegistration.js.map +1 -1
- package/build/component/driver/teamsApp/interfaces/appdefinitions/IValidationResult.d.ts +0 -1
- package/build/component/driver/teamsApp/interfaces/appdefinitions/IValidationResult.d.ts.map +1 -1
- package/build/component/driver/teamsApp/publishAppPackage.d.ts +1 -1
- package/build/component/driver/teamsApp/publishAppPackage.d.ts.map +1 -1
- package/build/component/driver/teamsApp/publishAppPackage.js +42 -42
- package/build/component/driver/teamsApp/publishAppPackage.js.map +1 -1
- package/build/component/driver/teamsApp/teamsappMgr.d.ts.map +1 -1
- package/build/component/driver/teamsApp/teamsappMgr.js +49 -48
- package/build/component/driver/teamsApp/teamsappMgr.js.map +1 -1
- package/build/component/driver/teamsApp/utils/CopilotGptManifestUtils.d.ts +3 -5
- package/build/component/driver/teamsApp/utils/CopilotGptManifestUtils.d.ts.map +1 -1
- package/build/component/driver/teamsApp/utils/CopilotGptManifestUtils.js +41 -72
- package/build/component/driver/teamsApp/utils/CopilotGptManifestUtils.js.map +1 -1
- package/build/component/driver/teamsApp/utils/ManifestUtils.d.ts +2 -3
- package/build/component/driver/teamsApp/utils/ManifestUtils.d.ts.map +1 -1
- package/build/component/driver/teamsApp/utils/ManifestUtils.js +61 -85
- package/build/component/driver/teamsApp/utils/ManifestUtils.js.map +1 -1
- package/build/component/driver/teamsApp/utils/PluginManifestUtils.d.ts +3 -4
- package/build/component/driver/teamsApp/utils/PluginManifestUtils.d.ts.map +1 -1
- package/build/component/driver/teamsApp/utils/PluginManifestUtils.js +18 -36
- package/build/component/driver/teamsApp/utils/PluginManifestUtils.js.map +1 -1
- package/build/component/driver/teamsApp/utils/telemetry.d.ts +9 -0
- package/build/component/driver/teamsApp/utils/telemetry.d.ts.map +1 -1
- package/build/component/driver/teamsApp/utils/telemetry.js +9 -0
- package/build/component/driver/teamsApp/utils/telemetry.js.map +1 -1
- package/build/component/driver/teamsApp/utils/utils.d.ts +4 -4
- package/build/component/driver/teamsApp/utils/utils.d.ts.map +1 -1
- package/build/component/driver/teamsApp/utils/utils.js +15 -45
- package/build/component/driver/teamsApp/utils/utils.js.map +1 -1
- package/build/component/driver/teamsApp/validate.js +27 -27
- package/build/component/driver/teamsApp/validate.js.map +1 -1
- package/build/component/driver/teamsApp/validateAppPackage.d.ts +5 -3
- package/build/component/driver/teamsApp/validateAppPackage.d.ts.map +1 -1
- package/build/component/driver/teamsApp/validateAppPackage.js +54 -68
- package/build/component/driver/teamsApp/validateAppPackage.js.map +1 -1
- package/build/component/driver/teamsApp/validateTestCases.d.ts +3 -3
- package/build/component/driver/teamsApp/validateTestCases.d.ts.map +1 -1
- package/build/component/driver/teamsApp/validateTestCases.js +49 -50
- package/build/component/driver/teamsApp/validateTestCases.js.map +1 -1
- package/build/component/driver/util/utils.d.ts +0 -3
- package/build/component/driver/util/utils.d.ts.map +1 -1
- package/build/component/driver/util/utils.js +1 -16
- package/build/component/driver/util/utils.js.map +1 -1
- package/build/component/driver/util/wrapUtil.d.ts.map +1 -1
- package/build/component/driver/util/wrapUtil.js +9 -12
- package/build/component/driver/util/wrapUtil.js.map +1 -1
- package/build/component/error/componentError.js +8 -8
- package/build/component/error/componentError.js.map +1 -1
- package/build/component/feature/collaboration.d.ts.map +1 -1
- package/build/component/feature/collaboration.js +59 -60
- package/build/component/feature/collaboration.js.map +1 -1
- package/build/component/feature/createAuthFiles.js +8 -8
- package/build/component/feature/createAuthFiles.js.map +1 -1
- package/build/component/feature/sso.js +6 -7
- package/build/component/feature/sso.js.map +1 -1
- package/build/component/generator/constant.d.ts +0 -1
- package/build/component/generator/constant.d.ts.map +1 -1
- package/build/component/generator/constant.js +1 -2
- package/build/component/generator/constant.js.map +1 -1
- package/build/component/generator/copilotPlugin/generator.d.ts +13 -0
- package/build/component/generator/copilotPlugin/generator.d.ts.map +1 -0
- package/build/component/generator/copilotPlugin/generator.js +275 -0
- package/build/component/generator/copilotPlugin/generator.js.map +1 -0
- package/build/component/generator/copilotPlugin/helper.d.ts +45 -0
- package/build/component/generator/copilotPlugin/helper.d.ts.map +1 -0
- package/build/component/generator/copilotPlugin/helper.js +710 -0
- package/build/component/generator/copilotPlugin/helper.js.map +1 -0
- package/build/component/generator/error.d.ts +1 -1
- package/build/component/generator/error.d.ts.map +1 -1
- package/build/component/generator/error.js +5 -5
- package/build/component/generator/error.js.map +1 -1
- package/build/component/generator/generator.d.ts.map +1 -1
- package/build/component/generator/generator.js +21 -27
- package/build/component/generator/generator.js.map +1 -1
- package/build/component/generator/generatorAction.d.ts +1 -1
- package/build/component/generator/generatorAction.d.ts.map +1 -1
- package/build/component/generator/generatorAction.js +22 -14
- package/build/component/generator/generatorAction.js.map +1 -1
- package/build/component/generator/generatorProvider.d.ts.map +1 -1
- package/build/component/generator/generatorProvider.js +2 -6
- package/build/component/generator/generatorProvider.js.map +1 -1
- package/build/component/generator/officeAddin/generator.d.ts +1 -0
- package/build/component/generator/officeAddin/generator.d.ts.map +1 -1
- package/build/component/generator/officeAddin/generator.js +73 -72
- package/build/component/generator/officeAddin/generator.js.map +1 -1
- package/build/component/generator/officeAddin/helperMethods.d.ts +0 -5
- package/build/component/generator/officeAddin/helperMethods.d.ts.map +1 -1
- package/build/component/generator/officeAddin/helperMethods.js +0 -37
- package/build/component/generator/officeAddin/helperMethods.js.map +1 -1
- package/build/component/generator/officeXMLAddin/generator.d.ts +13 -0
- package/build/component/generator/officeXMLAddin/generator.d.ts.map +1 -0
- package/build/component/generator/officeXMLAddin/generator.js +110 -0
- package/build/component/generator/officeXMLAddin/generator.js.map +1 -0
- package/build/component/generator/officeXMLAddin/projectConfig.d.ts +4 -2
- package/build/component/generator/officeXMLAddin/projectConfig.d.ts.map +1 -1
- package/build/component/generator/officeXMLAddin/projectConfig.js +86 -1
- package/build/component/generator/officeXMLAddin/projectConfig.js.map +1 -1
- package/build/component/generator/spfx/depsChecker/generatorChecker.d.ts.map +1 -1
- package/build/component/generator/spfx/depsChecker/generatorChecker.js +10 -11
- package/build/component/generator/spfx/depsChecker/generatorChecker.js.map +1 -1
- package/build/component/generator/spfx/depsChecker/yoChecker.d.ts.map +1 -1
- package/build/component/generator/spfx/depsChecker/yoChecker.js +6 -7
- package/build/component/generator/spfx/depsChecker/yoChecker.js.map +1 -1
- package/build/component/generator/spfx/error.d.ts +1 -0
- package/build/component/generator/spfx/error.d.ts.map +1 -1
- package/build/component/generator/spfx/error.js +24 -20
- package/build/component/generator/spfx/error.js.map +1 -1
- package/build/component/generator/spfx/spfxGenerator.d.ts +2 -2
- package/build/component/generator/spfx/spfxGenerator.d.ts.map +1 -1
- package/build/component/generator/spfx/spfxGenerator.js +105 -102
- package/build/component/generator/spfx/spfxGenerator.js.map +1 -1
- package/build/component/generator/spfx/utils/constants.d.ts +13 -0
- package/build/component/generator/spfx/utils/constants.d.ts.map +1 -1
- package/build/component/generator/spfx/utils/constants.js +24 -9
- package/build/component/generator/spfx/utils/constants.js.map +1 -1
- package/build/component/generator/spfx/utils/telemetry-helper.d.ts.map +1 -1
- package/build/component/generator/spfx/utils/telemetry-helper.js +9 -11
- package/build/component/generator/spfx/utils/telemetry-helper.js.map +1 -1
- package/build/component/generator/spfx/utils/utils.d.ts +1 -1
- package/build/component/generator/spfx/utils/utils.d.ts.map +1 -1
- package/build/component/generator/spfx/utils/utils.js +3 -3
- package/build/component/generator/spfx/utils/utils.js.map +1 -1
- package/build/component/generator/templates/ssrTabGenerator.d.ts.map +1 -1
- package/build/component/generator/templates/ssrTabGenerator.js +6 -6
- package/build/component/generator/templates/ssrTabGenerator.js.map +1 -1
- package/build/component/generator/templates/templateGenerator.d.ts +3 -3
- package/build/component/generator/templates/templateGenerator.d.ts.map +1 -1
- package/build/component/generator/templates/templateGenerator.js +18 -16
- package/build/component/generator/templates/templateGenerator.js.map +1 -1
- package/build/component/generator/templates/templateNames.d.ts +0 -3
- package/build/component/generator/templates/templateNames.d.ts.map +1 -1
- package/build/component/generator/templates/templateNames.js +112 -109
- package/build/component/generator/templates/templateNames.js.map +1 -1
- package/build/component/generator/templates/templateReplaceMap.d.ts.map +1 -1
- package/build/component/generator/templates/templateReplaceMap.js +15 -48
- package/build/component/generator/templates/templateReplaceMap.js.map +1 -1
- package/build/component/generator/utils.d.ts +12 -4
- package/build/component/generator/utils.d.ts.map +1 -1
- package/build/component/generator/utils.js +80 -49
- package/build/component/generator/utils.js.map +1 -1
- package/build/component/messages.js +7 -7
- package/build/component/messages.js.map +1 -1
- package/build/component/middleware/actionExecutionMW.d.ts +1 -1
- package/build/component/middleware/actionExecutionMW.d.ts.map +1 -1
- package/build/component/middleware/actionExecutionMW.js +13 -13
- package/build/component/middleware/actionExecutionMW.js.map +1 -1
- package/build/component/middleware/envMW.js +9 -9
- package/build/component/middleware/envMW.js.map +1 -1
- package/build/component/middleware/questionMW.js +4 -4
- package/build/component/middleware/questionMW.js.map +1 -1
- package/build/component/migrate.d.ts +0 -32
- package/build/component/migrate.d.ts.map +1 -1
- package/build/component/migrate.js +35 -112
- package/build/component/migrate.js.map +1 -1
- package/build/component/provisionUtils.d.ts.map +1 -1
- package/build/component/provisionUtils.js +29 -28
- package/build/component/provisionUtils.js.map +1 -1
- package/build/component/resource/botService/appStudio/appStudioClient.d.ts.map +1 -1
- package/build/component/resource/botService/appStudio/appStudioClient.js +22 -23
- package/build/component/resource/botService/appStudio/appStudioClient.js.map +1 -1
- package/build/component/resource/botService/botRegistration/botFrameworkRegistration.d.ts +1 -1
- package/build/component/resource/botService/botRegistration/botFrameworkRegistration.d.ts.map +1 -1
- package/build/component/resource/botService/botRegistration/botFrameworkRegistration.js +8 -11
- package/build/component/resource/botService/botRegistration/botFrameworkRegistration.js.map +1 -1
- package/build/component/resource/botService/constants.d.ts +13 -0
- package/build/component/resource/botService/constants.d.ts.map +1 -1
- package/build/component/resource/botService/constants.js +15 -1
- package/build/component/resource/botService/constants.js.map +1 -1
- package/build/component/resource/botService/errors.js +2 -2
- package/build/component/resource/botService/errors.js.map +1 -1
- package/build/component/resource/botService/messages.js +6 -6
- package/build/component/resource/botService/messages.js.map +1 -1
- package/build/component/resource/botService/strings.js +1 -1
- package/build/component/resource/botService/strings.js.map +1 -1
- package/build/component/telemetry.d.ts.map +1 -1
- package/build/component/telemetry.js +7 -6
- package/build/component/telemetry.js.map +1 -1
- package/build/component/utils/ResourceGroupHelper.d.ts +2 -10
- package/build/component/utils/ResourceGroupHelper.d.ts.map +1 -1
- package/build/component/utils/ResourceGroupHelper.js +62 -155
- package/build/component/utils/ResourceGroupHelper.js.map +1 -1
- package/build/component/utils/azureResourceOperation.js +2 -2
- package/build/component/utils/azureResourceOperation.js.map +1 -1
- package/build/component/utils/charsetUtils.d.ts +1 -1
- package/build/component/utils/charsetUtils.d.ts.map +1 -1
- package/build/component/utils/charsetUtils.js +1 -3
- package/build/component/utils/charsetUtils.js.map +1 -1
- package/build/component/utils/common.d.ts +3 -4
- package/build/component/utils/common.d.ts.map +1 -1
- package/build/component/utils/common.js +6 -17
- package/build/component/utils/common.js.map +1 -1
- package/build/component/utils/depsChecker/common.d.ts +3 -1
- package/build/component/utils/depsChecker/common.d.ts.map +1 -1
- package/build/component/utils/depsChecker/common.js +4 -2
- package/build/component/utils/depsChecker/common.js.map +1 -1
- package/build/component/utils/envUtil.d.ts +0 -1
- package/build/component/utils/envUtil.d.ts.map +1 -1
- package/build/component/utils/envUtil.js +20 -20
- package/build/component/utils/envUtil.js.map +1 -1
- package/build/component/utils/fileOperation.js +4 -3
- package/build/component/utils/fileOperation.js.map +1 -1
- package/build/component/utils/metadataGraphPermssion.js +3 -3
- package/build/component/utils/metadataGraphPermssion.js.map +1 -1
- package/build/component/utils/metadataUtil.js +3 -3
- package/build/component/utils/metadataUtil.js.map +1 -1
- package/build/component/utils/pathUtils.d.ts.map +1 -1
- package/build/component/utils/pathUtils.js +16 -14
- package/build/component/utils/pathUtils.js.map +1 -1
- package/build/component/utils/settingsUtil.js +8 -8
- package/build/component/utils/settingsUtil.js.map +1 -1
- package/build/component/utils/teamsFxTelemetryReporter.d.ts.map +1 -1
- package/build/component/utils/teamsFxTelemetryReporter.js +10 -7
- package/build/component/utils/teamsFxTelemetryReporter.js.map +1 -1
- package/build/component/utils.d.ts +12 -0
- package/build/component/utils.d.ts.map +1 -0
- package/build/component/utils.js +136 -0
- package/build/component/utils.js.map +1 -0
- package/build/component/workflow.d.ts +4 -0
- package/build/component/workflow.d.ts.map +1 -0
- package/build/component/workflow.js +18 -0
- package/build/component/workflow.js.map +1 -0
- package/build/core/FxCore.d.ts +4 -37
- package/build/core/FxCore.d.ts.map +1 -1
- package/build/core/FxCore.js +477 -750
- package/build/core/FxCore.js.map +1 -1
- package/build/core/callback.d.ts +2 -2
- package/build/core/callback.d.ts.map +1 -1
- package/build/core/callback.js.map +1 -1
- package/build/core/collaborator.d.ts.map +1 -1
- package/build/core/collaborator.js +72 -70
- package/build/core/collaborator.js.map +1 -1
- package/build/core/crypto.d.ts.map +1 -1
- package/build/core/crypto.js +5 -4
- package/build/core/crypto.js.map +1 -1
- package/build/core/environment.js +7 -7
- package/build/core/environment.js.map +1 -1
- package/build/core/environmentName.d.ts +1 -0
- package/build/core/environmentName.d.ts.map +1 -1
- package/build/core/environmentName.js +2 -0
- package/build/core/environmentName.js.map +1 -1
- package/build/core/error.d.ts +32 -0
- package/build/core/error.d.ts.map +1 -0
- package/build/core/error.js +122 -0
- package/build/core/error.js.map +1 -0
- package/build/{common → core}/globalVars.d.ts +1 -3
- package/build/core/globalVars.d.ts.map +1 -0
- package/build/{common → core}/globalVars.js +1 -12
- package/build/core/globalVars.js.map +1 -0
- package/build/core/middleware/concurrentLocker.d.ts.map +1 -1
- package/build/core/middleware/concurrentLocker.js +20 -19
- package/build/core/middleware/concurrentLocker.js.map +1 -1
- package/build/core/middleware/errorHandler.js +5 -5
- package/build/core/middleware/errorHandler.js.map +1 -1
- package/build/core/middleware/projectMigratorV3.d.ts +1 -5
- package/build/core/middleware/projectMigratorV3.d.ts.map +1 -1
- package/build/core/middleware/projectMigratorV3.js +100 -104
- package/build/core/middleware/projectMigratorV3.js.map +1 -1
- package/build/core/middleware/projectSettingsLoader.js +4 -4
- package/build/core/middleware/projectSettingsLoader.js.map +1 -1
- package/build/core/middleware/projectVersionChecker.js +14 -14
- package/build/core/middleware/projectVersionChecker.js.map +1 -1
- package/build/core/middleware/utils/MigrationUtils.js +5 -5
- package/build/core/middleware/utils/MigrationUtils.js.map +1 -1
- package/build/core/middleware/utils/appYmlGenerator.d.ts +0 -1
- package/build/core/middleware/utils/appYmlGenerator.d.ts.map +1 -1
- package/build/core/middleware/utils/appYmlGenerator.js +9 -15
- package/build/core/middleware/utils/appYmlGenerator.js.map +1 -1
- package/build/core/middleware/utils/debug/debugV3MigrationUtils.js +10 -10
- package/build/core/middleware/utils/debug/debugV3MigrationUtils.js.map +1 -1
- package/build/core/middleware/utils/debug/taskMigrator.js +74 -74
- package/build/core/middleware/utils/debug/taskMigrator.js.map +1 -1
- package/build/core/middleware/utils/migrationContext.js +1 -1
- package/build/core/middleware/utils/migrationContext.js.map +1 -1
- package/build/core/middleware/utils/v3MigrationUtils.js +13 -13
- package/build/core/middleware/utils/v3MigrationUtils.js.map +1 -1
- package/build/core/middleware/videoFilterAppBlocker.d.ts +0 -2
- package/build/core/middleware/videoFilterAppBlocker.d.ts.map +1 -1
- package/build/core/middleware/videoFilterAppBlocker.js +5 -21
- package/build/core/middleware/videoFilterAppBlocker.js.map +1 -1
- package/build/core/telemetry.d.ts +5 -0
- package/build/core/telemetry.d.ts.map +1 -1
- package/build/core/telemetry.js +17 -9
- package/build/core/telemetry.js.map +1 -1
- package/build/error/arm.js +10 -10
- package/build/error/arm.js.map +1 -1
- package/build/error/azure.js +20 -20
- package/build/error/azure.js.map +1 -1
- package/build/error/common.d.ts +1 -36
- package/build/error/common.d.ts.map +1 -1
- package/build/error/common.js +64 -175
- package/build/error/common.js.map +1 -1
- package/build/error/deploy.js +24 -24
- package/build/error/deploy.js.map +1 -1
- package/build/error/m365.js +6 -6
- package/build/error/m365.js.map +1 -1
- package/build/error/script.d.ts +2 -2
- package/build/error/script.d.ts.map +1 -1
- package/build/error/script.js +8 -14
- package/build/error/script.js.map +1 -1
- package/build/error/teamsApp.d.ts +0 -3
- package/build/error/teamsApp.d.ts.map +1 -1
- package/build/error/teamsApp.js +7 -20
- package/build/error/teamsApp.js.map +1 -1
- package/build/error/upgrade.js +2 -2
- package/build/error/upgrade.js.map +1 -1
- package/build/error/yml.js +13 -13
- package/build/error/yml.js.map +1 -1
- package/build/failpoint/index.d.ts +3 -0
- package/build/failpoint/index.d.ts.map +1 -0
- package/build/failpoint/index.js +11 -0
- package/build/failpoint/index.js.map +1 -0
- package/build/failpoint/marker.d.ts +13 -0
- package/build/failpoint/marker.d.ts.map +1 -0
- package/build/{question/inputs/SyncManifestInputs.js → failpoint/marker.js} +4 -1
- package/build/failpoint/marker.js.map +1 -0
- package/build/failpoint/runtime.d.ts +12 -0
- package/build/failpoint/runtime.d.ts.map +1 -0
- package/build/failpoint/runtime.js +67 -0
- package/build/failpoint/runtime.js.map +1 -0
- package/build/index.d.ts +36 -61
- package/build/index.d.ts.map +1 -1
- package/build/index.js +53 -132
- package/build/index.js.map +1 -1
- package/build/question/constants.d.ts +5 -269
- package/build/question/constants.d.ts.map +1 -1
- package/build/question/constants.js +13 -1107
- package/build/question/constants.js.map +1 -1
- package/build/question/create.d.ts +151 -13
- package/build/question/create.d.ts.map +1 -1
- package/build/question/create.js +1386 -542
- package/build/question/create.js.map +1 -1
- package/build/question/generator.js +2 -6
- package/build/question/generator.js.map +1 -1
- package/build/question/index.d.ts +3 -3
- package/build/question/index.d.ts.map +1 -1
- package/build/question/index.js +21 -23
- package/build/question/index.js.map +1 -1
- package/build/question/inputs/AddPluginInputs.d.ts +4 -8
- package/build/question/inputs/AddPluginInputs.d.ts.map +1 -1
- package/build/question/inputs/CreateProjectInputs.d.ts +8 -14
- package/build/question/inputs/CreateProjectInputs.d.ts.map +1 -1
- package/build/question/inputs/index.d.ts +0 -2
- package/build/question/inputs/index.d.ts.map +1 -1
- package/build/question/inputs/index.js +0 -2
- package/build/question/inputs/index.js.map +1 -1
- package/build/question/options/AddPluginOptions.d.ts.map +1 -1
- package/build/question/options/AddPluginOptions.js +10 -19
- package/build/question/options/AddPluginOptions.js.map +1 -1
- package/build/question/options/CreateProjectOptions.d.ts.map +1 -1
- package/build/question/options/CreateProjectOptions.js +33 -36
- package/build/question/options/CreateProjectOptions.js.map +1 -1
- package/build/question/options/index.d.ts +0 -2
- package/build/question/options/index.d.ts.map +1 -1
- package/build/question/options/index.js +0 -2
- package/build/question/options/index.js.map +1 -1
- package/build/question/other.d.ts +29 -4
- package/build/question/other.d.ts.map +1 -1
- package/build/question/other.js +343 -284
- package/build/question/other.js.map +1 -1
- package/build/question/questionNames.d.ts +78 -0
- package/build/question/questionNames.d.ts.map +1 -0
- package/build/question/questionNames.js +85 -0
- package/build/question/questionNames.js.map +1 -0
- package/build/question/util.d.ts +2 -0
- package/build/question/util.d.ts.map +1 -0
- package/build/question/util.js +18 -0
- package/build/question/util.js.map +1 -0
- package/build/ui/visitor.d.ts +1 -0
- package/build/ui/visitor.d.ts.map +1 -1
- package/build/ui/visitor.js +38 -57
- package/build/ui/visitor.js.map +1 -1
- package/package.json +14 -21
- package/resource/deps-checker/dotnet-install.ps1 +423 -912
- package/resource/deps-checker/dotnet-install.sh +238 -876
- package/resource/package.nls.json +156 -189
- package/resource/yaml-schema/yaml.schema.json +1 -59
- package/templates/core/v3Migration/js.ts.app.local.yml +3 -3
- package/templates/fallback/common.zip +0 -0
- package/templates/fallback/csharp.zip +0 -0
- package/templates/fallback/js.zip +0 -0
- package/templates/fallback/python.zip +0 -0
- package/templates/fallback/ts.zip +0 -0
- package/templates/plugins/resource/aad/auth/V3/aad.manifest.template.json +0 -6
- package/templates/plugins/resource/aad/manifest/aad.template.json +0 -6
- package/templates/plugins/resource/aad/manifest/bot/aad.manifest.template.json +0 -6
- package/templates/plugins/resource/aad/manifest/tab/aad.manifest.template.json +0 -6
- package/build/client/teamsDevPortalClient.d.ts +0 -128
- package/build/client/teamsDevPortalClient.d.ts.map +0 -1
- package/build/client/teamsDevPortalClient.js +0 -949
- package/build/client/teamsDevPortalClient.js.map +0 -1
- package/build/common/azureUtils.d.ts +0 -3
- package/build/common/azureUtils.d.ts.map +0 -1
- package/build/common/azureUtils.js +0 -50
- package/build/common/azureUtils.js.map +0 -1
- package/build/common/globalVars.d.ts.map +0 -1
- package/build/common/globalVars.js.map +0 -1
- package/build/common/requestUtils.d.ts +0 -4
- package/build/common/requestUtils.d.ts.map +0 -1
- package/build/common/requestUtils.js +0 -52
- package/build/common/requestUtils.js.map +0 -1
- package/build/common/secretmasker/dict.d.ts +0 -22
- package/build/common/secretmasker/dict.d.ts.map +0 -1
- package/build/common/secretmasker/dict.js +0 -83
- package/build/common/secretmasker/dict.js.map +0 -1
- package/build/common/secretmasker/feature.d.ts +0 -19
- package/build/common/secretmasker/feature.d.ts.map +0 -1
- package/build/common/secretmasker/feature.js +0 -389
- package/build/common/secretmasker/feature.js.map +0 -1
- package/build/common/secretmasker/masker.d.ts +0 -12
- package/build/common/secretmasker/masker.d.ts.map +0 -1
- package/build/common/secretmasker/masker.js +0 -54
- package/build/common/secretmasker/masker.js.map +0 -1
- package/build/component/deps-checker/checkerFactory.d.ts.map +0 -1
- package/build/component/deps-checker/checkerFactory.js.map +0 -1
- package/build/component/deps-checker/constant/helpLink.d.ts.map +0 -1
- package/build/component/deps-checker/constant/helpLink.js.map +0 -1
- package/build/component/deps-checker/constant/index.d.ts.map +0 -1
- package/build/component/deps-checker/constant/index.js.map +0 -1
- package/build/component/deps-checker/constant/message.d.ts.map +0 -1
- package/build/component/deps-checker/constant/message.js +0 -45
- package/build/component/deps-checker/constant/message.js.map +0 -1
- package/build/component/deps-checker/constant/telemetry.d.ts.map +0 -1
- package/build/component/deps-checker/constant/telemetry.js.map +0 -1
- package/build/component/deps-checker/coreDepsLoggerAdapter.d.ts.map +0 -1
- package/build/component/deps-checker/coreDepsLoggerAdapter.js.map +0 -1
- package/build/component/deps-checker/coreDepsTelemetryAdapter.d.ts.map +0 -1
- package/build/component/deps-checker/coreDepsTelemetryAdapter.js.map +0 -1
- package/build/component/deps-checker/depsChecker.d.ts.map +0 -1
- package/build/component/deps-checker/depsChecker.js.map +0 -1
- package/build/component/deps-checker/depsError.d.ts.map +0 -1
- package/build/component/deps-checker/depsError.js.map +0 -1
- package/build/component/deps-checker/depsLogger.d.ts.map +0 -1
- package/build/component/deps-checker/depsLogger.js.map +0 -1
- package/build/component/deps-checker/depsManager.d.ts.map +0 -1
- package/build/component/deps-checker/depsManager.js.map +0 -1
- package/build/component/deps-checker/depsTelemetry.d.ts.map +0 -1
- package/build/component/deps-checker/depsTelemetry.js.map +0 -1
- package/build/component/deps-checker/index.d.ts.map +0 -1
- package/build/component/deps-checker/index.js.map +0 -1
- package/build/component/deps-checker/internal/dotnetChecker.d.ts.map +0 -1
- package/build/component/deps-checker/internal/dotnetChecker.js.map +0 -1
- package/build/component/deps-checker/internal/funcToolChecker.d.ts.map +0 -1
- package/build/component/deps-checker/internal/funcToolChecker.js.map +0 -1
- package/build/component/deps-checker/internal/nodeChecker.d.ts.map +0 -1
- package/build/component/deps-checker/internal/nodeChecker.js.map +0 -1
- package/build/component/deps-checker/internal/testToolChecker.d.ts.map +0 -1
- package/build/component/deps-checker/internal/testToolChecker.js.map +0 -1
- package/build/component/deps-checker/internal/vxTestAppChecker.d.ts.map +0 -1
- package/build/component/deps-checker/internal/vxTestAppChecker.js.map +0 -1
- package/build/component/deps-checker/util/cpUtils.d.ts.map +0 -1
- package/build/component/deps-checker/util/cpUtils.js.map +0 -1
- package/build/component/deps-checker/util/downloadHelper.d.ts.map +0 -1
- package/build/component/deps-checker/util/downloadHelper.js.map +0 -1
- package/build/component/deps-checker/util/fileHelper.d.ts.map +0 -1
- package/build/component/deps-checker/util/fileHelper.js.map +0 -1
- package/build/component/deps-checker/util/index.d.ts.map +0 -1
- package/build/component/deps-checker/util/index.js.map +0 -1
- package/build/component/deps-checker/util/progressIndicator.d.ts.map +0 -1
- package/build/component/deps-checker/util/progressIndicator.js.map +0 -1
- package/build/component/deps-checker/util/system.d.ts.map +0 -1
- package/build/component/deps-checker/util/system.js.map +0 -1
- package/build/component/driver/aad/error/missingServiceManagamentReferenceError.d.ts +0 -5
- package/build/component/driver/aad/error/missingServiceManagamentReferenceError.d.ts.map +0 -1
- package/build/component/driver/aad/error/missingServiceManagamentReferenceError.js +0 -23
- package/build/component/driver/aad/error/missingServiceManagamentReferenceError.js.map +0 -1
- package/build/component/driver/apiKey/error/apiKeyFromScratchClientSecretInvalid.d.ts +0 -5
- package/build/component/driver/apiKey/error/apiKeyFromScratchClientSecretInvalid.d.ts.map +0 -1
- package/build/component/driver/apiKey/error/apiKeyFromScratchClientSecretInvalid.js +0 -21
- package/build/component/driver/apiKey/error/apiKeyFromScratchClientSecretInvalid.js.map +0 -1
- package/build/component/driver/oauth/error/oauthDisablePKCEError.d.ts +0 -5
- package/build/component/driver/oauth/error/oauthDisablePKCEError.d.ts.map +0 -1
- package/build/component/driver/oauth/error/oauthDisablePKCEError.js +0 -21
- package/build/component/driver/oauth/error/oauthDisablePKCEError.js.map +0 -1
- package/build/component/driver/oauth/error/oauthIdentityProviderInvalid.d.ts +0 -5
- package/build/component/driver/oauth/error/oauthIdentityProviderInvalid.d.ts.map +0 -1
- package/build/component/driver/oauth/error/oauthIdentityProviderInvalid.js +0 -21
- package/build/component/driver/oauth/error/oauthIdentityProviderInvalid.js.map +0 -1
- package/build/component/driver/teamsApp/interfaces/SyncManifest.d.ts +0 -20
- package/build/component/driver/teamsApp/interfaces/SyncManifest.d.ts.map +0 -1
- package/build/component/driver/teamsApp/interfaces/SyncManifest.js +0 -5
- package/build/component/driver/teamsApp/interfaces/SyncManifest.js.map +0 -1
- package/build/component/driver/teamsApp/syncManifest.d.ts +0 -14
- package/build/component/driver/teamsApp/syncManifest.d.ts.map +0 -1
- package/build/component/driver/teamsApp/syncManifest.js +0 -226
- package/build/component/driver/teamsApp/syncManifest.js.map +0 -1
- package/build/component/generator/apiSpec/generator.d.ts +0 -15
- package/build/component/generator/apiSpec/generator.d.ts.map +0 -1
- package/build/component/generator/apiSpec/generator.js +0 -274
- package/build/component/generator/apiSpec/generator.js.map +0 -1
- package/build/component/generator/apiSpec/helper.d.ts +0 -50
- package/build/component/generator/apiSpec/helper.d.ts.map +0 -1
- package/build/component/generator/apiSpec/helper.js +0 -834
- package/build/component/generator/apiSpec/helper.js.map +0 -1
- package/build/component/generator/copilotExtension/generator.d.ts +0 -19
- package/build/component/generator/copilotExtension/generator.d.ts.map +0 -1
- package/build/component/generator/copilotExtension/generator.js +0 -116
- package/build/component/generator/copilotExtension/generator.js.map +0 -1
- package/build/component/generator/copilotExtension/helper.d.ts +0 -8
- package/build/component/generator/copilotExtension/helper.d.ts.map +0 -1
- package/build/component/generator/copilotExtension/helper.js +0 -114
- package/build/component/generator/copilotExtension/helper.js.map +0 -1
- package/build/component/local/constants.d.ts +0 -186
- package/build/component/local/constants.d.ts.map +0 -1
- package/build/component/local/constants.js.map +0 -1
- package/build/component/local/index.d.ts.map +0 -1
- package/build/component/local/index.js.map +0 -1
- package/build/component/local/localCertificateManager.d.ts.map +0 -1
- package/build/component/local/localCertificateManager.js.map +0 -1
- package/build/component/local/localEnvManager.d.ts.map +0 -1
- package/build/component/local/localEnvManager.js.map +0 -1
- package/build/component/local/localTelemetryReporter.d.ts.map +0 -1
- package/build/component/local/localTelemetryReporter.js.map +0 -1
- package/build/component/local/npmLogHelper.d.ts.map +0 -1
- package/build/component/local/npmLogHelper.js.map +0 -1
- package/build/component/local/packageJsonHelper.d.ts.map +0 -1
- package/build/component/local/packageJsonHelper.js.map +0 -1
- package/build/component/local/portChecker.d.ts.map +0 -1
- package/build/component/local/portChecker.js.map +0 -1
- package/build/component/local/process.d.ts.map +0 -1
- package/build/component/local/process.js.map +0 -1
- package/build/component/local/taskDefinition.d.ts.map +0 -1
- package/build/component/local/taskDefinition.js.map +0 -1
- package/build/component/m365/constants.d.ts +0 -9
- package/build/component/m365/constants.d.ts.map +0 -1
- package/build/component/m365/constants.js.map +0 -1
- package/build/component/m365/errors.d.ts.map +0 -1
- package/build/component/m365/errors.js.map +0 -1
- package/build/component/m365/launchHelper.d.ts +0 -12
- package/build/component/m365/launchHelper.d.ts.map +0 -1
- package/build/component/m365/launchHelper.js.map +0 -1
- package/build/component/m365/packageService.d.ts.map +0 -1
- package/build/component/m365/packageService.js.map +0 -1
- package/build/component/m365/serviceConstant.d.ts +0 -3
- package/build/component/m365/serviceConstant.d.ts.map +0 -1
- package/build/component/m365/serviceConstant.js +0 -8
- package/build/component/m365/serviceConstant.js.map +0 -1
- package/build/component/utils/envFunctionUtils.d.ts +0 -12
- package/build/component/utils/envFunctionUtils.d.ts.map +0 -1
- package/build/component/utils/envFunctionUtils.js +0 -185
- package/build/component/utils/envFunctionUtils.js.map +0 -1
- package/build/question/inputs/SyncManifestInputs.d.ts +0 -16
- package/build/question/inputs/SyncManifestInputs.d.ts.map +0 -1
- package/build/question/inputs/SyncManifestInputs.js.map +0 -1
- package/build/question/inputs/UninstallInputs.d.ts +0 -22
- package/build/question/inputs/UninstallInputs.d.ts.map +0 -1
- package/build/question/inputs/UninstallInputs.js +0 -5
- package/build/question/inputs/UninstallInputs.js.map +0 -1
- package/build/question/options/SyncManifestOptions.d.ts +0 -10
- package/build/question/options/SyncManifestOptions.d.ts.map +0 -1
- package/build/question/options/SyncManifestOptions.js +0 -28
- package/build/question/options/SyncManifestOptions.js.map +0 -1
- package/build/question/options/UninstallOptions.d.ts +0 -10
- package/build/question/options/UninstallOptions.d.ts.map +0 -1
- package/build/question/options/UninstallOptions.js +0 -44
- package/build/question/options/UninstallOptions.js.map +0 -1
- package/build/tsconfig.tsbuildinfo +0 -1
- package/resource/dict.zip +0 -0
- package/resource/yaml-schema/v1.6/yaml.schema.json +0 -1842
- package/resource/yaml-schema/v1.7/yaml.schema.json +0 -1842
- /package/build/{component → common}/deps-checker/checkerFactory.d.ts +0 -0
- /package/build/{component → common}/deps-checker/checkerFactory.js +0 -0
- /package/build/{component → common}/deps-checker/constant/index.d.ts +0 -0
- /package/build/{component → common}/deps-checker/constant/index.js +0 -0
- /package/build/{component → common}/deps-checker/constant/message.d.ts +0 -0
- /package/build/{component → common}/deps-checker/constant/telemetry.d.ts +0 -0
- /package/build/{component → common}/deps-checker/constant/telemetry.js +0 -0
- /package/build/{component → common}/deps-checker/coreDepsLoggerAdapter.d.ts +0 -0
- /package/build/{component → common}/deps-checker/coreDepsLoggerAdapter.js +0 -0
- /package/build/{component → common}/deps-checker/coreDepsTelemetryAdapter.d.ts +0 -0
- /package/build/{component → common}/deps-checker/depsChecker.d.ts +0 -0
- /package/build/{component → common}/deps-checker/depsChecker.js +0 -0
- /package/build/{component → common}/deps-checker/depsError.d.ts +0 -0
- /package/build/{component → common}/deps-checker/depsError.js +0 -0
- /package/build/{component → common}/deps-checker/depsLogger.d.ts +0 -0
- /package/build/{component → common}/deps-checker/depsLogger.js +0 -0
- /package/build/{component → common}/deps-checker/depsManager.d.ts +0 -0
- /package/build/{component → common}/deps-checker/depsManager.js +0 -0
- /package/build/{component → common}/deps-checker/depsTelemetry.d.ts +0 -0
- /package/build/{component → common}/deps-checker/depsTelemetry.js +0 -0
- /package/build/{component → common}/deps-checker/index.d.ts +0 -0
- /package/build/{component → common}/deps-checker/index.js +0 -0
- /package/build/{component → common}/deps-checker/internal/dotnetChecker.d.ts +0 -0
- /package/build/{component → common}/deps-checker/internal/funcToolChecker.d.ts +0 -0
- /package/build/{component → common}/deps-checker/internal/nodeChecker.d.ts +0 -0
- /package/build/{component → common}/deps-checker/internal/nodeChecker.js +0 -0
- /package/build/{component → common}/deps-checker/internal/testToolChecker.d.ts +0 -0
- /package/build/{component → common}/deps-checker/internal/vxTestAppChecker.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/cpUtils.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/cpUtils.js +0 -0
- /package/build/{component → common}/deps-checker/util/downloadHelper.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/downloadHelper.js +0 -0
- /package/build/{component → common}/deps-checker/util/fileHelper.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/fileHelper.js +0 -0
- /package/build/{component → common}/deps-checker/util/index.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/index.js +0 -0
- /package/build/{component → common}/deps-checker/util/progressIndicator.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/progressIndicator.js +0 -0
- /package/build/{component → common}/deps-checker/util/system.d.ts +0 -0
- /package/build/{component → common}/deps-checker/util/system.js +0 -0
- /package/build/{component → common}/local/index.d.ts +0 -0
- /package/build/{component → common}/local/index.js +0 -0
- /package/build/{component → common}/local/localCertificateManager.d.ts +0 -0
- /package/build/{component → common}/local/localEnvManager.d.ts +0 -0
- /package/build/{component → common}/local/localTelemetryReporter.d.ts +0 -0
- /package/build/{component → common}/local/npmLogHelper.d.ts +0 -0
- /package/build/{component → common}/local/npmLogHelper.js +0 -0
- /package/build/{component → common}/local/packageJsonHelper.d.ts +0 -0
- /package/build/{component → common}/local/packageJsonHelper.js +0 -0
- /package/build/{component → common}/local/portChecker.d.ts +0 -0
- /package/build/{component → common}/local/process.d.ts +0 -0
- /package/build/{component → common}/local/process.js +0 -0
- /package/build/{component → common}/local/taskDefinition.d.ts +0 -0
- /package/build/{component → common}/m365/errors.d.ts +0 -0
- /package/build/{component → common}/m365/packageService.d.ts +0 -0
|
@@ -0,0 +1,710 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright (c) Microsoft Corporation.
|
|
3
|
+
// Licensed under the MIT license.
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.getEnvName = exports.updateForCustomApi = exports.formatValidationErrors = exports.isYamlSpecFile = exports.convertSpecParserErrorToFxError = exports.generateScaffoldingSummary = exports.logValidationResults = exports.listPluginExistingOperations = exports.listOperations = exports.OpenAIPluginManifestHelper = exports.defaultPluginManifestFileName = exports.defaultApiSpecJsonFileName = exports.defaultApiSpecYamlFileName = exports.defaultApiSpecFolderName = exports.invalidApiSpecErrorName = exports.specParserGenerateResultWarningsTelemetryProperty = exports.specParserGenerateResultAllSuccessTelemetryProperty = exports.specParserGenerateResultTelemetryEvent = exports.copilotPluginParserOptions = void 0;
|
|
6
|
+
const tslib_1 = require("tslib");
|
|
7
|
+
/**
|
|
8
|
+
* @author yuqzho@microsoft.com
|
|
9
|
+
*/
|
|
10
|
+
const teamsfx_api_1 = require("@microsoft/teamsfx-api");
|
|
11
|
+
const axios_1 = tslib_1.__importDefault(require("axios"));
|
|
12
|
+
const utils_1 = require("../utils");
|
|
13
|
+
const m365_spec_parser_1 = require("@microsoft/m365-spec-parser");
|
|
14
|
+
const fs_extra_1 = tslib_1.__importDefault(require("fs-extra"));
|
|
15
|
+
const localizeUtils_1 = require("../../../common/localizeUtils");
|
|
16
|
+
const error_1 = require("../../../error");
|
|
17
|
+
const os_1 = require("os");
|
|
18
|
+
const constant_1 = require("../../configManager/constant");
|
|
19
|
+
const ManifestUtils_1 = require("../../driver/teamsApp/utils/ManifestUtils");
|
|
20
|
+
const path_1 = tslib_1.__importDefault(require("path"));
|
|
21
|
+
const questionNames_1 = require("../../../question/questionNames");
|
|
22
|
+
const PluginManifestUtils_1 = require("../../driver/teamsApp/utils/PluginManifestUtils");
|
|
23
|
+
const constants_1 = require("../../../question/constants");
|
|
24
|
+
const question_1 = require("../../../question");
|
|
25
|
+
const featureFlags_1 = require("../../../common/featureFlags");
|
|
26
|
+
const manifestFilePath = "/.well-known/ai-plugin.json";
|
|
27
|
+
const componentName = "OpenAIPluginManifestHelper";
|
|
28
|
+
var OpenAIPluginManifestErrorType;
|
|
29
|
+
(function (OpenAIPluginManifestErrorType) {
|
|
30
|
+
OpenAIPluginManifestErrorType["AuthNotSupported"] = "openai-pliugin-auth-not-supported";
|
|
31
|
+
OpenAIPluginManifestErrorType["ApiUrlMissing"] = "openai-plugin-api-url-missing";
|
|
32
|
+
})(OpenAIPluginManifestErrorType || (OpenAIPluginManifestErrorType = {}));
|
|
33
|
+
exports.copilotPluginParserOptions = {
|
|
34
|
+
allowAPIKeyAuth: false,
|
|
35
|
+
allowBearerTokenAuth: featureFlags_1.isCopilotAuthEnabled(),
|
|
36
|
+
allowMultipleParameters: true,
|
|
37
|
+
allowOauth2: featureFlags_1.isCopilotAuthEnabled(),
|
|
38
|
+
projectType: m365_spec_parser_1.ProjectType.Copilot,
|
|
39
|
+
allowMissingId: true,
|
|
40
|
+
allowSwagger: true,
|
|
41
|
+
allowMethods: ["get", "post", "put", "delete", "patch", "head", "connect", "options", "trace"],
|
|
42
|
+
allowResponseSemantics: true,
|
|
43
|
+
allowConversationStarters: true,
|
|
44
|
+
allowConfirmation: true,
|
|
45
|
+
};
|
|
46
|
+
exports.specParserGenerateResultTelemetryEvent = "spec-parser-generate-result";
|
|
47
|
+
exports.specParserGenerateResultAllSuccessTelemetryProperty = "all-success";
|
|
48
|
+
exports.specParserGenerateResultWarningsTelemetryProperty = "warnings";
|
|
49
|
+
exports.invalidApiSpecErrorName = "invalid-api-spec";
|
|
50
|
+
const apiSpecNotUsedInPlugin = "api-spec-not-used-in-plugin";
|
|
51
|
+
exports.defaultApiSpecFolderName = "apiSpecificationFile";
|
|
52
|
+
exports.defaultApiSpecYamlFileName = "openapi.yaml";
|
|
53
|
+
exports.defaultApiSpecJsonFileName = "openapi.json";
|
|
54
|
+
exports.defaultPluginManifestFileName = "ai-plugin.json";
|
|
55
|
+
class OpenAIPluginManifestHelper {
|
|
56
|
+
static async loadOpenAIPluginManifest(input) {
|
|
57
|
+
input = input.trim();
|
|
58
|
+
let path = input.endsWith("/") ? input.substring(0, input.length - 1) : input;
|
|
59
|
+
if (!input.toLowerCase().endsWith(manifestFilePath)) {
|
|
60
|
+
path = path + manifestFilePath;
|
|
61
|
+
}
|
|
62
|
+
if (!input.toLowerCase().startsWith("https://") && !input.toLowerCase().startsWith("http://")) {
|
|
63
|
+
path = "https://" + path;
|
|
64
|
+
}
|
|
65
|
+
try {
|
|
66
|
+
const res = await utils_1.sendRequestWithRetry(async () => {
|
|
67
|
+
return await axios_1.default.get(path);
|
|
68
|
+
}, 3);
|
|
69
|
+
return res.data;
|
|
70
|
+
}
|
|
71
|
+
catch (e) {
|
|
72
|
+
throw new teamsfx_api_1.UserError(componentName, "loadOpenAIPluginManifest", localizeUtils_1.getLocalizedString("error.copilotPlugin.openAiPluginManifest.CannotGetManifest", path), localizeUtils_1.getLocalizedString("error.copilotPlugin.openAiPluginManifest.CannotGetManifest", path));
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
static async updateManifest(openAiPluginManifest, teamsAppManifest, manifestPath) {
|
|
76
|
+
teamsAppManifest.description.full = openAiPluginManifest.description_for_human;
|
|
77
|
+
teamsAppManifest.description.short = openAiPluginManifest.description_for_human;
|
|
78
|
+
teamsAppManifest.developer.websiteUrl = openAiPluginManifest.legal_info_url;
|
|
79
|
+
teamsAppManifest.developer.privacyUrl = openAiPluginManifest.legal_info_url;
|
|
80
|
+
teamsAppManifest.developer.termsOfUseUrl = openAiPluginManifest.legal_info_url;
|
|
81
|
+
await fs_extra_1.default.writeFile(manifestPath, JSON.stringify(teamsAppManifest, null, "\t"), "utf-8");
|
|
82
|
+
return teamsfx_api_1.ok(undefined);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
exports.OpenAIPluginManifestHelper = OpenAIPluginManifestHelper;
|
|
86
|
+
async function listOperations(context, manifest, apiSpecUrl, inputs, includeExistingAPIs = true, shouldLogWarning = true, existingCorrelationId) {
|
|
87
|
+
if (manifest) {
|
|
88
|
+
const errors = validateOpenAIPluginManifest(manifest);
|
|
89
|
+
logValidationResults(errors, [], context, false, shouldLogWarning, false, existingCorrelationId);
|
|
90
|
+
if (errors.length > 0) {
|
|
91
|
+
return teamsfx_api_1.err(errors);
|
|
92
|
+
}
|
|
93
|
+
apiSpecUrl = manifest.api.url;
|
|
94
|
+
}
|
|
95
|
+
const isPlugin = inputs[questionNames_1.QuestionNames.Capabilities] === constants_1.copilotPluginApiSpecOptionId;
|
|
96
|
+
const isCustomApi = inputs[questionNames_1.QuestionNames.CustomCopilotRag] === question_1.CustomCopilotRagOptions.customApi().id;
|
|
97
|
+
try {
|
|
98
|
+
const specParser = new m365_spec_parser_1.SpecParser(apiSpecUrl, isPlugin
|
|
99
|
+
? exports.copilotPluginParserOptions
|
|
100
|
+
: isCustomApi
|
|
101
|
+
? {
|
|
102
|
+
projectType: m365_spec_parser_1.ProjectType.TeamsAi,
|
|
103
|
+
}
|
|
104
|
+
: {
|
|
105
|
+
allowBearerTokenAuth: true,
|
|
106
|
+
allowMultipleParameters: true,
|
|
107
|
+
allowOauth2: featureFlags_1.isCopilotAuthEnabled(),
|
|
108
|
+
});
|
|
109
|
+
const validationRes = await specParser.validate();
|
|
110
|
+
validationRes.errors = formatValidationErrors(validationRes.errors, inputs);
|
|
111
|
+
logValidationResults(validationRes.errors, validationRes.warnings, context, true, shouldLogWarning, false, existingCorrelationId);
|
|
112
|
+
if (validationRes.status === m365_spec_parser_1.ValidationStatus.Error) {
|
|
113
|
+
return teamsfx_api_1.err(validationRes.errors);
|
|
114
|
+
}
|
|
115
|
+
const listResult = await specParser.list();
|
|
116
|
+
let operations = listResult.APIs.filter((value) => value.isValid);
|
|
117
|
+
context.telemetryReporter.sendTelemetryEvent("spec-parser-list-apis-result" /* listApis */, {
|
|
118
|
+
["valid-apis-count" /* validApisCount */]: listResult.validAPICount.toString(),
|
|
119
|
+
["all-apis-count" /* allApisCount */]: listResult.allAPICount.toString(),
|
|
120
|
+
["is-from-adding-api" /* isFromAddingApi */]: (!includeExistingAPIs).toString(),
|
|
121
|
+
});
|
|
122
|
+
// Filter out exsiting APIs
|
|
123
|
+
if (!includeExistingAPIs) {
|
|
124
|
+
const teamsManifestPath = inputs[questionNames_1.QuestionNames.ManifestPath];
|
|
125
|
+
if (!teamsManifestPath) {
|
|
126
|
+
throw new error_1.MissingRequiredInputError("teamsManifestPath", "inputs");
|
|
127
|
+
}
|
|
128
|
+
const manifest = await ManifestUtils_1.manifestUtils._readAppManifest(teamsManifestPath);
|
|
129
|
+
let existingOperations = [];
|
|
130
|
+
if (manifest.isOk()) {
|
|
131
|
+
if (isPlugin) {
|
|
132
|
+
existingOperations = await listPluginExistingOperations(manifest.value, teamsManifestPath, inputs[questionNames_1.QuestionNames.DestinationApiSpecFilePath]);
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
const existingOperationIds = ManifestUtils_1.manifestUtils.getOperationIds(manifest.value);
|
|
136
|
+
existingOperations = operations
|
|
137
|
+
.filter((operation) => existingOperationIds.includes(operation.operationId))
|
|
138
|
+
.map((operation) => operation.api);
|
|
139
|
+
}
|
|
140
|
+
operations = operations.filter((operation) => !existingOperations.includes(operation.api));
|
|
141
|
+
// No extra API can be added
|
|
142
|
+
if (operations.length == 0) {
|
|
143
|
+
const errors = formatValidationErrors([
|
|
144
|
+
{
|
|
145
|
+
type: m365_spec_parser_1.ErrorType.NoExtraAPICanBeAdded,
|
|
146
|
+
content: "",
|
|
147
|
+
},
|
|
148
|
+
], inputs);
|
|
149
|
+
logValidationResults(errors, [], context, true, false, false, existingCorrelationId);
|
|
150
|
+
return teamsfx_api_1.err(errors);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
throw manifest.error;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
const sortedOperations = sortOperations(operations);
|
|
158
|
+
return teamsfx_api_1.ok(sortedOperations);
|
|
159
|
+
}
|
|
160
|
+
catch (e) {
|
|
161
|
+
if (e instanceof m365_spec_parser_1.SpecParserError) {
|
|
162
|
+
throw convertSpecParserErrorToFxError(e);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
throw e;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
exports.listOperations = listOperations;
|
|
170
|
+
function sortOperations(operations) {
|
|
171
|
+
const operationsWithSeparator = [];
|
|
172
|
+
for (const operation of operations) {
|
|
173
|
+
const arr = operation.api.toUpperCase().split(" ");
|
|
174
|
+
const result = {
|
|
175
|
+
id: operation.api,
|
|
176
|
+
label: operation.api,
|
|
177
|
+
groupName: arr[0],
|
|
178
|
+
detail: !operation.auth
|
|
179
|
+
? localizeUtils_1.getLocalizedString("core.copilotPlugin.api.noAuth")
|
|
180
|
+
: m365_spec_parser_1.Utils.isBearerTokenAuth(operation.auth.authScheme)
|
|
181
|
+
? localizeUtils_1.getLocalizedString("core.copilotPlugin.api.apiKeyAuth")
|
|
182
|
+
: m365_spec_parser_1.Utils.isOAuthWithAuthCodeFlow(operation.auth.authScheme)
|
|
183
|
+
? localizeUtils_1.getLocalizedString("core.copilotPlugin.api.oauth")
|
|
184
|
+
: "",
|
|
185
|
+
data: {
|
|
186
|
+
serverUrl: operation.server,
|
|
187
|
+
},
|
|
188
|
+
};
|
|
189
|
+
if (operation.auth) {
|
|
190
|
+
if (m365_spec_parser_1.Utils.isBearerTokenAuth(operation.auth.authScheme)) {
|
|
191
|
+
result.data.authType = "apiKey";
|
|
192
|
+
result.data.authName = operation.auth.name;
|
|
193
|
+
}
|
|
194
|
+
else if (m365_spec_parser_1.Utils.isOAuthWithAuthCodeFlow(operation.auth.authScheme)) {
|
|
195
|
+
result.data.authType = "oauth2";
|
|
196
|
+
result.data.authName = operation.auth.name;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
operationsWithSeparator.push(result);
|
|
200
|
+
}
|
|
201
|
+
return operationsWithSeparator.sort((operation1, operation2) => {
|
|
202
|
+
const arr1 = operation1.id.toLowerCase().split(" ");
|
|
203
|
+
const arr2 = operation2.id.toLowerCase().split(" ");
|
|
204
|
+
return arr1[0] < arr2[0] ? -1 : arr1[0] > arr2[0] ? 1 : arr1[1].localeCompare(arr2[1]);
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
function formatTelemetryValidationProperty(result) {
|
|
208
|
+
return result.type.toString();
|
|
209
|
+
}
|
|
210
|
+
async function listPluginExistingOperations(manifest, teamsManifestPath, destinationApiSpecFilePath) {
|
|
211
|
+
const getApiSPecFileRes = await PluginManifestUtils_1.pluginManifestUtils.getApiSpecFilePathFromTeamsManifest(manifest, teamsManifestPath);
|
|
212
|
+
if (getApiSPecFileRes.isErr()) {
|
|
213
|
+
throw getApiSPecFileRes.error;
|
|
214
|
+
}
|
|
215
|
+
let apiSpecFilePath;
|
|
216
|
+
const apiSpecFiles = getApiSPecFileRes.value;
|
|
217
|
+
for (const file of apiSpecFiles) {
|
|
218
|
+
if (path_1.default.resolve(file) === path_1.default.resolve(destinationApiSpecFilePath)) {
|
|
219
|
+
apiSpecFilePath = file;
|
|
220
|
+
break;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
if (!apiSpecFilePath) {
|
|
224
|
+
throw new teamsfx_api_1.UserError("listPluginExistingOperations", apiSpecNotUsedInPlugin, localizeUtils_1.getLocalizedString("error.copilotPlugin.apiSpecNotUsedInPlugin", destinationApiSpecFilePath), localizeUtils_1.getLocalizedString("error.copilotPlugin.apiSpecNotUsedInPlugin", destinationApiSpecFilePath));
|
|
225
|
+
}
|
|
226
|
+
const specParser = new m365_spec_parser_1.SpecParser(apiSpecFilePath, exports.copilotPluginParserOptions);
|
|
227
|
+
const listResult = await specParser.list();
|
|
228
|
+
return listResult.APIs.map((o) => o.api);
|
|
229
|
+
}
|
|
230
|
+
exports.listPluginExistingOperations = listPluginExistingOperations;
|
|
231
|
+
function logValidationResults(errors, warnings, context, isApiSpec, shouldLogWarning, shouldSkipTelemetry, existingCorrelationId) {
|
|
232
|
+
if (!shouldSkipTelemetry) {
|
|
233
|
+
const properties = {
|
|
234
|
+
["validation-status" /* validationStatus */]: errors.length !== 0 ? "error" : warnings.length !== 0 ? "warning" : "success",
|
|
235
|
+
["validation-errors" /* validationErrors */]: errors
|
|
236
|
+
.map((error) => formatTelemetryValidationProperty(error))
|
|
237
|
+
.join(";"),
|
|
238
|
+
["validation-warnings" /* validationWarnings */]: warnings
|
|
239
|
+
.map((warn) => formatTelemetryValidationProperty(warn))
|
|
240
|
+
.join(";"),
|
|
241
|
+
};
|
|
242
|
+
if (existingCorrelationId) {
|
|
243
|
+
properties["correlation-id"] = existingCorrelationId;
|
|
244
|
+
}
|
|
245
|
+
context.telemetryReporter.sendTelemetryEvent(isApiSpec ? "validate-api-spec" /* validateApiSpec */ : "validate-openai-plugin-manifest" /* validateOpenAiPluginManifest */, properties);
|
|
246
|
+
}
|
|
247
|
+
if (errors.length === 0 && (warnings.length === 0 || !shouldLogWarning)) {
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
// errors > 0 || (warnings > 0 && shouldLogWarning)
|
|
251
|
+
const errorMessage = errors
|
|
252
|
+
.map((error) => {
|
|
253
|
+
return `${constant_1.SummaryConstant.Failed} ${error.content}`;
|
|
254
|
+
})
|
|
255
|
+
.join(os_1.EOL);
|
|
256
|
+
const warningMessage = shouldLogWarning
|
|
257
|
+
? warnings
|
|
258
|
+
.map((warning) => {
|
|
259
|
+
return `${constant_1.SummaryConstant.NotExecuted} ${warning.content}`;
|
|
260
|
+
})
|
|
261
|
+
.join(os_1.EOL)
|
|
262
|
+
: "";
|
|
263
|
+
const failed = errors.length;
|
|
264
|
+
const warns = warnings.length;
|
|
265
|
+
const summaryStr = [];
|
|
266
|
+
if (failed > 0) {
|
|
267
|
+
summaryStr.push(localizeUtils_1.getLocalizedString("core.copilotPlugin.validate.summary.validate.failed", failed));
|
|
268
|
+
}
|
|
269
|
+
if (warns > 0 && shouldLogWarning) {
|
|
270
|
+
summaryStr.push(localizeUtils_1.getLocalizedString("core.copilotPlugin.validate.summary.validate.warning", warns));
|
|
271
|
+
}
|
|
272
|
+
const outputMessage = isApiSpec
|
|
273
|
+
? os_1.EOL +
|
|
274
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.validate.apiSpec.summary", summaryStr.join(", "), errorMessage, warningMessage)
|
|
275
|
+
: os_1.EOL +
|
|
276
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.validate.openAIPluginManifest.summary", summaryStr.join(", "), errorMessage, warningMessage);
|
|
277
|
+
void context.logProvider.info(outputMessage);
|
|
278
|
+
}
|
|
279
|
+
exports.logValidationResults = logValidationResults;
|
|
280
|
+
function validateOpenAIPluginManifest(manifest) {
|
|
281
|
+
var _a, _b;
|
|
282
|
+
const errors = [];
|
|
283
|
+
if (!((_a = manifest.api) === null || _a === void 0 ? void 0 : _a.url)) {
|
|
284
|
+
errors.push({
|
|
285
|
+
type: OpenAIPluginManifestErrorType.ApiUrlMissing,
|
|
286
|
+
content: localizeUtils_1.getLocalizedString("core.createProjectQuestion.openAiPluginManifest.validationError.missingApiUrl", "api.url"),
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
if (((_b = manifest.auth) === null || _b === void 0 ? void 0 : _b.type) !== teamsfx_api_1.OpenAIManifestAuthType.None) {
|
|
290
|
+
errors.push({
|
|
291
|
+
type: OpenAIPluginManifestErrorType.AuthNotSupported,
|
|
292
|
+
content: localizeUtils_1.getLocalizedString("core.createProjectQuestion.openAiPluginManifest.validationError.authNotSupported", "none"),
|
|
293
|
+
});
|
|
294
|
+
}
|
|
295
|
+
return errors;
|
|
296
|
+
}
|
|
297
|
+
function generateScaffoldingSummary(warnings, teamsManifest, apiSpecFilePath) {
|
|
298
|
+
const apiSpecWarningMessage = formatApiSpecValidationWarningMessage(warnings, apiSpecFilePath, teamsManifest);
|
|
299
|
+
const manifestWarningResult = validateTeamsManifestLength(teamsManifest, warnings);
|
|
300
|
+
const manifestWarningMessage = manifestWarningResult.map((warn) => {
|
|
301
|
+
return `${constant_1.SummaryConstant.NotExecuted} ${warn}`;
|
|
302
|
+
});
|
|
303
|
+
if (apiSpecWarningMessage.length || manifestWarningMessage.length) {
|
|
304
|
+
let details = "";
|
|
305
|
+
if (apiSpecWarningMessage.length) {
|
|
306
|
+
details += os_1.EOL + apiSpecWarningMessage.join(os_1.EOL);
|
|
307
|
+
}
|
|
308
|
+
if (manifestWarningMessage.length) {
|
|
309
|
+
details += os_1.EOL + manifestWarningMessage.join(os_1.EOL);
|
|
310
|
+
}
|
|
311
|
+
return localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary", details);
|
|
312
|
+
}
|
|
313
|
+
else {
|
|
314
|
+
return "";
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
exports.generateScaffoldingSummary = generateScaffoldingSummary;
|
|
318
|
+
function formatApiSpecValidationWarningMessage(specWarnings, apiSpecFileName, teamsManifest) {
|
|
319
|
+
const resultWarnings = [];
|
|
320
|
+
const operationIdWarning = specWarnings.find((w) => w.type === m365_spec_parser_1.WarningType.OperationIdMissing);
|
|
321
|
+
if (operationIdWarning) {
|
|
322
|
+
const isApiMe = teamsfx_api_1.ManifestUtil.parseCommonProperties(teamsManifest).isApiME;
|
|
323
|
+
resultWarnings.push(localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.operationId", `${constant_1.SummaryConstant.NotExecuted} ${operationIdWarning.content}`, isApiMe ? teamsfx_api_1.ManifestTemplateFileName : apiSpecFileName));
|
|
324
|
+
}
|
|
325
|
+
const swaggerWarning = specWarnings.find((w) => w.type === m365_spec_parser_1.WarningType.ConvertSwaggerToOpenAPI);
|
|
326
|
+
if (swaggerWarning) {
|
|
327
|
+
resultWarnings.push(`${constant_1.SummaryConstant.NotExecuted} ` +
|
|
328
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.swaggerVersion", apiSpecFileName));
|
|
329
|
+
}
|
|
330
|
+
return resultWarnings;
|
|
331
|
+
}
|
|
332
|
+
function validateTeamsManifestLength(teamsManifest, warnings) {
|
|
333
|
+
var _a, _b, _c, _d, _e;
|
|
334
|
+
const nameShortLimit = 30;
|
|
335
|
+
const nameFullLimit = 100;
|
|
336
|
+
const descriptionShortLimit = 80;
|
|
337
|
+
const descriptionFullLimit = 4000;
|
|
338
|
+
const appnameSuffixPlaceholder = "${{APP_NAME_SUFFIX}}";
|
|
339
|
+
const devEnv = "dev";
|
|
340
|
+
const resultWarnings = [];
|
|
341
|
+
// validate name
|
|
342
|
+
const shortNameLength = teamsManifest.name.short.includes(appnameSuffixPlaceholder)
|
|
343
|
+
? teamsManifest.name.short.length - appnameSuffixPlaceholder.length + devEnv.length
|
|
344
|
+
: teamsManifest.name.short.length;
|
|
345
|
+
if (shortNameLength > nameShortLimit) {
|
|
346
|
+
resultWarnings.push(formatLengthExceedingErrorMessage("/name/short", nameShortLimit));
|
|
347
|
+
}
|
|
348
|
+
if (!!teamsManifest.name.full && ((_a = teamsManifest.name.full) === null || _a === void 0 ? void 0 : _a.length) > nameFullLimit) {
|
|
349
|
+
resultWarnings.push(formatLengthExceedingErrorMessage("/name/full", nameFullLimit));
|
|
350
|
+
}
|
|
351
|
+
// validate description
|
|
352
|
+
if (teamsManifest.description.short.length > descriptionShortLimit) {
|
|
353
|
+
resultWarnings.push(formatLengthExceedingErrorMessage("/description/short", descriptionShortLimit));
|
|
354
|
+
}
|
|
355
|
+
if (!((_b = teamsManifest.description.full) === null || _b === void 0 ? void 0 : _b.length)) {
|
|
356
|
+
resultWarnings.push(localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.teamsManifest.missingFullDescription") +
|
|
357
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.teamsManifest.mitigation", "full/description", path_1.default.join(teamsfx_api_1.AppPackageFolderName, teamsfx_api_1.ManifestTemplateFileName)));
|
|
358
|
+
}
|
|
359
|
+
if (teamsManifest.description.full.length > descriptionFullLimit) {
|
|
360
|
+
resultWarnings.push(formatLengthExceedingErrorMessage("/description/full", descriptionFullLimit));
|
|
361
|
+
}
|
|
362
|
+
// validate command
|
|
363
|
+
if (teamsfx_api_1.ManifestUtil.parseCommonProperties(teamsManifest).isApiME) {
|
|
364
|
+
const optionalParamsOnlyWarnings = warnings.filter((o) => o.type === m365_spec_parser_1.WarningType.OperationOnlyContainsOptionalParam);
|
|
365
|
+
const commands = teamsManifest.composeExtensions[0].commands;
|
|
366
|
+
if (optionalParamsOnlyWarnings) {
|
|
367
|
+
for (const optionalParamsOnlyWarning of optionalParamsOnlyWarnings) {
|
|
368
|
+
const command = commands.find((o) => o.id === optionalParamsOnlyWarning.data);
|
|
369
|
+
if (command && command.parameters) {
|
|
370
|
+
const parameterName = (_c = command.parameters[0]) === null || _c === void 0 ? void 0 : _c.name;
|
|
371
|
+
resultWarnings.push(localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.api.optionalParametersOnly", optionalParamsOnlyWarning.data, optionalParamsOnlyWarning.data) +
|
|
372
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.api.optionalParametersOnly.mitigation", parameterName, optionalParamsOnlyWarning.data, path_1.default.join(teamsfx_api_1.AppPackageFolderName, teamsfx_api_1.ManifestTemplateFileName), path_1.default.join(teamsfx_api_1.AppPackageFolderName, (_d = teamsManifest.composeExtensions[0].apiSpecificationFile) !== null && _d !== void 0 ? _d : "")));
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
for (const command of commands) {
|
|
377
|
+
if (command.type === "query") {
|
|
378
|
+
if (!command.apiResponseRenderingTemplateFile) {
|
|
379
|
+
const errorDetail = (_e = warnings.find((w) => w.type === m365_spec_parser_1.WarningType.GenerateCardFailed && w.data === command.id)) === null || _e === void 0 ? void 0 : _e.content;
|
|
380
|
+
resultWarnings.push(localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.teamsManifest.missingCardTemlate", "apiResponseRenderingTemplateFile", command.id) +
|
|
381
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.teamsManifest.missingCardTemlate.mitigation", teamsfx_api_1.AppPackageFolderName, `composeExtensions/commands/${command.id}/apiResponseRenderingTemplateFile`, path_1.default.join(teamsfx_api_1.AppPackageFolderName, teamsfx_api_1.ManifestTemplateFileName)) +
|
|
382
|
+
(errorDetail ? os_1.EOL + errorDetail : ""));
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
return resultWarnings;
|
|
388
|
+
}
|
|
389
|
+
function formatLengthExceedingErrorMessage(field, limit) {
|
|
390
|
+
return (localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.teamsManifest.lengthExceeding", field, limit.toString()) +
|
|
391
|
+
localizeUtils_1.getLocalizedString("core.copilotPlugin.scaffold.summary.warning.teamsManifest.mitigation", field, path_1.default.join(teamsfx_api_1.AppPackageFolderName, teamsfx_api_1.ManifestTemplateFileName)));
|
|
392
|
+
}
|
|
393
|
+
function convertSpecParserErrorToFxError(error) {
|
|
394
|
+
return new teamsfx_api_1.SystemError("SpecParser", error.errorType.toString(), error.message, error.message);
|
|
395
|
+
}
|
|
396
|
+
exports.convertSpecParserErrorToFxError = convertSpecParserErrorToFxError;
|
|
397
|
+
async function isYamlSpecFile(specPath) {
|
|
398
|
+
if (specPath.endsWith(".yaml") || specPath.endsWith(".yml")) {
|
|
399
|
+
return true;
|
|
400
|
+
}
|
|
401
|
+
else if (specPath.endsWith(".json")) {
|
|
402
|
+
return false;
|
|
403
|
+
}
|
|
404
|
+
const isRemoteFile = specPath.startsWith("http:") || specPath.startsWith("https:");
|
|
405
|
+
const fileContent = isRemoteFile
|
|
406
|
+
? (await axios_1.default.get(specPath)).data
|
|
407
|
+
: await fs_extra_1.default.readFile(specPath, "utf-8");
|
|
408
|
+
try {
|
|
409
|
+
JSON.parse(fileContent);
|
|
410
|
+
return false;
|
|
411
|
+
}
|
|
412
|
+
catch (error) {
|
|
413
|
+
return true;
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
exports.isYamlSpecFile = isYamlSpecFile;
|
|
417
|
+
function formatValidationErrors(errors, inputs) {
|
|
418
|
+
return errors.map((error) => {
|
|
419
|
+
return {
|
|
420
|
+
type: error.type,
|
|
421
|
+
content: formatValidationErrorContent(error, inputs),
|
|
422
|
+
data: error.data,
|
|
423
|
+
};
|
|
424
|
+
});
|
|
425
|
+
}
|
|
426
|
+
exports.formatValidationErrors = formatValidationErrors;
|
|
427
|
+
function mapInvalidReasonToMessage(reason) {
|
|
428
|
+
switch (reason) {
|
|
429
|
+
case m365_spec_parser_1.ErrorType.AuthTypeIsNotSupported:
|
|
430
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.AuthTypeIsNotSupported");
|
|
431
|
+
case m365_spec_parser_1.ErrorType.MissingOperationId:
|
|
432
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.MissingOperationId");
|
|
433
|
+
case m365_spec_parser_1.ErrorType.PostBodyContainMultipleMediaTypes:
|
|
434
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.PostBodyContainMultipleMediaTypes");
|
|
435
|
+
case m365_spec_parser_1.ErrorType.ResponseContainMultipleMediaTypes:
|
|
436
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.ResponseContainMultipleMediaTypes");
|
|
437
|
+
case m365_spec_parser_1.ErrorType.ResponseJsonIsEmpty:
|
|
438
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.ResponseJsonIsEmpty");
|
|
439
|
+
case m365_spec_parser_1.ErrorType.PostBodySchemaIsNotJson:
|
|
440
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.PostBodySchemaIsNotJson");
|
|
441
|
+
case m365_spec_parser_1.ErrorType.PostBodyContainsRequiredUnsupportedSchema:
|
|
442
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.PostBodyContainsRequiredUnsupportedSchema");
|
|
443
|
+
case m365_spec_parser_1.ErrorType.ParamsContainRequiredUnsupportedSchema:
|
|
444
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.ParamsContainRequiredUnsupportedSchema");
|
|
445
|
+
case m365_spec_parser_1.ErrorType.ParamsContainsNestedObject:
|
|
446
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.ParamsContainsNestedObject");
|
|
447
|
+
case m365_spec_parser_1.ErrorType.RequestBodyContainsNestedObject:
|
|
448
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.RequestBodyContainsNestedObject");
|
|
449
|
+
case m365_spec_parser_1.ErrorType.ExceededRequiredParamsLimit:
|
|
450
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.ExceededRequiredParamsLimit");
|
|
451
|
+
case m365_spec_parser_1.ErrorType.NoParameter:
|
|
452
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.NoParameter");
|
|
453
|
+
case m365_spec_parser_1.ErrorType.NoAPIInfo:
|
|
454
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.NoAPIInfo");
|
|
455
|
+
case m365_spec_parser_1.ErrorType.MethodNotAllowed:
|
|
456
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.MethodNotAllowed");
|
|
457
|
+
case m365_spec_parser_1.ErrorType.UrlPathNotExist:
|
|
458
|
+
return localizeUtils_1.getLocalizedString("core.common.invalidReason.UrlPathNotExist");
|
|
459
|
+
default:
|
|
460
|
+
return reason.toString();
|
|
461
|
+
}
|
|
462
|
+
}
|
|
463
|
+
function formatValidationErrorContent(error, inputs) {
|
|
464
|
+
const isPlugin = inputs[questionNames_1.QuestionNames.Capabilities] === constants_1.copilotPluginApiSpecOptionId;
|
|
465
|
+
try {
|
|
466
|
+
switch (error.type) {
|
|
467
|
+
case m365_spec_parser_1.ErrorType.SpecNotValid: {
|
|
468
|
+
let content = error.content;
|
|
469
|
+
if (error.content.startsWith("ResolverError: Error downloading")) {
|
|
470
|
+
content = error.content
|
|
471
|
+
.split("\n")
|
|
472
|
+
.map((o) => o.trim())
|
|
473
|
+
.join(". ");
|
|
474
|
+
content = `${content}. ${localizeUtils_1.getLocalizedString("core.common.ErrorFetchApiSpec")}`;
|
|
475
|
+
}
|
|
476
|
+
else if (error.content.startsWith("RangeError: Maximum call stack size exceeded")) {
|
|
477
|
+
content = localizeUtils_1.getLocalizedString("core.common.CircularReferenceNotSupported");
|
|
478
|
+
}
|
|
479
|
+
return content;
|
|
480
|
+
}
|
|
481
|
+
case m365_spec_parser_1.ErrorType.RemoteRefNotSupported:
|
|
482
|
+
return localizeUtils_1.getLocalizedString("core.common.RemoteRefNotSupported", error.data.join(", "));
|
|
483
|
+
case m365_spec_parser_1.ErrorType.NoServerInformation:
|
|
484
|
+
return localizeUtils_1.getLocalizedString("core.common.NoServerInformation");
|
|
485
|
+
case m365_spec_parser_1.ErrorType.UrlProtocolNotSupported:
|
|
486
|
+
return localizeUtils_1.getLocalizedString("core.common.UrlProtocolNotSupported", error.data);
|
|
487
|
+
case m365_spec_parser_1.ErrorType.RelativeServerUrlNotSupported:
|
|
488
|
+
return localizeUtils_1.getLocalizedString("core.common.RelativeServerUrlNotSupported");
|
|
489
|
+
case m365_spec_parser_1.ErrorType.NoSupportedApi:
|
|
490
|
+
const messages = [];
|
|
491
|
+
const invalidAPIInfo = error.data;
|
|
492
|
+
for (const info of invalidAPIInfo) {
|
|
493
|
+
// eslint-disable-next-line @typescript-eslint/restrict-template-expressions
|
|
494
|
+
const mes = `${info.api}: ${info.reason.map(mapInvalidReasonToMessage).join(", ")}`;
|
|
495
|
+
messages.push(mes);
|
|
496
|
+
}
|
|
497
|
+
if (messages.length === 0) {
|
|
498
|
+
messages.push(localizeUtils_1.getLocalizedString("core.common.invalidReason.NoAPIs"));
|
|
499
|
+
}
|
|
500
|
+
return isPlugin
|
|
501
|
+
? localizeUtils_1.getLocalizedString("core.common.NoSupportedApiCopilot", messages.join("\n"))
|
|
502
|
+
: localizeUtils_1.getLocalizedString("core.common.NoSupportedApi", messages.join("\n"));
|
|
503
|
+
case m365_spec_parser_1.ErrorType.NoExtraAPICanBeAdded:
|
|
504
|
+
return isPlugin
|
|
505
|
+
? localizeUtils_1.getLocalizedString("error.copilot.noExtraAPICanBeAdded")
|
|
506
|
+
: localizeUtils_1.getLocalizedString("error.apime.noExtraAPICanBeAdded");
|
|
507
|
+
case m365_spec_parser_1.ErrorType.ResolveServerUrlFailed:
|
|
508
|
+
return error.content;
|
|
509
|
+
case m365_spec_parser_1.ErrorType.Cancelled:
|
|
510
|
+
return localizeUtils_1.getLocalizedString("core.common.CancelledMessage");
|
|
511
|
+
case m365_spec_parser_1.ErrorType.SwaggerNotSupported:
|
|
512
|
+
return localizeUtils_1.getLocalizedString("core.common.SwaggerNotSupported");
|
|
513
|
+
case m365_spec_parser_1.ErrorType.SpecVersionNotSupported:
|
|
514
|
+
return localizeUtils_1.getLocalizedString("core.common.SpecVersionNotSupported", error.data);
|
|
515
|
+
default:
|
|
516
|
+
return error.content;
|
|
517
|
+
}
|
|
518
|
+
}
|
|
519
|
+
catch (e) {
|
|
520
|
+
return error.content;
|
|
521
|
+
}
|
|
522
|
+
}
|
|
523
|
+
function parseSpec(spec) {
|
|
524
|
+
const res = [];
|
|
525
|
+
let needAuth = false;
|
|
526
|
+
const paths = spec.paths;
|
|
527
|
+
if (paths) {
|
|
528
|
+
for (const pathUrl in paths) {
|
|
529
|
+
const pathItem = paths[pathUrl];
|
|
530
|
+
if (pathItem) {
|
|
531
|
+
const operations = pathItem;
|
|
532
|
+
for (const method in operations) {
|
|
533
|
+
if (method === "get" || method === "post") {
|
|
534
|
+
const operationItem = operations[method];
|
|
535
|
+
if (operationItem) {
|
|
536
|
+
const authResult = m365_spec_parser_1.Utils.getAuthArray(operationItem.security, spec);
|
|
537
|
+
const hasAuth = authResult.length != 0;
|
|
538
|
+
if (hasAuth) {
|
|
539
|
+
needAuth = true;
|
|
540
|
+
}
|
|
541
|
+
res.push({
|
|
542
|
+
item: operationItem,
|
|
543
|
+
method: method,
|
|
544
|
+
pathUrl: pathUrl,
|
|
545
|
+
auth: hasAuth,
|
|
546
|
+
});
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
}
|
|
550
|
+
}
|
|
551
|
+
}
|
|
552
|
+
}
|
|
553
|
+
return [res, needAuth];
|
|
554
|
+
}
|
|
555
|
+
async function updatePromptForCustomApi(spec, language, chatFolder) {
|
|
556
|
+
if (language === question_1.ProgrammingLanguage.JS || language === question_1.ProgrammingLanguage.TS) {
|
|
557
|
+
const promptFilePath = path_1.default.join(chatFolder, "skprompt.txt");
|
|
558
|
+
const prompt = `The following is a conversation with an AI assistant.\nThe assistant can help to call APIs for the open api spec file${spec.info.description ? ". " + spec.info.description : "."}\nIf the API doesn't require parameters, invoke it with default JSON object { "path": null, "body": null, "query": null }.\n\ncontext:\nAvailable actions: {{getAction}}.`;
|
|
559
|
+
await fs_extra_1.default.writeFile(promptFilePath, prompt, { encoding: "utf-8", flag: "w" });
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
async function updateAdaptiveCardForCustomApi(specItems, language, destinationPath) {
|
|
563
|
+
if (language === question_1.ProgrammingLanguage.JS || language === question_1.ProgrammingLanguage.TS) {
|
|
564
|
+
const adaptiveCardsFolderPath = path_1.default.join(destinationPath, "src", "adaptiveCards");
|
|
565
|
+
await fs_extra_1.default.ensureDir(adaptiveCardsFolderPath);
|
|
566
|
+
for (const item of specItems) {
|
|
567
|
+
const name = item.item.operationId;
|
|
568
|
+
const [card] = m365_spec_parser_1.AdaptiveCardGenerator.generateAdaptiveCard(item.item);
|
|
569
|
+
const cardFilePath = path_1.default.join(adaptiveCardsFolderPath, `${name}.json`);
|
|
570
|
+
await fs_extra_1.default.writeFile(cardFilePath, JSON.stringify(card, null, 2));
|
|
571
|
+
}
|
|
572
|
+
}
|
|
573
|
+
}
|
|
574
|
+
async function updateActionForCustomApi(specItems, language, chatFolder) {
|
|
575
|
+
var _a, _b;
|
|
576
|
+
if (language === question_1.ProgrammingLanguage.JS || language === question_1.ProgrammingLanguage.TS) {
|
|
577
|
+
const actionsFilePath = path_1.default.join(chatFolder, "actions.json");
|
|
578
|
+
const actions = [];
|
|
579
|
+
for (const item of specItems) {
|
|
580
|
+
const parameters = {
|
|
581
|
+
type: "object",
|
|
582
|
+
properties: {},
|
|
583
|
+
required: [],
|
|
584
|
+
};
|
|
585
|
+
const paramObject = item.item.parameters;
|
|
586
|
+
if (paramObject) {
|
|
587
|
+
for (let i = 0; i < paramObject.length; i++) {
|
|
588
|
+
const param = paramObject[i];
|
|
589
|
+
const schema = param.schema;
|
|
590
|
+
const paramType = param.in;
|
|
591
|
+
if (!parameters.properties[paramType]) {
|
|
592
|
+
parameters.properties[paramType] = {
|
|
593
|
+
type: "object",
|
|
594
|
+
properties: {},
|
|
595
|
+
required: [],
|
|
596
|
+
};
|
|
597
|
+
}
|
|
598
|
+
parameters.properties[paramType].properties[param.name] = schema;
|
|
599
|
+
parameters.properties[paramType].properties[param.name].description =
|
|
600
|
+
(_a = param.description) !== null && _a !== void 0 ? _a : "";
|
|
601
|
+
if (param.required) {
|
|
602
|
+
parameters.properties[paramType].required.push(param.name);
|
|
603
|
+
if (!parameters.required.includes(paramType)) {
|
|
604
|
+
parameters.required.push(paramType);
|
|
605
|
+
}
|
|
606
|
+
}
|
|
607
|
+
}
|
|
608
|
+
}
|
|
609
|
+
actions.push({
|
|
610
|
+
name: item.item.operationId,
|
|
611
|
+
description: (_b = item.item.description) !== null && _b !== void 0 ? _b : item.item.summary,
|
|
612
|
+
parameters: parameters,
|
|
613
|
+
});
|
|
614
|
+
}
|
|
615
|
+
await fs_extra_1.default.writeFile(actionsFilePath, JSON.stringify(actions, null, 2));
|
|
616
|
+
}
|
|
617
|
+
}
|
|
618
|
+
const ActionCode = {
|
|
619
|
+
javascript: `
|
|
620
|
+
app.ai.action("{{operationId}}", async (context, state, parameter) => {
|
|
621
|
+
const client = await api.getClient();
|
|
622
|
+
// Add authentication configuration for the client
|
|
623
|
+
const path = client.paths["{{pathUrl}}"];
|
|
624
|
+
if (path && path.{{method}}) {
|
|
625
|
+
const result = await path.{{method}}(parameter.path, parameter.body, {
|
|
626
|
+
params: parameter.query,
|
|
627
|
+
});
|
|
628
|
+
const card = generateAdaptiveCard("../adaptiveCards/{{operationId}}.json", result);
|
|
629
|
+
await context.sendActivity({ attachments: [card] });
|
|
630
|
+
} else {
|
|
631
|
+
await context.sendActivity("no result");
|
|
632
|
+
}
|
|
633
|
+
return "result";
|
|
634
|
+
});
|
|
635
|
+
`,
|
|
636
|
+
typescript: `
|
|
637
|
+
app.ai.action("{{operationId}}", async (context: TurnContext, state: ApplicationTurnState, parameter: any) => {
|
|
638
|
+
const client = await api.getClient();
|
|
639
|
+
// Add authentication configuration for the client
|
|
640
|
+
const path = client.paths["{{pathUrl}}"];
|
|
641
|
+
if (path && path.{{method}}) {
|
|
642
|
+
const result = await path.{{method}}(parameter.path, parameter.body, {
|
|
643
|
+
params: parameter.query,
|
|
644
|
+
});
|
|
645
|
+
const card = generateAdaptiveCard("../adaptiveCards/{{operationId}}.json", result);
|
|
646
|
+
await context.sendActivity({ attachments: [card] });
|
|
647
|
+
} else {
|
|
648
|
+
await context.sendActivity("no result");
|
|
649
|
+
}
|
|
650
|
+
return "result";
|
|
651
|
+
});
|
|
652
|
+
`,
|
|
653
|
+
};
|
|
654
|
+
const AuthCode = {
|
|
655
|
+
javascript: {
|
|
656
|
+
actionCode: `addAuthConfig(client);`,
|
|
657
|
+
actionPlaceholder: `// Add authentication configuration for the client`,
|
|
658
|
+
},
|
|
659
|
+
typescript: {
|
|
660
|
+
actionCode: `addAuthConfig(client);`,
|
|
661
|
+
actionPlaceholder: `// Add authentication configuration for the client`,
|
|
662
|
+
},
|
|
663
|
+
};
|
|
664
|
+
async function updateCodeForCustomApi(specItems, language, destinationPath, openapiSpecFileName, needAuth) {
|
|
665
|
+
if (language === question_1.ProgrammingLanguage.JS || language === question_1.ProgrammingLanguage.TS) {
|
|
666
|
+
const codeTemplate = ActionCode[language === question_1.ProgrammingLanguage.JS ? "javascript" : "typescript"];
|
|
667
|
+
const appFolderPath = path_1.default.join(destinationPath, "src", "app");
|
|
668
|
+
const actionsCode = [];
|
|
669
|
+
const authCodeTemplate = AuthCode[language === question_1.ProgrammingLanguage.JS ? "javascript" : "typescript"];
|
|
670
|
+
for (const item of specItems) {
|
|
671
|
+
const auth = item.auth;
|
|
672
|
+
const code = codeTemplate
|
|
673
|
+
.replace(authCodeTemplate.actionPlaceholder, auth ? authCodeTemplate.actionCode : "")
|
|
674
|
+
.replace(/{{operationId}}/g, item.item.operationId)
|
|
675
|
+
.replace(/{{pathUrl}}/g, item.pathUrl)
|
|
676
|
+
.replace(/{{method}}/g, item.method);
|
|
677
|
+
actionsCode.push(code);
|
|
678
|
+
}
|
|
679
|
+
// Update code in app file
|
|
680
|
+
const indexFilePath = path_1.default.join(appFolderPath, language === question_1.ProgrammingLanguage.JS ? "app.js" : "app.ts");
|
|
681
|
+
const indexFileContent = (await fs_extra_1.default.readFile(indexFilePath)).toString();
|
|
682
|
+
const updateIndexFileContent = indexFileContent
|
|
683
|
+
.replace("{{OPENAPI_SPEC_PATH}}", openapiSpecFileName)
|
|
684
|
+
.replace("// Replace with action code", actionsCode.join("\n"));
|
|
685
|
+
await fs_extra_1.default.writeFile(indexFilePath, updateIndexFileContent);
|
|
686
|
+
}
|
|
687
|
+
}
|
|
688
|
+
async function updateForCustomApi(spec, language, destinationPath, openapiSpecFileName) {
|
|
689
|
+
const chatFolder = path_1.default.join(destinationPath, "src", "prompts", "chat");
|
|
690
|
+
await fs_extra_1.default.ensureDir(chatFolder);
|
|
691
|
+
// 1. update prompt folder
|
|
692
|
+
await updatePromptForCustomApi(spec, language, chatFolder);
|
|
693
|
+
const [specItems, needAuth] = parseSpec(spec);
|
|
694
|
+
// 2. update adaptive card folder
|
|
695
|
+
await updateAdaptiveCardForCustomApi(specItems, language, destinationPath);
|
|
696
|
+
// 3. update actions file
|
|
697
|
+
await updateActionForCustomApi(specItems, language, chatFolder);
|
|
698
|
+
// 4. update code
|
|
699
|
+
await updateCodeForCustomApi(specItems, language, destinationPath, openapiSpecFileName, needAuth);
|
|
700
|
+
}
|
|
701
|
+
exports.updateForCustomApi = updateForCustomApi;
|
|
702
|
+
const EnvNameMapping = {
|
|
703
|
+
apiKey: "REGISTRATION_ID",
|
|
704
|
+
oauth2: "CONFIGURATION_ID",
|
|
705
|
+
};
|
|
706
|
+
function getEnvName(authName, authType) {
|
|
707
|
+
return m365_spec_parser_1.Utils.getSafeRegistrationIdEnvName(`${authName}_${EnvNameMapping[authType !== null && authType !== void 0 ? authType : "apiKey"]}`);
|
|
708
|
+
}
|
|
709
|
+
exports.getEnvName = getEnvName;
|
|
710
|
+
//# sourceMappingURL=helper.js.map
|