diff --git a/common/config/rush/pnpm-lock.yaml b/common/config/rush/pnpm-lock.yaml index edbd00d3aba9..ada4e43860d6 100644 --- a/common/config/rush/pnpm-lock.yaml +++ b/common/config/rush/pnpm-lock.yaml @@ -842,6 +842,9 @@ dependencies: '@rush-temp/defender-easm': specifier: file:./projects/defender-easm.tgz version: file:projects/defender-easm.tgz + '@rush-temp/defender-easm-rest': + specifier: file:./projects/defender-easm-rest.tgz + version: file:projects/defender-easm-rest.tgz '@rush-temp/dev-tool': specifier: file:./projects/dev-tool.tgz version: file:projects/dev-tool.tgz @@ -3453,7 +3456,7 @@ packages: /@types/bunyan@1.8.9: resolution: {integrity: sha512-ZqS9JGpBxVOvsawzmVt30sP++gSQMTejCkIAQ3VdadOcRE8izTyW66hufvwLeH+YEGP6Js2AW7Gz+RMyvrEbmw==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/chai-as-promised@7.1.8: @@ -3485,7 +3488,7 @@ packages: /@types/cors@2.8.17: resolution: {integrity: sha512-8CGDvrBj1zgo2qE+oS3pOCyYNqCPryMWY2bGfwA0dcfopWGgxs+78df0Rs3rc9THP4JkOhLsAa+15VdpAqkcUA==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/debug@4.1.12: @@ -3533,13 +3536,13 @@ packages: resolution: {integrity: sha512-yTbItCNreRooED33qjunPthRcSjERP1r4MqCZc7wv0u2sUkzTFp45tgUfS5+r7FrZPdmCCNflLhVSP/o+SemsQ==} dependencies: '@types/jsonfile': 6.1.4 - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/fs-extra@8.1.5: resolution: {integrity: sha512-0dzKcwO+S8s2kuF5Z9oUWatQJj5Uq/iqphEtE3GQJVRRYm/tD1LglU2UnXi2A8jLq5umkGouOXOR9y0n613ZwQ==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/fs-extra@9.0.13: @@ -3562,7 +3565,7 @@ packages: /@types/is-buffer@2.0.2: resolution: {integrity: sha512-G6OXy83Va+xEo8XgqAJYOuvOMxeey9xM5XKkvwJNmN8rVdcB+r15HvHsG86hl86JvU0y1aa7Z2ERkNFYWw9ySg==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/istanbul-lib-coverage@2.0.6: @@ -3580,19 +3583,19 @@ packages: /@types/jsonfile@6.1.4: resolution: {integrity: sha512-D5qGUYwjvnNNextdU59/+fI+spnwtTFmyQP0h+PfIOSkNfpU6AOICUOkm4i0OnSk+NyjdPJrxCDro0sJsWlRpQ==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/jsonwebtoken@9.0.6: resolution: {integrity: sha512-/5hndP5dCjloafCXns6SZyESp3Ldq7YjH3zwzwczYnjxIT0Fqzk5ROSYVGfFyczIue7IUEj8hkvLbPoLQ18vQw==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/jws@3.2.9: resolution: {integrity: sha512-xAqC7PI7QSBY3fXV1f2pbcdbBFoR4dF8+lH2z6MfZQVcGe14twYVfjzJ3CHhLS1NHxE+DnjUR5xaHu2/U9GGaQ==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/linkify-it@3.0.5: @@ -3646,7 +3649,7 @@ packages: /@types/mysql@2.15.22: resolution: {integrity: sha512-wK1pzsJVVAjYCSZWQoWHziQZbNggXFDUEIGf54g4ZM/ERuP86uGdWeKZWMYlqTPMZfHJJvLPyogXGvCOg87yLQ==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/node-fetch@2.6.11: @@ -3681,7 +3684,7 @@ packages: /@types/pg@8.6.1: resolution: {integrity: sha512-1Kc4oAGzAl7uqUStZCDvaLFqZrW9qWSjXOmBfdgyBP5La7Us6Mg4GBvRlSoaZMhQF/zSj1C8CtKMBkoiT8eL8w==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 pg-protocol: 1.6.1 pg-types: 2.2.0 dev: false @@ -3701,7 +3704,7 @@ packages: /@types/readdir-glob@1.1.5: resolution: {integrity: sha512-raiuEPUYqXu+nvtY2Pe8s8FEmZ3x5yAH4VkLdihcPdalvsHltomrRC9BzuStrJ9yk06470hS0Crw0f1pXqD+Hg==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/resolve@1.20.2: @@ -3748,13 +3751,13 @@ packages: /@types/stoppable@1.1.3: resolution: {integrity: sha512-7wGKIBJGE4ZxFjk9NkjAxZMLlIXroETqP1FJCdoSvKmEznwmBxQFmTB1dsCkAvVcNemuSZM5qkkd9HE/NL2JTw==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/through@0.0.33: resolution: {integrity: sha512-HsJ+z3QuETzP3cswwtzt2vEIiHBk/dCcHGhbmG5X3ecnwFD/lPrMpliGXxSCg03L9AhrdwA4Oz/qfspkDW+xGQ==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/trusted-types@2.0.7: @@ -3782,7 +3785,7 @@ packages: /@types/ws@7.4.7: resolution: {integrity: sha512-JQbbmxZTZehdc2iszGKs5oC3NFnjeay7mtAWrdt7qNtAVK0g19muApzAy4bm9byz79xa2ZnO/BOBC2R8RC5Lww==} dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false /@types/ws@8.5.10: @@ -3805,7 +3808,7 @@ packages: resolution: {integrity: sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==} requiresBuild: true dependencies: - '@types/node': 18.19.28 + '@types/node': 20.10.8 dev: false optional: true @@ -5420,7 +5423,7 @@ packages: dependencies: '@types/cookie': 0.4.1 '@types/cors': 2.8.17 - '@types/node': 18.19.28 + '@types/node': 20.10.8 accepts: 1.3.8 base64id: 2.0.0 cookie: 0.4.2 @@ -10200,8 +10203,8 @@ packages: hasBin: true dev: false - /typescript@5.4.3: - resolution: {integrity: sha512-KrPd3PKaCLr78MalgiwJnA25Nm8HAmdwN3mYUYZgG/wizIo9EainNVQI9/yDavtVFRN2h3k8uf3GLHuhDMgEHg==} + /typescript@5.4.4: + resolution: {integrity: sha512-dGE2Vv8cpVvw28v8HCPqyb08EzbBURxDpuhJvTrusShUfGnhHBafDsLdS1EhhxyL6BJQE+2cT3dDPAv+MQ6oLw==} engines: {node: '>=14.17'} hasBin: true dev: false @@ -19600,6 +19603,44 @@ packages: - utf-8-validate dev: false + file:projects/defender-easm-rest.tgz: + resolution: {integrity: sha512-HcIt/VgNdcthkmjIQbnEErYzJ4TyXBqwGAD0U+CZoT094yPnNhfcy09fPv56p+DYe0egoQqrA5x0EyoZc+pVRg==, tarball: file:projects/defender-easm-rest.tgz} + name: '@rush-temp/defender-easm-rest' + version: 0.0.0 + dependencies: + '@azure-tools/test-credential': 1.0.4 + '@azure-tools/test-recorder': 3.1.0 + '@azure/identity': 4.0.1 + '@microsoft/api-extractor': 7.43.0(@types/node@18.19.28) + '@types/node': 18.19.28 + '@vitest/browser': 1.4.0(playwright@1.42.1)(vitest@1.4.0) + '@vitest/coverage-istanbul': 1.4.0(vitest@1.4.0) + dotenv: 16.4.5 + eslint: 8.57.0 + mkdirp: 2.1.6 + playwright: 1.42.1 + prettier: 3.2.5 + rimraf: 5.0.5 + tshy: 1.13.0 + tslib: 2.6.2 + typescript: 5.3.3 + vitest: 1.4.0(@types/node@18.19.28)(@vitest/browser@1.4.0) + transitivePeerDependencies: + - '@edge-runtime/vm' + - '@vitest/ui' + - happy-dom + - jsdom + - less + - lightningcss + - safaridriver + - sass + - stylus + - sugarss + - supports-color + - terser + - webdriverio + dev: false + file:projects/defender-easm.tgz: resolution: {integrity: sha512-s7Y3F3WXQJaN8sBsvXliq93GUo1OKdVJTTVHL7r3yJZC88EjUI3auYZPBU8bGN1techInAXQbLD1dVZVATtiWQ==, tarball: file:projects/defender-easm.tgz} name: '@rush-temp/defender-easm' @@ -19651,7 +19692,7 @@ packages: name: '@rush-temp/dev-tool' version: 0.0.0 dependencies: - '@_ts/max': /typescript@5.4.3 + '@_ts/max': /typescript@5.4.4 '@_ts/min': /typescript@4.2.4 '@microsoft/api-extractor': 7.43.0(@types/node@18.19.28) '@rollup/plugin-commonjs': 25.0.7(rollup@4.13.2) @@ -20254,7 +20295,7 @@ packages: dev: false file:projects/identity-broker.tgz: - resolution: {integrity: sha512-vx9xKcy+ZhlA5PuFj3b7Wy96HXvMEp7BQ/NHiT+iIVUcMhrp6n40MuaPGh0dxLS/2XQnLLLmu1L7BHH0Gtqqaw==, tarball: file:projects/identity-broker.tgz} + resolution: {integrity: sha512-/1yRGPEHyWuO8GlEku4koWnbUYXwSdeA35zFn8p+U1YmNPSdDgz/0E/1/mw+Q3++Kpc9lbOeHFwxZ1dE/HrT0g==, tarball: file:projects/identity-broker.tgz} name: '@rush-temp/identity-broker' version: 0.0.0 dependencies: @@ -20282,7 +20323,7 @@ packages: dev: false file:projects/identity-cache-persistence.tgz: - resolution: {integrity: sha512-nvsuxkC8hNuUFrT4Hoxkuz10oArGS3SUs0Ssaq9hICOrUJdNcFEjRlgYRiPqpuM3oxC/HEBZ9AE5ppVHOCEcSg==, tarball: file:projects/identity-cache-persistence.tgz} + resolution: {integrity: sha512-Xxl1uL7DnRM0WyFOUhr11fyMK6M5H+693acw72m1AhOUbQ+rbDYWtWPJ8gpPxkSpoad2WQ74Bp5XWL3K3EyAyw==, tarball: file:projects/identity-cache-persistence.tgz} name: '@rush-temp/identity-cache-persistence' version: 0.0.0 dependencies: @@ -20318,7 +20359,7 @@ packages: dev: false file:projects/identity-vscode.tgz: - resolution: {integrity: sha512-LEj3TH59TnCC5VMd+EEm1lsbPq92b2MZWzMUQclrt69cNc/fR5wueyWkDVKUeIpL3juf9gIaDlTAW6TARoV6qQ==, tarball: file:projects/identity-vscode.tgz} + resolution: {integrity: sha512-4HZqGJZyak/tpbtgUeuajlrZ95S9q61bfAWy1kdmDMYWAhAmchZJTjBA4XI1kwqLnxCgxC1xQWyWYyz1O5i4pQ==, tarball: file:projects/identity-vscode.tgz} name: '@rush-temp/identity-vscode' version: 0.0.0 dependencies: diff --git a/rush.json b/rush.json index 931678c59c33..0eef7e8ee85a 100644 --- a/rush.json +++ b/rush.json @@ -1,7 +1,7 @@ /** * This is the main configuration file for Rush. * For full documentation, please see https://rushjs.io - */ { + */{ "$schema": "https://developer.microsoft.com/json-schemas/rush/v5/rush.schema.json", /** * (Required) This specifies the version of the Rush engine to be used in this repo. @@ -633,7 +633,9 @@ { "packageName": "@azure/identity", "projectFolder": "sdk/identity/identity", - "decoupledLocalDependencies": ["@azure/keyvault-keys"], + "decoupledLocalDependencies": [ + "@azure/keyvault-keys" + ], "versionPolicyName": "client" }, { @@ -2205,6 +2207,11 @@ "packageName": "@azure/arm-storageactions", "projectFolder": "sdk/storageactions/arm-storageactions", "versionPolicyName": "management" + }, + { + "packageName": "@azure-rest/defender-easm-rest", + "projectFolder": "sdk/easm/defendereasm-rest", + "versionPolicyName": "client" } ] -} +} \ No newline at end of file diff --git a/sdk/easm/ci.yml b/sdk/easm/ci.yml index 9cdf7397ee28..36f343190f98 100644 --- a/sdk/easm/ci.yml +++ b/sdk/easm/ci.yml @@ -1,5 +1,5 @@ # NOTE: Please refer to https://aka.ms/azsdk/engsys/ci-yaml before editing this file. - + trigger: branches: include: @@ -9,7 +9,6 @@ trigger: paths: include: - sdk/iot/ - pr: branches: include: @@ -17,10 +16,11 @@ pr: - feature/* - release/* - hotfix/* + exclude: + - feature/v4 paths: include: - sdk/easm/ - extends: template: ../../eng/pipelines/templates/stages/archetype-sdk-client.yml parameters: @@ -28,3 +28,5 @@ extends: Artifacts: - name: azure-rest-defender-easm safeName: azurerestdefendereasm + - name: azure-rest-defender-easm-rest + safeName: azurerestdefendereasmrest diff --git a/sdk/easm/defendereasm-rest/.eslintrc.json b/sdk/easm/defendereasm-rest/.eslintrc.json new file mode 100644 index 000000000000..619797ac39b6 --- /dev/null +++ b/sdk/easm/defendereasm-rest/.eslintrc.json @@ -0,0 +1,11 @@ +{ + "plugins": ["@azure/azure-sdk"], + "extends": ["plugin:@azure/azure-sdk/azure-sdk-base"], + "rules": { + "@azure/azure-sdk/ts-modules-only-named": "warn", + "@azure/azure-sdk/ts-apiextractor-json-types": "warn", + "@azure/azure-sdk/ts-package-json-types": "warn", + "@azure/azure-sdk/ts-package-json-engine-is-present": "warn", + "tsdoc/syntax": "warn" + } +} diff --git a/sdk/easm/defendereasm-rest/.tshy/browser.json b/sdk/easm/defendereasm-rest/.tshy/browser.json new file mode 100644 index 000000000000..32e74e04ec62 --- /dev/null +++ b/sdk/easm/defendereasm-rest/.tshy/browser.json @@ -0,0 +1,12 @@ +{ + "extends": "./build.json", + "include": [ + "../src/**/*.ts", + "../src/**/*.mts", + "../src/**/*.tsx" + ], + "exclude": [], + "compilerOptions": { + "outDir": "../.tshy-build/browser" + } +} diff --git a/sdk/easm/defendereasm-rest/.tshy/build.json b/sdk/easm/defendereasm-rest/.tshy/build.json new file mode 100644 index 000000000000..aea1a9e93b5d --- /dev/null +++ b/sdk/easm/defendereasm-rest/.tshy/build.json @@ -0,0 +1,8 @@ +{ + "extends": "../tsconfig.json", + "compilerOptions": { + "rootDir": "../src", + "module": "nodenext", + "moduleResolution": "nodenext" + } +} diff --git a/sdk/easm/defendereasm-rest/.tshy/commonjs.json b/sdk/easm/defendereasm-rest/.tshy/commonjs.json new file mode 100644 index 000000000000..5ace94d041f3 --- /dev/null +++ b/sdk/easm/defendereasm-rest/.tshy/commonjs.json @@ -0,0 +1,14 @@ +{ + "extends": "./build.json", + "include": [ + "../src/**/*.ts", + "../src/**/*.cts", + "../src/**/*.tsx" + ], + "exclude": [ + "../src/**/*.mts" + ], + "compilerOptions": { + "outDir": "../.tshy-build/commonjs" + } +} diff --git a/sdk/easm/defendereasm-rest/.tshy/esm.json b/sdk/easm/defendereasm-rest/.tshy/esm.json new file mode 100644 index 000000000000..ff5264e692d1 --- /dev/null +++ b/sdk/easm/defendereasm-rest/.tshy/esm.json @@ -0,0 +1,12 @@ +{ + "extends": "./build.json", + "include": [ + "../src/**/*.ts", + "../src/**/*.mts", + "../src/**/*.tsx" + ], + "exclude": [], + "compilerOptions": { + "outDir": "../.tshy-build/esm" + } +} diff --git a/sdk/easm/defendereasm-rest/.tshy/react-native.json b/sdk/easm/defendereasm-rest/.tshy/react-native.json new file mode 100644 index 000000000000..f431a06985d8 --- /dev/null +++ b/sdk/easm/defendereasm-rest/.tshy/react-native.json @@ -0,0 +1,12 @@ +{ + "extends": "./build.json", + "include": [ + "../src/**/*.ts", + "../src/**/*.mts", + "../src/**/*.tsx" + ], + "exclude": [], + "compilerOptions": { + "outDir": "../.tshy-build/react-native" + } +} diff --git a/sdk/easm/defendereasm-rest/README.md b/sdk/easm/defendereasm-rest/README.md new file mode 100644 index 000000000000..63dadc9ac7d2 --- /dev/null +++ b/sdk/easm/defendereasm-rest/README.md @@ -0,0 +1,57 @@ +# Azure DefenderEasm REST client library for JavaScript + +Defender EASM discovers and maps your digital attack surface to provide an "outside-in" perspective using probes to discover assets. The assets are provided with detailed metadata associated, including vulnerabilities, configurations and web components, allowing customers to view and prioritize external risk. The EASM REST API enables you to develop clients that integrate with your application. + +**Please rely heavily on our [REST client docs](https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/rest-clients.md) to use this library** + +Key links: + +- [Package (NPM)](https://www.npmjs.com/package/@azure-rest/defender-easm-rest) +- [API reference documentation](https://docs.microsoft.com/javascript/api/@azure-rest/defender-easm-rest?view=azure-node-preview) + +## Getting started + +### Currently supported environments + +- LTS versions of Node.js + +### Prerequisites + +- You must have an [Azure subscription](https://azure.microsoft.com/free/) to use this package. + +### Install the `@azure-rest/defender-easm-rest` package + +Install the Azure DefenderEasm REST client REST client library for JavaScript with `npm`: + +```bash +npm install @azure-rest/defender-easm-rest +``` + +### Create and authenticate a `EasmServiceClient` + +To use an [Azure Active Directory (AAD) token credential](https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/identity/identity/samples/AzureIdentityExamples.md#authenticating-with-a-pre-fetched-access-token), +provide an instance of the desired credential type obtained from the +[@azure/identity](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#credentials) library. + +To authenticate with AAD, you must first `npm` install [`@azure/identity`](https://www.npmjs.com/package/@azure/identity) + +After setup, you can choose which type of [credential](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#credentials) from `@azure/identity` to use. +As an example, [DefaultAzureCredential](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#defaultazurecredential) +can be used to authenticate the client. + +Set the values of the client ID, tenant ID, and client secret of the AAD application as environment variables: +AZURE_CLIENT_ID, AZURE_TENANT_ID, AZURE_CLIENT_SECRET + +## Troubleshooting + +### Logging + +Enabling logging may help uncover useful information about failures. In order to see a log of HTTP requests and responses, set the `AZURE_LOG_LEVEL` environment variable to `info`. Alternatively, logging can be enabled at runtime by calling `setLogLevel` in the `@azure/logger`: + +```javascript +const { setLogLevel } = require("@azure/logger"); + +setLogLevel("info"); +``` + +For more detailed instructions on how to enable logs, you can look at the [@azure/logger package docs](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/core/logger). diff --git a/sdk/easm/defendereasm-rest/api-extractor.json b/sdk/easm/defendereasm-rest/api-extractor.json new file mode 100644 index 000000000000..839dcd9cc6e8 --- /dev/null +++ b/sdk/easm/defendereasm-rest/api-extractor.json @@ -0,0 +1,18 @@ +{ + "$schema": "https://developer.microsoft.com/json-schemas/api-extractor/v7/api-extractor.schema.json", + "mainEntryPointFilePath": "./dist/esm/index.d.ts", + "docModel": { "enabled": true }, + "apiReport": { "enabled": true, "reportFolder": "./review" }, + "dtsRollup": { + "enabled": true, + "untrimmedFilePath": "", + "publicTrimmedFilePath": "./types/defender-easm-rest.d.ts" + }, + "messages": { + "tsdocMessageReporting": { "default": { "logLevel": "none" } }, + "extractorMessageReporting": { + "ae-missing-release-tag": { "logLevel": "none" }, + "ae-unresolved-link": { "logLevel": "none" } + } + } +} diff --git a/sdk/easm/defendereasm-rest/karma.conf.js b/sdk/easm/defendereasm-rest/karma.conf.js new file mode 100644 index 000000000000..a9d5f1b5fc59 --- /dev/null +++ b/sdk/easm/defendereasm-rest/karma.conf.js @@ -0,0 +1,133 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +// https://github.com/karma-runner/karma-chrome-launcher +process.env.CHROME_BIN = require("puppeteer").executablePath(); +require("dotenv").config(); +const { relativeRecordingsPath } = require("@azure-tools/test-recorder"); +process.env.RECORDINGS_RELATIVE_PATH = relativeRecordingsPath(); + +module.exports = function (config) { + config.set({ + // base path that will be used to resolve all patterns (eg. files, exclude) + basePath: "./", + + // frameworks to use + // available frameworks: https://npmjs.org/browse/keyword/karma-adapter + frameworks: ["source-map-support", "mocha"], + + plugins: [ + "karma-mocha", + "karma-mocha-reporter", + "karma-chrome-launcher", + "karma-firefox-launcher", + "karma-env-preprocessor", + "karma-coverage", + "karma-sourcemap-loader", + "karma-junit-reporter", + "karma-source-map-support", + ], + + // list of files / patterns to load in the browser + files: [ + "dist-test/index.browser.js", + { + pattern: "dist-test/index.browser.js.map", + type: "html", + included: false, + served: true, + }, + ], + + // list of files / patterns to exclude + exclude: [], + + // preprocess matching files before serving them to the browser + // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor + preprocessors: { + "**/*.js": ["sourcemap", "env"], + // IMPORTANT: COMMENT following line if you want to debug in your browsers!! + // Preprocess source file to calculate code coverage, however this will make source file unreadable + // "dist-test/index.js": ["coverage"] + }, + + envPreprocessor: [ + "TEST_MODE", + "ENDPOINT", + "AZURE_CLIENT_SECRET", + "AZURE_CLIENT_ID", + "AZURE_TENANT_ID", + "SUBSCRIPTION_ID", + "RECORDINGS_RELATIVE_PATH", + ], + + // test results reporter to use + // possible values: 'dots', 'progress' + // available reporters: https://npmjs.org/browse/keyword/karma-reporter + reporters: ["mocha", "coverage", "junit"], + + coverageReporter: { + // specify a common output directory + dir: "coverage-browser/", + reporters: [ + { type: "json", subdir: ".", file: "coverage.json" }, + { type: "lcovonly", subdir: ".", file: "lcov.info" }, + { type: "html", subdir: "html" }, + { type: "cobertura", subdir: ".", file: "cobertura-coverage.xml" }, + ], + }, + + junitReporter: { + outputDir: "", // results will be saved as $outputDir/$browserName.xml + outputFile: "test-results.browser.xml", // if included, results will be saved as $outputDir/$browserName/$outputFile + suite: "", // suite will become the package name attribute in xml testsuite element + useBrowserName: false, // add browser name to report and classes names + nameFormatter: undefined, // function (browser, result) to customize the name attribute in xml testcase element + classNameFormatter: undefined, // function (browser, result) to customize the classname attribute in xml testcase element + properties: {}, // key value pair of properties to add to the section of the report + }, + + // web server port + port: 9876, + + // enable / disable colors in the output (reporters and logs) + colors: true, + + // level of logging + // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG + logLevel: config.LOG_INFO, + + // enable / disable watching file and executing tests whenever any file changes + autoWatch: false, + + // --no-sandbox allows our tests to run in Linux without having to change the system. + // --disable-web-security allows us to authenticate from the browser without having to write tests using interactive auth, which would be far more complex. + browsers: ["ChromeHeadlessNoSandbox"], + customLaunchers: { + ChromeHeadlessNoSandbox: { + base: "ChromeHeadless", + flags: ["--no-sandbox", "--disable-web-security"], + }, + }, + + // Continuous Integration mode + // if true, Karma captures browsers, runs the tests and exits + singleRun: false, + + // Concurrency level + // how many browser should be started simultaneous + concurrency: 1, + + browserNoActivityTimeout: 60000000, + browserDisconnectTimeout: 10000, + browserDisconnectTolerance: 3, + + client: { + mocha: { + // change Karma's debug.html to the mocha web reporter + reporter: "html", + timeout: "600000", + }, + }, + }); +}; diff --git a/sdk/easm/defendereasm-rest/package.json b/sdk/easm/defendereasm-rest/package.json new file mode 100644 index 000000000000..96a0dd2aec2b --- /dev/null +++ b/sdk/easm/defendereasm-rest/package.json @@ -0,0 +1,133 @@ +{ + "name": "@azure-rest/defender-easm-rest", + "version": "1.0.0-beta.1", + "description": "A generated SDK for EasmService.", + "engines": { + "node": ">=18.0.0" + }, + "sideEffects": false, + "autoPublish": false, + "tshy": { + "exports": { + "./package.json": "./package.json", + ".": "./src/index.ts" + }, + "dialects": [ + "esm", + "commonjs" + ], + "esmDialects": [ + "browser", + "react-native" + ], + "selfLink": false + }, + "type": "module", + "keywords": [ + "node", + "azure", + "cloud", + "typescript", + "browser", + "isomorphic" + ], + "author": "Microsoft Corporation", + "license": "MIT", + "files": [ + "dist", + "README.md", + "LICENSE", + "review/*" + ], + "sdk-type": "client", + "repository": "github:Azure/azure-sdk-for-js", + "bugs": { + "url": "https://github.com/Azure/azure-sdk-for-js/issues" + }, + "prettier": "@azure/eslint-plugin-azure-sdk/prettier.json", + "//metadata": { + "constantPaths": [ + { + "path": "src/easmService.ts", + "prefix": "package-version" + } + ] + }, + "dependencies": { + "@azure-rest/core-client": "^1.2.0", + "@azure/core-auth": "^1.6.0", + "@azure/core-rest-pipeline": "^1.5.0", + "@azure/logger": "^1.0.0", + "tslib": "^2.6.2", + "@azure/core-paging": "^1.5.0" + }, + "devDependencies": { + "dotenv": "^16.0.0", + "@microsoft/api-extractor": "^7.40.3", + "@types/node": "^18.0.0", + "eslint": "^8.55.0", + "prettier": "^3.2.5", + "rimraf": "^5.0.5", + "mkdirp": "^3.0.1", + "typescript": "~5.3.3", + "tshy": "^1.11.1", + "@azure/core-util": "^1.0.0", + "@azure-tools/test-credential": "^1.0.0", + "@azure/identity": "^4.0.1", + "@azure-tools/test-recorder": "^3.0.0", + "@vitest/browser": "^1.3.1", + "@vitest/coverage-istanbul": "^1.3.1", + "playwright": "^1.41.2", + "vitest": "^1.3.1", + "@azure/dev-tool": "^1.0.0", + "@azure/eslint-plugin-azure-sdk": "^3.0.0" + }, + "scripts": { + "clean": "rimraf --glob dist dist-browser dist-esm test-dist temp types *.tgz *.log", + "extract-api": "rimraf review && mkdirp ./review && api-extractor run --local", + "pack": "npm pack 2>&1", + "lint": "eslint package.json api-extractor.json src test --ext .ts --ext .cts --ext .mts", + "lint:fix": "eslint package.json api-extractor.json src test --ext .ts --ext .cts --ext .mts --fix --fix-type [problem,suggestion]", + "unit-test": "npm run unit-test:node && npm run unit-test:browser", + "unit-test:browser": "npm run build:test && dev-tool run test:vitest --no-test-proxy --browser", + "unit-test:node": "dev-tool run test:vitest --no-test-proxy", + "integration-test": "npm run integration-test:node && npm run integration-test:browser", + "integration-test:browser": "echo skipped", + "integration-test:node": "echo skipped", + "audit": "node ../../../common/scripts/rush-audit.js && rimraf node_modules package-lock.json && npm i --package-lock-only 2>&1 && npm audit", + "build:samples": "dev-tool samples publish --force", + "check-format": "dev-tool run vendored prettier --list-different --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.{ts,cts,mts}\" \"test/**/*.{ts,cts,mts}\" \"*.{js,cjs,mjs,json}\"", + "execute:samples": "dev-tool samples run samples-dev", + "format": "dev-tool run vendored prettier --write --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.{ts,cts,mts}\" \"test/**/*.{ts,cts,mts}\" \"*.{js,cjs,mjs,json}\"", + "generate:client": "echo skipped", + "test:browser": "npm run clean && npm run build:test && npm run unit-test:browser && npm run integration-test:browser", + "minify": "uglifyjs -c -m --comments --source-map \"content='./dist/index.js.map'\" -o ./dist/index.min.js ./dist/index.js", + "build:test": "npm run clean && tshy && dev-tool run build-test", + "build": "npm run clean && tshy && mkdirp ./review && api-extractor run --local", + "test:node": "npm run clean && tshy && npm run unit-test:node && npm run integration-test:node", + "test": "npm run clean && tshy && npm run unit-test:node && dev-tool run bundle && npm run unit-test:browser && npm run integration-test" + }, + "exports": { + "./package.json": "./package.json", + ".": { + "browser": { + "types": "./dist/browser/index.d.ts", + "default": "./dist/browser/index.js" + }, + "react-native": { + "types": "./dist/react-native/index.d.ts", + "default": "./dist/react-native/index.js" + }, + "import": { + "types": "./dist/esm/index.d.ts", + "default": "./dist/esm/index.js" + }, + "require": { + "types": "./dist/commonjs/index.d.ts", + "default": "./dist/commonjs/index.js" + } + } + }, + "main": "./dist/commonjs/index.js", + "types": "./dist/commonjs/index.d.ts" +} diff --git a/sdk/easm/defendereasm-rest/review/defender-easm-rest.api.md b/sdk/easm/defendereasm-rest/review/defender-easm-rest.api.md new file mode 100644 index 000000000000..d58039ba3773 --- /dev/null +++ b/sdk/easm/defendereasm-rest/review/defender-easm-rest.api.md @@ -0,0 +1,3258 @@ +## API Report File for "@azure-rest/defender-easm-rest" + +> Do not edit this file. It is a report generated by [API Extractor](https://api-extractor.com/). + +```ts + +import { Client } from '@azure-rest/core-client'; +import { ClientOptions } from '@azure-rest/core-client'; +import { ErrorResponse } from '@azure-rest/core-client'; +import { HttpResponse } from '@azure-rest/core-client'; +import { Paged } from '@azure/core-paging'; +import { PagedAsyncIterableIterator } from '@azure/core-paging'; +import { PathUncheckedResponse } from '@azure-rest/core-client'; +import { RawHttpHeaders } from '@azure/core-rest-pipeline'; +import { RequestParameters } from '@azure-rest/core-client'; +import { StreamableMethod } from '@azure-rest/core-client'; +import { TokenCredential } from '@azure/core-auth'; + +// @public (undocumented) +export interface AlexaInfoOutput { + // (undocumented) + alexaRank?: number; + // (undocumented) + category?: string; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + recent?: boolean; +} + +// @public (undocumented) +export interface AsAssetOutput extends InventoryAssetOutput { + // (undocumented) + adminContacts?: Array; + // (undocumented) + adminNames?: Array; + // (undocumented) + adminOrgs?: Array; + // (undocumented) + adminPhones?: Array; + // (undocumented) + asn?: number; + // (undocumented) + asNames?: Array; + // (undocumented) + count?: number; + // (undocumented) + countries?: Array; + // (undocumented) + detailedFromWhoisAt?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + orgIds?: Array; + // (undocumented) + orgNames?: Array; + // (undocumented) + registrantContacts?: Array; + // (undocumented) + registrantNames?: Array; + // (undocumented) + registrantPhones?: Array; + // (undocumented) + registrarCreatedAt?: Array; + // (undocumented) + registrarNames?: Array; + // (undocumented) + registrarUpdatedAt?: Array; + // (undocumented) + registries?: Array; + // (undocumented) + sources?: Array; + // (undocumented) + technicalContacts?: Array; + // (undocumented) + technicalNames?: Array; + // (undocumented) + technicalOrgs?: Array; + // (undocumented) + technicalPhones?: Array; +} + +// @public (undocumented) +export interface AsAssetResourceOutput extends AssetResourceOutputParent { + asset: AsAssetOutput; + kind: "as"; +} + +// @public +export interface AssetChainKindSummaryResponseOutput { + affectedCount: number; + kind: string; +} + +// @public +export interface AssetChainRequest { + assetChainSource?: string; + sourceIds?: string[]; +} + +// @public +export interface AssetChainSummaryResponseOutput { + affectedAssetsSummary: Array; + affectedGroupsSummary: Array; + errors?: Array; +} + +// @public +export interface AssetPageResultOutput { + mark?: string; + nextLink?: string; + totalElements?: number; + value?: Array; +} + +// @public +export type AssetResourceOutput = AssetResourceOutputParent | AsAssetResourceOutput | ContactAssetResourceOutput | DomainAssetResourceOutput | HostAssetResourceOutput | IpAddressAssetResourceOutput | IpBlockAssetResourceOutput | PageAssetResourceOutput | SslCertAssetResourceOutput; + +// @public +export interface AssetResourceOutputParent { + auditTrail?: Array; + createdDate?: string; + discoGroupName?: string; + displayName?: string; + externalId?: string; + readonly id: string; + // (undocumented) + kind: string; + labels?: string[]; + name?: string; + // (undocumented) + reason?: string; + state?: string; + updatedDate?: string; + uuid?: string; + wildcard?: boolean; +} + +// @public (undocumented) +export interface AssetSecurityPolicyOutput { + // (undocumented) + count?: number; + // (undocumented) + description?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + isAffected?: boolean; + // (undocumented) + lastSeen?: string; + // (undocumented) + policyName?: string; + // (undocumented) + recent?: boolean; + // (undocumented) + sources?: Array; +} + +// @public +export interface AssetSummaryResultOutput { + children?: Array; + count?: number; + description?: string; + displayName?: string; + filter?: string; + labelName?: string; + link?: string; + metric?: string; + metricCategory?: string; + updatedAt?: string; +} + +// @public +export interface AssetUpdateData { + externalId?: string; + labels?: TypeSpecRecord; + state?: string; + transfers?: string; +} + +// @public (undocumented) +export interface AttributeOutput { + // (undocumented) + attributeType?: string; + // (undocumented) + attributeValue?: string; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + recent?: boolean; + // (undocumented) + sources?: Array; +} + +// @public +export interface AuditTrailItemOutput { + displayName?: string; + id?: string; + kind?: string; + name?: string; + reason?: string; +} + +// @public (undocumented) +export interface AzureCoreTraitsOutput { +} + +// @public (undocumented) +export interface AzureDataExplorerDataConnectionData extends DataConnectionDataParent { + kind: "azureDataExplorer"; + properties: AzureDataExplorerDataConnectionProperties; +} + +// @public (undocumented) +export interface AzureDataExplorerDataConnectionOutput extends DataConnectionOutputParent { + kind: "azureDataExplorer"; + properties: AzureDataExplorerDataConnectionPropertiesOutput; +} + +// @public (undocumented) +export interface AzureDataExplorerDataConnectionProperties extends DataConnectionProperties { + clusterName?: string; + databaseName?: string; + region?: string; +} + +// @public (undocumented) +export interface AzureDataExplorerDataConnectionPropertiesOutput extends DataConnectionPropertiesOutput { + clusterName?: string; + databaseName?: string; + region?: string; +} + +// @public (undocumented) +export interface BannerOutput { + // (undocumented) + banner?: string; + // (undocumented) + bannerMetadata?: string; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + port?: number; + // (undocumented) + recent?: boolean; + // (undocumented) + scanType?: string; + // (undocumented) + sha256?: string; + // (undocumented) + sources?: Array; +} + +// @public (undocumented) +export interface CancelTask { + post(options?: CancelTaskParameters): StreamableMethod; +} + +// @public +export interface CancelTask200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface CancelTaskDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface CancelTaskDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & CancelTaskDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type CancelTaskParameters = RequestParameters; + +// @public +export interface CisaCveResponseOutput { + count: number; + readonly cveId: string; + dateAdded: string; + dueDate: string; + notes: string; + product: string; + requiredAction: string; + shortDescription: string; + updatedAt: string; + vendorProject: string; + vulnerabilityName: string; +} + +// @public (undocumented) +export interface ContactAssetOutput extends InventoryAssetOutput { + // (undocumented) + count?: number; + // (undocumented) + email?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + names?: Array; + // (undocumented) + organizations?: Array; + // (undocumented) + sources?: Array; +} + +// @public (undocumented) +export interface ContactAssetResourceOutput extends AssetResourceOutputParent { + asset: ContactAssetOutput; + kind: "contact"; +} + +// @public (undocumented) +export interface CookieOutput { + // (undocumented) + cookieDomain?: string; + // (undocumented) + cookieExpiryDate?: string; + // (undocumented) + cookieName?: string; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + recent?: boolean; +} + +// @public +function createClient(endpointParam: string, credentials: TokenCredential, options?: ClientOptions): EasmServiceClient; +export default createClient; + +// @public +export interface CreateOrReplaceDataConnection200Response extends HttpResponse { + // (undocumented) + body: DataConnectionOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface CreateOrReplaceDataConnectionBodyParam { + // (undocumented) + body?: DataConnectionData; +} + +// @public (undocumented) +export interface CreateOrReplaceDataConnectionDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface CreateOrReplaceDataConnectionDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & CreateOrReplaceDataConnectionDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type CreateOrReplaceDataConnectionParameters = CreateOrReplaceDataConnectionBodyParam & RequestParameters; + +// @public +export interface CreateOrReplaceDiscoGroup200Response extends HttpResponse { + // (undocumented) + body: DiscoGroupOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface CreateOrReplaceDiscoGroupBodyParam { + // (undocumented) + body?: DiscoGroupData; +} + +// @public (undocumented) +export interface CreateOrReplaceDiscoGroupDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface CreateOrReplaceDiscoGroupDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & CreateOrReplaceDiscoGroupDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type CreateOrReplaceDiscoGroupParameters = CreateOrReplaceDiscoGroupBodyParam & RequestParameters; + +// @public +export interface CreateOrReplaceSavedFilter200Response extends HttpResponse { + // (undocumented) + body: SavedFilterOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface CreateOrReplaceSavedFilterBodyParam { + // (undocumented) + body?: SavedFilterData; +} + +// @public (undocumented) +export interface CreateOrReplaceSavedFilterDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface CreateOrReplaceSavedFilterDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & CreateOrReplaceSavedFilterDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type CreateOrReplaceSavedFilterParameters = CreateOrReplaceSavedFilterBodyParam & RequestParameters; + +// @public (undocumented) +export interface CveOutput { + // (undocumented) + cvss3Summary?: Cvss3SummaryOutput; + // (undocumented) + cvssScore?: number; + // (undocumented) + cweId?: string; + // (undocumented) + name?: string; +} + +// @public (undocumented) +export interface Cvss3SummaryOutput { + // (undocumented) + attackComplexity?: string; + // (undocumented) + attackVector?: string; + // (undocumented) + availabilityImpact?: string; + // (undocumented) + baseScore?: number; + // (undocumented) + baseSeverity?: string; + // (undocumented) + confidentialityImpact?: string; + // (undocumented) + exploitabilityScore?: number; + // (undocumented) + exploitCodeMaturity?: string; + // (undocumented) + impactScore?: number; + // (undocumented) + integrityImpact?: string; + // (undocumented) + privilegesRequired?: string; + // (undocumented) + remediationLevel?: string; + // (undocumented) + reportConfidence?: string; + // (undocumented) + scope?: string; + // (undocumented) + userInteraction?: string; + // (undocumented) + vectorString?: string; + // (undocumented) + version?: string; +} + +// @public (undocumented) +export interface DailyDeltaTypeResponseOutput extends DeltaTypeResponseOutput { + count: number; +} + +// @public (undocumented) +export type DataConnectionData = DataConnectionDataParent | LogAnalyticsDataConnectionData | AzureDataExplorerDataConnectionData; + +// @public (undocumented) +export interface DataConnectionDataParent { + content?: string; + frequency?: string; + frequencyOffset?: number; + // (undocumented) + kind: string; + name?: string; +} + +// @public (undocumented) +export type DataConnectionOutput = DataConnectionOutputParent | LogAnalyticsDataConnectionOutput | AzureDataExplorerDataConnectionOutput; + +// @public (undocumented) +export interface DataConnectionOutputParent { + active?: boolean; + content?: string; + readonly createdDate?: string; + displayName?: string; + frequency?: string; + frequencyOffset?: number; + id?: string; + readonly inactiveMessage?: string; + // (undocumented) + kind: string; + readonly name: string; + readonly updatedDate?: string; + readonly userUpdatedAt?: string; +} + +// @public +export interface DataConnectionProperties { +} + +// @public +export interface DataConnectionPropertiesOutput { +} + +// @public +export interface DeleteDataConnection204Response extends HttpResponse { + // (undocumented) + status: "204"; +} + +// @public (undocumented) +export interface DeleteDataConnectionDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface DeleteDataConnectionDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & DeleteDataConnectionDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type DeleteDataConnectionParameters = RequestParameters; + +// @public +export interface DeleteSavedFilter204Response extends HttpResponse { + // (undocumented) + status: "204"; +} + +// @public (undocumented) +export interface DeleteSavedFilterDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface DeleteSavedFilterDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & DeleteSavedFilterDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type DeleteSavedFilterParameters = RequestParameters; + +// @public (undocumented) +export interface DeltaDateResponseOutput { + date: string; + deltas: Array; +} + +// @public (undocumented) +export interface DeltaPageResponseOutput { + nextLink?: string; + totalElements?: number; + value?: Array; +} + +// @public (undocumented) +export interface DeltaRangeResponseOutput { + added: number; + difference: number; + kindSummaries: Array; + range: number; + removed: number; +} + +// @public (undocumented) +export interface DeltaResponseOutput { + createdAt: string; + kind: string; + name: string; + state: string; + updatedAt: string; +} + +// @public (undocumented) +export interface DeltaSummaryResponseOutput { + daily: Array; + summary: DeltaRangeResponseOutput; +} + +// @public (undocumented) +export interface DeltaTypeResponseOutput { + added: number; + difference: number; + kind: string; + removed: number; +} + +// @public (undocumented) +export interface DependentResourceOutput { + // (undocumented) + cached?: boolean; + // (undocumented) + contentType?: string; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + firstSeenCrawlGuid?: string; + // (undocumented) + firstSeenPageGuid?: string; + // (undocumented) + firstSeenResourceGuid?: string; + // (undocumented) + host?: string; + // (undocumented) + lastObservedActualSriHash?: string; + // (undocumented) + lastObservedExpectedSriHash?: string; + // (undocumented) + lastObservedValidation?: string; + // (undocumented) + lastObservedViolation?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + lastSeenCrawlGuid?: string; + // (undocumented) + lastSeenPageGuid?: string; + // (undocumented) + lastSeenResourceGuid?: string; + // (undocumented) + md5?: string; + // (undocumented) + responseBodyMinhash?: number[]; + // (undocumented) + responseBodySize?: number; + // (undocumented) + sha256?: string; + // (undocumented) + sha384?: string; + // (undocumented) + sha512?: string; + // (undocumented) + sriChecks?: Array; + // (undocumented) + url?: string; +} + +// @public +export interface DiscoGroupData { + description?: string; + excludes?: Array; + frequencyMilliseconds?: number; + name?: string; + names?: string[]; + seeds?: Array; + templateId?: string; + tier?: string; +} + +// @public (undocumented) +export interface DiscoGroupOutput { + createdDate?: string; + description?: string; + displayName?: string; + excludes?: Array; + frequencyMilliseconds?: number; + id?: string; + latestRun?: DiscoRunResultOutput; + readonly name: string; + names?: string[]; + seeds?: Array; + templateId?: string; + tier?: string; +} + +// @public +export interface DiscoGroupSummaryResponseOutput { + displayName: string; + id: string; + name: string; +} + +// @public (undocumented) +export interface DiscoRunPageResultOutput { + nextLink?: string; + totalElements?: number; + value?: Array; +} + +// @public +export interface DiscoRunResultOutput { + completedDate?: string; + excludes?: Array; + names?: string[]; + seeds?: Array; + startedDate?: string; + state?: string; + submittedDate?: string; + tier?: string; + totalAssetsFoundCount?: number; +} + +// @public +export interface DiscoSource { + kind?: string; + name?: string; +} + +// @public +export interface DiscoSourceOutput { + kind?: string; + name?: string; +} + +// @public +export interface DiscoTemplateOutput { + city?: string; + countryCode?: string; + displayName?: string; + readonly id: string; + industry?: string; + name?: string; + names?: string[]; + region?: string; + seeds?: Array; + stateCode?: string; +} + +// @public (undocumented) +export interface DismissAssetChain { + post(options?: DismissAssetChainParameters): StreamableMethod; +} + +// @public +export interface DismissAssetChain200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface DismissAssetChainDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface DismissAssetChainDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & DismissAssetChainDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type DismissAssetChainParameters = RequestParameters; + +// @public (undocumented) +export interface DismissSeedChain { + post(options?: DismissSeedChainParameters): StreamableMethod; +} + +// @public +export interface DismissSeedChain200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface DismissSeedChainBodyParam { + // (undocumented) + body?: AssetChainRequest; +} + +// @public (undocumented) +export interface DismissSeedChainDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface DismissSeedChainDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & DismissSeedChainDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type DismissSeedChainParameters = DismissSeedChainBodyParam & RequestParameters; + +// @public (undocumented) +export interface DomainAssetOutput { + // (undocumented) + adminContacts?: Array; + // (undocumented) + adminNames?: Array; + // (undocumented) + adminOrgs?: Array; + // (undocumented) + adminPhones?: Array; + // (undocumented) + alexaInfos?: Array; + // (undocumented) + count?: number; + // (undocumented) + detailedFromWhoisAt?: string; + // (undocumented) + domain?: string; + // (undocumented) + domainStatuses?: Array; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + mailServers?: Array; + // (undocumented) + nameServers?: Array; + // (undocumented) + parkedDomain?: Array; + // (undocumented) + registrantContacts?: Array; + // (undocumented) + registrantNames?: Array; + // (undocumented) + registrantOrgs?: Array; + // (undocumented) + registrantPhones?: Array; + // (undocumented) + registrarCreatedAt?: Array; + // (undocumented) + registrarExpiresAt?: Array; + // (undocumented) + registrarIanaIds?: Array; + // (undocumented) + registrarNames?: Array; + // (undocumented) + registrarUpdatedAt?: Array; + // (undocumented) + soaRecords?: Array; + // (undocumented) + sources?: Array; + // (undocumented) + technicalContacts?: Array; + // (undocumented) + technicalNames?: Array; + // (undocumented) + technicalOrgs?: Array; + // (undocumented) + technicalPhones?: Array; + // (undocumented) + whoisId?: number; + // (undocumented) + whoisServers?: Array; +} + +// @public (undocumented) +export interface DomainAssetResourceOutput extends AssetResourceOutputParent { + asset: DomainAssetOutput; + kind: "domain"; +} + +// @public (undocumented) +export interface DownloadTask { + post(options?: DownloadTaskParameters): StreamableMethod; +} + +// @public +export interface DownloadTask200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface DownloadTaskDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface DownloadTaskDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & DownloadTaskDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type DownloadTaskParameters = RequestParameters; + +// @public (undocumented) +export type EasmServiceClient = Client & { + path: Routes; +}; + +// @public +export interface ErrorDetailOutput { + code: string; + details?: Array; + innererror?: InnerErrorOutput; + message: string; + target?: string; +} + +// @public +export type GetArrayType = T extends Array ? TData : never; + +// @public (undocumented) +export interface GetAssetChainSummary { + post(options?: GetAssetChainSummaryParameters): StreamableMethod; +} + +// @public +export interface GetAssetChainSummary200Response extends HttpResponse { + // (undocumented) + body: AssetChainSummaryResponseOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetAssetChainSummaryBodyParam { + // (undocumented) + body?: AssetChainRequest; +} + +// @public (undocumented) +export interface GetAssetChainSummaryDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetAssetChainSummaryDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetAssetChainSummaryDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetAssetChainSummaryParameters = GetAssetChainSummaryBodyParam & RequestParameters; + +// @public (undocumented) +export interface GetAssetResource { + get(options?: GetAssetResourceParameters): StreamableMethod; +} + +// @public +export interface GetAssetResource200Response extends HttpResponse { + // (undocumented) + body: AssetResourceOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetAssetResourceDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetAssetResourceDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetAssetResourceDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetAssetResourceParameters = RequestParameters; + +// @public (undocumented) +export interface GetAssetsExport { + post(options?: GetAssetsExportParameters): StreamableMethod; +} + +// @public +export interface GetAssetsExport200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetAssetsExportDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetAssetsExportDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetAssetsExportDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetAssetsExportParameters = GetAssetsExportQueryParam & RequestParameters; + +// @public (undocumented) +export interface GetAssetsExportQueryParam { + // (undocumented) + queryParameters?: GetAssetsExportQueryParamProperties; +} + +// @public (undocumented) +export interface GetAssetsExportQueryParamProperties { + // (undocumented) + columns?: string[]; + // (undocumented) + fileName?: string; + filter?: string; + orderby?: string; +} + +// @public (undocumented) +export interface GetBillable { + post(options?: GetBillableParameters): StreamableMethod; +} + +// @public +export interface GetBillable200Response extends HttpResponse { + // (undocumented) + body: ReportBillableAssetSummaryResultOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetBillableDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetBillableDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetBillableDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetBillableParameters = RequestParameters; + +// @public (undocumented) +export interface GetCisaCve { + get(options?: GetCisaCveParameters): StreamableMethod; +} + +// @public +export interface GetCisaCve200Response extends HttpResponse { + // (undocumented) + body: CisaCveResponseOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetCisaCveDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetCisaCveDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetCisaCveDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetCisaCveParameters = RequestParameters; + +// @public (undocumented) +export interface GetCisaCves { + get(options?: GetCisaCvesParameters): StreamableMethod; +} + +// @public +export interface GetCisaCves200Response extends HttpResponse { + // (undocumented) + body: PagedCisaCveResponseOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetCisaCvesDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetCisaCvesDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetCisaCvesDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetCisaCvesParameters = RequestParameters; + +// @public (undocumented) +export interface GetDataConnection { + delete(options?: DeleteDataConnectionParameters): StreamableMethod; + get(options?: GetDataConnectionParameters): StreamableMethod; + put(options?: CreateOrReplaceDataConnectionParameters): StreamableMethod; +} + +// @public +export interface GetDataConnection200Response extends HttpResponse { + // (undocumented) + body: DataConnectionOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetDataConnectionDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetDataConnectionDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetDataConnectionDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetDataConnectionParameters = RequestParameters; + +// @public (undocumented) +export interface GetDeltaDetails { + post(options?: GetDeltaDetailsParameters): StreamableMethod; +} + +// @public +export interface GetDeltaDetails200Response extends HttpResponse { + // (undocumented) + body: DeltaPageResponseOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetDeltaDetailsDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetDeltaDetailsDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetDeltaDetailsDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetDeltaDetailsParameters = GetDeltaDetailsQueryParam & RequestParameters; + +// @public (undocumented) +export interface GetDeltaDetailsQueryParam { + // (undocumented) + queryParameters?: GetDeltaDetailsQueryParamProperties; +} + +// @public (undocumented) +export interface GetDeltaDetailsQueryParamProperties { + date?: string; + // (undocumented) + daysPrior?: number; + deltaDetailType?: string; + kind?: string; + maxpagesize?: number; + skip?: number; +} + +// @public (undocumented) +export interface GetDeltaSummary { + post(options?: GetDeltaSummaryParameters): StreamableMethod; +} + +// @public +export interface GetDeltaSummary200Response extends HttpResponse { + // (undocumented) + body: DeltaSummaryResponseOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetDeltaSummaryDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetDeltaSummaryDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetDeltaSummaryDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetDeltaSummaryParameters = GetDeltaSummaryQueryParam & RequestParameters; + +// @public (undocumented) +export interface GetDeltaSummaryQueryParam { + // (undocumented) + queryParameters?: GetDeltaSummaryQueryParamProperties; +} + +// @public (undocumented) +export interface GetDeltaSummaryQueryParamProperties { + date?: string; + // (undocumented) + daysPrior?: number; +} + +// @public (undocumented) +export interface GetDiscoGroup { + get(options?: GetDiscoGroupParameters): StreamableMethod; + put(options?: CreateOrReplaceDiscoGroupParameters): StreamableMethod; +} + +// @public +export interface GetDiscoGroup200Response extends HttpResponse { + // (undocumented) + body: DiscoGroupOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetDiscoGroupDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetDiscoGroupDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetDiscoGroupDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetDiscoGroupParameters = RequestParameters; + +// @public (undocumented) +export interface GetDiscoTemplate { + get(options?: GetDiscoTemplateParameters): StreamableMethod; +} + +// @public +export interface GetDiscoTemplate200Response extends HttpResponse { + // (undocumented) + body: DiscoTemplateOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetDiscoTemplateDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetDiscoTemplateDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetDiscoTemplateDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetDiscoTemplateParameters = RequestParameters; + +// @public (undocumented) +export interface GetObservations { + post(options?: GetObservationsParameters): StreamableMethod; +} + +// @public +export interface GetObservations200Response extends HttpResponse { + // (undocumented) + body: ObservationPageResponseOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetObservationsDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetObservationsDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetObservationsDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetObservationsParameters = GetObservationsQueryParam & RequestParameters; + +// @public (undocumented) +export interface GetObservationsQueryParam { + // (undocumented) + queryParameters?: GetObservationsQueryParamProperties; +} + +// @public (undocumented) +export interface GetObservationsQueryParamProperties { + filter?: string; + maxpagesize?: number; + orderby?: string; + skip?: number; +} + +// @public +export type GetPage = (pageLink: string, maxPageSize?: number) => Promise<{ + page: TPage; + nextPageLink?: string; +}>; + +// @public (undocumented) +export interface GetSavedFilter { + delete(options?: DeleteSavedFilterParameters): StreamableMethod; + get(options?: GetSavedFilterParameters): StreamableMethod; + put(options?: CreateOrReplaceSavedFilterParameters): StreamableMethod; +} + +// @public +export interface GetSavedFilter200Response extends HttpResponse { + // (undocumented) + body: SavedFilterOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetSavedFilterDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetSavedFilterDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetSavedFilterDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetSavedFilterParameters = RequestParameters; + +// @public (undocumented) +export interface GetSnapshot { + post(options?: GetSnapshotParameters): StreamableMethod; +} + +// @public +export interface GetSnapshot200Response extends HttpResponse { + // (undocumented) + body: ReportAssetSnapshotResultOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetSnapshotBodyParam { + // (undocumented) + body?: ReportAssetSnapshotRequest; +} + +// @public (undocumented) +export interface GetSnapshotDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetSnapshotDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetSnapshotDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export interface GetSnapshotExport { + post(options?: GetSnapshotExportParameters): StreamableMethod; +} + +// @public +export interface GetSnapshotExport200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetSnapshotExportBodyParam { + // (undocumented) + body?: ReportAssetSnapshotExportRequest; +} + +// @public (undocumented) +export interface GetSnapshotExportDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetSnapshotExportDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetSnapshotExportDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetSnapshotExportParameters = GetSnapshotExportBodyParam & RequestParameters; + +// @public (undocumented) +export type GetSnapshotParameters = GetSnapshotBodyParam & RequestParameters; + +// @public (undocumented) +export interface GetSummary { + post(options?: GetSummaryParameters): StreamableMethod; +} + +// @public +export interface GetSummary200Response extends HttpResponse { + // (undocumented) + body: ReportAssetSummaryResultOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetSummaryBodyParam { + // (undocumented) + body?: ReportAssetSummaryRequest; +} + +// @public (undocumented) +export interface GetSummaryDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetSummaryDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetSummaryDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetSummaryParameters = GetSummaryBodyParam & RequestParameters; + +// @public (undocumented) +export interface GetTask { + get(options?: GetTaskParameters): StreamableMethod; +} + +// @public +export interface GetTask200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface GetTaskDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface GetTaskDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & GetTaskDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type GetTaskParameters = RequestParameters; + +// @public (undocumented) +export interface GuidPairOutput { + // (undocumented) + crawlStateGuid?: string; + // (undocumented) + loadDate?: string; + // (undocumented) + pageGuid?: string; + // (undocumented) + recent?: boolean; +} + +// @public (undocumented) +export interface HostAssetOutput extends InventoryAssetOutput { + // (undocumented) + asns?: Array; + // (undocumented) + attributes?: Array; + // (undocumented) + banners?: Array; + // (undocumented) + childHosts?: Array; + // (undocumented) + cnames?: Array; + // (undocumented) + cookies?: Array; + // (undocumented) + count?: number; + // (undocumented) + domain?: string; + // (undocumented) + domainAsset?: DomainAssetOutput; + // (undocumented) + firstSeen?: string; + // (undocumented) + headers?: Array; + // (undocumented) + host?: string; + // (undocumented) + hostCore?: HostCoreOutput; + // (undocumented) + ipAddresses?: Array; + // (undocumented) + ipBlocks?: Array; + // (undocumented) + ipv4?: Array; + // (undocumented) + ipv6?: Array; + // (undocumented) + isWildcard?: Array; + // (undocumented) + lastSeen?: string; + // (undocumented) + location?: Array; + // (undocumented) + mxRecord?: Array; + // (undocumented) + nsRecord?: Array; + // (undocumented) + nxdomain?: Array; + // (undocumented) + parentHosts?: Array; + // (undocumented) + resourceUrls?: Array; + // (undocumented) + responseBodies?: Array; + // (undocumented) + scanMetadata?: Array; + // (undocumented) + services?: Array; + // (undocumented) + sources?: Array; + // (undocumented) + sslCerts?: Array; + // (undocumented) + sslServerConfig?: Array; + // (undocumented) + webComponents?: Array; + // (undocumented) + webserver?: Array; +} + +// @public (undocumented) +export interface HostAssetResourceOutput extends AssetResourceOutputParent { + asset: HostAssetOutput; + kind: "host"; +} + +// @public (undocumented) +export interface HostCoreOutput { + // (undocumented) + alexaRank?: number; + // (undocumented) + blacklistCauseCount?: number; + // (undocumented) + blacklistCauseFirstSeen?: string; + // (undocumented) + blacklistCauseLastSeen?: string; + // (undocumented) + blacklistResourceCount?: number; + // (undocumented) + blacklistResourceFirstSeen?: string; + // (undocumented) + blacklistResourceLastSeen?: string; + // (undocumented) + blacklistSequenceCount?: number; + // (undocumented) + blacklistSequenceFirstSeen?: string; + // (undocumented) + blacklistSequenceLastSeen?: string; + // (undocumented) + count?: number; + // (undocumented) + domain?: string; + // (undocumented) + domainMalwareReputationScore?: number; + // (undocumented) + domainPhishReputationScore?: number; + // (undocumented) + domainReputationScore?: number; + // (undocumented) + domainScamReputationScore?: number; + // (undocumented) + domainSpamReputationScore?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + host?: string; + // (undocumented) + hostMalwareReputationScore?: number; + // (undocumented) + hostPhishReputationScore?: number; + // (undocumented) + hostReputationScore?: number; + // (undocumented) + hostScamReputationScore?: number; + // (undocumented) + hostSpamReputationScore?: number; + // (undocumented) + lastSeen?: string; + // (undocumented) + malwareCauseCount?: number; + // (undocumented) + malwareResourceCount?: number; + // (undocumented) + malwareSequenceCount?: number; + // (undocumented) + phishCauseCount?: number; + // (undocumented) + phishResourceCount?: number; + // (undocumented) + phishSequenceCount?: number; + // (undocumented) + scamCauseCount?: number; + // (undocumented) + scamResourceCount?: number; + // (undocumented) + scamSequenceCount?: number; + // (undocumented) + spamCauseCount?: number; + // (undocumented) + spamResourceCount?: number; + // (undocumented) + spamSequenceCount?: number; + // (undocumented) + uuid?: string; +} + +// @public +export interface InnerErrorOutput { + code?: string; + value?: any; +} + +// @public +export interface InventoryAssetOutput { +} + +// @public (undocumented) +export interface IpAddressAssetOutput extends InventoryAssetOutput { + // (undocumented) + asns?: Array; + // (undocumented) + attributes?: Array; + // (undocumented) + banners?: Array; + // (undocumented) + cookies?: Array; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + headers?: Array; + // (undocumented) + hosts?: Array; + // (undocumented) + ipAddress?: string; + // (undocumented) + ipBlocks?: Array; + // (undocumented) + ipv4?: boolean; + // (undocumented) + ipv6?: boolean; + // (undocumented) + lastSeen?: string; + // (undocumented) + location?: Array; + // (undocumented) + mxRecord?: Array; + // (undocumented) + netRanges?: Array; + // (undocumented) + nsRecord?: Array; + // (undocumented) + nxdomain?: Array; + // (undocumented) + reputations?: Array; + // (undocumented) + scanMetadata?: Array; + // (undocumented) + services?: Array; + // (undocumented) + sources?: Array; + // (undocumented) + sslCerts?: Array; + // (undocumented) + sslServerConfig?: Array; + // (undocumented) + webComponents?: Array; +} + +// @public (undocumented) +export interface IpAddressAssetResourceOutput extends AssetResourceOutputParent { + asset: IpAddressAssetOutput; + kind: "ipAddress"; +} + +// @public (undocumented) +export interface IpBlockAssetOutput extends InventoryAssetOutput { + // (undocumented) + adminContacts?: Array; + // (undocumented) + adminNames?: Array; + // (undocumented) + adminOrgs?: Array; + // (undocumented) + adminPhones?: Array; + // (undocumented) + asns?: Array; + // (undocumented) + bgpPrefixes?: Array; + // (undocumented) + count?: number; + // (undocumented) + detailedFromWhoisAt?: string; + // (undocumented) + endIp?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + ipBlock?: string; + // (undocumented) + ipv4?: boolean; + // (undocumented) + ipv6?: boolean; + // (undocumented) + lastSeen?: string; + // (undocumented) + location?: Array; + // (undocumented) + netNames?: Array; + // (undocumented) + netRanges?: Array; + // (undocumented) + registrantContacts?: Array; + // (undocumented) + registrantNames?: Array; + // (undocumented) + registrantOrgs?: Array; + // (undocumented) + registrantPhones?: Array; + // (undocumented) + registrarCreatedAt?: Array; + // (undocumented) + registrarExpiresAt?: Array; + // (undocumented) + registrarUpdatedAt?: Array; + // (undocumented) + reputations?: Array; + // (undocumented) + sources?: Array; + // (undocumented) + startIp?: string; + // (undocumented) + technicalContacts?: Array; + // (undocumented) + technicalNames?: Array; + // (undocumented) + technicalOrgs?: Array; + // (undocumented) + technicalPhones?: Array; +} + +// @public (undocumented) +export interface IpBlockAssetResourceOutput extends AssetResourceOutputParent { + asset: IpBlockAssetOutput; + kind: "ipBlock"; +} + +// @public (undocumented) +export interface IpBlockOutput { + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + ipBlock?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + recent?: boolean; + // (undocumented) + sources?: Array; +} + +// @public (undocumented) +export function isUnexpected(response: ListAssetResource200Response | ListAssetResourceDefaultResponse): response is ListAssetResourceDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: UpdateAssets200Response | UpdateAssetsDefaultResponse): response is UpdateAssetsDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetAssetResource200Response | GetAssetResourceDefaultResponse): response is GetAssetResourceDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: DismissAssetChain200Response | DismissAssetChainDefaultResponse): response is DismissAssetChainDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetAssetsExport200Response | GetAssetsExportDefaultResponse): response is GetAssetsExportDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetObservations200Response | GetObservationsDefaultResponse): response is GetObservationsDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetDeltaDetails200Response | GetDeltaDetailsDefaultResponse): response is GetDeltaDetailsDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetDeltaSummary200Response | GetDeltaSummaryDefaultResponse): response is GetDeltaSummaryDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ListDataConnection200Response | ListDataConnectionDefaultResponse): response is ListDataConnectionDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ValidateDataConnection200Response | ValidateDataConnectionDefaultResponse): response is ValidateDataConnectionDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetDataConnection200Response | GetDataConnectionDefaultResponse): response is GetDataConnectionDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: CreateOrReplaceDataConnection200Response | CreateOrReplaceDataConnectionDefaultResponse): response is CreateOrReplaceDataConnectionDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: DeleteDataConnection204Response | DeleteDataConnectionDefaultResponse): response is DeleteDataConnectionDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ListDiscoGroup200Response | ListDiscoGroupDefaultResponse): response is ListDiscoGroupDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ValidateDiscoGroup200Response | ValidateDiscoGroupDefaultResponse): response is ValidateDiscoGroupDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetDiscoGroup200Response | GetDiscoGroupDefaultResponse): response is GetDiscoGroupDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: CreateOrReplaceDiscoGroup200Response | CreateOrReplaceDiscoGroupDefaultResponse): response is CreateOrReplaceDiscoGroupDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: RunDiscoGroup204Response | RunDiscoGroupDefaultResponse): response is RunDiscoGroupDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ListRuns200Response | ListRunsDefaultResponse): response is ListRunsDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetAssetChainSummary200Response | GetAssetChainSummaryDefaultResponse): response is GetAssetChainSummaryDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: DismissSeedChain200Response | DismissSeedChainDefaultResponse): response is DismissSeedChainDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ListDiscoTemplate200Response | ListDiscoTemplateDefaultResponse): response is ListDiscoTemplateDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetDiscoTemplate200Response | GetDiscoTemplateDefaultResponse): response is GetDiscoTemplateDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetBillable200Response | GetBillableDefaultResponse): response is GetBillableDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetSnapshot200Response | GetSnapshotDefaultResponse): response is GetSnapshotDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetSummary200Response | GetSummaryDefaultResponse): response is GetSummaryDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetSnapshotExport200Response | GetSnapshotExportDefaultResponse): response is GetSnapshotExportDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ListSavedFilter200Response | ListSavedFilterDefaultResponse): response is ListSavedFilterDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetSavedFilter200Response | GetSavedFilterDefaultResponse): response is GetSavedFilterDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: CreateOrReplaceSavedFilter200Response | CreateOrReplaceSavedFilterDefaultResponse): response is CreateOrReplaceSavedFilterDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: DeleteSavedFilter204Response | DeleteSavedFilterDefaultResponse): response is DeleteSavedFilterDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: ListTask200Response | ListTaskDefaultResponse): response is ListTaskDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetTask200Response | GetTaskDefaultResponse): response is GetTaskDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: CancelTask200Response | CancelTaskDefaultResponse): response is CancelTaskDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: RunTask200Response | RunTaskDefaultResponse): response is RunTaskDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: DownloadTask200Response | DownloadTaskDefaultResponse): response is DownloadTaskDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetCisaCves200Response | GetCisaCvesDefaultResponse): response is GetCisaCvesDefaultResponse; + +// @public (undocumented) +export function isUnexpected(response: GetCisaCve200Response | GetCisaCveDefaultResponse): response is GetCisaCveDefaultResponse; + +// @public (undocumented) +export interface ListAssetResource { + get(options?: ListAssetResourceParameters): StreamableMethod; + post(options: UpdateAssetsParameters): StreamableMethod; +} + +// @public +export interface ListAssetResource200Response extends HttpResponse { + // (undocumented) + body: PagedAssetResourceOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListAssetResourceDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListAssetResourceDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListAssetResourceDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListAssetResourceParameters = ListAssetResourceQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListAssetResourceQueryParam { + // (undocumented) + queryParameters?: ListAssetResourceQueryParamProperties; +} + +// @public (undocumented) +export interface ListAssetResourceQueryParamProperties { + filter?: string; + mark?: string; + maxpagesize?: number; + orderby?: string; + // (undocumented) + recentOnly?: boolean; + // (undocumented) + responseIncludes?: string[]; + responseType?: string; + skip?: number; +} + +// @public (undocumented) +export interface ListDataConnection { + get(options?: ListDataConnectionParameters): StreamableMethod; +} + +// @public +export interface ListDataConnection200Response extends HttpResponse { + // (undocumented) + body: PagedDataConnectionOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListDataConnectionDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListDataConnectionDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListDataConnectionDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListDataConnectionParameters = ListDataConnectionQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListDataConnectionQueryParam { + // (undocumented) + queryParameters?: ListDataConnectionQueryParamProperties; +} + +// @public (undocumented) +export interface ListDataConnectionQueryParamProperties { + maxpagesize?: number; + skip?: number; +} + +// @public (undocumented) +export interface ListDiscoGroup { + get(options?: ListDiscoGroupParameters): StreamableMethod; +} + +// @public +export interface ListDiscoGroup200Response extends HttpResponse { + // (undocumented) + body: PagedDiscoGroupOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListDiscoGroupDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListDiscoGroupDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListDiscoGroupDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListDiscoGroupParameters = ListDiscoGroupQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListDiscoGroupQueryParam { + // (undocumented) + queryParameters?: ListDiscoGroupQueryParamProperties; +} + +// @public (undocumented) +export interface ListDiscoGroupQueryParamProperties { + filter?: string; + maxpagesize?: number; + skip?: number; +} + +// @public (undocumented) +export interface ListDiscoTemplate { + get(options?: ListDiscoTemplateParameters): StreamableMethod; +} + +// @public +export interface ListDiscoTemplate200Response extends HttpResponse { + // (undocumented) + body: PagedDiscoTemplateOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListDiscoTemplateDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListDiscoTemplateDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListDiscoTemplateDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListDiscoTemplateParameters = ListDiscoTemplateQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListDiscoTemplateQueryParam { + // (undocumented) + queryParameters?: ListDiscoTemplateQueryParamProperties; +} + +// @public (undocumented) +export interface ListDiscoTemplateQueryParamProperties { + filter?: string; + maxpagesize?: number; + skip?: number; +} + +// @public (undocumented) +export interface ListRuns { + get(options?: ListRunsParameters): StreamableMethod; +} + +// @public +export interface ListRuns200Response extends HttpResponse { + // (undocumented) + body: DiscoRunPageResultOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListRunsDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListRunsDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListRunsDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListRunsParameters = ListRunsQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListRunsQueryParam { + // (undocumented) + queryParameters?: ListRunsQueryParamProperties; +} + +// @public (undocumented) +export interface ListRunsQueryParamProperties { + filter?: string; + maxpagesize?: number; + skip?: number; +} + +// @public (undocumented) +export interface ListSavedFilter { + get(options?: ListSavedFilterParameters): StreamableMethod; +} + +// @public +export interface ListSavedFilter200Response extends HttpResponse { + // (undocumented) + body: PagedSavedFilterOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListSavedFilterDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListSavedFilterDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListSavedFilterDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListSavedFilterParameters = ListSavedFilterQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListSavedFilterQueryParam { + // (undocumented) + queryParameters?: ListSavedFilterQueryParamProperties; +} + +// @public (undocumented) +export interface ListSavedFilterQueryParamProperties { + filter?: string; + maxpagesize?: number; + skip?: number; +} + +// @public (undocumented) +export interface ListTask { + get(options?: ListTaskParameters): StreamableMethod; +} + +// @public +export interface ListTask200Response extends HttpResponse { + // (undocumented) + body: PagedTaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ListTaskDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ListTaskDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ListTaskDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ListTaskParameters = ListTaskQueryParam & RequestParameters; + +// @public (undocumented) +export interface ListTaskQueryParam { + // (undocumented) + queryParameters?: ListTaskQueryParamProperties; +} + +// @public (undocumented) +export interface ListTaskQueryParamProperties { + filter?: string; + maxpagesize?: number; + orderby?: string; + skip?: number; +} + +// @public (undocumented) +export interface LocationOutput { + // (undocumented) + areaCode?: number; + // (undocumented) + city?: string; + // (undocumented) + countryCode?: string; + // (undocumented) + countryName?: string; + // (undocumented) + dmaCode?: number; + // (undocumented) + latitude?: number; + // (undocumented) + longitude?: number; + // (undocumented) + metroCodeId?: number; + // (undocumented) + postalCode?: string; + // (undocumented) + region?: string; + // (undocumented) + regionName?: string; +} + +// @public (undocumented) +export interface LogAnalyticsDataConnectionData extends DataConnectionDataParent { + kind: "logAnalytics"; + properties: LogAnalyticsDataConnectionProperties; +} + +// @public (undocumented) +export interface LogAnalyticsDataConnectionOutput extends DataConnectionOutputParent { + kind: "logAnalytics"; + properties: LogAnalyticsDataConnectionPropertiesOutput; +} + +// @public (undocumented) +export interface LogAnalyticsDataConnectionProperties extends DataConnectionProperties { + apiKey?: string; + workspaceId?: string; +} + +// @public (undocumented) +export interface LogAnalyticsDataConnectionPropertiesOutput extends DataConnectionPropertiesOutput { + apiKey?: string; + workspaceId?: string; +} + +// @public (undocumented) +export interface ObservationPageResponseOutput { + // (undocumented) + prioritySummary: TypeSpecRecordOutput; + // (undocumented) + totalElements: number; + // (undocumented) + value: Array; +} + +// @public (undocumented) +export interface ObservationResponseOutput { + // (undocumented) + cvssScoreV2: number; + // (undocumented) + cvssScoreV3: number; + // (undocumented) + name: string; + priority: string; + // (undocumented) + type: string[]; +} + +// @public (undocumented) +export interface ObservedBooleanOutput extends ObservedValueOutput { + // (undocumented) + sources?: Array; + // (undocumented) + value?: boolean; +} + +// @public (undocumented) +export interface ObservedHeaderOutput extends ObservedValueOutput { + // (undocumented) + headerName?: string; + // (undocumented) + headerValue?: string; +} + +// @public (undocumented) +export interface ObservedIntegerOutput extends ObservedValueOutput { + // (undocumented) + sources?: Array; + // (undocumented) + value?: number; +} + +// @public (undocumented) +export interface ObservedIntegersOutput extends ObservedValueOutput { + // (undocumented) + sources?: Array; + // (undocumented) + values?: number[]; +} + +// @public (undocumented) +export interface ObservedLocationOutput extends ObservedValueOutput { + // (undocumented) + sources?: Array; + // (undocumented) + value?: LocationOutput; +} + +// @public (undocumented) +export interface ObservedLongOutput extends ObservedValueOutput { + // (undocumented) + sources?: Array; + // (undocumented) + value?: number; +} + +// @public (undocumented) +export interface ObservedPortStateOutput extends ObservedValueOutput { + // (undocumented) + port?: number; + value?: string; +} + +// @public (undocumented) +export interface ObservedStringOutput extends ObservedValueOutput { + // (undocumented) + sources?: Array; + // (undocumented) + value?: string; +} + +// @public +export interface ObservedValueOutput { + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + recent?: boolean; +} + +// @public (undocumented) +export interface PageAssetOutput extends InventoryAssetOutput { + // (undocumented) + asns?: Array; + // (undocumented) + assetSecurityPolicies?: Array; + // (undocumented) + attributes?: Array; + // (undocumented) + cause?: PageCauseOutput; + // (undocumented) + cdns?: Array; + // (undocumented) + charsets?: Array; + // (undocumented) + cnames?: Array; + // (undocumented) + contentLengths?: Array; + // (undocumented) + contentTypes?: Array; + // (undocumented) + cookies?: Array; + // (undocumented) + count?: number; + // (undocumented) + domain?: string; + // (undocumented) + domainAsset?: DomainAssetOutput; + // (undocumented) + errors?: Array; + // (undocumented) + finalAsns?: Array; + // (undocumented) + finalIpAddresses?: Array; + // (undocumented) + finalIpBlocks?: Array; + // (undocumented) + finalResponseCodes?: Array; + // (undocumented) + finalUrls?: Array; + // (undocumented) + firstSeen?: string; + // (undocumented) + frames?: Array; + // (undocumented) + fullDomMinhashSignatures?: Array; + // (undocumented) + gdprAssetSecurityPolicies?: Array; + // (undocumented) + guids?: Array; + // (undocumented) + host?: string; + // (undocumented) + httpMethod?: string; + // (undocumented) + httpResponseCodes?: Array; + // (undocumented) + httpResponseMessages?: Array; + // (undocumented) + ipAddresses?: Array; + // (undocumented) + ipBlocks?: Array; + // (undocumented) + ipv4?: Array; + // (undocumented) + ipv6?: Array; + // (undocumented) + isRootUrl?: boolean; + // (undocumented) + languages?: Array; + // (undocumented) + lastSeen?: string; + // (undocumented) + location?: Array; + // (undocumented) + nonHtmlFrames?: Array; + // (undocumented) + parkedPage?: Array; + redirectType?: string; + // (undocumented) + redirectUrls?: Array; + // (undocumented) + referrer?: string; + // (undocumented) + resourceUrls?: Array; + // (undocumented) + responseBodies?: Array; + // (undocumented) + responseBodyHashSignatures?: Array; + // (undocumented) + responseBodyMinhashSignatures?: Array; + // (undocumented) + responseHeaders?: Array; + // (undocumented) + responseTimes?: Array; + // (undocumented) + rootUrl?: ObservedBooleanOutput; + // (undocumented) + service?: string; + // (undocumented) + services?: Array; + // (undocumented) + siteStatus?: string; + // (undocumented) + sources?: Array; + // (undocumented) + sslCerts?: Array; + // (undocumented) + sslServerConfig?: Array; + // (undocumented) + successful?: Array; + // (undocumented) + titles?: Array; + // (undocumented) + undirectedContent?: Array; + // (undocumented) + url?: string; + // (undocumented) + webComponents?: Array; + // (undocumented) + windowNames?: Array; + // (undocumented) + windows?: Array; +} + +// @public (undocumented) +export interface PageAssetResourceOutput extends AssetResourceOutputParent { + asset: PageAssetOutput; + kind: "page"; +} + +// @public (undocumented) +export interface PageCauseOutput { + // (undocumented) + cause?: string; + // (undocumented) + causeElementXPath?: string; + // (undocumented) + domChangeIndex?: number; + // (undocumented) + location?: string; + // (undocumented) + loopDetected?: boolean; + // (undocumented) + possibleMatches?: number; + // (undocumented) + version?: number; +} + +// @public +export type PagedAssetResourceOutput = Paged; + +// @public +export type PagedCisaCveResponseOutput = Paged; + +// @public +export type PagedDataConnectionOutput = Paged; + +// @public +export type PagedDiscoGroupOutput = Paged; + +// @public +export type PagedDiscoTemplateOutput = Paged; + +// @public +export type PagedSavedFilterOutput = Paged; + +// @public +export type PagedTaskOutput = Paged; + +// @public +export function paginate(client: Client, initialResponse: TResponse, options?: PagingOptions): PagedAsyncIterableIterator>; + +// @public +export type PaginateReturn = TResult extends { + body: { + value?: infer TPage; + }; +} ? GetArrayType : Array; + +// @public +export interface PagingOptions { + customGetPage?: GetPage[]>; +} + +// @public (undocumented) +export interface PortOutput { + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + port?: number; +} + +// @public +export interface ReportAssetSnapshotExportRequest { + columns?: string[]; + fileName?: string; + metric?: string; +} + +// @public +export interface ReportAssetSnapshotRequest { + labelName?: string; + metric?: string; + page?: number; + size?: number; +} + +// @public +export interface ReportAssetSnapshotResultOutput { + assets?: AssetPageResultOutput; + description?: string; + displayName?: string; + labelName?: string; + metric?: string; + updatedAt?: string; +} + +// @public +export interface ReportAssetSummaryRequest { + filters?: string[]; + groupBy?: string; + labelName?: string; + metricCategories?: string[]; + metrics?: string[]; + segmentBy?: string; +} + +// @public (undocumented) +export interface ReportAssetSummaryResultOutput { + assetSummaries?: Array; +} + +// @public +export interface ReportBillableAssetBreakdownOutput { + count?: number; + kind?: string; +} + +// @public (undocumented) +export interface ReportBillableAssetSnapshotResultOutput { + assetBreakdown?: Array; + date?: string; + total?: number; +} + +// @public (undocumented) +export interface ReportBillableAssetSummaryResultOutput { + // (undocumented) + assetSummaries?: Array; +} + +// @public (undocumented) +export interface ReputationOutput { + // (undocumented) + cidr?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + listName?: string; + // (undocumented) + listUpdatedAt?: string; + // (undocumented) + recent?: boolean; + // (undocumented) + threatType?: string; + // (undocumented) + trusted?: boolean; +} + +// @public (undocumented) +export interface ResourceUrlOutput { + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + recent?: boolean; + // (undocumented) + resources?: Array; + // (undocumented) + url?: string; +} + +// @public (undocumented) +export interface Routes { + (path: "/assets"): ListAssetResource; + (path: "/assets/{assetId}", assetId: string): GetAssetResource; + (path: "/assets/{assetId}:dismissAssetChain", assetId: string): DismissAssetChain; + (path: "/assets:export"): GetAssetsExport; + (path: "/assets/{assetId}:getObservations", assetId: string): GetObservations; + (path: "/assets:getDeltaDetails"): GetDeltaDetails; + (path: "/assets:getDeltaSummary"): GetDeltaSummary; + (path: "/dataConnections"): ListDataConnection; + (path: "/dataConnections:validate"): ValidateDataConnection; + (path: "/dataConnections/{dataConnectionName}", dataConnectionName: string): GetDataConnection; + (path: "/discoGroups"): ListDiscoGroup; + (path: "/discoGroups:validate"): ValidateDiscoGroup; + (path: "/discoGroups/{groupName}", groupName: string): GetDiscoGroup; + (path: "/discoGroups/{groupName}:run", groupName: string): RunDiscoGroup; + (path: "/discoGroups/{groupName}/runs", groupName: string): ListRuns; + (path: "/discoGroups:getAssetChainSummary"): GetAssetChainSummary; + (path: "/discoGroups:dismissSeedChain"): DismissSeedChain; + (path: "/discoTemplates"): ListDiscoTemplate; + (path: "/discoTemplates/{templateId}", templateId: string): GetDiscoTemplate; + (path: "/reports/assets:getBillable"): GetBillable; + (path: "/reports/assets:getSnapshot"): GetSnapshot; + (path: "/reports/assets:getSummary"): GetSummary; + (path: "/reports/assets:getSnapshotExport"): GetSnapshotExport; + (path: "/savedFilters"): ListSavedFilter; + (path: "/savedFilters/{filterName}", filterName: string): GetSavedFilter; + (path: "/tasks"): ListTask; + (path: "/tasks/{taskId}", taskId: string): GetTask; + (path: "/tasks/{taskId}:cancel", taskId: string): CancelTask; + (path: "/tasks/{taskId}:run", taskId: string): RunTask; + (path: "/tasks/{taskId}:download", taskId: string): DownloadTask; + (path: "/cisaCves"): GetCisaCves; + (path: "/cisaCves/{cveId}", cveId: string): GetCisaCve; +} + +// @public (undocumented) +export interface RunDiscoGroup { + post(options?: RunDiscoGroupParameters): StreamableMethod; +} + +// @public +export interface RunDiscoGroup204Response extends HttpResponse { + // (undocumented) + status: "204"; +} + +// @public (undocumented) +export interface RunDiscoGroupDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface RunDiscoGroupDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & RunDiscoGroupDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type RunDiscoGroupParameters = RequestParameters; + +// @public (undocumented) +export interface RunTask { + post(options?: RunTaskParameters): StreamableMethod; +} + +// @public +export interface RunTask200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface RunTaskDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface RunTaskDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & RunTaskDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type RunTaskParameters = RequestParameters; + +// @public +export interface SavedFilterData { + description: string; + filter: string; +} + +// @public (undocumented) +export interface SavedFilterOutput { + // (undocumented) + description?: string; + displayName?: string; + // (undocumented) + filter?: string; + id?: string; + readonly name: string; +} + +// @public (undocumented) +export interface ScanMetadataOutput { + // (undocumented) + bannerMetadata?: string; + // (undocumented) + endScan?: string; + // (undocumented) + port?: number; + // (undocumented) + startScan?: string; +} + +// @public (undocumented) +export interface ServiceOutput { + // (undocumented) + count?: number; + // (undocumented) + exceptions?: Array; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + port?: number; + // (undocumented) + portStates?: Array; + // (undocumented) + recent?: boolean; + // (undocumented) + scheme?: string; + // (undocumented) + sources?: Array; + // (undocumented) + sslCerts?: Array; + // (undocumented) + webComponents?: Array; +} + +// @public (undocumented) +export interface SoaRecordOutput { + // (undocumented) + count?: number; + // (undocumented) + email?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + nameServer?: string; + // (undocumented) + recent?: boolean; + // (undocumented) + serialNumber?: number; +} + +// @public (undocumented) +export interface SourceOutput { + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + reason?: string; + // (undocumented) + source?: string; +} + +// @public (undocumented) +export interface SslCertAssetOutput extends InventoryAssetOutput { + // (undocumented) + certificateAuthority?: boolean; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + invalidAfter?: string; + // (undocumented) + invalidBefore?: string; + // (undocumented) + issuerAlternativeNames?: string[]; + // (undocumented) + issuerCommonNames?: string[]; + // (undocumented) + issuerCountry?: string[]; + // (undocumented) + issuerLocality?: string[]; + // (undocumented) + issuerOrganizationalUnits?: string[]; + // (undocumented) + issuerOrganizations?: string[]; + // (undocumented) + issuerState?: string[]; + // (undocumented) + keyAlgorithm?: string; + // (undocumented) + keySize?: number; + // (undocumented) + lastSeen?: string; + // (undocumented) + organizationalUnits?: string[]; + // (undocumented) + organizations?: string[]; + // (undocumented) + recent?: boolean; + // (undocumented) + selfSigned?: boolean; + // (undocumented) + serialNumber?: string; + // (undocumented) + sha1?: string; + // (undocumented) + sigAlgName?: string; + // (undocumented) + sigAlgOid?: string; + // (undocumented) + sources?: Array; + // (undocumented) + subjectAlternativeNames?: string[]; + // (undocumented) + subjectCommonNames?: string[]; + // (undocumented) + subjectCountry?: string[]; + // (undocumented) + subjectLocality?: string[]; + // (undocumented) + subjectOrganizationalUnits?: string[]; + // (undocumented) + subjectOrganizations?: string[]; + // (undocumented) + subjectState?: string[]; + validationType?: string; + // (undocumented) + version?: number; +} + +// @public (undocumented) +export interface SslCertAssetResourceOutput extends AssetResourceOutputParent { + asset: SslCertAssetOutput; + kind: "sslCert"; +} + +// @public (undocumented) +export interface SslServerConfigOutput { + // (undocumented) + cipherSuites?: string[]; + // (undocumented) + count?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + sources?: Array; + // (undocumented) + tlsVersions?: string[]; +} + +// @public (undocumented) +export interface SubResourceIntegrityCheckOutput { + // (undocumented) + causePageUrl?: string; + // (undocumented) + count?: number; + // (undocumented) + crawlGuid?: string; + // (undocumented) + expectedHash?: string; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + pageGuid?: string; + // (undocumented) + resourceGuid?: string; + // (undocumented) + violation?: boolean; +} + +// @public (undocumented) +export interface TaskOutput { + completedAt?: string; + readonly id: string; + lastPolledAt?: string; + metadata?: TypeSpecRecordOutput; + phase?: string; + reason?: string; + startedAt?: string; + state?: string; +} + +// @public (undocumented) +export interface TypeSpecRecord extends Record { +} + +// @public (undocumented) +export interface TypeSpecRecordOutput extends Record { +} + +// @public (undocumented) +export interface TypeSpecRecordOutput extends Record { +} + +// @public +export interface UpdateAssets200Response extends HttpResponse { + // (undocumented) + body: TaskOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface UpdateAssetsBodyParam { + // (undocumented) + body?: AssetUpdateData; +} + +// @public (undocumented) +export interface UpdateAssetsDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface UpdateAssetsDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & UpdateAssetsDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type UpdateAssetsParameters = UpdateAssetsQueryParam & UpdateAssetsBodyParam & RequestParameters; + +// @public (undocumented) +export interface UpdateAssetsQueryParam { + // (undocumented) + queryParameters: UpdateAssetsQueryParamProperties; +} + +// @public (undocumented) +export interface UpdateAssetsQueryParamProperties { + filter: string; +} + +// @public (undocumented) +export interface ValidateDataConnection { + post(options?: ValidateDataConnectionParameters): StreamableMethod; +} + +// @public +export interface ValidateDataConnection200Response extends HttpResponse { + // (undocumented) + body: ValidateResultOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ValidateDataConnectionBodyParam { + // (undocumented) + body?: DataConnectionData; +} + +// @public (undocumented) +export interface ValidateDataConnectionDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ValidateDataConnectionDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ValidateDataConnectionDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ValidateDataConnectionParameters = ValidateDataConnectionBodyParam & RequestParameters; + +// @public (undocumented) +export interface ValidateDiscoGroup { + post(options?: ValidateDiscoGroupParameters): StreamableMethod; +} + +// @public +export interface ValidateDiscoGroup200Response extends HttpResponse { + // (undocumented) + body: ValidateResultOutput; + // (undocumented) + status: "200"; +} + +// @public (undocumented) +export interface ValidateDiscoGroupBodyParam { + // (undocumented) + body?: DiscoGroupData; +} + +// @public (undocumented) +export interface ValidateDiscoGroupDefaultHeaders { + "x-ms-error-code"?: string; +} + +// @public (undocumented) +export interface ValidateDiscoGroupDefaultResponse extends HttpResponse { + // (undocumented) + body: ErrorResponse; + // (undocumented) + headers: RawHttpHeaders & ValidateDiscoGroupDefaultHeaders; + // (undocumented) + status: string; +} + +// @public (undocumented) +export type ValidateDiscoGroupParameters = ValidateDiscoGroupBodyParam & RequestParameters; + +// @public +export interface ValidateResultOutput { + error?: ErrorDetailOutput; +} + +// @public (undocumented) +export interface WebComponentOutput { + // (undocumented) + count?: number; + // (undocumented) + cve?: Array; + // (undocumented) + endOfLife?: number; + // (undocumented) + firstSeen?: string; + // (undocumented) + lastSeen?: string; + // (undocumented) + name?: string; + // (undocumented) + ports?: Array; + // (undocumented) + recent?: boolean; + // (undocumented) + ruleId?: string[]; + // (undocumented) + service?: string; + // (undocumented) + sources?: Array; + // (undocumented) + type?: string; + // (undocumented) + version?: string; +} + +// (No @packageDocumentation comment for this package) + +``` diff --git a/sdk/easm/defendereasm-rest/src/clientDefinitions.ts b/sdk/easm/defendereasm-rest/src/clientDefinitions.ts new file mode 100644 index 000000000000..f5c10f7bf733 --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/clientDefinitions.ts @@ -0,0 +1,443 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { + ListAssetResourceParameters, + UpdateAssetsParameters, + GetAssetResourceParameters, + DismissAssetChainParameters, + GetAssetsExportParameters, + GetObservationsParameters, + GetDeltaDetailsParameters, + GetDeltaSummaryParameters, + ListDataConnectionParameters, + ValidateDataConnectionParameters, + GetDataConnectionParameters, + CreateOrReplaceDataConnectionParameters, + DeleteDataConnectionParameters, + ListDiscoGroupParameters, + ValidateDiscoGroupParameters, + GetDiscoGroupParameters, + CreateOrReplaceDiscoGroupParameters, + RunDiscoGroupParameters, + ListRunsParameters, + GetAssetChainSummaryParameters, + DismissSeedChainParameters, + ListDiscoTemplateParameters, + GetDiscoTemplateParameters, + GetBillableParameters, + GetSnapshotParameters, + GetSummaryParameters, + GetSnapshotExportParameters, + ListSavedFilterParameters, + GetSavedFilterParameters, + CreateOrReplaceSavedFilterParameters, + DeleteSavedFilterParameters, + ListTaskParameters, + GetTaskParameters, + CancelTaskParameters, + RunTaskParameters, + DownloadTaskParameters, + GetCisaCvesParameters, + GetCisaCveParameters, +} from "./parameters.js"; +import { + ListAssetResource200Response, + ListAssetResourceDefaultResponse, + UpdateAssets200Response, + UpdateAssetsDefaultResponse, + GetAssetResource200Response, + GetAssetResourceDefaultResponse, + DismissAssetChain200Response, + DismissAssetChainDefaultResponse, + GetAssetsExport200Response, + GetAssetsExportDefaultResponse, + GetObservations200Response, + GetObservationsDefaultResponse, + GetDeltaDetails200Response, + GetDeltaDetailsDefaultResponse, + GetDeltaSummary200Response, + GetDeltaSummaryDefaultResponse, + ListDataConnection200Response, + ListDataConnectionDefaultResponse, + ValidateDataConnection200Response, + ValidateDataConnectionDefaultResponse, + GetDataConnection200Response, + GetDataConnectionDefaultResponse, + CreateOrReplaceDataConnection200Response, + CreateOrReplaceDataConnectionDefaultResponse, + DeleteDataConnection204Response, + DeleteDataConnectionDefaultResponse, + ListDiscoGroup200Response, + ListDiscoGroupDefaultResponse, + ValidateDiscoGroup200Response, + ValidateDiscoGroupDefaultResponse, + GetDiscoGroup200Response, + GetDiscoGroupDefaultResponse, + CreateOrReplaceDiscoGroup200Response, + CreateOrReplaceDiscoGroupDefaultResponse, + RunDiscoGroup204Response, + RunDiscoGroupDefaultResponse, + ListRuns200Response, + ListRunsDefaultResponse, + GetAssetChainSummary200Response, + GetAssetChainSummaryDefaultResponse, + DismissSeedChain200Response, + DismissSeedChainDefaultResponse, + ListDiscoTemplate200Response, + ListDiscoTemplateDefaultResponse, + GetDiscoTemplate200Response, + GetDiscoTemplateDefaultResponse, + GetBillable200Response, + GetBillableDefaultResponse, + GetSnapshot200Response, + GetSnapshotDefaultResponse, + GetSummary200Response, + GetSummaryDefaultResponse, + GetSnapshotExport200Response, + GetSnapshotExportDefaultResponse, + ListSavedFilter200Response, + ListSavedFilterDefaultResponse, + GetSavedFilter200Response, + GetSavedFilterDefaultResponse, + CreateOrReplaceSavedFilter200Response, + CreateOrReplaceSavedFilterDefaultResponse, + DeleteSavedFilter204Response, + DeleteSavedFilterDefaultResponse, + ListTask200Response, + ListTaskDefaultResponse, + GetTask200Response, + GetTaskDefaultResponse, + CancelTask200Response, + CancelTaskDefaultResponse, + RunTask200Response, + RunTaskDefaultResponse, + DownloadTask200Response, + DownloadTaskDefaultResponse, + GetCisaCves200Response, + GetCisaCvesDefaultResponse, + GetCisaCve200Response, + GetCisaCveDefaultResponse, +} from "./responses.js"; +import { Client, StreamableMethod } from "@azure-rest/core-client"; + +export interface ListAssetResource { + /** Retrieve a list of assets for the provided search parameters. */ + get( + options?: ListAssetResourceParameters, + ): StreamableMethod; + /** Update labels on assets matching the provided filter. */ + post( + options: UpdateAssetsParameters, + ): StreamableMethod; +} + +export interface GetAssetResource { + /** Retrieve an asset by assetId. */ + get( + options?: GetAssetResourceParameters, + ): StreamableMethod; +} + +export interface DismissAssetChain { + /** Dismiss discovery chain for a given asset */ + post( + options?: DismissAssetChainParameters, + ): StreamableMethod; +} + +export interface GetAssetsExport { + /** Export a list of assets for the provided search parameters. */ + post( + options?: GetAssetsExportParameters, + ): StreamableMethod; +} + +export interface GetObservations { + /** Retrieve observations on an asset */ + post( + options?: GetObservationsParameters, + ): StreamableMethod; +} + +export interface GetDeltaDetails { + /** Retrieve a list of deltas for the provided time range. */ + post( + options?: GetDeltaDetailsParameters, + ): StreamableMethod; +} + +export interface GetDeltaSummary { + /** Retrieve a list of deltas with overall summary changes for the provided time range. */ + post( + options?: GetDeltaSummaryParameters, + ): StreamableMethod; +} + +export interface ListDataConnection { + /** Retrieve a list of data connections. */ + get( + options?: ListDataConnectionParameters, + ): StreamableMethod; +} + +export interface ValidateDataConnection { + /** Validate a data connection with a given dataConnectionName. */ + post( + options?: ValidateDataConnectionParameters, + ): StreamableMethod; +} + +export interface GetDataConnection { + /** Retrieve a data connection with a given dataConnectionName. */ + get( + options?: GetDataConnectionParameters, + ): StreamableMethod; + /** Create or replace a data connection with a given dataConnectionName. */ + put( + options?: CreateOrReplaceDataConnectionParameters, + ): StreamableMethod< + CreateOrReplaceDataConnection200Response | CreateOrReplaceDataConnectionDefaultResponse + >; + /** Delete a data connection with a given dataConnectionName. */ + delete( + options?: DeleteDataConnectionParameters, + ): StreamableMethod; +} + +export interface ListDiscoGroup { + /** Retrieve a list of discovery group for the provided search parameters. */ + get( + options?: ListDiscoGroupParameters, + ): StreamableMethod; +} + +export interface ValidateDiscoGroup { + /** Validate a discovery group with a given groupName. */ + post( + options?: ValidateDiscoGroupParameters, + ): StreamableMethod; +} + +export interface GetDiscoGroup { + /** Retrieve a discovery group with a given groupName. */ + get( + options?: GetDiscoGroupParameters, + ): StreamableMethod; + /** Create a discovery group with a given groupName. */ + put( + options?: CreateOrReplaceDiscoGroupParameters, + ): StreamableMethod< + CreateOrReplaceDiscoGroup200Response | CreateOrReplaceDiscoGroupDefaultResponse + >; +} + +export interface RunDiscoGroup { + /** Run a discovery group with a given groupName. */ + post( + options?: RunDiscoGroupParameters, + ): StreamableMethod; +} + +export interface ListRuns { + /** Retrieve a collection of discovery run results for a discovery group with a given groupName. */ + get( + options?: ListRunsParameters, + ): StreamableMethod; +} + +export interface GetAssetChainSummary { + /** Retrieve an asset chain summary. */ + post( + options?: GetAssetChainSummaryParameters, + ): StreamableMethod; +} + +export interface DismissSeedChain { + /** Dismiss a discovery seed chain for given seed identifiers. */ + post( + options?: DismissSeedChainParameters, + ): StreamableMethod; +} + +export interface ListDiscoTemplate { + /** Retrieve a list of disco templates for the provided search parameters. */ + get( + options?: ListDiscoTemplateParameters, + ): StreamableMethod; +} + +export interface GetDiscoTemplate { + /** Retrieve a disco template with a given templateId. */ + get( + options?: GetDiscoTemplateParameters, + ): StreamableMethod; +} + +export interface GetBillable { + /** Get billable assets summary for the workspace. */ + post( + options?: GetBillableParameters, + ): StreamableMethod; +} + +export interface GetSnapshot { + /** Get the most recent snapshot of asset summary values for the snapshot request. */ + post( + options?: GetSnapshotParameters, + ): StreamableMethod; +} + +export interface GetSummary { + /** Get asset summary details for the summary request. */ + post( + options?: GetSummaryParameters, + ): StreamableMethod; +} + +export interface GetSnapshotExport { + /** Get the most recent snapshot of asset summary values for the snapshot request exported to a file. */ + post( + options?: GetSnapshotExportParameters, + ): StreamableMethod; +} + +export interface ListSavedFilter { + /** Retrieve a list of saved filters for the provided search parameters. */ + get( + options?: ListSavedFilterParameters, + ): StreamableMethod; +} + +export interface GetSavedFilter { + /** Retrieve a saved filter by filterName. */ + get( + options?: GetSavedFilterParameters, + ): StreamableMethod; + /** Create or replace a saved filter with a given filterName. */ + put( + options?: CreateOrReplaceSavedFilterParameters, + ): StreamableMethod< + CreateOrReplaceSavedFilter200Response | CreateOrReplaceSavedFilterDefaultResponse + >; + /** Delete a saved filter with a given filterName. */ + delete( + options?: DeleteSavedFilterParameters, + ): StreamableMethod; +} + +export interface ListTask { + /** Retrieve a list of tasks for the provided search parameters. */ + get( + options?: ListTaskParameters, + ): StreamableMethod; +} + +export interface GetTask { + /** Retrieve a task by taskId. */ + get(options?: GetTaskParameters): StreamableMethod; +} + +export interface CancelTask { + /** Cancel a task by taskId. */ + post( + options?: CancelTaskParameters, + ): StreamableMethod; +} + +export interface RunTask { + /** Run a task by taskId. */ + post(options?: RunTaskParameters): StreamableMethod; +} + +export interface DownloadTask { + /** Download a task. */ + post( + options?: DownloadTaskParameters, + ): StreamableMethod; +} + +export interface GetCisaCves { + /** Retrieve a list of CisaCves for the provided search parameters. */ + get( + options?: GetCisaCvesParameters, + ): StreamableMethod; +} + +export interface GetCisaCve { + /** Retrieve details of CisaCve by cveId */ + get( + options?: GetCisaCveParameters, + ): StreamableMethod; +} + +export interface Routes { + /** Resource for '/assets' has methods for the following verbs: get, post */ + (path: "/assets"): ListAssetResource; + /** Resource for '/assets/\{assetId\}' has methods for the following verbs: get */ + (path: "/assets/{assetId}", assetId: string): GetAssetResource; + /** Resource for '/assets/\{assetId\}:dismissAssetChain' has methods for the following verbs: post */ + (path: "/assets/{assetId}:dismissAssetChain", assetId: string): DismissAssetChain; + /** Resource for '/assets:export' has methods for the following verbs: post */ + (path: "/assets:export"): GetAssetsExport; + /** Resource for '/assets/\{assetId\}:getObservations' has methods for the following verbs: post */ + (path: "/assets/{assetId}:getObservations", assetId: string): GetObservations; + /** Resource for '/assets:getDeltaDetails' has methods for the following verbs: post */ + (path: "/assets:getDeltaDetails"): GetDeltaDetails; + /** Resource for '/assets:getDeltaSummary' has methods for the following verbs: post */ + (path: "/assets:getDeltaSummary"): GetDeltaSummary; + /** Resource for '/dataConnections' has methods for the following verbs: get */ + (path: "/dataConnections"): ListDataConnection; + /** Resource for '/dataConnections:validate' has methods for the following verbs: post */ + (path: "/dataConnections:validate"): ValidateDataConnection; + /** Resource for '/dataConnections/\{dataConnectionName\}' has methods for the following verbs: get, put, delete */ + (path: "/dataConnections/{dataConnectionName}", dataConnectionName: string): GetDataConnection; + /** Resource for '/discoGroups' has methods for the following verbs: get */ + (path: "/discoGroups"): ListDiscoGroup; + /** Resource for '/discoGroups:validate' has methods for the following verbs: post */ + (path: "/discoGroups:validate"): ValidateDiscoGroup; + /** Resource for '/discoGroups/\{groupName\}' has methods for the following verbs: get, put */ + (path: "/discoGroups/{groupName}", groupName: string): GetDiscoGroup; + /** Resource for '/discoGroups/\{groupName\}:run' has methods for the following verbs: post */ + (path: "/discoGroups/{groupName}:run", groupName: string): RunDiscoGroup; + /** Resource for '/discoGroups/\{groupName\}/runs' has methods for the following verbs: get */ + (path: "/discoGroups/{groupName}/runs", groupName: string): ListRuns; + /** Resource for '/discoGroups:getAssetChainSummary' has methods for the following verbs: post */ + (path: "/discoGroups:getAssetChainSummary"): GetAssetChainSummary; + /** Resource for '/discoGroups:dismissSeedChain' has methods for the following verbs: post */ + (path: "/discoGroups:dismissSeedChain"): DismissSeedChain; + /** Resource for '/discoTemplates' has methods for the following verbs: get */ + (path: "/discoTemplates"): ListDiscoTemplate; + /** Resource for '/discoTemplates/\{templateId\}' has methods for the following verbs: get */ + (path: "/discoTemplates/{templateId}", templateId: string): GetDiscoTemplate; + /** Resource for '/reports/assets:getBillable' has methods for the following verbs: post */ + (path: "/reports/assets:getBillable"): GetBillable; + /** Resource for '/reports/assets:getSnapshot' has methods for the following verbs: post */ + (path: "/reports/assets:getSnapshot"): GetSnapshot; + /** Resource for '/reports/assets:getSummary' has methods for the following verbs: post */ + (path: "/reports/assets:getSummary"): GetSummary; + /** Resource for '/reports/assets:getSnapshotExport' has methods for the following verbs: post */ + (path: "/reports/assets:getSnapshotExport"): GetSnapshotExport; + /** Resource for '/savedFilters' has methods for the following verbs: get */ + (path: "/savedFilters"): ListSavedFilter; + /** Resource for '/savedFilters/\{filterName\}' has methods for the following verbs: get, put, delete */ + (path: "/savedFilters/{filterName}", filterName: string): GetSavedFilter; + /** Resource for '/tasks' has methods for the following verbs: get */ + (path: "/tasks"): ListTask; + /** Resource for '/tasks/\{taskId\}' has methods for the following verbs: get */ + (path: "/tasks/{taskId}", taskId: string): GetTask; + /** Resource for '/tasks/\{taskId\}:cancel' has methods for the following verbs: post */ + (path: "/tasks/{taskId}:cancel", taskId: string): CancelTask; + /** Resource for '/tasks/\{taskId\}:run' has methods for the following verbs: post */ + (path: "/tasks/{taskId}:run", taskId: string): RunTask; + /** Resource for '/tasks/\{taskId\}:download' has methods for the following verbs: post */ + (path: "/tasks/{taskId}:download", taskId: string): DownloadTask; + /** Resource for '/cisaCves' has methods for the following verbs: get */ + (path: "/cisaCves"): GetCisaCves; + /** Resource for '/cisaCves/\{cveId\}' has methods for the following verbs: get */ + (path: "/cisaCves/{cveId}", cveId: string): GetCisaCve; +} + +export type EasmServiceClient = Client & { + path: Routes; +}; diff --git a/sdk/easm/defendereasm-rest/src/easmService.ts b/sdk/easm/defendereasm-rest/src/easmService.ts new file mode 100644 index 000000000000..ad4d0964e67b --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/easmService.ts @@ -0,0 +1,43 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { getClient, ClientOptions } from "@azure-rest/core-client"; +import { logger } from "./logger.js"; +import { TokenCredential } from "@azure/core-auth"; +import { EasmServiceClient } from "./clientDefinitions.js"; + +/** + * Initialize a new instance of `EasmServiceClient` + * @param endpointParam - The endpoint hosting the requested resource. For example, https://{region}.easm.defender.microsoft.com/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/workspaces/{workspaceName} + * @param credentials - uniquely identify client credential + * @param options - the parameter for all optional parameters + */ +export default function createClient( + endpointParam: string, + credentials: TokenCredential, + options: ClientOptions = {}, +): EasmServiceClient { + const endpointUrl = options.endpoint ?? options.baseUrl ?? `${endpointParam}`; + options.apiVersion = options.apiVersion ?? "2024-03-01-preview"; + const userAgentInfo = `azsdk-js-defender-easm-rest/1.0.0-beta.1`; + const userAgentPrefix = + options.userAgentOptions && options.userAgentOptions.userAgentPrefix + ? `${options.userAgentOptions.userAgentPrefix} ${userAgentInfo}` + : `${userAgentInfo}`; + options = { + ...options, + userAgentOptions: { + userAgentPrefix, + }, + loggingOptions: { + logger: options.loggingOptions?.logger ?? logger.info, + }, + credentials: { + scopes: options.credentials?.scopes ?? ["https://easm.defender.microsoft.com/.default"], + }, + }; + + const client = getClient(endpointUrl, credentials, options) as EasmServiceClient; + + return client; +} diff --git a/sdk/easm/defendereasm-rest/src/index.ts b/sdk/easm/defendereasm-rest/src/index.ts new file mode 100644 index 000000000000..a2d4ec3c5db6 --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/index.ts @@ -0,0 +1,15 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import EasmService from "./easmService.js"; + +export * from "./easmService.js"; +export * from "./parameters.js"; +export * from "./responses.js"; +export * from "./clientDefinitions.js"; +export * from "./isUnexpected.js"; +export * from "./models.js"; +export * from "./outputModels.js"; +export * from "./paginateHelper.js"; + +export default EasmService; diff --git a/sdk/easm/defendereasm-rest/src/isUnexpected.ts b/sdk/easm/defendereasm-rest/src/isUnexpected.ts new file mode 100644 index 000000000000..6b5656ceeaa8 --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/isUnexpected.ts @@ -0,0 +1,429 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { + ListAssetResource200Response, + ListAssetResourceDefaultResponse, + UpdateAssets200Response, + UpdateAssetsDefaultResponse, + GetAssetResource200Response, + GetAssetResourceDefaultResponse, + DismissAssetChain200Response, + DismissAssetChainDefaultResponse, + GetAssetsExport200Response, + GetAssetsExportDefaultResponse, + GetObservations200Response, + GetObservationsDefaultResponse, + GetDeltaDetails200Response, + GetDeltaDetailsDefaultResponse, + GetDeltaSummary200Response, + GetDeltaSummaryDefaultResponse, + ListDataConnection200Response, + ListDataConnectionDefaultResponse, + ValidateDataConnection200Response, + ValidateDataConnectionDefaultResponse, + GetDataConnection200Response, + GetDataConnectionDefaultResponse, + CreateOrReplaceDataConnection200Response, + CreateOrReplaceDataConnectionDefaultResponse, + DeleteDataConnection204Response, + DeleteDataConnectionDefaultResponse, + ListDiscoGroup200Response, + ListDiscoGroupDefaultResponse, + ValidateDiscoGroup200Response, + ValidateDiscoGroupDefaultResponse, + GetDiscoGroup200Response, + GetDiscoGroupDefaultResponse, + CreateOrReplaceDiscoGroup200Response, + CreateOrReplaceDiscoGroupDefaultResponse, + RunDiscoGroup204Response, + RunDiscoGroupDefaultResponse, + ListRuns200Response, + ListRunsDefaultResponse, + GetAssetChainSummary200Response, + GetAssetChainSummaryDefaultResponse, + DismissSeedChain200Response, + DismissSeedChainDefaultResponse, + ListDiscoTemplate200Response, + ListDiscoTemplateDefaultResponse, + GetDiscoTemplate200Response, + GetDiscoTemplateDefaultResponse, + GetBillable200Response, + GetBillableDefaultResponse, + GetSnapshot200Response, + GetSnapshotDefaultResponse, + GetSummary200Response, + GetSummaryDefaultResponse, + GetSnapshotExport200Response, + GetSnapshotExportDefaultResponse, + ListSavedFilter200Response, + ListSavedFilterDefaultResponse, + GetSavedFilter200Response, + GetSavedFilterDefaultResponse, + CreateOrReplaceSavedFilter200Response, + CreateOrReplaceSavedFilterDefaultResponse, + DeleteSavedFilter204Response, + DeleteSavedFilterDefaultResponse, + ListTask200Response, + ListTaskDefaultResponse, + GetTask200Response, + GetTaskDefaultResponse, + CancelTask200Response, + CancelTaskDefaultResponse, + RunTask200Response, + RunTaskDefaultResponse, + DownloadTask200Response, + DownloadTaskDefaultResponse, + GetCisaCves200Response, + GetCisaCvesDefaultResponse, + GetCisaCve200Response, + GetCisaCveDefaultResponse, +} from "./responses.js"; + +const responseMap: Record = { + "GET /assets": ["200"], + "POST /assets": ["200"], + "GET /assets/{assetId}": ["200"], + "POST /assets/{assetId}:dismissAssetChain": ["200"], + "POST /assets:export": ["200"], + "POST /assets/{assetId}:getObservations": ["200"], + "POST /assets:getDeltaDetails": ["200"], + "POST /assets:getDeltaSummary": ["200"], + "GET /dataConnections": ["200"], + "POST /dataConnections:validate": ["200"], + "GET /dataConnections/{dataConnectionName}": ["200"], + "PUT /dataConnections/{dataConnectionName}": ["200"], + "DELETE /dataConnections/{dataConnectionName}": ["204"], + "GET /discoGroups": ["200"], + "POST /discoGroups:validate": ["200"], + "GET /discoGroups/{groupName}": ["200"], + "PUT /discoGroups/{groupName}": ["200"], + "POST /discoGroups/{groupName}:run": ["204"], + "GET /discoGroups/{groupName}/runs": ["200"], + "POST /discoGroups:getAssetChainSummary": ["200"], + "POST /discoGroups:dismissSeedChain": ["200"], + "GET /discoTemplates": ["200"], + "GET /discoTemplates/{templateId}": ["200"], + "POST /reports/assets:getBillable": ["200"], + "POST /reports/assets:getSnapshot": ["200"], + "POST /reports/assets:getSummary": ["200"], + "POST /reports/assets:getSnapshotExport": ["200"], + "GET /savedFilters": ["200"], + "GET /savedFilters/{filterName}": ["200"], + "PUT /savedFilters/{filterName}": ["200"], + "DELETE /savedFilters/{filterName}": ["204"], + "GET /tasks": ["200"], + "GET /tasks/{taskId}": ["200"], + "POST /tasks/{taskId}:cancel": ["200"], + "POST /tasks/{taskId}:run": ["200"], + "POST /tasks/{taskId}:download": ["200"], + "GET /cisaCves": ["200"], + "GET /cisaCves/{cveId}": ["200"], +}; + +export function isUnexpected( + response: ListAssetResource200Response | ListAssetResourceDefaultResponse, +): response is ListAssetResourceDefaultResponse; +export function isUnexpected( + response: UpdateAssets200Response | UpdateAssetsDefaultResponse, +): response is UpdateAssetsDefaultResponse; +export function isUnexpected( + response: GetAssetResource200Response | GetAssetResourceDefaultResponse, +): response is GetAssetResourceDefaultResponse; +export function isUnexpected( + response: DismissAssetChain200Response | DismissAssetChainDefaultResponse, +): response is DismissAssetChainDefaultResponse; +export function isUnexpected( + response: GetAssetsExport200Response | GetAssetsExportDefaultResponse, +): response is GetAssetsExportDefaultResponse; +export function isUnexpected( + response: GetObservations200Response | GetObservationsDefaultResponse, +): response is GetObservationsDefaultResponse; +export function isUnexpected( + response: GetDeltaDetails200Response | GetDeltaDetailsDefaultResponse, +): response is GetDeltaDetailsDefaultResponse; +export function isUnexpected( + response: GetDeltaSummary200Response | GetDeltaSummaryDefaultResponse, +): response is GetDeltaSummaryDefaultResponse; +export function isUnexpected( + response: ListDataConnection200Response | ListDataConnectionDefaultResponse, +): response is ListDataConnectionDefaultResponse; +export function isUnexpected( + response: ValidateDataConnection200Response | ValidateDataConnectionDefaultResponse, +): response is ValidateDataConnectionDefaultResponse; +export function isUnexpected( + response: GetDataConnection200Response | GetDataConnectionDefaultResponse, +): response is GetDataConnectionDefaultResponse; +export function isUnexpected( + response: CreateOrReplaceDataConnection200Response | CreateOrReplaceDataConnectionDefaultResponse, +): response is CreateOrReplaceDataConnectionDefaultResponse; +export function isUnexpected( + response: DeleteDataConnection204Response | DeleteDataConnectionDefaultResponse, +): response is DeleteDataConnectionDefaultResponse; +export function isUnexpected( + response: ListDiscoGroup200Response | ListDiscoGroupDefaultResponse, +): response is ListDiscoGroupDefaultResponse; +export function isUnexpected( + response: ValidateDiscoGroup200Response | ValidateDiscoGroupDefaultResponse, +): response is ValidateDiscoGroupDefaultResponse; +export function isUnexpected( + response: GetDiscoGroup200Response | GetDiscoGroupDefaultResponse, +): response is GetDiscoGroupDefaultResponse; +export function isUnexpected( + response: CreateOrReplaceDiscoGroup200Response | CreateOrReplaceDiscoGroupDefaultResponse, +): response is CreateOrReplaceDiscoGroupDefaultResponse; +export function isUnexpected( + response: RunDiscoGroup204Response | RunDiscoGroupDefaultResponse, +): response is RunDiscoGroupDefaultResponse; +export function isUnexpected( + response: ListRuns200Response | ListRunsDefaultResponse, +): response is ListRunsDefaultResponse; +export function isUnexpected( + response: GetAssetChainSummary200Response | GetAssetChainSummaryDefaultResponse, +): response is GetAssetChainSummaryDefaultResponse; +export function isUnexpected( + response: DismissSeedChain200Response | DismissSeedChainDefaultResponse, +): response is DismissSeedChainDefaultResponse; +export function isUnexpected( + response: ListDiscoTemplate200Response | ListDiscoTemplateDefaultResponse, +): response is ListDiscoTemplateDefaultResponse; +export function isUnexpected( + response: GetDiscoTemplate200Response | GetDiscoTemplateDefaultResponse, +): response is GetDiscoTemplateDefaultResponse; +export function isUnexpected( + response: GetBillable200Response | GetBillableDefaultResponse, +): response is GetBillableDefaultResponse; +export function isUnexpected( + response: GetSnapshot200Response | GetSnapshotDefaultResponse, +): response is GetSnapshotDefaultResponse; +export function isUnexpected( + response: GetSummary200Response | GetSummaryDefaultResponse, +): response is GetSummaryDefaultResponse; +export function isUnexpected( + response: GetSnapshotExport200Response | GetSnapshotExportDefaultResponse, +): response is GetSnapshotExportDefaultResponse; +export function isUnexpected( + response: ListSavedFilter200Response | ListSavedFilterDefaultResponse, +): response is ListSavedFilterDefaultResponse; +export function isUnexpected( + response: GetSavedFilter200Response | GetSavedFilterDefaultResponse, +): response is GetSavedFilterDefaultResponse; +export function isUnexpected( + response: CreateOrReplaceSavedFilter200Response | CreateOrReplaceSavedFilterDefaultResponse, +): response is CreateOrReplaceSavedFilterDefaultResponse; +export function isUnexpected( + response: DeleteSavedFilter204Response | DeleteSavedFilterDefaultResponse, +): response is DeleteSavedFilterDefaultResponse; +export function isUnexpected( + response: ListTask200Response | ListTaskDefaultResponse, +): response is ListTaskDefaultResponse; +export function isUnexpected( + response: GetTask200Response | GetTaskDefaultResponse, +): response is GetTaskDefaultResponse; +export function isUnexpected( + response: CancelTask200Response | CancelTaskDefaultResponse, +): response is CancelTaskDefaultResponse; +export function isUnexpected( + response: RunTask200Response | RunTaskDefaultResponse, +): response is RunTaskDefaultResponse; +export function isUnexpected( + response: DownloadTask200Response | DownloadTaskDefaultResponse, +): response is DownloadTaskDefaultResponse; +export function isUnexpected( + response: GetCisaCves200Response | GetCisaCvesDefaultResponse, +): response is GetCisaCvesDefaultResponse; +export function isUnexpected( + response: GetCisaCve200Response | GetCisaCveDefaultResponse, +): response is GetCisaCveDefaultResponse; +export function isUnexpected( + response: + | ListAssetResource200Response + | ListAssetResourceDefaultResponse + | UpdateAssets200Response + | UpdateAssetsDefaultResponse + | GetAssetResource200Response + | GetAssetResourceDefaultResponse + | DismissAssetChain200Response + | DismissAssetChainDefaultResponse + | GetAssetsExport200Response + | GetAssetsExportDefaultResponse + | GetObservations200Response + | GetObservationsDefaultResponse + | GetDeltaDetails200Response + | GetDeltaDetailsDefaultResponse + | GetDeltaSummary200Response + | GetDeltaSummaryDefaultResponse + | ListDataConnection200Response + | ListDataConnectionDefaultResponse + | ValidateDataConnection200Response + | ValidateDataConnectionDefaultResponse + | GetDataConnection200Response + | GetDataConnectionDefaultResponse + | CreateOrReplaceDataConnection200Response + | CreateOrReplaceDataConnectionDefaultResponse + | DeleteDataConnection204Response + | DeleteDataConnectionDefaultResponse + | ListDiscoGroup200Response + | ListDiscoGroupDefaultResponse + | ValidateDiscoGroup200Response + | ValidateDiscoGroupDefaultResponse + | GetDiscoGroup200Response + | GetDiscoGroupDefaultResponse + | CreateOrReplaceDiscoGroup200Response + | CreateOrReplaceDiscoGroupDefaultResponse + | RunDiscoGroup204Response + | RunDiscoGroupDefaultResponse + | ListRuns200Response + | ListRunsDefaultResponse + | GetAssetChainSummary200Response + | GetAssetChainSummaryDefaultResponse + | DismissSeedChain200Response + | DismissSeedChainDefaultResponse + | ListDiscoTemplate200Response + | ListDiscoTemplateDefaultResponse + | GetDiscoTemplate200Response + | GetDiscoTemplateDefaultResponse + | GetBillable200Response + | GetBillableDefaultResponse + | GetSnapshot200Response + | GetSnapshotDefaultResponse + | GetSummary200Response + | GetSummaryDefaultResponse + | GetSnapshotExport200Response + | GetSnapshotExportDefaultResponse + | ListSavedFilter200Response + | ListSavedFilterDefaultResponse + | GetSavedFilter200Response + | GetSavedFilterDefaultResponse + | CreateOrReplaceSavedFilter200Response + | CreateOrReplaceSavedFilterDefaultResponse + | DeleteSavedFilter204Response + | DeleteSavedFilterDefaultResponse + | ListTask200Response + | ListTaskDefaultResponse + | GetTask200Response + | GetTaskDefaultResponse + | CancelTask200Response + | CancelTaskDefaultResponse + | RunTask200Response + | RunTaskDefaultResponse + | DownloadTask200Response + | DownloadTaskDefaultResponse + | GetCisaCves200Response + | GetCisaCvesDefaultResponse + | GetCisaCve200Response + | GetCisaCveDefaultResponse, +): response is + | ListAssetResourceDefaultResponse + | UpdateAssetsDefaultResponse + | GetAssetResourceDefaultResponse + | DismissAssetChainDefaultResponse + | GetAssetsExportDefaultResponse + | GetObservationsDefaultResponse + | GetDeltaDetailsDefaultResponse + | GetDeltaSummaryDefaultResponse + | ListDataConnectionDefaultResponse + | ValidateDataConnectionDefaultResponse + | GetDataConnectionDefaultResponse + | CreateOrReplaceDataConnectionDefaultResponse + | DeleteDataConnectionDefaultResponse + | ListDiscoGroupDefaultResponse + | ValidateDiscoGroupDefaultResponse + | GetDiscoGroupDefaultResponse + | CreateOrReplaceDiscoGroupDefaultResponse + | RunDiscoGroupDefaultResponse + | ListRunsDefaultResponse + | GetAssetChainSummaryDefaultResponse + | DismissSeedChainDefaultResponse + | ListDiscoTemplateDefaultResponse + | GetDiscoTemplateDefaultResponse + | GetBillableDefaultResponse + | GetSnapshotDefaultResponse + | GetSummaryDefaultResponse + | GetSnapshotExportDefaultResponse + | ListSavedFilterDefaultResponse + | GetSavedFilterDefaultResponse + | CreateOrReplaceSavedFilterDefaultResponse + | DeleteSavedFilterDefaultResponse + | ListTaskDefaultResponse + | GetTaskDefaultResponse + | CancelTaskDefaultResponse + | RunTaskDefaultResponse + | DownloadTaskDefaultResponse + | GetCisaCvesDefaultResponse + | GetCisaCveDefaultResponse { + const lroOriginal = response.headers["x-ms-original-url"]; + const url = new URL(lroOriginal ?? response.request.url); + const method = response.request.method; + let pathDetails = responseMap[`${method} ${url.pathname}`]; + if (!pathDetails) { + pathDetails = getParametrizedPathSuccess(method, url.pathname); + } + return !pathDetails.includes(response.status); +} + +function getParametrizedPathSuccess(method: string, path: string): string[] { + const pathParts = path.split("/"); + + // Traverse list to match the longest candidate + // matchedLen: the length of candidate path + // matchedValue: the matched status code array + let matchedLen = -1, + matchedValue: string[] = []; + + // Iterate the responseMap to find a match + for (const [key, value] of Object.entries(responseMap)) { + // Extracting the path from the map key which is in format + // GET /path/foo + if (!key.startsWith(method)) { + continue; + } + const candidatePath = getPathFromMapKey(key); + // Get each part of the url path + const candidateParts = candidatePath.split("/"); + + // track if we have found a match to return the values found. + let found = true; + for (let i = candidateParts.length - 1, j = pathParts.length - 1; i >= 1 && j >= 1; i--, j--) { + if (candidateParts[i]?.startsWith("{") && candidateParts[i]?.indexOf("}") !== -1) { + const start = candidateParts[i]!.indexOf("}") + 1, + end = candidateParts[i]?.length; + // If the current part of the candidate is a "template" part + // Try to use the suffix of pattern to match the path + // {guid} ==> $ + // {guid}:export ==> :export$ + const isMatched = new RegExp(`${candidateParts[i]?.slice(start, end)}`).test( + pathParts[j] || "", + ); + + if (!isMatched) { + found = false; + break; + } + continue; + } + + // If the candidate part is not a template and + // the parts don't match mark the candidate as not found + // to move on with the next candidate path. + if (candidateParts[i] !== pathParts[j]) { + found = false; + break; + } + } + + // We finished evaluating the current candidate parts + // Update the matched value if and only if we found the longer pattern + if (found && candidatePath.length > matchedLen) { + matchedLen = candidatePath.length; + matchedValue = value; + } + } + + return matchedValue; +} + +function getPathFromMapKey(mapKey: string): string { + const pathStart = mapKey.indexOf("/"); + return mapKey.slice(pathStart); +} diff --git a/sdk/easm/defendereasm-rest/src/logger.ts b/sdk/easm/defendereasm-rest/src/logger.ts new file mode 100644 index 000000000000..b5cba53d7d35 --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/logger.ts @@ -0,0 +1,5 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { createClientLogger } from "@azure/logger"; +export const logger = createClientLogger("defender-easm-rest"); diff --git a/sdk/easm/defendereasm-rest/src/models.ts b/sdk/easm/defendereasm-rest/src/models.ts new file mode 100644 index 000000000000..1ae6f561cdda --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/models.ts @@ -0,0 +1,172 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +/** A request body used to update an asset. */ +export interface AssetUpdateData { + /** + * The state to update the asset to. + * + * Possible values: "candidate", "confirmed", "dismissed", "candidateInvestigate", "associatedPartner", "associatedThirdparty" + */ + state?: string; + /** A string which can be used to identify the asset in external systems. */ + externalId?: string; + /** Any Labels to update the asset with. */ + labels?: TypeSpecRecord; + /** + * A list of asset types to cascade the updates to. + * + * Possible values: "as", "contact", "domain", "host", "ipAddress", "ipBlock", "page", "sslCert" + */ + transfers?: string; +} + +export interface TypeSpecRecord extends Record {} + +export interface LogAnalyticsDataConnectionProperties extends DataConnectionProperties { + /** log analytics api key */ + apiKey?: string; + /** log analytics workspace id */ + workspaceId?: string; +} + +/** The properties required to establish connection to a particular service */ +export interface DataConnectionProperties {} + +export interface AzureDataExplorerDataConnectionProperties extends DataConnectionProperties { + /** The azure data explorer cluster name */ + clusterName?: string; + /** The azure data explorer region */ + region?: string; + /** The azure data explorer database name */ + databaseName?: string; +} + +export interface DataConnectionDataParent { + /** The name of data connection */ + name?: string; + /** + * The type of data the data connection will transfer. + * + * Possible values: "assets", "attackSurfaceInsights" + */ + content?: string; + /** + * The rate at which the data connection will receive updates. + * + * Possible values: "daily", "weekly", "monthly" + */ + frequency?: string; + /** The day to update the data connection on. (1-7 for weekly, 1-31 for monthly) */ + frequencyOffset?: number; + kind: string; +} + +export interface LogAnalyticsDataConnectionData extends DataConnectionDataParent { + /** The kind of DataConnectionData */ + kind: "logAnalytics"; + /** properties */ + properties: LogAnalyticsDataConnectionProperties; +} + +export interface AzureDataExplorerDataConnectionData extends DataConnectionDataParent { + /** The kind of DataConnectionData */ + kind: "azureDataExplorer"; + /** properties */ + properties: AzureDataExplorerDataConnectionProperties; +} + +/** Source entity used to drive discovery. */ +export interface DiscoSource { + /** + * The kind of disco source. + * + * Possible values: "as", "attribute", "contact", "domain", "host", "ipBlock" + */ + kind?: string; + /** The name for the disco source. */ + name?: string; +} + +/** A request body used to create a discovery group. */ +export interface DiscoGroupData { + /** The name for a disco group. */ + name?: string; + /** The description for a disco group. */ + description?: string; + /** The tier for the disco group which will affect the algorithm used for the disco runs in this group. */ + tier?: string; + /** The frequency at which the disco group is supposed to be rerun in milliseconds. */ + frequencyMilliseconds?: number; + /** The list of seeds used for the disco group runs. */ + seeds?: Array; + /** The list of names used for the disco group runs. */ + names?: string[]; + /** The list of excludes used for the disco group runs, aka assets to exclude from the discovery algorithm. */ + excludes?: Array; + /** The unique identifier for the disco template used for the disco group creation. */ + templateId?: string; +} + +/** AssetChainRequest containing information needed for the retrieval of the asset chain summary. */ +export interface AssetChainRequest { + /** + * Asset chain source. + * + * Possible values: "DISCO_GROUP", "DISCO_SEED", "ASSET_CHAIN" + */ + assetChainSource?: string; + /** A collection of asset chain source ids. */ + sourceIds?: string[]; +} + +/** A request body used to retrieve an asset report snapshot. */ +export interface ReportAssetSnapshotRequest { + /** The metric to retrieve a snapshot for. */ + metric?: string; + /** The name of the label to retrieve a snapshot for. */ + labelName?: string; + /** The number of assets per page. */ + size?: number; + /** The page to retrieve. */ + page?: number; +} + +/** A request body used to retrieve summary asset information. One and only one collection of summary identifiers must be provided: filters, metrics, or metricCategories. */ +export interface ReportAssetSummaryRequest { + /** Categories to retrieve risk reporting data for. */ + metricCategories?: string[]; + /** Metrics to retrieve risk reporting data for. */ + metrics?: string[]; + /** Query filters to apply to the asset summary. */ + filters?: string[]; + /** A parameter to group the assets by (first level facet field), only used when the chosen summary identifier is filters. */ + groupBy?: string; + /** A parameter to segment the assets by (second level facet field), only used when the chosen summary identifier is filters. */ + segmentBy?: string; + /** Currently unused. */ + labelName?: string; +} + +/** A request body used for an asset report snapshot export. */ +export interface ReportAssetSnapshotExportRequest { + /** The metric to retrieve a snapshot for. */ + metric?: string; + /** The filename of the exported file. */ + fileName?: string; + /** The columns to include in the export */ + columns?: string[]; +} + +/** A request body used to create a saved filter. */ +export interface SavedFilterData { + /** An expression on the resource type that selects the resources to be returned. */ + filter: string; + /** A human readable description of the saved filter. */ + description: string; +} + +export type DataConnectionData = + | DataConnectionDataParent + | LogAnalyticsDataConnectionData + | AzureDataExplorerDataConnectionData; diff --git a/sdk/easm/defendereasm-rest/src/outputModels.ts b/sdk/easm/defendereasm-rest/src/outputModels.ts new file mode 100644 index 000000000000..295568e9281d --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/outputModels.ts @@ -0,0 +1,1224 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { Paged } from "@azure/core-paging"; +import { ErrorResponse } from "@azure-rest/core-client"; + +/** The items in the current page of results. */ +export interface AssetResourceOutputParent { + /** The system generated unique id for the resource. */ + readonly id: string; + /** The caller provided unique name for the resource. */ + name?: string; + /** The name that can be used for display purposes. */ + displayName?: string; + /** Global UUID for the asset. */ + uuid?: string; + /** The date this asset was first added to this workspace. */ + createdDate?: string; + /** The date this asset was last updated for this workspace. */ + updatedDate?: string; + /** Possible values: "candidate", "confirmed", "dismissed", "candidateInvestigate", "associatedPartner", "associatedThirdparty", "archived" */ + state?: string; + /** An optional customer provided identifier for this asset. */ + externalId?: string; + /** Customer labels assigned to this asset. */ + labels?: string[]; + /** An indicator of whether this asset represents a wildcard rollup of assets on this domain. */ + wildcard?: boolean; + /** The name of the DiscoGroup that brought added this asset to the workspace. */ + discoGroupName?: string; + /** The history of how this asset was pulled into the workspace through the discovery process. */ + auditTrail?: Array; + reason?: string; + kind: string; +} + +/** The history of how this asset was pulled into the workspace through the discovery process. */ +export interface AuditTrailItemOutput { + /** The system generated unique id for the resource. */ + id?: string; + /** The caller provided unique name for the resource. */ + name?: string; + /** The name that can be used for display purposes. */ + displayName?: string; + /** + * The kind of asset. + * + * Possible values: "as", "contact", "domain", "host", "ipAddress", "ipBlock", "page", "sslCert" + */ + kind?: string; + /** An explanation of why this audit trail node was discovered from the previous node. */ + reason?: string; +} + +export interface AsAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "as"; + /** asset */ + asset: AsAssetOutput; +} + +export interface AsAssetOutput extends InventoryAssetOutput { + asn?: number; + asNames?: Array; + orgNames?: Array; + orgIds?: Array; + countries?: Array; + registries?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + registrarCreatedAt?: Array; + registrarUpdatedAt?: Array; + registrantContacts?: Array; + adminContacts?: Array; + technicalContacts?: Array; + registrarNames?: Array; + registrantNames?: Array; + adminNames?: Array; + technicalNames?: Array; + adminOrgs?: Array; + technicalOrgs?: Array; + registrantPhones?: Array; + adminPhones?: Array; + technicalPhones?: Array; + detailedFromWhoisAt?: string; +} + +export interface ObservedStringOutput extends ObservedValueOutput { + value?: string; + sources?: Array; +} + +export interface SourceOutput { + source?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + reason?: string; +} + +/** Template model for observed values */ +export interface ObservedValueOutput { + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; +} + +export interface ObservedLongOutput extends ObservedValueOutput { + value?: number; + sources?: Array; +} + +export interface ObservedIntegerOutput extends ObservedValueOutput { + value?: number; + sources?: Array; +} + +export interface ObservedBooleanOutput extends ObservedValueOutput { + value?: boolean; + sources?: Array; +} + +export interface ObservedHeaderOutput extends ObservedValueOutput { + headerName?: string; + headerValue?: string; +} + +export interface ObservedPortStateOutput extends ObservedValueOutput { + /** Possible values: "open", "closed", "filtered" */ + value?: string; + port?: number; +} + +export interface ObservedLocationOutput extends ObservedValueOutput { + value?: LocationOutput; + sources?: Array; +} + +export interface LocationOutput { + countryCode?: string; + countryName?: string; + region?: string; + regionName?: string; + city?: string; + areaCode?: number; + postalCode?: string; + latitude?: number; + longitude?: number; + dmaCode?: number; + metroCodeId?: number; +} + +export interface ObservedIntegersOutput extends ObservedValueOutput { + values?: number[]; + sources?: Array; +} + +/** A inventory base model created for swagger documentation purpose */ +export interface InventoryAssetOutput {} + +export interface ContactAssetOutput extends InventoryAssetOutput { + email?: string; + names?: Array; + organizations?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; +} + +export interface HostAssetOutput extends InventoryAssetOutput { + host?: string; + domain?: string; + ipAddresses?: Array; + webComponents?: Array; + headers?: Array; + attributes?: Array; + cookies?: Array; + sslCerts?: Array; + parentHosts?: Array; + childHosts?: Array; + hostCore?: HostCoreOutput; + services?: Array; + cnames?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + resourceUrls?: Array; + scanMetadata?: Array; + asns?: Array; + ipBlocks?: Array; + responseBodies?: Array; + domainAsset?: DomainAssetOutput; + nsRecord?: Array; + mxRecord?: Array; + webserver?: Array; + location?: Array; + nxdomain?: Array; + sslServerConfig?: Array; + isWildcard?: Array; + banners?: Array; + ipv4?: Array; + ipv6?: Array; +} + +export interface WebComponentOutput { + name?: string; + type?: string; + version?: string; + ruleId?: string[]; + firstSeen?: string; + lastSeen?: string; + count?: number; + cve?: Array; + endOfLife?: number; + recent?: boolean; + ports?: Array; + sources?: Array; + service?: string; +} + +export interface CveOutput { + name?: string; + cweId?: string; + cvssScore?: number; + cvss3Summary?: Cvss3SummaryOutput; +} + +export interface Cvss3SummaryOutput { + version?: string; + vectorString?: string; + attackVector?: string; + attackComplexity?: string; + privilegesRequired?: string; + userInteraction?: string; + scope?: string; + confidentialityImpact?: string; + integrityImpact?: string; + availabilityImpact?: string; + baseScore?: number; + baseSeverity?: string; + exploitCodeMaturity?: string; + remediationLevel?: string; + reportConfidence?: string; + exploitabilityScore?: number; + impactScore?: number; +} + +export interface PortOutput { + port?: number; + firstSeen?: string; + lastSeen?: string; + count?: number; +} + +export interface AttributeOutput { + attributeType?: string; + attributeValue?: string; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; +} + +export interface CookieOutput { + cookieName?: string; + cookieDomain?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; + cookieExpiryDate?: string; +} + +export interface SslCertAssetOutput extends InventoryAssetOutput { + sha1?: string; + subjectCommonNames?: string[]; + organizations?: string[]; + organizationalUnits?: string[]; + issuerCommonNames?: string[]; + sigAlgName?: string; + invalidAfter?: string; + serialNumber?: string; + subjectAlternativeNames?: string[]; + issuerAlternativeNames?: string[]; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + invalidBefore?: string; + keySize?: number; + keyAlgorithm?: string; + subjectLocality?: string[]; + subjectState?: string[]; + subjectCountry?: string[]; + issuerLocality?: string[]; + issuerState?: string[]; + issuerCountry?: string[]; + subjectOrganizations?: string[]; + subjectOrganizationalUnits?: string[]; + issuerOrganizations?: string[]; + issuerOrganizationalUnits?: string[]; + version?: number; + certificateAuthority?: boolean; + selfSigned?: boolean; + sigAlgOid?: string; + recent?: boolean; + /** Possible values: "domainValidation", "organizationValidation", "extendedValidation" */ + validationType?: string; +} + +export interface HostCoreOutput { + host?: string; + domain?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + blacklistCauseFirstSeen?: string; + blacklistCauseLastSeen?: string; + blacklistCauseCount?: number; + blacklistResourceFirstSeen?: string; + blacklistResourceLastSeen?: string; + blacklistResourceCount?: number; + blacklistSequenceFirstSeen?: string; + blacklistSequenceLastSeen?: string; + blacklistSequenceCount?: number; + phishCauseCount?: number; + malwareCauseCount?: number; + spamCauseCount?: number; + scamCauseCount?: number; + phishResourceCount?: number; + malwareResourceCount?: number; + spamResourceCount?: number; + scamResourceCount?: number; + phishSequenceCount?: number; + malwareSequenceCount?: number; + spamSequenceCount?: number; + scamSequenceCount?: number; + alexaRank?: number; + hostReputationScore?: number; + hostPhishReputationScore?: number; + hostMalwareReputationScore?: number; + hostSpamReputationScore?: number; + hostScamReputationScore?: number; + domainReputationScore?: number; + domainPhishReputationScore?: number; + domainMalwareReputationScore?: number; + domainSpamReputationScore?: number; + domainScamReputationScore?: number; + uuid?: string; +} + +export interface ServiceOutput { + scheme?: string; + port?: number; + webComponents?: Array; + sslCerts?: Array; + exceptions?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; + portStates?: Array; +} + +export interface ResourceUrlOutput { + url?: string; + resources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; +} + +export interface DependentResourceOutput { + md5?: string; + responseBodySize?: number; + firstSeen?: string; + lastSeen?: string; + count?: number; + firstSeenCrawlGuid?: string; + firstSeenPageGuid?: string; + firstSeenResourceGuid?: string; + lastSeenCrawlGuid?: string; + lastSeenPageGuid?: string; + lastSeenResourceGuid?: string; + responseBodyMinhash?: number[]; + contentType?: string; + sha256?: string; + sha384?: string; + sha512?: string; + url?: string; + cached?: boolean; + sriChecks?: Array; + host?: string; + lastObservedViolation?: string; + lastObservedValidation?: string; + lastObservedActualSriHash?: string; + lastObservedExpectedSriHash?: string; +} + +export interface SubResourceIntegrityCheckOutput { + violation?: boolean; + firstSeen?: string; + lastSeen?: string; + count?: number; + causePageUrl?: string; + crawlGuid?: string; + pageGuid?: string; + resourceGuid?: string; + expectedHash?: string; +} + +export interface ScanMetadataOutput { + port?: number; + bannerMetadata?: string; + startScan?: string; + endScan?: string; +} + +export interface IpBlockOutput { + ipBlock?: string; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; +} + +export interface DomainAssetOutput { + domain?: string; + whoisId?: number; + registrarIanaIds?: Array; + registrantContacts?: Array; + registrantOrgs?: Array; + adminContacts?: Array; + technicalContacts?: Array; + alexaInfos?: Array; + nameServers?: Array; + mailServers?: Array; + whoisServers?: Array; + domainStatuses?: Array; + registrarCreatedAt?: Array; + registrarUpdatedAt?: Array; + registrarExpiresAt?: Array; + soaRecords?: Array; + detailedFromWhoisAt?: string; + registrarNames?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + parkedDomain?: Array; + registrantNames?: Array; + adminNames?: Array; + technicalNames?: Array; + adminOrgs?: Array; + technicalOrgs?: Array; + registrantPhones?: Array; + adminPhones?: Array; + technicalPhones?: Array; +} + +export interface AlexaInfoOutput { + alexaRank?: number; + category?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; +} + +export interface SoaRecordOutput { + nameServer?: string; + email?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + serialNumber?: number; + recent?: boolean; +} + +export interface SslServerConfigOutput { + tlsVersions?: string[]; + cipherSuites?: string[]; + firstSeen?: string; + lastSeen?: string; + count?: number; + sources?: Array; +} + +export interface BannerOutput { + port?: number; + banner?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + scanType?: string; + bannerMetadata?: string; + recent?: boolean; + sha256?: string; + sources?: Array; +} + +export interface IpAddressAssetOutput extends InventoryAssetOutput { + ipAddress?: string; + asns?: Array; + reputations?: Array; + webComponents?: Array; + netRanges?: Array; + headers?: Array; + attributes?: Array; + cookies?: Array; + sslCerts?: Array; + services?: Array; + ipBlocks?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + banners?: Array; + scanMetadata?: Array; + nsRecord?: Array; + mxRecord?: Array; + location?: Array; + hosts?: Array; + nxdomain?: Array; + sslServerConfig?: Array; + ipv4?: boolean; + ipv6?: boolean; +} + +export interface ReputationOutput { + listName?: string; + threatType?: string; + trusted?: boolean; + cidr?: string; + firstSeen?: string; + lastSeen?: string; + listUpdatedAt?: string; + recent?: boolean; +} + +export interface IpBlockAssetOutput extends InventoryAssetOutput { + ipBlock?: string; + asns?: Array; + bgpPrefixes?: Array; + netNames?: Array; + registrantContacts?: Array; + registrantOrgs?: Array; + adminContacts?: Array; + technicalContacts?: Array; + registrarCreatedAt?: Array; + registrarUpdatedAt?: Array; + netRanges?: Array; + startIp?: string; + endIp?: string; + reputations?: Array; + detailedFromWhoisAt?: string; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + location?: Array; + registrarExpiresAt?: Array; + registrantNames?: Array; + adminNames?: Array; + technicalNames?: Array; + adminOrgs?: Array; + technicalOrgs?: Array; + registrantPhones?: Array; + adminPhones?: Array; + technicalPhones?: Array; + ipv4?: boolean; + ipv6?: boolean; +} + +export interface PageAssetOutput extends InventoryAssetOutput { + url?: string; + httpMethod?: string; + service?: string; + ipAddresses?: Array; + successful?: Array; + httpResponseCodes?: Array; + httpResponseMessages?: Array; + responseTimes?: Array; + frames?: Array; + windows?: Array; + nonHtmlFrames?: Array; + undirectedContent?: Array; + contentTypes?: Array; + contentLengths?: Array; + windowNames?: Array; + charsets?: Array; + titles?: Array; + languages?: Array; + responseHeaders?: Array; + cookies?: Array; + webComponents?: Array; + attributes?: Array; + assetSecurityPolicies?: Array; + responseBodyMinhashSignatures?: Array; + fullDomMinhashSignatures?: Array; + responseBodyHashSignatures?: Array; + errors?: Array; + sslCerts?: Array; + sources?: Array; + firstSeen?: string; + lastSeen?: string; + count?: number; + cause?: PageCauseOutput; + referrer?: string; + redirectUrls?: Array; + /** Possible values: "httpHeader", "metaRefresh", "javascript", "final" */ + redirectType?: string; + finalUrls?: Array; + finalResponseCodes?: Array; + parkedPage?: Array; + resourceUrls?: Array; + guids?: Array; + finalIpAddresses?: Array; + asns?: Array; + ipBlocks?: Array; + finalAsns?: Array; + finalIpBlocks?: Array; + responseBodies?: Array; + domainAsset?: DomainAssetOutput; + rootUrl?: ObservedBooleanOutput; + isRootUrl?: boolean; + location?: Array; + services?: Array; + siteStatus?: string; + cnames?: Array; + cdns?: Array; + host?: string; + domain?: string; + sslServerConfig?: Array; + gdprAssetSecurityPolicies?: Array; + ipv4?: Array; + ipv6?: Array; +} + +export interface AssetSecurityPolicyOutput { + policyName?: string; + isAffected?: boolean; + description?: string; + firstSeen?: string; + lastSeen?: string; + count?: number; + recent?: boolean; + sources?: Array; +} + +export interface PageCauseOutput { + cause?: string; + causeElementXPath?: string; + location?: string; + possibleMatches?: number; + loopDetected?: boolean; + version?: number; + domChangeIndex?: number; +} + +export interface GuidPairOutput { + pageGuid?: string; + crawlStateGuid?: string; + loadDate?: string; + recent?: boolean; +} + +export interface ContactAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "contact"; + /** asset */ + asset: ContactAssetOutput; +} + +export interface DomainAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "domain"; + /** asset */ + asset: DomainAssetOutput; +} + +export interface HostAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "host"; + /** asset */ + asset: HostAssetOutput; +} + +export interface IpAddressAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "ipAddress"; + /** asset */ + asset: IpAddressAssetOutput; +} + +export interface IpBlockAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "ipBlock"; + /** asset */ + asset: IpBlockAssetOutput; +} + +export interface PageAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "page"; + /** asset */ + asset: PageAssetOutput; +} + +export interface SslCertAssetResourceOutput extends AssetResourceOutputParent { + /** The kind of AssetResource */ + kind: "sslCert"; + /** asset */ + asset: SslCertAssetOutput; +} + +export interface TaskOutput { + /** The unique identifier of the task. */ + readonly id: string; + /** The time the task started. */ + startedAt?: string; + /** The time the task completed. */ + completedAt?: string; + /** The last time the status of the task was updated. */ + lastPolledAt?: string; + /** + * The state the task is in. + * + * Possible values: "pending", "running", "paused", "complete", "incomplete", "failed", "warning" + */ + state?: string; + /** + * The phase the task is in. + * + * Possible values: "running", "polling", "complete" + */ + phase?: string; + /** The reason the task was moved into its current state, if the task wasn't completed. */ + reason?: string; + /** Attributes unique to the task. This differs by task type. */ + metadata?: TypeSpecRecordOutput; +} + +export interface TypeSpecRecordOutput extends Record {} + +export interface AzureCoreTraitsOutput {} + +export interface ObservationPageResponseOutput { + totalElements: number; + prioritySummary: TypeSpecRecordOutput; + value: Array; +} + +export interface TypeSpecRecordOutput extends Record {} + +export interface ObservationResponseOutput { + name: string; + type: string[]; + /** Possible values: 3, 2, 1, 0 */ + priority: string; + cvssScoreV2: number; + cvssScoreV3: number; +} + +export interface DeltaPageResponseOutput { + /** The total number of items available in the full result set. */ + totalElements?: number; + /** The link to access the next page of results. Not set if at the end of the result set. */ + nextLink?: string; + /** The items in the current page of results. */ + value?: Array; +} + +export interface DeltaResponseOutput { + /** + * Shows the asset kind + * + * Possible values: "page", "resource", "mailServer", "nameServer", "host", "domain", "ipAddress", "ipBlock", "as", "contact", "sslCert" + */ + kind: string; + /** Shows the asset name */ + name: string; + /** Shows the date when the asset was originally created */ + createdAt: string; + /** Shows the date when the asset was last updated, usually the date the we trying to pull up the results for */ + updatedAt: string; + /** + * Shows the inventory state + * + * Possible values: "candidate", "candidateInvestigate", "confirmed", "associated", "associatedPartner", "associatedThirdParty", "archived", "dismissed", "autoconfirmed" + */ + state: string; +} + +export interface DeltaSummaryResponseOutput { + /** Contains added, removed, and difference values for the whole range either 7 or 30 days */ + summary: DeltaRangeResponseOutput; + /** Contains added, removed, count, and difference values for each day */ + daily: Array; +} + +export interface DeltaRangeResponseOutput { + /** The range of dates requested */ + range: number; + /** The total amount of assets removed over a date range */ + removed: number; + /** The total amount of assets added over a date range */ + added: number; + /** The total amount of assets changed removed over a date range */ + difference: number; + /** A list of summary changes per asset kind */ + kindSummaries: Array; +} + +export interface DeltaTypeResponseOutput { + /** + * The kind of asset + * + * Possible values: "page", "resource", "mailServer", "nameServer", "host", "domain", "ipAddress", "ipBlock", "as", "contact", "sslCert" + */ + kind: string; + /** The amount of assets removed for one asset kind */ + removed: number; + /** The amount of assets added for one asset kind */ + added: number; + /** The amount of assets changed for one asset kind */ + difference: number; +} + +export interface DailyDeltaTypeResponseOutput extends DeltaTypeResponseOutput { + /** The current number of assets for one asset kind */ + count: number; +} + +export interface DeltaDateResponseOutput { + /** The date that is being requested */ + date: string; + /** A list of summary counts per day */ + deltas: Array; +} + +export interface DataConnectionOutputParent { + /** The system generated unique id for the resource. */ + id?: string; + /** The caller provided unique name for the resource. */ + readonly name: string; + /** The name that can be used for display purposes. */ + displayName?: string; + /** + * The type of data the data connection will transfer + * + * Possible values: "assets", "attackSurfaceInsights" + */ + content?: string; + /** The date the data connection was created. */ + readonly createdDate?: string; + /** + * The rate at which the data connection will receive updates. + * + * Possible values: "daily", "weekly", "monthly" + */ + frequency?: string; + /** The day to update the data connection on. */ + frequencyOffset?: number; + /** The date the data connection was last updated. */ + readonly updatedDate?: string; + /** The date the data connection was last updated by user. */ + readonly userUpdatedAt?: string; + /** An indicator of whether the data connection is active. */ + active?: boolean; + /** A message that specifies details about data connection if inactive. */ + readonly inactiveMessage?: string; + kind: string; +} + +export interface LogAnalyticsDataConnectionOutput extends DataConnectionOutputParent { + /** The kind of DataConnection */ + kind: "logAnalytics"; + /** properties */ + properties: LogAnalyticsDataConnectionPropertiesOutput; +} + +export interface LogAnalyticsDataConnectionPropertiesOutput extends DataConnectionPropertiesOutput { + /** log analytics api key */ + apiKey?: string; + /** log analytics workspace id */ + workspaceId?: string; +} + +/** The properties required to establish connection to a particular service */ +export interface DataConnectionPropertiesOutput {} + +export interface AzureDataExplorerDataConnectionPropertiesOutput + extends DataConnectionPropertiesOutput { + /** The azure data explorer cluster name */ + clusterName?: string; + /** The azure data explorer region */ + region?: string; + /** The azure data explorer database name */ + databaseName?: string; +} + +export interface AzureDataExplorerDataConnectionOutput extends DataConnectionOutputParent { + /** The kind of DataConnection */ + kind: "azureDataExplorer"; + /** properties */ + properties: AzureDataExplorerDataConnectionPropertiesOutput; +} + +/** Validate result for validate action endpoints */ +export interface ValidateResultOutput { + /** This is the top-level error object whose code matches the x-ms-error-code response header. */ + error?: ErrorDetailOutput; +} + +/** This is the top-level error object whose code matches the x-ms-error-code response header. */ +export interface ErrorDetailOutput { + /** This is one of a server-defined set of error codes. */ + code: string; + /** This is a human-readable representation of the error. */ + message: string; + /** This is the error target. */ + target?: string; + /** This is an array of details about specific errors that led to this reported error. */ + details?: Array; + /** This is an object containing more specific information than the current object about the error. */ + innererror?: InnerErrorOutput; +} + +/** This is an object containing more specific information than the current object about the error. */ +export interface InnerErrorOutput { + /** This is a more specific error code than was provided by the containing error. */ + code?: string; + /** This is an additional field representing the value that caused the error to help with debugging. */ + value?: any; +} + +export interface DiscoGroupOutput { + /** The system generated unique id for the resource. */ + id?: string; + /** The caller provided unique name for the resource. */ + readonly name: string; + /** The name that can be used for display purposes. */ + displayName?: string; + /** The description for a disco group. */ + description?: string; + /** The tier for the disco group which will affect the algorithm used for the disco runs in this group. */ + tier?: string; + /** The frequency at which the disco group is supposed to be rerun in milliseconds. */ + frequencyMilliseconds?: number; + /** The list of seeds used for the disco group runs. */ + seeds?: Array; + /** The list of names used for the disco group runs. */ + names?: string[]; + /** The list of excludes used for the disco group runs, aka assets to exclude from the discovery algorithm. */ + excludes?: Array; + /** The latest run of this disco group with some limited information, null if the group has never been run. */ + latestRun?: DiscoRunResultOutput; + /** The date for the disco group was created. */ + createdDate?: string; + /** The unique identifier for the disco template used for the disco group creation. */ + templateId?: string; +} + +/** Source entity used to drive discovery. */ +export interface DiscoSourceOutput { + /** + * The kind of disco source. + * + * Possible values: "as", "attribute", "contact", "domain", "host", "ipBlock" + */ + kind?: string; + /** The name for the disco source. */ + name?: string; +} + +/** The latest run of this disco group with some limited information, null if the group has never been run. */ +export interface DiscoRunResultOutput { + /** The date for when the disco run was created in the system. */ + submittedDate?: string; + /** The date for when the disco run was actually started by the system. */ + startedDate?: string; + /** The date for when the disco run was completed by the system. */ + completedDate?: string; + /** The tier which will affect the algorithm used for the disco run. */ + tier?: string; + /** + * The State of the disco run. + * + * Possible values: "pending", "running", "completed", "failed" + */ + state?: string; + /** The total count of assets that were found this disco run. */ + totalAssetsFoundCount?: number; + /** The list of seeds used for the disco run. */ + seeds?: Array; + /** The list of excludes used for the disco run, aka assets to exclude from the discovery algorithm. */ + excludes?: Array; + /** The list of names used for the disco run. */ + names?: string[]; +} + +export interface DiscoRunPageResultOutput { + /** The total number of items available in the full result set. */ + totalElements?: number; + /** The link to access the next page of results. Not set if at the end of the result set. */ + nextLink?: string; + /** The items in the current page of results. */ + value?: Array; +} + +/** Response for the asset chain summary. */ +export interface AssetChainSummaryResponseOutput { + /** A list of asset chain summaries per asset kind */ + affectedAssetsSummary: Array; + /** A list of disco group summaries */ + affectedGroupsSummary: Array; + /** The list of exceptions */ + errors?: Array; +} + +/** A list of asset chain summaries per asset kind */ +export interface AssetChainKindSummaryResponseOutput { + /** + * The kind of asset + * + * Possible values: "as", "contact", "domain", "host", "ipAddress", "ipBlock", "page", "sslCert" + */ + kind: string; + /** The amount of assets affected for a given asset kind */ + affectedCount: number; +} + +/** A list of disco group summaries */ +export interface DiscoGroupSummaryResponseOutput { + /** The system generated unique id for the resource. */ + id: string; + /** The caller provided unique name for the resource. */ + name: string; + /** The name that can be used for display purposes. */ + displayName: string; +} + +/** The items in the current page of results. */ +export interface DiscoTemplateOutput { + /** The system generated unique id for the resource. */ + readonly id: string; + /** The caller provided unique name for the resource. */ + name?: string; + /** The name that can be used for display purposes. */ + displayName?: string; + /** The name of the industry. */ + industry?: string; + /** The name of the region. */ + region?: string; + /** The country code. */ + countryCode?: string; + /** The state code. */ + stateCode?: string; + /** The name of the city. */ + city?: string; + /** The list of disco template seeds. */ + seeds?: Array; + /** The list of disco template names. */ + names?: string[]; +} + +export interface ReportBillableAssetSummaryResultOutput { + assetSummaries?: Array; +} + +export interface ReportBillableAssetSnapshotResultOutput { + /** The date these assets were billed on. */ + date?: string; + /** The total number of billable assets for this date. */ + total?: number; + /** The breakdown of billable asset counts for each asset type. */ + assetBreakdown?: Array; +} + +/** The breakdown of billable asset counts for each asset type. */ +export interface ReportBillableAssetBreakdownOutput { + /** + * The kind of billable asset. + * + * Possible values: "domain", "host", "ipAddress" + */ + kind?: string; + /** The number of assets of this type. */ + count?: number; +} + +/** A snapshot of assets captured daily for the provided metric. Asset details only contain primary properties. Detailed asset data can be retrieved from the asset endpoints. */ +export interface ReportAssetSnapshotResultOutput { + /** The name of the metric. */ + displayName?: string; + /** The unique metric name. */ + metric?: string; + /** The customer label that was filtered on, if one was provided. */ + labelName?: string; + /** The last time this asset data was updated on this metric. */ + updatedAt?: string; + /** A description of what the metric represents. */ + description?: string; + /** The page of assets that match the provided metric. */ + assets?: AssetPageResultOutput; +} + +/** The page of assets that match the provided metric. */ +export interface AssetPageResultOutput { + /** The total number of items available in the full result set. */ + totalElements?: number; + /** The cursor mark to be used on the next request. Not set if using paging. */ + mark?: string; + /** The link to access the next page of results. Not set if at the end of the result set. */ + nextLink?: string; + /** The items in the current page of results. */ + value?: Array; +} + +export interface ReportAssetSummaryResultOutput { + /** The collection of asset summaries. */ + assetSummaries?: Array; +} + +/** The collection of asset summaries. */ +export interface AssetSummaryResultOutput { + /** The name of the summary response. Depending on the request time this will either be the asset filter, risk category, or risk metric. */ + displayName?: string; + /** The description of the summary response. Filters don't have a description. */ + description?: string; + /** The last time risk categories or risk metrics were captured. Set to the current time for asset filter requests, which always pull the live asset data. */ + updatedAt?: string; + /** If the request is for a metric category, this will contain the requested unique category name. */ + metricCategory?: string; + /** If the request is for a metric, this will contain the requested unique metric name. */ + metric?: string; + /** If the request is for an asset filter, this will contain the corresponding filter. */ + filter?: string; + /** An optional label used to filter requests results. */ + labelName?: string; + /** The count of assets matching the request parameters. */ + count?: number; + /** The link to the corresponding asset details. */ + link?: string; + /** The corresponding child entities. For metric categories this will contain metrics. For filters with groupBy and segmentBy this will contain facets. */ + children?: Array; +} + +export interface SavedFilterOutput { + /** The system generated unique id for the resource. */ + id?: string; + /** The caller provided unique name for the resource. */ + readonly name: string; + /** The name that can be used for display purposes. */ + displayName?: string; + filter?: string; + description?: string; +} + +/** cisa cve in a given workspace. */ +export interface CisaCveResponseOutput { + /** The CVE ID of the vulnerability in the format CVE-YYYY-NNNN, note that the number portion can have more than 4 digits. */ + readonly cveId: string; + /** The vendor or project name for the vulnerability. */ + vendorProject: string; + /** The vulnerability product */ + product: string; + /** The name of the vulnerability */ + vulnerabilityName: string; + /** A short description of the vulnerability */ + shortDescription: string; + /** The required action to address the vulnerability */ + requiredAction: string; + /** Any additional notes about the vulnerability */ + notes: string; + /** The date the vulnerability was added to the catalog in the format YYYY-MM-DD */ + dateAdded: string; + /** The date the required action is due in the format YYYY-MM-DD */ + dueDate: string; + /** The date the vulnerability was updated */ + updatedAt: string; + /** The number of assets affected by the vulnerability */ + count: number; +} + +/** The items in the current page of results. */ +export type AssetResourceOutput = + | AssetResourceOutputParent + | AsAssetResourceOutput + | ContactAssetResourceOutput + | DomainAssetResourceOutput + | HostAssetResourceOutput + | IpAddressAssetResourceOutput + | IpBlockAssetResourceOutput + | PageAssetResourceOutput + | SslCertAssetResourceOutput; +export type DataConnectionOutput = + | DataConnectionOutputParent + | LogAnalyticsDataConnectionOutput + | AzureDataExplorerDataConnectionOutput; +/** Paged collection of AssetResource items */ +export type PagedAssetResourceOutput = Paged; +/** Paged collection of DataConnection items */ +export type PagedDataConnectionOutput = Paged; +/** Paged collection of DiscoGroup items */ +export type PagedDiscoGroupOutput = Paged; +/** Paged collection of DiscoTemplate items */ +export type PagedDiscoTemplateOutput = Paged; +/** Paged collection of SavedFilter items */ +export type PagedSavedFilterOutput = Paged; +/** Paged collection of Task items */ +export type PagedTaskOutput = Paged; +/** Paged collection of CisaCveResponse items */ +export type PagedCisaCveResponseOutput = Paged; diff --git a/sdk/easm/defendereasm-rest/src/paginateHelper.ts b/sdk/easm/defendereasm-rest/src/paginateHelper.ts new file mode 100644 index 000000000000..f0d91c952cda --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/paginateHelper.ts @@ -0,0 +1,131 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { getPagedAsyncIterator, PagedAsyncIterableIterator, PagedResult } from "@azure/core-paging"; +import { Client, createRestError, PathUncheckedResponse } from "@azure-rest/core-client"; + +/** + * Helper type to extract the type of an array + */ +export type GetArrayType = T extends Array ? TData : never; + +/** + * The type of a custom function that defines how to get a page and a link to the next one if any. + */ +export type GetPage = ( + pageLink: string, + maxPageSize?: number, +) => Promise<{ + page: TPage; + nextPageLink?: string; +}>; + +/** + * Options for the paging helper + */ +export interface PagingOptions { + /** + * Custom function to extract pagination details for crating the PagedAsyncIterableIterator + */ + customGetPage?: GetPage[]>; +} + +/** + * Helper type to infer the Type of the paged elements from the response type + * This type is generated based on the swagger information for x-ms-pageable + * specifically on the itemName property which indicates the property of the response + * where the page items are found. The default value is `value`. + * This type will allow us to provide strongly typed Iterator based on the response we get as second parameter + */ +export type PaginateReturn = TResult extends { + body: { value?: infer TPage }; +} + ? GetArrayType + : Array; + +/** + * Helper to paginate results from an initial response that follows the specification of Autorest `x-ms-pageable` extension + * @param client - Client to use for sending the next page requests + * @param initialResponse - Initial response containing the nextLink and current page of elements + * @param customGetPage - Optional - Function to define how to extract the page and next link to be used to paginate the results + * @returns - PagedAsyncIterableIterator to iterate the elements + */ +export function paginate( + client: Client, + initialResponse: TResponse, + options: PagingOptions = {}, +): PagedAsyncIterableIterator> { + // Extract element type from initial response + type TElement = PaginateReturn; + let firstRun = true; + const itemName = "value"; + const nextLinkName = "nextLink"; + const { customGetPage } = options; + const pagedResult: PagedResult = { + firstPageLink: "", + getPage: + typeof customGetPage === "function" + ? customGetPage + : async (pageLink: string) => { + const result = firstRun ? initialResponse : await client.pathUnchecked(pageLink).get(); + firstRun = false; + checkPagingRequest(result); + const nextLink = getNextLink(result.body, nextLinkName); + const values = getElements(result.body, itemName); + return { + page: values, + nextPageLink: nextLink, + }; + }, + }; + + return getPagedAsyncIterator(pagedResult); +} + +/** + * Gets for the value of nextLink in the body + */ +function getNextLink(body: unknown, nextLinkName?: string): string | undefined { + if (!nextLinkName) { + return undefined; + } + + const nextLink = (body as Record)[nextLinkName]; + + if (typeof nextLink !== "string" && typeof nextLink !== "undefined") { + throw new Error(`Body Property ${nextLinkName} should be a string or undefined`); + } + + return nextLink; +} + +/** + * Gets the elements of the current request in the body. + */ +function getElements(body: unknown, itemName: string): T[] { + const value = (body as Record)[itemName] as T[]; + + // value has to be an array according to the x-ms-pageable extension. + // The fact that this must be an array is used above to calculate the + // type of elements in the page in PaginateReturn + if (!Array.isArray(value)) { + throw new Error( + `Couldn't paginate response\n Body doesn't contain an array property with name: ${itemName}`, + ); + } + + return value ?? []; +} + +/** + * Checks if a request failed + */ +function checkPagingRequest(response: PathUncheckedResponse): void { + const Http2xxStatusCodes = ["200", "201", "202", "203", "204", "205", "206", "207", "208", "226"]; + if (!Http2xxStatusCodes.includes(response.status)) { + throw createRestError( + `Pagination failed with unexpected statusCode ${response.status}`, + response, + ); + } +} diff --git a/sdk/easm/defendereasm-rest/src/parameters.ts b/sdk/easm/defendereasm-rest/src/parameters.ts new file mode 100644 index 000000000000..87305579b817 --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/parameters.ts @@ -0,0 +1,291 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { RequestParameters } from "@azure-rest/core-client"; +import { + AssetUpdateData, + DataConnectionData, + DiscoGroupData, + AssetChainRequest, + ReportAssetSnapshotRequest, + ReportAssetSummaryRequest, + ReportAssetSnapshotExportRequest, + SavedFilterData, +} from "./models.js"; + +export interface ListAssetResourceQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** A list of expressions that specify the order of the returned resources. */ + orderby?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; + /** Specify this value instead of 'skip' to use cursor-based searching. Initial value is '*' and subsequent values are returned in the response. */ + mark?: string; + /** + * Specify the response type. The possible values are: ID, STANDARD, FULL, REDUCED + * + * Possible values: "id", "standard", "full", "reduced" + */ + responseType?: string; + responseIncludes?: string[]; + recentOnly?: boolean; +} + +export interface ListAssetResourceQueryParam { + queryParameters?: ListAssetResourceQueryParamProperties; +} + +export type ListAssetResourceParameters = ListAssetResourceQueryParam & RequestParameters; + +export interface UpdateAssetsBodyParam { + body?: AssetUpdateData; +} + +export interface UpdateAssetsQueryParamProperties { + /** An expression on the resource type that selects the resources to be returned. */ + filter: string; +} + +export interface UpdateAssetsQueryParam { + queryParameters: UpdateAssetsQueryParamProperties; +} + +export type UpdateAssetsParameters = UpdateAssetsQueryParam & + UpdateAssetsBodyParam & + RequestParameters; +export type GetAssetResourceParameters = RequestParameters; +export type DismissAssetChainParameters = RequestParameters; + +export interface GetAssetsExportQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** A list of expressions that specify the order of the returned resources. */ + orderby?: string; + fileName?: string; + columns?: string[]; +} + +export interface GetAssetsExportQueryParam { + queryParameters?: GetAssetsExportQueryParamProperties; +} + +export type GetAssetsExportParameters = GetAssetsExportQueryParam & RequestParameters; + +export interface GetObservationsQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** A list of expressions that specify the order of the returned resources. */ + orderby?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface GetObservationsQueryParam { + queryParameters?: GetObservationsQueryParamProperties; +} + +export type GetObservationsParameters = GetObservationsQueryParam & RequestParameters; + +export interface GetDeltaDetailsQueryParamProperties { + /** Possible values: "added", "removed" */ + deltaDetailType?: string; + daysPrior?: number; + /** Possible values: "page", "resource", "mailServer", "nameServer", "host", "domain", "ipAddress", "ipBlock", "as", "contact", "sslCert" */ + kind?: string; + /** expected format to be: yyyy-MM-dd */ + date?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface GetDeltaDetailsQueryParam { + queryParameters?: GetDeltaDetailsQueryParamProperties; +} + +export type GetDeltaDetailsParameters = GetDeltaDetailsQueryParam & RequestParameters; + +export interface GetDeltaSummaryQueryParamProperties { + daysPrior?: number; + /** expected format to be: yyyy-MM-dd */ + date?: string; +} + +export interface GetDeltaSummaryQueryParam { + queryParameters?: GetDeltaSummaryQueryParamProperties; +} + +export type GetDeltaSummaryParameters = GetDeltaSummaryQueryParam & RequestParameters; + +export interface ListDataConnectionQueryParamProperties { + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface ListDataConnectionQueryParam { + queryParameters?: ListDataConnectionQueryParamProperties; +} + +export type ListDataConnectionParameters = ListDataConnectionQueryParam & RequestParameters; + +export interface ValidateDataConnectionBodyParam { + body?: DataConnectionData; +} + +export type ValidateDataConnectionParameters = ValidateDataConnectionBodyParam & RequestParameters; +export type GetDataConnectionParameters = RequestParameters; + +export interface CreateOrReplaceDataConnectionBodyParam { + body?: DataConnectionData; +} + +export type CreateOrReplaceDataConnectionParameters = CreateOrReplaceDataConnectionBodyParam & + RequestParameters; +export type DeleteDataConnectionParameters = RequestParameters; + +export interface ListDiscoGroupQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface ListDiscoGroupQueryParam { + queryParameters?: ListDiscoGroupQueryParamProperties; +} + +export type ListDiscoGroupParameters = ListDiscoGroupQueryParam & RequestParameters; + +export interface ValidateDiscoGroupBodyParam { + body?: DiscoGroupData; +} + +export type ValidateDiscoGroupParameters = ValidateDiscoGroupBodyParam & RequestParameters; +export type GetDiscoGroupParameters = RequestParameters; + +export interface CreateOrReplaceDiscoGroupBodyParam { + body?: DiscoGroupData; +} + +export type CreateOrReplaceDiscoGroupParameters = CreateOrReplaceDiscoGroupBodyParam & + RequestParameters; +export type RunDiscoGroupParameters = RequestParameters; + +export interface ListRunsQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface ListRunsQueryParam { + queryParameters?: ListRunsQueryParamProperties; +} + +export type ListRunsParameters = ListRunsQueryParam & RequestParameters; + +export interface GetAssetChainSummaryBodyParam { + body?: AssetChainRequest; +} + +export type GetAssetChainSummaryParameters = GetAssetChainSummaryBodyParam & RequestParameters; + +export interface DismissSeedChainBodyParam { + body?: AssetChainRequest; +} + +export type DismissSeedChainParameters = DismissSeedChainBodyParam & RequestParameters; + +export interface ListDiscoTemplateQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface ListDiscoTemplateQueryParam { + queryParameters?: ListDiscoTemplateQueryParamProperties; +} + +export type ListDiscoTemplateParameters = ListDiscoTemplateQueryParam & RequestParameters; +export type GetDiscoTemplateParameters = RequestParameters; +export type GetBillableParameters = RequestParameters; + +export interface GetSnapshotBodyParam { + body?: ReportAssetSnapshotRequest; +} + +export type GetSnapshotParameters = GetSnapshotBodyParam & RequestParameters; + +export interface GetSummaryBodyParam { + body?: ReportAssetSummaryRequest; +} + +export type GetSummaryParameters = GetSummaryBodyParam & RequestParameters; + +export interface GetSnapshotExportBodyParam { + body?: ReportAssetSnapshotExportRequest; +} + +export type GetSnapshotExportParameters = GetSnapshotExportBodyParam & RequestParameters; + +export interface ListSavedFilterQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface ListSavedFilterQueryParam { + queryParameters?: ListSavedFilterQueryParamProperties; +} + +export type ListSavedFilterParameters = ListSavedFilterQueryParam & RequestParameters; +export type GetSavedFilterParameters = RequestParameters; + +export interface CreateOrReplaceSavedFilterBodyParam { + body?: SavedFilterData; +} + +export type CreateOrReplaceSavedFilterParameters = CreateOrReplaceSavedFilterBodyParam & + RequestParameters; +export type DeleteSavedFilterParameters = RequestParameters; + +export interface ListTaskQueryParamProperties { + /** Filter the result list using the given expression. */ + filter?: string; + /** A list of expressions that specify the order of the returned resources. */ + orderby?: string; + /** The number of result items to skip. */ + skip?: number; + /** The maximum number of result items per page. */ + maxpagesize?: number; +} + +export interface ListTaskQueryParam { + queryParameters?: ListTaskQueryParamProperties; +} + +export type ListTaskParameters = ListTaskQueryParam & RequestParameters; +export type GetTaskParameters = RequestParameters; +export type CancelTaskParameters = RequestParameters; +export type RunTaskParameters = RequestParameters; +export type DownloadTaskParameters = RequestParameters; +export type GetCisaCvesParameters = RequestParameters; +export type GetCisaCveParameters = RequestParameters; diff --git a/sdk/easm/defendereasm-rest/src/responses.ts b/sdk/easm/defendereasm-rest/src/responses.ts new file mode 100644 index 000000000000..e12e392d551b --- /dev/null +++ b/sdk/easm/defendereasm-rest/src/responses.ts @@ -0,0 +1,673 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { RawHttpHeaders } from "@azure/core-rest-pipeline"; +import { HttpResponse, ErrorResponse } from "@azure-rest/core-client"; +import { + PagedAssetResourceOutput, + TaskOutput, + AssetResourceOutput, + ObservationPageResponseOutput, + DeltaPageResponseOutput, + DeltaSummaryResponseOutput, + PagedDataConnectionOutput, + ValidateResultOutput, + DataConnectionOutput, + PagedDiscoGroupOutput, + DiscoGroupOutput, + DiscoRunPageResultOutput, + AssetChainSummaryResponseOutput, + PagedDiscoTemplateOutput, + DiscoTemplateOutput, + ReportBillableAssetSummaryResultOutput, + ReportAssetSnapshotResultOutput, + ReportAssetSummaryResultOutput, + PagedSavedFilterOutput, + SavedFilterOutput, + PagedTaskOutput, + PagedCisaCveResponseOutput, + CisaCveResponseOutput, +} from "./outputModels.js"; + +/** The request has succeeded. */ +export interface ListAssetResource200Response extends HttpResponse { + status: "200"; + body: PagedAssetResourceOutput; +} + +export interface ListAssetResourceDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListAssetResourceDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListAssetResourceDefaultHeaders; +} + +/** The request has succeeded. */ +export interface UpdateAssets200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface UpdateAssetsDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface UpdateAssetsDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & UpdateAssetsDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetAssetResource200Response extends HttpResponse { + status: "200"; + body: AssetResourceOutput; +} + +export interface GetAssetResourceDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetAssetResourceDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetAssetResourceDefaultHeaders; +} + +/** The request has succeeded. */ +export interface DismissAssetChain200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface DismissAssetChainDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface DismissAssetChainDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & DismissAssetChainDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetAssetsExport200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface GetAssetsExportDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetAssetsExportDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetAssetsExportDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetObservations200Response extends HttpResponse { + status: "200"; + body: ObservationPageResponseOutput; +} + +export interface GetObservationsDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetObservationsDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetObservationsDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetDeltaDetails200Response extends HttpResponse { + status: "200"; + body: DeltaPageResponseOutput; +} + +export interface GetDeltaDetailsDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetDeltaDetailsDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetDeltaDetailsDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetDeltaSummary200Response extends HttpResponse { + status: "200"; + body: DeltaSummaryResponseOutput; +} + +export interface GetDeltaSummaryDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetDeltaSummaryDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetDeltaSummaryDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ListDataConnection200Response extends HttpResponse { + status: "200"; + body: PagedDataConnectionOutput; +} + +export interface ListDataConnectionDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListDataConnectionDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListDataConnectionDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ValidateDataConnection200Response extends HttpResponse { + status: "200"; + body: ValidateResultOutput; +} + +export interface ValidateDataConnectionDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ValidateDataConnectionDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ValidateDataConnectionDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetDataConnection200Response extends HttpResponse { + status: "200"; + body: DataConnectionOutput; +} + +export interface GetDataConnectionDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetDataConnectionDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetDataConnectionDefaultHeaders; +} + +/** The request has succeeded. */ +export interface CreateOrReplaceDataConnection200Response extends HttpResponse { + status: "200"; + body: DataConnectionOutput; +} + +export interface CreateOrReplaceDataConnectionDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface CreateOrReplaceDataConnectionDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & CreateOrReplaceDataConnectionDefaultHeaders; +} + +/** There is no content to send for this request, but the headers may be useful. */ +export interface DeleteDataConnection204Response extends HttpResponse { + status: "204"; +} + +export interface DeleteDataConnectionDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface DeleteDataConnectionDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & DeleteDataConnectionDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ListDiscoGroup200Response extends HttpResponse { + status: "200"; + body: PagedDiscoGroupOutput; +} + +export interface ListDiscoGroupDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListDiscoGroupDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListDiscoGroupDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ValidateDiscoGroup200Response extends HttpResponse { + status: "200"; + body: ValidateResultOutput; +} + +export interface ValidateDiscoGroupDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ValidateDiscoGroupDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ValidateDiscoGroupDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetDiscoGroup200Response extends HttpResponse { + status: "200"; + body: DiscoGroupOutput; +} + +export interface GetDiscoGroupDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetDiscoGroupDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetDiscoGroupDefaultHeaders; +} + +/** The request has succeeded. */ +export interface CreateOrReplaceDiscoGroup200Response extends HttpResponse { + status: "200"; + body: DiscoGroupOutput; +} + +export interface CreateOrReplaceDiscoGroupDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface CreateOrReplaceDiscoGroupDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & CreateOrReplaceDiscoGroupDefaultHeaders; +} + +/** There is no content to send for this request, but the headers may be useful. */ +export interface RunDiscoGroup204Response extends HttpResponse { + status: "204"; +} + +export interface RunDiscoGroupDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface RunDiscoGroupDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & RunDiscoGroupDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ListRuns200Response extends HttpResponse { + status: "200"; + body: DiscoRunPageResultOutput; +} + +export interface ListRunsDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListRunsDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListRunsDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetAssetChainSummary200Response extends HttpResponse { + status: "200"; + body: AssetChainSummaryResponseOutput; +} + +export interface GetAssetChainSummaryDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetAssetChainSummaryDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetAssetChainSummaryDefaultHeaders; +} + +/** The request has succeeded. */ +export interface DismissSeedChain200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface DismissSeedChainDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface DismissSeedChainDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & DismissSeedChainDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ListDiscoTemplate200Response extends HttpResponse { + status: "200"; + body: PagedDiscoTemplateOutput; +} + +export interface ListDiscoTemplateDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListDiscoTemplateDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListDiscoTemplateDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetDiscoTemplate200Response extends HttpResponse { + status: "200"; + body: DiscoTemplateOutput; +} + +export interface GetDiscoTemplateDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetDiscoTemplateDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetDiscoTemplateDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetBillable200Response extends HttpResponse { + status: "200"; + body: ReportBillableAssetSummaryResultOutput; +} + +export interface GetBillableDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetBillableDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetBillableDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetSnapshot200Response extends HttpResponse { + status: "200"; + body: ReportAssetSnapshotResultOutput; +} + +export interface GetSnapshotDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetSnapshotDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetSnapshotDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetSummary200Response extends HttpResponse { + status: "200"; + body: ReportAssetSummaryResultOutput; +} + +export interface GetSummaryDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetSummaryDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetSummaryDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetSnapshotExport200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface GetSnapshotExportDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetSnapshotExportDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetSnapshotExportDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ListSavedFilter200Response extends HttpResponse { + status: "200"; + body: PagedSavedFilterOutput; +} + +export interface ListSavedFilterDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListSavedFilterDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListSavedFilterDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetSavedFilter200Response extends HttpResponse { + status: "200"; + body: SavedFilterOutput; +} + +export interface GetSavedFilterDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetSavedFilterDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetSavedFilterDefaultHeaders; +} + +/** The request has succeeded. */ +export interface CreateOrReplaceSavedFilter200Response extends HttpResponse { + status: "200"; + body: SavedFilterOutput; +} + +export interface CreateOrReplaceSavedFilterDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface CreateOrReplaceSavedFilterDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & CreateOrReplaceSavedFilterDefaultHeaders; +} + +/** There is no content to send for this request, but the headers may be useful. */ +export interface DeleteSavedFilter204Response extends HttpResponse { + status: "204"; +} + +export interface DeleteSavedFilterDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface DeleteSavedFilterDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & DeleteSavedFilterDefaultHeaders; +} + +/** The request has succeeded. */ +export interface ListTask200Response extends HttpResponse { + status: "200"; + body: PagedTaskOutput; +} + +export interface ListTaskDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface ListTaskDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & ListTaskDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetTask200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface GetTaskDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetTaskDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetTaskDefaultHeaders; +} + +/** The request has succeeded. */ +export interface CancelTask200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface CancelTaskDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface CancelTaskDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & CancelTaskDefaultHeaders; +} + +/** The request has succeeded. */ +export interface RunTask200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface RunTaskDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface RunTaskDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & RunTaskDefaultHeaders; +} + +/** The request has succeeded. */ +export interface DownloadTask200Response extends HttpResponse { + status: "200"; + body: TaskOutput; +} + +export interface DownloadTaskDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface DownloadTaskDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & DownloadTaskDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetCisaCves200Response extends HttpResponse { + status: "200"; + body: PagedCisaCveResponseOutput; +} + +export interface GetCisaCvesDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetCisaCvesDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetCisaCvesDefaultHeaders; +} + +/** The request has succeeded. */ +export interface GetCisaCve200Response extends HttpResponse { + status: "200"; + body: CisaCveResponseOutput; +} + +export interface GetCisaCveDefaultHeaders { + /** String error code indicating what went wrong. */ + "x-ms-error-code"?: string; +} + +export interface GetCisaCveDefaultResponse extends HttpResponse { + status: string; + body: ErrorResponse; + headers: RawHttpHeaders & GetCisaCveDefaultHeaders; +} diff --git a/sdk/easm/defendereasm-rest/test/public/sampleTest.spec.ts b/sdk/easm/defendereasm-rest/test/public/sampleTest.spec.ts new file mode 100644 index 000000000000..344657d6f17e --- /dev/null +++ b/sdk/easm/defendereasm-rest/test/public/sampleTest.spec.ts @@ -0,0 +1,21 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { createRecorder } from "./utils/recordedClient.js"; +import { assert, beforeEach, afterEach, it, describe } from "vitest"; + +describe("My test", () => { + // let recorder: Recorder; + + beforeEach(async function () { + // recorder = await createRecorder(this); + }); + + afterEach(async function () { + // await recorder.stop(); + }); + + it("sample test", async function () { + assert.equal(1, 1); + }); +}); diff --git a/sdk/easm/defendereasm-rest/test/public/utils/env.browser.ts b/sdk/easm/defendereasm-rest/test/public/utils/env.browser.ts new file mode 100644 index 000000000000..fd2aca680c7b --- /dev/null +++ b/sdk/easm/defendereasm-rest/test/public/utils/env.browser.ts @@ -0,0 +1,2 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. diff --git a/sdk/easm/defendereasm-rest/test/public/utils/env.ts b/sdk/easm/defendereasm-rest/test/public/utils/env.ts new file mode 100644 index 000000000000..0e06855b73ae --- /dev/null +++ b/sdk/easm/defendereasm-rest/test/public/utils/env.ts @@ -0,0 +1,6 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import * as dotenv from "dotenv"; + +dotenv.config(); diff --git a/sdk/easm/defendereasm-rest/test/public/utils/recordedClient.ts b/sdk/easm/defendereasm-rest/test/public/utils/recordedClient.ts new file mode 100644 index 000000000000..6cc58bc15e11 --- /dev/null +++ b/sdk/easm/defendereasm-rest/test/public/utils/recordedClient.ts @@ -0,0 +1,29 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { Context } from "mocha"; +import { Recorder, RecorderStartOptions } from "@azure-tools/test-recorder"; +import "./env"; + +const envSetupForPlayback: Record = { + ENDPOINT: "https://endpoint", + AZURE_CLIENT_ID: "azure_client_id", + AZURE_CLIENT_SECRET: "azure_client_secret", + AZURE_TENANT_ID: "88888888-8888-8888-8888-888888888888", + SUBSCRIPTION_ID: "azure_subscription_id", +}; + +const recorderEnvSetup: RecorderStartOptions = { + envSetupForPlayback, +}; + +/** + * creates the recorder and reads the environment variables from the `.env` file. + * Should be called first in the test suite to make sure environment variables are + * read before they are being used. + */ +export async function createRecorder(context: Context): Promise { + const recorder = new Recorder(context.currentTest); + await recorder.start(recorderEnvSetup); + return recorder; +} diff --git a/sdk/easm/defendereasm-rest/tsconfig.browser.config.json b/sdk/easm/defendereasm-rest/tsconfig.browser.config.json new file mode 100644 index 000000000000..1b37aebc5457 --- /dev/null +++ b/sdk/easm/defendereasm-rest/tsconfig.browser.config.json @@ -0,0 +1,10 @@ +{ + "extends": "./.tshy/build.json", + "include": ["./src/**/*.ts", "./src/**/*.mts", "./test/**/*.spec.ts"], + "exclude": ["./test/**/node/**/*.ts"], + "compilerOptions": { + "outDir": "./dist-test/browser", + "rootDir": ".", + "skipLibCheck": true + } +} diff --git a/sdk/easm/defendereasm-rest/tsconfig.json b/sdk/easm/defendereasm-rest/tsconfig.json new file mode 100644 index 000000000000..3bd968590b3d --- /dev/null +++ b/sdk/easm/defendereasm-rest/tsconfig.json @@ -0,0 +1,9 @@ +{ + "extends": "../../../tsconfig.package", + "compilerOptions": { + "module": "NodeNext", + "moduleResolution": "NodeNext", + "rootDir": "." + }, + "include": ["./src/**/*.ts", "./src/**/*.mts", "./src/**/*.cts", "test/**/*.ts", "./test/**/*.ts"] +} diff --git a/sdk/easm/defendereasm-rest/vitest.browser.config.ts b/sdk/easm/defendereasm-rest/vitest.browser.config.ts new file mode 100644 index 000000000000..dc2f66e5d521 --- /dev/null +++ b/sdk/easm/defendereasm-rest/vitest.browser.config.ts @@ -0,0 +1,33 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { defineConfig } from "vitest/config"; + +export default defineConfig({ + define: { + "process.env": process.env, + }, + test: { + reporters: ["basic", "junit"], + outputFile: { + junit: "test-results.browser.xml", + }, + browser: { + enabled: true, + headless: true, + name: "chromium", + provider: "playwright", + }, + fakeTimers: { + toFake: ["setTimeout", "Date"], + }, + watch: false, + include: ["dist-test/browser/**/*.spec.js"], + coverage: { + include: ["dist-test/browser/**/*.spec.js"], + provider: "istanbul", + reporter: ["text", "json", "html"], + reportsDirectory: "coverage-browser", + }, + }, +}); diff --git a/sdk/easm/defendereasm-rest/vitest.config.ts b/sdk/easm/defendereasm-rest/vitest.config.ts new file mode 100644 index 000000000000..7c014c00af62 --- /dev/null +++ b/sdk/easm/defendereasm-rest/vitest.config.ts @@ -0,0 +1,31 @@ +// Copyright (c) Microsoft Corporation. +// Licensed under the MIT license. + +import { defineConfig } from "vitest/config"; + +export default defineConfig({ + test: { + reporters: ["basic", "junit"], + outputFile: { + junit: "test-results.browser.xml", + }, + fakeTimers: { + toFake: ["setTimeout", "Date"], + }, + watch: false, + include: ["test/**/*.spec.ts"], + exclude: ["test/**/browser/*.spec.ts"], + coverage: { + include: ["src/**/*.ts"], + exclude: [ + "src/**/*-browser.mts", + "src/**/*-react-native.mts", + "vitest*.config.ts", + "samples-dev/**/*.ts", + ], + provider: "istanbul", + reporter: ["text", "json", "html"], + reportsDirectory: "coverage", + }, + }, +});