@azure/arm-compute 23.2.0 → 23.3.0-alpha.20260122.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/computeManagementClient.d.ts +3 -1
- package/dist/browser/computeManagementClient.d.ts.map +1 -1
- package/dist/browser/computeManagementClient.js +6 -2
- package/dist/browser/computeManagementClient.js.map +1 -1
- package/dist/browser/models/index.d.ts +316 -3
- package/dist/browser/models/index.d.ts.map +1 -1
- package/dist/browser/models/index.js +22 -0
- package/dist/browser/models/index.js.map +1 -1
- package/dist/browser/models/mappers.d.ts +19 -0
- package/dist/browser/models/mappers.d.ts.map +1 -1
- package/dist/browser/models/mappers.js +533 -0
- package/dist/browser/models/mappers.js.map +1 -1
- package/dist/browser/models/parameters.d.ts +6 -0
- package/dist/browser/models/parameters.d.ts.map +1 -1
- package/dist/browser/models/parameters.js +47 -2
- package/dist/browser/models/parameters.js.map +1 -1
- package/dist/browser/operations/galleryInVMAccessControlProfileVersions.d.ts.map +1 -1
- package/dist/browser/operations/galleryInVMAccessControlProfileVersions.js.map +1 -1
- package/dist/browser/operations/galleryScriptVersions.d.ts +111 -0
- package/dist/browser/operations/galleryScriptVersions.d.ts.map +1 -0
- package/dist/browser/operations/galleryScriptVersions.js +484 -0
- package/dist/browser/operations/galleryScriptVersions.js.map +1 -0
- package/dist/browser/operations/galleryScripts.d.ts +101 -0
- package/dist/browser/operations/galleryScripts.d.ts.map +1 -0
- package/dist/browser/operations/galleryScripts.js +454 -0
- package/dist/browser/operations/galleryScripts.js.map +1 -0
- package/dist/browser/operations/index.d.ts +2 -0
- package/dist/browser/operations/index.d.ts.map +1 -1
- package/dist/browser/operations/index.js +2 -0
- package/dist/browser/operations/index.js.map +1 -1
- package/dist/browser/operations/virtualMachineScaleSetRollingUpgrades.d.ts.map +1 -1
- package/dist/browser/operations/virtualMachineScaleSetRollingUpgrades.js.map +1 -1
- package/dist/browser/operations/virtualMachineScaleSetVMRunCommands.d.ts.map +1 -1
- package/dist/browser/operations/virtualMachineScaleSetVMRunCommands.js.map +1 -1
- package/dist/browser/operationsInterfaces/galleryScriptVersions.d.ts +84 -0
- package/dist/browser/operationsInterfaces/galleryScriptVersions.d.ts.map +1 -0
- package/dist/browser/operationsInterfaces/galleryScriptVersions.js +4 -0
- package/dist/browser/operationsInterfaces/galleryScriptVersions.js.map +1 -0
- package/dist/browser/operationsInterfaces/galleryScripts.d.ts +76 -0
- package/dist/browser/operationsInterfaces/galleryScripts.d.ts.map +1 -0
- package/dist/browser/operationsInterfaces/galleryScripts.js +4 -0
- package/dist/browser/operationsInterfaces/galleryScripts.js.map +1 -0
- package/dist/browser/operationsInterfaces/index.d.ts +2 -0
- package/dist/browser/operationsInterfaces/index.d.ts.map +1 -1
- package/dist/browser/operationsInterfaces/index.js +2 -0
- package/dist/browser/operationsInterfaces/index.js.map +1 -1
- package/dist/commonjs/computeManagementClient.d.ts +3 -1
- package/dist/commonjs/computeManagementClient.d.ts.map +1 -1
- package/dist/commonjs/computeManagementClient.js +5 -1
- package/dist/commonjs/computeManagementClient.js.map +1 -1
- package/dist/commonjs/models/index.d.ts +316 -3
- package/dist/commonjs/models/index.d.ts.map +1 -1
- package/dist/commonjs/models/index.js +23 -1
- package/dist/commonjs/models/index.js.map +1 -1
- package/dist/commonjs/models/mappers.d.ts +19 -0
- package/dist/commonjs/models/mappers.d.ts.map +1 -1
- package/dist/commonjs/models/mappers.js +539 -6
- package/dist/commonjs/models/mappers.js.map +1 -1
- package/dist/commonjs/models/parameters.d.ts +6 -0
- package/dist/commonjs/models/parameters.d.ts.map +1 -1
- package/dist/commonjs/models/parameters.js +47 -2
- package/dist/commonjs/models/parameters.js.map +1 -1
- package/dist/commonjs/operations/galleryInVMAccessControlProfileVersions.d.ts.map +1 -1
- package/dist/commonjs/operations/galleryInVMAccessControlProfileVersions.js.map +1 -1
- package/dist/commonjs/operations/galleryScriptVersions.d.ts +111 -0
- package/dist/commonjs/operations/galleryScriptVersions.d.ts.map +1 -0
- package/dist/commonjs/operations/galleryScriptVersions.js +489 -0
- package/dist/commonjs/operations/galleryScriptVersions.js.map +1 -0
- package/dist/commonjs/operations/galleryScripts.d.ts +101 -0
- package/dist/commonjs/operations/galleryScripts.d.ts.map +1 -0
- package/dist/commonjs/operations/galleryScripts.js +459 -0
- package/dist/commonjs/operations/galleryScripts.js.map +1 -0
- package/dist/commonjs/operations/index.d.ts +2 -0
- package/dist/commonjs/operations/index.d.ts.map +1 -1
- package/dist/commonjs/operations/index.js +2 -0
- package/dist/commonjs/operations/index.js.map +1 -1
- package/dist/commonjs/operations/virtualMachineScaleSetRollingUpgrades.d.ts.map +1 -1
- package/dist/commonjs/operations/virtualMachineScaleSetRollingUpgrades.js.map +1 -1
- package/dist/commonjs/operations/virtualMachineScaleSetVMRunCommands.d.ts.map +1 -1
- package/dist/commonjs/operations/virtualMachineScaleSetVMRunCommands.js.map +1 -1
- package/dist/commonjs/operationsInterfaces/galleryScriptVersions.d.ts +84 -0
- package/dist/commonjs/operationsInterfaces/galleryScriptVersions.d.ts.map +1 -0
- package/dist/commonjs/operationsInterfaces/galleryScriptVersions.js +5 -0
- package/dist/commonjs/operationsInterfaces/galleryScriptVersions.js.map +1 -0
- package/dist/commonjs/operationsInterfaces/galleryScripts.d.ts +76 -0
- package/dist/commonjs/operationsInterfaces/galleryScripts.d.ts.map +1 -0
- package/dist/commonjs/operationsInterfaces/galleryScripts.js +5 -0
- package/dist/commonjs/operationsInterfaces/galleryScripts.js.map +1 -0
- package/dist/commonjs/operationsInterfaces/index.d.ts +2 -0
- package/dist/commonjs/operationsInterfaces/index.d.ts.map +1 -1
- package/dist/commonjs/operationsInterfaces/index.js +2 -0
- package/dist/commonjs/operationsInterfaces/index.js.map +1 -1
- package/dist/commonjs/tsdoc-metadata.json +1 -1
- package/dist/esm/computeManagementClient.d.ts +3 -1
- package/dist/esm/computeManagementClient.d.ts.map +1 -1
- package/dist/esm/computeManagementClient.js +6 -2
- package/dist/esm/computeManagementClient.js.map +1 -1
- package/dist/esm/models/index.d.ts +316 -3
- package/dist/esm/models/index.d.ts.map +1 -1
- package/dist/esm/models/index.js +22 -0
- package/dist/esm/models/index.js.map +1 -1
- package/dist/esm/models/mappers.d.ts +19 -0
- package/dist/esm/models/mappers.d.ts.map +1 -1
- package/dist/esm/models/mappers.js +533 -0
- package/dist/esm/models/mappers.js.map +1 -1
- package/dist/esm/models/parameters.d.ts +6 -0
- package/dist/esm/models/parameters.d.ts.map +1 -1
- package/dist/esm/models/parameters.js +47 -2
- package/dist/esm/models/parameters.js.map +1 -1
- package/dist/esm/operations/galleryInVMAccessControlProfileVersions.d.ts.map +1 -1
- package/dist/esm/operations/galleryInVMAccessControlProfileVersions.js.map +1 -1
- package/dist/esm/operations/galleryScriptVersions.d.ts +111 -0
- package/dist/esm/operations/galleryScriptVersions.d.ts.map +1 -0
- package/dist/esm/operations/galleryScriptVersions.js +484 -0
- package/dist/esm/operations/galleryScriptVersions.js.map +1 -0
- package/dist/esm/operations/galleryScripts.d.ts +101 -0
- package/dist/esm/operations/galleryScripts.d.ts.map +1 -0
- package/dist/esm/operations/galleryScripts.js +454 -0
- package/dist/esm/operations/galleryScripts.js.map +1 -0
- package/dist/esm/operations/index.d.ts +2 -0
- package/dist/esm/operations/index.d.ts.map +1 -1
- package/dist/esm/operations/index.js +2 -0
- package/dist/esm/operations/index.js.map +1 -1
- package/dist/esm/operations/virtualMachineScaleSetRollingUpgrades.d.ts.map +1 -1
- package/dist/esm/operations/virtualMachineScaleSetRollingUpgrades.js.map +1 -1
- package/dist/esm/operations/virtualMachineScaleSetVMRunCommands.d.ts.map +1 -1
- package/dist/esm/operations/virtualMachineScaleSetVMRunCommands.js.map +1 -1
- package/dist/esm/operationsInterfaces/galleryScriptVersions.d.ts +84 -0
- package/dist/esm/operationsInterfaces/galleryScriptVersions.d.ts.map +1 -0
- package/dist/esm/operationsInterfaces/galleryScriptVersions.js +4 -0
- package/dist/esm/operationsInterfaces/galleryScriptVersions.js.map +1 -0
- package/dist/esm/operationsInterfaces/galleryScripts.d.ts +76 -0
- package/dist/esm/operationsInterfaces/galleryScripts.d.ts.map +1 -0
- package/dist/esm/operationsInterfaces/galleryScripts.js +4 -0
- package/dist/esm/operationsInterfaces/galleryScripts.js.map +1 -0
- package/dist/esm/operationsInterfaces/index.d.ts +2 -0
- package/dist/esm/operationsInterfaces/index.d.ts.map +1 -1
- package/dist/esm/operationsInterfaces/index.js +2 -0
- package/dist/esm/operationsInterfaces/index.js.map +1 -1
- package/dist/react-native/computeManagementClient.d.ts +3 -1
- package/dist/react-native/computeManagementClient.d.ts.map +1 -1
- package/dist/react-native/computeManagementClient.js +6 -2
- package/dist/react-native/computeManagementClient.js.map +1 -1
- package/dist/react-native/models/index.d.ts +316 -3
- package/dist/react-native/models/index.d.ts.map +1 -1
- package/dist/react-native/models/index.js +22 -0
- package/dist/react-native/models/index.js.map +1 -1
- package/dist/react-native/models/mappers.d.ts +19 -0
- package/dist/react-native/models/mappers.d.ts.map +1 -1
- package/dist/react-native/models/mappers.js +533 -0
- package/dist/react-native/models/mappers.js.map +1 -1
- package/dist/react-native/models/parameters.d.ts +6 -0
- package/dist/react-native/models/parameters.d.ts.map +1 -1
- package/dist/react-native/models/parameters.js +47 -2
- package/dist/react-native/models/parameters.js.map +1 -1
- package/dist/react-native/operations/galleryInVMAccessControlProfileVersions.d.ts.map +1 -1
- package/dist/react-native/operations/galleryInVMAccessControlProfileVersions.js.map +1 -1
- package/dist/react-native/operations/galleryScriptVersions.d.ts +111 -0
- package/dist/react-native/operations/galleryScriptVersions.d.ts.map +1 -0
- package/dist/react-native/operations/galleryScriptVersions.js +484 -0
- package/dist/react-native/operations/galleryScriptVersions.js.map +1 -0
- package/dist/react-native/operations/galleryScripts.d.ts +101 -0
- package/dist/react-native/operations/galleryScripts.d.ts.map +1 -0
- package/dist/react-native/operations/galleryScripts.js +454 -0
- package/dist/react-native/operations/galleryScripts.js.map +1 -0
- package/dist/react-native/operations/index.d.ts +2 -0
- package/dist/react-native/operations/index.d.ts.map +1 -1
- package/dist/react-native/operations/index.js +2 -0
- package/dist/react-native/operations/index.js.map +1 -1
- package/dist/react-native/operations/virtualMachineScaleSetRollingUpgrades.d.ts.map +1 -1
- package/dist/react-native/operations/virtualMachineScaleSetRollingUpgrades.js.map +1 -1
- package/dist/react-native/operations/virtualMachineScaleSetVMRunCommands.d.ts.map +1 -1
- package/dist/react-native/operations/virtualMachineScaleSetVMRunCommands.js.map +1 -1
- package/dist/react-native/operationsInterfaces/galleryScriptVersions.d.ts +84 -0
- package/dist/react-native/operationsInterfaces/galleryScriptVersions.d.ts.map +1 -0
- package/dist/react-native/operationsInterfaces/galleryScriptVersions.js +4 -0
- package/dist/react-native/operationsInterfaces/galleryScriptVersions.js.map +1 -0
- package/dist/react-native/operationsInterfaces/galleryScripts.d.ts +76 -0
- package/dist/react-native/operationsInterfaces/galleryScripts.d.ts.map +1 -0
- package/dist/react-native/operationsInterfaces/galleryScripts.js +4 -0
- package/dist/react-native/operationsInterfaces/galleryScripts.js.map +1 -0
- package/dist/react-native/operationsInterfaces/index.d.ts +2 -0
- package/dist/react-native/operationsInterfaces/index.d.ts.map +1 -1
- package/dist/react-native/operationsInterfaces/index.js +2 -0
- package/dist/react-native/operationsInterfaces/index.js.map +1 -1
- package/package.json +10 -10
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/models/index.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;;;AAi1QlC,+DAA+D;AAC/D,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,WAAW;IACX,4BAAa,CAAA;IACb,aAAa;IACb,gCAAiB,CAAA;IACjB,iBAAiB;IACjB,yCAA0B,CAAA;AAC5B,CAAC,EAPW,WAAW,2BAAX,WAAW,QAOtB;AAaD,mEAAmE;AACnE,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,eAAe;IACf,wCAAqB,CAAA;AACvB,CAAC,EAHW,eAAe,+BAAf,eAAe,QAG1B;AAWD,sEAAsE;AACtE,IAAY,kBASX;AATD,WAAY,kBAAkB;IAC5B,WAAW;IACX,mCAAa,CAAA;IACb,kBAAkB;IAClB,iDAA2B,CAAA;IAC3B,sBAAsB;IACtB,yDAAmC,CAAA;IACnC,UAAU;IACV,iCAAW,CAAA;AACb,CAAC,EATW,kBAAkB,kCAAlB,kBAAkB,QAS7B;AAcD,mGAAmG;AACnG,IAAY,+CAKX;AALD,WAAY,+CAA+C;IACzD,mCAAmC;IACnC,kHAA+D,CAAA;IAC/D,yBAAyB;IACzB,8FAA2C,CAAA;AAC7C,CAAC,EALW,+CAA+C,+DAA/C,+CAA+C,QAK1D;AAYD,yGAAyG;AACzG,IAAY,qDAOX;AAPD,WAAY,qDAAqD;IAC/D,4BAA4B;IAC5B,wGAA+C,CAAA;IAC/C,6BAA6B;IAC7B,0GAAiD,CAAA;IACjD,UAAU;IACV,oEAAW,CAAA;AACb,CAAC,EAPW,qDAAqD,qEAArD,qDAAqD,QAOhE;AAaD,wEAAwE;AACxE,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,yGAAyG;IACzG,6CAAqB,CAAA;IACrB,+GAA+G;IAC/G,uCAAe,CAAA;AACjB,CAAC,EALW,oBAAoB,oCAApB,oBAAoB,QAK/B;AAYD,4EAA4E;AAC5E,IAAY,wBAeX;AAfD,WAAY,wBAAwB;IAClC,kBAAkB;IAClB,wDAA4B,CAAA;IAC5B,iBAAiB;IACjB,sDAA0B,CAAA;IAC1B,qBAAqB;IACrB,8DAAkC,CAAA;IAClC,kBAAkB;IAClB,wDAA4B,CAAA;IAC5B,iBAAiB;IACjB,sDAA0B,CAAA;IAC1B,qBAAqB;IACrB,8DAAkC,CAAA;IAClC,mBAAmB;IACnB,0DAA8B,CAAA;AAChC,CAAC,EAfW,wBAAwB,wCAAxB,wBAAwB,QAenC;AAiBD,8EAA8E;AAC9E,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,SAAS;IACT,uCAAS,CAAA;IACT,SAAS;IACT,uCAAS,CAAA;AACX,CAAC,EALW,0BAA0B,0CAA1B,0BAA0B,QAKrC;AAYD,8EAA8E;AAC9E,IAAY,0BAGX;AAHD,WAAY,0BAA0B;IACpC,eAAe;IACf,mDAAqB,CAAA;AACvB,CAAC,EAHW,0BAA0B,0CAA1B,0BAA0B,QAGrC;AAWD,oEAAoE;AACpE,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,WAAW;IACX,iCAAa,CAAA;IACb,gBAAgB;IAChB,2CAAuB,CAAA;AACzB,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B;AAYD,0EAA0E;AAC1E,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,UAAU;IACV,qCAAW,CAAA;IACX,YAAY;IACZ,yCAAe,CAAA;AACjB,CAAC,EALW,sBAAsB,sCAAtB,sBAAsB,QAKjC;AAYD,mEAAmE;AACnE,IAAY,eAOX;AAPD,WAAY,eAAe;IACzB,aAAa;IACb,oCAAiB,CAAA;IACjB,8BAA8B;IAC9B,sEAAmD,CAAA;IACnD,iBAAiB;IACjB,4CAAyB,CAAA;AAC3B,CAAC,EAPW,eAAe,+BAAf,eAAe,QAO1B;AAaD,wEAAwE;AACxE,IAAY,oBAOX;AAPD,WAAY,oBAAoB;IAC9B,WAAW;IACX,qCAAa,CAAA;IACb,YAAY;IACZ,uCAAe,CAAA;IACf,WAAW;IACX,qCAAa,CAAA;AACf,CAAC,EAPW,oBAAoB,oCAApB,oBAAoB,QAO/B;AAaD,qEAAqE;AACrE,IAAY,iBAOX;AAPD,WAAY,iBAAiB;IAC3B,cAAc;IACd,wCAAmB,CAAA;IACnB,cAAc;IACd,wCAAmB,CAAA;IACnB,cAAc;IACd,wCAAmB,CAAA;AACrB,CAAC,EAPW,iBAAiB,iCAAjB,iBAAiB,QAO5B;AAaD,gFAAgF;AAChF,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,aAAa;IACb,iDAAiB,CAAA;IACjB,oBAAoB;IACpB,+DAA+B,CAAA;IAC/B,0BAA0B;IAC1B,2EAA2C,CAAA;AAC7C,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAaD,mFAAmF;AACnF,IAAY,+BAKX;AALD,WAAY,+BAA+B;IACzC,mBAAmB;IACnB,gEAA6B,CAAA;IAC7B,0BAA0B;IAC1B,8EAA2C,CAAA;AAC7C,CAAC,EALW,+BAA+B,+CAA/B,+BAA+B,QAK1C;AAYD,4GAA4G;AAC5G,IAAY,wDASX;AATD,WAAY,wDAAwD;IAClE,cAAc;IACd,+EAAmB,CAAA;IACnB,iBAAiB;IACjB,qFAAyB,CAAA;IACzB,YAAY;IACZ,2EAAe,CAAA;IACf,aAAa;IACb,6EAAiB,CAAA;AACnB,CAAC,EATW,wDAAwD,wEAAxD,wDAAwD,QASnE;AAcD,8EAA8E;AAC9E,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,mBAAmB;IACnB,2DAA6B,CAAA;IAC7B,0BAA0B;IAC1B,yEAA2C,CAAA;AAC7C,CAAC,EALW,0BAA0B,0CAA1B,0BAA0B,QAKrC;AAYD,iFAAiF;AACjF,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,mBAAmB;IACnB,8DAA6B,CAAA;IAC7B,0BAA0B;IAC1B,4EAA2C,CAAA;AAC7C,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC;AAYD,0GAA0G;AAC1G,IAAY,sDASX;AATD,WAAY,sDAAsD;IAChE,cAAc;IACd,6EAAmB,CAAA;IACnB,iBAAiB;IACjB,mFAAyB,CAAA;IACzB,YAAY;IACZ,yEAAe,CAAA;IACf,aAAa;IACb,2EAAiB,CAAA;AACnB,CAAC,EATW,sDAAsD,sEAAtD,sDAAsD,QASjE;AAcD,8EAA8E;AAC9E,IAAY,0BAWX;AAXD,WAAY,0BAA0B;IACpC,gBAAgB;IAChB,qDAAuB,CAAA;IACvB,YAAY;IACZ,6CAAe,CAAA;IACf,aAAa;IACb,+CAAiB,CAAA;IACjB,WAAW;IACX,2CAAa,CAAA;IACb,cAAc;IACd,iDAAmB,CAAA;AACrB,CAAC,EAXW,0BAA0B,0CAA1B,0BAA0B,QAWrC;AAeD,wEAAwE;AACxE,IAAY,oBAGX;AAHD,WAAY,oBAAoB;IAC9B,YAAY;IACZ,uCAAe,CAAA;AACjB,CAAC,EAHW,oBAAoB,oCAApB,oBAAoB,QAG/B;AAWD,0EAA0E;AAC1E,IAAY,sBAOX;AAPD,WAAY,sBAAsB;IAChC,gBAAgB;IAChB,iDAAuB,CAAA;IACvB,mBAAmB;IACnB,uDAA6B,CAAA;IAC7B,eAAe;IACf,+CAAqB,CAAA;AACvB,CAAC,EAPW,sBAAsB,sCAAtB,sBAAsB,QAOjC;AAaD,gFAAgF;AAChF,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,uBAAuB;IACvB,qEAAqC,CAAA;IACrC,2BAA2B;IAC3B,6EAA6C,CAAA;IAC7C,sBAAsB;IACtB,mEAAmC,CAAA;AACrC,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAaD,8EAA8E;AAC9E,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,aAAa;IACb,+CAAiB,CAAA;IACjB,aAAa;IACb,+CAAiB,CAAA;AACnB,CAAC,EALW,0BAA0B,0CAA1B,0BAA0B,QAKrC;AAYD,4EAA4E;AAC5E,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC,WAAW;IACX,yCAAa,CAAA;IACb,WAAW;IACX,yCAAa,CAAA;AACf,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAYD,kFAAkF;AAClF,IAAY,8BASX;AATD,WAAY,8BAA8B;IACxC,kBAAkB;IAClB,6DAA2B,CAAA;IAC3B,wBAAwB;IACxB,yEAAuC,CAAA;IACvC,yBAAyB;IACzB,2EAAyC,CAAA;IACzC,cAAc;IACd,qDAAmB,CAAA;AACrB,CAAC,EATW,8BAA8B,8CAA9B,8BAA8B,QASzC;AAcD,kEAAkE;AAClE,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,WAAW;IACX,+BAAa,CAAA;IACb,WAAW;IACX,+BAAa,CAAA;AACf,CAAC,EALW,cAAc,8BAAd,cAAc,QAKzB;AAYD,sEAAsE;AACtE,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC5B,aAAa;IACb,uCAAiB,CAAA;IACjB,aAAa;IACb,uCAAiB,CAAA;AACnB,CAAC,EALW,kBAAkB,kCAAlB,kBAAkB,QAK7B;AAYD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,YAAY;IACZ,8CAAe,CAAA;IACf,eAAe;IACf,oDAAqB,CAAA;AACvB,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,eAAe;IACf,oDAAqB,CAAA;IACrB,aAAa;IACb,gDAAiB,CAAA;AACnB,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,sFAAsF;AACtF,IAAY,kCAOX;AAPD,WAAY,kCAAkC;IAC5C,WAAW;IACX,mDAAa,CAAA;IACb,6BAA6B;IAC7B,uFAAiD,CAAA;IACjD,eAAe;IACf,2DAAqB,CAAA;AACvB,CAAC,EAPW,kCAAkC,kDAAlC,kCAAkC,QAO7C;AAaD,qFAAqF;AACrF,IAAY,iCAWX;AAXD,WAAY,iCAAiC;IAC3C,WAAW;IACX,kDAAa,CAAA;IACb,SAAS;IACT,8CAAS,CAAA;IACT,SAAS;IACT,8CAAS,CAAA;IACT,SAAS;IACT,8CAAS,CAAA;IACT,SAAS;IACT,8CAAS,CAAA;AACX,CAAC,EAXW,iCAAiC,iDAAjC,iCAAiC,QAW5C;AAeD,0EAA0E;AAC1E,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,4BAA4B;IAC5B,8DAAoC,CAAA;IACpC,+BAA+B;IAC/B,iEAAuC,CAAA;AACzC,CAAC,EALW,sBAAsB,sCAAtB,sBAAsB,QAKjC;AAYD,sEAAsE;AACtE,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC5B,oBAAoB;IACpB,qDAA+B,CAAA;IAC/B,qBAAqB;IACrB,uDAAiC,CAAA;AACnC,CAAC,EALW,kBAAkB,kCAAlB,kBAAkB,QAK7B;AAYD,6DAA6D;AAC7D,IAAY,SAKX;AALD,WAAY,SAAS;IACnB,YAAY;IACZ,4BAAe,CAAA;IACf,cAAc;IACd,gCAAmB,CAAA;AACrB,CAAC,EALW,SAAS,yBAAT,SAAS,QAKpB;AAYD,8DAA8D;AAC9D,IAAY,UAOX;AAPD,WAAY,UAAU;IACpB,YAAY;IACZ,6BAAe,CAAA;IACf,cAAc;IACd,iCAAmB,CAAA;IACnB,eAAe;IACf,mCAAqB,CAAA;AACvB,CAAC,EAPW,UAAU,0BAAV,UAAU,QAOrB;AAaD,oFAAoF;AACpF,IAAY,gCAOX;AAPD,WAAY,gCAAgC;IAC1C,cAAc;IACd,uDAAmB,CAAA;IACnB,UAAU;IACV,+CAAW,CAAA;IACX,WAAW;IACX,iDAAa,CAAA;AACf,CAAC,EAPW,gCAAgC,gDAAhC,gCAAgC,QAO3C;AAaD,0FAA0F;AAC1F,IAAY,sCAKX;AALD,WAAY,sCAAsC;IAChD,iBAAiB;IACjB,mEAAyB,CAAA;IACzB,aAAa;IACb,2DAAiB,CAAA;AACnB,CAAC,EALW,sCAAsC,sDAAtC,sCAAsC,QAKjD;AAYD,2FAA2F;AAC3F,IAAY,uCAOX;AAPD,WAAY,uCAAuC;IACjD,cAAc;IACd,8DAAmB,CAAA;IACnB,eAAe;IACf,gEAAqB,CAAA;IACrB,eAAe;IACf,gEAAqB,CAAA;AACvB,CAAC,EAPW,uCAAuC,uDAAvC,uCAAuC,QAOlD;AAaD,0EAA0E;AAC1E,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,cAAc;IACd,6CAAmB,CAAA;IACnB,eAAe;IACf,+CAAqB,CAAA;AACvB,CAAC,EALW,sBAAsB,sCAAtB,sBAAsB,QAKjC;AAYD,0EAA0E;AAC1E,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,eAAe;IACf,+CAAqB,CAAA;AACvB,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAWD,0EAA0E;AAC1E,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,yBAAyB;IACzB,mEAAyC,CAAA;AAC3C,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAWD,0FAA0F;AAC1F,IAAY,sCAKX;AALD,WAAY,sCAAsC;IAChD,cAAc;IACd,6DAAmB,CAAA;IACnB,gBAAgB;IAChB,iEAAuB,CAAA;AACzB,CAAC,EALW,sCAAsC,sDAAtC,sCAAsC,QAKjD;AAYD,2EAA2E;AAC3E,IAAY,uBAOX;AAPD,WAAY,uBAAuB;IACjC,kBAAkB;IAClB,sDAA2B,CAAA;IAC3B,wBAAwB;IACxB,kEAAuC,CAAA;IACvC,kBAAkB;IAClB,sDAA2B,CAAA;AAC7B,CAAC,EAPW,uBAAuB,uCAAvB,uBAAuB,QAOlC;AAaD,uFAAuF;AACvF,IAAY,mCAKX;AALD,WAAY,mCAAmC;IAC7C,2CAA2C;IAC3C,oDAAa,CAAA;IACb,8CAA8C;IAC9C,sDAAe,CAAA;AACjB,CAAC,EALW,mCAAmC,mDAAnC,mCAAmC,QAK9C;AAYD,gFAAgF;AAChF,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,UAAU;IACV,2CAAW,CAAA;IACX,+DAA+D;IAC/D,6CAAa,CAAA;AACf,CAAC,EALW,4BAA4B,4CAA5B,4BAA4B,QAKvC;AAYD,gFAAgF;AAChF,IAAY,4BA6UX;AA7UD,WAAY,4BAA4B;IACtC,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,uBAAuB;IACvB,wEAAwC,CAAA;IACxC,uBAAuB;IACvB,wEAAwC,CAAA;IACxC,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,qBAAqB;IACrB,kEAAkC,CAAA;IAClC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,qBAAqB;IACrB,kEAAkC,CAAA;IAClC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;AAChC,CAAC,EA7UW,4BAA4B,4CAA5B,4BAA4B,QA6UvC;AAgLD,8EAA8E;AAC9E,IAAY,0BAGX;AAHD,WAAY,0BAA0B;IACpC,kBAAkB;IAClB,yDAA2B,CAAA;AAC7B,CAAC,EAHW,0BAA0B,0CAA1B,0BAA0B,QAGrC;AAWD,mEAAmE;AACnE,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,WAAW;IACX,gCAAa,CAAA;IACb,WAAW;IACX,gCAAa,CAAA;AACf,CAAC,EALW,eAAe,+BAAf,eAAe,QAK1B;AAYD,iFAAiF;AACjF,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,cAAc;IACd,oDAAmB,CAAA;IACnB,aAAa;IACb,kDAAiB,CAAA;AACnB,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC;AAYD,6EAA6E;AAC7E,IAAY,yBAKX;AALD,WAAY,yBAAyB;IACnC,SAAS;IACT,sCAAS,CAAA;IACT,SAAS;IACT,sCAAS,CAAA;AACX,CAAC,EALW,yBAAyB,yCAAzB,yBAAyB,QAKpC;AAYD,6EAA6E;AAC7E,IAAY,yBAWX;AAXD,WAAY,yBAAyB;IACnC,cAAc;IACd,gDAAmB,CAAA;IACnB,iBAAiB;IACjB,sDAAyB,CAAA;IACzB,aAAa;IACb,8CAAiB,CAAA;IACjB,gBAAgB;IAChB,oDAAuB,CAAA;IACvB,4BAA4B;IAC5B,4EAA+C,CAAA;AACjD,CAAC,EAXW,yBAAyB,yCAAzB,yBAAyB,QAWpC;AAeD,oFAAoF;AACpF,IAAY,gCAKX;AALD,WAAY,gCAAgC;IAC1C,eAAe;IACf,yDAAqB,CAAA;IACrB,YAAY;IACZ,mDAAe,CAAA;AACjB,CAAC,EALW,gCAAgC,gDAAhC,gCAAgC,QAK3C;AAYD,4EAA4E;AAC5E,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC,cAAc;IACd,+CAAmB,CAAA;IACnB,YAAY;IACZ,2CAAe,CAAA;AACjB,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAYD,mFAAmF;AACnF,IAAY,+BAOX;AAPD,WAAY,+BAA+B;IACzC,yEAAyE;IACzE,sGAAmE,CAAA;IACnE,uHAAuH;IACvH,sGAAmE,CAAA;IACnE,sJAAsJ;IACtJ,8HAA2F,CAAA;AAC7F,CAAC,EAPW,+BAA+B,+CAA/B,+BAA+B,QAO1C;AAaD,6EAA6E;AAC7E,IAAY,yBAOX;AAPD,WAAY,yBAAyB;IACnC,sBAAsB;IACtB,gEAAmC,CAAA;IACnC,2BAA2B;IAC3B,0EAA6C,CAAA;IAC7C,4BAA4B;IAC5B,4EAA+C,CAAA;AACjD,CAAC,EAPW,yBAAyB,yCAAzB,yBAAyB,QAOpC;AAaD,4EAA4E;AAC5E,IAAY,wBAWX;AAXD,WAAY,wBAAwB;IAClC,qBAAqB;IACrB,+CAAmB,CAAA;IACnB,4EAA4E;IAC5E,+CAAmB,CAAA;IACnB,+FAA+F;IAC/F,mDAAuB,CAAA;IACvB,6GAA6G;IAC7G,2DAA+B,CAAA;IAC/B,iGAAiG;IACjG,qFAAyD,CAAA;AAC3D,CAAC,EAXW,wBAAwB,wCAAxB,wBAAwB,QAWnC;AAeD,8EAA8E;AAC9E,IAAY,0BAGX;AAHD,WAAY,0BAA0B;IACpC,mBAAmB;IACnB,2DAA6B,CAAA;AAC/B,CAAC,EAHW,0BAA0B,0CAA1B,0BAA0B,QAGrC;AAWD,kGAAkG;AAClG,IAAY,8CAGX;AAHD,WAAY,8CAA8C;IACxD,mBAAmB;IACnB,+EAA6B,CAAA;AAC/B,CAAC,EAHW,8CAA8C,8DAA9C,8CAA8C,QAGzD;AAWD,6FAA6F;AAC7F,IAAY,yCAGX;AAHD,WAAY,yCAAyC;IACnD,mBAAmB;IACnB,0EAA6B,CAAA;AAC/B,CAAC,EAHW,yCAAyC,yDAAzC,yCAAyC,QAGpD;AAWD,4FAA4F;AAC5F,IAAY,wCAGX;AAHD,WAAY,wCAAwC;IAClD,oBAAoB;IACpB,2EAA+B,CAAA;AACjC,CAAC,EAHW,wCAAwC,wDAAxC,wCAAwC,QAGnD;AAWD,kFAAkF;AAClF,IAAY,8BAGX;AAHD,WAAY,8BAA8B;IACxC,mBAAmB;IACnB,+DAA6B,CAAA;AAC/B,CAAC,EAHW,8BAA8B,8CAA9B,8BAA8B,QAGzC;AAWD,2EAA2E;AAC3E,IAAY,uBAKX;AALD,WAAY,uBAAuB;IACjC,UAAU;IACV,sCAAW,CAAA;IACX,cAAc;IACd,8CAAmB,CAAA;AACrB,CAAC,EALW,uBAAuB,uCAAvB,uBAAuB,QAKlC;AAYD,qFAAqF;AACrF,IAAY,iCAGX;AAHD,WAAY,iCAAiC;IAC3C,eAAe;IACf,0DAAqB,CAAA;AACvB,CAAC,EAHW,iCAAiC,iDAAjC,iCAAiC,QAG5C;AAWD,kFAAkF;AAClF,IAAY,8BAKX;AALD,WAAY,8BAA8B;IACxC,uBAAuB;IACvB,uEAAqC,CAAA;IACrC,sDAAsD;IACtD,uFAAqD,CAAA;AACvD,CAAC,EALW,8BAA8B,8CAA9B,8BAA8B,QAKzC;AAYD,kFAAkF;AAClF,IAAY,8BAOX;AAPD,WAAY,8BAA8B;IACxC,iBAAiB;IACjB,2DAAyB,CAAA;IACzB,cAAc;IACd,qDAAmB,CAAA;IACnB,gBAAgB;IAChB,yDAAuB,CAAA;AACzB,CAAC,EAPW,8BAA8B,8CAA9B,8BAA8B,QAOzC;AAaD,4FAA4F;AAC5F,IAAY,wCAKX;AALD,WAAY,wCAAwC;IAClD,yDAAyD;IACzD,qEAAyB,CAAA;IACzB,wDAAwD;IACxD,mEAAuB,CAAA;AACzB,CAAC,EALW,wCAAwC,wDAAxC,wCAAwC,QAKnD;AAYD,wFAAwF;AACxF,IAAY,oCAKX;AALD,WAAY,oCAAoC;IAC9C,aAAa;IACb,yDAAiB,CAAA;IACjB,cAAc;IACd,2DAAmB,CAAA;AACrB,CAAC,EALW,oCAAoC,oDAApC,oCAAoC,QAK/C;AAYD,yEAAyE;AACzE,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,SAAS;IACT,kCAAS,CAAA;IACT,SAAS;IACT,kCAAS,CAAA;AACX,CAAC,EALW,qBAAqB,qCAArB,qBAAqB,QAKhC;AAYD,kFAAkF;AAClF,IAAY,8BASX;AATD,WAAY,8BAA8B;IACxC,cAAc;IACd,qDAAmB,CAAA;IACnB,eAAe;IACf,uDAAqB,CAAA;IACrB,iBAAiB;IACjB,2DAAyB,CAAA;IACzB,aAAa;IACb,mDAAiB,CAAA;AACnB,CAAC,EATW,8BAA8B,8CAA9B,8BAA8B,QASzC;AAcD,yEAAyE;AACzE,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,iCAAiC;IACjC,4CAAmB,CAAA;IACnB,qCAAqC;IACrC,oDAA2B,CAAA;AAC7B,CAAC,EALW,qBAAqB,qCAArB,qBAAqB,QAKhC;AAYD,uEAAuE;AACvE,IAAY,mBAeX;AAfD,WAAY,mBAAmB;IAC7B,cAAc;IACd,0CAAmB,CAAA;IACnB,cAAc;IACd,0CAAmB,CAAA;IACnB,cAAc;IACd,0CAAmB,CAAA;IACnB,aAAa;IACb,wCAAiB,CAAA;IACjB,gBAAgB;IAChB,8CAAuB,CAAA;IACvB,eAAe;IACf,4CAAqB,CAAA;IACrB,eAAe;IACf,4CAAqB,CAAA;AACvB,CAAC,EAfW,mBAAmB,mCAAnB,mBAAmB,QAe9B;AAiBD,6EAA6E;AAC7E,IAAY,yBAGX;AAHD,WAAY,yBAAyB;IACnC,mBAAmB;IACnB,0DAA6B,CAAA;AAC/B,CAAC,EAHW,yBAAyB,yCAAzB,yBAAyB,QAGpC;AAWD,mFAAmF;AACnF,IAAY,+BASX;AATD,WAAY,+BAA+B;IACzC,cAAc;IACd,sDAAmB,CAAA;IACnB,mBAAmB;IACnB,gEAA6B,CAAA;IAC7B,2BAA2B;IAC3B,gFAA6C,CAAA;IAC7C,uBAAuB;IACvB,wEAAqC,CAAA;AACvC,CAAC,EATW,+BAA+B,+CAA/B,+BAA+B,QAS1C;AAcD,6EAA6E;AAC7E,IAAY,yBAKX;AALD,WAAY,yBAAyB;IACnC,cAAc;IACd,gDAAmB,CAAA;IACnB,gBAAgB;IAChB,oDAAuB,CAAA;AACzB,CAAC,EALW,yBAAyB,yCAAzB,yBAAyB,QAKpC;AAYD,kFAAkF;AAClF,IAAY,8BAOX;AAPD,WAAY,8BAA8B;IACxC,iBAAiB;IACjB,2DAAyB,CAAA;IACzB,YAAY;IACZ,iDAAe,CAAA;IACf,aAAa;IACb,mDAAiB,CAAA;AACnB,CAAC,EAPW,8BAA8B,8CAA9B,8BAA8B,QAOzC;AAaD,0FAA0F;AAC1F,IAAY,sCAiBX;AAjBD,WAAY,sCAAsC;IAChD,eAAe;IACf,+DAAqB,CAAA;IACrB,eAAe;IACf,+DAAqB,CAAA;IACrB,mBAAmB;IACnB,uEAA6B,CAAA;IAC7B,kBAAkB;IAClB,qEAA2B,CAAA;IAC3B,kBAAkB;IAClB,qEAA2B,CAAA;IAC3B,iBAAiB;IACjB,mEAAyB,CAAA;IACzB,YAAY;IACZ,yDAAe,CAAA;IACf,cAAc;IACd,6DAAmB,CAAA;AACrB,CAAC,EAjBW,sCAAsC,sDAAtC,sCAAsC,QAiBjD;AAkBD,wFAAwF;AACxF,IAAY,oCAOX;AAPD,WAAY,oCAAoC;IAC9C,eAAe;IACf,6DAAqB,CAAA;IACrB,eAAe;IACf,6DAAqB,CAAA;IACrB,YAAY;IACZ,uDAAe,CAAA;AACjB,CAAC,EAPW,oCAAoC,oDAApC,oCAAoC,QAO/C;AAaD,iFAAiF;AACjF,IAAY,6BAaX;AAbD,WAAY,6BAA6B;IACvC,cAAc;IACd,oDAAmB,CAAA;IACnB,gBAAgB;IAChB,wDAAuB,CAAA;IACvB,eAAe;IACf,sDAAqB,CAAA;IACrB,cAAc;IACd,oDAAmB,CAAA;IACnB,aAAa;IACb,kDAAiB,CAAA;IACjB,gBAAgB;IAChB,wDAAuB,CAAA;AACzB,CAAC,EAbW,6BAA6B,6CAA7B,6BAA6B,QAaxC;AAgBD,+EAA+E;AAC/E,IAAY,2BAaX;AAbD,WAAY,2BAA2B;IACrC,cAAc;IACd,kDAAmB,CAAA;IACnB,gBAAgB;IAChB,sDAAuB,CAAA;IACvB,aAAa;IACb,gDAAiB,CAAA;IACjB,eAAe;IACf,oDAAqB,CAAA;IACrB,kBAAkB;IAClB,0DAA2B,CAAA;IAC3B,cAAc;IACd,kDAAmB,CAAA;AACrB,CAAC,EAbW,2BAA2B,2CAA3B,2BAA2B,QAatC;AAgBD,+FAA+F;AAC/F,IAAY,2CAOX;AAPD,WAAY,2CAA2C;IACrD,cAAc;IACd,kEAAmB,CAAA;IACnB,eAAe;IACf,oEAAqB,CAAA;IACrB,eAAe;IACf,oEAAqB,CAAA;AACvB,CAAC,EAPW,2CAA2C,2DAA3C,2CAA2C,QAOtD;AAaD,mGAAmG;AACnG,IAAY,+CASX;AATD,WAAY,+CAA+C;IACzD,gBAAgB;IAChB,0EAAuB,CAAA;IACvB,eAAe;IACf,wEAAqB,CAAA;IACrB,eAAe;IACf,wEAAqB,CAAA;IACrB,aAAa;IACb,oEAAiB,CAAA;AACnB,CAAC,EATW,+CAA+C,+DAA/C,+CAA+C,QAS1D;AAcD,8EAA8E;AAC9E,IAAY,0BAOX;AAPD,WAAY,0BAA0B;IACpC,2IAA2I;IAC3I,iGAAmE,CAAA;IACnE,4KAA4K;IAC5K,yHAA2F,CAAA;IAC3F,sGAAsG;IACtG,+GAAiF,CAAA;AACnF,CAAC,EAPW,0BAA0B,0CAA1B,0BAA0B,QAOrC;AAaD,sFAAsF;AACtF,IAAY,kCASX;AATD,WAAY,kCAAkC;IAC5C,qBAAqB;IACrB,uEAAiC,CAAA;IACjC,mBAAmB;IACnB,mEAA6B,CAAA;IAC7B,iCAAiC;IACjC,iGAA2D,CAAA;IAC3D,WAAW;IACX,mDAAa,CAAA;AACf,CAAC,EATW,kCAAkC,kDAAlC,kCAAkC,QAS7C;AAcD,qEAAqE;AACrE,IAAY,iBAKX;AALD,WAAY,iBAAiB;IAC3B,UAAU;IACV,gCAAW,CAAA;IACX,YAAY;IACZ,oCAAe,CAAA;AACjB,CAAC,EALW,iBAAiB,iCAAjB,iBAAiB,QAK5B;AAYD,gFAAgF;AAChF,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,qDAAqD;IACrD,iFAAiD,CAAA;IACjD,2EAA2E;IAC3E,mHAAmF,CAAA;AACrF,CAAC,EALW,4BAA4B,4CAA5B,4BAA4B,QAKvC;AAYD,yEAAyE;AACzE,IAAY,qBAuBX;AAvBD,WAAY,qBAAqB;IAC/B,+DAA+D;IAC/D,wCAAe,CAAA;IACf,qCAAqC;IACrC,0CAAiB,CAAA;IACjB,8GAA8G;IAC9G,gDAAuB,CAAA;IACvB,0HAA0H;IAC1H,0CAAiB,CAAA;IACjB,gHAAgH;IAChH,sCAAa,CAAA;IACb,iEAAiE;IACjE,4CAAmB,CAAA;IACnB,6GAA6G;IAC7G,0CAAiB,CAAA;IACjB,8JAA8J;IAC9J,gDAAuB,CAAA;IACvB,0ZAA0Z;IAC1Z,sDAA6B,CAAA;IAC7B,+SAA+S;IAC/S,sEAA6C,CAAA;IAC7C,sEAAsE;IACtE,oEAA2C,CAAA;AAC7C,CAAC,EAvBW,qBAAqB,qCAArB,qBAAqB,QAuBhC;AAqBD,uFAAuF;AACvF,IAAY,mCAKX;AALD,WAAY,mCAAmC;IAC7C,WAAW;IACX,oDAAa,CAAA;IACb,eAAe;IACf,4DAAqB,CAAA;AACvB,CAAC,EALW,mCAAmC,mDAAnC,mCAAmC,QAK9C;AAYD,kEAAkE;AAClE,IAAY,cAiBX;AAjBD,WAAY,cAAc;IACxB,8DAA8D;IAC9D,2CAAyB,CAAA;IACzB,sDAAsD;IACtD,uCAAqB,CAAA;IACrB,wDAAwD;IACxD,uCAAqB,CAAA;IACrB,iEAAiE;IACjE,mCAAiB,CAAA;IACjB,mEAAmE;IACnE,yCAAuB,CAAA;IACvB,qGAAqG;IACrG,qDAAmC,CAAA;IACnC,2EAA2E;IAC3E,iDAA+B,CAAA;IAC/B,0FAA0F;IAC1F,+CAA6B,CAAA;AAC/B,CAAC,EAjBW,cAAc,8BAAd,cAAc,QAiBzB;AAkBD,uEAAuE;AACvE,IAAY,mBAOX;AAPD,WAAY,mBAAmB;IAC7B,4JAA4J;IAC5J,0FAAmE,CAAA;IACnE,yGAAyG;IACzG,0FAAmE,CAAA;IACnE,wIAAwI;IACxI,kHAA2F,CAAA;AAC7F,CAAC,EAPW,mBAAmB,mCAAnB,mBAAmB,QAO9B;AAaD,4EAA4E;AAC5E,IAAY,wBAOX;AAPD,WAAY,wBAAwB;IAClC,gEAAgE;IAChE,iDAAqB,CAAA;IACrB,+FAA+F;IAC/F,yDAA6B,CAAA;IAC7B,mCAAmC;IACnC,+CAAmB,CAAA;AACrB,CAAC,EAPW,wBAAwB,wCAAxB,wBAAwB,QAOnC;AAaD,0EAA0E;AAC1E,IAAY,sBAWX;AAXD,WAAY,sBAAsB;IAChC,+GAA+G;IAC/G,yDAA+B,CAAA;IAC/B,wEAAwE;IACxE,4IAAkH,CAAA;IAClH,gHAAgH;IAChH,oHAA0F,CAAA;IAC1F,gHAAgH;IAChH,oHAA0F,CAAA;IAC1F,2GAA2G;IAC3G,0FAAgE,CAAA;AAClE,CAAC,EAXW,sBAAsB,sCAAtB,sBAAsB,QAWjC;AAeD,4EAA4E;AAC5E,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC,4QAA4Q;IAC5Q,+CAAmB,CAAA;IACnB,8PAA8P;IAC9P,iDAAqB,CAAA;AACvB,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAYD,2EAA2E;AAC3E,IAAY,uBAKX;AALD,WAAY,uBAAuB;IACjC,mNAAmN;IACnN,wEAA6C,CAAA;IAC7C,yFAAyF;IACzF,wCAAa,CAAA;AACf,CAAC,EALW,uBAAuB,uCAAvB,uBAAuB,QAKlC;AAYD,oFAAoF;AACpF,IAAY,gCAKX;AALD,WAAY,gCAAgC;IAC1C,+FAA+F;IAC/F,iDAAa,CAAA;IACb,wFAAwF;IACxF,2EAAuC,CAAA;AACzC,CAAC,EALW,gCAAgC,gDAAhC,gCAAgC,QAK3C;AAYD,gFAAgF;AAChF,IAAY,4BAeX;AAfD,WAAY,4BAA4B;IACtC,oGAAoG;IACpG,4DAA4B,CAAA;IAC5B,sGAAsG;IACtG,0DAA0B,CAAA;IAC1B,wHAAwH;IACxH,kEAAkC,CAAA;IAClC,mLAAmL;IACnL,4DAA4B,CAAA;IAC5B,gIAAgI;IAChI,0DAA0B,CAAA;IAC1B,wKAAwK;IACxK,kEAAkC,CAAA;IAClC,4KAA4K;IAC5K,8DAA8B,CAAA;AAChC,CAAC,EAfW,4BAA4B,4CAA5B,4BAA4B,QAevC;AAiBD,kFAAkF;AAClF,IAAY,8BAGX;AAHD,WAAY,8BAA8B;IACxC,gJAAgJ;IAChJ,2EAAyC,CAAA;AAC3C,CAAC,EAHW,8BAA8B,8CAA9B,8BAA8B,QAGzC;AAWD,oFAAoF;AACpF,IAAY,gCAOX;AAPD,WAAY,gCAAgC;IAC1C,6CAA6C;IAC7C,gEAA4B,CAAA;IAC5B,4CAA4C;IAC5C,8DAA0B,CAAA;IAC1B,sCAAsC;IACtC,gEAA4B,CAAA;AAC9B,CAAC,EAPW,gCAAgC,gDAAhC,gCAAgC,QAO3C;AAaD,oEAAoE;AACpE,IAAY,gBAOX;AAPD,WAAY,gBAAgB;IAC1B,WAAW;IACX,iCAAa,CAAA;IACb,WAAW;IACX,iCAAa,CAAA;IACb,YAAY;IACZ,mCAAe,CAAA;AACjB,CAAC,EAPW,gBAAgB,gCAAhB,gBAAgB,QAO3B;AAaD,mEAAmE;AACnE,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,4EAA4E;IAC5E,8BAAW,CAAA;IACX,gFAAgF;IAChF,gCAAa,CAAA;AACf,CAAC,EALW,eAAe,+BAAf,eAAe,QAK1B;AAYD,6EAA6E;AAC7E,IAAY,yBAGX;AAHD,WAAY,yBAAyB;IACnC,eAAe;IACf,kDAAqB,CAAA;AACvB,CAAC,EAHW,yBAAyB,yCAAzB,yBAAyB,QAGpC;AAWD,iFAAiF;AACjF,IAAY,6BAaX;AAbD,WAAY,6BAA6B;IACvC,eAAe;IACf,sDAAqB,CAAA;IACrB,eAAe;IACf,sDAAqB,CAAA;IACrB,aAAa;IACb,kDAAiB,CAAA;IACjB,gBAAgB;IAChB,wDAAuB,CAAA;IACvB,eAAe;IACf,sDAAqB,CAAA;IACrB,gBAAgB;IAChB,wDAAuB,CAAA;AACzB,CAAC,EAbW,6BAA6B,6CAA7B,6BAA6B,QAaxC;AAgBD,sFAAsF;AACtF,IAAY,kCAOX;AAPD,WAAY,kCAAkC;IAC5C,cAAc;IACd,yDAAmB,CAAA;IACnB,aAAa;IACb,uDAAiB,CAAA;IACjB,gBAAgB;IAChB,6DAAuB,CAAA;AACzB,CAAC,EAPW,kCAAkC,kDAAlC,kCAAkC,QAO7C;AAaD,iFAAiF;AACjF,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,oBAAoB;IACpB,gEAA+B,CAAA;IAC/B,iBAAiB;IACjB,0DAAyB,CAAA;AAC3B,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC;AAYD,qEAAqE;AACrE,IAAY,iBASX;AATD,WAAY,iBAAiB;IAC3B,gBAAgB;IAChB,4CAAuB,CAAA;IACvB,iBAAiB;IACjB,8CAAyB,CAAA;IACzB,aAAa;IACb,sCAAiB,CAAA;IACjB,cAAc;IACd,wCAAmB,CAAA;AACrB,CAAC,EATW,iBAAiB,iCAAjB,iBAAiB,QAS5B;AAcD,kFAAkF;AAClF,IAAY,8BAOX;AAPD,WAAY,8BAA8B;IACxC,0BAA0B;IAC1B,6EAA2C,CAAA;IAC3C,gDAAgD;IAChD,yHAAuF,CAAA;IACvF,+BAA+B;IAC/B,uFAAqD,CAAA;AACvD,CAAC,EAPW,8BAA8B,8CAA9B,8BAA8B,QAOzC;AAaD,oEAAoE;AACpE,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,aAAa;IACb,qCAAiB,CAAA;IACjB,WAAW;IACX,iCAAa,CAAA;AACf,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B;AAYD,iFAAiF;AACjF,IAAY,6BAOX;AAPD,WAAY,6BAA6B;IACvC,WAAW;IACX,8CAAa,CAAA;IACb,eAAe;IACf,sDAAqB,CAAA;IACrB,gBAAgB;IAChB,wDAAuB,CAAA;AACzB,CAAC,EAPW,6BAA6B,6CAA7B,6BAA6B,QAOxC;AAaD,uEAAuE;AACvE,IAAY,mBAGX;AAHD,WAAY,mBAAmB;IAC7B,aAAa;IACb,wCAAiB,CAAA;AACnB,CAAC,EAHW,mBAAmB,mCAAnB,mBAAmB,QAG9B;AAWD,0EAA0E;AAC1E,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,kBAAkB;IAClB,qDAA2B,CAAA;AAC7B,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAWD,4EAA4E;AAC5E,IAAY,wBAGX;AAHD,WAAY,wBAAwB;IAClC,2BAA2B;IAC3B,0EAA8C,CAAA;AAChD,CAAC,EAHW,wBAAwB,wCAAxB,wBAAwB,QAGnC;AAWD,+FAA+F;AAC/F,IAAY,2CAKX;AALD,WAAY,2CAA2C;IACrD,WAAW;IACX,4DAAa,CAAA;IACb,YAAY;IACZ,8DAAe,CAAA;AACjB,CAAC,EALW,2CAA2C,2DAA3C,2CAA2C,QAKtD;AAYD,2EAA2E;AAC3E,IAAY,uBASX;AATD,WAAY,uBAAuB;IACjC,kBAAkB;IAClB,uDAA4B,CAAA;IAC5B,kBAAkB;IAClB,uDAA4B,CAAA;IAC5B,iBAAiB;IACjB,qDAA0B,CAAA;IAC1B,mBAAmB;IACnB,yDAA8B,CAAA;AAChC,CAAC,EATW,uBAAuB,uCAAvB,uBAAuB,QASlC;AAcD,qFAAqF;AACrF,IAAY,iCASX;AATD,WAAY,iCAAiC;IAC3C,uCAAuC;IACvC,0GAAqE,CAAA;IACrE,uBAAuB;IACvB,0EAAqC,CAAA;IACrC,uBAAuB;IACvB,0EAAqC,CAAA;IACrC,sBAAsB;IACtB,wEAAmC,CAAA;AACrC,CAAC,EATW,iCAAiC,iDAAjC,iCAAiC,QAS5C;AAcD,wEAAwE;AACxE,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,WAAW;IACX,qCAAa,CAAA;IACb,cAAc;IACd,2CAAmB,CAAA;AACrB,CAAC,EALW,oBAAoB,oCAApB,oBAAoB,QAK/B;AAYD,oFAAoF;AACpF,IAAY,gCAKX;AALD,WAAY,gCAAgC;IAC1C,eAAe;IACf,yDAAqB,CAAA;IACrB,cAAc;IACd,uDAAmB,CAAA;AACrB,CAAC,EALW,gCAAgC,gDAAhC,gCAAgC,QAK3C;AAYD,mFAAmF;AACnF,IAAY,+BASX;AATD,WAAY,+BAA+B;IACzC,kBAAkB;IAClB,+DAA4B,CAAA;IAC5B,kBAAkB;IAClB,+DAA4B,CAAA;IAC5B,qBAAqB;IACrB,qEAAkC,CAAA;IAClC,iBAAiB;IACjB,6DAA0B,CAAA;AAC5B,CAAC,EATW,+BAA+B,+CAA/B,+BAA+B,QAS1C;AAcD,mFAAmF;AACnF,IAAY,+BASX;AATD,WAAY,+BAA+B;IACzC,cAAc;IACd,sDAAmB,CAAA;IACnB,iBAAiB;IACjB,4DAAyB,CAAA;IACzB,gBAAgB;IAChB,0DAAuB,CAAA;IACvB,aAAa;IACb,oDAAiB,CAAA;AACnB,CAAC,EATW,+BAA+B,+CAA/B,+BAA+B,QAS1C;AAcD,yEAAyE;AACzE,IAAY,qBASX;AATD,WAAY,qBAAqB;IAC/B,cAAc;IACd,4CAAmB,CAAA;IACnB,kBAAkB;IAClB,oDAA2B,CAAA;IAC3B,gBAAgB;IAChB,gDAAuB,CAAA;IACvB,aAAa;IACb,0CAAiB,CAAA;AACnB,CAAC,EATW,qBAAqB,qCAArB,qBAAqB,QAShC;AAcD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,wBAAwB;IACxB,sEAAuC,CAAA;IACvC,mBAAmB;IACnB,4DAA6B,CAAA;AAC/B,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,gFAAgF;AAChF,IAAY,4BASX;AATD,WAAY,4BAA4B;IACtC,YAAY;IACZ,+CAAe,CAAA;IACf,yBAAyB;IACzB,yEAAyC,CAAA;IACzC,0BAA0B;IAC1B,2EAA2C,CAAA;IAC3C,cAAc;IACd,mDAAmB,CAAA;AACrB,CAAC,EATW,4BAA4B,4CAA5B,4BAA4B,QASvC;AAcD,yEAAyE;AACzE,IAAY,qBAOX;AAPD,WAAY,qBAAqB;IAC/B,cAAc;IACd,4CAAmB,CAAA;IACnB,aAAa;IACb,0CAAiB,CAAA;IACjB,gBAAgB;IAChB,gDAAuB,CAAA;AACzB,CAAC,EAPW,qBAAqB,qCAArB,qBAAqB,QAOhC;AAaD,+EAA+E;AAC/E,IAAY,2BAOX;AAPD,WAAY,2BAA2B;IACrC,YAAY;IACZ,8CAAe,CAAA;IACf,cAAc;IACd,kDAAmB,CAAA;IACnB,eAAe;IACf,oDAAqB,CAAA;AACvB,CAAC,EAPW,2BAA2B,2CAA3B,2BAA2B,QAOtC;AAaD,uEAAuE;AACvE,IAAY,mBAKX;AALD,WAAY,mBAAmB;IAC7B,YAAY;IACZ,sCAAe,CAAA;IACf,WAAW;IACX,oCAAa,CAAA;AACf,CAAC,EALW,mBAAmB,mCAAnB,mBAAmB,QAK9B;AAYD,oFAAoF;AACpF,IAAY,gCASX;AATD,WAAY,gCAAgC;IAC1C,UAAU;IACV,+CAAW,CAAA;IACX,aAAa;IACb,qDAAiB,CAAA;IACjB,YAAY;IACZ,mDAAe,CAAA;IACf,sBAAsB;IACtB,uEAAmC,CAAA;AACrC,CAAC,EATW,gCAAgC,gDAAhC,gCAAgC,QAS3C;AAcD,iFAAiF;AACjF,IAAY,6BAGX;AAHD,WAAY,6BAA6B;IACvC,aAAa;IACb,kDAAiB,CAAA;AACnB,CAAC,EAHW,6BAA6B,6CAA7B,6BAA6B,QAGxC;AAWD,gFAAgF;AAChF,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,WAAW;IACX,6CAAa,CAAA;IACb,aAAa;IACb,iDAAiB,CAAA;IACjB,mBAAmB;IACnB,6DAA6B,CAAA;AAC/B,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAaD,6EAA6E;AAC7E,IAAY,yBAKX;AALD,WAAY,yBAAyB;IACnC,iBAAiB;IACjB,sDAAyB,CAAA;IACzB,cAAc;IACd,gDAAmB,CAAA;AACrB,CAAC,EALW,yBAAyB,yCAAzB,yBAAyB,QAKpC;AAYD,gFAAgF;AAChF,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,cAAc;IACd,mDAAmB,CAAA;IACnB,cAAc;IACd,mDAAmB,CAAA;AACrB,CAAC,EALW,4BAA4B,4CAA5B,4BAA4B,QAKvC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n// Code generated by Microsoft (R) AutoRest Code Generator.\n// Changes may cause incorrect behavior and will be lost if the code is regenerated.\n\nimport type * as coreClient from \"@azure/core-client\";\n\n/** A list of REST API operations supported by an Azure Resource Provider. It contains an URL link to get the next set of results. */\nexport interface OperationListResult {\n /**\n * List of operations supported by the resource provider\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly value?: Operation[];\n /**\n * URL to get the next set of operation list results (if there are any).\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly nextLink?: string;\n}\n\n/** Details of a REST API operation, returned from the Resource Provider Operations API */\nexport interface Operation {\n /**\n * The name of the operation, as per Resource-Based Access Control (RBAC). Examples: \"Microsoft.Compute/virtualMachines/write\", \"Microsoft.Compute/virtualMachines/capture/action\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Whether the operation applies to data-plane. This is \"true\" for data-plane operations and \"false\" for ARM/control-plane operations.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isDataAction?: boolean;\n /** Localized display information for this particular operation. */\n display?: OperationDisplay;\n /**\n * The intended executor of the operation; as in Resource Based Access Control (RBAC) and audit logs UX. Default value is \"user,system\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly origin?: Origin;\n /**\n * Enum. Indicates the action type. \"Internal\" refers to actions that are for internal only APIs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly actionType?: ActionType;\n}\n\n/** Localized display information for this particular operation. */\nexport interface OperationDisplay {\n /**\n * The localized friendly form of the resource provider name, e.g. \"Microsoft Monitoring Insights\" or \"Microsoft Compute\".\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provider?: string;\n /**\n * The localized friendly name of the resource type related to this operation. E.g. \"Virtual Machines\" or \"Job Schedule Collections\".\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resource?: string;\n /**\n * The concise, localized friendly name for the operation; suitable for dropdowns. E.g. \"Create or Update Virtual Machine\", \"Restart Virtual Machine\".\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly operation?: string;\n /**\n * The short, localized friendly description of the operation; suitable for tool tips and detailed views.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly description?: string;\n}\n\n/** An error response from the Compute service. */\nexport interface CloudError {\n /** Api error. */\n error?: ApiError;\n}\n\n/** Api error. */\nexport interface ApiError {\n /** The Api error details */\n details?: ApiErrorBase[];\n /** The Api inner error */\n innererror?: InnerError;\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Api error base. */\nexport interface ApiErrorBase {\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Inner error details. */\nexport interface InnerError {\n /** The exception type. */\n exceptiontype?: string;\n /** The internal error message or exception dump. */\n errordetail?: string;\n}\n\n/** The List Availability Set operation response. */\nexport interface AvailabilitySetListResult {\n /** The list of availability sets. */\n value: AvailabilitySet[];\n /** The URI to fetch the next page of AvailabilitySets. Call ListNext() with this URI to fetch the next page of AvailabilitySets. */\n nextLink?: string;\n}\n\nexport interface SubResource {\n /** Resource Id */\n id?: string;\n}\n\n/** Instance view status. */\nexport interface InstanceViewStatus {\n /** The status code. */\n code?: string;\n /** The level code. */\n level?: StatusLevelTypes;\n /** The short localizable label for the status. */\n displayStatus?: string;\n /** The detailed status message, including for alerts and error messages. */\n message?: string;\n /** The time of the status. */\n time?: Date;\n}\n\n/** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations. */\nexport interface ScheduledEventsPolicy {\n /** The configuration parameters used while creating userInitiatedRedeploy scheduled event setting creation. */\n userInitiatedRedeploy?: UserInitiatedRedeploy;\n /** The configuration parameters used while creating userInitiatedReboot scheduled event setting creation. */\n userInitiatedReboot?: UserInitiatedReboot;\n /** The configuration parameters used while publishing scheduledEventsAdditionalPublishingTargets. */\n scheduledEventsAdditionalPublishingTargets?: ScheduledEventsAdditionalPublishingTargets;\n /** The configuration parameters used while creating AllInstancesDown scheduled event setting creation. */\n allInstancesDown?: AllInstancesDown;\n}\n\n/** Specifies Redeploy related Scheduled Event related configurations. */\nexport interface UserInitiatedRedeploy {\n /** Specifies Redeploy Scheduled Event related configurations. */\n automaticallyApprove?: boolean;\n}\n\n/** Specifies Reboot related Scheduled Event related configurations. */\nexport interface UserInitiatedReboot {\n /** Specifies Reboot Scheduled Event related configurations. */\n automaticallyApprove?: boolean;\n}\n\nexport interface ScheduledEventsAdditionalPublishingTargets {\n /** The configuration parameters used while creating eventGridAndResourceGraph Scheduled Event setting. */\n eventGridAndResourceGraph?: EventGridAndResourceGraph;\n}\n\n/** Specifies eventGridAndResourceGraph related Scheduled Event related configurations. */\nexport interface EventGridAndResourceGraph {\n /** Specifies if event grid and resource graph is enabled for Scheduled event related configurations. */\n enable?: boolean;\n /** Specifies the api-version to determine which Scheduled Events configuration schema version will be delivered. */\n scheduledEventsApiVersion?: string;\n}\n\n/** Specifies if Scheduled Events should be auto-approved when all instances are down. */\nexport interface AllInstancesDown {\n /**\n * Specifies if Scheduled Events should be auto-approved when all instances are down.\n * its default value is true\n */\n automaticallyApprove?: boolean;\n}\n\n/** Describes the Availability Set properties related to migration to Flexible Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetMigrationInfo {\n /**\n * Indicates the target Virtual Machine ScaleSet properties upon triggering a seamless migration without downtime of the VMs via the ConvertToVirtualMachineScaleSet API.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly defaultVirtualMachineScaleSetInfo?: DefaultVirtualMachineScaleSetInfo;\n /**\n * Specifies the Virtual Machine Scale Set that the Availability Set is migrated to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly migrateToVirtualMachineScaleSet?: SubResource;\n}\n\n/** Indicates the target Virtual Machine ScaleSet properties upon triggering a seamless migration without downtime of the VMs via the ConvertToVirtualMachineScaleSet API. */\nexport interface DefaultVirtualMachineScaleSetInfo {\n /**\n * Indicates if the the maximum capacity of the default migrated Virtual Machine Scale Set after its migration will be constrained to a limited number of VMs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly constrainedMaximumCapacity?: boolean;\n /**\n * The default Virtual Machine ScaleSet Uri that the Availability Set will be moved to upon triggering a seamless migration via the ConvertToVirtualMachineScaleSet API.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly defaultVirtualMachineScaleSet?: SubResource;\n}\n\n/** Describes a virtual machine scale set sku. NOTE: If the new VM SKU is not supported on the hardware the scale set is currently on, you need to deallocate the VMs in the scale set before you modify the SKU name. */\nexport interface Sku {\n /** The sku name. */\n name?: string;\n /** Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of virtual machines in the scale set. */\n capacity?: number;\n}\n\n/** Common fields that are returned in the response for all Azure Resource Manager resources */\nexport interface Resource {\n /**\n * Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * The name of the resource\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The type of the resource. E.g. \"Microsoft.Compute/virtualMachines\" or \"Microsoft.Storage/storageAccounts\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Azure Resource Manager metadata containing createdBy and modifiedBy information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly systemData?: SystemData;\n}\n\n/** Metadata pertaining to creation and last modification of the resource. */\nexport interface SystemData {\n /** The identity that created the resource. */\n createdBy?: string;\n /** The type of identity that created the resource. */\n createdByType?: CreatedByType;\n /** The timestamp of resource creation (UTC). */\n createdAt?: Date;\n /** The identity that last modified the resource. */\n lastModifiedBy?: string;\n /** The type of identity that last modified the resource. */\n lastModifiedByType?: CreatedByType;\n /** The timestamp of resource last modification (UTC) */\n lastModifiedAt?: Date;\n}\n\n/** The List capacity reservation group with resource group response. */\nexport interface CapacityReservationGroupListResult {\n /** The list of capacity reservation groups. */\n value: CapacityReservationGroup[];\n /** The URI to fetch the next page of capacity reservation groups. Call ListNext() with this URI to fetch the next page of capacity reservation groups. */\n nextLink?: string;\n}\n\nexport interface SubResourceReadOnly {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n}\n\nexport interface CapacityReservationGroupInstanceView {\n /**\n * List of instance view of the capacity reservations under the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacityReservations?: CapacityReservationInstanceViewWithName[];\n /**\n * List of the subscriptions that the capacity reservation group is shared with. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sharedSubscriptionIds?: SubResourceReadOnly[];\n}\n\n/** The instance view of a capacity reservation that provides as snapshot of the runtime properties of the capacity reservation that is managed by the platform and can change outside of control plane operations. */\nexport interface CapacityReservationInstanceView {\n /** Unutilized capacity of the capacity reservation. */\n utilizationInfo?: CapacityReservationUtilization;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** Represents the capacity reservation utilization in terms of resources allocated. */\nexport interface CapacityReservationUtilization {\n /**\n * The value provides the current capacity of the VM size which was reserved successfully and for which the customer is getting billed. Minimum api-version: 2022-08-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly currentCapacity?: number;\n /**\n * A list of all virtual machines resource ids allocated against the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAllocated?: SubResourceReadOnly[];\n}\n\nexport interface ResourceSharingProfile {\n /** Specifies an array of subscription resource IDs that capacity reservation group is shared with. Block Capacity Reservations does not support sharing across subscriptions. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details. */\n subscriptionIds?: SubResource[];\n}\n\n/** The List Dedicated Host Group with resource group response. */\nexport interface DedicatedHostGroupListResult {\n /** The list of dedicated host groups. */\n value: DedicatedHostGroup[];\n /** The URI to fetch the next page of Dedicated Host Groups. Call ListNext() with this URI to fetch the next page of Dedicated Host Groups. */\n nextLink?: string;\n}\n\nexport interface DedicatedHostGroupInstanceView {\n /** List of instance view of the dedicated hosts under the dedicated host group. */\n hosts?: DedicatedHostInstanceViewWithName[];\n}\n\n/** The instance view of a dedicated host. */\nexport interface DedicatedHostInstanceView {\n /**\n * Specifies the unique id of the dedicated physical machine on which the dedicated host resides.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assetId?: string;\n /** Unutilized capacity of the dedicated host. */\n availableCapacity?: DedicatedHostAvailableCapacity;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** Dedicated host unutilized capacity. */\nexport interface DedicatedHostAvailableCapacity {\n /** The unutilized capacity of the dedicated host represented in terms of each VM size that is allowed to be deployed to the dedicated host. */\n allocatableVMs?: DedicatedHostAllocatableVM[];\n}\n\n/** Represents the dedicated host unutilized capacity in terms of a specific VM size. */\nexport interface DedicatedHostAllocatableVM {\n /** VM size in terms of which the unutilized capacity is represented. */\n vmSize?: string;\n /** Maximum number of VMs of size vmSize that can fit in the dedicated host's remaining capacity. */\n count?: number;\n}\n\n/** Enables or disables a capability on the dedicated host group. Minimum api-version: 2022-03-01. */\nexport interface DedicatedHostGroupPropertiesAdditionalCapabilities {\n /** The flag that enables or disables a capability to have UltraSSD Enabled Virtual Machines on Dedicated Hosts of the Dedicated Host Group. For the Virtual Machines to be UltraSSD Enabled, UltraSSDEnabled flag for the resource needs to be set true as well. The value is defaulted to 'false' when not provided. Please refer to https://docs.microsoft.com/en-us/azure/virtual-machines/disks-enable-ultra-ssd for more details on Ultra SSD feature. **Note:** The ultraSSDEnabled setting can only be enabled for Host Groups that are created as zonal. Minimum api-version: 2022-03-01. */\n ultraSSDEnabled?: boolean;\n}\n\n/** The List Image operation response. */\nexport interface ImageListResult {\n /** The list of Images */\n value: Image[];\n /** The uri to fetch the next page of Images. Call ListNext() with this to fetch the next page of Images. */\n nextLink?: string;\n}\n\n/** Describes a storage profile. */\nexport interface ImageStorageProfile {\n /** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: ImageOSDisk;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: ImageDataDisk[];\n /** Specifies whether an image is zone resilient or not. Default is false. Zone resilient images can be created only in regions that provide Zone Redundant Storage (ZRS). */\n zoneResilient?: boolean;\n}\n\n/** Describes a image disk. */\nexport interface ImageDisk {\n /** The snapshot. */\n snapshot?: SubResource;\n /** The managedDisk. */\n managedDisk?: SubResource;\n /** The Virtual Hard Disk. */\n blobUri?: string;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The default values are: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies the size of empty data disks in gigabytes. This element can be used to overwrite the name of the disk in a virtual machine image. This value cannot be larger than 1023 GB. */\n diskSizeGB?: number;\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?: StorageAccountTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed image disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n}\n\n/** The complex type of the extended location. */\nexport interface ExtendedLocation {\n /** The name of the extended location. */\n name?: string;\n /** The type of the extended location. */\n type?: ExtendedLocationTypes;\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface PurchasePlan {\n /** The publisher ID. */\n publisher: string;\n /** The plan ID. */\n name: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n}\n\n/** Contains the os disk image information. */\nexport interface OSDiskImage {\n /** The operating system of the osDiskImage. */\n operatingSystem: OperatingSystemTypes;\n}\n\n/** Contains the data disk images information. */\nexport interface DataDiskImage {\n /**\n * Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lun?: number;\n}\n\n/** Describes automatic OS upgrade properties on the image. */\nexport interface AutomaticOSUpgradeProperties {\n /** Specifies whether automatic OS upgrade is supported on the image. */\n automaticOSUpgradeSupported: boolean;\n}\n\n/** Specifies the disallowed configuration for a virtual machine image. */\nexport interface DisallowedConfiguration {\n /** VM disk types which are disallowed. */\n vmDiskType?: VmDiskTypes;\n}\n\n/** Specifies additional capabilities supported by the image */\nexport interface VirtualMachineImageFeature {\n /** The name of the feature. */\n name?: string;\n /** The corresponding value for the feature. */\n value?: string;\n}\n\n/** Describes image deprecation status properties on the image. */\nexport interface ImageDeprecationStatus {\n /** Describes the state of the image. */\n imageState?: ImageState;\n /** The time, in future, at which this image will be marked as deprecated. This scheduled time is chosen by the Publisher. */\n scheduledDeprecationTime?: Date;\n /** Describes the alternative option specified by the Publisher for this image when this image is deprecated. */\n alternativeOption?: AlternativeOption;\n}\n\n/** Describes the alternative option specified by the Publisher for this image when this image is deprecated. */\nexport interface AlternativeOption {\n /** Describes the type of the alternative option. */\n type?: AlternativeType;\n /** Indicates the alternative option value specified by the Publisher. This is the Offer name when the type is Offer or the Plan name when the type is Plan. */\n value?: string;\n}\n\n/** The List VmImages in EdgeZone operation response. */\nexport interface VmImagesInEdgeZoneListResult {\n /** The list of VMImages in EdgeZone */\n value?: VirtualMachineImageResource[];\n /** The URI to fetch the next page of VMImages in EdgeZone. Call ListNext() with this URI to fetch the next page of VmImages. */\n nextLink?: string;\n}\n\n/** Api input base class for LogAnalytics Api. */\nexport interface LogAnalyticsInputBase {\n /** SAS Uri of the logging blob container to which LogAnalytics Api writes output logs to. */\n blobContainerSasUri: string;\n /** From time of the query */\n fromTime: Date;\n /** To time of the query */\n toTime: Date;\n /** Group query result by Throttle Policy applied. */\n groupByThrottlePolicy?: boolean;\n /** Group query result by Operation Name. */\n groupByOperationName?: boolean;\n /** Group query result by Resource Name. */\n groupByResourceName?: boolean;\n /** Group query result by Client Application ID. */\n groupByClientApplicationId?: boolean;\n /** Group query result by User Agent. */\n groupByUserAgent?: boolean;\n}\n\n/** LogAnalytics operation status response */\nexport interface LogAnalyticsOperationResult {\n /**\n * LogAnalyticsOutput\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly properties?: LogAnalyticsOutput;\n}\n\n/** LogAnalytics output properties */\nexport interface LogAnalyticsOutput {\n /**\n * Output file Uri path to blob container.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly output?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface RunCommandListResult {\n /** The list of virtual machine run commands. */\n value: RunCommandDocumentBase[];\n /** The uri to fetch the next page of run commands. Call ListNext() with this to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Describes the properties of a Run Command metadata. */\nexport interface RunCommandDocumentBase {\n /** The VM run command schema. */\n schema: string;\n /** The VM run command id. */\n id: string;\n /** The Operating System type. */\n osType: OperatingSystemTypes;\n /** The VM run command label. */\n label: string;\n /** The VM run command description. */\n description: string;\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandParameterDefinition {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter type. */\n type: string;\n /** The run command parameter default value. */\n defaultValue?: string;\n /** The run command parameter required. */\n required?: boolean;\n}\n\n/** The List Usages operation response. */\nexport interface ListUsagesResult {\n /** The list of compute resource usages. */\n value: Usage[];\n /** The URI to fetch the next page of compute resource usage information. Call ListNext() with this to fetch the next page of compute resource usage information. */\n nextLink?: string;\n}\n\n/** Describes Compute Resource Usage. */\nexport interface Usage {\n /** An enum describing the unit of usage measurement. */\n unit: \"Count\";\n /** The current usage of the resource. */\n currentValue: number;\n /** The maximum permitted usage of the resource. */\n limit: number;\n /** The name of the type of usage. */\n name: UsageName;\n}\n\n/** The Usage Names. */\nexport interface UsageName {\n /** The name of the resource. */\n value?: string;\n /** The localized name of the resource. */\n localizedValue?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListResult {\n /** The list of virtual machine scale sets. */\n value: VirtualMachineScaleSet[];\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of VMSS. */\n nextLink?: string;\n}\n\n/** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\nexport interface Plan {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product?: string;\n /** The promotion code. */\n promotionCode?: string;\n}\n\n/** Describes an upgrade policy - automatic, manual, or rolling. */\nexport interface UpgradePolicy {\n /** Specifies the mode of an upgrade to virtual machines in the scale set.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of updates to virtual machines in the scale set. You do this by using the manualUpgrade action.<br /><br /> **Automatic** - All virtual machines in the scale set are automatically updated at the same time. */\n mode?: UpgradeMode;\n /** The configuration parameters used while performing a rolling upgrade. */\n rollingUpgradePolicy?: RollingUpgradePolicy;\n /** Configuration parameters used for performing automatic OS Upgrade. */\n automaticOSUpgradePolicy?: AutomaticOSUpgradePolicy;\n}\n\n/** The configuration parameters used while performing a rolling upgrade. */\nexport interface RollingUpgradePolicy {\n /** The maximum percent of total virtual machine instances that will be upgraded simultaneously by the rolling upgrade in one batch. As this is a maximum, unhealthy instances in previous or future batches can cause the percentage of instances in a batch to decrease to ensure higher reliability. The default value for this parameter is 20%. */\n maxBatchInstancePercent?: number;\n /** The maximum percentage of the total virtual machine instances in the scale set that can be simultaneously unhealthy, either as a result of being upgraded, or by being found in an unhealthy state by the virtual machine health checks before the rolling upgrade aborts. This constraint will be checked prior to starting any batch. The default value for this parameter is 20%. */\n maxUnhealthyInstancePercent?: number;\n /** The maximum percentage of upgraded virtual machine instances that can be found to be in an unhealthy state. This check will happen after each batch is upgraded. If this percentage is ever exceeded, the rolling update aborts. The default value for this parameter is 20%. */\n maxUnhealthyUpgradedInstancePercent?: number;\n /** The wait time between completing the update for all virtual machines in one batch and starting the next batch. The time duration should be specified in ISO 8601 format. The default value is 0 seconds (PT0S). */\n pauseTimeBetweenBatches?: string;\n /** Allow VMSS to ignore AZ boundaries when constructing upgrade batches. Take into consideration the Update Domain and maxBatchInstancePercent to determine the batch size. */\n enableCrossZoneUpgrade?: boolean;\n /** Upgrade all unhealthy instances in a scale set before any healthy instances. */\n prioritizeUnhealthyInstances?: boolean;\n /** Rollback failed instances to previous model if the Rolling Upgrade policy is violated. */\n rollbackFailedInstancesOnPolicyBreach?: boolean;\n /** Create new virtual machines to upgrade the scale set, rather than updating the existing virtual machines. Existing virtual machines will be deleted once the new virtual machines are created for each batch. */\n maxSurge?: boolean;\n}\n\n/** The configuration parameters used for performing automatic OS upgrade. */\nexport interface AutomaticOSUpgradePolicy {\n /** Indicates whether OS upgrades should automatically be applied to scale set instances in a rolling fashion when a newer version of the OS image becomes available. Default value is false. If this is set to true for Windows based scale sets, [enableAutomaticUpdates](https://docs.microsoft.com/dotnet/api/microsoft.azure.management.compute.models.windowsconfiguration.enableautomaticupdates?view=azure-dotnet) is automatically set to false and cannot be set to true. */\n enableAutomaticOSUpgrade?: boolean;\n /** Whether OS image rollback feature should be disabled. Default value is false. */\n disableAutomaticRollback?: boolean;\n /** Indicates whether rolling upgrade policy should be used during Auto OS Upgrade. Default value is false. Auto OS Upgrade will fallback to the default policy if no policy is defined on the VMSS. */\n useRollingUpgradePolicy?: boolean;\n /** Indicates whether Auto OS Upgrade should undergo deferral. Deferred OS upgrades will send advanced notifications on a per-VM basis that an OS upgrade from rolling upgrades is incoming, via the IMDS tag 'Platform.PendingOSUpgrade'. The upgrade then defers until the upgrade is approved via an ApproveRollingUpgrade call. */\n osRollingUpgradeDeferral?: boolean;\n}\n\n/** Specifies the configuration parameters for automatic repairs on the virtual machine scale set. */\nexport interface AutomaticRepairsPolicy {\n /** Specifies whether automatic repairs should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n /** The amount of time for which automatic repairs are suspended due to a state change on VM. The grace time starts after the state change has completed. This helps avoid premature or accidental repairs. The time duration should be specified in ISO 8601 format. The minimum allowed grace period is 10 minutes (PT10M), which is also the default value. The maximum allowed grace period is 90 minutes (PT90M). */\n gracePeriod?: string;\n /** Type of repair action (replace, restart, reimage) that will be used for repairing unhealthy virtual machines in the scale set. Default value is replace. */\n repairAction?: RepairAction;\n}\n\n/** Describes a virtual machine scale set virtual machine profile. */\nexport interface VirtualMachineScaleSetVMProfile {\n /** Specifies the operating system settings for the virtual machines in the scale set. */\n osProfile?: VirtualMachineScaleSetOSProfile;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: VirtualMachineScaleSetStorageProfile;\n /** Specifies properties of the network interfaces of the virtual machines in the scale set. */\n networkProfile?: VirtualMachineScaleSetNetworkProfile;\n /** Specifies the Security related profile settings for the virtual machines in the scale set. */\n securityProfile?: SecurityProfile;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies a collection of settings for extensions installed on virtual machines in the scale set. */\n extensionProfile?: VirtualMachineScaleSetExtensionProfile;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies the priority for the virtual machines in the scale set. Minimum api-version: 2017-10-30-preview. */\n priority?: VirtualMachinePriorityTypes;\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: VirtualMachineEvictionPolicyTypes;\n /** Specifies the billing related details of a Azure Spot VMSS. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the virtual machines in the scale set, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01. */\n userData?: string;\n /** Specifies the capacity reservation related details of a scale set. Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfile;\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n applicationProfile?: ApplicationProfile;\n /** Specifies the hardware profile related details of a scale set. Minimum api-version: 2021-11-01. */\n hardwareProfile?: VirtualMachineScaleSetHardwareProfile;\n /** Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version. Minimum api-version: 2022-11-01 */\n serviceArtifactReference?: ServiceArtifactReference;\n /** Specifies the security posture to be used in the scale set. Minimum api-version: 2023-03-01 */\n securityPostureReference?: SecurityPostureReference;\n /**\n * Specifies the time in which this VM profile for the Virtual Machine Scale Set was created. This value will be added to VMSS Flex VM tags when creating/updating the VMSS VM Profile. Minimum API version for this property is 2023-09-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Describes a virtual machine scale set OS profile. */\nexport interface VirtualMachineScaleSetOSProfile {\n /** Specifies the computer name prefix for all of the virtual machines in the scale set. Computer name prefixes must be 1 to 15 characters long. */\n computerNamePrefix?: string;\n /** Specifies the name of the administrator account. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters */\n adminUsername?: string;\n /**\n * Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)\n * This value contains a credential. Consider obscuring before showing to users\n */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. For using cloud-init for your VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init) */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfiguration;\n /** Specifies the Linux operating system settings on the virtual machine. For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfiguration;\n /** Specifies set of certificates that should be installed onto the virtual machines in the scale set. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: VaultSecretGroup[];\n /** Specifies whether extension operations should be allowed on the virtual machine scale set. This may only be set to False when no extensions are present on the virtual machine scale set. */\n allowExtensionOperations?: boolean;\n /** Optional property which must either be set to True or omitted. */\n requireGuestProvisionSignal?: boolean;\n}\n\n/** Specifies Windows operating system settings on the virtual machine. */\nexport interface WindowsConfiguration {\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. When this property is not specified in the request body, it is set to true by default. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** Indicates whether Automatic Updates is enabled for the Windows virtual machine. Default value is true. For virtual machine scale sets, this property can be updated and updates will take effect on OS reprovisioning. */\n enableAutomaticUpdates?: boolean;\n /** Specifies the time zone of the virtual machine. e.g. \"Pacific Standard Time\". Possible values can be [TimeZoneInfo.Id](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.id?#System_TimeZoneInfo_Id) value from time zones returned by [TimeZoneInfo.GetSystemTimeZones](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.getsystemtimezones). */\n timeZone?: string;\n /** Specifies additional base-64 encoded XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. */\n additionalUnattendContent?: AdditionalUnattendContent[];\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Windows. */\n patchSettings?: PatchSettings;\n /** Specifies the Windows Remote Management listeners. This enables remote Windows PowerShell. */\n winRM?: WinRMConfiguration;\n /**\n * Indicates whether VMAgent Platform Updates are enabled for the Windows Virtual Machine.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** Specifies additional XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. Contents are defined by setting name, component name, and the pass in which the content is applied. */\nexport interface AdditionalUnattendContent {\n /** The pass name. Currently, the only allowable value is OobeSystem. */\n passName?: \"OobeSystem\";\n /** The component name. Currently, the only allowable value is Microsoft-Windows-Shell-Setup. */\n componentName?: \"Microsoft-Windows-Shell-Setup\";\n /** Specifies the name of the setting to which the content applies. Possible values are: FirstLogonCommands and AutoLogon. */\n settingName?: SettingNames;\n /** Specifies the XML formatted content that is added to the unattend.xml file for the specified path and component. The XML must be less than 4KB and must include the root element for the setting or feature that is being inserted. */\n content?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Windows. */\nexport interface PatchSettings {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of patches to a virtual machine. You do this by applying patches manually inside the VM. In this mode, automatic updates are disabled; the property WindowsConfiguration.enableAutomaticUpdates must be false<br /><br /> **AutomaticByOS** - The virtual machine will automatically be updated by the OS. The property WindowsConfiguration.enableAutomaticUpdates must be true. <br /><br /> **AutomaticByPlatform** - the virtual machine will automatically updated by the platform. The properties provisionVMAgent and WindowsConfiguration.enableAutomaticUpdates must be true */\n patchMode?: WindowsVMGuestPatchMode;\n /** Enables customers to patch their Azure VMs without requiring a reboot. For enableHotpatching, the 'provisionVMAgent' must be set to true and 'patchMode' must be set to 'AutomaticByPlatform'. */\n enableHotpatching?: boolean;\n /** Specifies the mode of VM Guest patch assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine.<br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: WindowsPatchAssessmentMode;\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Windows. */\n automaticByPlatformSettings?: WindowsVMGuestPatchAutomaticByPlatformSettings;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Windows patch settings. */\nexport interface WindowsVMGuestPatchAutomaticByPlatformSettings {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: WindowsVMGuestPatchAutomaticByPlatformRebootSetting;\n /** Enables customer to schedule patching without accidental upgrades */\n bypassPlatformSafetyChecksOnUserSchedule?: boolean;\n}\n\n/** Describes Windows Remote Management configuration of the VM */\nexport interface WinRMConfiguration {\n /** The list of Windows Remote Management listeners */\n listeners?: WinRMListener[];\n}\n\n/** Describes Protocol and thumbprint of Windows Remote Management listener */\nexport interface WinRMListener {\n /** Specifies the protocol of WinRM listener. Possible values are: **http,** **https.** */\n protocol?: ProtocolTypes;\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n}\n\n/** Specifies the Linux operating system settings on the virtual machine. For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\nexport interface LinuxConfiguration {\n /** Specifies whether password authentication should be disabled. */\n disablePasswordAuthentication?: boolean;\n /** Specifies the ssh key configuration for a Linux OS. */\n ssh?: SshConfiguration;\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. When this property is not specified in the request body, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Linux. */\n patchSettings?: LinuxPatchSettings;\n /** Indicates whether VMAgent Platform Updates is enabled for the Linux virtual machine. Default value is false. */\n enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** SSH configuration for Linux based VMs running on Azure */\nexport interface SshConfiguration {\n /** The list of SSH public keys used to authenticate with linux based VMs. */\n publicKeys?: SshPublicKey[];\n}\n\n/** Contains information about SSH certificate public key and the path on the Linux VM where the public key is placed. */\nexport interface SshPublicKey {\n /** Specifies the full path on the created VM where ssh public key is stored. If the file already exists, the specified key is appended to the file. Example: /home/user/.ssh/authorized_keys */\n path?: string;\n /** SSH public key certificate used to authenticate with the VM through ssh. The key needs to be at least 2048-bit and in ssh-rsa format. For creating ssh keys, see [Create SSH keys on Linux and Mac for Linux VMs in Azure]https://docs.microsoft.com/azure/virtual-machines/linux/create-ssh-keys-detailed). */\n keyData?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Linux. */\nexport interface LinuxPatchSettings {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - The virtual machine's default patching configuration is used. <br /><br /> **AutomaticByPlatform** - The virtual machine will be automatically updated by the platform. The property provisionVMAgent must be true */\n patchMode?: LinuxVMGuestPatchMode;\n /** Specifies the mode of VM Guest Patch Assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine. <br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: LinuxPatchAssessmentMode;\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Linux. */\n automaticByPlatformSettings?: LinuxVMGuestPatchAutomaticByPlatformSettings;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Linux patch settings. */\nexport interface LinuxVMGuestPatchAutomaticByPlatformSettings {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: LinuxVMGuestPatchAutomaticByPlatformRebootSetting;\n /** Enables customer to schedule patching without accidental upgrades */\n bypassPlatformSafetyChecksOnUserSchedule?: boolean;\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface VaultSecretGroup {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResource;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: VaultCertificate[];\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the VM. */\nexport interface VaultCertificate {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be It is the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n /** For Windows VMs, specifies the certificate store on the Virtual Machine to which the certificate should be added. The specified certificate store is implicitly in the LocalMachine account. For Linux VMs, the certificate file is placed under the /var/lib/waagent directory, with the file name <UppercaseThumbprint>.crt for the X509 certificate file and <UppercaseThumbprint>.prv for private key. Both of these files are .pem formatted. */\n certificateStore?: string;\n}\n\n/** Describes a virtual machine scale set storage profile. */\nexport interface VirtualMachineScaleSetStorageProfile {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReference;\n /** Specifies information about the operating system disk used by the virtual machines in the scale set. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: VirtualMachineScaleSetOSDisk;\n /** Specifies the parameters that are used to add data disks to the virtual machines in the scale set. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: VirtualMachineScaleSetDataDisk[];\n /** Specifies the disk controller type configured for the virtual machines in the scale set. Minimum api-version: 2022-08-01 */\n diskControllerType?: DiskControllerTypes;\n}\n\n/** Describes a virtual machine scale set operating system disk. */\nexport interface VirtualMachineScaleSetOSDisk {\n /** The disk name. */\n name?: string;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The default values are: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machines in the scale set should be created. The only allowed value is: **FromImage.** This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the ephemeral disk Settings for the operating system disk used by the virtual machine scale set. */\n diffDiskSettings?: DiffDiskSettings;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property 'diskSizeGB' is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** Specifies information about the unmanaged user image to base the scale set on. */\n image?: VirtualHardDisk;\n /** Specifies the container urls that are used to store operating system disks for the scale set. */\n vhdContainers?: string[];\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParameters;\n /** Specifies whether OS Disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only). <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the OS disk is retained after VMSS Flex VM is deleted. <br><br> The default value is set to **Delete**. For an Ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for Ephemeral OS Disk. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes the parameters of ephemeral disk settings that can be specified for operating system disk. **Note:** The ephemeral disk settings can only be specified for managed disk. */\nexport interface DiffDiskSettings {\n /** Specifies the ephemeral disk settings for operating system disk. */\n option?: DiffDiskOptions;\n /** Specifies the ephemeral disk placement for operating system disk. Possible values are: **CacheDisk,** **ResourceDisk,** **NvmeDisk.** The defaulting behavior is: **CacheDisk** if one is configured for the VM size otherwise **ResourceDisk** or **NvmeDisk** is used. Refer to the VM size documentation for Windows VM at https://docs.microsoft.com/azure/virtual-machines/windows/sizes and Linux VM at https://docs.microsoft.com/azure/virtual-machines/linux/sizes to check which VM sizes exposes a cache disk. Minimum api-version for NvmeDisk: 2024-03-01. */\n placement?: DiffDiskPlacement;\n}\n\n/** Describes the uri of a disk. */\nexport interface VirtualHardDisk {\n /** Specifies the virtual hard disk's uri. */\n uri?: string;\n}\n\n/** Describes the parameters of a ScaleSet managed disk. */\nexport interface VirtualMachineScaleSetManagedDiskParameters {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?: StorageAccountTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfile;\n}\n\n/** Specifies the security profile settings for the managed disk. **Note:** It can only be set for Confidential VMs. */\nexport interface VMDiskSecurityProfile {\n /** Specifies the EncryptionType of the managed disk. It is set to DiskWithVMGuestState for encryption of the managed disk along with VMGuestState blob, VMGuestStateOnly for encryption of just the VMGuestState blob, and NonPersistedTPM for not persisting firmware state in the VMGuestState blob.. **Note:** It can be set for only Confidential VMs. */\n securityEncryptionType?: SecurityEncryptionTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk that is used for Customer Managed Key encrypted ConfidentialVM OS Disk and VMGuest blob. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n}\n\n/** Describes a virtual machine scale set data disk. */\nexport interface VirtualMachineScaleSetDataDisk {\n /** The disk name. */\n name?: string;\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The default values are: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** The create option. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParameters;\n /** Specifies the Read-Write IOPS for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskIopsReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskMBpsReadWrite?: number;\n /** Specifies whether data disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only).<br><br> Possible values: <br><br> **Delete** If this value is used, the data disk is deleted when the VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the data disk is retained after VMSS Flex VM is deleted.<br><br> The default value is set to **Delete**. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes a virtual machine scale set network profile. */\nexport interface VirtualMachineScaleSetNetworkProfile {\n /** A reference to a load balancer probe used to determine the health of an instance in the virtual machine scale set. The reference will be in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'. */\n healthProbe?: ApiEntityReference;\n /** The list of network configurations. */\n networkInterfaceConfigurations?: VirtualMachineScaleSetNetworkConfiguration[];\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations for Virtual Machine Scale Set with orchestration mode 'Flexible' */\n networkApiVersion?: NetworkApiVersion;\n}\n\n/** The API entity reference. */\nexport interface ApiEntityReference {\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/... */\n id?: string;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetNetworkConfiguration {\n /** The network configuration name. */\n name: string;\n /** Resource tags applied to the networkInterface address created by this NetworkInterfaceConfiguration */\n tags?: { [propertyName: string]: string };\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResource;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettings;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations?: VirtualMachineScaleSetIPConfiguration[];\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** Specifies whether the Auxiliary mode is enabled for the Network Interface resource. */\n auxiliaryMode?: NetworkInterfaceAuxiliaryMode;\n /** Specifies whether the Auxiliary sku is enabled for the Network Interface resource. */\n auxiliarySku?: NetworkInterfaceAuxiliarySku;\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetNetworkConfigurationDnsSettings {\n /** List of DNS servers IP addresses */\n dnsServers?: string[];\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. */\nexport interface VirtualMachineScaleSetIPConfiguration {\n /** The IP configuration name. */\n name: string;\n /** Specifies the identifier of the subnet. */\n subnet?: ApiEntityReference;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetPublicIPAddressConfiguration;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: IPVersion;\n /** Specifies an array of references to backend address pools of application gateways. A scale set can reference backend address pools of multiple application gateways. Multiple scale sets cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: SubResource[];\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: SubResource[];\n /** Specifies an array of references to backend address pools of load balancers. A scale set can reference backend address pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerBackendAddressPools?: SubResource[];\n /** Specifies an array of references to inbound Nat pools of the load balancers. A scale set can reference inbound nat pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerInboundNatPools?: SubResource[];\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetPublicIPAddressConfiguration {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSku;\n /** Resource tags applied to the publicIP address created by this PublicIPAddressConfiguration */\n tags?: { [propertyName: string]: string };\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettings;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: VirtualMachineScaleSetIpTag[];\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResource;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: IPVersion;\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: DeleteOptions;\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettings {\n /** The Domain name label.The concatenation of the domain name label and vm index will be the domain name labels of the PublicIPAddress resources that will be created */\n domainNameLabel: string;\n /** The Domain name label scope.The concatenation of the hashed domain name label that generated according to the policy from domain name label scope and vm index will be the domain name labels of the PublicIPAddress resources that will be created */\n domainNameLabelScope?: DomainNameLabelScopeTypes;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineScaleSetIpTag {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\nexport interface PublicIPAddressSku {\n /** Specify public IP sku name */\n name?: PublicIPAddressSkuName;\n /** Specify public IP sku tier */\n tier?: PublicIPAddressSkuTier;\n}\n\n/** Specifies the Security profile settings for the virtual machine or virtual machine scale set. */\nexport interface SecurityProfile {\n /** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. Minimum api-version: 2020-12-01. */\n uefiSettings?: UefiSettings;\n /** This property can be used by user in the request to enable or disable the Host Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the disks including Resource/Temp disk at host itself. The default behavior is: The Encryption at host will be disabled unless this property is set to true for the resource. */\n encryptionAtHost?: boolean;\n /** Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings. The default behavior is: UefiSettings will not be enabled unless this property is set. */\n securityType?: SecurityTypes;\n /** Specifies the Managed Identity used by ADE to get access token for keyvault operations. */\n encryptionIdentity?: EncryptionIdentity;\n /** Specifies ProxyAgent settings while creating the virtual machine. Minimum api-version: 2023-09-01. */\n proxyAgentSettings?: ProxyAgentSettings;\n}\n\n/** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. Minimum api-version: 2020-12-01. */\nexport interface UefiSettings {\n /** Specifies whether secure boot should be enabled on the virtual machine. Minimum api-version: 2020-12-01. */\n secureBootEnabled?: boolean;\n /** Specifies whether vTPM should be enabled on the virtual machine. Minimum api-version: 2020-12-01. */\n vTpmEnabled?: boolean;\n}\n\n/** Specifies the Managed Identity used by ADE to get access token for keyvault operations. */\nexport interface EncryptionIdentity {\n /** Specifies ARM Resource ID of one of the user identities associated with the VM. */\n userAssignedIdentityResourceId?: string;\n}\n\n/** Specifies ProxyAgent settings for the virtual machine or virtual machine scale set. Minimum api-version: 2023-09-01. */\nexport interface ProxyAgentSettings {\n /** Specifies whether ProxyAgent feature should be enabled on the virtual machine or virtual machine scale set. */\n enabled?: boolean;\n /** Specifies the mode that ProxyAgent will execute on. Warning: this property has been deprecated, please specify 'mode' under particular hostendpoint setting. */\n mode?: Mode;\n /** Increase the value of this property allows users to reset the key used for securing communication channel between guest and host. */\n keyIncarnationId?: number;\n /** Specifies the Wire Server endpoint settings while creating the virtual machine or virtual machine scale set. Minimum api-version: 2024-03-01. */\n wireServer?: HostEndpointSettings;\n /** Specifies the IMDS endpoint settings while creating the virtual machine or virtual machine scale set. Minimum api-version: 2024-03-01. */\n imds?: HostEndpointSettings;\n /** Specify whether to implicitly install the ProxyAgent Extension. This option is currently applicable only for Linux Os. */\n addProxyAgentExtension?: boolean;\n}\n\n/** Specifies particular host endpoint settings. */\nexport interface HostEndpointSettings {\n /** Specifies the execution mode. In Audit mode, the system acts as if it is enforcing the access control policy, including emitting access denial entries in the logs but it does not actually deny any requests to host endpoints. In Enforce mode, the system will enforce the access control and it is the recommended mode of operation. */\n mode?: Modes;\n /** Specifies the InVMAccessControlProfileVersion resource id in the format of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/inVMAccessControlProfiles/{profile}/versions/{version} */\n inVMAccessControlProfileReferenceId?: string;\n}\n\n/** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\nexport interface DiagnosticsProfile {\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. **NOTE**: If storageUri is being specified then ensure that the storage account is in the same region and subscription as the VM. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnostics;\n}\n\n/** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\nexport interface BootDiagnostics {\n /** Whether boot diagnostics should be enabled on the Virtual Machine. */\n enabled?: boolean;\n /** Uri of the storage account to use for placing the console output and screenshot. If storageUri is not specified while enabling boot diagnostics, managed storage will be used. */\n storageUri?: string;\n}\n\n/** Describes a virtual machine scale set extension profile. */\nexport interface VirtualMachineScaleSetExtensionProfile {\n /** The virtual machine scale set child extension resources. */\n extensions?: VirtualMachineScaleSetExtension[];\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). Minimum api-version: 2020-06-01. */\n extensionsTimeBudget?: string;\n}\n\n/** Describes a reference to Key Vault Secret */\nexport interface KeyVaultSecretReference {\n /** The URL referencing a secret in a Key Vault. */\n secretUrl: string;\n /** The relative URL of the Key Vault containing the secret. */\n sourceVault: SubResource;\n}\n\n/** Specifies the billing related details of a Azure Spot VM or VMSS. Minimum api-version: 2019-03-01. */\nexport interface BillingProfile {\n /** Specifies the maximum price you are willing to pay for a Azure Spot VM/VMSS. This price is in US Dollars. <br><br> This price will be compared with the current Azure Spot price for the VM size. Also, the prices are compared at the time of create/update of Azure Spot VM/VMSS and the operation will only succeed if the maxPrice is greater than the current Azure Spot price. <br><br> The maxPrice will also be used for evicting a Azure Spot VM/VMSS if the current Azure Spot price goes beyond the maxPrice after creation of VM/VMSS. <br><br> Possible values are: <br><br> - Any decimal value greater than zero. Example: 0.01538 <br><br> -1 – indicates default price to be up-to on-demand. <br><br> You can set the maxPrice to -1 to indicate that the Azure Spot VM/VMSS should not be evicted for price reasons. Also, the default max price is -1 if it is not provided by you. <br><br>Minimum api-version: 2019-03-01. */\n maxPrice?: number;\n}\n\nexport interface ScheduledEventsProfile {\n /** Specifies Terminate Scheduled Event related configurations. */\n terminateNotificationProfile?: TerminateNotificationProfile;\n /** Specifies OS Image Scheduled Event related configurations. */\n osImageNotificationProfile?: OSImageNotificationProfile;\n}\n\nexport interface TerminateNotificationProfile {\n /** Configurable length of time a Virtual Machine being deleted will have to potentially approve the Terminate Scheduled Event before the event is auto approved (timed out). The configuration must be specified in ISO 8601 format, the default value is 5 minutes (PT5M) */\n notBeforeTimeout?: string;\n /** Specifies whether the Terminate Scheduled event is enabled or disabled. */\n enable?: boolean;\n}\n\nexport interface OSImageNotificationProfile {\n /** Length of time a Virtual Machine being reimaged or having its OS upgraded will have to potentially approve the OS Image Scheduled Event before the event is auto approved (timed out). The configuration is specified in ISO 8601 format, and the value must be 15 minutes (PT15M) */\n notBeforeTimeout?: string;\n /** Specifies whether the OS Image Scheduled event is enabled or disabled. */\n enable?: boolean;\n}\n\n/** The parameters of a capacity reservation Profile. */\nexport interface CapacityReservationProfile {\n /** Specifies the capacity reservation group resource id that should be used for allocating the virtual machine or scaleset vm instances provided enough capacity has been reserved. Please refer to https://aka.ms/CapacityReservation for more details. */\n capacityReservationGroup?: SubResource;\n}\n\n/** Contains the list of gallery applications that should be made available to the VM/VMSS */\nexport interface ApplicationProfile {\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n galleryApplications?: VMGalleryApplication[];\n}\n\n/** Specifies the required information to reference a compute gallery application version */\nexport interface VMGalleryApplication {\n /** Optional, Specifies a passthrough value for more generic context. */\n tags?: string;\n /** Optional, Specifies the order in which the packages have to be installed */\n order?: number;\n /** Specifies the GalleryApplicationVersion resource id on the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/applications/{application}/versions/{version} */\n packageReferenceId: string;\n /** Optional, Specifies the uri to an azure blob that will replace the default configuration for the package if provided */\n configurationReference?: string;\n /** Optional, If true, any failure for any operation in the VmApplication will fail the deployment */\n treatFailureAsDeploymentFailure?: boolean;\n /** If set to true, when a new Gallery Application version is available in PIR/SIG, it will be automatically updated for the VM/VMSS */\n enableAutomaticUpgrade?: boolean;\n}\n\n/** Specifies the hardware settings for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetHardwareProfile {\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-11-01. Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizeProperties;\n}\n\n/** Specifies VM Size Property settings on the virtual machine. */\nexport interface VMSizeProperties {\n /** Specifies the number of vCPUs available for the VM. When this property is not specified in the request body the default behavior is to set it to the value of vCPUs available for that VM size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list). */\n vCPUsAvailable?: number;\n /** Specifies the vCPU to physical core ratio. When this property is not specified in the request body the default behavior is set to the value of vCPUsPerCore for the VM Size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list). **Setting this property to 1 also means that hyper-threading is disabled.** */\n vCPUsPerCore?: number;\n}\n\n/** Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version. Minimum api-version: 2022-11-01 */\nexport interface ServiceArtifactReference {\n /** The service artifact reference id in the form of /subscriptions/{subscriptionId}/resourceGroups/{resourceGroup}/providers/Microsoft.Compute/galleries/{galleryName}/serviceArtifacts/{serviceArtifactName}/vmArtifactsProfiles/{vmArtifactsProfilesName} */\n id?: string;\n}\n\n/** Specifies the security posture to be used in the scale set. Minimum api-version: 2023-03-01 */\nexport interface SecurityPostureReference {\n /** The security posture reference id in the form of /CommunityGalleries/{communityGalleryName}/securityPostures/{securityPostureName}/versions/{major.minor.patch}|latest */\n id: string;\n /** The list of virtual machine extension names to exclude when applying the security posture. */\n excludeExtensions?: string[];\n /** Whether the security posture can be overridden by the user. */\n isOverridable?: boolean;\n}\n\n/** Enables or disables a capability on the virtual machine or virtual machine scale set. */\nexport interface AdditionalCapabilities {\n /** The flag that enables or disables a capability to have one or more managed data disks with UltraSSD_LRS storage account type on the VM or VMSS. Managed disks with storage account type UltraSSD_LRS can be added to a virtual machine or virtual machine scale set only if this property is enabled. */\n ultraSSDEnabled?: boolean;\n /** The flag that enables or disables hibernation capability on the VM. */\n hibernationEnabled?: boolean;\n /** The flag enables the usage of FIPS 140-3 compliant cryptography on the protectedSettings of an extension. Learn more at: https://aka.ms/linuxagentfipssupport. */\n enableFips1403Encryption?: boolean;\n}\n\n/** Describes a scale-in policy for a virtual machine scale set. */\nexport interface ScaleInPolicy {\n /** The rules to be followed when scaling-in a virtual machine scale set. <br><br> Possible values are: <br><br> **Default** When a virtual machine scale set is scaled in, the scale set will first be balanced across zones if it is a zonal scale set. Then, it will be balanced across Fault Domains as far as possible. Within each Fault Domain, the virtual machines chosen for removal will be the newest ones that are not protected from scale-in. <br><br> **OldestVM** When a virtual machine scale set is being scaled-in, the oldest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the oldest virtual machines that are not protected will be chosen for removal. <br><br> **NewestVM** When a virtual machine scale set is being scaled-in, the newest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the newest virtual machines that are not protected will be chosen for removal. <br><br> */\n rules?: VirtualMachineScaleSetScaleInRules[];\n /** This property allows you to specify if virtual machines chosen for removal have to be force deleted when a virtual machine scale set is being scaled-in.(Feature in Preview) */\n forceDeletion?: boolean;\n /** This property allows you to prioritize the deletion of unhealthy and inactive VMs when a virtual machine scale set is being scaled-in.(Feature in Preview) */\n prioritizeUnhealthyVMs?: boolean;\n}\n\n/** Specifies the Spot-Try-Restore properties for the virtual machine scale set. With this property customer can enable or disable automatic restore of the evicted Spot VMSS VM instances opportunistically based on capacity availability and pricing constraint. */\nexport interface SpotRestorePolicy {\n /** Enables the Spot-Try-Restore feature where evicted VMSS SPOT instances will be tried to be restored opportunistically based on capacity availability and pricing constraints */\n enabled?: boolean;\n /** Timeout value expressed as an ISO 8601 time duration after which the platform will not try to restore the VMSS SPOT instances */\n restoreTimeout?: string;\n}\n\n/** Specifies the target splits for Spot and Regular priority VMs within a scale set with flexible orchestration mode. With this property the customer is able to specify the base number of regular priority VMs created as the VMSS flex instance scales out and the split between Spot and Regular priority VMs after this base target has been reached. */\nexport interface PriorityMixPolicy {\n /** The base number of regular priority VMs that will be created in this scale set as it scales out. */\n baseRegularPriorityCount?: number;\n /** The percentage of VM instances, after the base regular priority count has been reached, that are expected to use regular priority. */\n regularPriorityPercentageAboveBase?: number;\n}\n\n/** Describes an resiliency policy - AutomaticZoneRebalancingPolicy, ResilientVMCreationPolicy and/or ResilientVMDeletionPolicy. */\nexport interface ResiliencyPolicy {\n /** The configuration parameters used while performing resilient VM creation. */\n resilientVMCreationPolicy?: ResilientVMCreationPolicy;\n /** The configuration parameters used while performing resilient VM deletion. */\n resilientVMDeletionPolicy?: ResilientVMDeletionPolicy;\n /** The configuration parameters used while performing automatic AZ balancing. */\n automaticZoneRebalancingPolicy?: AutomaticZoneRebalancingPolicy;\n /** The configuration parameters used while performing zone allocation. */\n zoneAllocationPolicy?: ZoneAllocationPolicy;\n}\n\n/** The configuration parameters used while performing resilient VM creation. */\nexport interface ResilientVMCreationPolicy {\n /** Specifies whether resilient VM creation should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n}\n\n/** The configuration parameters used while performing resilient VM deletion. */\nexport interface ResilientVMDeletionPolicy {\n /** Specifies whether resilient VM deletion should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n}\n\n/** The configuration parameters used while performing automatic AZ balancing. */\nexport interface AutomaticZoneRebalancingPolicy {\n /** Specifies whether Automatic AZ Balancing should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n /** Type of rebalance strategy that will be used for rebalancing virtual machines in the scale set across availability zones. Default and only supported value for now is Recreate. */\n rebalanceStrategy?: RebalanceStrategy;\n /** Type of rebalance behavior that will be used for recreating virtual machines in the scale set across availability zones. Default and only supported value for now is CreateBeforeDelete. */\n rebalanceBehavior?: RebalanceBehavior;\n}\n\n/** The configuration parameters for zone allocation of a virtual machine scale set. */\nexport interface ZoneAllocationPolicy {\n /** The maximum number of availability zones to use if the ZonePlacementPolicy is 'Auto'. If not specified, all availability zones will be used. */\n maxZoneCount?: number;\n /** The configuration parameters used to limit the number of virtual machines per availability zone in the virtual machine scale set. */\n maxInstancePercentPerZonePolicy?: MaxInstancePercentPerZonePolicy;\n}\n\n/** The configuration parameters used to limit the number of virtual machines per availability zone in the virtual machine scale set. */\nexport interface MaxInstancePercentPerZonePolicy {\n /** Specifies whether maxInstancePercentPerZonePolicy should be enabled on the virtual machine scale set. */\n enabled?: boolean;\n /** Limit on the number of instances in each zone as a percentage of the total capacity of the virtual machine scale set. */\n value?: number;\n}\n\n/** Specifies the sku profile for the virtual machine scale set. With this property the customer is able to specify a list of VM sizes and an allocation strategy. */\nexport interface SkuProfile {\n /** Specifies the VM sizes for the virtual machine scale set. */\n vmSizes?: SkuProfileVMSize[];\n /** Specifies the allocation strategy for the virtual machine scale set based on which the VMs will be allocated. */\n allocationStrategy?: AllocationStrategy;\n}\n\n/** Specifies the VM Size. */\nexport interface SkuProfileVMSize {\n /** Specifies the name of the VM Size. */\n name?: string;\n /** Specifies the rank (a.k.a priority) associated with the VM Size. */\n rank?: number;\n}\n\n/** Identity for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetIdentity {\n /**\n * The principal id of virtual machine scale set identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The tenant id associated with the virtual machine scale set. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine scale set. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine scale set. */\n type?: ResourceIdentityType;\n /** The list of user identities associated with the virtual machine scale set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\nexport interface UserAssignedIdentitiesValue {\n /**\n * The principal id of user assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The client id of user assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly clientId?: string;\n}\n\n/** Describes the user-defined constraints for resource hardware placement. */\nexport interface Placement {\n /** Specifies the policy for resource's placement in availability zone. Possible values are: **Any** (used for Virtual Machines), **Auto** (used for Virtual Machine Scale Sets) - An availability zone will be automatically picked by system as part of resource creation. */\n zonePlacementPolicy?: ZonePlacementPolicyType;\n /** This property supplements the 'zonePlacementPolicy' property. If 'zonePlacementPolicy' is set to 'Any'/'Auto', availability zone selected by the system must be present in the list of availability zones passed with 'includeZones'. If 'includeZones' is not provided, all availability zones in region will be considered for selection. */\n includeZones?: string[];\n /** This property supplements the 'zonePlacementPolicy' property. If 'zonePlacementPolicy' is set to 'Any'/'Auto', availability zone selected by the system must not be present in the list of availability zones passed with 'excludeZones'. If 'excludeZones' is not provided, all availability zones in region will be considered for selection. */\n excludeZones?: string[];\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineListResult {\n /** The list of virtual machines. */\n value: VirtualMachine[];\n /** The URI to fetch the next page of VMs. Call ListNext() with this URI to fetch the next page of Virtual Machines. */\n nextLink?: string;\n}\n\n/** Specifies the hardware settings for the virtual machine. */\nexport interface HardwareProfile {\n /** Specifies the size of the virtual machine. The enum data type is currently deprecated and will be removed by December 23rd 2023. The recommended way to get the list of available sizes is using these APIs: [List all available virtual machine sizes in an availability set](https://docs.microsoft.com/rest/api/compute/availabilitysets/listavailablesizes), [List all available virtual machine sizes in a region]( https://docs.microsoft.com/rest/api/compute/resourceskus/list), [List all available virtual machine sizes for resizing](https://docs.microsoft.com/rest/api/compute/virtualmachines/listavailablesizes). For more information about virtual machine sizes, see [Sizes for virtual machines](https://docs.microsoft.com/azure/virtual-machines/sizes). The available VM sizes depend on region and availability set. */\n vmSize?: VirtualMachineSizeTypes;\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-07-01. This feature is still in preview mode and is not supported for VirtualMachineScaleSet. Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizeProperties;\n}\n\n/** Specifies the storage settings for the virtual machine disks. */\nexport interface StorageProfile {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReference;\n /** Specifies information about the operating system disk used by the virtual machine. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: OSDisk;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: DataDisk[];\n /** Specifies the disk controller type configured for the VM. **Note:** This property will be set to the default disk controller type if not specified provided virtual machine is being created with 'hyperVGeneration' set to V2 based on the capabilities of the operating system disk and VM size from the the specified minimum api version. You need to deallocate the VM before updating its disk controller type unless you are updating the VM size in the VM configuration which implicitly deallocates and reallocates the VM. Minimum api-version: 2022-08-01. */\n diskControllerType?: DiskControllerTypes;\n /** Specifies whether the regional disks should be aligned/moved to the VM zone. This is applicable only for VMs with placement property set. Please note that this change is irreversible. Minimum api-version: 2024-11-01. */\n alignRegionalDisksToVMZone?: boolean;\n}\n\n/** Specifies information about the operating system disk used by the virtual machine. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\nexport interface OSDisk {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** Specifies the encryption settings for the OS Disk. Minimum api-version: 2015-06-15. */\n encryptionSettings?: DiskEncryptionSettings;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDisk;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDisk;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The defaulting behavior is: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies the ephemeral Disk Settings for the operating system disk used by the virtual machine. */\n diffDiskSettings?: DiffDiskSettings;\n /** Specifies how the virtual machine disk should be created. Possible values are **Attach:** This value is used when you are using a specialized disk to create the virtual machine. **FromImage:** This value is used when you are using an image to create the virtual machine. If you are using a platform image, you should also use the imageReference element described above. If you are using a marketplace image, you should also use the plan element previously described. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property 'diskSizeGB' is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParameters;\n /** Specifies whether OS Disk should be deleted or detached upon VM deletion. Possible values are: **Delete.** If this value is used, the OS disk is deleted when VM is deleted. **Detach.** If this value is used, the os disk is retained after VM is deleted. The default value is set to **Detach**. For an ephemeral OS Disk, the default value is set to **Delete**. The user cannot change the delete option for an ephemeral OS Disk. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes a Encryption Settings for a Disk */\nexport interface DiskEncryptionSettings {\n /** Specifies the location of the disk encryption key, which is a Key Vault Secret. */\n diskEncryptionKey?: KeyVaultSecretReference;\n /** Specifies the location of the key encryption key in Key Vault. */\n keyEncryptionKey?: KeyVaultKeyReference;\n /** Specifies whether disk encryption should be enabled on the virtual machine. */\n enabled?: boolean;\n}\n\n/** Describes a reference to Key Vault Key */\nexport interface KeyVaultKeyReference {\n /** The URL referencing a key encryption key in Key Vault. */\n keyUrl: string;\n /** The relative URL of the Key Vault containing the key. */\n sourceVault: SubResource;\n}\n\n/** Describes a data disk. */\nexport interface DataDisk {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDisk;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDisk;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The defaulting behavior is: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machine disk should be created. Possible values are **Attach:** This value is used when you are using a specialized disk to create the virtual machine. **FromImage:** This value is used when you are using an image to create the virtual machine data disk. If you are using a platform image, you should also use the imageReference element described above. If you are using a marketplace image, you should also use the plan element previously described. **Empty:** This value is used when creating an empty data disk. **Copy:** This value is used to create a data disk from a snapshot or another disk. **Restore:** This value is used to create a data disk from a disk restore point. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property 'diskSizeGB' is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParameters;\n /** The source resource identifier. It can be a snapshot, or disk restore point from which to create a disk. */\n sourceResource?: ApiEntityReference;\n /** Specifies whether the data disk is in process of detachment from the VirtualMachine/VirtualMachineScaleset */\n toBeDetached?: boolean;\n /** Specifies the Read-Write IOPS for the managed disk when StorageAccountType is UltraSSD_LRS. */\n diskIopsReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk when StorageAccountType is UltraSSD_LRS. */\n diskMBpsReadWrite?: number;\n /** Specifies the detach behavior to be used while detaching a disk or which is already in the process of detachment from the virtual machine. Supported values: **ForceDetach.** detachOption: **ForceDetach** is applicable only for managed data disks. If a previous detachment attempt of the data disk did not complete due to an unexpected failure from the virtual machine and the disk is still not released then use force-detach as a last resort option to detach the disk forcibly from the VM. All writes might not have been flushed when using this detach behavior. **This feature is still in preview**. To force-detach a data disk update toBeDetached to 'true' along with setting detachOption: 'ForceDetach'. */\n detachOption?: DiskDetachOptionTypes;\n /** Specifies whether data disk should be deleted or detached upon VM deletion. Possible values are: **Delete.** If this value is used, the data disk is deleted when VM is deleted. **Detach.** If this value is used, the data disk is retained after VM is deleted. The default value is set to **Detach**. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Specifies the operating system settings for the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\nexport interface OSProfile {\n /** Specifies the host OS name of the virtual machine. This name cannot be updated after the VM is created. **Max-length (Windows):** 15 characters. **Max-length (Linux):** 64 characters. For naming conventions and restrictions see [Azure infrastructure services implementation guidelines](https://docs.microsoft.com/azure/azure-resource-manager/management/resource-name-rules). */\n computerName?: string;\n /** Specifies the name of the administrator account. <br><br> This property cannot be updated after the VM is created. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters. */\n adminUsername?: string;\n /**\n * Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)\n * This value contains a credential. Consider obscuring before showing to users\n */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. **Note: Do not pass any secrets or passwords in customData property.** This property cannot be updated after the VM is created. The property 'customData' is passed to the VM to be saved as a file, for more information see [Custom Data on Azure VMs](https://azure.microsoft.com/blog/custom-data-and-cloud-init-on-windows-azure/). For using cloud-init for your Linux VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init). */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfiguration;\n /** Specifies the Linux operating system settings on the virtual machine. For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfiguration;\n /** Specifies set of certificates that should be installed onto the virtual machine. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: VaultSecretGroup[];\n /** Specifies whether extension operations should be allowed on the virtual machine. This may only be set to False when no extensions are present on the virtual machine. */\n allowExtensionOperations?: boolean;\n /** Optional property which must either be set to True or omitted. */\n requireGuestProvisionSignal?: boolean;\n}\n\n/** Specifies the network interfaces or the networking configuration of the virtual machine. */\nexport interface NetworkProfile {\n /** Specifies the list of resource Ids for the network interfaces associated with the virtual machine. */\n networkInterfaces?: NetworkInterfaceReference[];\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations */\n networkApiVersion?: NetworkApiVersion;\n /** Specifies the networking configurations that will be used to create the virtual machine networking resources. */\n networkInterfaceConfigurations?: VirtualMachineNetworkInterfaceConfiguration[];\n}\n\n/** Describes a virtual machine network interface configurations. */\nexport interface VirtualMachineNetworkInterfaceConfiguration {\n /** The network interface configuration name. */\n name: string;\n /** Resource tags applied to the networkInterface address created by this NetworkInterfaceConfiguration */\n tags?: { [propertyName: string]: string };\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResource;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineNetworkInterfaceDnsSettingsConfiguration;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations?: VirtualMachineNetworkInterfaceIPConfiguration[];\n dscpConfiguration?: SubResource;\n /** Specifies whether the Auxiliary mode is enabled for the Network Interface resource. */\n auxiliaryMode?: NetworkInterfaceAuxiliaryMode;\n /** Specifies whether the Auxiliary sku is enabled for the Network Interface resource. */\n auxiliarySku?: NetworkInterfaceAuxiliarySku;\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachineNetworkInterfaceDnsSettingsConfiguration {\n /** List of DNS servers IP addresses */\n dnsServers?: string[];\n}\n\n/** Describes a virtual machine network profile's IP configuration. */\nexport interface VirtualMachineNetworkInterfaceIPConfiguration {\n /** The IP configuration name. */\n name: string;\n /** Specifies the identifier of the subnet. */\n subnet?: SubResource;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachinePublicIPAddressConfiguration;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: IPVersions;\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: SubResource[];\n /** Specifies an array of references to backend address pools of application gateways. A virtual machine can reference backend address pools of multiple application gateways. Multiple virtual machines cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: SubResource[];\n /** Specifies an array of references to backend address pools of load balancers. A virtual machine can reference backend address pools of one public and one internal load balancer. [Multiple virtual machines cannot use the same basic sku load balancer]. */\n loadBalancerBackendAddressPools?: SubResource[];\n}\n\n/** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachinePublicIPAddressConfiguration {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSku;\n /** Resource tags applied to the publicIP address created by this PublicIPAddressConfiguration */\n tags?: { [propertyName: string]: string };\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** Specify what happens to the public IP address when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachinePublicIPAddressDnsSettingsConfiguration;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: VirtualMachineIpTag[];\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResource;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: IPVersions;\n /** Specify the public IP allocation type */\n publicIPAllocationMethod?: PublicIPAllocationMethod;\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachinePublicIPAddressDnsSettingsConfiguration {\n /** The Domain name label prefix of the PublicIPAddress resources that will be created. The generated name label is the concatenation of the domain name label and vm network profile unique ID. */\n domainNameLabel: string;\n /** The Domain name label scope of the PublicIPAddress resources that will be created. The generated name label is the concatenation of the hashed domain name label with policy according to the domain name label scope and vm network profile unique ID. */\n domainNameLabelScope?: DomainNameLabelScopeTypes;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineIpTag {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** The instance view of a virtual machine. */\nexport interface VirtualMachineInstanceView {\n /** Specifies the update domain of the virtual machine. */\n platformUpdateDomain?: number;\n /** Specifies the fault domain of the virtual machine. */\n platformFaultDomain?: number;\n /** The computer name assigned to the virtual machine. */\n computerName?: string;\n /** The Operating System running on the virtual machine. */\n osName?: string;\n /** The version of Operating System running on the virtual machine. */\n osVersion?: string;\n /** Specifies the HyperVGeneration Type associated with a resource */\n hyperVGeneration?: HyperVGenerationType;\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceView;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatus;\n /** The virtual machine disk information. */\n disks?: DiskInstanceView[];\n /** The extensions information. */\n extensions?: VirtualMachineExtensionInstanceView[];\n /**\n * The health status for the VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmHealth?: VirtualMachineHealthStatus;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceView;\n /**\n * Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. Minimum api-version: 2020-06-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assignedHost?: string;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n /** [Preview Feature] The status of virtual machine patch operations. */\n patchStatus?: VirtualMachinePatchStatus;\n /**\n * [Preview Feature] Specifies whether the VM is currently in or out of the Standby Pool.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isVMInStandbyPool?: boolean;\n}\n\n/** The instance view of the VM Agent running on the virtual machine. */\nexport interface VirtualMachineAgentInstanceView {\n /** The VM Agent full version. */\n vmAgentVersion?: string;\n /** The virtual machine extension handler instance view. */\n extensionHandlers?: VirtualMachineExtensionHandlerInstanceView[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The instance view of a virtual machine extension handler. */\nexport interface VirtualMachineExtensionHandlerInstanceView {\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The extension handler status. */\n status?: InstanceViewStatus;\n}\n\n/** Maintenance Operation Status. */\nexport interface MaintenanceRedeployStatus {\n /** True, if customer is allowed to perform Maintenance. */\n isCustomerInitiatedMaintenanceAllowed?: boolean;\n /** Start Time for the Pre Maintenance Window. */\n preMaintenanceWindowStartTime?: Date;\n /** End Time for the Pre Maintenance Window. */\n preMaintenanceWindowEndTime?: Date;\n /** Start Time for the Maintenance Window. */\n maintenanceWindowStartTime?: Date;\n /** End Time for the Maintenance Window. */\n maintenanceWindowEndTime?: Date;\n /** The Last Maintenance Operation Result Code. */\n lastOperationResultCode?: MaintenanceOperationResultCodeTypes;\n /** Message returned for the last Maintenance Operation. */\n lastOperationMessage?: string;\n}\n\n/** The instance view of the disk. */\nexport interface DiskInstanceView {\n /** The disk name. */\n name?: string;\n /** Specifies the encryption settings for the OS Disk. <br><br> Minimum api-version: 2015-06-15 */\n encryptionSettings?: DiskEncryptionSettings[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The instance view of a virtual machine extension. */\nexport interface VirtualMachineExtensionInstanceView {\n /** The virtual machine extension name. */\n name?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The resource status information. */\n substatuses?: InstanceViewStatus[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The health status of the VM. */\nexport interface VirtualMachineHealthStatus {\n /**\n * The health status information for the VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: InstanceViewStatus;\n}\n\n/** The instance view of a virtual machine boot diagnostics. */\nexport interface BootDiagnosticsInstanceView {\n /**\n * The console screenshot blob URI. **Note:** This will **not** be set if boot diagnostics is currently enabled with managed storage.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly consoleScreenshotBlobUri?: string;\n /**\n * The serial console log blob Uri. **Note:** This will **not** be set if boot diagnostics is currently enabled with managed storage.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serialConsoleLogBlobUri?: string;\n /**\n * The boot diagnostics status information for the VM. **Note:** It will be set only if there are errors encountered in enabling boot diagnostics.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: InstanceViewStatus;\n}\n\n/** The status of virtual machine patch operations. */\nexport interface VirtualMachinePatchStatus {\n /** The available patch summary of the latest assessment operation for the virtual machine. */\n availablePatchSummary?: AvailablePatchSummary;\n /** The installation summary of the latest installation operation for the virtual machine. */\n lastPatchInstallationSummary?: LastPatchInstallationSummary;\n /**\n * The enablement status of the specified patchMode\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly configurationStatuses?: InstanceViewStatus[];\n}\n\n/** Describes the properties of an virtual machine instance view for available patch summary. */\nexport interface AvailablePatchSummary {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assessmentActivityId?: string;\n /**\n * The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootPending?: boolean;\n /**\n * The number of critical or security patches that have been detected as available and not yet installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly criticalAndSecurityPatchCount?: number;\n /**\n * The number of all available patches excluding critical and security.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly otherPatchCount?: number;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastModifiedTime?: Date;\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Describes the properties of the last installed patch summary. */\nexport interface LastPatchInstallationSummary {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installationActivityId?: string;\n /**\n * Describes whether the operation ran out of time before it completed all its intended actions\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maintenanceWindowExceeded?: boolean;\n /**\n * The number of all available patches but not going to be installed because it didn't match a classification or inclusion list entry.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly notSelectedPatchCount?: number;\n /**\n * The number of all available patches but excluded explicitly by a customer-specified exclusion list match.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly excludedPatchCount?: number;\n /**\n * The number of all available patches expected to be installed over the course of the patch installation operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly pendingPatchCount?: number;\n /**\n * The count of patches that successfully installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installedPatchCount?: number;\n /**\n * The count of patches that failed installation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedPatchCount?: number;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastModifiedTime?: Date;\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Identity for the virtual machine. */\nexport interface VirtualMachineIdentity {\n /**\n * The principal id of virtual machine identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The tenant id associated with the virtual machine. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine. */\n type?: ResourceIdentityType;\n /** The list of user identities associated with the Virtual Machine. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineSizeListResult {\n /** The list of virtual machine sizes. */\n value?: VirtualMachineSize[];\n /** The link to the next page of items. */\n nextLink?: string;\n}\n\n/** Describes the properties of a VM size. */\nexport interface VirtualMachineSize {\n /** The name of the virtual machine size. */\n name?: string;\n /** The number of cores supported by the virtual machine size. For Constrained vCPU capable VM sizes, this number represents the total vCPUs of quota that the VM uses. For accurate vCPU count, please refer to https://docs.microsoft.com/azure/virtual-machines/constrained-vcpu or https://docs.microsoft.com/rest/api/compute/resourceskus/list */\n numberOfCores?: number;\n /** The OS disk size, in MB, allowed by the virtual machine size. */\n osDiskSizeInMB?: number;\n /** The resource disk size, in MB, allowed by the virtual machine size. */\n resourceDiskSizeInMB?: number;\n /** The amount of memory, in MB, supported by the virtual machine size. */\n memoryInMB?: number;\n /** The maximum number of data disks that can be attached to the virtual machine size. */\n maxDataDiskCount?: number;\n}\n\n/** The List Proximity Placement Group operation response. */\nexport interface ProximityPlacementGroupListResult {\n /** The list of proximity placement groups. */\n value: ProximityPlacementGroup[];\n /** The URI to fetch the next page of proximity placement groups. */\n nextLink?: string;\n}\n\n/** Specifies the user intent of the proximity placement group. */\nexport interface ProximityPlacementGroupPropertiesIntent {\n /** Specifies possible sizes of virtual machines that can be created in the proximity placement group. */\n vmSizes?: string[];\n}\n\n/** The List restore point collection operation response. */\nexport interface RestorePointCollectionListResult {\n /** Gets the list of restore point collections. */\n value: RestorePointCollection[];\n /** The uri to fetch the next page of RestorePointCollections. Call ListNext() with this to fetch the next page of RestorePointCollections. */\n nextLink?: string;\n}\n\n/** The properties of the source resource that this restore point collection is created from. */\nexport interface RestorePointCollectionSourceProperties {\n /**\n * Location of the source resource used to create this restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** Resource Id of the source resource used to create this restore point collection */\n id?: string;\n}\n\n/** Describes the properties of the Virtual Machine for which the restore point was created. The properties provided are a subset and the snapshot of the overall Virtual Machine properties captured at the time of the restore point creation. */\nexport interface RestorePointSourceMetadata {\n /**\n * Gets the hardware profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hardwareProfile?: HardwareProfile;\n /** Gets the storage profile. */\n storageProfile?: RestorePointSourceVMStorageProfile;\n /**\n * Gets the OS profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly osProfile?: OSProfile;\n /**\n * Gets the diagnostics profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diagnosticsProfile?: DiagnosticsProfile;\n /**\n * Gets the license type, which is for bring your own license scenario.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly licenseType?: string;\n /**\n * Gets the virtual machine unique id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /**\n * Gets the security profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly securityProfile?: SecurityProfile;\n /**\n * Location of the VM from which the restore point was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * UserData associated with the source VM for which restore point is captured, which is a base-64 encoded value.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly userData?: string;\n /**\n * HyperVGeneration of the source VM for which restore point is captured.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hyperVGeneration?: HyperVGenerationTypes;\n}\n\n/** Describes the storage profile. */\nexport interface RestorePointSourceVMStorageProfile {\n /** Gets the OS disk of the VM captured at the time of the restore point creation. */\n osDisk?: RestorePointSourceVmosDisk;\n /** Gets the data disks of the VM captured at the time of the restore point creation. */\n dataDisks?: RestorePointSourceVMDataDisk[];\n /**\n * Gets the disk controller type of the VM captured at the time of the restore point creation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskControllerType?: DiskControllerTypes;\n}\n\n/** Describes an Operating System disk. */\nexport interface RestorePointSourceVmosDisk {\n /**\n * Gets the Operating System type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly osType?: OperatingSystemType;\n /**\n * Gets the disk encryption settings.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly encryptionSettings?: DiskEncryptionSettings;\n /**\n * Gets the disk name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Gets the caching type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly caching?: CachingTypes;\n /**\n * Gets the disk size in GB.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeGB?: number;\n /** Gets the managed disk details */\n managedDisk?: ManagedDiskParameters;\n /** Contains Disk Restore Point properties. */\n diskRestorePoint?: DiskRestorePointAttributes;\n /**\n * Shows true if the disk is write-accelerator enabled.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly writeAcceleratorEnabled?: boolean;\n}\n\n/** Encryption at rest settings for disk restore point. It is an optional property that can be specified in the input while creating a restore point. */\nexport interface RestorePointEncryption {\n /** Describes the parameter of customer managed disk encryption set resource id that can be specified for disk. **Note:** The disk encryption set resource id can only be specified for managed disk. Please refer https://aka.ms/mdssewithcmkoverview for more details. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** The type of key used to encrypt the data of the disk restore point. */\n type?: RestorePointEncryptionType;\n}\n\n/** Describes a data disk. */\nexport interface RestorePointSourceVMDataDisk {\n /**\n * Gets the logical unit number.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lun?: number;\n /**\n * Gets the disk name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Gets the caching type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly caching?: CachingTypes;\n /**\n * Gets the initial disk size in GB for blank data disks, and the new desired size for existing OS and Data disks.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeGB?: number;\n /** Contains the managed disk details. */\n managedDisk?: ManagedDiskParameters;\n /** Contains Disk Restore Point properties. */\n diskRestorePoint?: DiskRestorePointAttributes;\n /**\n * Shows true if the disk is write-accelerator enabled.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly writeAcceleratorEnabled?: boolean;\n}\n\n/** The instance view of a restore point. */\nexport interface RestorePointInstanceView {\n /** The disk restore points information. */\n diskRestorePoints?: DiskRestorePointInstanceView[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointInstanceView {\n /** Disk restore point Id. */\n id?: string;\n /** The state of snapshot which determines the access availability of the snapshot. */\n snapshotAccessState?: SnapshotAccessState;\n /** The disk restore point replication status information. */\n replicationStatus?: DiskRestorePointReplicationStatus;\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointReplicationStatus {\n /** The resource status information. */\n status?: InstanceViewStatus;\n /** Replication completion percentage. */\n completionPercent?: number;\n}\n\n/** The list SSH public keys operation response. */\nexport interface SshPublicKeysGroupListResult {\n /** The list of SSH public keys. */\n value: SshPublicKeyResource[];\n /** The URI to fetch the next page of SSH public keys. Call ListNext() with this URI to fetch the next page of SSH public keys. */\n nextLink?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListWithLinkResult {\n /** The list of virtual machine scale sets. */\n value: VirtualMachineScaleSet[];\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of Virtual Machine Scale Sets. */\n nextLink?: string;\n}\n\n/** The Update Resource model definition. */\nexport interface UpdateResource {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** Describes the Virtual Machine Scale Set to convert from Availability Set. */\nexport interface ConvertToVirtualMachineScaleSetInput {\n /** Specifies information about the Virtual Machine Scale Set that the Availability Set should be converted to. */\n virtualMachineScaleSetName?: string;\n}\n\n/** Describes the Virtual Machine Scale Set to migrate from Availability Set. */\nexport interface MigrateToVirtualMachineScaleSetInput {\n /** Specifies information about the Virtual Machine Scale Set that the Availability Set should be migrated to. Minimum api‐version: 2024‐11‐01. */\n virtualMachineScaleSetFlexible: SubResource;\n}\n\n/** The list capacity reservation operation response. */\nexport interface CapacityReservationListResult {\n /** The list of capacity reservations. */\n value: CapacityReservation[];\n /** The URI to fetch the next page of capacity reservations. Call ListNext() with this URI to fetch the next page of capacity reservations. */\n nextLink?: string;\n}\n\n/** Defines the schedule for Block-type capacity reservations. Specifies the schedule during which capacity reservation is active and VM or VMSS resource can be allocated using reservation. This property is required and only supported when the capacity reservation group type is 'Block'. The scheduleProfile, start, and end fields are immutable after creation. Minimum API version: 2025-04-01. Please refer to https://aka.ms/blockcapacityreservation for more details. */\nexport interface ScheduleProfile {\n /** The required start date for block capacity reservations. Must be today or within 56 days in the future. For same-day scheduling, requests must be submitted before 11:30 AM UTC. Example: 2025-06-27. */\n start?: string;\n /** The required end date for block capacity reservations. Must be after the start date, with a duration of either 1–14 whole days or 3–26 whole weeks. Example: 2025-06-28. */\n end?: string;\n}\n\n/** The list dedicated host operation response. */\nexport interface DedicatedHostListResult {\n /** The list of dedicated hosts. */\n value: DedicatedHost[];\n /** The URI to fetch the next page of dedicated hosts. Call ListNext() with this URI to fetch the next page of dedicated hosts. */\n nextLink?: string;\n}\n\n/** The List Dedicated Host sizes operation response. */\nexport interface DedicatedHostSizeListResult {\n /** The list of dedicated host sizes. */\n value?: string[];\n /** The link to the next page of items. */\n nextLink?: string;\n}\n\n/** Parameters for GenerateSshKeyPair. */\nexport interface SshGenerateKeyPairInputParameters {\n /** The encryption type of the SSH keys to be generated. See SshEncryptionTypes for possible set of values. If not provided, will default to RSA */\n encryptionType?: SshEncryptionTypes;\n}\n\n/** Response from generation of an SSH key pair. */\nexport interface SshPublicKeyGenerateKeyPairResult {\n /** Private key portion of the key pair used to authenticate to a virtual machine through ssh. The private key is returned in RFC3447 format and should be treated as a secret. */\n privateKey: string;\n /** Public key portion of the key pair used to authenticate to a virtual machine through ssh. The public key is in ssh-rsa format. */\n publicKey: string;\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/sshPublicKeys/{SshPublicKeyName} */\n id: string;\n}\n\n/** Describes a virtual machine scale set virtual machine profile. */\nexport interface VirtualMachineScaleSetUpdateVMProfile {\n /** The virtual machine scale set OS profile. */\n osProfile?: VirtualMachineScaleSetUpdateOSProfile;\n /** The virtual machine scale set storage profile. */\n storageProfile?: VirtualMachineScaleSetUpdateStorageProfile;\n /** The virtual machine scale set network profile. */\n networkProfile?: VirtualMachineScaleSetUpdateNetworkProfile;\n /** The virtual machine scale set security posture reference. */\n securityPostureReference?: SecurityPostureReferenceUpdate;\n /** The virtual machine scale set Security profile */\n securityProfile?: SecurityProfile;\n /** The virtual machine scale set diagnostics profile. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** The virtual machine scale set extension profile. */\n extensionProfile?: VirtualMachineScaleSetExtensionProfile;\n /** The license type, which is for bring your own license scenario. */\n licenseType?: string;\n /** Specifies the billing related details of a Azure Spot VMSS. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n /** Specifies the hardware profile related details of a scale set. Minimum api-version: 2021-11-01. */\n hardwareProfile?: VirtualMachineScaleSetHardwareProfile;\n}\n\n/** Describes a virtual machine scale set OS profile. */\nexport interface VirtualMachineScaleSetUpdateOSProfile {\n /** A base-64 encoded string of custom data. */\n customData?: string;\n /** The Windows Configuration of the OS profile. */\n windowsConfiguration?: WindowsConfiguration;\n /** The Linux Configuration of the OS profile. */\n linuxConfiguration?: LinuxConfiguration;\n /** The List of certificates for addition to the VM. */\n secrets?: VaultSecretGroup[];\n}\n\n/** Describes a virtual machine scale set storage profile. */\nexport interface VirtualMachineScaleSetUpdateStorageProfile {\n /** The image reference. */\n imageReference?: ImageReference;\n /** The OS disk. */\n osDisk?: VirtualMachineScaleSetUpdateOSDisk;\n /** The data disks. */\n dataDisks?: VirtualMachineScaleSetDataDisk[];\n /** Specifies the disk controller type configured for the virtual machines in the scale set. **Note:** You need to deallocate the virtual machines in the scale set before updating its disk controller type based on the upgrade mode configured for the scale set. Minimum api-version: 2022-08-01 */\n diskControllerType?: DiskControllerTypes;\n}\n\n/** Describes virtual machine scale set operating system disk Update Object. This should be used for Updating VMSS OS Disk. */\nexport interface VirtualMachineScaleSetUpdateOSDisk {\n /** The caching type. */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies the ephemeral disk Settings for the operating system disk used by the virtual machine scale set. */\n diffDiskSettings?: DiffDiskSettings;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The Source User Image VirtualHardDisk. This VirtualHardDisk will be copied before using it to attach to the Virtual Machine. If SourceImage is provided, the destination VirtualHardDisk should not exist. */\n image?: VirtualHardDisk;\n /** The list of virtual hard disk container uris. */\n vhdContainers?: string[];\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParameters;\n /** Specifies whether OS Disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only). <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the OS disk is retained after VMSS Flex VM is deleted. <br><br> The default value is set to **Delete**. For an Ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for Ephemeral OS Disk. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes a virtual machine scale set network profile. */\nexport interface VirtualMachineScaleSetUpdateNetworkProfile {\n /** A reference to a load balancer probe used to determine the health of an instance in the virtual machine scale set. The reference will be in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'. */\n healthProbe?: ApiEntityReference;\n /** The list of network configurations. */\n networkInterfaceConfigurations?: VirtualMachineScaleSetUpdateNetworkConfiguration[];\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations for Virtual Machine Scale Set with orchestration mode 'Flexible' */\n networkApiVersion?: NetworkApiVersion;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetUpdateNetworkConfiguration {\n /** The network configuration name. */\n name?: string;\n /** Resource tags applied to the networkInterface address created by this NetworkInterfaceConfiguration */\n tags?: { [propertyName: string]: string };\n /** Whether this is a primary NIC on a virtual machine. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResource;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettings;\n /** The virtual machine scale set IP Configuration. */\n ipConfigurations?: VirtualMachineScaleSetUpdateIPConfiguration[];\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** Specifies whether the Auxiliary mode is enabled for the Network Interface resource. */\n auxiliaryMode?: NetworkInterfaceAuxiliaryMode;\n /** Specifies whether the Auxiliary sku is enabled for the Network Interface resource. */\n auxiliarySku?: NetworkInterfaceAuxiliarySku;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. NOTE: The subnet of a scale set may be modified as long as the original subnet and the new subnet are in the same virtual network */\nexport interface VirtualMachineScaleSetUpdateIPConfiguration {\n /** The IP configuration name. */\n name?: string;\n /** The subnet. */\n subnet?: ApiEntityReference;\n /** Specifies the primary IP Configuration in case the network interface has more than one IP Configuration. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetUpdatePublicIPAddressConfiguration;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: IPVersion;\n /** The application gateway backend address pools. */\n applicationGatewayBackendAddressPools?: SubResource[];\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: SubResource[];\n /** The load balancer backend address pools. */\n loadBalancerBackendAddressPools?: SubResource[];\n /** The load balancer inbound nat pools. */\n loadBalancerInboundNatPools?: SubResource[];\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetUpdatePublicIPAddressConfiguration {\n /** The publicIP address configuration name. */\n name?: string;\n /** Resource tags applied to the publicIP address created by this PublicIPAddressConfiguration */\n tags?: { [propertyName: string]: string };\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettings;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResource;\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: DeleteOptions;\n}\n\n/** Specifies the security posture to be used in the scale set. Minimum api-version: 2023-03-01 */\nexport interface SecurityPostureReferenceUpdate {\n /** The security posture reference id in the form of /CommunityGalleries/{communityGalleryName}/securityPostures/{securityPostureName}/versions/{major.minor.patch}|latest */\n id?: string;\n /** The list of virtual machine extension names to exclude when applying the security posture. */\n excludeExtensions?: string[];\n /** Whether the security posture can be overridden by the user. */\n isOverridable?: boolean;\n}\n\n/** Specifies a list of virtual machine instance IDs from the VM scale set. */\nexport interface VirtualMachineScaleSetVMInstanceIDs {\n /** The virtual machine scale set instance ids. Omitting the virtual machine scale set instance ids will result in the operation being performed on all virtual machines in the virtual machine scale set. */\n instanceIds?: string[];\n}\n\nexport interface VMScaleSetConvertToSinglePlacementGroupInput {\n /** Id of the placement group in which you want future virtual machine instances to be placed. To query placement group Id, please use Virtual Machine Scale Set VMs - Get API. If not provided, the platform will choose one with maximum number of virtual machine instances. */\n activePlacementGroupId?: string;\n}\n\n/** Specifies a list of virtual machine instance IDs from the VM scale set. */\nexport interface VirtualMachineScaleSetVMInstanceRequiredIDs {\n /** The virtual machine scale set instance ids. */\n instanceIds: string[];\n}\n\n/** The List VM scale set extension operation response. */\nexport interface VirtualMachineScaleSetExtensionListResult {\n /** The list of VM scale set extensions. */\n value: VirtualMachineScaleSetExtension[];\n /** The uri to fetch the next page of VM scale set extensions. Call ListNext() with this to fetch the next page of VM scale set extensions. */\n nextLink?: string;\n}\n\n/** Response after calling a manual recovery walk */\nexport interface RecoveryWalkResponse {\n /**\n * Whether the recovery walk was performed\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly walkPerformed?: boolean;\n /**\n * The next update domain that needs to be walked. Null means walk spanning all update domains has been completed\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly nextPlatformUpdateDomain?: number;\n}\n\n/** The instance view of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceView {\n /**\n * The instance view status summary for the virtual machine scale set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachine?: VirtualMachineScaleSetInstanceViewStatusesSummary;\n /**\n * The extensions information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly extensions?: VirtualMachineScaleSetVMExtensionsSummary[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n /**\n * The orchestration services information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly orchestrationServices?: OrchestrationServiceSummary[];\n}\n\n/** Instance view statuses summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceViewStatusesSummary {\n /**\n * The extensions information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statusesSummary?: VirtualMachineStatusCodeCount[];\n}\n\n/** The status code and count of the virtual machine scale set instance view status summary. */\nexport interface VirtualMachineStatusCodeCount {\n /**\n * The instance view status code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * The number of instances having a particular status code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly count?: number;\n}\n\n/** Extensions summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetVMExtensionsSummary {\n /**\n * The extension name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The extensions information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statusesSummary?: VirtualMachineStatusCodeCount[];\n}\n\n/** Summary for an orchestration service of a virtual machine scale set. */\nexport interface OrchestrationServiceSummary {\n /**\n * The name of the service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serviceName?: OrchestrationServiceNames;\n /**\n * The current state of the service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serviceState?: OrchestrationServiceState;\n /**\n * The latest operation status of the service. Minimum API version for this property is 2025-04-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly latestOperationStatus?: OrchestrationServiceOperationStatus;\n /**\n * The last UTC time when the operation status changed. Minimum API version for this property is 2025-04-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastStatusChangeTime?: Date;\n}\n\n/** List of Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface VirtualMachineScaleSetListOSUpgradeHistory {\n /** The list of OS upgrades performed on the virtual machine scale set. */\n value: UpgradeOperationHistoricalStatusInfo[];\n /** The uri to fetch the next page of OS Upgrade History. Call ListNext() with this to fetch the next page of history of upgrades. */\n nextLink?: string;\n}\n\n/** Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface UpgradeOperationHistoricalStatusInfo {\n /**\n * Information about the properties of the upgrade operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly properties?: UpgradeOperationHistoricalStatusInfoProperties;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n}\n\n/** Describes each OS upgrade on the Virtual Machine Scale Set. */\nexport interface UpgradeOperationHistoricalStatusInfoProperties {\n /**\n * Information about the overall status of the upgrade operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly runningStatus?: UpgradeOperationHistoryStatus;\n /**\n * Counts of the VMs in each state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly progress?: RollingUpgradeProgressInfo;\n /**\n * Error Details for this upgrade if there are any.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n /**\n * Invoker of the Upgrade Operation\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startedBy?: UpgradeOperationInvoker;\n /**\n * Image Reference details\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly targetImageReference?: ImageReference;\n /**\n * Information about OS rollback if performed\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rollbackInfo?: RollbackStatusInfo;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface UpgradeOperationHistoryStatus {\n /**\n * Code indicating the current status of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: UpgradeState;\n /**\n * Start time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * End time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly endTime?: Date;\n}\n\n/** Information about the number of virtual machine instances in each upgrade state. */\nexport interface RollingUpgradeProgressInfo {\n /**\n * The number of instances that have been successfully upgraded.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly successfulInstanceCount?: number;\n /**\n * The number of instances that have failed to be upgraded successfully.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedInstanceCount?: number;\n /**\n * The number of instances that are currently being upgraded.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly inProgressInstanceCount?: number;\n /**\n * The number of instances that have not yet begun to be upgraded.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly pendingInstanceCount?: number;\n}\n\n/** Information about rollback on failed VM instances after a OS Upgrade operation. */\nexport interface RollbackStatusInfo {\n /**\n * The number of instances which have been successfully rolled back.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly successfullyRolledbackInstanceCount?: number;\n /**\n * The number of instances which failed to rollback.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedRolledbackInstanceCount?: number;\n /**\n * Error details if OS rollback failed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rollbackError?: ApiError;\n}\n\n/** Parameters for Reimaging Virtual Machine. NOTE: Virtual Machine OS disk will always be reimaged */\nexport interface VirtualMachineReimageParameters {\n /** Specifies whether to reimage temp disk. Default value: false. Note: This temp disk reimage parameter is only supported for VM/VMSS with Ephemeral OS disk. */\n tempDisk?: boolean;\n /** Specifies in decimal number, the version the OS disk should be reimaged to. If exact version is not provided, the OS disk is reimaged to the existing version of OS Disk. */\n exactVersion?: string;\n /** Specifies information required for reimaging the non-ephemeral OS disk. */\n osProfile?: OSProfileProvisioningData;\n}\n\n/** Additional parameters for Reimaging Non-Ephemeral Virtual Machine. */\nexport interface OSProfileProvisioningData {\n /**\n * Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)\n * This value contains a credential. Consider obscuring before showing to users\n */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. **Note: Do not pass any secrets or passwords in customData property.** This property cannot be updated after the VM is created. The property customData is passed to the VM to be saved as a file, for more information see [Custom Data on Azure VMs](https://azure.microsoft.com/blog/custom-data-and-cloud-init-on-windows-azure/). If using cloud-init for your Linux VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init). */\n customData?: string;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface RollingUpgradeRunningStatus {\n /**\n * Code indicating the current status of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: RollingUpgradeStatusCode;\n /**\n * Start time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * The last action performed on the rolling upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastAction?: RollingUpgradeActionType;\n /**\n * Last action time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastActionTime?: Date;\n}\n\n/** The input for ScaleOut */\nexport interface VMScaleSetScaleOutInput {\n /** Specifies the number of virtual machines in the scale set. */\n capacity: number;\n /** The input properties for ScaleOut */\n properties?: VMScaleSetScaleOutInputProperties;\n}\n\n/** The input properties for ScaleOut */\nexport interface VMScaleSetScaleOutInputProperties {\n /** The zone in which the scale out is requested for the virtual machine scale set. */\n zone?: string;\n}\n\n/** The input for OrchestrationServiceState */\nexport interface OrchestrationServiceStateInput {\n /** The name of the service. */\n serviceName: OrchestrationServiceNames;\n /** The action to be performed. */\n action: OrchestrationServiceStateAction;\n}\n\n/** The Virtual Machine Scale Set List Skus operation response. */\nexport interface VirtualMachineScaleSetListSkusResult {\n /** The list of skus available for the virtual machine scale set. */\n value: VirtualMachineScaleSetSku[];\n /** The uri to fetch the next page of Virtual Machine Scale Set Skus. Call ListNext() with this to fetch the next page of VMSS Skus. */\n nextLink?: string;\n}\n\n/** Describes an available virtual machine scale set sku. */\nexport interface VirtualMachineScaleSetSku {\n /**\n * The type of resource the sku applies to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resourceType?: string;\n /**\n * The Sku.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sku?: Sku;\n /**\n * Specifies the number of virtual machines in the scale set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacity?: VirtualMachineScaleSetSkuCapacity;\n}\n\n/** Describes scaling information of a sku. */\nexport interface VirtualMachineScaleSetSkuCapacity {\n /**\n * The minimum capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly minimum?: number;\n /**\n * The maximum capacity that can be set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maximum?: number;\n /**\n * The default capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly defaultCapacity?: number;\n /**\n * The scale type applicable to the sku.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly scaleType?: VirtualMachineScaleSetSkuScaleType;\n}\n\n/** The List Virtual Machine Scale Set VMs operation response. */\nexport interface VirtualMachineScaleSetVMListResult {\n /** The list of virtual machine scale sets VMs. */\n value: VirtualMachineScaleSetVM[];\n /** The uri to fetch the next page of Virtual Machine Scale Set VMs. Call ListNext() with this to fetch the next page of VMSS VMs. */\n nextLink?: string;\n}\n\n/** The instance view of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMInstanceView {\n /** The Update Domain count. */\n platformUpdateDomain?: number;\n /** The Fault Domain count. */\n platformFaultDomain?: number;\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceView;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatus;\n /** The disks information. */\n disks?: DiskInstanceView[];\n /** The extensions information. */\n extensions?: VirtualMachineExtensionInstanceView[];\n /**\n * The health status for the VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmHealth?: VirtualMachineHealthStatus;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceView;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n /**\n * Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. Minimum api-version: 2020-06-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assignedHost?: string;\n /** The placement group in which the VM is running. If the VM is deallocated it will not have a placementGroupId. */\n placementGroupId?: string;\n /** Specifies the host OS name of the virtual machine. <br><br> This name cannot be updated after the VM is created. <br><br> **Max-length (Windows):** 15 characters <br><br> **Max-length (Linux):** 64 characters. <br><br> For naming conventions and restrictions see [Azure infrastructure services implementation guidelines](https://docs.microsoft.com/azure/virtual-machines/virtual-machines-linux-infrastructure-subscription-accounts-guidelines?toc=%2fazure%2fvirtual-machines%2flinux%2ftoc.json#1-naming-conventions). */\n computerName?: string;\n /** The Operating System running on the hybrid machine. */\n osName?: string;\n /** The version of Operating System running on the hybrid machine. */\n osVersion?: string;\n /** The hypervisor generation of the Virtual Machine [V1, V2] */\n hyperVGeneration?: HyperVGeneration;\n}\n\n/** Describes a virtual machine scale set VM network profile. */\nexport interface VirtualMachineScaleSetVMNetworkProfileConfiguration {\n /** The list of network configurations. */\n networkInterfaceConfigurations?: VirtualMachineScaleSetNetworkConfiguration[];\n}\n\n/** The protection policy of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMProtectionPolicy {\n /** Indicates that the virtual machine scale set VM shouldn't be considered for deletion during a scale-in operation. */\n protectFromScaleIn?: boolean;\n /** Indicates that model updates or actions (including scale-in) initiated on the virtual machine scale set should not be applied to the virtual machine scale set VM. */\n protectFromScaleSetActions?: boolean;\n}\n\n/** Specifies the input for attaching and detaching a list of managed data disks. */\nexport interface AttachDetachDataDisksRequest {\n /** The list of managed data disks to be attached. */\n dataDisksToAttach?: DataDisksToAttach[];\n /** The list of managed data disks to be detached. */\n dataDisksToDetach?: DataDisksToDetach[];\n}\n\n/** Describes the data disk to be attached. */\nexport interface DataDisksToAttach {\n /** ID of the managed data disk. */\n diskId: string;\n /** The logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. If not specified, lun would be auto assigned. */\n lun?: number;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The defaulting behavior is: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether data disk should be deleted or detached upon VM deletion. Possible values are: **Delete.** If this value is used, the data disk is deleted when VM is deleted. **Detach.** If this value is used, the data disk is retained after VM is deleted. The default value is set to **Detach**. */\n deleteOption?: DiskDeleteOptionTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n}\n\n/** Describes the data disk to be detached. */\nexport interface DataDisksToDetach {\n /** ID of the managed data disk. */\n diskId: string;\n /** Supported options available for Detach of a disk from a VM. Refer to DetachOption object reference for more details. */\n detachOption?: DiskDetachOptionTypes;\n}\n\n/** The List VMSS VM Extension operation response */\nexport interface VirtualMachineScaleSetVMExtensionsListResult {\n /** The list of VMSS VM extensions */\n value?: VirtualMachineScaleSetVMExtension[];\n}\n\n/** The SAS URIs of the console screenshot and serial log blobs. */\nexport interface RetrieveBootDiagnosticsDataResult {\n /**\n * The console screenshot blob URI\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly consoleScreenshotBlobUri?: string;\n /**\n * The serial console log blob URI.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serialConsoleLogBlobUri?: string;\n}\n\n/** Capture Virtual Machine parameters. */\nexport interface RunCommandInput {\n /** Specifies a commandId of predefined built-in script. Command IDs available for Linux are listed at https://aka.ms/RunCommandManagedLinux#available-commands, Windows at https://aka.ms/RunCommandManagedWindows#available-commands. */\n commandId: string;\n /** Optional. The script to be executed. When this value is given, the given script will override the default script of the command. */\n script?: string[];\n /** The run command parameters. */\n parameters?: RunCommandInputParameter[];\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandInputParameter {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter value. */\n value: string;\n}\n\nexport interface RunCommandResult {\n /** Run command operation response. */\n value?: InstanceViewStatus[];\n}\n\n/** The List run command operation response */\nexport interface VirtualMachineRunCommandsListResult {\n /** The list of run commands. */\n value: VirtualMachineRunCommand[];\n /** The uri to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Describes the script sources for run command. Use only one of these script sources: script, scriptUri, commandId, galleryScriptReferenceId. */\nexport interface VirtualMachineRunCommandScriptSource {\n /** Specifies the script content to be executed on the VM. */\n script?: string;\n /** Specifies the script download location. It can be either SAS URI of an Azure storage blob with read access or public URI. */\n scriptUri?: string;\n /** Specifies a commandId of predefined built-in script. Command IDs available for Linux are listed at https://aka.ms/RunCommandManagedLinux#available-commands, Windows at https://aka.ms/RunCommandManagedWindows#available-commands. */\n commandId?: string;\n /** User-assigned managed identity that has access to scriptUri in case of Azure storage blob. Use an empty object in case of system-assigned identity. Make sure the Azure storage blob exists, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged. */\n scriptUriManagedIdentity?: RunCommandManagedIdentity;\n /** Optional. Specify which shell to use for running the script. These values must match those expected by the extension. Currently supported only for Windows VMs, script uses Powershell 7 when specified. Powershell 7 must be already installed on the machine to use Powershell7 parameter value. */\n scriptShell?: ScriptShellTypes;\n /** The resource ID of a Gallery Script version that needs to be executed. Example ID looks like /subscriptions/{subId}/resourceGroups/{rgName}/providers/Microsoft.Compute/galleries/{galleryName}/scripts/{scriptName}/versions/{version}. */\n galleryScriptReferenceId?: string;\n}\n\n/** Contains clientId or objectId (use only one, not both) of a user-assigned managed identity that has access to storage blob used in Run Command. Use an empty RunCommandManagedIdentity object in case of system-assigned identity. Make sure the Azure storage blob exists in case of scriptUri, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment with scriptUri blob and 'Storage Blob Data Contributor' for Append blobs(outputBlobUri, errorBlobUri). In case of user assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged. */\nexport interface RunCommandManagedIdentity {\n /** Client Id (GUID value) of the user-assigned managed identity. ObjectId should not be used if this is provided. */\n clientId?: string;\n /** Object Id (GUID value) of the user-assigned managed identity. ClientId should not be used if this is provided. */\n objectId?: string;\n}\n\n/** The instance view of a virtual machine run command. */\nexport interface VirtualMachineRunCommandInstanceView {\n /** Script execution status. */\n executionState?: ExecutionState;\n /** Communicate script configuration errors or execution messages. */\n executionMessage?: string;\n /** Exit code returned from script execution. */\n exitCode?: number;\n /** Script output stream. */\n output?: string;\n /** Script error stream. */\n error?: string;\n /** Script start time. */\n startTime?: Date;\n /** Script end time. */\n endTime?: Date;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** Describes the properties of an AssessPatches result. */\nexport interface VirtualMachineAssessPatchesResult {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assessmentActivityId?: string;\n /**\n * The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootPending?: boolean;\n /**\n * The number of critical or security patches that have been detected as available and not yet installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly criticalAndSecurityPatchCount?: number;\n /**\n * The number of all available patches excluding critical and security.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly otherPatchCount?: number;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startDateTime?: Date;\n /**\n * The list of patches that have been detected as available for installation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly availablePatches?: VirtualMachineSoftwarePatchProperties[];\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Describes the properties of a Virtual Machine software patch. */\nexport interface VirtualMachineSoftwarePatchProperties {\n /**\n * A unique identifier for the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly patchId?: string;\n /**\n * The friendly name of the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The version number of the patch. This property applies only to Linux patches.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The KBID of the patch. Only applies to Windows patches.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly kbId?: string;\n /**\n * The classification(s) of the patch as provided by the patch publisher.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly classifications?: string[];\n /**\n * Describes the reboot requirements of the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootBehavior?: VMGuestPatchRebootBehavior;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly activityId?: string;\n /**\n * The UTC timestamp when the repository published this patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The UTC timestamp of the last update to this patch record.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastModifiedDateTime?: Date;\n /**\n * Describes the availability of a given patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assessmentState?: PatchAssessmentState;\n}\n\n/** Capture Virtual Machine parameters. */\nexport interface VirtualMachineCaptureParameters {\n /** The captured virtual hard disk's name prefix. */\n vhdPrefix: string;\n /** The destination container name. */\n destinationContainerName: string;\n /** Specifies whether to overwrite the destination virtual hard disk, in case of conflict. */\n overwriteVhds: boolean;\n}\n\n/** The List Extension operation response */\nexport interface VirtualMachineExtensionsListResult {\n /** The list of extensions */\n value?: VirtualMachineExtension[];\n}\n\n/** Input for InstallPatches as directly received by the API */\nexport interface VirtualMachineInstallPatchesParameters {\n /** Specifies the maximum amount of time that the operation will run. It must be an ISO 8601-compliant duration string such as PT4H (4 hours) */\n maximumDuration?: string;\n /** Defines when it is acceptable to reboot a VM during a software update operation. */\n rebootSetting: VMGuestPatchRebootSetting;\n /** Input for InstallPatches on a Windows VM, as directly received by the API */\n windowsParameters?: WindowsParameters;\n /** Input for InstallPatches on a Linux VM, as directly received by the API */\n linuxParameters?: LinuxParameters;\n}\n\n/** Input for InstallPatches on a Windows VM, as directly received by the API */\nexport interface WindowsParameters {\n /** The update classifications to select when installing patches for Windows. */\n classificationsToInclude?: VMGuestPatchClassificationWindows[];\n /** Kbs to include in the patch operation */\n kbNumbersToInclude?: string[];\n /** Kbs to exclude in the patch operation */\n kbNumbersToExclude?: string[];\n /** Filters out Kbs that don't have an InstallationRebootBehavior of 'NeverReboots' when this is set to true. */\n excludeKbsRequiringReboot?: boolean;\n /** This is used to install patches that were published on or before this given max published date. */\n maxPatchPublishDate?: Date;\n /** This is used to include patches that match the given patch name masks. Alphanumeric strings and wildcard expressions consisting of * and ? are only supported as input values in the list. Null, empty and only whitespaces strings as inputs values are not supported. */\n patchNameMasksToInclude?: string[];\n /** This is used to exclude patches that match the given patch name masks. Alphanumeric strings and wildcard expressions consisting of * and ? are only supported as input values in the list. Null, empty and only whitespaces strings as inputs values are not supported. */\n patchNameMasksToExclude?: string[];\n}\n\n/** Input for InstallPatches on a Linux VM, as directly received by the API */\nexport interface LinuxParameters {\n /** The update classifications to select when installing patches for Linux. */\n classificationsToInclude?: VMGuestPatchClassificationLinux[];\n /** packages to include in the patch operation. Format: packageName_packageVersion */\n packageNameMasksToInclude?: string[];\n /** packages to exclude in the patch operation. Format: packageName_packageVersion */\n packageNameMasksToExclude?: string[];\n /** This is used as a maintenance run identifier for Auto VM Guest Patching in Linux. */\n maintenanceRunId?: string;\n}\n\n/** The result summary of an installation operation. */\nexport interface VirtualMachineInstallPatchesResult {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Failed\", \"Succeeded\", \"Unknown\" or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installationActivityId?: string;\n /**\n * The reboot state of the VM following completion of the operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootStatus?: VMGuestPatchRebootStatus;\n /**\n * Whether the operation ran out of time before it completed all its intended actions.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maintenanceWindowExceeded?: boolean;\n /**\n * The number of patches that were not installed due to the user blocking their installation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly excludedPatchCount?: number;\n /**\n * The number of patches that were detected as available for install, but did not meet the operation's criteria.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly notSelectedPatchCount?: number;\n /**\n * The number of patches that were identified as meeting the installation criteria, but were not able to be installed. Typically this happens when maintenanceWindowExceeded == true.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly pendingPatchCount?: number;\n /**\n * The number of patches successfully installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installedPatchCount?: number;\n /**\n * The number of patches that could not be installed due to some issue. See errors for details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedPatchCount?: number;\n /**\n * The patches that were installed during the operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly patches?: PatchInstallationDetail[];\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startDateTime?: Date;\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Information about a specific patch that was encountered during an installation action. */\nexport interface PatchInstallationDetail {\n /**\n * A unique identifier for the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly patchId?: string;\n /**\n * The friendly name of the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The version string of the package. It may conform to Semantic Versioning. Only applies to Linux.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The KBID of the patch. Only applies to Windows patches.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly kbId?: string;\n /**\n * The classification(s) of the patch as provided by the patch publisher.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly classifications?: string[];\n /**\n * The state of the patch after the installation operation completed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installationState?: PatchInstallationState;\n}\n\n/** The input of virtual machine migration from Availability Set to Flexible Virtual Machine Scale Set. */\nexport interface MigrateVMToVirtualMachineScaleSetInput {\n /** The target zone of VM migration to Flexible Virtual Machine Scale Set. */\n targetZone?: string;\n /** The target compute fault domain of VM migration to Flexible Virtual Machine Scale Set. */\n targetFaultDomain?: number;\n /** The target Virtual Machine size of VM migration to Flexible Virtual Machine Scale Set. */\n targetVMSize?: string;\n}\n\n/** The List disk access operation response. */\nexport interface DiskAccessList {\n /** The DiskAccess items on this page */\n value: DiskAccess[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** The Private Endpoint resource. */\nexport interface PrivateEndpoint {\n /**\n * The ARM identifier for Private Endpoint\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n}\n\n/** A collection of information about the state of the connection between service consumer and provider. */\nexport interface PrivateLinkServiceConnectionState {\n /** Indicates whether the connection has been Approved/Rejected/Removed by the owner of the service. */\n status?: PrivateEndpointServiceConnectionStatus;\n /** The reason for approval/rejection of the connection. */\n description?: string;\n /** A message indicating if changes on the service provider require any updates on the consumer. */\n actionsRequired?: string;\n}\n\n/** The List disk encryption set operation response. */\nexport interface DiskEncryptionSetList {\n /** The DiskEncryptionSet items on this page */\n value: DiskEncryptionSet[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Key Vault Key Url to be used for server side encryption of Managed Disks and Snapshots */\nexport interface KeyForDiskEncryptionSet {\n /** Resource id of the KeyVault containing the key or secret. This property is optional and cannot be used if the KeyVault subscription is not the same as the Disk Encryption Set subscription. */\n sourceVault?: SourceVault;\n /** Fully versioned Key Url pointing to a key in KeyVault. Version segment of the Url is required regardless of rotationToLatestKeyVersionEnabled value. */\n keyUrl: string;\n}\n\n/** The vault id is an Azure Resource Manager Resource id in the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.KeyVault/vaults/{vaultName} */\nexport interface SourceVault {\n /** Resource Id */\n id?: string;\n}\n\n/** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\nexport interface EncryptionSetIdentity {\n /** The type of Managed Identity used by the DiskEncryptionSet. Only SystemAssigned is supported for new creations. Disk Encryption Sets can be updated with Identity type None during migration of subscription to a new Azure Active Directory tenant; it will cause the encrypted resources to lose access to the keys. */\n type?: DiskEncryptionSetIdentityType;\n /**\n * The object id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-identity-principal-id header in the PUT request if the resource has a systemAssigned(implicit) identity\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The tenant id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-client-tenant-id header in the PUT request if the resource has a systemAssigned(implicit) identity\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The list of user identities associated with the disk encryption set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\n/** The List Disks operation response. */\nexport interface DiskList {\n /** The Disk items on this page */\n value: Disk[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface DiskPurchasePlan {\n /** The plan ID. */\n name: string;\n /** The publisher ID. */\n publisher: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n /** The Offer Promotion Code. */\n promotionCode?: string;\n}\n\n/** List of supported capabilities persisted on the disk resource for VM use. */\nexport interface SupportedCapabilities {\n /** The disk controllers that an OS disk supports. If set it can be SCSI or SCSI, NVME or NVME, SCSI. */\n diskControllerTypes?: string;\n /** True if the image from which the OS disk is created supports accelerated networking. */\n acceleratedNetwork?: boolean;\n /** CPU architecture supported by an OS disk. */\n architecture?: Architecture;\n /** Refers to the security capability of the disk supported to create a Trusted launch or Confidential VM */\n supportedSecurityOption?: SupportedSecurityOption;\n}\n\n/** Data used when creating a disk. */\nexport interface CreationData {\n /** This enumerates the possible sources of a disk's creation. */\n createOption: DiskCreateOption;\n /** Required if createOption is Import. The Azure Resource Manager identifier of the storage account containing the blob to import as a disk. */\n storageAccountId?: string;\n /** Disk source information for PIR or user images. */\n imageReference?: ImageDiskReference;\n /** Required if creating from a Gallery Image. The id/sharedGalleryImageId/communityGalleryImageId of the ImageDiskReference will be the ARM id of the shared galley image version from which to create a disk. */\n galleryImageReference?: ImageDiskReference;\n /** If createOption is Import, this is the URI of a blob to be imported into a managed disk. */\n sourceUri?: string;\n /** If createOption is Copy, this is the ARM id of the source snapshot or disk. */\n sourceResourceId?: string;\n /**\n * If this field is set, this is the unique id identifying the source of this resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceUniqueId?: string;\n /** If createOption is Upload, this is the size of the contents of the upload including the VHD footer. This value should be between 20972032 (20 MiB + 512 bytes for the VHD footer) and 35183298347520 bytes (32 TiB + 512 bytes for the VHD footer). */\n uploadSizeBytes?: number;\n /** Logical sector size in bytes for Ultra disks. Supported values are 512 ad 4096. 4096 is the default. */\n logicalSectorSize?: number;\n /** If createOption is ImportSecure, this is the URI of a blob to be imported into VM guest state. */\n securityDataUri?: string;\n /** If createOption is ImportSecure, this is the URI of a blob to be imported into VM metadata for Confidential VM. */\n securityMetadataUri?: string;\n /** Set this flag to true to get a boost on the performance target of the disk deployed, see here on the respective performance target. This flag can only be set on disk creation time and cannot be disabled after enabled. */\n performancePlus?: boolean;\n /** Required if createOption is CopyFromSanSnapshot. This is the ARM id of the source elastic san volume snapshot. */\n elasticSanResourceId?: string;\n /** If this field is set on a snapshot and createOption is CopyStart, the snapshot will be copied at a quicker speed. */\n provisionedBandwidthCopySpeed?: ProvisionedBandwidthCopyOption;\n /** For snapshots created from Premium SSD v2 or Ultra disk, this property determines the time in minutes the snapshot is retained for instant access to enable faster restore. */\n instantAccessDurationMinutes?: number;\n}\n\n/** The source image used for creating the disk. */\nexport interface ImageDiskReference {\n /** A relative uri containing either a Platform Image Repository, user image, or Azure Compute Gallery image reference. */\n id?: string;\n /** A relative uri containing a direct shared Azure Compute Gallery image reference. */\n sharedGalleryImageId?: string;\n /** A relative uri containing a community Azure Compute Gallery image reference. */\n communityGalleryImageId?: string;\n /** If the disk is created from an image's data disk, this is an index that indicates which of the data disks in the image to use. For OS disks, this field is null. */\n lun?: number;\n}\n\n/** Encryption settings for disk or snapshot */\nexport interface EncryptionSettingsCollection {\n /** Set this flag to true and provide DiskEncryptionKey and optional KeyEncryptionKey to enable encryption. Set this flag to false and remove DiskEncryptionKey and KeyEncryptionKey to disable encryption. If EncryptionSettings is null in the request object, the existing settings remain unchanged. */\n enabled: boolean;\n /** A collection of encryption settings, one for each disk volume. */\n encryptionSettings?: EncryptionSettingsElement[];\n /** Describes what type of encryption is used for the disks. Once this field is set, it cannot be overwritten. '1.0' corresponds to Azure Disk Encryption with AAD app.'1.1' corresponds to Azure Disk Encryption. */\n encryptionSettingsVersion?: string;\n}\n\n/** Encryption settings for one disk volume. */\nexport interface EncryptionSettingsElement {\n /** Key Vault Secret Url and vault id of the disk encryption key */\n diskEncryptionKey?: KeyVaultAndSecretReference;\n /** Key Vault Key Url and vault id of the key encryption key. KeyEncryptionKey is optional and when provided is used to unwrap the disk encryption key. */\n keyEncryptionKey?: KeyVaultAndKeyReference;\n}\n\n/** Key Vault Secret Url and vault id of the encryption key */\nexport interface KeyVaultAndSecretReference {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVault;\n /** Url pointing to a key or secret in KeyVault */\n secretUrl: string;\n}\n\n/** Key Vault Key Url and vault id of KeK, KeK is optional and when provided is used to unwrap the encryptionKey */\nexport interface KeyVaultAndKeyReference {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVault;\n /** Url pointing to a key or secret in KeyVault */\n keyUrl: string;\n}\n\n/** Encryption at rest settings for disk or snapshot */\nexport interface Encryption {\n /** ResourceId of the disk encryption set to use for enabling encryption at rest. */\n diskEncryptionSetId?: string;\n /** The type of key used to encrypt the data of the disk. */\n type?: EncryptionType;\n}\n\nexport interface ShareInfoElement {\n /**\n * A relative URI containing the ID of the VM that has the disk attached.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmUri?: string;\n}\n\n/** Properties of the disk for which update is pending. */\nexport interface PropertyUpdatesInProgress {\n /** The target performance tier of the disk if a tier change operation is in progress. */\n targetTier?: string;\n}\n\n/** Contains the security related information for the resource. */\nexport interface DiskSecurityProfile {\n /** Specifies the SecurityType of the VM. Applicable for OS disks only. */\n securityType?: DiskSecurityTypes;\n /** ResourceId of the disk encryption set associated to Confidential VM supported disk encrypted with customer managed key */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** In the case of an availability or connectivity issue with the data disk, specify the behavior of your VM */\nexport interface AvailabilityPolicy {\n /** Determines on how to handle disks with slow I/O. */\n actionOnDiskDelay?: AvailabilityPolicyDiskDelay;\n}\n\n/** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\nexport interface DiskSku {\n /** The sku name. */\n name?: DiskStorageAccountTypes;\n /**\n * The sku tier.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n}\n\n/** The List Snapshots operation response. */\nexport interface SnapshotList {\n /** A list of snapshots. */\n value: Snapshot[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\nexport interface CopyCompletionError {\n /** Indicates the error code if the background copy of a resource created via the CopyStart operation fails. */\n errorCode: CopyCompletionErrorReason;\n /** Indicates the error message if the background copy of a resource created via the CopyStart operation fails. */\n errorMessage: string;\n}\n\n/** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\nexport interface SnapshotSku {\n /** The sku name. */\n name?: SnapshotStorageAccountTypes;\n /**\n * The sku tier.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n}\n\n/** Used for updating a disk access resource. */\nexport interface DiskAccessUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** A list of private link resources */\nexport interface PrivateEndpointConnectionListResult {\n /** The PrivateEndpointConnection items on this page */\n value: PrivateEndpointConnection[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** A list of private link resources */\nexport interface PrivateLinkResourceListResult {\n /** Array of private link resources */\n value?: PrivateLinkResource[];\n}\n\n/** A private link resource */\nexport interface PrivateLinkResource {\n /**\n * private link resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * private link resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * private link resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * The private link resource group id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly groupId?: string;\n /**\n * The private link resource required member names.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly requiredMembers?: string[];\n /** The private link resource DNS zone name. */\n requiredZoneNames?: string[];\n}\n\n/** disk encryption set update resource. */\nexport interface DiskEncryptionSetUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n /** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\n identity?: EncryptionSetIdentity;\n /** The type of key used to encrypt the data of the disk. */\n encryptionType?: DiskEncryptionSetType;\n /** Key Vault Key Url to be used for server side encryption of Managed Disks and Snapshots */\n activeKey?: KeyForDiskEncryptionSet;\n /** Set this flag to true to enable auto-updating of this disk encryption set to the latest key version. */\n rotationToLatestKeyVersionEnabled?: boolean;\n /** Multi-tenant application client id to access key vault in a different tenant. Setting the value to 'None' will clear the property. */\n federatedClientId?: string;\n}\n\n/** The List resources which are encrypted with the disk encryption set. */\nexport interface ResourceUriList {\n /** A list of IDs or Owner IDs of resources which are encrypted with the disk encryption set. */\n value: string[];\n /** The uri to fetch the next page of encrypted resources. Call ListNext() with this to fetch the next page of encrypted resources. */\n nextLink?: string;\n}\n\n/** Disk update resource. */\nexport interface DiskUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n /** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\n sku?: DiskSku;\n /** the Operating System type. */\n osType?: OperatingSystemTypes;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /** The number of IOPS allowed for this disk; only settable for UltraSSD disks. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadWrite?: number;\n /** The bandwidth allowed for this disk; only settable for UltraSSD disks. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadWrite?: number;\n /** The total number of IOPS that will be allowed across all VMs mounting the shared disk as ReadOnly. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadOnly?: number;\n /** The total throughput (MBps) that will be allowed across all VMs mounting the shared disk as ReadOnly. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadOnly?: number;\n /** The maximum number of VMs that can attach to the disk at the same time. Value greater than one indicates a disk that can be mounted on multiple VMs at the same time. */\n maxShares?: number;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Performance tier of the disk (e.g, P4, S10) as described here: https://azure.microsoft.com/en-us/pricing/details/managed-disks/. Does not apply to Ultra disks. */\n tier?: string;\n /** Set to true to enable bursting beyond the provisioned performance target of the disk. Bursting is disabled by default. Does not apply to Ultra disks. */\n burstingEnabled?: boolean;\n /** Purchase plan information to be added on the OS disk */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities to be added on the OS disk. */\n supportedCapabilities?: SupportedCapabilities;\n /**\n * Properties of the disk for which update is pending.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly propertyUpdatesInProgress?: PropertyUpdatesInProgress;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /** Setting this property to true improves reliability and performance of data disks that are frequently (more than 5 times a day) by detached from one virtual machine and attached to another. This property should not be set for disks that are not detached and attached frequently as it causes the disks to not align with the fault domain of the virtual machine. */\n optimizedForFrequentAttach?: boolean;\n /** Determines how platform treats disk failures */\n availabilityPolicy?: AvailabilityPolicy;\n}\n\n/** Data used for requesting a SAS. */\nexport interface GrantAccessData {\n /** The Access Level, accepted values include None, Read, Write. */\n access: AccessLevel;\n /** Time duration in seconds until the SAS access expires. */\n durationInSeconds: number;\n /** Set this flag to true to get additional SAS for VM guest state */\n getSecureVMGuestStateSAS?: boolean;\n /** Used to specify the file format when making request for SAS on a VHDX file format snapshot */\n fileFormat?: FileFormat;\n}\n\n/** A disk access SAS uri. */\nexport interface AccessUri {\n /**\n * A SAS uri for accessing a disk.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly accessSAS?: string;\n /**\n * A SAS uri for accessing a VM guest state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly securityDataAccessSAS?: string;\n /**\n * A SAS uri for accessing a VM metadata.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly securityMetadataAccessSAS?: string;\n}\n\n/** The List Disk Restore Points operation response. */\nexport interface DiskRestorePointList {\n /** The DiskRestorePoint items on this page */\n value: DiskRestorePoint[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Snapshot update resource. */\nexport interface SnapshotUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n /** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\n sku?: SnapshotSku;\n /** the Operating System type. */\n osType?: OperatingSystemTypes;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Indicates the OS on a snapshot supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilities;\n /**\n * The state of snapshot which determines the access availability of the snapshot.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly snapshotAccessState?: SnapshotAccessState;\n}\n\n/** The List Resource Skus operation response. */\nexport interface ResourceSkusResult {\n /** The ResourceSku items on this page */\n value: ResourceSku[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Describes an available Compute SKU. */\nexport interface ResourceSku {\n /**\n * The type of resource the SKU applies to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resourceType?: string;\n /**\n * The name of SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic**\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n /**\n * The Size of the SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly size?: string;\n /**\n * The Family of this particular SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly family?: string;\n /**\n * The Kind of resources that are supported in this SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly kind?: string;\n /**\n * Specifies the number of virtual machines in the scale set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacity?: ResourceSkuCapacity;\n /**\n * The set of locations that the SKU is available.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly locations?: string[];\n /**\n * A list of locations and availability zones in those locations where the SKU is available.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly locationInfo?: ResourceSkuLocationInfo[];\n /**\n * The api versions that support this SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly apiVersions?: string[];\n /**\n * Metadata for retrieving price info.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly costs?: ResourceSkuCosts[];\n /**\n * A name value pair to describe the capability.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capabilities?: ResourceSkuCapabilities[];\n /**\n * The restrictions because of which SKU cannot be used. This is empty if there are no restrictions.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restrictions?: ResourceSkuRestrictions[];\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuCapacity {\n /**\n * The minimum capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly minimum?: number;\n /**\n * The maximum capacity that can be set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maximum?: number;\n /**\n * The default capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly default?: number;\n /**\n * The scale type applicable to the sku.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly scaleType?: ResourceSkuCapacityScaleType;\n}\n\n/** Describes an available Compute SKU Location Information. */\nexport interface ResourceSkuLocationInfo {\n /**\n * Location of the SKU\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * List of availability zones where the SKU is supported.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zones?: string[];\n /**\n * Details of capabilities available to a SKU in specific zones.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zoneDetails?: ResourceSkuZoneDetails[];\n /**\n * The names of extended locations.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly extendedLocations?: string[];\n /**\n * The type of the extended location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: ExtendedLocationType;\n}\n\n/** Describes The zonal capabilities of a SKU. */\nexport interface ResourceSkuZoneDetails {\n /**\n * The set of zones that the SKU is available in with the specified capabilities.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string[];\n /**\n * A list of capabilities that are available for the SKU in the specified list of zones.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capabilities?: ResourceSkuCapabilities[];\n}\n\n/** Describes The SKU capabilities object. */\nexport interface ResourceSkuCapabilities {\n /**\n * An invariant to describe the feature.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * An invariant if the feature is measured by quantity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly value?: string;\n}\n\n/** Describes metadata for retrieving price info. */\nexport interface ResourceSkuCosts {\n /**\n * Used for querying price from commerce.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly meterID?: string;\n /**\n * The multiplier is needed to extend the base metered cost.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly quantity?: number;\n /**\n * An invariant to show the extended unit.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly extendedUnit?: string;\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuRestrictions {\n /**\n * The type of restrictions.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: ResourceSkuRestrictionsType;\n /**\n * The value of restrictions. If the restriction type is set to location. This would be different locations where the SKU is restricted.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly values?: string[];\n /**\n * The information about the restriction where the SKU cannot be used.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restrictionInfo?: ResourceSkuRestrictionInfo;\n /**\n * The reason for restriction.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reasonCode?: ResourceSkuRestrictionsReasonCode;\n}\n\n/** Describes an available Compute SKU Restriction Information. */\nexport interface ResourceSkuRestrictionInfo {\n /**\n * Locations where the SKU is restricted\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly locations?: string[];\n /**\n * List of availability zones where the SKU is restricted.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zones?: string[];\n}\n\n/** Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). */\nexport interface ErrorResponse {\n /** The error object. */\n error?: ErrorDetail;\n}\n\n/** The error detail. */\nexport interface ErrorDetail {\n /**\n * The error code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * The error message.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly message?: string;\n /**\n * The error target.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly target?: string;\n /**\n * The error details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly details?: ErrorDetail[];\n /**\n * The error additional info.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly additionalInfo?: ErrorAdditionalInfo[];\n}\n\n/** The resource management error additional info. */\nexport interface ErrorAdditionalInfo {\n /**\n * The additional info type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * The additional info.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly info?: any;\n}\n\n/** The List Galleries operation response. */\nexport interface GalleryList {\n /** A list of galleries. */\n value: Gallery[];\n /** The uri to fetch the next page of galleries. Call ListNext() with this to fetch the next page of galleries. */\n nextLink?: string;\n /** The security profile of a gallery image version */\n securityProfile?: ImageVersionSecurityProfile;\n}\n\n/** Describes the gallery unique name. */\nexport interface GalleryIdentifier {\n /**\n * The unique name of the Shared Image Gallery. This name is generated automatically by Azure.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueName?: string;\n}\n\n/** Profile for gallery sharing to subscription or tenant */\nexport interface SharingProfile {\n /** This property allows you to specify the permission of sharing gallery. Possible values are: **Private,** **Groups,** **Community.** */\n permissions?: GallerySharingPermissionTypes;\n /**\n * A list of sharing profile groups.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly groups?: SharingProfileGroup[];\n /** Information of community gallery if current gallery is shared to community. */\n communityGalleryInfo?: CommunityGalleryInfo;\n}\n\n/** Group of the gallery sharing profile */\nexport interface SharingProfileGroup {\n /** This property allows you to specify the type of sharing group. Possible values are: **Subscriptions,** **AADTenants.** */\n type?: SharingProfileGroupTypes;\n /** A list of subscription/tenant ids the gallery is aimed to be shared to. */\n ids?: string[];\n}\n\n/** Information of community gallery if current gallery is shared to community */\nexport interface CommunityGalleryInfo {\n /** The link to the publisher website. Visible to all users. */\n publisherUri?: string;\n /** Community gallery publisher support email. The email address of the publisher. Visible to all users. */\n publisherContact?: string;\n /** End-user license agreement for community gallery image. */\n eula?: string;\n /** The prefix of the gallery name that will be displayed publicly. Visible to all users. */\n publicNamePrefix?: string;\n /**\n * Contains info about whether community gallery sharing is enabled.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly communityGalleryEnabled?: boolean;\n /**\n * Community gallery public name list.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publicNames?: string[];\n}\n\n/** Contains information about the soft deletion policy of the gallery. */\nexport interface SoftDeletePolicy {\n /** Enables soft-deletion for resources in this gallery, allowing them to be recovered within retention time. */\n isSoftDeleteEnabled?: boolean;\n}\n\n/** Sharing status of current gallery. */\nexport interface SharingStatus {\n /**\n * Aggregated sharing state of current gallery.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly aggregatedState?: SharingState;\n /** Summary of all regional sharing status. */\n summary?: RegionalSharingStatus[];\n}\n\n/** Gallery regional sharing status */\nexport interface RegionalSharingStatus {\n /** Region name */\n region?: string;\n /**\n * Gallery sharing state in current region\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly state?: SharingState;\n /** Details of gallery regional sharing failure. */\n details?: string;\n}\n\n/** Identity for the virtual machine. */\nexport interface GalleryIdentity {\n /**\n * The principal id of the gallery identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The AAD tenant id of the gallery identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The type of identity used for the gallery. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove all identities from the gallery. */\n type?: ResourceIdentityType;\n /** The list of user identities associated with the gallery. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\n/** The security profile of a gallery image version */\nexport interface ImageVersionSecurityProfile {\n /** Contains UEFI settings for the image version. */\n uefiSettings?: GalleryImageVersionUefiSettings;\n}\n\n/** Contains UEFI settings for the image version. */\nexport interface GalleryImageVersionUefiSettings {\n /** The name of the template(s) that contains default UEFI key signatures that will be added to the image. */\n signatureTemplateNames?: UefiSignatureTemplateName[];\n /** Additional UEFI key signatures that will be added to the image in addition to the signature templates */\n additionalSignatures?: UefiKeySignatures;\n}\n\n/** Additional UEFI key signatures that will be added to the image in addition to the signature templates */\nexport interface UefiKeySignatures {\n /** The Platform Key of this image version. */\n pk?: UefiKey;\n /** The Key Encryption Keys of this image version. */\n kek?: UefiKey[];\n /** The database of UEFI keys for this image version. */\n db?: UefiKey[];\n /** The database of revoked UEFI keys for this image version. */\n dbx?: UefiKey[];\n}\n\n/** A UEFI key signature. */\nexport interface UefiKey {\n /** The type of key signature. */\n type?: UefiKeyType;\n /** The value of the key signature. */\n value?: string[];\n}\n\n/** The metadata of community gallery. */\nexport interface CommunityGalleryMetadata {\n /** The publisher URI of this community gallery. */\n publisherUri?: string;\n /** The publisher email id of this community gallery. */\n publisherContact: string;\n /** The end-user license agreement for this community gallery. */\n eula?: string;\n /** A list of public names the gallery has. */\n publicNames: string[];\n /** The link for the privacy statement of this community gallery from the gallery publisher. */\n privacyStatementUri?: string;\n}\n\n/** Base information about the community gallery resource in azure compute gallery. */\nexport interface PirCommunityGalleryResource {\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** The unique id of this community gallery. */\n uniqueId?: string;\n}\n\n/** The List Community Gallery Images operation response. */\nexport interface CommunityGalleryImageList {\n /** A list of community gallery images. */\n value: CommunityGalleryImage[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** This is the community gallery image definition identifier. */\nexport interface CommunityGalleryImageIdentifier {\n /** The name of the gallery image definition publisher. */\n publisher?: string;\n /** The name of the gallery image definition offer. */\n offer?: string;\n /** The name of the gallery image definition SKU. */\n sku?: string;\n}\n\n/** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\nexport interface RecommendedMachineConfiguration {\n /** Describes the resource range. */\n vCPUs?: ResourceRange;\n /** Describes the resource range. */\n memory?: ResourceRange;\n}\n\n/** Describes the resource range. */\nexport interface ResourceRange {\n /** The minimum number of the resource. */\n min?: number;\n /** The maximum number of the resource. */\n max?: number;\n}\n\n/** Describes the disallowed disk types. */\nexport interface Disallowed {\n /** A list of disk types. */\n diskTypes?: string[];\n}\n\n/** A feature for gallery image. */\nexport interface GalleryImageFeature {\n /** The name of the gallery image feature. */\n name?: string;\n /** The value of the gallery image feature. */\n value?: string;\n /** The minimum gallery image version which supports this feature. */\n startsAtVersion?: string;\n}\n\n/** Describes the gallery image definition purchase plan. This is used by marketplace images. */\nexport interface ImagePurchasePlan {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** The product ID. */\n product?: string;\n}\n\n/** The List Community Gallery Image versions operation response. */\nexport interface CommunityGalleryImageVersionList {\n /** A list of community gallery image versions. */\n value: CommunityGalleryImageVersion[];\n /** The URI to fetch the next page of community gallery image versions. Call ListNext() with this to fetch the next page of community gallery image versions. */\n nextLink?: string;\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface SharedGalleryImageVersionStorageProfile {\n /** This is the OS disk image. */\n osDiskImage?: SharedGalleryOSDiskImage;\n /** A list of data disk images. */\n dataDiskImages?: SharedGalleryDataDiskImage[];\n}\n\n/** This is the disk image base class. */\nexport interface SharedGalleryDiskImage {\n /**\n * This property indicates the size of the VHD to be created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: SharedGalleryHostCaching;\n}\n\n/** The List Shared Galleries operation response. */\nexport interface SharedGalleryList {\n /** A list of shared galleries. */\n value: SharedGallery[];\n /** The uri to fetch the next page of shared galleries. Call ListNext() with this to fetch the next page of shared galleries. */\n nextLink?: string;\n}\n\n/** The Resource model definition. */\nexport interface PirResource {\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n}\n\n/** The List Shared Gallery Images operation response. */\nexport interface SharedGalleryImageList {\n /** A list of shared gallery images. */\n value: SharedGalleryImage[];\n /** The uri to fetch the next page of shared gallery images. Call ListNext() with this to fetch the next page of shared gallery images. */\n nextLink?: string;\n}\n\n/** This is the gallery image definition identifier. */\nexport interface GalleryImageIdentifier {\n /** The name of the gallery image definition publisher. */\n publisher: string;\n /** The name of the gallery image definition offer. */\n offer: string;\n /** The name of the gallery image definition SKU. */\n sku: string;\n}\n\n/** The List Shared Gallery Image versions operation response. */\nexport interface SharedGalleryImageVersionList {\n /** The SharedGalleryImageVersion items on this page */\n value: SharedGalleryImageVersion[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** The Update Resource model definition. */\nexport interface UpdateResourceDefinition {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** The List Gallery Applications operation response. */\nexport interface GalleryApplicationList {\n /** The GalleryApplication items on this page */\n value: GalleryApplication[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** A custom action that can be performed with a Gallery Application Version. */\nexport interface GalleryApplicationCustomAction {\n /** The name of the custom action. Must be unique within the Gallery Application Version. */\n name: string;\n /** The script to run when executing this custom action. */\n script: string;\n /** Description to help the users understand what this custom action does. */\n description?: string;\n /** The parameters that this custom action uses */\n parameters?: GalleryApplicationCustomActionParameter[];\n}\n\n/** The definition of a parameter that can be passed to a custom action of a Gallery Application Version. */\nexport interface GalleryApplicationCustomActionParameter {\n /** The name of the custom action. Must be unique within the Gallery Application Version. */\n name: string;\n /** Indicates whether this parameter must be passed when running the custom action. */\n required?: boolean;\n /** Specifies the type of the custom action parameter. Possible values are: String, ConfigurationDataBlob or LogOutputBlob */\n type?: GalleryApplicationCustomActionParameterType;\n /** The default value of the parameter. Only applies to string types */\n defaultValue?: string;\n /** A description to help users understand what this parameter means */\n description?: string;\n}\n\n/** The List Gallery Application version operation response. */\nexport interface GalleryApplicationVersionList {\n /** A list of gallery Application Versions. */\n value: GalleryApplicationVersion[];\n /** The uri to fetch the next page of gallery Application Versions. Call ListNext() with this to fetch the next page of gallery Application Versions. */\n nextLink?: string;\n}\n\n/** The source image from which the Image Version is going to be created. */\nexport interface UserArtifactSource {\n /** Required. The mediaLink of the artifact, must be a readable storage page blob. */\n mediaLink: string;\n /** Optional. The defaultConfigurationLink of the artifact, must be a readable storage page blob. */\n defaultConfigurationLink?: string;\n}\n\nexport interface UserArtifactManage {\n /** Required. The path and arguments to install the gallery application. This is limited to 4096 characters. */\n install: string;\n /** Required. The path and arguments to remove the gallery application. This is limited to 4096 characters. */\n remove: string;\n /** Optional. The path and arguments to update the gallery application. If not present, then update operation will invoke remove command on the previous version and install command on the current version of the gallery application. This is limited to 4096 characters. */\n update?: string;\n}\n\n/** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\nexport interface UserArtifactSettings {\n /** Optional. The name to assign the downloaded package file on the VM. This is limited to 4096 characters. If not specified, the package file will be named the same as the Gallery Application name. */\n packageFileName?: string;\n /** Optional. The name to assign the downloaded config file on the VM. This is limited to 4096 characters. If not specified, the config file will be named the Gallery Application name appended with \"_config\". */\n configFileName?: string;\n /** Optional. The action to be taken with regards to install/update/remove of the gallery application in the event of a reboot. */\n scriptBehaviorAfterReboot?: GalleryApplicationScriptRebootBehavior;\n}\n\n/** Describes the basic gallery artifact publishing profile. */\nexport interface GalleryArtifactPublishingProfileBase {\n /** The target regions where the Image Version is going to be replicated to. This property is updatable. */\n targetRegions?: TargetRegion[];\n /** The number of replicas of the Image Version to be created per region. This property would take effect for a region when regionalReplicaCount is not specified. This property is updatable. */\n replicaCount?: number;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the gallery image version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /** The end of life date of the gallery image version. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: StorageAccountType;\n /** Optional parameter which specifies the mode to be used for replication. This property is not updatable. */\n replicationMode?: ReplicationMode;\n /** The target extended locations where the Image Version is going to be replicated to. This property is updatable. */\n targetExtendedLocations?: GalleryTargetExtendedLocation[];\n}\n\n/** Describes the target region information. */\nexport interface TargetRegion {\n /** The name of the region. */\n name: string;\n /** The number of replicas of the Image Version to be created per region. This property is updatable. */\n regionalReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: StorageAccountType;\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImages;\n /** Contains the flag setting to hide an image when users specify version='latest' */\n excludeFromLatest?: boolean;\n /** List of storage sku with replica count to create direct drive replicas. */\n additionalReplicaSets?: AdditionalReplicaSet[];\n}\n\n/** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\nexport interface EncryptionImages {\n /** Contains encryption settings for an OS disk image. */\n osDiskImage?: OSDiskImageEncryption;\n /** A list of encryption specifications for data disk images. */\n dataDiskImages?: DataDiskImageEncryption[];\n}\n\n/** Contains security profile for an OS disk image. */\nexport interface OSDiskImageSecurityProfile {\n /** confidential VM encryption types */\n confidentialVMEncryptionType?: ConfidentialVMEncryptionType;\n /** secure VM disk encryption set id */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** This is the disk image encryption base class. */\nexport interface DiskImageEncryption {\n /** A relative URI containing the resource ID of the disk encryption set. */\n diskEncryptionSetId?: string;\n}\n\n/** Describes the additional replica set information. */\nexport interface AdditionalReplicaSet {\n /** Specifies the storage account type to be used to create the direct drive replicas */\n storageAccountType?: StorageAccountType;\n /** The number of direct drive replicas of the Image Version to be created.This Property is updatable */\n regionalReplicaCount?: number;\n}\n\nexport interface GalleryTargetExtendedLocation {\n /** The name of the region. */\n name?: string;\n /** The name of the extended location. */\n extendedLocation?: GalleryExtendedLocation;\n /** The number of replicas of the Image Version to be created per extended location. This property is updatable. */\n extendedLocationReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: EdgeZoneStorageAccountType;\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImages;\n}\n\n/** The name of the extended location. */\nexport interface GalleryExtendedLocation {\n name?: string;\n /** It is type of the extended location. */\n type?: GalleryExtendedLocationType;\n}\n\n/** This is the safety profile of the Gallery Artifact Version. */\nexport interface GalleryArtifactSafetyProfileBase {\n /** Indicates whether or not removing this Gallery Image Version from replicated regions is allowed. */\n allowDeletionOfReplicatedLocations?: boolean;\n}\n\n/** This is the replication status of the gallery image version. */\nexport interface ReplicationStatus {\n /**\n * This is the aggregated replication status based on all the regional replication status flags.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly aggregatedState?: AggregatedReplicationState;\n /**\n * This is a summary of replication status for each region.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly summary?: RegionalReplicationStatus[];\n}\n\n/** This is the regional replication status. */\nexport interface RegionalReplicationStatus {\n /**\n * The region to which the gallery image version is being replicated to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly region?: string;\n /**\n * This is the regional replication state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly state?: ReplicationState;\n /**\n * The details of the replication status.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly details?: string;\n /**\n * It indicates progress of the replication job.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly progress?: number;\n}\n\n/** The List Gallery Images operation response. */\nexport interface GalleryImageList {\n /** A list of Shared Image Gallery images. */\n value: GalleryImage[];\n /** The uri to fetch the next page of Image Definitions in the Shared Image Gallery. Call ListNext() with this to fetch the next page of gallery image definitions. */\n nextLink?: string;\n}\n\n/** The List Gallery Image version operation response. */\nexport interface GalleryImageVersionList {\n /** A list of gallery image versions. */\n value: GalleryImageVersion[];\n /** The uri to fetch the next page of gallery image versions. Call ListNext() with this to fetch the next page of gallery image versions. */\n nextLink?: string;\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface GalleryImageVersionStorageProfile {\n /** The source of the gallery artifact version. */\n source?: GalleryArtifactVersionFullSource;\n /** This is the OS disk image. */\n osDiskImage?: GalleryOSDiskImage;\n /** A list of data disk images. */\n dataDiskImages?: GalleryDataDiskImage[];\n}\n\n/** The gallery artifact version source. */\nexport interface GalleryArtifactVersionSource {\n /** The id of the gallery artifact version source. */\n id?: string;\n}\n\n/** This is the disk image base class. */\nexport interface GalleryDiskImage {\n /**\n * This property indicates the size of the VHD to be created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sizeInGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: HostCaching;\n /** The source for the disk image. */\n source?: GalleryDiskImageSource;\n}\n\n/** A policy violation reported against a gallery artifact. */\nexport interface PolicyViolation {\n /** Describes the nature of the policy violation. */\n category?: PolicyViolationCategory;\n /** Describes specific details about why this policy violation was reported. */\n details?: string;\n}\n\n/** This is the validations profile of a Gallery Image Version. */\nexport interface ValidationsProfile {\n /** The published time of the image version */\n validationEtag?: string;\n executedValidations?: ExecutedValidation[];\n /** This specifies the pub, offer, sku and version of the image version metadata */\n platformAttributes?: PlatformAttribute[];\n}\n\n/** This is the executed Validation. */\nexport interface ExecutedValidation {\n /** This property specifies the type of image version validation. */\n type?: string;\n /** This property specifies the status of the validationProfile of the image version. */\n status?: ValidationStatus;\n /** This property specifies the valid version of the validation. */\n version?: string;\n /** This property specifies the starting timestamp. */\n executionTime?: Date;\n}\n\n/** This is the platform attribute of the image version. */\nexport interface PlatformAttribute {\n /**\n * This property specifies the name of the platformAttribute. It is read-only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * This property specifies the value of the corresponding name property. It is read-only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly value?: string;\n}\n\n/** The List Gallery InVMAccessControlProfiles operation response. */\nexport interface GalleryInVMAccessControlProfileList {\n /** The GalleryInVMAccessControlProfile items on this page */\n value: GalleryInVMAccessControlProfile[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** The properties of a gallery ResourceProfile. */\nexport interface GalleryResourceProfilePropertiesBase {\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n}\n\n/** The List Gallery InVMAccessControlProfile Versions operation response. */\nexport interface GalleryInVMAccessControlProfileVersionList {\n /** The GalleryInVMAccessControlProfileVersion items on this page */\n value: GalleryInVMAccessControlProfileVersion[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\nexport interface AccessControlRules {\n /** A list of privileges. */\n privileges?: AccessControlRulesPrivilege[];\n /** A list of roles. */\n roles?: AccessControlRulesRole[];\n /** A list of identities. */\n identities?: AccessControlRulesIdentity[];\n /** A list of role assignments. */\n roleAssignments?: AccessControlRulesRoleAssignment[];\n}\n\n/** The properties of an Access Control Rule Privilege. */\nexport interface AccessControlRulesPrivilege {\n /** The name of the privilege. */\n name: string;\n /** The HTTP path corresponding to the privilege. */\n path: string;\n /** The query parameters to match in the path. */\n queryParameters?: { [propertyName: string]: string };\n}\n\n/** The properties of an Access Control Rule Role. */\nexport interface AccessControlRulesRole {\n /** The name of the role. */\n name: string;\n /** A list of privileges needed by this role. */\n privileges: string[];\n}\n\n/** The properties of an Access Control Rule Identity. */\nexport interface AccessControlRulesIdentity {\n /** The name of the identity. */\n name: string;\n /** The username corresponding to this identity. */\n userName?: string;\n /** The groupName corresponding to this identity. */\n groupName?: string;\n /** The path to the executable. */\n exePath?: string;\n /** The process name of the executable. */\n processName?: string;\n}\n\n/** The properties of an Access Control Rule RoleAssignment. */\nexport interface AccessControlRulesRoleAssignment {\n /** The name of the role. */\n role: string;\n /** A list of identities that can access the privileges defined by the role. */\n identities: string[];\n}\n\n/** The properties of a gallery ResourceProfile version. */\nexport interface GalleryResourceProfileVersionPropertiesBase {\n /** The target regions where the Resource Profile version is going to be replicated to. This property is updatable. */\n targetLocations?: TargetRegion[];\n /** If set to true, Virtual Machines deployed from the latest version of the Resource Profile won't use this Profile version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the Resource Profile Version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** Specifies information about the gallery sharing profile update. */\nexport interface SharingUpdate {\n /** This property allows you to specify the operation type of gallery sharing update. Possible values are: **Add,** **Remove,** **Reset.** */\n operationType: SharingUpdateOperationTypes;\n /** A list of sharing profile groups. */\n groups?: SharingProfileGroup[];\n}\n\n/** The List Soft-deleted Resources operation response. */\nexport interface GallerySoftDeletedResourceList {\n /** The GallerySoftDeletedResource items on this page */\n value: GallerySoftDeletedResource[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Describes the cloud service role instance. */\nexport interface RoleInstance {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource Name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource Type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource Location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * Resource tags.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tags?: { [propertyName: string]: string };\n /** The role instance SKU. */\n sku?: InstanceSku;\n /** Role instance properties. */\n properties?: RoleInstanceProperties;\n}\n\n/** The role instance SKU. */\nexport interface InstanceSku {\n /**\n * The sku name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The tier of the cloud service role instance.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n}\n\n/** Role instance properties. */\nexport interface RoleInstanceProperties {\n /** Describes the network profile for the role instance. */\n networkProfile?: RoleInstanceNetworkProfile;\n /** The instance view of the role instance. */\n instanceView?: RoleInstanceView;\n}\n\n/** Describes the network profile for the role instance. */\nexport interface RoleInstanceNetworkProfile {\n /**\n * Specifies the list of resource Ids for the network interfaces associated with the role instance.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly networkInterfaces?: SubResource[];\n}\n\n/** The instance view of the role instance. */\nexport interface RoleInstanceView {\n /**\n * The Update Domain.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformUpdateDomain?: number;\n /**\n * The Fault Domain.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformFaultDomain?: number;\n /**\n * Specifies a unique identifier generated internally for the cloud service associated with this role instance. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateId?: string;\n /** NOTE: This property will not be serialized. It can only be populated by the server. */\n readonly statuses?: ResourceInstanceViewStatus[];\n}\n\n/** Instance view status. */\nexport interface ResourceInstanceViewStatus {\n /**\n * The status code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * The short localizable label for the status.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly displayStatus?: string;\n /**\n * The detailed status message, including for alerts and error messages.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly message?: string;\n /**\n * The time of the status.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly time?: Date;\n /** The level code. */\n level?: StatusLevelTypes;\n}\n\n/** The list operation result. */\nexport interface RoleInstanceListResult {\n /** The list of resources. */\n value: RoleInstance[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a role of the cloud service. */\nexport interface CloudServiceRole {\n /**\n * Resource id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSku;\n /** The cloud service role properties. */\n properties?: CloudServiceRoleProperties;\n}\n\n/** Describes the cloud service role sku. */\nexport interface CloudServiceRoleSku {\n /** The sku name. NOTE: If the new SKU is not supported on the hardware the cloud service is currently on, you need to delete and recreate the cloud service or move back to the old sku. */\n name?: string;\n /** Specifies the tier of the cloud service. Possible Values are <br /><br /> **Standard** <br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of role instances in the cloud service. */\n capacity?: number;\n}\n\n/** The cloud service role properties. */\nexport interface CloudServiceRoleProperties {\n /**\n * Specifies the ID which uniquely identifies a cloud service role.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n}\n\n/** The list operation result. */\nexport interface CloudServiceRoleListResult {\n /** The list of resources. */\n value: CloudServiceRole[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes the cloud service. */\nexport interface CloudService {\n /**\n * Resource Id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource location. */\n location: string;\n /** Resource tags. */\n tags?: { [propertyName: string]: string };\n /** Cloud service properties */\n properties?: CloudServiceProperties;\n /**\n * Metadata pertaining to creation and last modification of the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly systemData?: SystemData;\n /** List of logical availability zone of the resource. List should contain only 1 zone where cloud service should be provisioned. This field is optional. */\n zones?: string[];\n}\n\n/** Cloud service properties */\nexport interface CloudServiceProperties {\n /**\n * Specifies a URL that refers to the location of the service package in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n packageUrl?: string;\n /** Specifies the XML service configuration (.cscfg) for the cloud service. */\n configuration?: string;\n /**\n * Specifies a URL that refers to the location of the service configuration in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n configurationUrl?: string;\n /**\n * (Optional) Indicates whether to start the cloud service immediately after it is created. The default value is `true`.\n * If false, the service model is still deployed, but the code is not run immediately. Instead, the service is PoweredOff until you call Start, at which time the service will be started. A deployed service still incurs charges, even if it is poweredoff.\n */\n startCloudService?: boolean;\n /**\n * (Optional) Indicates whether the role sku properties (roleProfile.roles.sku) specified in the model/template should override the role instance count and vm size specified in the .cscfg and .csdef respectively.\n * The default value is `false`.\n */\n allowModelOverride?: boolean;\n /**\n * Update mode for the cloud service. Role instances are allocated to update domains when the service is deployed. Updates can be initiated manually in each update domain or initiated automatically in all update domains.\n * Possible Values are <br /><br />**Auto**<br /><br />**Manual** <br /><br />**Simultaneous**<br /><br />\n * If not specified, the default value is Auto. If set to Manual, PUT UpdateDomain must be called to apply the update. If set to Auto, the update is automatically applied to each update domain in sequence.\n */\n upgradeMode?: CloudServiceUpgradeMode;\n /** Describes the role profile for the cloud service. */\n roleProfile?: CloudServiceRoleProfile;\n /** Describes the OS profile for the cloud service. */\n osProfile?: CloudServiceOsProfile;\n /** Network Profile for the cloud service. */\n networkProfile?: CloudServiceNetworkProfile;\n /** Describes a cloud service extension profile. */\n extensionProfile?: CloudServiceExtensionProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The unique identifier for the cloud service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n}\n\n/** Describes the role profile for the cloud service. */\nexport interface CloudServiceRoleProfile {\n /** List of roles for the cloud service. */\n roles?: CloudServiceRoleProfileProperties[];\n}\n\n/** Describes the role properties. */\nexport interface CloudServiceRoleProfileProperties {\n /** Resource name. */\n name?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSku;\n}\n\n/** Describes the OS profile for the cloud service. */\nexport interface CloudServiceOsProfile {\n /** Specifies set of certificates that should be installed onto the role instances. */\n secrets?: CloudServiceVaultSecretGroup[];\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface CloudServiceVaultSecretGroup {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResource;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: CloudServiceVaultCertificate[];\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the role instance. */\nexport interface CloudServiceVaultCertificate {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. */\n certificateUrl?: string;\n /** Flag indicating if the certificate provided is a bootstrap certificate to be used by the Key Vault Extension to fetch the remaining certificates. */\n isBootstrapCertificate?: boolean;\n}\n\n/** Network Profile for the cloud service. */\nexport interface CloudServiceNetworkProfile {\n /** List of Load balancer configurations. Cloud service can have up to two load balancer configurations, corresponding to a Public Load Balancer and an Internal Load Balancer. */\n loadBalancerConfigurations?: LoadBalancerConfiguration[];\n /**\n * Slot type for the cloud service.\n * Possible values are <br /><br />**Production**<br /><br />**Staging**<br /><br />\n * If not specified, the default value is Production.\n */\n slotType?: CloudServiceSlotType;\n /** The id reference of the cloud service containing the target IP with which the subject cloud service can perform a swap. This property cannot be updated once it is set. The swappable cloud service referred by this id must be present otherwise an error will be thrown. */\n swappableCloudService?: SubResource;\n}\n\n/** Describes the load balancer configuration. */\nexport interface LoadBalancerConfiguration {\n /** Resource Id */\n id?: string;\n /** The name of the Load balancer */\n name: string;\n /** Properties of the load balancer configuration. */\n properties: LoadBalancerConfigurationProperties;\n}\n\n/** Describes the properties of the load balancer configuration. */\nexport interface LoadBalancerConfigurationProperties {\n /** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\n frontendIpConfigurations: LoadBalancerFrontendIpConfiguration[];\n}\n\n/** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\nexport interface LoadBalancerFrontendIpConfiguration {\n /** The name of the resource that is unique within the set of frontend IP configurations used by the load balancer. This name can be used to access the resource. */\n name: string;\n /** Properties of load balancer frontend ip configuration. */\n properties: LoadBalancerFrontendIpConfigurationProperties;\n}\n\n/** Describes a cloud service IP Configuration */\nexport interface LoadBalancerFrontendIpConfigurationProperties {\n /** The reference to the public ip address resource. */\n publicIPAddress?: SubResource;\n /** The reference to the virtual network subnet resource. */\n subnet?: SubResource;\n /** The virtual network private IP address of the IP configuration. */\n privateIPAddress?: string;\n}\n\n/** Describes a cloud service extension profile. */\nexport interface CloudServiceExtensionProfile {\n /** List of extensions for the cloud service. */\n extensions?: Extension[];\n}\n\n/** Describes a cloud service Extension. */\nexport interface Extension {\n /** The name of the extension. */\n name?: string;\n /** Extension Properties. */\n properties?: CloudServiceExtensionProperties;\n}\n\n/** Extension Properties. */\nexport interface CloudServiceExtensionProperties {\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension. */\n type?: string;\n /** Specifies the version of the extension. Specifies the version of the extension. If this element is not specified or an asterisk (*) is used as the value, the latest version of the extension is used. If the value is specified with a major version number and an asterisk as the minor version number (X.), the latest minor version of the specified major version is selected. If a major version number and a minor version number are specified (X.Y), the specific extension version is selected. If a version is specified, an auto-upgrade is performed on the role instance. */\n typeHandlerVersion?: string;\n /** Explicitly specify whether platform can automatically upgrade typeHandlerVersion to higher minor versions when they become available. */\n autoUpgradeMinorVersion?: boolean;\n /** Public settings for the extension. For JSON extensions, this is the JSON settings for the extension. For XML Extension (like RDP), this is the XML setting for the extension. */\n settings?: any;\n /** Protected settings for the extension which are encrypted before sent to the role instance. */\n protectedSettings?: any;\n /** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\n protectedSettingsFromKeyVault?: CloudServiceVaultAndSecretReference;\n /**\n * Tag to force apply the provided public and protected settings.\n * Changing the tag value allows for re-running the extension without changing any of the public or protected settings.\n * If forceUpdateTag is not changed, updates to public or protected settings would still be applied by the handler.\n * If neither forceUpdateTag nor any of public or protected settings change, extension would flow to the role instance with the same sequence-number, and\n * it is up to handler implementation whether to re-run it or not\n */\n forceUpdateTag?: string;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Optional list of roles to apply this extension. If property is not specified or '*' is specified, extension is applied to all roles in the cloud service. */\n rolesAppliedTo?: string[];\n}\n\n/** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\nexport interface CloudServiceVaultAndSecretReference {\n /** The ARM Resource ID of the Key Vault */\n sourceVault?: SubResource;\n /** Secret URL which contains the protected settings of the extension */\n secretUrl?: string;\n}\n\nexport interface CloudServiceUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** InstanceView of CloudService as a whole */\nexport interface CloudServiceInstanceView {\n /** Instance view statuses. */\n roleInstance?: InstanceViewStatusesSummary;\n /**\n * The version of the SDK that was used to generate the package for the cloud service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sdkVersion?: string;\n /**\n * Specifies a list of unique identifiers generated internally for the cloud service. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateIds?: string[];\n /** NOTE: This property will not be serialized. It can only be populated by the server. */\n readonly statuses?: ResourceInstanceViewStatus[];\n}\n\n/** Instance view statuses. */\nexport interface InstanceViewStatusesSummary {\n /**\n * The summary.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statusesSummary?: StatusCodeCount[];\n}\n\n/** The status code and count of the cloud service instance view statuses */\nexport interface StatusCodeCount {\n /**\n * The instance view status code\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * Number of instances having this status code\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly count?: number;\n}\n\n/** The list operation result. */\nexport interface CloudServiceListResult {\n /** The list of resources. */\n value: CloudService[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Specifies a list of role instances from the cloud service. */\nexport interface RoleInstances {\n /** List of cloud service role instance names. Value of '*' will signify all role instances of the cloud service. */\n roleInstances: string[];\n}\n\n/** Defines an update domain for the cloud service. */\nexport interface UpdateDomain {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource Name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n}\n\n/** The list operation result. */\nexport interface UpdateDomainListResult {\n /** The list of resources. */\n value: UpdateDomain[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS version. */\nexport interface OSVersion {\n /**\n * Resource Id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** OS version properties. */\n properties?: OSVersionProperties;\n}\n\n/** OS version properties. */\nexport interface OSVersionProperties {\n /**\n * The family of this OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly family?: string;\n /**\n * The family label of this OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly familyLabel?: string;\n /**\n * The OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The OS version label.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly label?: string;\n /**\n * Specifies whether this is the default OS version for its family.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isDefault?: boolean;\n /**\n * Specifies whether this OS version is active.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSVersionListResult {\n /** The list of resources. */\n value: OSVersion[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS family. */\nexport interface OSFamily {\n /**\n * Resource Id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** OS family properties. */\n properties?: OSFamilyProperties;\n}\n\n/** OS family properties. */\nexport interface OSFamilyProperties {\n /**\n * The OS family name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The OS family label.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly label?: string;\n /**\n * List of OS versions belonging to this family.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly versions?: OSVersionPropertiesBase[];\n}\n\n/** Configuration view of an OS version. */\nexport interface OSVersionPropertiesBase {\n /**\n * The OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The OS version label.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly label?: string;\n /**\n * Specifies whether this is the default OS version for its family.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isDefault?: boolean;\n /**\n * Specifies whether this OS version is active.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSFamilyListResult {\n /** The list of resources. */\n value: OSFamily[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** The Resource model definition with location property as optional. */\nexport interface ResourceWithOptionalLocation {\n /** Resource location */\n location?: string;\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** Describes the parameter of customer managed disk encryption set resource id that can be specified for disk. **Note:** The disk encryption set resource id can only be specified for managed disk. Please refer https://aka.ms/mdssewithcmkoverview for more details. */\nexport interface DiskEncryptionSetParameters extends SubResource {}\n\n/** Virtual machine image resource information. */\nexport interface VirtualMachineImageResource extends SubResource {\n /** The name of the resource. */\n name: string;\n /** The supported Azure location of the resource. */\n location: string;\n /** Specifies the tags that are assigned to the virtual machine. For more information about using tags, see [Using tags to organize your Azure resources](https://docs.microsoft.com/azure/azure-resource-manager/resource-group-using-tags.md). */\n tags?: { [propertyName: string]: string };\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocation;\n}\n\n/** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. NOTE: Image reference publisher and offer can only be set when you create the scale set. */\nexport interface ImageReference extends SubResource {\n /** The image publisher. */\n publisher?: string;\n /** Specifies the offer of the platform image or marketplace image used to create the virtual machine. */\n offer?: string;\n /** The image SKU. */\n sku?: string;\n /** Specifies the version of the platform image or marketplace image used to create the virtual machine. The allowed formats are Major.Minor.Build or 'latest'. Major, Minor, and Build are decimal numbers. Specify 'latest' to use the latest version of an image available at deploy time. Even if you use 'latest', the VM image will not automatically update after deploy time even if a new version becomes available. Please do not use field 'version' for gallery image deployment, gallery image should always use 'id' field for deployment, to use 'latest' version of gallery image, just set '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/images/{imageName}' in the 'id' field without version input. */\n version?: string;\n /**\n * Specifies in decimal numbers, the version of platform image or marketplace image used to create the virtual machine. This readonly field differs from 'version', only if the value specified in 'version' field is 'latest'.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly exactVersion?: string;\n /** Specified the shared gallery image unique id for vm deployment. This can be fetched from shared gallery image GET call. */\n sharedGalleryImageId?: string;\n /** Specified the community gallery image unique id for vm deployment. This can be fetched from community gallery image GET call. */\n communityGalleryImageId?: string;\n}\n\n/** The parameters of a managed disk. */\nexport interface ManagedDiskParameters extends SubResource {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?: StorageAccountTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfile;\n}\n\n/** Describes a network interface reference. */\nexport interface NetworkInterfaceReference extends SubResource {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n}\n\nexport interface SubResourceWithColocationStatus extends SubResource {\n /** Describes colocation status of a resource in the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatus;\n}\n\n/** Output of virtual machine capture operation. */\nexport interface VirtualMachineCaptureResult extends SubResource {\n /**\n * the schema of the captured virtual machine\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly schema?: string;\n /**\n * the version of the content\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly contentVersion?: string;\n /**\n * parameters of the captured virtual machine\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly parameters?: any;\n /**\n * a list of resource items of the captured virtual machine\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resources?: any[];\n}\n\n/** The resource model definition for an Azure Resource Manager tracked top level resource which has 'tags' and a 'location' */\nexport interface TrackedResource extends Resource {\n /** Resource tags. */\n tags?: { [propertyName: string]: string };\n /** The geo-location where the resource lives */\n location: string;\n}\n\n/** The resource model definition for a Azure Resource Manager proxy resource. It will not have tags and a location */\nexport interface ProxyResource extends Resource {}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtension extends SubResourceReadOnly {\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource name */\n name?: string;\n /** If a value is provided and is different from the previous value, the extension handler will be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** Disk Restore Point details. */\nexport interface DiskRestorePointAttributes extends SubResourceReadOnly {\n /** Encryption at rest settings for disk restore point. It is an optional property that can be specified in the input while creating a restore point. */\n encryption?: RestorePointEncryption;\n /** Resource Id of the source disk restore point. */\n sourceDiskRestorePoint?: ApiEntityReference;\n}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionUpdate extends SubResourceReadOnly {\n /**\n * The name of the extension.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** If a value is provided and is different from the previous value, the extension handler will be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtension extends SubResourceReadOnly {\n /** The location of the extension. */\n location?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** The virtual machine extension instance view. */\n instanceView?: VirtualMachineExtensionInstanceView;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtensionUpdate extends SubResourceReadOnly {\n /**\n * The name of the extension.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** The instance view of a capacity reservation that includes the name of the capacity reservation. It is used for the response to the instance view of a capacity reservation group. */\nexport interface CapacityReservationInstanceViewWithName extends CapacityReservationInstanceView {\n /**\n * The name of the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n}\n\n/** The instance view of a dedicated host that includes the name of the dedicated host. It is used for the response to the instance view of a dedicated host group. */\nexport interface DedicatedHostInstanceViewWithName extends DedicatedHostInstanceView {\n /**\n * The name of the dedicated host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n}\n\n/** Describes an Operating System disk. */\nexport interface ImageOSDisk extends ImageDisk {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from a custom image. Possible values are: **Windows,** **Linux.** */\n osType: OperatingSystemTypes;\n /** The OS State. For managed images, use Generalized. */\n osState: OperatingSystemStateTypes;\n}\n\n/** Describes a data disk. */\nexport interface ImageDataDisk extends ImageDisk {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n}\n\n/** Api request input for LogAnalytics getRequestRateByInterval Api. */\nexport interface RequestRateByIntervalInput extends LogAnalyticsInputBase {\n /** Interval value in minutes used to create LogAnalytics call rate logs. */\n intervalLength: IntervalInMins;\n}\n\n/** Api request input for LogAnalytics getThrottledRequests Api. */\nexport interface ThrottledRequestsInput extends LogAnalyticsInputBase {}\n\n/** Describes the properties of a Run Command. */\nexport interface RunCommandDocument extends RunCommandDocumentBase {\n /** The script to be executed. */\n script: string[];\n /** The parameters used by the script. */\n parameters?: RunCommandParameterDefinition[];\n}\n\n/** Specifies information about the availability set that the virtual machine should be assigned to. Only tags may be updated. */\nexport interface AvailabilitySetUpdate extends UpdateResource {\n /** Sku of the availability set */\n sku?: Sku;\n /** Update Domain count. */\n platformUpdateDomainCount?: number;\n /** Fault Domain count. */\n platformFaultDomainCount?: number;\n /** A list of references to all virtual machines in the availability set. */\n virtualMachines?: SubResource[];\n /** Specifies information about the proximity placement group that the availability set should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /**\n * The resource status information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statuses?: InstanceViewStatus[];\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the availability set. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /**\n * Describes the migration properties on the Availability Set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachineScaleSetMigrationInfo?: VirtualMachineScaleSetMigrationInfo;\n}\n\n/** Specifies information about the capacity reservation group. Only tags can be updated. */\nexport interface CapacityReservationGroupUpdate extends UpdateResource {\n /**\n * A list of all capacity reservation resource ids that belong to capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacityReservations?: SubResourceReadOnly[];\n /**\n * A list of references to all virtual machines associated to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The capacity reservation group instance view which has the list of instance views for all the capacity reservations that belong to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationGroupInstanceView;\n /** Specifies the settings to enable sharing across subscriptions for the capacity reservation group resource. The capacity reservation group resource can generally be shared across subscriptions belonging to a single Azure AAD tenant or across AAD tenants if there is a trust relationship established between the tenants. Block capacity reservation does not support sharing across subscriptions. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details. */\n sharingProfile?: ResourceSharingProfile;\n /** Indicates the type of capacity reservation. Allowed values are 'Block' for block capacity reservations and 'Targeted' for reservations that enable a VM to consume a specific capacity reservation when a capacity reservation group is provided. The reservation type is immutable and cannot be changed after it is assigned. */\n reservationType?: ReservationType;\n}\n\n/** Specifies information about the capacity reservation. sku.capacity cannot be updated for Block Capacity Reservation. Tags can be update for all Capacity Reservation Types. */\nexport interface CapacityReservationUpdate extends UpdateResource {\n /** SKU of the resource for which capacity needs be reserved. The SKU name and capacity is required to be set. Currently VM Skus with the capability called 'CapacityReservationSupported' set to true are supported. When 'CapacityReservationSupported' is true, the SKU capability also specifies the 'SupportedCapacityReservationTypes', which lists the types of capacity reservations (such as Targeted or Block) that the SKU supports. Refer to List Microsoft.Compute SKUs in a region (https://docs.microsoft.com/rest/api/compute/resourceskus/list) for supported values. **Note:** The SKU name and capacity cannot be updated for Block capacity reservations. */\n sku?: Sku;\n /**\n * A unique id generated and assigned to the capacity reservation by the platform which does not change throughout the lifetime of the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reservationId?: string;\n /**\n * Specifies the value of fault domain count that Capacity Reservation supports for requested VM size. **Note:** The fault domain count specified for a resource (like virtual machines scale set) must be less than or equal to this value if it deploys using capacity reservation. Minimum api-version: 2022-08-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformFaultDomainCount?: number;\n /**\n * A list of all virtual machine resource ids that are associated with the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The date time when the capacity reservation was last updated.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The Capacity reservation instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationInstanceView;\n /**\n * Specifies the time at which the Capacity Reservation resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** Defines the schedule for Block-type capacity reservations. Specifies the schedule during which capacity reservation is active and VM or VMSS resource can be allocated using reservation. This property is required and only supported when the capacity reservation group type is 'Block'. The scheduleProfile, start, and end fields are immutable after creation. Minimum API version: 2025-04-01. Please refer to https://aka.ms/blockcapacityreservation for more details. */\n scheduleProfile?: ScheduleProfile;\n}\n\n/** Specifies information about the dedicated host group that the dedicated host should be assigned to. Only tags may be updated. */\nexport interface DedicatedHostGroupUpdate extends UpdateResource {\n /** Availability Zone to use for this host group. Only single zone is supported. The zone can be assigned only during creation. If not provided, the group supports all zones in the region. If provided, enforces each host in the group to be in the same zone. */\n zones?: string[];\n /** Number of fault domains that the host group can span. */\n platformFaultDomainCount?: number;\n /**\n * A list of references to all dedicated hosts in the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hosts?: SubResourceReadOnly[];\n /**\n * The dedicated host group instance view, which has the list of instance view of the dedicated hosts under the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostGroupInstanceView;\n /** Specifies whether virtual machines or virtual machine scale sets can be placed automatically on the dedicated host group. Automatic placement means resources are allocated on dedicated hosts, that are chosen by Azure, under the dedicated host group. The value is defaulted to 'false' when not provided. Minimum api-version: 2020-06-01. */\n supportAutomaticPlacement?: boolean;\n /** Enables or disables a capability on the dedicated host group. Minimum api-version: 2022-03-01. */\n additionalCapabilities?: DedicatedHostGroupPropertiesAdditionalCapabilities;\n}\n\n/** Specifies information about the dedicated host. Only tags, autoReplaceOnFailure and licenseType may be updated. */\nexport interface DedicatedHostUpdate extends UpdateResource {\n /** [List all available dedicated host sizes for resizing] (https://docs.microsoft.com/rest/api/compute/dedicated-hosts/listavailablesizes). Resizing can be only used to scale up DedicatedHost. Only name is required to be set. */\n sku?: Sku;\n /** Fault domain of the dedicated host within a dedicated host group. */\n platformFaultDomain?: number;\n /** Specifies whether the dedicated host should be replaced automatically in case of a failure. The value is defaulted to 'true' when not provided. */\n autoReplaceOnFailure?: boolean;\n /**\n * A unique id generated and assigned to the dedicated host by the platform. Does not change throughout the lifetime of the host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hostId?: string;\n /**\n * A list of references to all virtual machines in the Dedicated Host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachines?: SubResourceReadOnly[];\n /** Specifies the software license type that will be applied to the VMs deployed on the dedicated host. Possible values are: **None,** **Windows_Server_Hybrid,** **Windows_Server_Perpetual.** The default value is: **None.** */\n licenseType?: DedicatedHostLicenseTypes;\n /**\n * The date when the host was first provisioned.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The dedicated host instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostInstanceView;\n /**\n * Specifies the time at which the Dedicated Host resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** The source user image virtual hard disk. Only tags may be updated. */\nexport interface ImageUpdate extends UpdateResource {\n /** The source virtual machine from which Image is created. */\n sourceVirtualMachine?: SubResource;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: ImageStorageProfile;\n /**\n * The provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies the HyperVGenerationType of the VirtualMachine created from the image. From API Version 2019-03-01 if the image source is a blob, then we need the user to specify the value, if the source is managed resource like disk or snapshot, we may require the user to specify the property if we cannot deduce it from the source managed resource. */\n hyperVGeneration?: HyperVGenerationTypes;\n}\n\n/** Specifies information about the proximity placement group. */\nexport interface ProximityPlacementGroupUpdate extends UpdateResource {}\n\n/** Update Restore Point collection parameters. */\nexport interface RestorePointCollectionUpdate extends UpdateResource {\n /** The properties of the source resource that this restore point collection is created from. */\n source?: RestorePointCollectionSourceProperties;\n /**\n * The provisioning state of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The unique id of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePointCollectionId?: string;\n /**\n * A list containing all restore points created under this restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePoints?: RestorePoint[];\n /** This property determines whether instant access snapshot is enabled for restore points created under this restore point collection for Premium SSD v2 or Ultra disk. Instant access snapshot for Premium SSD v2 or Ultra disk is instantaneously available for restoring disk with fast restore performance. */\n instantAccess?: boolean;\n}\n\n/** Specifies information about the SSH public key. */\nexport interface SshPublicKeyUpdateResource extends UpdateResource {\n /** SSH public key used to authenticate to a virtual machine through ssh. If this property is not initially provided when the resource is created, the publicKey property will be populated when generateKeyPair is called. If the public key is provided upon resource creation, the provided public key needs to be at least 2048-bit and in ssh-rsa format. */\n publicKey?: string;\n}\n\n/** Describes a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetUpdate extends UpdateResource {\n /** The virtual machine scale set sku. */\n sku?: Sku;\n /** The purchase plan when deploying a virtual machine scale set from VM Marketplace images. */\n plan?: Plan;\n /** The identity of the virtual machine scale set, if configured. */\n identity?: VirtualMachineScaleSetIdentity;\n /** The virtual machine scale set zones. */\n zones?: string[];\n /** The upgrade policy. */\n upgradePolicy?: UpgradePolicy;\n /** Policy for automatic repairs. */\n automaticRepairsPolicy?: AutomaticRepairsPolicy;\n /** The virtual machine profile. */\n virtualMachineProfile?: VirtualMachineScaleSetUpdateVMProfile;\n /** Specifies whether the Virtual Machine Scale Set should be overprovisioned. */\n overprovision?: boolean;\n /** When Overprovision is enabled, extensions are launched only on the requested number of VMs which are finally kept. This property will hence ensure that the extensions do not run on the extra overprovisioned VMs. */\n doNotRunExtensionsOnOverprovisionedVMs?: boolean;\n /** When true this limits the scale set to a single placement group, of max size 100 virtual machines. NOTE: If singlePlacementGroup is true, it may be modified to false. However, if singlePlacementGroup is false, it may not be modified to true. */\n singlePlacementGroup?: boolean;\n /** Specifies additional capabilities enabled or disabled on the Virtual Machines in the Virtual Machine Scale Set. For instance: whether the Virtual Machines have the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the policies applied when scaling in Virtual Machines in the Virtual Machine Scale Set. */\n scaleInPolicy?: ScaleInPolicy;\n /** Specifies information about the proximity placement group that the virtual machine scale set should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies the desired targets for mixing Spot and Regular priority VMs within the same VMSS Flex instance. */\n priorityMixPolicy?: PriorityMixPolicy;\n /** Specifies the Spot Restore properties for the virtual machine scale set. */\n spotRestorePolicy?: SpotRestorePolicy;\n /** Policy for Resiliency */\n resiliencyPolicy?: ResiliencyPolicy;\n /** Specifies the align mode between Virtual Machine Scale Set compute and storage Fault Domain count. */\n zonalPlatformFaultDomainAlignMode?: ZonalPlatformFaultDomainAlignMode;\n /** Specifies the sku profile for the virtual machine scale set. */\n skuProfile?: SkuProfile;\n}\n\n/** Describes a Virtual Machine run command. */\nexport interface VirtualMachineRunCommandUpdate extends UpdateResource {\n /** The source of the run command script. */\n source?: VirtualMachineRunCommandScriptSource;\n /** The parameters used by the script. */\n parameters?: RunCommandInputParameter[];\n /** The parameters used by the script. */\n protectedParameters?: RunCommandInputParameter[];\n /** Optional. If set to true, provisioning will complete as soon as the script starts and will not wait for script to complete. */\n asyncExecution?: boolean;\n /** Specifies the user account on the VM when executing the run command. */\n runAsUser?: string;\n /** Specifies the user account password on the VM when executing the run command. */\n runAsPassword?: string;\n /** The timeout in seconds to execute the run command. */\n timeoutInSeconds?: number;\n /** Specifies the Azure storage blob where script output stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer outputBlobManagedIdentity parameter. */\n outputBlobUri?: string;\n /** Specifies the Azure storage blob where script error stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer errorBlobManagedIdentity parameter. */\n errorBlobUri?: string;\n /** User-assigned managed identity that has access to outputBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n outputBlobManagedIdentity?: RunCommandManagedIdentity;\n /** User-assigned managed identity that has access to errorBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n errorBlobManagedIdentity?: RunCommandManagedIdentity;\n /**\n * The provisioning state, which only appears in the response. If treatFailureAsDeploymentFailure set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If treatFailureAsDeploymentFailure set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine run command instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineRunCommandInstanceView;\n /** Optional. If set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results */\n treatFailureAsDeploymentFailure?: boolean;\n}\n\n/** Describes a Virtual Machine Update. */\nexport interface VirtualMachineUpdate extends UpdateResource {\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentity;\n /** The virtual machine zones. */\n zones?: string[];\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfile;\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the virtual machine. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfile;\n /** Specifies additional capabilities enabled or disabled on the virtual machine. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the operating system settings used while creating the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\n osProfile?: OSProfile;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfile;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfile;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to availability set at creation time. The availability set to which the VM is being added should be under the same resource group as the availability set resource. An existing VM cannot be added to an availability set. This property cannot exist along with a non-null properties.virtualMachineScaleSet reference. */\n availabilitySet?: SubResource;\n /** Specifies information about the virtual machine scale set that the virtual machine should be assigned to. Virtual machines specified in the same virtual machine scale set are allocated to different nodes to maximize availability. Currently, a VM can only be added to virtual machine scale set at creation time. An existing VM cannot be added to a virtual machine scale set. This property cannot exist along with a non-null properties.availabilitySet reference. Minimum api‐version: 2019‐03‐01. */\n virtualMachineScaleSet?: SubResource;\n /** Specifies information about the proximity placement group that the virtual machine should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies the priority for the virtual machine. Minimum api-version: 2019-03-01 */\n priority?: VirtualMachinePriorityTypes;\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: VirtualMachineEvictionPolicyTypes;\n /** Specifies the billing related details of a Azure Spot virtual machine. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies information about the dedicated host that the virtual machine resides in. Minimum api-version: 2018-10-01. */\n host?: SubResource;\n /** Specifies information about the dedicated host group that the virtual machine resides in. **Note:** User cannot specify both host and hostGroup properties. Minimum api-version: 2020-06-01. */\n hostGroup?: SubResource;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineInstanceView;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /**\n * Specifies the VM unique ID which is a 128-bits identifier that is encoded and stored in all Azure IaaS VMs SMBIOS and can be read using platform BIOS commands.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). Minimum api-version: 2020-06-01. */\n extensionsTimeBudget?: string;\n /** Specifies the scale set logical fault domain into which the Virtual Machine will be created. By default, the Virtual Machine will by automatically assigned to a fault domain that best maintains balance across available fault domains. This is applicable only if the 'virtualMachineScaleSet' property of this Virtual Machine is set. The Virtual Machine Scale Set that is referenced, must have 'platformFaultDomainCount' greater than 1. This property cannot be updated once the Virtual Machine is created. Fault domain assignment can be viewed in the Virtual Machine Instance View. Minimum api‐version: 2020‐12‐01. */\n platformFaultDomain?: number;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01. */\n userData?: string;\n /** Specifies information about the capacity reservation that is used to allocate virtual machine. Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfile;\n /** Specifies the gallery applications that should be made available to the VM/VMSS. */\n applicationProfile?: ApplicationProfile;\n /**\n * Specifies the time at which the Virtual Machine resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Describes a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionUpdate extends UpdateResource {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** Describes a Virtual Machine Scale Set VM Reimage Parameters. */\nexport interface VirtualMachineScaleSetVMReimageParameters extends VirtualMachineReimageParameters {\n /** Parameter to force update ephemeral OS disk for a virtual machine scale set VM */\n forceUpdateOSDiskForEphemeral?: boolean;\n}\n\n/** Specifies information about the Community Gallery that you want to create or update. */\nexport interface CommunityGallery extends PirCommunityGalleryResource {\n /** The disclaimer for a community gallery resource. */\n disclaimer?: string;\n /** The artifact tags of a community gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n /** The metadata of community gallery. */\n communityMetadata?: CommunityGalleryMetadata;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface CommunityGalleryImage extends PirCommunityGalleryResource {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the community gallery image definition identifier. */\n identifier?: CommunityGalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Privacy statement URI for the current community gallery image. */\n privacyStatementUri?: string;\n /** The end-user license agreement for the current community gallery image. */\n eula?: string;\n /** The disclaimer for a community gallery resource. */\n disclaimer?: string;\n /** The artifact tags of a community gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface CommunityGalleryImageVersion extends PirCommunityGalleryResource {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: Date;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfile;\n /** The disclaimer for a community gallery resource. */\n disclaimer?: string;\n /** The artifact tags of a community gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** This is the OS disk image. */\nexport interface SharedGalleryOSDiskImage extends SharedGalleryDiskImage {}\n\n/** This is the data disk image. */\nexport interface SharedGalleryDataDiskImage extends SharedGalleryDiskImage {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** Base information about the shared gallery resource in pir. */\nexport interface PirSharedGalleryResource extends PirResource {\n /** The unique id of this shared gallery. */\n uniqueId?: string;\n}\n\n/** Specifies information about the Shared Image Gallery that you want to update. */\nexport interface GalleryUpdate extends UpdateResourceDefinition {\n /** The identity of the gallery, if configured. */\n identity?: GalleryIdentity;\n /** The description of this Shared Image Gallery resource. This property is updatable. */\n description?: string;\n /** Describes the gallery unique name. */\n identifier?: GalleryIdentifier;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** Profile for gallery sharing to subscription or tenant */\n sharingProfile?: SharingProfile;\n /** Contains information about the soft deletion policy of the gallery. */\n softDeletePolicy?: SoftDeletePolicy;\n /**\n * Sharing status of current gallery.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sharingStatus?: SharingStatus;\n}\n\n/** Specifies information about the gallery Application Definition that you want to update. */\nexport interface GalleryApplicationUpdate extends UpdateResourceDefinition {\n /** The description of this gallery Application Definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery Application Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Application Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This property allows you to specify the supported type of the OS that application is built for. Possible values are: **Windows,** **Linux.** */\n supportedOSType?: OperatingSystemTypes;\n /** A list of custom actions that can be performed with all of the Gallery Application Versions within this Gallery Application. */\n customActions?: GalleryApplicationCustomAction[];\n}\n\n/** Specifies information about the gallery Application Version that you want to update. */\nexport interface GalleryApplicationVersionUpdate extends UpdateResourceDefinition {\n /** The publishing profile of a gallery image version. */\n publishingProfile?: GalleryApplicationVersionPublishingProfile;\n /** The safety profile of the Gallery Application Version. */\n safetyProfile?: GalleryApplicationVersionSafetyProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** Specifies information about the gallery image definition that you want to update. */\nexport interface GalleryImageUpdate extends UpdateResourceDefinition {\n /** The description of this gallery image definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery image definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the gallery image definition identifier. */\n identifier?: GalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Optional. Must be set to true if the gallery image features are being updated. */\n allowUpdateImage?: boolean;\n}\n\n/** Specifies information about the gallery image version that you want to update. */\nexport interface GalleryImageVersionUpdate extends UpdateResourceDefinition {\n /** The publishing profile of a gallery image Version. */\n publishingProfile?: GalleryImageVersionPublishingProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** This is the storage profile of a Gallery Image Version. */\n storageProfile?: GalleryImageVersionStorageProfile;\n /** This is the safety profile of the Gallery Image Version. */\n safetyProfile?: GalleryImageVersionSafetyProfile;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** The security profile of a gallery image version */\n securityProfile?: ImageVersionSecurityProfile;\n /** Indicates if this is a soft-delete resource restoration request. */\n restore?: boolean;\n /**\n * This is the validations profile of a Gallery Image Version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly validationsProfile?: ValidationsProfile;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile that you want to update. */\nexport interface GalleryInVMAccessControlProfileUpdate extends UpdateResourceDefinition {\n /** Describes the properties of a gallery inVMAccessControlProfile. */\n properties?: GalleryInVMAccessControlProfileProperties;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile version that you want to update. */\nexport interface GalleryInVMAccessControlProfileVersionUpdate extends UpdateResourceDefinition {\n /** The target regions where the Resource Profile version is going to be replicated to. This property is updatable. */\n targetLocations?: TargetRegion[];\n /** If set to true, Virtual Machines deployed from the latest version of the Resource Profile won't use this Profile version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the Resource Profile Version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** This property allows you to specify whether the access control rules are in Audit mode, in Enforce mode or Disabled. Possible values are: 'Audit', 'Enforce' or 'Disabled'. */\n mode?: AccessControlRulesMode;\n /** This property allows you to specify if the requests will be allowed to access the host endpoints. Possible values are: 'Allow', 'Deny'. */\n defaultAccess?: EndpointAccess;\n /** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\n rules?: AccessControlRules;\n}\n\n/** The publishing profile of a gallery image version. */\nexport interface GalleryApplicationVersionPublishingProfile\n extends GalleryArtifactPublishingProfileBase {\n /** The source image from which the Image Version is going to be created. */\n source: UserArtifactSource;\n manageActions?: UserArtifactManage;\n /** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\n settings?: UserArtifactSettings;\n /** Optional. Additional settings to pass to the vm-application-manager extension. For advanced use only. */\n advancedSettings?: { [propertyName: string]: string };\n /** Optional. Whether or not this application reports health. */\n enableHealthCheck?: boolean;\n /** A list of custom actions that can be performed with this Gallery Application Version. */\n customActions?: GalleryApplicationCustomAction[];\n}\n\n/** The publishing profile of a gallery image Version. */\nexport interface GalleryImageVersionPublishingProfile\n extends GalleryArtifactPublishingProfileBase {}\n\n/** Contains encryption settings for an OS disk image. */\nexport interface OSDiskImageEncryption extends DiskImageEncryption {\n /** This property specifies the security profile of an OS disk image. */\n securityProfile?: OSDiskImageSecurityProfile;\n}\n\n/** Contains encryption settings for a data disk image. */\nexport interface DataDiskImageEncryption extends DiskImageEncryption {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** The safety profile of the Gallery Application Version. */\nexport interface GalleryApplicationVersionSafetyProfile extends GalleryArtifactSafetyProfileBase {}\n\n/** This is the safety profile of the Gallery Image Version. */\nexport interface GalleryImageVersionSafetyProfile extends GalleryArtifactSafetyProfileBase {\n /**\n * Indicates whether this image has been reported as violating Microsoft's policies.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reportedForPolicyViolation?: boolean;\n /**\n * A list of Policy Violations that have been reported for this Gallery Image Version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly policyViolations?: PolicyViolation[];\n /** Indicates whether or not the deletion is blocked for this Gallery Image Version if its End Of Life has not expired. */\n blockDeletionBeforeEndOfLife?: boolean;\n}\n\n/** The source of the gallery artifact version. */\nexport interface GalleryArtifactVersionFullSource extends GalleryArtifactVersionSource {\n /** The resource Id of the source Community Gallery Image. Only required when using Community Gallery Image as a source. */\n communityGalleryImageId?: string;\n /** The resource Id of the source virtual machine. Only required when capturing a virtual machine to source this Gallery Image Version. */\n virtualMachineId?: string;\n}\n\n/** The source for the disk image. */\nexport interface GalleryDiskImageSource extends GalleryArtifactVersionSource {\n /** The uri of the gallery artifact version source. Currently used to specify vhd/blob source. */\n uri?: string;\n /** The Storage Account Id that contains the vhd blob being used as a source for this artifact version. */\n storageAccountId?: string;\n}\n\n/** This is the OS disk image. */\nexport interface GalleryOSDiskImage extends GalleryDiskImage {}\n\n/** This is the data disk image. */\nexport interface GalleryDataDiskImage extends GalleryDiskImage {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** Describes the properties of a gallery inVMAccessControlProfile. */\nexport interface GalleryInVMAccessControlProfileProperties\n extends GalleryResourceProfilePropertiesBase {\n /** The description of this gallery inVMAccessControlProfile resources. This property is updatable. */\n description?: string;\n /** This property allows you to specify the OS type of the VMs/VMSS for which this profile can be used against. Possible values are: 'Windows' or 'Linux' */\n osType: OperatingSystemTypes;\n /** This property allows you to specify the Endpoint type for which this profile is defining the access control for. Possible values are: 'WireServer' or 'IMDS' */\n applicableHostEndpoint: EndpointTypes;\n}\n\n/** Describes the properties of an inVMAccessControlProfile version. */\nexport interface GalleryInVMAccessControlProfileVersionProperties\n extends GalleryResourceProfileVersionPropertiesBase {\n /** This property allows you to specify whether the access control rules are in Audit mode, in Enforce mode or Disabled. Possible values are: 'Audit', 'Enforce' or 'Disabled'. */\n mode: AccessControlRulesMode;\n /** This property allows you to specify if the requests will be allowed to access the host endpoints. Possible values are: 'Allow', 'Deny'. */\n defaultAccess: EndpointAccess;\n /** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\n rules?: AccessControlRules;\n}\n\n/** Describes a Virtual Machine Image. */\nexport interface VirtualMachineImage extends VirtualMachineImageResource {\n /** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\n plan?: PurchasePlan;\n /** Contains the os disk image information. */\n osDiskImage?: OSDiskImage;\n /** The list of data disk images information. */\n dataDiskImages?: DataDiskImage[];\n /** Describes automatic OS upgrade properties on the image. */\n automaticOSUpgradeProperties?: AutomaticOSUpgradeProperties;\n /** Specifies the HyperVGeneration Type */\n hyperVGeneration?: HyperVGenerationTypes;\n /** Specifies disallowed configuration for the VirtualMachine created from the image */\n disallowed?: DisallowedConfiguration;\n features?: VirtualMachineImageFeature[];\n /** Specifies the Architecture Type */\n architecture?: ArchitectureTypes;\n /** Describes image deprecation status properties on the image. */\n imageDeprecationStatus?: ImageDeprecationStatus;\n}\n\n/** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to an availability set at creation time. An existing VM cannot be added to an availability set. */\nexport interface AvailabilitySet extends TrackedResource {\n /** Sku of the availability set, only name is required to be set. See AvailabilitySetSkuTypes for possible set of values. Use 'Aligned' for virtual machines with managed disks and 'Classic' for virtual machines with unmanaged disks. Default value is 'Classic'. */\n sku?: Sku;\n /** Update Domain count. */\n platformUpdateDomainCount?: number;\n /** Fault Domain count. */\n platformFaultDomainCount?: number;\n /** A list of references to all virtual machines in the availability set. */\n virtualMachines?: SubResource[];\n /** Specifies information about the proximity placement group that the availability set should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /**\n * The resource status information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statuses?: InstanceViewStatus[];\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the availability set. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /**\n * Describes the migration properties on the Availability Set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachineScaleSetMigrationInfo?: VirtualMachineScaleSetMigrationInfo;\n}\n\n/** Specifies information about the capacity reservation group that the capacity reservations should be assigned to. Currently, a capacity reservation can only be added to a capacity reservation group at creation time. An existing capacity reservation cannot be added or moved to another capacity reservation group. */\nexport interface CapacityReservationGroup extends TrackedResource {\n /** The availability zones. */\n zones?: string[];\n /**\n * A list of all capacity reservation resource ids that belong to capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacityReservations?: SubResourceReadOnly[];\n /**\n * A list of references to all virtual machines associated to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The capacity reservation group instance view which has the list of instance views for all the capacity reservations that belong to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationGroupInstanceView;\n /** Specifies the settings to enable sharing across subscriptions for the capacity reservation group resource. The capacity reservation group resource can generally be shared across subscriptions belonging to a single Azure AAD tenant or across AAD tenants if there is a trust relationship established between the tenants. Block capacity reservation does not support sharing across subscriptions. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details. */\n sharingProfile?: ResourceSharingProfile;\n /** Indicates the type of capacity reservation. Allowed values are 'Block' for block capacity reservations and 'Targeted' for reservations that enable a VM to consume a specific capacity reservation when a capacity reservation group is provided. The reservation type is immutable and cannot be changed after it is assigned. */\n reservationType?: ReservationType;\n}\n\n/** Specifies information about the dedicated host group that the dedicated hosts should be assigned to. Currently, a dedicated host can only be added to a dedicated host group at creation time. An existing dedicated host cannot be added to another dedicated host group. */\nexport interface DedicatedHostGroup extends TrackedResource {\n /** The availability zones. */\n zones?: string[];\n /** Number of fault domains that the host group can span. */\n platformFaultDomainCount?: number;\n /**\n * A list of references to all dedicated hosts in the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hosts?: SubResourceReadOnly[];\n /**\n * The dedicated host group instance view, which has the list of instance view of the dedicated hosts under the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostGroupInstanceView;\n /** Specifies whether virtual machines or virtual machine scale sets can be placed automatically on the dedicated host group. Automatic placement means resources are allocated on dedicated hosts, that are chosen by Azure, under the dedicated host group. The value is defaulted to 'false' when not provided. Minimum api-version: 2020-06-01. */\n supportAutomaticPlacement?: boolean;\n /** Enables or disables a capability on the dedicated host group. Minimum api-version: 2022-03-01. */\n additionalCapabilities?: DedicatedHostGroupPropertiesAdditionalCapabilities;\n}\n\n/** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\nexport interface Image extends TrackedResource {\n /** The extended location of the Image. */\n extendedLocation?: ExtendedLocation;\n /** The source virtual machine from which Image is created. */\n sourceVirtualMachine?: SubResource;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: ImageStorageProfile;\n /**\n * The provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies the HyperVGenerationType of the VirtualMachine created from the image. From API Version 2019-03-01 if the image source is a blob, then we need the user to specify the value, if the source is managed resource like disk or snapshot, we may require the user to specify the property if we cannot deduce it from the source managed resource. */\n hyperVGeneration?: HyperVGenerationTypes;\n}\n\n/** Describes a Virtual Machine Extension Image. */\nexport interface VirtualMachineExtensionImage extends TrackedResource {\n /** The operating system this extension supports. */\n operatingSystem?: string;\n /** The type of role (IaaS or PaaS) this extension supports. */\n computeRole?: string;\n /** The schema defined by publisher, where extension consumers should provide settings in a matching schema. */\n handlerSchema?: string;\n /** Whether the extension can be used on xRP VMScaleSets. By default existing extensions are usable on scalesets, but there might be cases where a publisher wants to explicitly indicate the extension is only enabled for CRP VMs but not VMSS. */\n vmScaleSetEnabled?: boolean;\n /** Whether the handler can support multiple extensions. */\n supportsMultipleExtensions?: boolean;\n}\n\n/** Describes a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSet extends TrackedResource {\n /** The virtual machine scale set sku. */\n sku?: Sku;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /** The identity of the virtual machine scale set, if configured. */\n identity?: VirtualMachineScaleSetIdentity;\n /** The availability zones. */\n zones?: string[];\n /** The extended location of the Virtual Machine Scale Set. */\n extendedLocation?: ExtendedLocation;\n /**\n * Etag is property returned in Create/Update/Get response of the VMSS, so that customer can supply it in the header to ensure optimistic updates\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly etag?: string;\n /** Placement section specifies the user-defined constraints for virtual machine scale set hardware placement. This property cannot be changed once VMSS is provisioned. Minimum api-version: 2025-04-01. */\n placement?: Placement;\n /** The upgrade policy. */\n upgradePolicy?: UpgradePolicy;\n /** The ScheduledEventsPolicy. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /** Policy for automatic repairs. */\n automaticRepairsPolicy?: AutomaticRepairsPolicy;\n /** The virtual machine profile. */\n virtualMachineProfile?: VirtualMachineScaleSetVMProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies whether the Virtual Machine Scale Set should be overprovisioned. */\n overprovision?: boolean;\n /** When Overprovision is enabled, extensions are launched only on the requested number of VMs which are finally kept. This property will hence ensure that the extensions do not run on the extra overprovisioned VMs. */\n doNotRunExtensionsOnOverprovisionedVMs?: boolean;\n /**\n * Specifies the ID which uniquely identifies a Virtual Machine Scale Set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n /** When true this limits the scale set to a single placement group, of max size 100 virtual machines. NOTE: If singlePlacementGroup is true, it may be modified to false. However, if singlePlacementGroup is false, it may not be modified to true. */\n singlePlacementGroup?: boolean;\n /** Whether to force strictly even Virtual Machine distribution cross x-zones in case there is zone outage. zoneBalance property can only be set if the zones property of the scale set contains more than one zone. If there are no zones or only one zone specified, then zoneBalance property should not be set. */\n zoneBalance?: boolean;\n /** Fault Domain count for each placement group. */\n platformFaultDomainCount?: number;\n /** Specifies information about the proximity placement group that the virtual machine scale set should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies information about the dedicated host group that the virtual machine scale set resides in. Minimum api-version: 2020-06-01. */\n hostGroup?: SubResource;\n /** Specifies additional capabilities enabled or disabled on the Virtual Machines in the Virtual Machine Scale Set. For instance: whether the Virtual Machines have the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the policies applied when scaling in Virtual Machines in the Virtual Machine Scale Set. */\n scaleInPolicy?: ScaleInPolicy;\n /** Specifies the orchestration mode for the virtual machine scale set. */\n orchestrationMode?: OrchestrationMode;\n /** Specifies the Spot Restore properties for the virtual machine scale set. */\n spotRestorePolicy?: SpotRestorePolicy;\n /** Specifies the desired targets for mixing Spot and Regular priority VMs within the same VMSS Flex instance. */\n priorityMixPolicy?: PriorityMixPolicy;\n /**\n * Specifies the time at which the Virtual Machine Scale Set resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** Optional property which must either be set to True or omitted. */\n constrainedMaximumCapacity?: boolean;\n /** Policy for Resiliency */\n resiliencyPolicy?: ResiliencyPolicy;\n /** Specifies the align mode between Virtual Machine Scale Set compute and storage Fault Domain count. */\n zonalPlatformFaultDomainAlignMode?: ZonalPlatformFaultDomainAlignMode;\n /** Specifies the sku profile for the virtual machine scale set. */\n skuProfile?: SkuProfile;\n /** Specifies the high speed interconnect placement for the virtual machine scale set. */\n highSpeedInterconnectPlacement?: HighSpeedInterconnectPlacement;\n}\n\n/** Describes a Virtual Machine Extension. */\nexport interface VirtualMachineExtension extends TrackedResource {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** The virtual machine extension instance view. */\n instanceView?: VirtualMachineExtensionInstanceView;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n}\n\n/** Describes a Virtual Machine. */\nexport interface VirtualMachine extends TrackedResource {\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /**\n * The virtual machine child extension resources.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resources?: VirtualMachineExtension[];\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentity;\n /** The availability zones. */\n zones?: string[];\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocation;\n /**\n * ManagedBy is set to Virtual Machine Scale Set(VMSS) flex ARM resourceID, if the VM is part of the VMSS. This property is used by platform for internal resource group delete optimization.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedBy?: string;\n /**\n * Etag is property returned in Create/Update/Get response of the VM, so that customer can supply it in the header to ensure optimistic updates.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly etag?: string;\n /** Placement section specifies the user-defined constraints for virtual machine hardware placement. This property cannot be changed once VM is provisioned. Minimum api-version: 2024-11-01. */\n placement?: Placement;\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfile;\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the virtual machine. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfile;\n /** Specifies additional capabilities enabled or disabled on the virtual machine. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the operating system settings used while creating the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\n osProfile?: OSProfile;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfile;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfile;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to availability set at creation time. The availability set to which the VM is being added should be under the same resource group as the availability set resource. An existing VM cannot be added to an availability set. This property cannot exist along with a non-null properties.virtualMachineScaleSet reference. */\n availabilitySet?: SubResource;\n /** Specifies information about the virtual machine scale set that the virtual machine should be assigned to. Virtual machines specified in the same virtual machine scale set are allocated to different nodes to maximize availability. Currently, a VM can only be added to virtual machine scale set at creation time. An existing VM cannot be added to a virtual machine scale set. This property cannot exist along with a non-null properties.availabilitySet reference. Minimum api‐version: 2019‐03‐01. */\n virtualMachineScaleSet?: SubResource;\n /** Specifies information about the proximity placement group that the virtual machine should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies the priority for the virtual machine. Minimum api-version: 2019-03-01 */\n priority?: VirtualMachinePriorityTypes;\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: VirtualMachineEvictionPolicyTypes;\n /** Specifies the billing related details of a Azure Spot virtual machine. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies information about the dedicated host that the virtual machine resides in. Minimum api-version: 2018-10-01. */\n host?: SubResource;\n /** Specifies information about the dedicated host group that the virtual machine resides in. **Note:** User cannot specify both host and hostGroup properties. Minimum api-version: 2020-06-01. */\n hostGroup?: SubResource;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineInstanceView;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /**\n * Specifies the VM unique ID which is a 128-bits identifier that is encoded and stored in all Azure IaaS VMs SMBIOS and can be read using platform BIOS commands.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). Minimum api-version: 2020-06-01. */\n extensionsTimeBudget?: string;\n /** Specifies the scale set logical fault domain into which the Virtual Machine will be created. By default, the Virtual Machine will by automatically assigned to a fault domain that best maintains balance across available fault domains. This is applicable only if the 'virtualMachineScaleSet' property of this Virtual Machine is set. The Virtual Machine Scale Set that is referenced, must have 'platformFaultDomainCount' greater than 1. This property cannot be updated once the Virtual Machine is created. Fault domain assignment can be viewed in the Virtual Machine Instance View. Minimum api‐version: 2020‐12‐01. */\n platformFaultDomain?: number;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01. */\n userData?: string;\n /** Specifies information about the capacity reservation that is used to allocate virtual machine. Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfile;\n /** Specifies the gallery applications that should be made available to the VM/VMSS. */\n applicationProfile?: ApplicationProfile;\n /**\n * Specifies the time at which the Virtual Machine resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Specifies information about the proximity placement group. */\nexport interface ProximityPlacementGroup extends TrackedResource {\n /** The availability zones. */\n zones?: string[];\n /** Specifies the type of the proximity placement group. Possible values are: **Standard** : Co-locate resources within an Azure region or Availability Zone. **Ultra** : For future use. */\n proximityPlacementGroupType?: ProximityPlacementGroupType;\n /**\n * A list of references to all virtual machines in the proximity placement group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachines?: SubResourceWithColocationStatus[];\n /**\n * A list of references to all virtual machine scale sets in the proximity placement group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachineScaleSets?: SubResourceWithColocationStatus[];\n /**\n * A list of references to all availability sets in the proximity placement group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly availabilitySets?: SubResourceWithColocationStatus[];\n /** Describes colocation status of the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatus;\n /** Specifies the user intent of the proximity placement group. */\n intent?: ProximityPlacementGroupPropertiesIntent;\n}\n\n/** Create or update Restore Point collection parameters. */\nexport interface RestorePointCollection extends TrackedResource {\n /** The properties of the source resource that this restore point collection is created from. */\n source?: RestorePointCollectionSourceProperties;\n /**\n * The provisioning state of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The unique id of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePointCollectionId?: string;\n /**\n * A list containing all restore points created under this restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePoints?: RestorePoint[];\n /** This property determines whether instant access snapshot is enabled for restore points created under this restore point collection for Premium SSD v2 or Ultra disk. Instant access snapshot for Premium SSD v2 or Ultra disk is instantaneously available for restoring disk with fast restore performance. */\n instantAccess?: boolean;\n}\n\n/** Specifies information about the SSH public key. */\nexport interface SshPublicKeyResource extends TrackedResource {\n /** SSH public key used to authenticate to a virtual machine through ssh. If this property is not initially provided when the resource is created, the publicKey property will be populated when generateKeyPair is called. If the public key is provided upon resource creation, the provided public key needs to be at least 2048-bit and in ssh-rsa format. */\n publicKey?: string;\n}\n\n/** Specifies information about the capacity reservation. */\nexport interface CapacityReservation extends TrackedResource {\n /** SKU of the resource for which capacity needs be reserved. The SKU name and capacity is required to be set. For Block capacity reservations, sku.capacity can only accept values 1, 2, 4, 8, 16, 32, 64. Currently VM Skus with the capability called 'CapacityReservationSupported' set to true are supported. When 'CapacityReservationSupported' is true, the SKU capability also specifies the 'SupportedCapacityReservationTypes', which lists the types of capacity reservations (such as Targeted or Block) that the SKU supports. Refer to List Microsoft.Compute SKUs in a region (https://docs.microsoft.com/rest/api/compute/resourceskus/list) for supported values. */\n sku: Sku;\n /** The availability zones. */\n zones?: string[];\n /**\n * A unique id generated and assigned to the capacity reservation by the platform which does not change throughout the lifetime of the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reservationId?: string;\n /**\n * Specifies the value of fault domain count that Capacity Reservation supports for requested VM size. **Note:** The fault domain count specified for a resource (like virtual machines scale set) must be less than or equal to this value if it deploys using capacity reservation. Minimum api-version: 2022-08-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformFaultDomainCount?: number;\n /**\n * A list of all virtual machine resource ids that are associated with the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The date time when the capacity reservation was last updated.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The Capacity reservation instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationInstanceView;\n /**\n * Specifies the time at which the Capacity Reservation resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** Defines the schedule for Block-type capacity reservations. Specifies the schedule during which capacity reservation is active and VM or VMSS resource can be allocated using reservation. This property is required and only supported when the capacity reservation group type is 'Block'. The scheduleProfile, start, and end fields are immutable after creation. Minimum API version: 2025-04-01. Please refer to https://aka.ms/blockcapacityreservation for more details. */\n scheduleProfile?: ScheduleProfile;\n}\n\n/** Specifies information about the Dedicated host. */\nexport interface DedicatedHost extends TrackedResource {\n /** SKU of the dedicated host for Hardware Generation and VM family. Only name is required to be set. List Microsoft.Compute SKUs for a list of possible values. */\n sku: Sku;\n /** Fault domain of the dedicated host within a dedicated host group. */\n platformFaultDomain?: number;\n /** Specifies whether the dedicated host should be replaced automatically in case of a failure. The value is defaulted to 'true' when not provided. */\n autoReplaceOnFailure?: boolean;\n /**\n * A unique id generated and assigned to the dedicated host by the platform. Does not change throughout the lifetime of the host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hostId?: string;\n /**\n * A list of references to all virtual machines in the Dedicated Host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachines?: SubResourceReadOnly[];\n /** Specifies the software license type that will be applied to the VMs deployed on the dedicated host. Possible values are: **None,** **Windows_Server_Hybrid,** **Windows_Server_Perpetual.** The default value is: **None.** */\n licenseType?: DedicatedHostLicenseTypes;\n /**\n * The date when the host was first provisioned.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The dedicated host instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostInstanceView;\n /**\n * Specifies the time at which the Dedicated Host resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** The status of the latest virtual machine scale set rolling upgrade. */\nexport interface RollingUpgradeStatusInfo extends TrackedResource {\n /**\n * The rolling upgrade policies applied for this upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly policy?: RollingUpgradePolicy;\n /**\n * Information about the current running state of the overall upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly runningStatus?: RollingUpgradeRunningStatus;\n /**\n * Information about the number of virtual machine instances in each upgrade state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly progress?: RollingUpgradeProgressInfo;\n /**\n * Error details for this upgrade, if there are any.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Describes a virtual machine scale set virtual machine. */\nexport interface VirtualMachineScaleSetVM extends TrackedResource {\n /**\n * The virtual machine instance ID.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceId?: string;\n /**\n * The virtual machine SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sku?: Sku;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /**\n * The virtual machine child extension resources.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resources?: VirtualMachineExtension[];\n /**\n * The virtual machine zones.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zones?: string[];\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentity;\n /**\n * Etag is property returned in Update/Get response of the VMSS VM, so that customer can supply it in the header to ensure optimistic updates.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly etag?: string;\n /**\n * Specifies whether the latest model has been applied to the virtual machine.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly latestModelApplied?: boolean;\n /**\n * Azure VM unique ID.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /**\n * The virtual machine instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineScaleSetVMInstanceView;\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfile;\n /** Specifies the resilient VM deletion status for the virtual machine. */\n resilientVMDeletionStatus?: ResilientVMDeletionStatus;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfile;\n /** Specifies additional capabilities enabled or disabled on the virtual machine in the scale set. For instance: whether the virtual machine has the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the operating system settings for the virtual machine. */\n osProfile?: OSProfile;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfile;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfile;\n /** Specifies the network profile configuration of the virtual machine. */\n networkProfileConfiguration?: VirtualMachineScaleSetVMNetworkProfileConfiguration;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to availability set at creation time. An existing VM cannot be added to an availability set. */\n availabilitySet?: SubResource;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /**\n * Specifies whether the model applied to the virtual machine is the model of the virtual machine scale set or the customized model for the virtual machine.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly modelDefinitionApplied?: string;\n /** Specifies the protection policy of the virtual machine. */\n protectionPolicy?: VirtualMachineScaleSetVMProtectionPolicy;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01 */\n userData?: string;\n /**\n * Specifies the time at which the Virtual Machine resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Describes a Virtual Machine run command. */\nexport interface VirtualMachineRunCommand extends TrackedResource {\n /** The source of the run command script. */\n source?: VirtualMachineRunCommandScriptSource;\n /** The parameters used by the script. */\n parameters?: RunCommandInputParameter[];\n /** The parameters used by the script. */\n protectedParameters?: RunCommandInputParameter[];\n /** Optional. If set to true, provisioning will complete as soon as the script starts and will not wait for script to complete. */\n asyncExecution?: boolean;\n /** Specifies the user account on the VM when executing the run command. */\n runAsUser?: string;\n /** Specifies the user account password on the VM when executing the run command. */\n runAsPassword?: string;\n /** The timeout in seconds to execute the run command. */\n timeoutInSeconds?: number;\n /** Specifies the Azure storage blob where script output stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer outputBlobManagedIdentity parameter. */\n outputBlobUri?: string;\n /** Specifies the Azure storage blob where script error stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer errorBlobManagedIdentity parameter. */\n errorBlobUri?: string;\n /** User-assigned managed identity that has access to outputBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n outputBlobManagedIdentity?: RunCommandManagedIdentity;\n /** User-assigned managed identity that has access to errorBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n errorBlobManagedIdentity?: RunCommandManagedIdentity;\n /**\n * The provisioning state, which only appears in the response. If treatFailureAsDeploymentFailure set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If treatFailureAsDeploymentFailure set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine run command instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineRunCommandInstanceView;\n /** Optional. If set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results */\n treatFailureAsDeploymentFailure?: boolean;\n}\n\n/** disk access resource. */\nexport interface DiskAccess extends TrackedResource {\n /** The extended location where the disk access will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocation;\n /**\n * A readonly collection of private endpoint connections created on the disk. Currently only one endpoint connection is supported.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateEndpointConnections?: PrivateEndpointConnection[];\n /**\n * The disk access resource provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The time when the disk access was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** disk encryption set resource. */\nexport interface DiskEncryptionSet extends TrackedResource {\n /** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\n identity?: EncryptionSetIdentity;\n /** The type of key used to encrypt the data of the disk. */\n encryptionType?: DiskEncryptionSetType;\n /** The key vault key which is currently used by this disk encryption set. */\n activeKey?: KeyForDiskEncryptionSet;\n /**\n * A readonly collection of key vault keys previously used by this disk encryption set while a key rotation is in progress. It will be empty if there is no ongoing key rotation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly previousKeys?: KeyForDiskEncryptionSet[];\n /**\n * The disk encryption set provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Set this flag to true to enable auto-updating of this disk encryption set to the latest key version. */\n rotationToLatestKeyVersionEnabled?: boolean;\n /**\n * The time when the active key of this disk encryption set was updated.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastKeyRotationTimestamp?: Date;\n /**\n * The error that was encountered during auto-key rotation. If an error is present, then auto-key rotation will not be attempted until the error on this disk encryption set is fixed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly autoKeyRotationError?: ApiError;\n /** Multi-tenant application client id to access key vault in a different tenant. Setting the value to 'None' will clear the property. */\n federatedClientId?: string;\n}\n\n/** Disk resource. */\nexport interface Disk extends TrackedResource {\n /**\n * A relative URI containing the ID of the VM that has the disk attached.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedBy?: string;\n /**\n * List of relative URIs containing the IDs of the VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedByExtended?: string[];\n /** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\n sku?: DiskSku;\n /** The Logical zone list for Disk. */\n zones?: string[];\n /** The extended location where the disk will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocation;\n /**\n * The time when the disk was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** The Operating System type. */\n osType?: OperatingSystemTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** Purchase plan information for the the image from which the OS disk was created. E.g. - {name: 2019-Datacenter, publisher: MicrosoftWindowsServer, product: WindowsServer} */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilities;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData?: CreationData;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /**\n * The size of the disk in bytes. This field is read only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeBytes?: number;\n /**\n * Unique Guid identifying the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n /** Encryption settings collection used for Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /**\n * The disk provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** The number of IOPS allowed for this disk; only settable for UltraSSD disks. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadWrite?: number;\n /** The bandwidth allowed for this disk; only settable for UltraSSD disks. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadWrite?: number;\n /** The total number of IOPS that will be allowed across all VMs mounting the shared disk as ReadOnly. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadOnly?: number;\n /** The total throughput (MBps) that will be allowed across all VMs mounting the shared disk as ReadOnly. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadOnly?: number;\n /**\n * The state of the disk.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskState?: DiskState;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** The maximum number of VMs that can attach to the disk at the same time. Value greater than one indicates a disk that can be mounted on multiple VMs at the same time. */\n maxShares?: number;\n /**\n * Details of the list of all VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly shareInfo?: ShareInfoElement[];\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /**\n * Latest time when bursting was last enabled on a disk.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly burstingEnabledTime?: Date;\n /** Performance tier of the disk (e.g, P4, S10) as described here: https://azure.microsoft.com/en-us/pricing/details/managed-disks/. Does not apply to Ultra disks. */\n tier?: string;\n /** Set to true to enable bursting beyond the provisioned performance target of the disk. Bursting is disabled by default. Does not apply to Ultra disks. */\n burstingEnabled?: boolean;\n /**\n * Properties of the disk for which update is pending.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly propertyUpdatesInProgress?: PropertyUpdatesInProgress;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfile;\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /** Setting this property to true improves reliability and performance of data disks that are frequently (more than 5 times a day) by detached from one virtual machine and attached to another. This property should not be set for disks that are not detached and attached frequently as it causes the disks to not align with the fault domain of the virtual machine. */\n optimizedForFrequentAttach?: boolean;\n /**\n * The UTC time when the ownership state of the disk was last changed i.e., the time the disk was last attached or detached from a VM or the time when the VM to which the disk was attached was deallocated or started.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastOwnershipUpdateTime?: Date;\n /** Determines how platform treats disk failures */\n availabilityPolicy?: AvailabilityPolicy;\n}\n\n/** Snapshot resource. */\nexport interface Snapshot extends TrackedResource {\n /**\n * Unused. Always Null.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedBy?: string;\n /** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\n sku?: SnapshotSku;\n /** The extended location where the snapshot will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocation;\n /**\n * The time when the snapshot was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** The Operating System type. */\n osType?: OperatingSystemTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** Purchase plan information for the image from which the source disk for the snapshot was originally created. */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities for the image from which the source disk from the snapshot was originally created. */\n supportedCapabilities?: SupportedCapabilities;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData?: CreationData;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /**\n * The size of the disk in bytes. This field is read only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeBytes?: number;\n /**\n * The state of the snapshot.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskState?: DiskState;\n /**\n * Unique Guid identifying the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /**\n * The disk provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Whether a snapshot is incremental. Incremental snapshots on the same disk occupy less space than full snapshots and can be diffed. */\n incremental?: boolean;\n /**\n * Incremental snapshots for a disk share an incremental snapshot family id. The Get Page Range Diff API can only be called on incremental snapshots with the same family id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly incrementalSnapshotFamilyId?: string;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfile;\n /** Indicates the OS on a snapshot supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\n copyCompletionError?: CopyCompletionError;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /**\n * The state of snapshot which determines the access availability of the snapshot.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly snapshotAccessState?: SnapshotAccessState;\n}\n\n/** Specifies information about the Shared Image Gallery that you want to create or update. */\nexport interface Gallery extends TrackedResource {\n /** The identity of the gallery, if configured. */\n identity?: GalleryIdentity;\n /** The description of this Shared Image Gallery resource. This property is updatable. */\n description?: string;\n /** Describes the gallery unique name. */\n identifier?: GalleryIdentifier;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** Profile for gallery sharing to subscription or tenant */\n sharingProfile?: SharingProfile;\n /** Contains information about the soft deletion policy of the gallery. */\n softDeletePolicy?: SoftDeletePolicy;\n /**\n * Sharing status of current gallery.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sharingStatus?: SharingStatus;\n}\n\n/** Specifies information about the gallery Application Definition that you want to create or update. */\nexport interface GalleryApplication extends TrackedResource {\n /** The description of this gallery Application Definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery Application Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Application Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This property allows you to specify the supported type of the OS that application is built for. Possible values are: **Windows,** **Linux.** */\n supportedOSType?: OperatingSystemTypes;\n /** A list of custom actions that can be performed with all of the Gallery Application Versions within this Gallery Application. */\n customActions?: GalleryApplicationCustomAction[];\n}\n\n/** Specifies information about the gallery Application Version that you want to create or update. */\nexport interface GalleryApplicationVersion extends TrackedResource {\n /** The publishing profile of a gallery image version. */\n publishingProfile?: GalleryApplicationVersionPublishingProfile;\n /** The safety profile of the Gallery Application Version. */\n safetyProfile?: GalleryApplicationVersionSafetyProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface GalleryImage extends TrackedResource {\n /** The description of this gallery image definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery image definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the gallery image definition identifier. */\n identifier?: GalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Optional. Must be set to true if the gallery image features are being updated. */\n allowUpdateImage?: boolean;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface GalleryImageVersion extends TrackedResource {\n /** The publishing profile of a gallery image Version. */\n publishingProfile?: GalleryImageVersionPublishingProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** This is the storage profile of a Gallery Image Version. */\n storageProfile?: GalleryImageVersionStorageProfile;\n /** This is the safety profile of the Gallery Image Version. */\n safetyProfile?: GalleryImageVersionSafetyProfile;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** The security profile of a gallery image version */\n securityProfile?: ImageVersionSecurityProfile;\n /** Indicates if this is a soft-delete resource restoration request. */\n restore?: boolean;\n /**\n * This is the validations profile of a Gallery Image Version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly validationsProfile?: ValidationsProfile;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile that you want to create or update. */\nexport interface GalleryInVMAccessControlProfile extends TrackedResource {\n /** Describes the properties of a gallery inVMAccessControlProfile. */\n properties?: GalleryInVMAccessControlProfileProperties;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile version that you want to create or update. */\nexport interface GalleryInVMAccessControlProfileVersion extends TrackedResource {\n /** The target regions where the Resource Profile version is going to be replicated to. This property is updatable. */\n targetLocations?: TargetRegion[];\n /** If set to true, Virtual Machines deployed from the latest version of the Resource Profile won't use this Profile version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the Resource Profile Version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** This property allows you to specify whether the access control rules are in Audit mode, in Enforce mode or Disabled. Possible values are: 'Audit', 'Enforce' or 'Disabled'. */\n mode?: AccessControlRulesMode;\n /** This property allows you to specify if the requests will be allowed to access the host endpoints. Possible values are: 'Allow', 'Deny'. */\n defaultAccess?: EndpointAccess;\n /** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\n rules?: AccessControlRules;\n}\n\n/** The details information of soft-deleted resource. */\nexport interface GallerySoftDeletedResource extends TrackedResource {\n /** arm id of the soft-deleted resource */\n resourceArmId?: string;\n /** artifact type of the soft-deleted resource */\n softDeletedArtifactType?: SoftDeletedArtifactTypes;\n /** The timestamp for when the resource is soft-deleted. In dateTime offset format. */\n softDeletedTime?: string;\n}\n\n/** Restore Point details. */\nexport interface RestorePoint extends ProxyResource {\n /** List of disk resource ids that the customer wishes to exclude from the restore point. If no disks are specified, all disks will be included. */\n excludeDisks?: ApiEntityReference[];\n /** Gets the details of the VM captured at the time of the restore point creation. */\n sourceMetadata?: RestorePointSourceMetadata;\n /**\n * Gets the provisioning state of the restore point.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** ConsistencyMode of the RestorePoint. Can be specified in the input while creating a restore point. For now, only CrashConsistent is accepted as a valid input. Please refer to https://aka.ms/RestorePoints for more details. */\n consistencyMode?: ConsistencyModeTypes;\n /** Gets the creation time of the restore point. */\n timeCreated?: Date;\n /** Resource Id of the source restore point from which a copy needs to be created. */\n sourceRestorePoint?: ApiEntityReference;\n /**\n * The restore point instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: RestorePointInstanceView;\n /** This property determines the time in minutes the snapshot is retained as instant access for restoring Premium SSD v2 or Ultra disk with fast restore performance in this restore point. */\n instantAccessDurationMinutes?: number;\n}\n\n/** The Private Endpoint Connection resource. */\nexport interface PrivateEndpointConnection extends ProxyResource {\n /**\n * The resource of private end point.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateEndpoint?: PrivateEndpoint;\n /** A collection of information about the state of the connection between DiskAccess and Virtual Network. */\n privateLinkServiceConnectionState?: PrivateLinkServiceConnectionState;\n /**\n * The provisioning state of the private endpoint connection resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: PrivateEndpointConnectionProvisioningState;\n}\n\n/** Properties of disk restore point */\nexport interface DiskRestorePoint extends ProxyResource {\n /**\n * The timestamp of restorePoint creation\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /**\n * arm id of source disk or source disk restore point.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceResourceId?: string;\n /**\n * The Operating System type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly osType?: OperatingSystemTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** Purchase plan information for the the image from which the OS disk was created. */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilities;\n /**\n * id of the backing snapshot's MIS family\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly familyId?: string;\n /**\n * unique incarnation id of the source disk\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceUniqueId?: string;\n /**\n * Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly encryption?: Encryption;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Percentage complete for the background copy of disk restore point when source resource is from a different region. */\n completionPercent?: number;\n /**\n * Replication state of disk restore point when source resource is from a different region.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationState?: string;\n /**\n * Location of source disk or source disk restore point when source resource is from a different region.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceResourceLocation?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfile;\n /**\n * Logical sector size in bytes for disk restore points of UltraSSD_LRS and PremiumV2_LRS disks. Supported values are 512 and 4096. 4096 is the default.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly logicalSectorSize?: number;\n}\n\n/** Describes a Virtual Machine Scale Set VM Reimage Parameters. */\nexport interface VirtualMachineScaleSetReimageParameters\n extends VirtualMachineScaleSetVMReimageParameters {\n /** The virtual machine scale set instance ids. Omitting the virtual machine scale set instance ids will result in the operation being performed on all virtual machines in the virtual machine scale set. */\n instanceIds?: string[];\n}\n\n/** Specifies information about the Shared Gallery that you want to create or update. */\nexport interface SharedGallery extends PirSharedGalleryResource {\n /**\n * The artifact tags of a shared gallery resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly artifactTags?: { [propertyName: string]: string };\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface SharedGalleryImage extends PirSharedGalleryResource {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the gallery image definition identifier. */\n identifier?: GalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Privacy statement uri for the current community gallery image. */\n privacyStatementUri?: string;\n /** End-user license agreement for the current community gallery image. */\n eula?: string;\n /** The artifact tags of a shared gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface SharedGalleryImageVersion extends PirSharedGalleryResource {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: Date;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfile;\n /** The artifact tags of a shared gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** Defines headers for AvailabilitySets_convertToVirtualMachineScaleSet operation. */\nexport interface AvailabilitySetsConvertToVirtualMachineScaleSetHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Images_createOrUpdate operation. */\nexport interface ImagesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Images_update operation. */\nexport interface ImagesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Images_delete operation. */\nexport interface ImagesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for LogAnalytics_exportRequestRateByInterval operation. */\nexport interface LogAnalyticsExportRequestRateByIntervalHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for LogAnalytics_exportThrottledRequests operation. */\nexport interface LogAnalyticsExportThrottledRequestsHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineRunCommands_createOrUpdate operation. */\nexport interface VirtualMachineRunCommandsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineRunCommands_update operation. */\nexport interface VirtualMachineRunCommandsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineRunCommands_delete operation. */\nexport interface VirtualMachineRunCommandsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_update operation. */\nexport interface VirtualMachineScaleSetsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_delete operation. */\nexport interface VirtualMachineScaleSetsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_approveRollingUpgrade operation. */\nexport interface VirtualMachineScaleSetsApproveRollingUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_deallocate operation. */\nexport interface VirtualMachineScaleSetsDeallocateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_deleteInstances operation. */\nexport interface VirtualMachineScaleSetsDeleteInstancesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_updateInstances operation. */\nexport interface VirtualMachineScaleSetsUpdateInstancesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_performMaintenance operation. */\nexport interface VirtualMachineScaleSetsPerformMaintenanceHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_powerOff operation. */\nexport interface VirtualMachineScaleSetsPowerOffHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_reapply operation. */\nexport interface VirtualMachineScaleSetsReapplyHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_redeploy operation. */\nexport interface VirtualMachineScaleSetsRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_reimage operation. */\nexport interface VirtualMachineScaleSetsReimageHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_reimageAll operation. */\nexport interface VirtualMachineScaleSetsReimageAllHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_restart operation. */\nexport interface VirtualMachineScaleSetsRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_scaleOut operation. */\nexport interface VirtualMachineScaleSetsScaleOutHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_setOrchestrationServiceState operation. */\nexport interface VirtualMachineScaleSetsSetOrchestrationServiceStateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_start operation. */\nexport interface VirtualMachineScaleSetsStartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_createOrUpdate operation. */\nexport interface VirtualMachinesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_update operation. */\nexport interface VirtualMachinesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_delete operation. */\nexport interface VirtualMachinesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_assessPatches operation. */\nexport interface VirtualMachinesAssessPatchesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_attachDetachDataDisks operation. */\nexport interface VirtualMachinesAttachDetachDataDisksHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_capture operation. */\nexport interface VirtualMachinesCaptureHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_convertToManagedDisks operation. */\nexport interface VirtualMachinesConvertToManagedDisksHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_deallocate operation. */\nexport interface VirtualMachinesDeallocateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_installPatches operation. */\nexport interface VirtualMachinesInstallPatchesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_migrateToVMScaleSet operation. */\nexport interface VirtualMachinesMigrateToVMScaleSetHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_performMaintenance operation. */\nexport interface VirtualMachinesPerformMaintenanceHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_powerOff operation. */\nexport interface VirtualMachinesPowerOffHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_reapply operation. */\nexport interface VirtualMachinesReapplyHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_redeploy operation. */\nexport interface VirtualMachinesRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_reimage operation. */\nexport interface VirtualMachinesReimageHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_restart operation. */\nexport interface VirtualMachinesRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_runCommand operation. */\nexport interface VirtualMachinesRunCommandHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_start operation. */\nexport interface VirtualMachinesStartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for RestorePointCollections_delete operation. */\nexport interface RestorePointCollectionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for CapacityReservations_createOrUpdate operation. */\nexport interface CapacityReservationsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for CapacityReservations_update operation. */\nexport interface CapacityReservationsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for CapacityReservations_delete operation. */\nexport interface CapacityReservationsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_createOrUpdate operation. */\nexport interface DedicatedHostsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_update operation. */\nexport interface DedicatedHostsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_delete operation. */\nexport interface DedicatedHostsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_redeploy operation. */\nexport interface DedicatedHostsRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_restart operation. */\nexport interface DedicatedHostsRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for RestorePoints_create operation. */\nexport interface RestorePointsCreateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for RestorePoints_delete operation. */\nexport interface RestorePointsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetRollingUpgrades_startExtensionUpgrade operation. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartExtensionUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetRollingUpgrades_startOSUpgrade operation. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartOSUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetRollingUpgrades_cancel operation. */\nexport interface VirtualMachineScaleSetRollingUpgradesCancelHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetExtensions_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetExtensionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetExtensions_update operation. */\nexport interface VirtualMachineScaleSetExtensionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetExtensions_delete operation. */\nexport interface VirtualMachineScaleSetExtensionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_update operation. */\nexport interface VirtualMachineScaleSetVMsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_delete operation. */\nexport interface VirtualMachineScaleSetVMsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_approveRollingUpgrade operation. */\nexport interface VirtualMachineScaleSetVMsApproveRollingUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_attachDetachDataDisks operation. */\nexport interface VirtualMachineScaleSetVMsAttachDetachDataDisksHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_deallocate operation. */\nexport interface VirtualMachineScaleSetVMsDeallocateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_performMaintenance operation. */\nexport interface VirtualMachineScaleSetVMsPerformMaintenanceHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_powerOff operation. */\nexport interface VirtualMachineScaleSetVMsPowerOffHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_redeploy operation. */\nexport interface VirtualMachineScaleSetVMsRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_reimage operation. */\nexport interface VirtualMachineScaleSetVMsReimageHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_reimageAll operation. */\nexport interface VirtualMachineScaleSetVMsReimageAllHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_restart operation. */\nexport interface VirtualMachineScaleSetVMsRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_runCommand operation. */\nexport interface VirtualMachineScaleSetVMsRunCommandHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_start operation. */\nexport interface VirtualMachineScaleSetVMsStartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMExtensions_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetVMExtensionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMExtensions_update operation. */\nexport interface VirtualMachineScaleSetVMExtensionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMExtensions_delete operation. */\nexport interface VirtualMachineScaleSetVMExtensionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMRunCommands_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetVMRunCommandsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMRunCommands_update operation. */\nexport interface VirtualMachineScaleSetVMRunCommandsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMRunCommands_delete operation. */\nexport interface VirtualMachineScaleSetVMRunCommandsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineExtensions_createOrUpdate operation. */\nexport interface VirtualMachineExtensionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineExtensions_update operation. */\nexport interface VirtualMachineExtensionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineExtensions_delete operation. */\nexport interface VirtualMachineExtensionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_createOrUpdate operation. */\nexport interface DiskAccessesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_update operation. */\nexport interface DiskAccessesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_delete operation. */\nexport interface DiskAccessesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_updateAPrivateEndpointConnection operation. */\nexport interface DiskAccessesUpdateAPrivateEndpointConnectionHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_deleteAPrivateEndpointConnection operation. */\nexport interface DiskAccessesDeleteAPrivateEndpointConnectionHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskEncryptionSets_createOrUpdate operation. */\nexport interface DiskEncryptionSetsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskEncryptionSets_update operation. */\nexport interface DiskEncryptionSetsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskEncryptionSets_delete operation. */\nexport interface DiskEncryptionSetsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_createOrUpdate operation. */\nexport interface DisksCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_update operation. */\nexport interface DisksUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_delete operation. */\nexport interface DisksDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_grantAccess operation. */\nexport interface DisksGrantAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_revokeAccess operation. */\nexport interface DisksRevokeAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_createOrUpdate operation. */\nexport interface SnapshotsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_update operation. */\nexport interface SnapshotsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_delete operation. */\nexport interface SnapshotsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_grantAccess operation. */\nexport interface SnapshotsGrantAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_revokeAccess operation. */\nexport interface SnapshotsRevokeAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskRestorePoint_grantAccess operation. */\nexport interface DiskRestorePointGrantAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskRestorePoint_revokeAccess operation. */\nexport interface DiskRestorePointRevokeAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Galleries_createOrUpdate operation. */\nexport interface GalleriesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Galleries_update operation. */\nexport interface GalleriesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Galleries_delete operation. */\nexport interface GalleriesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplications_createOrUpdate operation. */\nexport interface GalleryApplicationsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplications_update operation. */\nexport interface GalleryApplicationsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplications_delete operation. */\nexport interface GalleryApplicationsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplicationVersions_createOrUpdate operation. */\nexport interface GalleryApplicationVersionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplicationVersions_update operation. */\nexport interface GalleryApplicationVersionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplicationVersions_delete operation. */\nexport interface GalleryApplicationVersionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImages_createOrUpdate operation. */\nexport interface GalleryImagesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImages_update operation. */\nexport interface GalleryImagesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImages_delete operation. */\nexport interface GalleryImagesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImageVersions_createOrUpdate operation. */\nexport interface GalleryImageVersionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImageVersions_update operation. */\nexport interface GalleryImageVersionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImageVersions_delete operation. */\nexport interface GalleryImageVersionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfiles_createOrUpdate operation. */\nexport interface GalleryInVMAccessControlProfilesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfiles_update operation. */\nexport interface GalleryInVMAccessControlProfilesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfiles_delete operation. */\nexport interface GalleryInVMAccessControlProfilesDeleteHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfileVersions_createOrUpdate operation. */\nexport interface GalleryInVMAccessControlProfileVersionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfileVersions_update operation. */\nexport interface GalleryInVMAccessControlProfileVersionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfileVersions_delete operation. */\nexport interface GalleryInVMAccessControlProfileVersionsDeleteHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n}\n\n/** Defines headers for GallerySharingProfile_update operation. */\nexport interface GallerySharingProfileUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Known values of {@link Origin} that the service accepts. */\nexport enum KnownOrigin {\n /** User */\n User = \"user\",\n /** System */\n System = \"system\",\n /** UserSystem */\n UserSystem = \"user,system\",\n}\n\n/**\n * Defines values for Origin. \\\n * {@link KnownOrigin} can be used interchangeably with Origin,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **user** \\\n * **system** \\\n * **user,system**\n */\nexport type Origin = string;\n\n/** Known values of {@link ActionType} that the service accepts. */\nexport enum KnownActionType {\n /** Internal */\n Internal = \"Internal\",\n}\n\n/**\n * Defines values for ActionType. \\\n * {@link KnownActionType} can be used interchangeably with ActionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Internal**\n */\nexport type ActionType = string;\n\n/** Known values of {@link CreatedByType} that the service accepts. */\nexport enum KnownCreatedByType {\n /** User */\n User = \"User\",\n /** Application */\n Application = \"Application\",\n /** ManagedIdentity */\n ManagedIdentity = \"ManagedIdentity\",\n /** Key */\n Key = \"Key\",\n}\n\n/**\n * Defines values for CreatedByType. \\\n * {@link KnownCreatedByType} can be used interchangeably with CreatedByType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **User** \\\n * **Application** \\\n * **ManagedIdentity** \\\n * **Key**\n */\nexport type CreatedByType = string;\n\n/** Known values of {@link ExpandTypesForGetCapacityReservationGroups} that the service accepts. */\nexport enum KnownExpandTypesForGetCapacityReservationGroups {\n /** VirtualMachineScaleSetVMsRef */\n VirtualMachineScaleSetVMsRef = \"virtualMachineScaleSetVMs/$ref\",\n /** VirtualMachinesRef */\n VirtualMachinesRef = \"virtualMachines/$ref\",\n}\n\n/**\n * Defines values for ExpandTypesForGetCapacityReservationGroups. \\\n * {@link KnownExpandTypesForGetCapacityReservationGroups} can be used interchangeably with ExpandTypesForGetCapacityReservationGroups,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **virtualMachineScaleSetVMs\\/$ref** \\\n * **virtualMachines\\/$ref**\n */\nexport type ExpandTypesForGetCapacityReservationGroups = string;\n\n/** Known values of {@link ResourceIdOptionsForGetCapacityReservationGroups} that the service accepts. */\nexport enum KnownResourceIdOptionsForGetCapacityReservationGroups {\n /** CreatedInSubscription */\n CreatedInSubscription = \"CreatedInSubscription\",\n /** SharedWithSubscription */\n SharedWithSubscription = \"SharedWithSubscription\",\n /** All */\n All = \"All\",\n}\n\n/**\n * Defines values for ResourceIdOptionsForGetCapacityReservationGroups. \\\n * {@link KnownResourceIdOptionsForGetCapacityReservationGroups} can be used interchangeably with ResourceIdOptionsForGetCapacityReservationGroups,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CreatedInSubscription** \\\n * **SharedWithSubscription** \\\n * **All**\n */\nexport type ResourceIdOptionsForGetCapacityReservationGroups = string;\n\n/** Known values of {@link ReservationType} that the service accepts. */\nexport enum KnownReservationType {\n /** To consume on demand allocated capacity reservation when a capacity reservation group is provided. */\n Targeted = \"Targeted\",\n /** To consume scheduled allocated block capacity reservation when a capacity reservation group is provided. */\n Block = \"Block\",\n}\n\n/**\n * Defines values for ReservationType. \\\n * {@link KnownReservationType} can be used interchangeably with ReservationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Targeted**: To consume on demand allocated capacity reservation when a capacity reservation group is provided. \\\n * **Block**: To consume scheduled allocated block capacity reservation when a capacity reservation group is provided.\n */\nexport type ReservationType = string;\n\n/** Known values of {@link StorageAccountTypes} that the service accepts. */\nexport enum KnownStorageAccountTypes {\n /** StandardLRS */\n StandardLRS = \"Standard_LRS\",\n /** PremiumLRS */\n PremiumLRS = \"Premium_LRS\",\n /** StandardSSDLRS */\n StandardSSDLRS = \"StandardSSD_LRS\",\n /** UltraSSDLRS */\n UltraSSDLRS = \"UltraSSD_LRS\",\n /** PremiumZRS */\n PremiumZRS = \"Premium_ZRS\",\n /** StandardSSDZRS */\n StandardSSDZRS = \"StandardSSD_ZRS\",\n /** PremiumV2LRS */\n PremiumV2LRS = \"PremiumV2_LRS\",\n}\n\n/**\n * Defines values for StorageAccountTypes. \\\n * {@link KnownStorageAccountTypes} can be used interchangeably with StorageAccountTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS** \\\n * **Premium_LRS** \\\n * **StandardSSD_LRS** \\\n * **UltraSSD_LRS** \\\n * **Premium_ZRS** \\\n * **StandardSSD_ZRS** \\\n * **PremiumV2_LRS**\n */\nexport type StorageAccountTypes = string;\n\n/** Known values of {@link HyperVGenerationTypes} that the service accepts. */\nexport enum KnownHyperVGenerationTypes {\n /** V1 */\n V1 = \"V1\",\n /** V2 */\n V2 = \"V2\",\n}\n\n/**\n * Defines values for HyperVGenerationTypes. \\\n * {@link KnownHyperVGenerationTypes} can be used interchangeably with HyperVGenerationTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **V1** \\\n * **V2**\n */\nexport type HyperVGenerationTypes = string;\n\n/** Known values of {@link ExtendedLocationTypes} that the service accepts. */\nexport enum KnownExtendedLocationTypes {\n /** EdgeZone */\n EdgeZone = \"EdgeZone\",\n}\n\n/**\n * Defines values for ExtendedLocationTypes. \\\n * {@link KnownExtendedLocationTypes} can be used interchangeably with ExtendedLocationTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EdgeZone**\n */\nexport type ExtendedLocationTypes = string;\n\n/** Known values of {@link VmDiskTypes} that the service accepts. */\nexport enum KnownVmDiskTypes {\n /** None */\n None = \"None\",\n /** Unmanaged */\n Unmanaged = \"Unmanaged\",\n}\n\n/**\n * Defines values for VmDiskTypes. \\\n * {@link KnownVmDiskTypes} can be used interchangeably with VmDiskTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Unmanaged**\n */\nexport type VmDiskTypes = string;\n\n/** Known values of {@link ArchitectureTypes} that the service accepts. */\nexport enum KnownArchitectureTypes {\n /** X64 */\n X64 = \"x64\",\n /** Arm64 */\n Arm64 = \"Arm64\",\n}\n\n/**\n * Defines values for ArchitectureTypes. \\\n * {@link KnownArchitectureTypes} can be used interchangeably with ArchitectureTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **x64** \\\n * **Arm64**\n */\nexport type ArchitectureTypes = string;\n\n/** Known values of {@link ImageState} that the service accepts. */\nexport enum KnownImageState {\n /** Active */\n Active = \"Active\",\n /** ScheduledForDeprecation */\n ScheduledForDeprecation = \"ScheduledForDeprecation\",\n /** Deprecated */\n Deprecated = \"Deprecated\",\n}\n\n/**\n * Defines values for ImageState. \\\n * {@link KnownImageState} can be used interchangeably with ImageState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Active** \\\n * **ScheduledForDeprecation** \\\n * **Deprecated**\n */\nexport type ImageState = string;\n\n/** Known values of {@link AlternativeType} that the service accepts. */\nexport enum KnownAlternativeType {\n /** None */\n None = \"None\",\n /** Offer */\n Offer = \"Offer\",\n /** Plan */\n Plan = \"Plan\",\n}\n\n/**\n * Defines values for AlternativeType. \\\n * {@link KnownAlternativeType} can be used interchangeably with AlternativeType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Offer** \\\n * **Plan**\n */\nexport type AlternativeType = string;\n\n/** Known values of {@link RepairAction} that the service accepts. */\nexport enum KnownRepairAction {\n /** Replace */\n Replace = \"Replace\",\n /** Restart */\n Restart = \"Restart\",\n /** Reimage */\n Reimage = \"Reimage\",\n}\n\n/**\n * Defines values for RepairAction. \\\n * {@link KnownRepairAction} can be used interchangeably with RepairAction,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Replace** \\\n * **Restart** \\\n * **Reimage**\n */\nexport type RepairAction = string;\n\n/** Known values of {@link WindowsVMGuestPatchMode} that the service accepts. */\nexport enum KnownWindowsVMGuestPatchMode {\n /** Manual */\n Manual = \"Manual\",\n /** AutomaticByOS */\n AutomaticByOS = \"AutomaticByOS\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for WindowsVMGuestPatchMode. \\\n * {@link KnownWindowsVMGuestPatchMode} can be used interchangeably with WindowsVMGuestPatchMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Manual** \\\n * **AutomaticByOS** \\\n * **AutomaticByPlatform**\n */\nexport type WindowsVMGuestPatchMode = string;\n\n/** Known values of {@link WindowsPatchAssessmentMode} that the service accepts. */\nexport enum KnownWindowsPatchAssessmentMode {\n /** ImageDefault */\n ImageDefault = \"ImageDefault\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for WindowsPatchAssessmentMode. \\\n * {@link KnownWindowsPatchAssessmentMode} can be used interchangeably with WindowsPatchAssessmentMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ImageDefault** \\\n * **AutomaticByPlatform**\n */\nexport type WindowsPatchAssessmentMode = string;\n\n/** Known values of {@link WindowsVMGuestPatchAutomaticByPlatformRebootSetting} that the service accepts. */\nexport enum KnownWindowsVMGuestPatchAutomaticByPlatformRebootSetting {\n /** Unknown */\n Unknown = \"Unknown\",\n /** IfRequired */\n IfRequired = \"IfRequired\",\n /** Never */\n Never = \"Never\",\n /** Always */\n Always = \"Always\",\n}\n\n/**\n * Defines values for WindowsVMGuestPatchAutomaticByPlatformRebootSetting. \\\n * {@link KnownWindowsVMGuestPatchAutomaticByPlatformRebootSetting} can be used interchangeably with WindowsVMGuestPatchAutomaticByPlatformRebootSetting,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **IfRequired** \\\n * **Never** \\\n * **Always**\n */\nexport type WindowsVMGuestPatchAutomaticByPlatformRebootSetting = string;\n\n/** Known values of {@link LinuxVMGuestPatchMode} that the service accepts. */\nexport enum KnownLinuxVMGuestPatchMode {\n /** ImageDefault */\n ImageDefault = \"ImageDefault\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for LinuxVMGuestPatchMode. \\\n * {@link KnownLinuxVMGuestPatchMode} can be used interchangeably with LinuxVMGuestPatchMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ImageDefault** \\\n * **AutomaticByPlatform**\n */\nexport type LinuxVMGuestPatchMode = string;\n\n/** Known values of {@link LinuxPatchAssessmentMode} that the service accepts. */\nexport enum KnownLinuxPatchAssessmentMode {\n /** ImageDefault */\n ImageDefault = \"ImageDefault\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for LinuxPatchAssessmentMode. \\\n * {@link KnownLinuxPatchAssessmentMode} can be used interchangeably with LinuxPatchAssessmentMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ImageDefault** \\\n * **AutomaticByPlatform**\n */\nexport type LinuxPatchAssessmentMode = string;\n\n/** Known values of {@link LinuxVMGuestPatchAutomaticByPlatformRebootSetting} that the service accepts. */\nexport enum KnownLinuxVMGuestPatchAutomaticByPlatformRebootSetting {\n /** Unknown */\n Unknown = \"Unknown\",\n /** IfRequired */\n IfRequired = \"IfRequired\",\n /** Never */\n Never = \"Never\",\n /** Always */\n Always = \"Always\",\n}\n\n/**\n * Defines values for LinuxVMGuestPatchAutomaticByPlatformRebootSetting. \\\n * {@link KnownLinuxVMGuestPatchAutomaticByPlatformRebootSetting} can be used interchangeably with LinuxVMGuestPatchAutomaticByPlatformRebootSetting,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **IfRequired** \\\n * **Never** \\\n * **Always**\n */\nexport type LinuxVMGuestPatchAutomaticByPlatformRebootSetting = string;\n\n/** Known values of {@link DiskCreateOptionTypes} that the service accepts. */\nexport enum KnownDiskCreateOptionTypes {\n /** FromImage */\n FromImage = \"FromImage\",\n /** Empty */\n Empty = \"Empty\",\n /** Attach */\n Attach = \"Attach\",\n /** Copy */\n Copy = \"Copy\",\n /** Restore */\n Restore = \"Restore\",\n}\n\n/**\n * Defines values for DiskCreateOptionTypes. \\\n * {@link KnownDiskCreateOptionTypes} can be used interchangeably with DiskCreateOptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **FromImage** \\\n * **Empty** \\\n * **Attach** \\\n * **Copy** \\\n * **Restore**\n */\nexport type DiskCreateOptionTypes = string;\n\n/** Known values of {@link DiffDiskOptions} that the service accepts. */\nexport enum KnownDiffDiskOptions {\n /** Local */\n Local = \"Local\",\n}\n\n/**\n * Defines values for DiffDiskOptions. \\\n * {@link KnownDiffDiskOptions} can be used interchangeably with DiffDiskOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Local**\n */\nexport type DiffDiskOptions = string;\n\n/** Known values of {@link DiffDiskPlacement} that the service accepts. */\nexport enum KnownDiffDiskPlacement {\n /** CacheDisk */\n CacheDisk = \"CacheDisk\",\n /** ResourceDisk */\n ResourceDisk = \"ResourceDisk\",\n /** NvmeDisk */\n NvmeDisk = \"NvmeDisk\",\n}\n\n/**\n * Defines values for DiffDiskPlacement. \\\n * {@link KnownDiffDiskPlacement} can be used interchangeably with DiffDiskPlacement,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CacheDisk** \\\n * **ResourceDisk** \\\n * **NvmeDisk**\n */\nexport type DiffDiskPlacement = string;\n\n/** Known values of {@link SecurityEncryptionTypes} that the service accepts. */\nexport enum KnownSecurityEncryptionTypes {\n /** VMGuestStateOnly */\n VMGuestStateOnly = \"VMGuestStateOnly\",\n /** DiskWithVMGuestState */\n DiskWithVMGuestState = \"DiskWithVMGuestState\",\n /** NonPersistedTPM */\n NonPersistedTPM = \"NonPersistedTPM\",\n}\n\n/**\n * Defines values for SecurityEncryptionTypes. \\\n * {@link KnownSecurityEncryptionTypes} can be used interchangeably with SecurityEncryptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **VMGuestStateOnly** \\\n * **DiskWithVMGuestState** \\\n * **NonPersistedTPM**\n */\nexport type SecurityEncryptionTypes = string;\n\n/** Known values of {@link DiskDeleteOptionTypes} that the service accepts. */\nexport enum KnownDiskDeleteOptionTypes {\n /** Delete */\n Delete = \"Delete\",\n /** Detach */\n Detach = \"Detach\",\n}\n\n/**\n * Defines values for DiskDeleteOptionTypes. \\\n * {@link KnownDiskDeleteOptionTypes} can be used interchangeably with DiskDeleteOptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Delete** \\\n * **Detach**\n */\nexport type DiskDeleteOptionTypes = string;\n\n/** Known values of {@link DiskControllerTypes} that the service accepts. */\nexport enum KnownDiskControllerTypes {\n /** Scsi */\n Scsi = \"SCSI\",\n /** NVMe */\n NVMe = \"NVMe\",\n}\n\n/**\n * Defines values for DiskControllerTypes. \\\n * {@link KnownDiskControllerTypes} can be used interchangeably with DiskControllerTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **SCSI** \\\n * **NVMe**\n */\nexport type DiskControllerTypes = string;\n\n/** Known values of {@link DomainNameLabelScopeTypes} that the service accepts. */\nexport enum KnownDomainNameLabelScopeTypes {\n /** TenantReuse */\n TenantReuse = \"TenantReuse\",\n /** SubscriptionReuse */\n SubscriptionReuse = \"SubscriptionReuse\",\n /** ResourceGroupReuse */\n ResourceGroupReuse = \"ResourceGroupReuse\",\n /** NoReuse */\n NoReuse = \"NoReuse\",\n}\n\n/**\n * Defines values for DomainNameLabelScopeTypes. \\\n * {@link KnownDomainNameLabelScopeTypes} can be used interchangeably with DomainNameLabelScopeTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TenantReuse** \\\n * **SubscriptionReuse** \\\n * **ResourceGroupReuse** \\\n * **NoReuse**\n */\nexport type DomainNameLabelScopeTypes = string;\n\n/** Known values of {@link IPVersion} that the service accepts. */\nexport enum KnownIPVersion {\n /** IPv4 */\n IPv4 = \"IPv4\",\n /** IPv6 */\n IPv6 = \"IPv6\",\n}\n\n/**\n * Defines values for IPVersion. \\\n * {@link KnownIPVersion} can be used interchangeably with IPVersion,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **IPv4** \\\n * **IPv6**\n */\nexport type IPVersion = string;\n\n/** Known values of {@link DeleteOptions} that the service accepts. */\nexport enum KnownDeleteOptions {\n /** Delete */\n Delete = \"Delete\",\n /** Detach */\n Detach = \"Detach\",\n}\n\n/**\n * Defines values for DeleteOptions. \\\n * {@link KnownDeleteOptions} can be used interchangeably with DeleteOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Delete** \\\n * **Detach**\n */\nexport type DeleteOptions = string;\n\n/** Known values of {@link PublicIPAddressSkuName} that the service accepts. */\nexport enum KnownPublicIPAddressSkuName {\n /** Basic */\n Basic = \"Basic\",\n /** Standard */\n Standard = \"Standard\",\n}\n\n/**\n * Defines values for PublicIPAddressSkuName. \\\n * {@link KnownPublicIPAddressSkuName} can be used interchangeably with PublicIPAddressSkuName,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Basic** \\\n * **Standard**\n */\nexport type PublicIPAddressSkuName = string;\n\n/** Known values of {@link PublicIPAddressSkuTier} that the service accepts. */\nexport enum KnownPublicIPAddressSkuTier {\n /** Regional */\n Regional = \"Regional\",\n /** Global */\n Global = \"Global\",\n}\n\n/**\n * Defines values for PublicIPAddressSkuTier. \\\n * {@link KnownPublicIPAddressSkuTier} can be used interchangeably with PublicIPAddressSkuTier,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Regional** \\\n * **Global**\n */\nexport type PublicIPAddressSkuTier = string;\n\n/** Known values of {@link NetworkInterfaceAuxiliaryMode} that the service accepts. */\nexport enum KnownNetworkInterfaceAuxiliaryMode {\n /** None */\n None = \"None\",\n /** AcceleratedConnections */\n AcceleratedConnections = \"AcceleratedConnections\",\n /** Floating */\n Floating = \"Floating\",\n}\n\n/**\n * Defines values for NetworkInterfaceAuxiliaryMode. \\\n * {@link KnownNetworkInterfaceAuxiliaryMode} can be used interchangeably with NetworkInterfaceAuxiliaryMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **AcceleratedConnections** \\\n * **Floating**\n */\nexport type NetworkInterfaceAuxiliaryMode = string;\n\n/** Known values of {@link NetworkInterfaceAuxiliarySku} that the service accepts. */\nexport enum KnownNetworkInterfaceAuxiliarySku {\n /** None */\n None = \"None\",\n /** A1 */\n A1 = \"A1\",\n /** A2 */\n A2 = \"A2\",\n /** A4 */\n A4 = \"A4\",\n /** A8 */\n A8 = \"A8\",\n}\n\n/**\n * Defines values for NetworkInterfaceAuxiliarySku. \\\n * {@link KnownNetworkInterfaceAuxiliarySku} can be used interchangeably with NetworkInterfaceAuxiliarySku,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **A1** \\\n * **A2** \\\n * **A4** \\\n * **A8**\n */\nexport type NetworkInterfaceAuxiliarySku = string;\n\n/** Known values of {@link NetworkApiVersion} that the service accepts. */\nexport enum KnownNetworkApiVersion {\n /** TwoThousandTwenty1101 */\n TwoThousandTwenty1101 = \"2020-11-01\",\n /** TwoThousandTwentyTwo1101 */\n TwoThousandTwentyTwo1101 = \"2022-11-01\",\n}\n\n/**\n * Defines values for NetworkApiVersion. \\\n * {@link KnownNetworkApiVersion} can be used interchangeably with NetworkApiVersion,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **2020-11-01** \\\n * **2022-11-01**\n */\nexport type NetworkApiVersion = string;\n\n/** Known values of {@link SecurityTypes} that the service accepts. */\nexport enum KnownSecurityTypes {\n /** TrustedLaunch */\n TrustedLaunch = \"TrustedLaunch\",\n /** ConfidentialVM */\n ConfidentialVM = \"ConfidentialVM\",\n}\n\n/**\n * Defines values for SecurityTypes. \\\n * {@link KnownSecurityTypes} can be used interchangeably with SecurityTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TrustedLaunch** \\\n * **ConfidentialVM**\n */\nexport type SecurityTypes = string;\n\n/** Known values of {@link Mode} that the service accepts. */\nexport enum KnownMode {\n /** Audit */\n Audit = \"Audit\",\n /** Enforce */\n Enforce = \"Enforce\",\n}\n\n/**\n * Defines values for Mode. \\\n * {@link KnownMode} can be used interchangeably with Mode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Audit** \\\n * **Enforce**\n */\nexport type Mode = string;\n\n/** Known values of {@link Modes} that the service accepts. */\nexport enum KnownModes {\n /** Audit */\n Audit = \"Audit\",\n /** Enforce */\n Enforce = \"Enforce\",\n /** Disabled */\n Disabled = \"Disabled\",\n}\n\n/**\n * Defines values for Modes. \\\n * {@link KnownModes} can be used interchangeably with Modes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Audit** \\\n * **Enforce** \\\n * **Disabled**\n */\nexport type Modes = string;\n\n/** Known values of {@link VirtualMachinePriorityTypes} that the service accepts. */\nexport enum KnownVirtualMachinePriorityTypes {\n /** Regular */\n Regular = \"Regular\",\n /** Low */\n Low = \"Low\",\n /** Spot */\n Spot = \"Spot\",\n}\n\n/**\n * Defines values for VirtualMachinePriorityTypes. \\\n * {@link KnownVirtualMachinePriorityTypes} can be used interchangeably with VirtualMachinePriorityTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Regular** \\\n * **Low** \\\n * **Spot**\n */\nexport type VirtualMachinePriorityTypes = string;\n\n/** Known values of {@link VirtualMachineEvictionPolicyTypes} that the service accepts. */\nexport enum KnownVirtualMachineEvictionPolicyTypes {\n /** Deallocate */\n Deallocate = \"Deallocate\",\n /** Delete */\n Delete = \"Delete\",\n}\n\n/**\n * Defines values for VirtualMachineEvictionPolicyTypes. \\\n * {@link KnownVirtualMachineEvictionPolicyTypes} can be used interchangeably with VirtualMachineEvictionPolicyTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Deallocate** \\\n * **Delete**\n */\nexport type VirtualMachineEvictionPolicyTypes = string;\n\n/** Known values of {@link VirtualMachineScaleSetScaleInRules} that the service accepts. */\nexport enum KnownVirtualMachineScaleSetScaleInRules {\n /** Default */\n Default = \"Default\",\n /** OldestVM */\n OldestVM = \"OldestVM\",\n /** NewestVM */\n NewestVM = \"NewestVM\",\n}\n\n/**\n * Defines values for VirtualMachineScaleSetScaleInRules. \\\n * {@link KnownVirtualMachineScaleSetScaleInRules} can be used interchangeably with VirtualMachineScaleSetScaleInRules,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Default** \\\n * **OldestVM** \\\n * **NewestVM**\n */\nexport type VirtualMachineScaleSetScaleInRules = string;\n\n/** Known values of {@link OrchestrationMode} that the service accepts. */\nexport enum KnownOrchestrationMode {\n /** Uniform */\n Uniform = \"Uniform\",\n /** Flexible */\n Flexible = \"Flexible\",\n}\n\n/**\n * Defines values for OrchestrationMode. \\\n * {@link KnownOrchestrationMode} can be used interchangeably with OrchestrationMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Uniform** \\\n * **Flexible**\n */\nexport type OrchestrationMode = string;\n\n/** Known values of {@link RebalanceStrategy} that the service accepts. */\nexport enum KnownRebalanceStrategy {\n /** Recreate */\n Recreate = \"Recreate\",\n}\n\n/**\n * Defines values for RebalanceStrategy. \\\n * {@link KnownRebalanceStrategy} can be used interchangeably with RebalanceStrategy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Recreate**\n */\nexport type RebalanceStrategy = string;\n\n/** Known values of {@link RebalanceBehavior} that the service accepts. */\nexport enum KnownRebalanceBehavior {\n /** CreateBeforeDelete */\n CreateBeforeDelete = \"CreateBeforeDelete\",\n}\n\n/**\n * Defines values for RebalanceBehavior. \\\n * {@link KnownRebalanceBehavior} can be used interchangeably with RebalanceBehavior,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CreateBeforeDelete**\n */\nexport type RebalanceBehavior = string;\n\n/** Known values of {@link ZonalPlatformFaultDomainAlignMode} that the service accepts. */\nexport enum KnownZonalPlatformFaultDomainAlignMode {\n /** Aligned */\n Aligned = \"Aligned\",\n /** Unaligned */\n Unaligned = \"Unaligned\",\n}\n\n/**\n * Defines values for ZonalPlatformFaultDomainAlignMode. \\\n * {@link KnownZonalPlatformFaultDomainAlignMode} can be used interchangeably with ZonalPlatformFaultDomainAlignMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Aligned** \\\n * **Unaligned**\n */\nexport type ZonalPlatformFaultDomainAlignMode = string;\n\n/** Known values of {@link AllocationStrategy} that the service accepts. */\nexport enum KnownAllocationStrategy {\n /** LowestPrice */\n LowestPrice = \"LowestPrice\",\n /** CapacityOptimized */\n CapacityOptimized = \"CapacityOptimized\",\n /** Prioritized */\n Prioritized = \"Prioritized\",\n}\n\n/**\n * Defines values for AllocationStrategy. \\\n * {@link KnownAllocationStrategy} can be used interchangeably with AllocationStrategy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **LowestPrice** \\\n * **CapacityOptimized** \\\n * **Prioritized**\n */\nexport type AllocationStrategy = string;\n\n/** Known values of {@link HighSpeedInterconnectPlacement} that the service accepts. */\nexport enum KnownHighSpeedInterconnectPlacement {\n /** No high speed interconnect placement */\n None = \"None\",\n /** Trunk high speed interconnect placement */\n Trunk = \"Trunk\",\n}\n\n/**\n * Defines values for HighSpeedInterconnectPlacement. \\\n * {@link KnownHighSpeedInterconnectPlacement} can be used interchangeably with HighSpeedInterconnectPlacement,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None**: No high speed interconnect placement \\\n * **Trunk**: Trunk high speed interconnect placement\n */\nexport type HighSpeedInterconnectPlacement = string;\n\n/** Known values of {@link ZonePlacementPolicyType} that the service accepts. */\nexport enum KnownZonePlacementPolicyType {\n /** Any */\n Any = \"Any\",\n /** Automatic zone placement in a Virtual Machine Scale Set. */\n Auto = \"Auto\",\n}\n\n/**\n * Defines values for ZonePlacementPolicyType. \\\n * {@link KnownZonePlacementPolicyType} can be used interchangeably with ZonePlacementPolicyType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Any** \\\n * **Auto**: Automatic zone placement in a Virtual Machine Scale Set.\n */\nexport type ZonePlacementPolicyType = string;\n\n/** Known values of {@link VirtualMachineSizeTypes} that the service accepts. */\nexport enum KnownVirtualMachineSizeTypes {\n /** BasicA0 */\n BasicA0 = \"Basic_A0\",\n /** BasicA1 */\n BasicA1 = \"Basic_A1\",\n /** BasicA2 */\n BasicA2 = \"Basic_A2\",\n /** BasicA3 */\n BasicA3 = \"Basic_A3\",\n /** BasicA4 */\n BasicA4 = \"Basic_A4\",\n /** StandardA0 */\n StandardA0 = \"Standard_A0\",\n /** StandardA1 */\n StandardA1 = \"Standard_A1\",\n /** StandardA2 */\n StandardA2 = \"Standard_A2\",\n /** StandardA3 */\n StandardA3 = \"Standard_A3\",\n /** StandardA4 */\n StandardA4 = \"Standard_A4\",\n /** StandardA5 */\n StandardA5 = \"Standard_A5\",\n /** StandardA6 */\n StandardA6 = \"Standard_A6\",\n /** StandardA7 */\n StandardA7 = \"Standard_A7\",\n /** StandardA8 */\n StandardA8 = \"Standard_A8\",\n /** StandardA9 */\n StandardA9 = \"Standard_A9\",\n /** StandardA10 */\n StandardA10 = \"Standard_A10\",\n /** StandardA11 */\n StandardA11 = \"Standard_A11\",\n /** StandardA1V2 */\n StandardA1V2 = \"Standard_A1_v2\",\n /** StandardA2V2 */\n StandardA2V2 = \"Standard_A2_v2\",\n /** StandardA4V2 */\n StandardA4V2 = \"Standard_A4_v2\",\n /** StandardA8V2 */\n StandardA8V2 = \"Standard_A8_v2\",\n /** StandardA2MV2 */\n StandardA2MV2 = \"Standard_A2m_v2\",\n /** StandardA4MV2 */\n StandardA4MV2 = \"Standard_A4m_v2\",\n /** StandardA8MV2 */\n StandardA8MV2 = \"Standard_A8m_v2\",\n /** StandardB1S */\n StandardB1S = \"Standard_B1s\",\n /** StandardB1Ms */\n StandardB1Ms = \"Standard_B1ms\",\n /** StandardB2S */\n StandardB2S = \"Standard_B2s\",\n /** StandardB2Ms */\n StandardB2Ms = \"Standard_B2ms\",\n /** StandardB4Ms */\n StandardB4Ms = \"Standard_B4ms\",\n /** StandardB8Ms */\n StandardB8Ms = \"Standard_B8ms\",\n /** StandardD1 */\n StandardD1 = \"Standard_D1\",\n /** StandardD2 */\n StandardD2 = \"Standard_D2\",\n /** StandardD3 */\n StandardD3 = \"Standard_D3\",\n /** StandardD4 */\n StandardD4 = \"Standard_D4\",\n /** StandardD11 */\n StandardD11 = \"Standard_D11\",\n /** StandardD12 */\n StandardD12 = \"Standard_D12\",\n /** StandardD13 */\n StandardD13 = \"Standard_D13\",\n /** StandardD14 */\n StandardD14 = \"Standard_D14\",\n /** StandardD1V2 */\n StandardD1V2 = \"Standard_D1_v2\",\n /** StandardD2V2 */\n StandardD2V2 = \"Standard_D2_v2\",\n /** StandardD3V2 */\n StandardD3V2 = \"Standard_D3_v2\",\n /** StandardD4V2 */\n StandardD4V2 = \"Standard_D4_v2\",\n /** StandardD5V2 */\n StandardD5V2 = \"Standard_D5_v2\",\n /** StandardD2V3 */\n StandardD2V3 = \"Standard_D2_v3\",\n /** StandardD4V3 */\n StandardD4V3 = \"Standard_D4_v3\",\n /** StandardD8V3 */\n StandardD8V3 = \"Standard_D8_v3\",\n /** StandardD16V3 */\n StandardD16V3 = \"Standard_D16_v3\",\n /** StandardD32V3 */\n StandardD32V3 = \"Standard_D32_v3\",\n /** StandardD64V3 */\n StandardD64V3 = \"Standard_D64_v3\",\n /** StandardD2SV3 */\n StandardD2SV3 = \"Standard_D2s_v3\",\n /** StandardD4SV3 */\n StandardD4SV3 = \"Standard_D4s_v3\",\n /** StandardD8SV3 */\n StandardD8SV3 = \"Standard_D8s_v3\",\n /** StandardD16SV3 */\n StandardD16SV3 = \"Standard_D16s_v3\",\n /** StandardD32SV3 */\n StandardD32SV3 = \"Standard_D32s_v3\",\n /** StandardD64SV3 */\n StandardD64SV3 = \"Standard_D64s_v3\",\n /** StandardD11V2 */\n StandardD11V2 = \"Standard_D11_v2\",\n /** StandardD12V2 */\n StandardD12V2 = \"Standard_D12_v2\",\n /** StandardD13V2 */\n StandardD13V2 = \"Standard_D13_v2\",\n /** StandardD14V2 */\n StandardD14V2 = \"Standard_D14_v2\",\n /** StandardD15V2 */\n StandardD15V2 = \"Standard_D15_v2\",\n /** StandardDS1 */\n StandardDS1 = \"Standard_DS1\",\n /** StandardDS2 */\n StandardDS2 = \"Standard_DS2\",\n /** StandardDS3 */\n StandardDS3 = \"Standard_DS3\",\n /** StandardDS4 */\n StandardDS4 = \"Standard_DS4\",\n /** StandardDS11 */\n StandardDS11 = \"Standard_DS11\",\n /** StandardDS12 */\n StandardDS12 = \"Standard_DS12\",\n /** StandardDS13 */\n StandardDS13 = \"Standard_DS13\",\n /** StandardDS14 */\n StandardDS14 = \"Standard_DS14\",\n /** StandardDS1V2 */\n StandardDS1V2 = \"Standard_DS1_v2\",\n /** StandardDS2V2 */\n StandardDS2V2 = \"Standard_DS2_v2\",\n /** StandardDS3V2 */\n StandardDS3V2 = \"Standard_DS3_v2\",\n /** StandardDS4V2 */\n StandardDS4V2 = \"Standard_DS4_v2\",\n /** StandardDS5V2 */\n StandardDS5V2 = \"Standard_DS5_v2\",\n /** StandardDS11V2 */\n StandardDS11V2 = \"Standard_DS11_v2\",\n /** StandardDS12V2 */\n StandardDS12V2 = \"Standard_DS12_v2\",\n /** StandardDS13V2 */\n StandardDS13V2 = \"Standard_DS13_v2\",\n /** StandardDS14V2 */\n StandardDS14V2 = \"Standard_DS14_v2\",\n /** StandardDS15V2 */\n StandardDS15V2 = \"Standard_DS15_v2\",\n /** StandardDS134V2 */\n StandardDS134V2 = \"Standard_DS13-4_v2\",\n /** StandardDS132V2 */\n StandardDS132V2 = \"Standard_DS13-2_v2\",\n /** StandardDS148V2 */\n StandardDS148V2 = \"Standard_DS14-8_v2\",\n /** StandardDS144V2 */\n StandardDS144V2 = \"Standard_DS14-4_v2\",\n /** StandardE2V3 */\n StandardE2V3 = \"Standard_E2_v3\",\n /** StandardE4V3 */\n StandardE4V3 = \"Standard_E4_v3\",\n /** StandardE8V3 */\n StandardE8V3 = \"Standard_E8_v3\",\n /** StandardE16V3 */\n StandardE16V3 = \"Standard_E16_v3\",\n /** StandardE32V3 */\n StandardE32V3 = \"Standard_E32_v3\",\n /** StandardE64V3 */\n StandardE64V3 = \"Standard_E64_v3\",\n /** StandardE2SV3 */\n StandardE2SV3 = \"Standard_E2s_v3\",\n /** StandardE4SV3 */\n StandardE4SV3 = \"Standard_E4s_v3\",\n /** StandardE8SV3 */\n StandardE8SV3 = \"Standard_E8s_v3\",\n /** StandardE16SV3 */\n StandardE16SV3 = \"Standard_E16s_v3\",\n /** StandardE32SV3 */\n StandardE32SV3 = \"Standard_E32s_v3\",\n /** StandardE64SV3 */\n StandardE64SV3 = \"Standard_E64s_v3\",\n /** StandardE3216V3 */\n StandardE3216V3 = \"Standard_E32-16_v3\",\n /** StandardE328SV3 */\n StandardE328SV3 = \"Standard_E32-8s_v3\",\n /** StandardE6432SV3 */\n StandardE6432SV3 = \"Standard_E64-32s_v3\",\n /** StandardE6416SV3 */\n StandardE6416SV3 = \"Standard_E64-16s_v3\",\n /** StandardF1 */\n StandardF1 = \"Standard_F1\",\n /** StandardF2 */\n StandardF2 = \"Standard_F2\",\n /** StandardF4 */\n StandardF4 = \"Standard_F4\",\n /** StandardF8 */\n StandardF8 = \"Standard_F8\",\n /** StandardF16 */\n StandardF16 = \"Standard_F16\",\n /** StandardF1S */\n StandardF1S = \"Standard_F1s\",\n /** StandardF2S */\n StandardF2S = \"Standard_F2s\",\n /** StandardF4S */\n StandardF4S = \"Standard_F4s\",\n /** StandardF8S */\n StandardF8S = \"Standard_F8s\",\n /** StandardF16S */\n StandardF16S = \"Standard_F16s\",\n /** StandardF2SV2 */\n StandardF2SV2 = \"Standard_F2s_v2\",\n /** StandardF4SV2 */\n StandardF4SV2 = \"Standard_F4s_v2\",\n /** StandardF8SV2 */\n StandardF8SV2 = \"Standard_F8s_v2\",\n /** StandardF16SV2 */\n StandardF16SV2 = \"Standard_F16s_v2\",\n /** StandardF32SV2 */\n StandardF32SV2 = \"Standard_F32s_v2\",\n /** StandardF64SV2 */\n StandardF64SV2 = \"Standard_F64s_v2\",\n /** StandardF72SV2 */\n StandardF72SV2 = \"Standard_F72s_v2\",\n /** StandardG1 */\n StandardG1 = \"Standard_G1\",\n /** StandardG2 */\n StandardG2 = \"Standard_G2\",\n /** StandardG3 */\n StandardG3 = \"Standard_G3\",\n /** StandardG4 */\n StandardG4 = \"Standard_G4\",\n /** StandardG5 */\n StandardG5 = \"Standard_G5\",\n /** StandardGS1 */\n StandardGS1 = \"Standard_GS1\",\n /** StandardGS2 */\n StandardGS2 = \"Standard_GS2\",\n /** StandardGS3 */\n StandardGS3 = \"Standard_GS3\",\n /** StandardGS4 */\n StandardGS4 = \"Standard_GS4\",\n /** StandardGS5 */\n StandardGS5 = \"Standard_GS5\",\n /** StandardGS48 */\n StandardGS48 = \"Standard_GS4-8\",\n /** StandardGS44 */\n StandardGS44 = \"Standard_GS4-4\",\n /** StandardGS516 */\n StandardGS516 = \"Standard_GS5-16\",\n /** StandardGS58 */\n StandardGS58 = \"Standard_GS5-8\",\n /** StandardH8 */\n StandardH8 = \"Standard_H8\",\n /** StandardH16 */\n StandardH16 = \"Standard_H16\",\n /** StandardH8M */\n StandardH8M = \"Standard_H8m\",\n /** StandardH16M */\n StandardH16M = \"Standard_H16m\",\n /** StandardH16R */\n StandardH16R = \"Standard_H16r\",\n /** StandardH16Mr */\n StandardH16Mr = \"Standard_H16mr\",\n /** StandardL4S */\n StandardL4S = \"Standard_L4s\",\n /** StandardL8S */\n StandardL8S = \"Standard_L8s\",\n /** StandardL16S */\n StandardL16S = \"Standard_L16s\",\n /** StandardL32S */\n StandardL32S = \"Standard_L32s\",\n /** StandardM64S */\n StandardM64S = \"Standard_M64s\",\n /** StandardM64Ms */\n StandardM64Ms = \"Standard_M64ms\",\n /** StandardM128S */\n StandardM128S = \"Standard_M128s\",\n /** StandardM128Ms */\n StandardM128Ms = \"Standard_M128ms\",\n /** StandardM6432Ms */\n StandardM6432Ms = \"Standard_M64-32ms\",\n /** StandardM6416Ms */\n StandardM6416Ms = \"Standard_M64-16ms\",\n /** StandardM12864Ms */\n StandardM12864Ms = \"Standard_M128-64ms\",\n /** StandardM12832Ms */\n StandardM12832Ms = \"Standard_M128-32ms\",\n /** StandardNC6 */\n StandardNC6 = \"Standard_NC6\",\n /** StandardNC12 */\n StandardNC12 = \"Standard_NC12\",\n /** StandardNC24 */\n StandardNC24 = \"Standard_NC24\",\n /** StandardNC24R */\n StandardNC24R = \"Standard_NC24r\",\n /** StandardNC6SV2 */\n StandardNC6SV2 = \"Standard_NC6s_v2\",\n /** StandardNC12SV2 */\n StandardNC12SV2 = \"Standard_NC12s_v2\",\n /** StandardNC24SV2 */\n StandardNC24SV2 = \"Standard_NC24s_v2\",\n /** StandardNC24RsV2 */\n StandardNC24RsV2 = \"Standard_NC24rs_v2\",\n /** StandardNC6SV3 */\n StandardNC6SV3 = \"Standard_NC6s_v3\",\n /** StandardNC12SV3 */\n StandardNC12SV3 = \"Standard_NC12s_v3\",\n /** StandardNC24SV3 */\n StandardNC24SV3 = \"Standard_NC24s_v3\",\n /** StandardNC24RsV3 */\n StandardNC24RsV3 = \"Standard_NC24rs_v3\",\n /** StandardND6S */\n StandardND6S = \"Standard_ND6s\",\n /** StandardND12S */\n StandardND12S = \"Standard_ND12s\",\n /** StandardND24S */\n StandardND24S = \"Standard_ND24s\",\n /** StandardND24Rs */\n StandardND24Rs = \"Standard_ND24rs\",\n /** StandardNV6 */\n StandardNV6 = \"Standard_NV6\",\n /** StandardNV12 */\n StandardNV12 = \"Standard_NV12\",\n /** StandardNV24 */\n StandardNV24 = \"Standard_NV24\",\n}\n\n/**\n * Defines values for VirtualMachineSizeTypes. \\\n * {@link KnownVirtualMachineSizeTypes} can be used interchangeably with VirtualMachineSizeTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Basic_A0** \\\n * **Basic_A1** \\\n * **Basic_A2** \\\n * **Basic_A3** \\\n * **Basic_A4** \\\n * **Standard_A0** \\\n * **Standard_A1** \\\n * **Standard_A2** \\\n * **Standard_A3** \\\n * **Standard_A4** \\\n * **Standard_A5** \\\n * **Standard_A6** \\\n * **Standard_A7** \\\n * **Standard_A8** \\\n * **Standard_A9** \\\n * **Standard_A10** \\\n * **Standard_A11** \\\n * **Standard_A1_v2** \\\n * **Standard_A2_v2** \\\n * **Standard_A4_v2** \\\n * **Standard_A8_v2** \\\n * **Standard_A2m_v2** \\\n * **Standard_A4m_v2** \\\n * **Standard_A8m_v2** \\\n * **Standard_B1s** \\\n * **Standard_B1ms** \\\n * **Standard_B2s** \\\n * **Standard_B2ms** \\\n * **Standard_B4ms** \\\n * **Standard_B8ms** \\\n * **Standard_D1** \\\n * **Standard_D2** \\\n * **Standard_D3** \\\n * **Standard_D4** \\\n * **Standard_D11** \\\n * **Standard_D12** \\\n * **Standard_D13** \\\n * **Standard_D14** \\\n * **Standard_D1_v2** \\\n * **Standard_D2_v2** \\\n * **Standard_D3_v2** \\\n * **Standard_D4_v2** \\\n * **Standard_D5_v2** \\\n * **Standard_D2_v3** \\\n * **Standard_D4_v3** \\\n * **Standard_D8_v3** \\\n * **Standard_D16_v3** \\\n * **Standard_D32_v3** \\\n * **Standard_D64_v3** \\\n * **Standard_D2s_v3** \\\n * **Standard_D4s_v3** \\\n * **Standard_D8s_v3** \\\n * **Standard_D16s_v3** \\\n * **Standard_D32s_v3** \\\n * **Standard_D64s_v3** \\\n * **Standard_D11_v2** \\\n * **Standard_D12_v2** \\\n * **Standard_D13_v2** \\\n * **Standard_D14_v2** \\\n * **Standard_D15_v2** \\\n * **Standard_DS1** \\\n * **Standard_DS2** \\\n * **Standard_DS3** \\\n * **Standard_DS4** \\\n * **Standard_DS11** \\\n * **Standard_DS12** \\\n * **Standard_DS13** \\\n * **Standard_DS14** \\\n * **Standard_DS1_v2** \\\n * **Standard_DS2_v2** \\\n * **Standard_DS3_v2** \\\n * **Standard_DS4_v2** \\\n * **Standard_DS5_v2** \\\n * **Standard_DS11_v2** \\\n * **Standard_DS12_v2** \\\n * **Standard_DS13_v2** \\\n * **Standard_DS14_v2** \\\n * **Standard_DS15_v2** \\\n * **Standard_DS13-4_v2** \\\n * **Standard_DS13-2_v2** \\\n * **Standard_DS14-8_v2** \\\n * **Standard_DS14-4_v2** \\\n * **Standard_E2_v3** \\\n * **Standard_E4_v3** \\\n * **Standard_E8_v3** \\\n * **Standard_E16_v3** \\\n * **Standard_E32_v3** \\\n * **Standard_E64_v3** \\\n * **Standard_E2s_v3** \\\n * **Standard_E4s_v3** \\\n * **Standard_E8s_v3** \\\n * **Standard_E16s_v3** \\\n * **Standard_E32s_v3** \\\n * **Standard_E64s_v3** \\\n * **Standard_E32-16_v3** \\\n * **Standard_E32-8s_v3** \\\n * **Standard_E64-32s_v3** \\\n * **Standard_E64-16s_v3** \\\n * **Standard_F1** \\\n * **Standard_F2** \\\n * **Standard_F4** \\\n * **Standard_F8** \\\n * **Standard_F16** \\\n * **Standard_F1s** \\\n * **Standard_F2s** \\\n * **Standard_F4s** \\\n * **Standard_F8s** \\\n * **Standard_F16s** \\\n * **Standard_F2s_v2** \\\n * **Standard_F4s_v2** \\\n * **Standard_F8s_v2** \\\n * **Standard_F16s_v2** \\\n * **Standard_F32s_v2** \\\n * **Standard_F64s_v2** \\\n * **Standard_F72s_v2** \\\n * **Standard_G1** \\\n * **Standard_G2** \\\n * **Standard_G3** \\\n * **Standard_G4** \\\n * **Standard_G5** \\\n * **Standard_GS1** \\\n * **Standard_GS2** \\\n * **Standard_GS3** \\\n * **Standard_GS4** \\\n * **Standard_GS5** \\\n * **Standard_GS4-8** \\\n * **Standard_GS4-4** \\\n * **Standard_GS5-16** \\\n * **Standard_GS5-8** \\\n * **Standard_H8** \\\n * **Standard_H16** \\\n * **Standard_H8m** \\\n * **Standard_H16m** \\\n * **Standard_H16r** \\\n * **Standard_H16mr** \\\n * **Standard_L4s** \\\n * **Standard_L8s** \\\n * **Standard_L16s** \\\n * **Standard_L32s** \\\n * **Standard_M64s** \\\n * **Standard_M64ms** \\\n * **Standard_M128s** \\\n * **Standard_M128ms** \\\n * **Standard_M64-32ms** \\\n * **Standard_M64-16ms** \\\n * **Standard_M128-64ms** \\\n * **Standard_M128-32ms** \\\n * **Standard_NC6** \\\n * **Standard_NC12** \\\n * **Standard_NC24** \\\n * **Standard_NC24r** \\\n * **Standard_NC6s_v2** \\\n * **Standard_NC12s_v2** \\\n * **Standard_NC24s_v2** \\\n * **Standard_NC24rs_v2** \\\n * **Standard_NC6s_v3** \\\n * **Standard_NC12s_v3** \\\n * **Standard_NC24s_v3** \\\n * **Standard_NC24rs_v3** \\\n * **Standard_ND6s** \\\n * **Standard_ND12s** \\\n * **Standard_ND24s** \\\n * **Standard_ND24rs** \\\n * **Standard_NV6** \\\n * **Standard_NV12** \\\n * **Standard_NV24**\n */\nexport type VirtualMachineSizeTypes = string;\n\n/** Known values of {@link DiskDetachOptionTypes} that the service accepts. */\nexport enum KnownDiskDetachOptionTypes {\n /** ForceDetach */\n ForceDetach = \"ForceDetach\",\n}\n\n/**\n * Defines values for DiskDetachOptionTypes. \\\n * {@link KnownDiskDetachOptionTypes} can be used interchangeably with DiskDetachOptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ForceDetach**\n */\nexport type DiskDetachOptionTypes = string;\n\n/** Known values of {@link IPVersions} that the service accepts. */\nexport enum KnownIPVersions {\n /** IPv4 */\n IPv4 = \"IPv4\",\n /** IPv6 */\n IPv6 = \"IPv6\",\n}\n\n/**\n * Defines values for IPVersions. \\\n * {@link KnownIPVersions} can be used interchangeably with IPVersions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **IPv4** \\\n * **IPv6**\n */\nexport type IPVersions = string;\n\n/** Known values of {@link PublicIPAllocationMethod} that the service accepts. */\nexport enum KnownPublicIPAllocationMethod {\n /** Dynamic */\n Dynamic = \"Dynamic\",\n /** Static */\n Static = \"Static\",\n}\n\n/**\n * Defines values for PublicIPAllocationMethod. \\\n * {@link KnownPublicIPAllocationMethod} can be used interchangeably with PublicIPAllocationMethod,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Dynamic** \\\n * **Static**\n */\nexport type PublicIPAllocationMethod = string;\n\n/** Known values of {@link HyperVGenerationType} that the service accepts. */\nexport enum KnownHyperVGenerationType {\n /** V1 */\n V1 = \"V1\",\n /** V2 */\n V2 = \"V2\",\n}\n\n/**\n * Defines values for HyperVGenerationType. \\\n * {@link KnownHyperVGenerationType} can be used interchangeably with HyperVGenerationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **V1** \\\n * **V2**\n */\nexport type HyperVGenerationType = string;\n\n/** Known values of {@link PatchOperationStatus} that the service accepts. */\nexport enum KnownPatchOperationStatus {\n /** Unknown */\n Unknown = \"Unknown\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** CompletedWithWarnings */\n CompletedWithWarnings = \"CompletedWithWarnings\",\n}\n\n/**\n * Defines values for PatchOperationStatus. \\\n * {@link KnownPatchOperationStatus} can be used interchangeably with PatchOperationStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **InProgress** \\\n * **Failed** \\\n * **Succeeded** \\\n * **CompletedWithWarnings**\n */\nexport type PatchOperationStatus = string;\n\n/** Known values of {@link ProximityPlacementGroupType} that the service accepts. */\nexport enum KnownProximityPlacementGroupType {\n /** Standard */\n Standard = \"Standard\",\n /** Ultra */\n Ultra = \"Ultra\",\n}\n\n/**\n * Defines values for ProximityPlacementGroupType. \\\n * {@link KnownProximityPlacementGroupType} can be used interchangeably with ProximityPlacementGroupType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard** \\\n * **Ultra**\n */\nexport type ProximityPlacementGroupType = string;\n\n/** Known values of {@link OperatingSystemType} that the service accepts. */\nexport enum KnownOperatingSystemType {\n /** Windows */\n Windows = \"Windows\",\n /** Linux */\n Linux = \"Linux\",\n}\n\n/**\n * Defines values for OperatingSystemType. \\\n * {@link KnownOperatingSystemType} can be used interchangeably with OperatingSystemType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Windows** \\\n * **Linux**\n */\nexport type OperatingSystemType = string;\n\n/** Known values of {@link RestorePointEncryptionType} that the service accepts. */\nexport enum KnownRestorePointEncryptionType {\n /** Disk Restore Point is encrypted at rest with Platform managed key. */\n EncryptionAtRestWithPlatformKey = \"EncryptionAtRestWithPlatformKey\",\n /** Disk Restore Point is encrypted at rest with Customer managed key that can be changed and revoked by a customer. */\n EncryptionAtRestWithCustomerKey = \"EncryptionAtRestWithCustomerKey\",\n /** Disk Restore Point is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed. */\n EncryptionAtRestWithPlatformAndCustomerKeys = \"EncryptionAtRestWithPlatformAndCustomerKeys\",\n}\n\n/**\n * Defines values for RestorePointEncryptionType. \\\n * {@link KnownRestorePointEncryptionType} can be used interchangeably with RestorePointEncryptionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptionAtRestWithPlatformKey**: Disk Restore Point is encrypted at rest with Platform managed key. \\\n * **EncryptionAtRestWithCustomerKey**: Disk Restore Point is encrypted at rest with Customer managed key that can be changed and revoked by a customer. \\\n * **EncryptionAtRestWithPlatformAndCustomerKeys**: Disk Restore Point is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed.\n */\nexport type RestorePointEncryptionType = string;\n\n/** Known values of {@link ConsistencyModeTypes} that the service accepts. */\nexport enum KnownConsistencyModeTypes {\n /** CrashConsistent */\n CrashConsistent = \"CrashConsistent\",\n /** FileSystemConsistent */\n FileSystemConsistent = \"FileSystemConsistent\",\n /** ApplicationConsistent */\n ApplicationConsistent = \"ApplicationConsistent\",\n}\n\n/**\n * Defines values for ConsistencyModeTypes. \\\n * {@link KnownConsistencyModeTypes} can be used interchangeably with ConsistencyModeTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CrashConsistent** \\\n * **FileSystemConsistent** \\\n * **ApplicationConsistent**\n */\nexport type ConsistencyModeTypes = string;\n\n/** Known values of {@link SnapshotAccessState} that the service accepts. */\nexport enum KnownSnapshotAccessState {\n /** Default value. */\n Unknown = \"Unknown\",\n /** The snapshot cannot be used for restore, copy or download to offline. */\n Pending = \"Pending\",\n /** The snapshot can be used for restore, copy to different region, and download to offline. */\n Available = \"Available\",\n /** The snapshot can be used for restoring disks with fast performance but cannot be copied or downloaded. */\n InstantAccess = \"InstantAccess\",\n /** The snapshot can be used for restoring disks with fast performance, copied and downloaded. */\n AvailableWithInstantAccess = \"AvailableWithInstantAccess\",\n}\n\n/**\n * Defines values for SnapshotAccessState. \\\n * {@link KnownSnapshotAccessState} can be used interchangeably with SnapshotAccessState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown**: Default value. \\\n * **Pending**: The snapshot cannot be used for restore, copy or download to offline. \\\n * **Available**: The snapshot can be used for restore, copy to different region, and download to offline. \\\n * **InstantAccess**: The snapshot can be used for restoring disks with fast performance but cannot be copied or downloaded. \\\n * **AvailableWithInstantAccess**: The snapshot can be used for restoring disks with fast performance, copied and downloaded.\n */\nexport type SnapshotAccessState = string;\n\n/** Known values of {@link ExpandTypesForListVMs} that the service accepts. */\nexport enum KnownExpandTypesForListVMs {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for ExpandTypesForListVMs. \\\n * {@link KnownExpandTypesForListVMs} can be used interchangeably with ExpandTypesForListVMs,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type ExpandTypesForListVMs = string;\n\n/** Known values of {@link CapacityReservationGroupInstanceViewTypes} that the service accepts. */\nexport enum KnownCapacityReservationGroupInstanceViewTypes {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for CapacityReservationGroupInstanceViewTypes. \\\n * {@link KnownCapacityReservationGroupInstanceViewTypes} can be used interchangeably with CapacityReservationGroupInstanceViewTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type CapacityReservationGroupInstanceViewTypes = string;\n\n/** Known values of {@link CapacityReservationInstanceViewTypes} that the service accepts. */\nexport enum KnownCapacityReservationInstanceViewTypes {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for CapacityReservationInstanceViewTypes. \\\n * {@link KnownCapacityReservationInstanceViewTypes} can be used interchangeably with CapacityReservationInstanceViewTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type CapacityReservationInstanceViewTypes = string;\n\n/** Known values of {@link RestorePointCollectionExpandOptions} that the service accepts. */\nexport enum KnownRestorePointCollectionExpandOptions {\n /** RestorePoints */\n RestorePoints = \"restorePoints\",\n}\n\n/**\n * Defines values for RestorePointCollectionExpandOptions. \\\n * {@link KnownRestorePointCollectionExpandOptions} can be used interchangeably with RestorePointCollectionExpandOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **restorePoints**\n */\nexport type RestorePointCollectionExpandOptions = string;\n\n/** Known values of {@link RestorePointExpandOptions} that the service accepts. */\nexport enum KnownRestorePointExpandOptions {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for RestorePointExpandOptions. \\\n * {@link KnownRestorePointExpandOptions} can be used interchangeably with RestorePointExpandOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type RestorePointExpandOptions = string;\n\n/** Known values of {@link SshEncryptionTypes} that the service accepts. */\nexport enum KnownSshEncryptionTypes {\n /** RSA */\n RSA = \"RSA\",\n /** Ed25519 */\n Ed25519 = \"Ed25519\",\n}\n\n/**\n * Defines values for SshEncryptionTypes. \\\n * {@link KnownSshEncryptionTypes} can be used interchangeably with SshEncryptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **RSA** \\\n * **Ed25519**\n */\nexport type SshEncryptionTypes = string;\n\n/** Known values of {@link ExpandTypesForGetVMScaleSets} that the service accepts. */\nexport enum KnownExpandTypesForGetVMScaleSets {\n /** UserData */\n UserData = \"userData\",\n}\n\n/**\n * Defines values for ExpandTypesForGetVMScaleSets. \\\n * {@link KnownExpandTypesForGetVMScaleSets} can be used interchangeably with ExpandTypesForGetVMScaleSets,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **userData**\n */\nexport type ExpandTypesForGetVMScaleSets = string;\n\n/** Known values of {@link OrchestrationServiceNames} that the service accepts. */\nexport enum KnownOrchestrationServiceNames {\n /** AutomaticRepairs */\n AutomaticRepairs = \"AutomaticRepairs\",\n /** AutomaticZoneRebalancing orchestration service. */\n AutomaticZoneRebalancing = \"AutomaticZoneRebalancing\",\n}\n\n/**\n * Defines values for OrchestrationServiceNames. \\\n * {@link KnownOrchestrationServiceNames} can be used interchangeably with OrchestrationServiceNames,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **AutomaticRepairs** \\\n * **AutomaticZoneRebalancing**: AutomaticZoneRebalancing orchestration service.\n */\nexport type OrchestrationServiceNames = string;\n\n/** Known values of {@link OrchestrationServiceState} that the service accepts. */\nexport enum KnownOrchestrationServiceState {\n /** NotRunning */\n NotRunning = \"NotRunning\",\n /** Running */\n Running = \"Running\",\n /** Suspended */\n Suspended = \"Suspended\",\n}\n\n/**\n * Defines values for OrchestrationServiceState. \\\n * {@link KnownOrchestrationServiceState} can be used interchangeably with OrchestrationServiceState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **NotRunning** \\\n * **Running** \\\n * **Suspended**\n */\nexport type OrchestrationServiceState = string;\n\n/** Known values of {@link OrchestrationServiceOperationStatus} that the service accepts. */\nexport enum KnownOrchestrationServiceOperationStatus {\n /** InProgress orchestration service operation status. */\n InProgress = \"InProgress\",\n /** Completed orchestration service operation status. */\n Completed = \"Completed\",\n}\n\n/**\n * Defines values for OrchestrationServiceOperationStatus. \\\n * {@link KnownOrchestrationServiceOperationStatus} can be used interchangeably with OrchestrationServiceOperationStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **InProgress**: InProgress orchestration service operation status. \\\n * **Completed**: Completed orchestration service operation status.\n */\nexport type OrchestrationServiceOperationStatus = string;\n\n/** Known values of {@link OrchestrationServiceStateAction} that the service accepts. */\nexport enum KnownOrchestrationServiceStateAction {\n /** Resume */\n Resume = \"Resume\",\n /** Suspend */\n Suspend = \"Suspend\",\n}\n\n/**\n * Defines values for OrchestrationServiceStateAction. \\\n * {@link KnownOrchestrationServiceStateAction} can be used interchangeably with OrchestrationServiceStateAction,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Resume** \\\n * **Suspend**\n */\nexport type OrchestrationServiceStateAction = string;\n\n/** Known values of {@link HyperVGeneration} that the service accepts. */\nexport enum KnownHyperVGeneration {\n /** V1 */\n V1 = \"V1\",\n /** V2 */\n V2 = \"V2\",\n}\n\n/**\n * Defines values for HyperVGeneration. \\\n * {@link KnownHyperVGeneration} can be used interchangeably with HyperVGeneration,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **V1** \\\n * **V2**\n */\nexport type HyperVGeneration = string;\n\n/** Known values of {@link ResilientVMDeletionStatus} that the service accepts. */\nexport enum KnownResilientVMDeletionStatus {\n /** Enabled */\n Enabled = \"Enabled\",\n /** Disabled */\n Disabled = \"Disabled\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for ResilientVMDeletionStatus. \\\n * {@link KnownResilientVMDeletionStatus} can be used interchangeably with ResilientVMDeletionStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Enabled** \\\n * **Disabled** \\\n * **InProgress** \\\n * **Failed**\n */\nexport type ResilientVMDeletionStatus = string;\n\n/** Known values of {@link ScriptShellTypes} that the service accepts. */\nexport enum KnownScriptShellTypes {\n /** Default script shell type. */\n Default = \"Default\",\n /** Powershell7 script shell type. */\n Powershell7 = \"Powershell7\",\n}\n\n/**\n * Defines values for ScriptShellTypes. \\\n * {@link KnownScriptShellTypes} can be used interchangeably with ScriptShellTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Default**: Default script shell type. \\\n * **Powershell7**: Powershell7 script shell type.\n */\nexport type ScriptShellTypes = string;\n\n/** Known values of {@link ExecutionState} that the service accepts. */\nexport enum KnownExecutionState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Pending */\n Pending = \"Pending\",\n /** Running */\n Running = \"Running\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** TimedOut */\n TimedOut = \"TimedOut\",\n /** Canceled */\n Canceled = \"Canceled\",\n}\n\n/**\n * Defines values for ExecutionState. \\\n * {@link KnownExecutionState} can be used interchangeably with ExecutionState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Pending** \\\n * **Running** \\\n * **Failed** \\\n * **Succeeded** \\\n * **TimedOut** \\\n * **Canceled**\n */\nexport type ExecutionState = string;\n\n/** Known values of {@link ExpandTypeForListVMs} that the service accepts. */\nexport enum KnownExpandTypeForListVMs {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for ExpandTypeForListVMs. \\\n * {@link KnownExpandTypeForListVMs} can be used interchangeably with ExpandTypeForListVMs,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type ExpandTypeForListVMs = string;\n\n/** Known values of {@link VMGuestPatchRebootBehavior} that the service accepts. */\nexport enum KnownVMGuestPatchRebootBehavior {\n /** Unknown */\n Unknown = \"Unknown\",\n /** NeverReboots */\n NeverReboots = \"NeverReboots\",\n /** AlwaysRequiresReboot */\n AlwaysRequiresReboot = \"AlwaysRequiresReboot\",\n /** CanRequestReboot */\n CanRequestReboot = \"CanRequestReboot\",\n}\n\n/**\n * Defines values for VMGuestPatchRebootBehavior. \\\n * {@link KnownVMGuestPatchRebootBehavior} can be used interchangeably with VMGuestPatchRebootBehavior,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **NeverReboots** \\\n * **AlwaysRequiresReboot** \\\n * **CanRequestReboot**\n */\nexport type VMGuestPatchRebootBehavior = string;\n\n/** Known values of {@link PatchAssessmentState} that the service accepts. */\nexport enum KnownPatchAssessmentState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Available */\n Available = \"Available\",\n}\n\n/**\n * Defines values for PatchAssessmentState. \\\n * {@link KnownPatchAssessmentState} can be used interchangeably with PatchAssessmentState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Available**\n */\nexport type PatchAssessmentState = string;\n\n/** Known values of {@link VMGuestPatchRebootSetting} that the service accepts. */\nexport enum KnownVMGuestPatchRebootSetting {\n /** IfRequired */\n IfRequired = \"IfRequired\",\n /** Never */\n Never = \"Never\",\n /** Always */\n Always = \"Always\",\n}\n\n/**\n * Defines values for VMGuestPatchRebootSetting. \\\n * {@link KnownVMGuestPatchRebootSetting} can be used interchangeably with VMGuestPatchRebootSetting,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **IfRequired** \\\n * **Never** \\\n * **Always**\n */\nexport type VMGuestPatchRebootSetting = string;\n\n/** Known values of {@link VMGuestPatchClassificationWindows} that the service accepts. */\nexport enum KnownVMGuestPatchClassificationWindows {\n /** Critical */\n Critical = \"Critical\",\n /** Security */\n Security = \"Security\",\n /** UpdateRollUp */\n UpdateRollUp = \"UpdateRollUp\",\n /** FeaturePack */\n FeaturePack = \"FeaturePack\",\n /** ServicePack */\n ServicePack = \"ServicePack\",\n /** Definition */\n Definition = \"Definition\",\n /** Tools */\n Tools = \"Tools\",\n /** Updates */\n Updates = \"Updates\",\n}\n\n/**\n * Defines values for VMGuestPatchClassificationWindows. \\\n * {@link KnownVMGuestPatchClassificationWindows} can be used interchangeably with VMGuestPatchClassificationWindows,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Critical** \\\n * **Security** \\\n * **UpdateRollUp** \\\n * **FeaturePack** \\\n * **ServicePack** \\\n * **Definition** \\\n * **Tools** \\\n * **Updates**\n */\nexport type VMGuestPatchClassificationWindows = string;\n\n/** Known values of {@link VMGuestPatchClassificationLinux} that the service accepts. */\nexport enum KnownVMGuestPatchClassificationLinux {\n /** Critical */\n Critical = \"Critical\",\n /** Security */\n Security = \"Security\",\n /** Other */\n Other = \"Other\",\n}\n\n/**\n * Defines values for VMGuestPatchClassificationLinux. \\\n * {@link KnownVMGuestPatchClassificationLinux} can be used interchangeably with VMGuestPatchClassificationLinux,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Critical** \\\n * **Security** \\\n * **Other**\n */\nexport type VMGuestPatchClassificationLinux = string;\n\n/** Known values of {@link VMGuestPatchRebootStatus} that the service accepts. */\nexport enum KnownVMGuestPatchRebootStatus {\n /** Unknown */\n Unknown = \"Unknown\",\n /** NotNeeded */\n NotNeeded = \"NotNeeded\",\n /** Required */\n Required = \"Required\",\n /** Started */\n Started = \"Started\",\n /** Failed */\n Failed = \"Failed\",\n /** Completed */\n Completed = \"Completed\",\n}\n\n/**\n * Defines values for VMGuestPatchRebootStatus. \\\n * {@link KnownVMGuestPatchRebootStatus} can be used interchangeably with VMGuestPatchRebootStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **NotNeeded** \\\n * **Required** \\\n * **Started** \\\n * **Failed** \\\n * **Completed**\n */\nexport type VMGuestPatchRebootStatus = string;\n\n/** Known values of {@link PatchInstallationState} that the service accepts. */\nexport enum KnownPatchInstallationState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Installed */\n Installed = \"Installed\",\n /** Failed */\n Failed = \"Failed\",\n /** Excluded */\n Excluded = \"Excluded\",\n /** NotSelected */\n NotSelected = \"NotSelected\",\n /** Pending */\n Pending = \"Pending\",\n}\n\n/**\n * Defines values for PatchInstallationState. \\\n * {@link KnownPatchInstallationState} can be used interchangeably with PatchInstallationState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Installed** \\\n * **Failed** \\\n * **Excluded** \\\n * **NotSelected** \\\n * **Pending**\n */\nexport type PatchInstallationState = string;\n\n/** Known values of {@link PrivateEndpointServiceConnectionStatus} that the service accepts. */\nexport enum KnownPrivateEndpointServiceConnectionStatus {\n /** Pending */\n Pending = \"Pending\",\n /** Approved */\n Approved = \"Approved\",\n /** Rejected */\n Rejected = \"Rejected\",\n}\n\n/**\n * Defines values for PrivateEndpointServiceConnectionStatus. \\\n * {@link KnownPrivateEndpointServiceConnectionStatus} can be used interchangeably with PrivateEndpointServiceConnectionStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Pending** \\\n * **Approved** \\\n * **Rejected**\n */\nexport type PrivateEndpointServiceConnectionStatus = string;\n\n/** Known values of {@link PrivateEndpointConnectionProvisioningState} that the service accepts. */\nexport enum KnownPrivateEndpointConnectionProvisioningState {\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** Creating */\n Creating = \"Creating\",\n /** Deleting */\n Deleting = \"Deleting\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for PrivateEndpointConnectionProvisioningState. \\\n * {@link KnownPrivateEndpointConnectionProvisioningState} can be used interchangeably with PrivateEndpointConnectionProvisioningState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Succeeded** \\\n * **Creating** \\\n * **Deleting** \\\n * **Failed**\n */\nexport type PrivateEndpointConnectionProvisioningState = string;\n\n/** Known values of {@link DiskEncryptionSetType} that the service accepts. */\nexport enum KnownDiskEncryptionSetType {\n /** Resource using diskEncryptionSet would be encrypted at rest with Customer managed key that can be changed and revoked by a customer. */\n EncryptionAtRestWithCustomerKey = \"EncryptionAtRestWithCustomerKey\",\n /** Resource using diskEncryptionSet would be encrypted at rest with two layers of encryption. One of the keys is Customer managed and the other key is Platform managed. */\n EncryptionAtRestWithPlatformAndCustomerKeys = \"EncryptionAtRestWithPlatformAndCustomerKeys\",\n /** Confidential VM supported disk and VM guest state would be encrypted with customer managed key. */\n ConfidentialVmEncryptedWithCustomerKey = \"ConfidentialVmEncryptedWithCustomerKey\",\n}\n\n/**\n * Defines values for DiskEncryptionSetType. \\\n * {@link KnownDiskEncryptionSetType} can be used interchangeably with DiskEncryptionSetType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptionAtRestWithCustomerKey**: Resource using diskEncryptionSet would be encrypted at rest with Customer managed key that can be changed and revoked by a customer. \\\n * **EncryptionAtRestWithPlatformAndCustomerKeys**: Resource using diskEncryptionSet would be encrypted at rest with two layers of encryption. One of the keys is Customer managed and the other key is Platform managed. \\\n * **ConfidentialVmEncryptedWithCustomerKey**: Confidential VM supported disk and VM guest state would be encrypted with customer managed key.\n */\nexport type DiskEncryptionSetType = string;\n\n/** Known values of {@link DiskEncryptionSetIdentityType} that the service accepts. */\nexport enum KnownDiskEncryptionSetIdentityType {\n /** SystemAssigned */\n SystemAssigned = \"SystemAssigned\",\n /** UserAssigned */\n UserAssigned = \"UserAssigned\",\n /** SystemAssignedUserAssigned */\n SystemAssignedUserAssigned = \"SystemAssigned, UserAssigned\",\n /** None */\n None = \"None\",\n}\n\n/**\n * Defines values for DiskEncryptionSetIdentityType. \\\n * {@link KnownDiskEncryptionSetIdentityType} can be used interchangeably with DiskEncryptionSetIdentityType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **SystemAssigned** \\\n * **UserAssigned** \\\n * **SystemAssigned, UserAssigned** \\\n * **None**\n */\nexport type DiskEncryptionSetIdentityType = string;\n\n/** Known values of {@link Architecture} that the service accepts. */\nexport enum KnownArchitecture {\n /** X64 */\n X64 = \"x64\",\n /** Arm64 */\n Arm64 = \"Arm64\",\n}\n\n/**\n * Defines values for Architecture. \\\n * {@link KnownArchitecture} can be used interchangeably with Architecture,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **x64** \\\n * **Arm64**\n */\nexport type Architecture = string;\n\n/** Known values of {@link SupportedSecurityOption} that the service accepts. */\nexport enum KnownSupportedSecurityOption {\n /** The disk supports creating Trusted Launch VMs. */\n TrustedLaunchSupported = \"TrustedLaunchSupported\",\n /** The disk supports creating both Trusted Launch and Confidential VMs. */\n TrustedLaunchAndConfidentialVMSupported = \"TrustedLaunchAndConfidentialVMSupported\",\n}\n\n/**\n * Defines values for SupportedSecurityOption. \\\n * {@link KnownSupportedSecurityOption} can be used interchangeably with SupportedSecurityOption,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TrustedLaunchSupported**: The disk supports creating Trusted Launch VMs. \\\n * **TrustedLaunchAndConfidentialVMSupported**: The disk supports creating both Trusted Launch and Confidential VMs.\n */\nexport type SupportedSecurityOption = string;\n\n/** Known values of {@link DiskCreateOption} that the service accepts. */\nexport enum KnownDiskCreateOption {\n /** Create an empty data disk of a size given by diskSizeGB. */\n Empty = \"Empty\",\n /** Disk will be attached to a VM. */\n Attach = \"Attach\",\n /** Create a new disk from a platform image specified by the given imageReference or galleryImageReference. */\n FromImage = \"FromImage\",\n /** Create a disk by importing from a blob specified by a sourceUri in a storage account specified by storageAccountId. */\n Import = \"Import\",\n /** Create a new disk or snapshot by copying from a disk or snapshot specified by the given sourceResourceId. */\n Copy = \"Copy\",\n /** Create a new disk by copying from a backup recovery point. */\n Restore = \"Restore\",\n /** Create a new disk by obtaining a write token and using it to directly upload the contents of the disk. */\n Upload = \"Upload\",\n /** Create a new disk by using a deep copy process, where the resource creation is considered complete only after all data has been copied from the source. */\n CopyStart = \"CopyStart\",\n /** Similar to Import create option. Create a new Trusted Launch VM or Confidential VM supported disk by importing additional blobs for VM guest state specified by securityDataUri and VM metadata specified by securityMetadataUri in storage account specified by storageAccountId. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. */\n ImportSecure = \"ImportSecure\",\n /** Similar to Upload create option. Create a new Trusted Launch VM or Confidential VM supported disk and upload using write token in disk, VM guest state and VM metadata. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. */\n UploadPreparedSecure = \"UploadPreparedSecure\",\n /** Create a new disk by exporting from elastic san volume snapshot */\n CopyFromSanSnapshot = \"CopyFromSanSnapshot\",\n}\n\n/**\n * Defines values for DiskCreateOption. \\\n * {@link KnownDiskCreateOption} can be used interchangeably with DiskCreateOption,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Empty**: Create an empty data disk of a size given by diskSizeGB. \\\n * **Attach**: Disk will be attached to a VM. \\\n * **FromImage**: Create a new disk from a platform image specified by the given imageReference or galleryImageReference. \\\n * **Import**: Create a disk by importing from a blob specified by a sourceUri in a storage account specified by storageAccountId. \\\n * **Copy**: Create a new disk or snapshot by copying from a disk or snapshot specified by the given sourceResourceId. \\\n * **Restore**: Create a new disk by copying from a backup recovery point. \\\n * **Upload**: Create a new disk by obtaining a write token and using it to directly upload the contents of the disk. \\\n * **CopyStart**: Create a new disk by using a deep copy process, where the resource creation is considered complete only after all data has been copied from the source. \\\n * **ImportSecure**: Similar to Import create option. Create a new Trusted Launch VM or Confidential VM supported disk by importing additional blobs for VM guest state specified by securityDataUri and VM metadata specified by securityMetadataUri in storage account specified by storageAccountId. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. \\\n * **UploadPreparedSecure**: Similar to Upload create option. Create a new Trusted Launch VM or Confidential VM supported disk and upload using write token in disk, VM guest state and VM metadata. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. \\\n * **CopyFromSanSnapshot**: Create a new disk by exporting from elastic san volume snapshot\n */\nexport type DiskCreateOption = string;\n\n/** Known values of {@link ProvisionedBandwidthCopyOption} that the service accepts. */\nexport enum KnownProvisionedBandwidthCopyOption {\n /** None */\n None = \"None\",\n /** Enhanced */\n Enhanced = \"Enhanced\",\n}\n\n/**\n * Defines values for ProvisionedBandwidthCopyOption. \\\n * {@link KnownProvisionedBandwidthCopyOption} can be used interchangeably with ProvisionedBandwidthCopyOption,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Enhanced**\n */\nexport type ProvisionedBandwidthCopyOption = string;\n\n/** Known values of {@link DiskState} that the service accepts. */\nexport enum KnownDiskState {\n /** The disk is not being used and can be attached to a VM. */\n Unattached = \"Unattached\",\n /** The disk is currently attached to a running VM. */\n Attached = \"Attached\",\n /** The disk is attached to a stopped-deallocated VM. */\n Reserved = \"Reserved\",\n /** The disk is attached to a VM which is in hibernated state. */\n Frozen = \"Frozen\",\n /** The disk currently has an Active SAS Uri associated with it. */\n ActiveSAS = \"ActiveSAS\",\n /** The disk is attached to a VM in hibernated state and has an active SAS URI associated with it. */\n ActiveSASFrozen = \"ActiveSASFrozen\",\n /** A disk is ready to be created by upload by requesting a write token. */\n ReadyToUpload = \"ReadyToUpload\",\n /** A disk is created for upload and a write token has been issued for uploading to it. */\n ActiveUpload = \"ActiveUpload\",\n}\n\n/**\n * Defines values for DiskState. \\\n * {@link KnownDiskState} can be used interchangeably with DiskState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unattached**: The disk is not being used and can be attached to a VM. \\\n * **Attached**: The disk is currently attached to a running VM. \\\n * **Reserved**: The disk is attached to a stopped-deallocated VM. \\\n * **Frozen**: The disk is attached to a VM which is in hibernated state. \\\n * **ActiveSAS**: The disk currently has an Active SAS Uri associated with it. \\\n * **ActiveSASFrozen**: The disk is attached to a VM in hibernated state and has an active SAS URI associated with it. \\\n * **ReadyToUpload**: A disk is ready to be created by upload by requesting a write token. \\\n * **ActiveUpload**: A disk is created for upload and a write token has been issued for uploading to it.\n */\nexport type DiskState = string;\n\n/** Known values of {@link EncryptionType} that the service accepts. */\nexport enum KnownEncryptionType {\n /** Disk is encrypted at rest with Platform managed key. It is the default encryption type. This is not a valid encryption type for disk encryption sets. */\n EncryptionAtRestWithPlatformKey = \"EncryptionAtRestWithPlatformKey\",\n /** Disk is encrypted at rest with Customer managed key that can be changed and revoked by a customer. */\n EncryptionAtRestWithCustomerKey = \"EncryptionAtRestWithCustomerKey\",\n /** Disk is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed. */\n EncryptionAtRestWithPlatformAndCustomerKeys = \"EncryptionAtRestWithPlatformAndCustomerKeys\",\n}\n\n/**\n * Defines values for EncryptionType. \\\n * {@link KnownEncryptionType} can be used interchangeably with EncryptionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptionAtRestWithPlatformKey**: Disk is encrypted at rest with Platform managed key. It is the default encryption type. This is not a valid encryption type for disk encryption sets. \\\n * **EncryptionAtRestWithCustomerKey**: Disk is encrypted at rest with Customer managed key that can be changed and revoked by a customer. \\\n * **EncryptionAtRestWithPlatformAndCustomerKeys**: Disk is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed.\n */\nexport type EncryptionType = string;\n\n/** Known values of {@link NetworkAccessPolicy} that the service accepts. */\nexport enum KnownNetworkAccessPolicy {\n /** The disk can be exported or uploaded to from any network. */\n AllowAll = \"AllowAll\",\n /** The disk can be exported or uploaded to using a DiskAccess resource's private endpoints. */\n AllowPrivate = \"AllowPrivate\",\n /** The disk cannot be exported. */\n DenyAll = \"DenyAll\",\n}\n\n/**\n * Defines values for NetworkAccessPolicy. \\\n * {@link KnownNetworkAccessPolicy} can be used interchangeably with NetworkAccessPolicy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **AllowAll**: The disk can be exported or uploaded to from any network. \\\n * **AllowPrivate**: The disk can be exported or uploaded to using a DiskAccess resource's private endpoints. \\\n * **DenyAll**: The disk cannot be exported.\n */\nexport type NetworkAccessPolicy = string;\n\n/** Known values of {@link DiskSecurityTypes} that the service accepts. */\nexport enum KnownDiskSecurityTypes {\n /** Trusted Launch provides security features such as secure boot and virtual Trusted Platform Module (vTPM) */\n TrustedLaunch = \"TrustedLaunch\",\n /** Indicates Confidential VM disk with only VM guest state encrypted */\n ConfidentialVMVmguestStateOnlyEncryptedWithPlatformKey = \"ConfidentialVM_VMGuestStateOnlyEncryptedWithPlatformKey\",\n /** Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a platform managed key */\n ConfidentialVMDiskEncryptedWithPlatformKey = \"ConfidentialVM_DiskEncryptedWithPlatformKey\",\n /** Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a customer managed key */\n ConfidentialVMDiskEncryptedWithCustomerKey = \"ConfidentialVM_DiskEncryptedWithCustomerKey\",\n /** Indicates Confidential VM disk with a ephemeral vTPM. vTPM state is not persisted across VM reboots. */\n ConfidentialVMNonPersistedTPM = \"ConfidentialVM_NonPersistedTPM\",\n}\n\n/**\n * Defines values for DiskSecurityTypes. \\\n * {@link KnownDiskSecurityTypes} can be used interchangeably with DiskSecurityTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TrustedLaunch**: Trusted Launch provides security features such as secure boot and virtual Trusted Platform Module (vTPM) \\\n * **ConfidentialVM_VMGuestStateOnlyEncryptedWithPlatformKey**: Indicates Confidential VM disk with only VM guest state encrypted \\\n * **ConfidentialVM_DiskEncryptedWithPlatformKey**: Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a platform managed key \\\n * **ConfidentialVM_DiskEncryptedWithCustomerKey**: Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a customer managed key \\\n * **ConfidentialVM_NonPersistedTPM**: Indicates Confidential VM disk with a ephemeral vTPM. vTPM state is not persisted across VM reboots.\n */\nexport type DiskSecurityTypes = string;\n\n/** Known values of {@link PublicNetworkAccess} that the service accepts. */\nexport enum KnownPublicNetworkAccess {\n /** You can generate a SAS URI to access the underlying data of the disk publicly on the internet when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate. */\n Enabled = \"Enabled\",\n /** You cannot access the underlying data of the disk publicly on the internet even when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate. */\n Disabled = \"Disabled\",\n}\n\n/**\n * Defines values for PublicNetworkAccess. \\\n * {@link KnownPublicNetworkAccess} can be used interchangeably with PublicNetworkAccess,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Enabled**: You can generate a SAS URI to access the underlying data of the disk publicly on the internet when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate. \\\n * **Disabled**: You cannot access the underlying data of the disk publicly on the internet even when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate.\n */\nexport type PublicNetworkAccess = string;\n\n/** Known values of {@link DataAccessAuthMode} that the service accepts. */\nexport enum KnownDataAccessAuthMode {\n /** When export\\/upload URL is used, the system checks if the user has an identity in Azure Active Directory and has necessary permissions to export\\/upload the data. Please refer to aka.ms\\/DisksAzureADAuth. */\n AzureActiveDirectory = \"AzureActiveDirectory\",\n /** No additional authentication would be performed when accessing export\\/upload URL. */\n None = \"None\",\n}\n\n/**\n * Defines values for DataAccessAuthMode. \\\n * {@link KnownDataAccessAuthMode} can be used interchangeably with DataAccessAuthMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **AzureActiveDirectory**: When export\\/upload URL is used, the system checks if the user has an identity in Azure Active Directory and has necessary permissions to export\\/upload the data. Please refer to aka.ms\\/DisksAzureADAuth. \\\n * **None**: No additional authentication would be performed when accessing export\\/upload URL.\n */\nexport type DataAccessAuthMode = string;\n\n/** Known values of {@link AvailabilityPolicyDiskDelay} that the service accepts. */\nexport enum KnownAvailabilityPolicyDiskDelay {\n /** Defaults to behavior without av policy specified, which is VM restart upon slow disk io. */\n None = \"None\",\n /** Upon a disk io failure or slow response, try detaching then reattaching the disk. */\n AutomaticReattach = \"AutomaticReattach\",\n}\n\n/**\n * Defines values for AvailabilityPolicyDiskDelay. \\\n * {@link KnownAvailabilityPolicyDiskDelay} can be used interchangeably with AvailabilityPolicyDiskDelay,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None**: Defaults to behavior without av policy specified, which is VM restart upon slow disk io. \\\n * **AutomaticReattach**: Upon a disk io failure or slow response, try detaching then reattaching the disk.\n */\nexport type AvailabilityPolicyDiskDelay = string;\n\n/** Known values of {@link DiskStorageAccountTypes} that the service accepts. */\nexport enum KnownDiskStorageAccountTypes {\n /** Standard HDD locally redundant storage. Best for backup, non-critical, and infrequent access. */\n StandardLRS = \"Standard_LRS\",\n /** Premium SSD locally redundant storage. Best for production and performance sensitive workloads. */\n PremiumLRS = \"Premium_LRS\",\n /** Standard SSD locally redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test. */\n StandardSSDLRS = \"StandardSSD_LRS\",\n /** Ultra SSD locally redundant storage. Best for IO-intensive workloads such as SAP HANA, top tier databases (for example, SQL, Oracle), and other transaction-heavy workloads. */\n UltraSSDLRS = \"UltraSSD_LRS\",\n /** Premium SSD zone redundant storage. Best for the production workloads that need storage resiliency against zone failures. */\n PremiumZRS = \"Premium_ZRS\",\n /** Standard SSD zone redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test that need storage resiliency against zone failures. */\n StandardSSDZRS = \"StandardSSD_ZRS\",\n /** Premium SSD v2 locally redundant storage. Best for production and performance-sensitive workloads that consistently require low latency and high IOPS and throughput. */\n PremiumV2LRS = \"PremiumV2_LRS\",\n}\n\n/**\n * Defines values for DiskStorageAccountTypes. \\\n * {@link KnownDiskStorageAccountTypes} can be used interchangeably with DiskStorageAccountTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS**: Standard HDD locally redundant storage. Best for backup, non-critical, and infrequent access. \\\n * **Premium_LRS**: Premium SSD locally redundant storage. Best for production and performance sensitive workloads. \\\n * **StandardSSD_LRS**: Standard SSD locally redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test. \\\n * **UltraSSD_LRS**: Ultra SSD locally redundant storage. Best for IO-intensive workloads such as SAP HANA, top tier databases (for example, SQL, Oracle), and other transaction-heavy workloads. \\\n * **Premium_ZRS**: Premium SSD zone redundant storage. Best for the production workloads that need storage resiliency against zone failures. \\\n * **StandardSSD_ZRS**: Standard SSD zone redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test that need storage resiliency against zone failures. \\\n * **PremiumV2_LRS**: Premium SSD v2 locally redundant storage. Best for production and performance-sensitive workloads that consistently require low latency and high IOPS and throughput.\n */\nexport type DiskStorageAccountTypes = string;\n\n/** Known values of {@link CopyCompletionErrorReason} that the service accepts. */\nexport enum KnownCopyCompletionErrorReason {\n /** Indicates that the source snapshot was deleted while the background copy of the resource created via CopyStart operation was in progress. */\n CopySourceNotFound = \"CopySourceNotFound\",\n}\n\n/**\n * Defines values for CopyCompletionErrorReason. \\\n * {@link KnownCopyCompletionErrorReason} can be used interchangeably with CopyCompletionErrorReason,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CopySourceNotFound**: Indicates that the source snapshot was deleted while the background copy of the resource created via CopyStart operation was in progress.\n */\nexport type CopyCompletionErrorReason = string;\n\n/** Known values of {@link SnapshotStorageAccountTypes} that the service accepts. */\nexport enum KnownSnapshotStorageAccountTypes {\n /** Standard HDD locally redundant storage */\n StandardLRS = \"Standard_LRS\",\n /** Premium SSD locally redundant storage */\n PremiumLRS = \"Premium_LRS\",\n /** Standard zone redundant storage */\n StandardZRS = \"Standard_ZRS\",\n}\n\n/**\n * Defines values for SnapshotStorageAccountTypes. \\\n * {@link KnownSnapshotStorageAccountTypes} can be used interchangeably with SnapshotStorageAccountTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS**: Standard HDD locally redundant storage \\\n * **Premium_LRS**: Premium SSD locally redundant storage \\\n * **Standard_ZRS**: Standard zone redundant storage\n */\nexport type SnapshotStorageAccountTypes = string;\n\n/** Known values of {@link AccessLevel} that the service accepts. */\nexport enum KnownAccessLevel {\n /** None */\n None = \"None\",\n /** Read */\n Read = \"Read\",\n /** Write */\n Write = \"Write\",\n}\n\n/**\n * Defines values for AccessLevel. \\\n * {@link KnownAccessLevel} can be used interchangeably with AccessLevel,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Read** \\\n * **Write**\n */\nexport type AccessLevel = string;\n\n/** Known values of {@link FileFormat} that the service accepts. */\nexport enum KnownFileFormat {\n /** A VHD file is a disk image file in the Virtual Hard Disk file format. */\n VHD = \"VHD\",\n /** A VHDX file is a disk image file in the Virtual Hard Disk v2 file format. */\n Vhdx = \"VHDX\",\n}\n\n/**\n * Defines values for FileFormat. \\\n * {@link KnownFileFormat} can be used interchangeably with FileFormat,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **VHD**: A VHD file is a disk image file in the Virtual Hard Disk file format. \\\n * **VHDX**: A VHDX file is a disk image file in the Virtual Hard Disk v2 file format.\n */\nexport type FileFormat = string;\n\n/** Known values of {@link ExtendedLocationType} that the service accepts. */\nexport enum KnownExtendedLocationType {\n /** EdgeZone */\n EdgeZone = \"EdgeZone\",\n}\n\n/**\n * Defines values for ExtendedLocationType. \\\n * {@link KnownExtendedLocationType} can be used interchangeably with ExtendedLocationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EdgeZone**\n */\nexport type ExtendedLocationType = string;\n\n/** Known values of {@link GalleryProvisioningState} that the service accepts. */\nexport enum KnownGalleryProvisioningState {\n /** Creating */\n Creating = \"Creating\",\n /** Updating */\n Updating = \"Updating\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** Deleting */\n Deleting = \"Deleting\",\n /** Migrating */\n Migrating = \"Migrating\",\n}\n\n/**\n * Defines values for GalleryProvisioningState. \\\n * {@link KnownGalleryProvisioningState} can be used interchangeably with GalleryProvisioningState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Creating** \\\n * **Updating** \\\n * **Failed** \\\n * **Succeeded** \\\n * **Deleting** \\\n * **Migrating**\n */\nexport type GalleryProvisioningState = string;\n\n/** Known values of {@link GallerySharingPermissionTypes} that the service accepts. */\nexport enum KnownGallerySharingPermissionTypes {\n /** Private */\n Private = \"Private\",\n /** Groups */\n Groups = \"Groups\",\n /** Community */\n Community = \"Community\",\n}\n\n/**\n * Defines values for GallerySharingPermissionTypes. \\\n * {@link KnownGallerySharingPermissionTypes} can be used interchangeably with GallerySharingPermissionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Private** \\\n * **Groups** \\\n * **Community**\n */\nexport type GallerySharingPermissionTypes = string;\n\n/** Known values of {@link SharingProfileGroupTypes} that the service accepts. */\nexport enum KnownSharingProfileGroupTypes {\n /** Subscriptions */\n Subscriptions = \"Subscriptions\",\n /** AADTenants */\n AADTenants = \"AADTenants\",\n}\n\n/**\n * Defines values for SharingProfileGroupTypes. \\\n * {@link KnownSharingProfileGroupTypes} can be used interchangeably with SharingProfileGroupTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Subscriptions** \\\n * **AADTenants**\n */\nexport type SharingProfileGroupTypes = string;\n\n/** Known values of {@link SharingState} that the service accepts. */\nexport enum KnownSharingState {\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Failed */\n Failed = \"Failed\",\n /** Unknown */\n Unknown = \"Unknown\",\n}\n\n/**\n * Defines values for SharingState. \\\n * {@link KnownSharingState} can be used interchangeably with SharingState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Succeeded** \\\n * **InProgress** \\\n * **Failed** \\\n * **Unknown**\n */\nexport type SharingState = string;\n\n/** Known values of {@link UefiSignatureTemplateName} that the service accepts. */\nexport enum KnownUefiSignatureTemplateName {\n /** NoSignatureTemplate */\n NoSignatureTemplate = \"NoSignatureTemplate\",\n /** MicrosoftUefiCertificateAuthorityTemplate */\n MicrosoftUefiCertificateAuthorityTemplate = \"MicrosoftUefiCertificateAuthorityTemplate\",\n /** MicrosoftWindowsTemplate */\n MicrosoftWindowsTemplate = \"MicrosoftWindowsTemplate\",\n}\n\n/**\n * Defines values for UefiSignatureTemplateName. \\\n * {@link KnownUefiSignatureTemplateName} can be used interchangeably with UefiSignatureTemplateName,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **NoSignatureTemplate** \\\n * **MicrosoftUefiCertificateAuthorityTemplate** \\\n * **MicrosoftWindowsTemplate**\n */\nexport type UefiSignatureTemplateName = string;\n\n/** Known values of {@link UefiKeyType} that the service accepts. */\nexport enum KnownUefiKeyType {\n /** Sha256 */\n Sha256 = \"sha256\",\n /** X509 */\n X509 = \"x509\",\n}\n\n/**\n * Defines values for UefiKeyType. \\\n * {@link KnownUefiKeyType} can be used interchangeably with UefiKeyType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **sha256** \\\n * **x509**\n */\nexport type UefiKeyType = string;\n\n/** Known values of {@link SharedGalleryHostCaching} that the service accepts. */\nexport enum KnownSharedGalleryHostCaching {\n /** None */\n None = \"None\",\n /** ReadOnly */\n ReadOnly = \"ReadOnly\",\n /** ReadWrite */\n ReadWrite = \"ReadWrite\",\n}\n\n/**\n * Defines values for SharedGalleryHostCaching. \\\n * {@link KnownSharedGalleryHostCaching} can be used interchangeably with SharedGalleryHostCaching,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **ReadOnly** \\\n * **ReadWrite**\n */\nexport type SharedGalleryHostCaching = string;\n\n/** Known values of {@link SharedToValues} that the service accepts. */\nexport enum KnownSharedToValues {\n /** Tenant */\n Tenant = \"tenant\",\n}\n\n/**\n * Defines values for SharedToValues. \\\n * {@link KnownSharedToValues} can be used interchangeably with SharedToValues,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **tenant**\n */\nexport type SharedToValues = string;\n\n/** Known values of {@link SelectPermissions} that the service accepts. */\nexport enum KnownSelectPermissions {\n /** Permissions */\n Permissions = \"Permissions\",\n}\n\n/**\n * Defines values for SelectPermissions. \\\n * {@link KnownSelectPermissions} can be used interchangeably with SelectPermissions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Permissions**\n */\nexport type SelectPermissions = string;\n\n/** Known values of {@link GalleryExpandParams} that the service accepts. */\nexport enum KnownGalleryExpandParams {\n /** SharingProfileGroups */\n SharingProfileGroups = \"SharingProfile/Groups\",\n}\n\n/**\n * Defines values for GalleryExpandParams. \\\n * {@link KnownGalleryExpandParams} can be used interchangeably with GalleryExpandParams,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **SharingProfile\\/Groups**\n */\nexport type GalleryExpandParams = string;\n\n/** Known values of {@link GalleryApplicationScriptRebootBehavior} that the service accepts. */\nexport enum KnownGalleryApplicationScriptRebootBehavior {\n /** None */\n None = \"None\",\n /** Rerun */\n Rerun = \"Rerun\",\n}\n\n/**\n * Defines values for GalleryApplicationScriptRebootBehavior. \\\n * {@link KnownGalleryApplicationScriptRebootBehavior} can be used interchangeably with GalleryApplicationScriptRebootBehavior,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Rerun**\n */\nexport type GalleryApplicationScriptRebootBehavior = string;\n\n/** Known values of {@link StorageAccountType} that the service accepts. */\nexport enum KnownStorageAccountType {\n /** StandardLRS */\n StandardLRS = \"Standard_LRS\",\n /** StandardZRS */\n StandardZRS = \"Standard_ZRS\",\n /** PremiumLRS */\n PremiumLRS = \"Premium_LRS\",\n /** PremiumV2LRS */\n PremiumV2LRS = \"PremiumV2_LRS\",\n}\n\n/**\n * Defines values for StorageAccountType. \\\n * {@link KnownStorageAccountType} can be used interchangeably with StorageAccountType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS** \\\n * **Standard_ZRS** \\\n * **Premium_LRS** \\\n * **PremiumV2_LRS**\n */\nexport type StorageAccountType = string;\n\n/** Known values of {@link ConfidentialVMEncryptionType} that the service accepts. */\nexport enum KnownConfidentialVMEncryptionType {\n /** EncryptedVMGuestStateOnlyWithPmk */\n EncryptedVMGuestStateOnlyWithPmk = \"EncryptedVMGuestStateOnlyWithPmk\",\n /** EncryptedWithPmk */\n EncryptedWithPmk = \"EncryptedWithPmk\",\n /** EncryptedWithCmk */\n EncryptedWithCmk = \"EncryptedWithCmk\",\n /** NonPersistedTPM */\n NonPersistedTPM = \"NonPersistedTPM\",\n}\n\n/**\n * Defines values for ConfidentialVMEncryptionType. \\\n * {@link KnownConfidentialVMEncryptionType} can be used interchangeably with ConfidentialVMEncryptionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptedVMGuestStateOnlyWithPmk** \\\n * **EncryptedWithPmk** \\\n * **EncryptedWithCmk** \\\n * **NonPersistedTPM**\n */\nexport type ConfidentialVMEncryptionType = string;\n\n/** Known values of {@link ReplicationMode} that the service accepts. */\nexport enum KnownReplicationMode {\n /** Full */\n Full = \"Full\",\n /** Shallow */\n Shallow = \"Shallow\",\n}\n\n/**\n * Defines values for ReplicationMode. \\\n * {@link KnownReplicationMode} can be used interchangeably with ReplicationMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Full** \\\n * **Shallow**\n */\nexport type ReplicationMode = string;\n\n/** Known values of {@link GalleryExtendedLocationType} that the service accepts. */\nexport enum KnownGalleryExtendedLocationType {\n /** EdgeZone */\n EdgeZone = \"EdgeZone\",\n /** Unknown */\n Unknown = \"Unknown\",\n}\n\n/**\n * Defines values for GalleryExtendedLocationType. \\\n * {@link KnownGalleryExtendedLocationType} can be used interchangeably with GalleryExtendedLocationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EdgeZone** \\\n * **Unknown**\n */\nexport type GalleryExtendedLocationType = string;\n\n/** Known values of {@link EdgeZoneStorageAccountType} that the service accepts. */\nexport enum KnownEdgeZoneStorageAccountType {\n /** StandardLRS */\n StandardLRS = \"Standard_LRS\",\n /** StandardZRS */\n StandardZRS = \"Standard_ZRS\",\n /** StandardSSDLRS */\n StandardSSDLRS = \"StandardSSD_LRS\",\n /** PremiumLRS */\n PremiumLRS = \"Premium_LRS\",\n}\n\n/**\n * Defines values for EdgeZoneStorageAccountType. \\\n * {@link KnownEdgeZoneStorageAccountType} can be used interchangeably with EdgeZoneStorageAccountType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS** \\\n * **Standard_ZRS** \\\n * **StandardSSD_LRS** \\\n * **Premium_LRS**\n */\nexport type EdgeZoneStorageAccountType = string;\n\n/** Known values of {@link AggregatedReplicationState} that the service accepts. */\nexport enum KnownAggregatedReplicationState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Completed */\n Completed = \"Completed\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for AggregatedReplicationState. \\\n * {@link KnownAggregatedReplicationState} can be used interchangeably with AggregatedReplicationState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **InProgress** \\\n * **Completed** \\\n * **Failed**\n */\nexport type AggregatedReplicationState = string;\n\n/** Known values of {@link ReplicationState} that the service accepts. */\nexport enum KnownReplicationState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Replicating */\n Replicating = \"Replicating\",\n /** Completed */\n Completed = \"Completed\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for ReplicationState. \\\n * {@link KnownReplicationState} can be used interchangeably with ReplicationState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Replicating** \\\n * **Completed** \\\n * **Failed**\n */\nexport type ReplicationState = string;\n\n/** Known values of {@link ReplicationStatusTypes} that the service accepts. */\nexport enum KnownReplicationStatusTypes {\n /** ReplicationStatus */\n ReplicationStatus = \"ReplicationStatus\",\n /** UefiSettings */\n UefiSettings = \"UefiSettings\",\n}\n\n/**\n * Defines values for ReplicationStatusTypes. \\\n * {@link KnownReplicationStatusTypes} can be used interchangeably with ReplicationStatusTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ReplicationStatus** \\\n * **UefiSettings**\n */\nexport type ReplicationStatusTypes = string;\n\n/** Known values of {@link PolicyViolationCategory} that the service accepts. */\nexport enum KnownPolicyViolationCategory {\n /** Other */\n Other = \"Other\",\n /** ImageFlaggedUnsafe */\n ImageFlaggedUnsafe = \"ImageFlaggedUnsafe\",\n /** CopyrightValidation */\n CopyrightValidation = \"CopyrightValidation\",\n /** IpTheft */\n IpTheft = \"IpTheft\",\n}\n\n/**\n * Defines values for PolicyViolationCategory. \\\n * {@link KnownPolicyViolationCategory} can be used interchangeably with PolicyViolationCategory,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Other** \\\n * **ImageFlaggedUnsafe** \\\n * **CopyrightValidation** \\\n * **IpTheft**\n */\nexport type PolicyViolationCategory = string;\n\n/** Known values of {@link ValidationStatus} that the service accepts. */\nexport enum KnownValidationStatus {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n}\n\n/**\n * Defines values for ValidationStatus. \\\n * {@link KnownValidationStatus} can be used interchangeably with ValidationStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Failed** \\\n * **Succeeded**\n */\nexport type ValidationStatus = string;\n\n/** Known values of {@link AccessControlRulesMode} that the service accepts. */\nexport enum KnownAccessControlRulesMode {\n /** Audit */\n Audit = \"Audit\",\n /** Enforce */\n Enforce = \"Enforce\",\n /** Disabled */\n Disabled = \"Disabled\",\n}\n\n/**\n * Defines values for AccessControlRulesMode. \\\n * {@link KnownAccessControlRulesMode} can be used interchangeably with AccessControlRulesMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Audit** \\\n * **Enforce** \\\n * **Disabled**\n */\nexport type AccessControlRulesMode = string;\n\n/** Known values of {@link EndpointAccess} that the service accepts. */\nexport enum KnownEndpointAccess {\n /** Allow */\n Allow = \"Allow\",\n /** Deny */\n Deny = \"Deny\",\n}\n\n/**\n * Defines values for EndpointAccess. \\\n * {@link KnownEndpointAccess} can be used interchangeably with EndpointAccess,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Allow** \\\n * **Deny**\n */\nexport type EndpointAccess = string;\n\n/** Known values of {@link SharingUpdateOperationTypes} that the service accepts. */\nexport enum KnownSharingUpdateOperationTypes {\n /** Add */\n Add = \"Add\",\n /** Remove */\n Remove = \"Remove\",\n /** Reset */\n Reset = \"Reset\",\n /** EnableCommunity */\n EnableCommunity = \"EnableCommunity\",\n}\n\n/**\n * Defines values for SharingUpdateOperationTypes. \\\n * {@link KnownSharingUpdateOperationTypes} can be used interchangeably with SharingUpdateOperationTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Add** \\\n * **Remove** \\\n * **Reset** \\\n * **EnableCommunity**\n */\nexport type SharingUpdateOperationTypes = string;\n\n/** Known values of {@link SoftDeletedArtifactTypes} that the service accepts. */\nexport enum KnownSoftDeletedArtifactTypes {\n /** Images */\n Images = \"Images\",\n}\n\n/**\n * Defines values for SoftDeletedArtifactTypes. \\\n * {@link KnownSoftDeletedArtifactTypes} can be used interchangeably with SoftDeletedArtifactTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Images**\n */\nexport type SoftDeletedArtifactTypes = string;\n\n/** Known values of {@link CloudServiceUpgradeMode} that the service accepts. */\nexport enum KnownCloudServiceUpgradeMode {\n /** Auto */\n Auto = \"Auto\",\n /** Manual */\n Manual = \"Manual\",\n /** Simultaneous */\n Simultaneous = \"Simultaneous\",\n}\n\n/**\n * Defines values for CloudServiceUpgradeMode. \\\n * {@link KnownCloudServiceUpgradeMode} can be used interchangeably with CloudServiceUpgradeMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Auto** \\\n * **Manual** \\\n * **Simultaneous**\n */\nexport type CloudServiceUpgradeMode = string;\n\n/** Known values of {@link CloudServiceSlotType} that the service accepts. */\nexport enum KnownCloudServiceSlotType {\n /** Production */\n Production = \"Production\",\n /** Staging */\n Staging = \"Staging\",\n}\n\n/**\n * Defines values for CloudServiceSlotType. \\\n * {@link KnownCloudServiceSlotType} can be used interchangeably with CloudServiceSlotType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Production** \\\n * **Staging**\n */\nexport type CloudServiceSlotType = string;\n\n/** Known values of {@link AvailabilitySetSkuTypes} that the service accepts. */\nexport enum KnownAvailabilitySetSkuTypes {\n /** Classic */\n Classic = \"Classic\",\n /** Aligned */\n Aligned = \"Aligned\",\n}\n\n/**\n * Defines values for AvailabilitySetSkuTypes. \\\n * {@link KnownAvailabilitySetSkuTypes} can be used interchangeably with AvailabilitySetSkuTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Classic** \\\n * **Aligned**\n */\nexport type AvailabilitySetSkuTypes = string;\n/** Defines values for StatusLevelTypes. */\nexport type StatusLevelTypes = \"Info\" | \"Warning\" | \"Error\";\n/** Defines values for OperatingSystemTypes. */\nexport type OperatingSystemTypes = \"Windows\" | \"Linux\";\n/** Defines values for OperatingSystemStateTypes. */\nexport type OperatingSystemStateTypes = \"Generalized\" | \"Specialized\";\n/** Defines values for CachingTypes. */\nexport type CachingTypes = \"None\" | \"ReadOnly\" | \"ReadWrite\";\n/** Defines values for IntervalInMins. */\nexport type IntervalInMins = \"ThreeMins\" | \"FiveMins\" | \"ThirtyMins\" | \"SixtyMins\";\n/** Defines values for UpgradeMode. */\nexport type UpgradeMode = \"Automatic\" | \"Manual\" | \"Rolling\";\n/** Defines values for SettingNames. */\nexport type SettingNames = \"AutoLogon\" | \"FirstLogonCommands\";\n/** Defines values for ProtocolTypes. */\nexport type ProtocolTypes = \"Http\" | \"Https\";\n/** Defines values for ResourceIdentityType. */\nexport type ResourceIdentityType =\n | \"SystemAssigned\"\n | \"UserAssigned\"\n | \"SystemAssigned, UserAssigned\"\n | \"None\";\n/** Defines values for MaintenanceOperationResultCodeTypes. */\nexport type MaintenanceOperationResultCodeTypes =\n | \"None\"\n | \"RetryLater\"\n | \"MaintenanceAborted\"\n | \"MaintenanceCompleted\";\n/** Defines values for InstanceViewTypes. */\nexport type InstanceViewTypes = \"instanceView\" | \"userData\" | \"resiliencyView\";\n/** Defines values for DedicatedHostLicenseTypes. */\nexport type DedicatedHostLicenseTypes =\n | \"None\"\n | \"Windows_Server_Hybrid\"\n | \"Windows_Server_Perpetual\";\n/** Defines values for UpgradeState. */\nexport type UpgradeState = \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n/** Defines values for UpgradeOperationInvoker. */\nexport type UpgradeOperationInvoker = \"Unknown\" | \"User\" | \"Platform\";\n/** Defines values for RollingUpgradeStatusCode. */\nexport type RollingUpgradeStatusCode = \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n/** Defines values for RollingUpgradeActionType. */\nexport type RollingUpgradeActionType = \"Start\" | \"Cancel\";\n/** Defines values for VirtualMachineScaleSetSkuScaleType. */\nexport type VirtualMachineScaleSetSkuScaleType = \"Automatic\" | \"None\";\n/** Defines values for ResourceSkuCapacityScaleType. */\nexport type ResourceSkuCapacityScaleType = \"Automatic\" | \"Manual\" | \"None\";\n/** Defines values for ResourceSkuRestrictionsType. */\nexport type ResourceSkuRestrictionsType = \"Location\" | \"Zone\";\n/** Defines values for ResourceSkuRestrictionsReasonCode. */\nexport type ResourceSkuRestrictionsReasonCode = \"QuotaId\" | \"NotAvailableForSubscription\";\n/** Defines values for GalleryApplicationCustomActionParameterType. */\nexport type GalleryApplicationCustomActionParameterType =\n | \"String\"\n | \"ConfigurationDataBlob\"\n | \"LogOutputBlob\";\n/** Defines values for HostCaching. */\nexport type HostCaching = \"None\" | \"ReadOnly\" | \"ReadWrite\";\n/** Defines values for EndpointTypes. */\nexport type EndpointTypes = \"WireServer\" | \"IMDS\";\n\n/** Optional parameters. */\nexport interface OperationsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type OperationsListResponse = OperationListResult;\n\n/** Optional parameters. */\nexport interface OperationsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type OperationsListNextResponse = OperationListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. Allowed values are 'instanceView'. */\n expand?: string;\n}\n\n/** Contains response data for the listBySubscription operation. */\nexport type AvailabilitySetsListBySubscriptionResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type AvailabilitySetsListResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type AvailabilitySetsGetResponse = AvailabilitySet;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type AvailabilitySetsCreateOrUpdateResponse = AvailabilitySet;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type AvailabilitySetsUpdateResponse = AvailabilitySet;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsCancelMigrationToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsConvertToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {\n /** Parameters supplied to the migrate operation on the availability set. */\n parameters?: ConvertToVirtualMachineScaleSetInput;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the convertToVirtualMachineScaleSet operation. */\nexport type AvailabilitySetsConvertToVirtualMachineScaleSetResponse =\n AvailabilitySetsConvertToVirtualMachineScaleSetHeaders;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsStartMigrationToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsValidateMigrationToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListAvailableSizesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizes operation. */\nexport type AvailabilitySetsListAvailableSizesResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type AvailabilitySetsListBySubscriptionNextResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type AvailabilitySetsListNextResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListAvailableSizesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizesNext operation. */\nexport type AvailabilitySetsListAvailableSizesNextResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. Based on the expand param(s) specified we return Virtual Machine or ScaleSet VM Instance or both resource Ids which are associated to capacity reservation group in the response. */\n expand?: ExpandTypesForGetCapacityReservationGroups;\n /** The query option to fetch Capacity Reservation Group Resource Ids. <br> 'CreatedInSubscription' enables fetching Resource Ids for all capacity reservation group resources created in the subscription. <br> 'SharedWithSubscription' enables fetching Resource Ids for all capacity reservation group resources shared with the subscription. <br> 'All' enables fetching Resource Ids for all capacity reservation group resources shared with the subscription and created in the subscription. */\n resourceIdsOnly?: ResourceIdOptionsForGetCapacityReservationGroups;\n}\n\n/** Contains response data for the listBySubscription operation. */\nexport type CapacityReservationGroupsListBySubscriptionResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. Based on the expand param(s) specified we return Virtual Machine or ScaleSet VM Instance or both resource Ids which are associated to capacity reservation group in the response. */\n expand?: ExpandTypesForGetCapacityReservationGroups;\n}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type CapacityReservationGroupsListByResourceGroupResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the list of instance views of the capacity reservations under the capacity reservation group which is a snapshot of the runtime properties of a capacity reservation that is managed by the platform and can change outside of control plane operations. */\n expand?: CapacityReservationGroupInstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type CapacityReservationGroupsGetResponse = CapacityReservationGroup;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type CapacityReservationGroupsCreateOrUpdateResponse = CapacityReservationGroup;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type CapacityReservationGroupsUpdateResponse = CapacityReservationGroup;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsDeleteOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type CapacityReservationGroupsListBySubscriptionNextResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type CapacityReservationGroupsListByResourceGroupNextResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscription operation. */\nexport type DedicatedHostGroupsListBySubscriptionResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DedicatedHostGroupsListByResourceGroupResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the list of instance views of the dedicated hosts under the dedicated host group. 'UserData' is not supported for dedicated host group. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type DedicatedHostGroupsGetResponse = DedicatedHostGroup;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DedicatedHostGroupsCreateOrUpdateResponse = DedicatedHostGroup;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type DedicatedHostGroupsUpdateResponse = DedicatedHostGroup;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type DedicatedHostGroupsListBySubscriptionNextResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DedicatedHostGroupsListByResourceGroupNextResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface ImagesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type ImagesListResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface ImagesListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type ImagesListByResourceGroupResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface ImagesGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type ImagesGetResponse = Image;\n\n/** Optional parameters. */\nexport interface ImagesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type ImagesCreateOrUpdateResponse = Image;\n\n/** Optional parameters. */\nexport interface ImagesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type ImagesUpdateResponse = Image;\n\n/** Optional parameters. */\nexport interface ImagesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface ImagesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type ImagesListNextResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface ImagesListByResourceGroupNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type ImagesListByResourceGroupNextResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListPublishersOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPublishers operation. */\nexport type VirtualMachineImagesEdgeZoneListPublishersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListOffersOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOffers operation. */\nexport type VirtualMachineImagesEdgeZoneListOffersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListSkusOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkus operation. */\nexport type VirtualMachineImagesEdgeZoneListSkusResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineImagesEdgeZoneListResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineImagesEdgeZoneGetResponse = VirtualMachineImage;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListByEdgeZoneOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByEdgeZone operation. */\nexport type VirtualMachineImagesListByEdgeZoneResponse = VmImagesInEdgeZoneListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListPublishersOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPublishers operation. */\nexport type VirtualMachineImagesListPublishersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListOffersOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOffers operation. */\nexport type VirtualMachineImagesListOffersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListSkusOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkus operation. */\nexport type VirtualMachineImagesListSkusResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineImagesListResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineImagesGetResponse = VirtualMachineImage;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListWithPropertiesOptionalParams\n extends coreClient.OperationOptions {\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n}\n\n/** Contains response data for the listWithProperties operation. */\nexport type VirtualMachineImagesListWithPropertiesResponse = VirtualMachineImage[];\n\n/** Optional parameters. */\nexport interface LogAnalyticsExportRequestRateByIntervalOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the exportRequestRateByInterval operation. */\nexport type LogAnalyticsExportRequestRateByIntervalResponse = LogAnalyticsOperationResult;\n\n/** Optional parameters. */\nexport interface LogAnalyticsExportThrottledRequestsOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the exportThrottledRequests operation. */\nexport type LogAnalyticsExportThrottledRequestsResponse = LogAnalyticsOperationResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionImagesListTypesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listTypes operation. */\nexport type VirtualMachineExtensionImagesListTypesResponse = VirtualMachineExtensionImage[];\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionImagesListVersionsOptionalParams\n extends coreClient.OperationOptions {\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n /** The filter to apply on the operation. */\n filter?: string;\n}\n\n/** Contains response data for the listVersions operation. */\nexport type VirtualMachineExtensionImagesListVersionsResponse = VirtualMachineExtensionImage[];\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionImagesGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineExtensionImagesGetResponse = VirtualMachineExtensionImage;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineRunCommandsListResponse = RunCommandListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineRunCommandsGetResponse = RunCommandDocument;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListByVirtualMachineOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the listByVirtualMachine operation. */\nexport type VirtualMachineRunCommandsListByVirtualMachineResponse =\n VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsGetByVirtualMachineOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the getByVirtualMachine operation. */\nexport type VirtualMachineRunCommandsGetByVirtualMachineResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineRunCommandsCreateOrUpdateResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineRunCommandsUpdateResponse = VirtualMachineRunCommandsUpdateHeaders &\n VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineRunCommandsListNextResponse = RunCommandListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListByVirtualMachineNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByVirtualMachineNext operation. */\nexport type VirtualMachineRunCommandsListByVirtualMachineNextResponse =\n VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface UsageListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type UsageListResponse = ListUsagesResult;\n\n/** Optional parameters. */\nexport interface UsageListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type UsageListNextResponse = ListUsagesResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListByLocationOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocation operation. */\nexport type VirtualMachineScaleSetsListByLocationResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListAllOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAll operation. */\nexport type VirtualMachineScaleSetsListAllResponse = VirtualMachineScaleSetListWithLinkResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetsListResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'UserData' retrieves the UserData property of the VM scale set that was provided by the user during the VM scale set Create/Update operation */\n expand?: ExpandTypesForGetVMScaleSets;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetsGetResponse = VirtualMachineScaleSet;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetsCreateOrUpdateResponse = VirtualMachineScaleSet;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetsUpdateResponse = VirtualMachineScaleSetsUpdateHeaders &\n VirtualMachineScaleSet;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to force delete a VM scale set. (Feature in Preview) */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsApproveRollingUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the approveRollingUpgrade operation. */\nexport type VirtualMachineScaleSetsApproveRollingUpgradeResponse =\n VirtualMachineScaleSetsApproveRollingUpgradeHeaders;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsConvertToSinglePlacementGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsDeallocateOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Optional parameter to hibernate a virtual machine from the VM scale set. (This feature is available for VMSS with Flexible OrchestrationMode only) */\n hibernate?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsDeleteInstancesOptionalParams\n extends coreClient.OperationOptions {\n /** Optional parameter to force delete virtual machines from the VM scale set. (Feature in Preview) */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsForceRecoveryServiceFabricPlatformUpdateDomainWalkOptionalParams\n extends coreClient.OperationOptions {\n /** The zone in which the manual recovery walk is requested for cross zone virtual machine scale set */\n zone?: string;\n /** The placement group id for which the manual recovery walk is requested. */\n placementGroupId?: string;\n}\n\n/** Contains response data for the forceRecoveryServiceFabricPlatformUpdateDomainWalk operation. */\nexport type VirtualMachineScaleSetsForceRecoveryServiceFabricPlatformUpdateDomainWalkResponse =\n RecoveryWalkResponse;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetInstanceViewOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type VirtualMachineScaleSetsGetInstanceViewResponse = VirtualMachineScaleSetInstanceView;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsUpdateInstancesOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetOSUpgradeHistoryOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSUpgradeHistory operation. */\nexport type VirtualMachineScaleSetsGetOSUpgradeHistoryResponse =\n VirtualMachineScaleSetListOSUpgradeHistory;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsPerformMaintenanceOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsPowerOffOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified */\n skipShutdown?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsReapplyOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsRedeployOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsReimageOptionalParams extends coreClient.OperationOptions {\n /** Parameters for Reimaging VM ScaleSet. */\n vmScaleSetReimageInput?: VirtualMachineScaleSetReimageParameters;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsReimageAllOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsRestartOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsScaleOutOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsSetOrchestrationServiceStateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListSkusOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkus operation. */\nexport type VirtualMachineScaleSetsListSkusResponse = VirtualMachineScaleSetListSkusResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsStartOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListByLocationNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocationNext operation. */\nexport type VirtualMachineScaleSetsListByLocationNextResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListAllNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type VirtualMachineScaleSetsListAllNextResponse = VirtualMachineScaleSetListWithLinkResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetsListNextResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetOSUpgradeHistoryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSUpgradeHistoryNext operation. */\nexport type VirtualMachineScaleSetsGetOSUpgradeHistoryNextResponse =\n VirtualMachineScaleSetListOSUpgradeHistory;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListSkusNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkusNext operation. */\nexport type VirtualMachineScaleSetsListSkusNextResponse = VirtualMachineScaleSetListSkusResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListByLocationOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocation operation. */\nexport type VirtualMachinesListByLocationResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAllOptionalParams extends coreClient.OperationOptions {\n /** The system query option to filter VMs returned in the response. Allowed value is 'virtualMachineScaleSet/id' eq /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{vmssName}' */\n filter?: string;\n /** statusOnly=true enables fetching run time status of all Virtual Machines in the subscription. */\n statusOnly?: string;\n /** The expand expression to apply on operation. 'instanceView' enables fetching run time status of all Virtual Machines, this can only be specified if a valid $filter option is specified */\n expand?: ExpandTypesForListVMs;\n}\n\n/** Contains response data for the listAll operation. */\nexport type VirtualMachinesListAllResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListOptionalParams extends coreClient.OperationOptions {\n /** The system query option to filter VMs returned in the response. Allowed value is 'virtualMachineScaleSet/id' eq /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{vmssName}' */\n filter?: string;\n /** The expand expression to apply on operation. 'instanceView' enables fetching run time status of all Virtual Machines, this can only be specified if a valid $filter option is specified */\n expand?: ExpandTypeForListVMs;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachinesListResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' retrieves a snapshot of the runtime properties of the virtual machine that is managed by the platform and can change outside of control plane operations. 'UserData' retrieves the UserData property as part of the VM model view that was provided by the user during the VM Create/Update operation. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachinesGetResponse = VirtualMachine;\n\n/** Optional parameters. */\nexport interface VirtualMachinesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachinesCreateOrUpdateResponse = VirtualMachine;\n\n/** Optional parameters. */\nexport interface VirtualMachinesUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachinesUpdateResponse = VirtualMachinesUpdateHeaders & VirtualMachine;\n\n/** Optional parameters. */\nexport interface VirtualMachinesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to force delete virtual machines. */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesAssessPatchesOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the assessPatches operation. */\nexport type VirtualMachinesAssessPatchesResponse = VirtualMachineAssessPatchesResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesAttachDetachDataDisksOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the attachDetachDataDisks operation. */\nexport type VirtualMachinesAttachDetachDataDisksResponse = StorageProfile;\n\n/** Optional parameters. */\nexport interface VirtualMachinesCaptureOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the capture operation. */\nexport type VirtualMachinesCaptureResponse = VirtualMachineCaptureResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesConvertToManagedDisksOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesDeallocateOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to hibernate a virtual machine. */\n hibernate?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesGeneralizeOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachinesInstallPatchesOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the installPatches operation. */\nexport type VirtualMachinesInstallPatchesResponse = VirtualMachineInstallPatchesResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesInstanceViewOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the instanceView operation. */\nexport type VirtualMachinesInstanceViewResponse = VirtualMachineInstanceView;\n\n/** Optional parameters. */\nexport interface VirtualMachinesMigrateToVMScaleSetOptionalParams\n extends coreClient.OperationOptions {\n /** Parameters supplied to the Migrate Virtual Machine operation. */\n parameters?: MigrateVMToVirtualMachineScaleSetInput;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the migrateToVMScaleSet operation. */\nexport type VirtualMachinesMigrateToVMScaleSetResponse = VirtualMachinesMigrateToVMScaleSetHeaders;\n\n/** Optional parameters. */\nexport interface VirtualMachinesPerformMaintenanceOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesPowerOffOptionalParams extends coreClient.OperationOptions {\n /** The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified */\n skipShutdown?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesReapplyOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesRedeployOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesReimageOptionalParams extends coreClient.OperationOptions {\n /** Parameters supplied to the Reimage Virtual Machine operation. */\n parameters?: VirtualMachineReimageParameters;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesRestartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesRetrieveBootDiagnosticsDataOptionalParams\n extends coreClient.OperationOptions {\n /** Expiration duration in minutes for the SAS URIs with a value between 1 to 1440 minutes. **Note:** If not specified, SAS URIs will be generated with a default expiration duration of 120 minutes. */\n sasUriExpirationTimeInMinutes?: number;\n}\n\n/** Contains response data for the retrieveBootDiagnosticsData operation. */\nexport type VirtualMachinesRetrieveBootDiagnosticsDataResponse = RetrieveBootDiagnosticsDataResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesRunCommandOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the runCommand operation. */\nexport type VirtualMachinesRunCommandResponse = RunCommandResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesSimulateEvictionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachinesStartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAvailableSizesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizes operation. */\nexport type VirtualMachinesListAvailableSizesResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListByLocationNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocationNext operation. */\nexport type VirtualMachinesListByLocationNextResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAllNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type VirtualMachinesListAllNextResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachinesListNextResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAvailableSizesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizesNext operation. */\nexport type VirtualMachinesListAvailableSizesNextResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineSizesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineSizesListResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineSizesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineSizesListNextResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscription operation. */\nexport type ProximityPlacementGroupsListBySubscriptionResponse = ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type ProximityPlacementGroupsListByResourceGroupResponse = ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsGetOptionalParams extends coreClient.OperationOptions {\n /** includeColocationStatus=true enables fetching the colocation status of all the resources in the proximity placement group. */\n includeColocationStatus?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type ProximityPlacementGroupsGetResponse = ProximityPlacementGroup;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type ProximityPlacementGroupsCreateOrUpdateResponse = ProximityPlacementGroup;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type ProximityPlacementGroupsUpdateResponse = ProximityPlacementGroup;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type ProximityPlacementGroupsListBySubscriptionNextResponse =\n ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type ProximityPlacementGroupsListByResourceGroupNextResponse =\n ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListAllOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAll operation. */\nexport type RestorePointCollectionsListAllResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type RestorePointCollectionsListResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. If expand=restorePoints, server will return all contained restore points in the restorePointCollection. */\n expand?: RestorePointCollectionExpandOptions;\n}\n\n/** Contains response data for the get operation. */\nexport type RestorePointCollectionsGetResponse = RestorePointCollection;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type RestorePointCollectionsCreateOrUpdateResponse = RestorePointCollection;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type RestorePointCollectionsUpdateResponse = RestorePointCollection;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListAllNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type RestorePointCollectionsListAllNextResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type RestorePointCollectionsListNextResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscription operation. */\nexport type SshPublicKeysListBySubscriptionResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type SshPublicKeysListByResourceGroupResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SshPublicKeysGetResponse = SshPublicKeyResource;\n\n/** Optional parameters. */\nexport interface SshPublicKeysCreateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the create operation. */\nexport type SshPublicKeysCreateResponse = SshPublicKeyResource;\n\n/** Optional parameters. */\nexport interface SshPublicKeysUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type SshPublicKeysUpdateResponse = SshPublicKeyResource;\n\n/** Optional parameters. */\nexport interface SshPublicKeysDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface SshPublicKeysGenerateKeyPairOptionalParams extends coreClient.OperationOptions {\n /** Parameters supplied to generate the SSH public key. */\n parameters?: SshGenerateKeyPairInputParameters;\n}\n\n/** Contains response data for the generateKeyPair operation. */\nexport type SshPublicKeysGenerateKeyPairResponse = SshPublicKeyGenerateKeyPairResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type SshPublicKeysListBySubscriptionNextResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type SshPublicKeysListByResourceGroupNextResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationsListByCapacityReservationGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByCapacityReservationGroup operation. */\nexport type CapacityReservationsListByCapacityReservationGroupResponse =\n CapacityReservationListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' retrieves a snapshot of the runtime properties of the capacity reservation that is managed by the platform and can change outside of control plane operations. */\n expand?: CapacityReservationInstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type CapacityReservationsGetResponse = CapacityReservation;\n\n/** Optional parameters. */\nexport interface CapacityReservationsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type CapacityReservationsCreateOrUpdateResponse = CapacityReservation;\n\n/** Optional parameters. */\nexport interface CapacityReservationsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type CapacityReservationsUpdateResponse = CapacityReservation;\n\n/** Optional parameters. */\nexport interface CapacityReservationsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CapacityReservationsListByCapacityReservationGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByCapacityReservationGroupNext operation. */\nexport type CapacityReservationsListByCapacityReservationGroupNextResponse =\n CapacityReservationListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsListByHostGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByHostGroup operation. */\nexport type DedicatedHostsListByHostGroupResponse = DedicatedHostListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the list of instance views of the dedicated host. 'UserData' is not supported for dedicated host. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type DedicatedHostsGetResponse = DedicatedHost;\n\n/** Optional parameters. */\nexport interface DedicatedHostsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DedicatedHostsCreateOrUpdateResponse = DedicatedHost;\n\n/** Optional parameters. */\nexport interface DedicatedHostsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DedicatedHostsUpdateResponse = DedicatedHostsUpdateHeaders & DedicatedHost;\n\n/** Optional parameters. */\nexport interface DedicatedHostsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DedicatedHostsListAvailableSizesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizes operation. */\nexport type DedicatedHostsListAvailableSizesResponse = DedicatedHostSizeListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsRedeployOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the redeploy operation. */\nexport type DedicatedHostsRedeployResponse = DedicatedHostsRedeployHeaders;\n\n/** Optional parameters. */\nexport interface DedicatedHostsRestartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the restart operation. */\nexport type DedicatedHostsRestartResponse = DedicatedHostsRestartHeaders;\n\n/** Optional parameters. */\nexport interface DedicatedHostsListByHostGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByHostGroupNext operation. */\nexport type DedicatedHostsListByHostGroupNextResponse = DedicatedHostListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsListAvailableSizesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizesNext operation. */\nexport type DedicatedHostsListAvailableSizesNextResponse = DedicatedHostSizeListResult;\n\n/** Optional parameters. */\nexport interface RestorePointsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' retrieves information about the run-time state of a restore point. */\n expand?: RestorePointExpandOptions;\n}\n\n/** Contains response data for the get operation. */\nexport type RestorePointsGetResponse = RestorePoint;\n\n/** Optional parameters. */\nexport interface RestorePointsCreateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the create operation. */\nexport type RestorePointsCreateResponse = RestorePointsCreateHeaders & RestorePoint;\n\n/** Optional parameters. */\nexport interface RestorePointsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartExtensionUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartOSUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesCancelOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesGetLatestOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getLatest operation. */\nexport type VirtualMachineScaleSetRollingUpgradesGetLatestResponse = RollingUpgradeStatusInfo;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsListOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetExtensionsListResponse =\n VirtualMachineScaleSetExtensionListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsGetOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetExtensionsGetResponse = VirtualMachineScaleSetExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetExtensionsCreateOrUpdateResponse =\n VirtualMachineScaleSetExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetExtensionsUpdateResponse = VirtualMachineScaleSetExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetExtensionsListNextResponse =\n VirtualMachineScaleSetExtensionListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. Allowed values are 'instanceView'. */\n expand?: string;\n /** The filter to apply to the operation. Allowed values are 'startswith(instanceView/statuses/code, 'PowerState') eq true', 'properties/latestModelApplied eq true', 'properties/latestModelApplied eq false'. */\n filter?: string;\n /** The list parameters. Allowed values are 'instanceView', 'instanceView/statuses'. */\n select?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetVMsListResponse = VirtualMachineScaleSetVMListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the instance view of the virtual machine. 'UserData' will retrieve the UserData of the virtual machine. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetVMsGetResponse = VirtualMachineScaleSetVM;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetVMsUpdateResponse = VirtualMachineScaleSetVM;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to force delete a virtual machine from a VM scale set. (Feature in Preview) */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsApproveRollingUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the approveRollingUpgrade operation. */\nexport type VirtualMachineScaleSetVMsApproveRollingUpgradeResponse =\n VirtualMachineScaleSetVMsApproveRollingUpgradeHeaders;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsAttachDetachDataDisksOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the attachDetachDataDisks operation. */\nexport type VirtualMachineScaleSetVMsAttachDetachDataDisksResponse = StorageProfile;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsDeallocateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsGetInstanceViewOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type VirtualMachineScaleSetVMsGetInstanceViewResponse = VirtualMachineScaleSetVMInstanceView;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsPerformMaintenanceOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsPowerOffOptionalParams\n extends coreClient.OperationOptions {\n /** The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified */\n skipShutdown?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRedeployOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsReimageOptionalParams\n extends coreClient.OperationOptions {\n /** Parameters for the Reimaging Virtual machine in ScaleSet. */\n vmScaleSetVMReimageInput?: VirtualMachineScaleSetVMReimageParameters;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsReimageAllOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRestartOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRetrieveBootDiagnosticsDataOptionalParams\n extends coreClient.OperationOptions {\n /** Expiration duration in minutes for the SAS URIs with a value between 1 to 1440 minutes. **Note:** If not specified, SAS URIs will be generated with a default expiration duration of 120 minutes. */\n sasUriExpirationTimeInMinutes?: number;\n}\n\n/** Contains response data for the retrieveBootDiagnosticsData operation. */\nexport type VirtualMachineScaleSetVMsRetrieveBootDiagnosticsDataResponse =\n RetrieveBootDiagnosticsDataResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRunCommandOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the runCommand operation. */\nexport type VirtualMachineScaleSetVMsRunCommandResponse = RunCommandResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsSimulateEvictionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsStartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetVMsListNextResponse = VirtualMachineScaleSetVMListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsListOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetVMExtensionsListResponse =\n VirtualMachineScaleSetVMExtensionsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsGetOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetVMExtensionsGetResponse = VirtualMachineScaleSetVMExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetVMExtensionsCreateOrUpdateResponse =\n VirtualMachineScaleSetVMExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetVMExtensionsUpdateResponse =\n VirtualMachineScaleSetVMExtensionsUpdateHeaders & VirtualMachineScaleSetVMExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsListOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetVMRunCommandsListResponse = VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsGetOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetVMRunCommandsGetResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetVMRunCommandsCreateOrUpdateResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetVMRunCommandsUpdateResponse =\n VirtualMachineScaleSetVMRunCommandsUpdateHeaders & VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetVMRunCommandsListNextResponse =\n VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineExtensionsListResponse = VirtualMachineExtensionsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineExtensionsGetResponse = VirtualMachineExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineExtensionsCreateOrUpdateResponse = VirtualMachineExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineExtensionsUpdateResponse = VirtualMachineExtensionsUpdateHeaders &\n VirtualMachineExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskAccessesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type DiskAccessesListResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DiskAccessesListByResourceGroupResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DiskAccessesGetResponse = DiskAccess;\n\n/** Optional parameters. */\nexport interface DiskAccessesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DiskAccessesCreateOrUpdateResponse = DiskAccess;\n\n/** Optional parameters. */\nexport interface DiskAccessesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DiskAccessesUpdateResponse = DiskAccess;\n\n/** Optional parameters. */\nexport interface DiskAccessesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskAccessesListPrivateEndpointConnectionsOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPrivateEndpointConnections operation. */\nexport type DiskAccessesListPrivateEndpointConnectionsResponse =\n PrivateEndpointConnectionListResult;\n\n/** Optional parameters. */\nexport interface DiskAccessesGetAPrivateEndpointConnectionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getAPrivateEndpointConnection operation. */\nexport type DiskAccessesGetAPrivateEndpointConnectionResponse = PrivateEndpointConnection;\n\n/** Optional parameters. */\nexport interface DiskAccessesUpdateAPrivateEndpointConnectionOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the updateAPrivateEndpointConnection operation. */\nexport type DiskAccessesUpdateAPrivateEndpointConnectionResponse = PrivateEndpointConnection;\n\n/** Optional parameters. */\nexport interface DiskAccessesDeleteAPrivateEndpointConnectionOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskAccessesGetPrivateLinkResourcesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getPrivateLinkResources operation. */\nexport type DiskAccessesGetPrivateLinkResourcesResponse = PrivateLinkResourceListResult;\n\n/** Optional parameters. */\nexport interface DiskAccessesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type DiskAccessesListNextResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DiskAccessesListByResourceGroupNextResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesListPrivateEndpointConnectionsNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPrivateEndpointConnectionsNext operation. */\nexport type DiskAccessesListPrivateEndpointConnectionsNextResponse =\n PrivateEndpointConnectionListResult;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type DiskEncryptionSetsListResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DiskEncryptionSetsListByResourceGroupResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DiskEncryptionSetsGetResponse = DiskEncryptionSet;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DiskEncryptionSetsCreateOrUpdateResponse = DiskEncryptionSet;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DiskEncryptionSetsUpdateResponse = DiskEncryptionSet;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListAssociatedResourcesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAssociatedResources operation. */\nexport type DiskEncryptionSetsListAssociatedResourcesResponse = ResourceUriList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type DiskEncryptionSetsListNextResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DiskEncryptionSetsListByResourceGroupNextResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListAssociatedResourcesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAssociatedResourcesNext operation. */\nexport type DiskEncryptionSetsListAssociatedResourcesNextResponse = ResourceUriList;\n\n/** Optional parameters. */\nexport interface DisksListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type DisksListResponse = DiskList;\n\n/** Optional parameters. */\nexport interface DisksListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DisksListByResourceGroupResponse = DiskList;\n\n/** Optional parameters. */\nexport interface DisksGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DisksGetResponse = Disk;\n\n/** Optional parameters. */\nexport interface DisksCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DisksCreateOrUpdateResponse = Disk;\n\n/** Optional parameters. */\nexport interface DisksUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DisksUpdateResponse = Disk;\n\n/** Optional parameters. */\nexport interface DisksDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DisksGrantAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the grantAccess operation. */\nexport type DisksGrantAccessResponse = AccessUri;\n\n/** Optional parameters. */\nexport interface DisksRevokeAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DisksListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type DisksListNextResponse = DiskList;\n\n/** Optional parameters. */\nexport interface DisksListByResourceGroupNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DisksListByResourceGroupNextResponse = DiskList;\n\n/** Optional parameters. */\nexport interface SnapshotsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type SnapshotsListResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface SnapshotsListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type SnapshotsListByResourceGroupResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface SnapshotsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SnapshotsGetResponse = Snapshot;\n\n/** Optional parameters. */\nexport interface SnapshotsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type SnapshotsCreateOrUpdateResponse = Snapshot;\n\n/** Optional parameters. */\nexport interface SnapshotsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type SnapshotsUpdateResponse = Snapshot;\n\n/** Optional parameters. */\nexport interface SnapshotsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface SnapshotsGrantAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the grantAccess operation. */\nexport type SnapshotsGrantAccessResponse = AccessUri;\n\n/** Optional parameters. */\nexport interface SnapshotsRevokeAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface SnapshotsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SnapshotsListNextResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface SnapshotsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type SnapshotsListByResourceGroupNextResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface DiskRestorePointListByRestorePointOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByRestorePoint operation. */\nexport type DiskRestorePointListByRestorePointResponse = DiskRestorePointList;\n\n/** Optional parameters. */\nexport interface DiskRestorePointGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DiskRestorePointGetResponse = DiskRestorePoint;\n\n/** Optional parameters. */\nexport interface DiskRestorePointGrantAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the grantAccess operation. */\nexport type DiskRestorePointGrantAccessResponse = AccessUri;\n\n/** Optional parameters. */\nexport interface DiskRestorePointRevokeAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskRestorePointListByRestorePointNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByRestorePointNext operation. */\nexport type DiskRestorePointListByRestorePointNextResponse = DiskRestorePointList;\n\n/** Optional parameters. */\nexport interface ResourceSkusListOptionalParams extends coreClient.OperationOptions {\n /** The filter to apply on the operation. Only **location** filter is supported currently. */\n filter?: string;\n /** To Include Extended Locations information or not in the response. */\n includeExtendedLocations?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type ResourceSkusListResponse = ResourceSkusResult;\n\n/** Optional parameters. */\nexport interface ResourceSkusListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type ResourceSkusListNextResponse = ResourceSkusResult;\n\n/** Optional parameters. */\nexport interface GalleriesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type GalleriesListResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface GalleriesListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type GalleriesListByResourceGroupResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface GalleriesGetOptionalParams extends coreClient.OperationOptions {\n /** The select expression to apply on the operation. */\n select?: SelectPermissions;\n /** The expand query option to apply on the operation. */\n expand?: GalleryExpandParams;\n}\n\n/** Contains response data for the get operation. */\nexport type GalleriesGetResponse = Gallery;\n\n/** Optional parameters. */\nexport interface GalleriesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleriesCreateOrUpdateResponse = Gallery;\n\n/** Optional parameters. */\nexport interface GalleriesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleriesUpdateResponse = GalleriesUpdateHeaders & Gallery;\n\n/** Optional parameters. */\nexport interface GalleriesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleriesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type GalleriesListNextResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface GalleriesListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type GalleriesListByResourceGroupNextResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface CommunityGalleriesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CommunityGalleriesGetResponse = CommunityGallery;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImagesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CommunityGalleryImagesListResponse = CommunityGalleryImageList;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CommunityGalleryImagesGetResponse = CommunityGalleryImage;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImagesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CommunityGalleryImagesListNextResponse = CommunityGalleryImageList;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImageVersionsListOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CommunityGalleryImageVersionsListResponse = CommunityGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImageVersionsGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CommunityGalleryImageVersionsGetResponse = CommunityGalleryImageVersion;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImageVersionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CommunityGalleryImageVersionsListNextResponse = CommunityGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface SharedGalleriesListOptionalParams extends coreClient.OperationOptions {\n /** The query parameter to decide what shared galleries to fetch when doing listing operations. */\n sharedTo?: SharedToValues;\n}\n\n/** Contains response data for the list operation. */\nexport type SharedGalleriesListResponse = SharedGalleryList;\n\n/** Optional parameters. */\nexport interface SharedGalleriesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SharedGalleriesGetResponse = SharedGallery;\n\n/** Optional parameters. */\nexport interface SharedGalleriesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SharedGalleriesListNextResponse = SharedGalleryList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImagesListOptionalParams extends coreClient.OperationOptions {\n /** The query parameter to decide what shared galleries to fetch when doing listing operations. */\n sharedTo?: SharedToValues;\n}\n\n/** Contains response data for the list operation. */\nexport type SharedGalleryImagesListResponse = SharedGalleryImageList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SharedGalleryImagesGetResponse = SharedGalleryImage;\n\n/** Optional parameters. */\nexport interface SharedGalleryImagesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SharedGalleryImagesListNextResponse = SharedGalleryImageList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImageVersionsListOptionalParams extends coreClient.OperationOptions {\n /** The query parameter to decide what shared galleries to fetch when doing listing operations. */\n sharedTo?: SharedToValues;\n}\n\n/** Contains response data for the list operation. */\nexport type SharedGalleryImageVersionsListResponse = SharedGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImageVersionsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SharedGalleryImageVersionsGetResponse = SharedGalleryImageVersion;\n\n/** Optional parameters. */\nexport interface SharedGalleryImageVersionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SharedGalleryImageVersionsListNextResponse = SharedGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsListByGalleryOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryApplicationsListByGalleryResponse = GalleryApplicationList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryApplicationsGetResponse = GalleryApplication;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryApplicationsCreateOrUpdateResponse = GalleryApplication;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryApplicationsUpdateResponse = GalleryApplicationsUpdateHeaders &\n GalleryApplication;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryApplicationsListByGalleryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryApplicationsListByGalleryNextResponse = GalleryApplicationList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsListByGalleryApplicationOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryApplication operation. */\nexport type GalleryApplicationVersionsListByGalleryApplicationResponse =\n GalleryApplicationVersionList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: ReplicationStatusTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type GalleryApplicationVersionsGetResponse = GalleryApplicationVersion;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryApplicationVersionsCreateOrUpdateResponse = GalleryApplicationVersion;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryApplicationVersionsUpdateResponse = GalleryApplicationVersionsUpdateHeaders &\n GalleryApplicationVersion;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsListByGalleryApplicationNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryApplicationNext operation. */\nexport type GalleryApplicationVersionsListByGalleryApplicationNextResponse =\n GalleryApplicationVersionList;\n\n/** Optional parameters. */\nexport interface GalleryImagesListByGalleryOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryImagesListByGalleryResponse = GalleryImageList;\n\n/** Optional parameters. */\nexport interface GalleryImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryImagesGetResponse = GalleryImage;\n\n/** Optional parameters. */\nexport interface GalleryImagesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryImagesCreateOrUpdateResponse = GalleryImage;\n\n/** Optional parameters. */\nexport interface GalleryImagesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryImagesUpdateResponse = GalleryImagesUpdateHeaders & GalleryImage;\n\n/** Optional parameters. */\nexport interface GalleryImagesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryImagesListByGalleryNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryImagesListByGalleryNextResponse = GalleryImageList;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsListByGalleryImageOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryImage operation. */\nexport type GalleryImageVersionsListByGalleryImageResponse = GalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: ReplicationStatusTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type GalleryImageVersionsGetResponse = GalleryImageVersion;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryImageVersionsCreateOrUpdateResponse = GalleryImageVersion;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryImageVersionsUpdateResponse = GalleryImageVersionsUpdateHeaders &\n GalleryImageVersion;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsListByGalleryImageNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryImageNext operation. */\nexport type GalleryImageVersionsListByGalleryImageNextResponse = GalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesListByGalleryOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryInVMAccessControlProfilesListByGalleryResponse =\n GalleryInVMAccessControlProfileList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryInVMAccessControlProfilesGetResponse = GalleryInVMAccessControlProfile;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryInVMAccessControlProfilesCreateOrUpdateResponse =\n GalleryInVMAccessControlProfile;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryInVMAccessControlProfilesUpdateResponse =\n GalleryInVMAccessControlProfilesUpdateHeaders & GalleryInVMAccessControlProfile;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the delete operation. */\nexport type GalleryInVMAccessControlProfilesDeleteResponse =\n GalleryInVMAccessControlProfilesDeleteHeaders;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesListByGalleryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryInVMAccessControlProfilesListByGalleryNextResponse =\n GalleryInVMAccessControlProfileList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryInVMAccessControlProfile operation. */\nexport type GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileResponse =\n GalleryInVMAccessControlProfileVersionList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryInVMAccessControlProfileVersionsGetResponse =\n GalleryInVMAccessControlProfileVersion;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryInVMAccessControlProfileVersionsCreateOrUpdateResponse =\n GalleryInVMAccessControlProfileVersion;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryInVMAccessControlProfileVersionsUpdateResponse =\n GalleryInVMAccessControlProfileVersionsUpdateHeaders & GalleryInVMAccessControlProfileVersion;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the delete operation. */\nexport type GalleryInVMAccessControlProfileVersionsDeleteResponse =\n GalleryInVMAccessControlProfileVersionsDeleteHeaders;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryInVMAccessControlProfileNext operation. */\nexport type GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileNextResponse =\n GalleryInVMAccessControlProfileVersionList;\n\n/** Optional parameters. */\nexport interface GallerySharingProfileUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GallerySharingProfileUpdateResponse = SharingUpdate;\n\n/** Optional parameters. */\nexport interface SoftDeletedResourceListByArtifactNameOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByArtifactName operation. */\nexport type SoftDeletedResourceListByArtifactNameResponse = GallerySoftDeletedResourceList;\n\n/** Optional parameters. */\nexport interface SoftDeletedResourceListByArtifactNameNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByArtifactNameNext operation. */\nexport type SoftDeletedResourceListByArtifactNameNextResponse = GallerySoftDeletedResourceList;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. 'UserData' is not supported for cloud services. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type CloudServiceRoleInstancesGetResponse = RoleInstance;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesGetInstanceViewOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type CloudServiceRoleInstancesGetInstanceViewResponse = RoleInstanceView;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. 'UserData' is not supported for cloud services. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the list operation. */\nexport type CloudServiceRoleInstancesListResponse = RoleInstanceListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesRestartOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesReimageOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesRebuildOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesGetRemoteDesktopFileOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getRemoteDesktopFile operation. */\nexport type CloudServiceRoleInstancesGetRemoteDesktopFileResponse = {\n /**\n * BROWSER ONLY\n *\n * The response body as a browser Blob.\n * Always `undefined` in node.js.\n */\n blobBody?: Promise<Blob>;\n /**\n * NODEJS ONLY\n *\n * The response body as a node.js Readable stream.\n * Always `undefined` in the browser.\n */\n readableStreamBody?: NodeJS.ReadableStream;\n};\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CloudServiceRoleInstancesListNextResponse = RoleInstanceListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceRolesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CloudServiceRolesGetResponse = CloudServiceRole;\n\n/** Optional parameters. */\nexport interface CloudServiceRolesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CloudServiceRolesListResponse = CloudServiceRoleListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceRolesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CloudServiceRolesListNextResponse = CloudServiceRoleListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** The cloud service object. */\n parameters?: CloudService;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type CloudServicesCreateOrUpdateResponse = CloudService;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateOptionalParams extends coreClient.OperationOptions {\n /** The cloud service object. */\n parameters?: CloudServiceUpdate;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type CloudServicesUpdateResponse = CloudService;\n\n/** Optional parameters. */\nexport interface CloudServicesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CloudServicesGetResponse = CloudService;\n\n/** Optional parameters. */\nexport interface CloudServicesGetInstanceViewOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type CloudServicesGetInstanceViewResponse = CloudServiceInstanceView;\n\n/** Optional parameters. */\nexport interface CloudServicesListAllOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAll operation. */\nexport type CloudServicesListAllResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CloudServicesListResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesStartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesPowerOffOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesRestartOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesReimageOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesRebuildOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesDeleteInstancesOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesListAllNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type CloudServicesListAllNextResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CloudServicesListNextResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainWalkUpdateDomainOptionalParams\n extends coreClient.OperationOptions {\n /** The update domain object. */\n parameters?: UpdateDomain;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainGetUpdateDomainOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getUpdateDomain operation. */\nexport type CloudServicesUpdateDomainGetUpdateDomainResponse = UpdateDomain;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainListUpdateDomainsOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listUpdateDomains operation. */\nexport type CloudServicesUpdateDomainListUpdateDomainsResponse = UpdateDomainListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainListUpdateDomainsNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listUpdateDomainsNext operation. */\nexport type CloudServicesUpdateDomainListUpdateDomainsNextResponse = UpdateDomainListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsGetOSVersionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSVersion operation. */\nexport type CloudServiceOperatingSystemsGetOSVersionResponse = OSVersion;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSVersionsOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSVersions operation. */\nexport type CloudServiceOperatingSystemsListOSVersionsResponse = OSVersionListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsGetOSFamilyOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSFamily operation. */\nexport type CloudServiceOperatingSystemsGetOSFamilyResponse = OSFamily;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSFamiliesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSFamilies operation. */\nexport type CloudServiceOperatingSystemsListOSFamiliesResponse = OSFamilyListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSVersionsNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSVersionsNext operation. */\nexport type CloudServiceOperatingSystemsListOSVersionsNextResponse = OSVersionListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSFamiliesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSFamiliesNext operation. */\nexport type CloudServiceOperatingSystemsListOSFamiliesNextResponse = OSFamilyListResult;\n\n/** Optional parameters. */\nexport interface ComputeManagementClientOptionalParams extends coreClient.ServiceClientOptions {\n /** server parameter */\n $host?: string;\n /** Overrides client endpoint. */\n endpoint?: string;\n}\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/models/index.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;;;AA0hRlC,+DAA+D;AAC/D,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,WAAW;IACX,4BAAa,CAAA;IACb,aAAa;IACb,gCAAiB,CAAA;IACjB,iBAAiB;IACjB,yCAA0B,CAAA;AAC5B,CAAC,EAPW,WAAW,2BAAX,WAAW,QAOtB;AAaD,mEAAmE;AACnE,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,eAAe;IACf,wCAAqB,CAAA;AACvB,CAAC,EAHW,eAAe,+BAAf,eAAe,QAG1B;AAWD,sEAAsE;AACtE,IAAY,kBASX;AATD,WAAY,kBAAkB;IAC5B,WAAW;IACX,mCAAa,CAAA;IACb,kBAAkB;IAClB,iDAA2B,CAAA;IAC3B,sBAAsB;IACtB,yDAAmC,CAAA;IACnC,UAAU;IACV,iCAAW,CAAA;AACb,CAAC,EATW,kBAAkB,kCAAlB,kBAAkB,QAS7B;AAcD,mGAAmG;AACnG,IAAY,+CAKX;AALD,WAAY,+CAA+C;IACzD,mCAAmC;IACnC,kHAA+D,CAAA;IAC/D,yBAAyB;IACzB,8FAA2C,CAAA;AAC7C,CAAC,EALW,+CAA+C,+DAA/C,+CAA+C,QAK1D;AAYD,yGAAyG;AACzG,IAAY,qDAOX;AAPD,WAAY,qDAAqD;IAC/D,4BAA4B;IAC5B,wGAA+C,CAAA;IAC/C,6BAA6B;IAC7B,0GAAiD,CAAA;IACjD,UAAU;IACV,oEAAW,CAAA;AACb,CAAC,EAPW,qDAAqD,qEAArD,qDAAqD,QAOhE;AAaD,wEAAwE;AACxE,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,yGAAyG;IACzG,6CAAqB,CAAA;IACrB,+GAA+G;IAC/G,uCAAe,CAAA;AACjB,CAAC,EALW,oBAAoB,oCAApB,oBAAoB,QAK/B;AAYD,4EAA4E;AAC5E,IAAY,wBAeX;AAfD,WAAY,wBAAwB;IAClC,kBAAkB;IAClB,wDAA4B,CAAA;IAC5B,iBAAiB;IACjB,sDAA0B,CAAA;IAC1B,qBAAqB;IACrB,8DAAkC,CAAA;IAClC,kBAAkB;IAClB,wDAA4B,CAAA;IAC5B,iBAAiB;IACjB,sDAA0B,CAAA;IAC1B,qBAAqB;IACrB,8DAAkC,CAAA;IAClC,mBAAmB;IACnB,0DAA8B,CAAA;AAChC,CAAC,EAfW,wBAAwB,wCAAxB,wBAAwB,QAenC;AAiBD,8EAA8E;AAC9E,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,SAAS;IACT,uCAAS,CAAA;IACT,SAAS;IACT,uCAAS,CAAA;AACX,CAAC,EALW,0BAA0B,0CAA1B,0BAA0B,QAKrC;AAYD,8EAA8E;AAC9E,IAAY,0BAGX;AAHD,WAAY,0BAA0B;IACpC,eAAe;IACf,mDAAqB,CAAA;AACvB,CAAC,EAHW,0BAA0B,0CAA1B,0BAA0B,QAGrC;AAWD,oEAAoE;AACpE,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,WAAW;IACX,iCAAa,CAAA;IACb,gBAAgB;IAChB,2CAAuB,CAAA;AACzB,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B;AAYD,0EAA0E;AAC1E,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,UAAU;IACV,qCAAW,CAAA;IACX,YAAY;IACZ,yCAAe,CAAA;AACjB,CAAC,EALW,sBAAsB,sCAAtB,sBAAsB,QAKjC;AAYD,mEAAmE;AACnE,IAAY,eAOX;AAPD,WAAY,eAAe;IACzB,aAAa;IACb,oCAAiB,CAAA;IACjB,8BAA8B;IAC9B,sEAAmD,CAAA;IACnD,iBAAiB;IACjB,4CAAyB,CAAA;AAC3B,CAAC,EAPW,eAAe,+BAAf,eAAe,QAO1B;AAaD,wEAAwE;AACxE,IAAY,oBAOX;AAPD,WAAY,oBAAoB;IAC9B,WAAW;IACX,qCAAa,CAAA;IACb,YAAY;IACZ,uCAAe,CAAA;IACf,WAAW;IACX,qCAAa,CAAA;AACf,CAAC,EAPW,oBAAoB,oCAApB,oBAAoB,QAO/B;AAaD,qEAAqE;AACrE,IAAY,iBAOX;AAPD,WAAY,iBAAiB;IAC3B,cAAc;IACd,wCAAmB,CAAA;IACnB,cAAc;IACd,wCAAmB,CAAA;IACnB,cAAc;IACd,wCAAmB,CAAA;AACrB,CAAC,EAPW,iBAAiB,iCAAjB,iBAAiB,QAO5B;AAaD,gFAAgF;AAChF,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,aAAa;IACb,iDAAiB,CAAA;IACjB,oBAAoB;IACpB,+DAA+B,CAAA;IAC/B,0BAA0B;IAC1B,2EAA2C,CAAA;AAC7C,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAaD,mFAAmF;AACnF,IAAY,+BAKX;AALD,WAAY,+BAA+B;IACzC,mBAAmB;IACnB,gEAA6B,CAAA;IAC7B,0BAA0B;IAC1B,8EAA2C,CAAA;AAC7C,CAAC,EALW,+BAA+B,+CAA/B,+BAA+B,QAK1C;AAYD,4GAA4G;AAC5G,IAAY,wDASX;AATD,WAAY,wDAAwD;IAClE,cAAc;IACd,+EAAmB,CAAA;IACnB,iBAAiB;IACjB,qFAAyB,CAAA;IACzB,YAAY;IACZ,2EAAe,CAAA;IACf,aAAa;IACb,6EAAiB,CAAA;AACnB,CAAC,EATW,wDAAwD,wEAAxD,wDAAwD,QASnE;AAcD,8EAA8E;AAC9E,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,mBAAmB;IACnB,2DAA6B,CAAA;IAC7B,0BAA0B;IAC1B,yEAA2C,CAAA;AAC7C,CAAC,EALW,0BAA0B,0CAA1B,0BAA0B,QAKrC;AAYD,iFAAiF;AACjF,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,mBAAmB;IACnB,8DAA6B,CAAA;IAC7B,0BAA0B;IAC1B,4EAA2C,CAAA;AAC7C,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC;AAYD,0GAA0G;AAC1G,IAAY,sDASX;AATD,WAAY,sDAAsD;IAChE,cAAc;IACd,6EAAmB,CAAA;IACnB,iBAAiB;IACjB,mFAAyB,CAAA;IACzB,YAAY;IACZ,yEAAe,CAAA;IACf,aAAa;IACb,2EAAiB,CAAA;AACnB,CAAC,EATW,sDAAsD,sEAAtD,sDAAsD,QASjE;AAcD,8EAA8E;AAC9E,IAAY,0BAWX;AAXD,WAAY,0BAA0B;IACpC,gBAAgB;IAChB,qDAAuB,CAAA;IACvB,YAAY;IACZ,6CAAe,CAAA;IACf,aAAa;IACb,+CAAiB,CAAA;IACjB,WAAW;IACX,2CAAa,CAAA;IACb,cAAc;IACd,iDAAmB,CAAA;AACrB,CAAC,EAXW,0BAA0B,0CAA1B,0BAA0B,QAWrC;AAeD,wEAAwE;AACxE,IAAY,oBAGX;AAHD,WAAY,oBAAoB;IAC9B,YAAY;IACZ,uCAAe,CAAA;AACjB,CAAC,EAHW,oBAAoB,oCAApB,oBAAoB,QAG/B;AAWD,0EAA0E;AAC1E,IAAY,sBAOX;AAPD,WAAY,sBAAsB;IAChC,gBAAgB;IAChB,iDAAuB,CAAA;IACvB,mBAAmB;IACnB,uDAA6B,CAAA;IAC7B,eAAe;IACf,+CAAqB,CAAA;AACvB,CAAC,EAPW,sBAAsB,sCAAtB,sBAAsB,QAOjC;AAaD,gFAAgF;AAChF,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,uBAAuB;IACvB,qEAAqC,CAAA;IACrC,2BAA2B;IAC3B,6EAA6C,CAAA;IAC7C,sBAAsB;IACtB,mEAAmC,CAAA;AACrC,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAaD,8EAA8E;AAC9E,IAAY,0BAKX;AALD,WAAY,0BAA0B;IACpC,aAAa;IACb,+CAAiB,CAAA;IACjB,aAAa;IACb,+CAAiB,CAAA;AACnB,CAAC,EALW,0BAA0B,0CAA1B,0BAA0B,QAKrC;AAYD,4EAA4E;AAC5E,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC,WAAW;IACX,yCAAa,CAAA;IACb,WAAW;IACX,yCAAa,CAAA;AACf,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAYD,kFAAkF;AAClF,IAAY,8BASX;AATD,WAAY,8BAA8B;IACxC,kBAAkB;IAClB,6DAA2B,CAAA;IAC3B,wBAAwB;IACxB,yEAAuC,CAAA;IACvC,yBAAyB;IACzB,2EAAyC,CAAA;IACzC,cAAc;IACd,qDAAmB,CAAA;AACrB,CAAC,EATW,8BAA8B,8CAA9B,8BAA8B,QASzC;AAcD,kEAAkE;AAClE,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,WAAW;IACX,+BAAa,CAAA;IACb,WAAW;IACX,+BAAa,CAAA;AACf,CAAC,EALW,cAAc,8BAAd,cAAc,QAKzB;AAYD,sEAAsE;AACtE,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC5B,aAAa;IACb,uCAAiB,CAAA;IACjB,aAAa;IACb,uCAAiB,CAAA;AACnB,CAAC,EALW,kBAAkB,kCAAlB,kBAAkB,QAK7B;AAYD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,YAAY;IACZ,8CAAe,CAAA;IACf,eAAe;IACf,oDAAqB,CAAA;AACvB,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,eAAe;IACf,oDAAqB,CAAA;IACrB,aAAa;IACb,gDAAiB,CAAA;AACnB,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,sFAAsF;AACtF,IAAY,kCAOX;AAPD,WAAY,kCAAkC;IAC5C,WAAW;IACX,mDAAa,CAAA;IACb,6BAA6B;IAC7B,uFAAiD,CAAA;IACjD,eAAe;IACf,2DAAqB,CAAA;AACvB,CAAC,EAPW,kCAAkC,kDAAlC,kCAAkC,QAO7C;AAaD,qFAAqF;AACrF,IAAY,iCAWX;AAXD,WAAY,iCAAiC;IAC3C,WAAW;IACX,kDAAa,CAAA;IACb,SAAS;IACT,8CAAS,CAAA;IACT,SAAS;IACT,8CAAS,CAAA;IACT,SAAS;IACT,8CAAS,CAAA;IACT,SAAS;IACT,8CAAS,CAAA;AACX,CAAC,EAXW,iCAAiC,iDAAjC,iCAAiC,QAW5C;AAeD,0EAA0E;AAC1E,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,4BAA4B;IAC5B,8DAAoC,CAAA;IACpC,+BAA+B;IAC/B,iEAAuC,CAAA;AACzC,CAAC,EALW,sBAAsB,sCAAtB,sBAAsB,QAKjC;AAYD,sEAAsE;AACtE,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC5B,oBAAoB;IACpB,qDAA+B,CAAA;IAC/B,qBAAqB;IACrB,uDAAiC,CAAA;AACnC,CAAC,EALW,kBAAkB,kCAAlB,kBAAkB,QAK7B;AAYD,6DAA6D;AAC7D,IAAY,SAKX;AALD,WAAY,SAAS;IACnB,YAAY;IACZ,4BAAe,CAAA;IACf,cAAc;IACd,gCAAmB,CAAA;AACrB,CAAC,EALW,SAAS,yBAAT,SAAS,QAKpB;AAYD,8DAA8D;AAC9D,IAAY,UAOX;AAPD,WAAY,UAAU;IACpB,YAAY;IACZ,6BAAe,CAAA;IACf,cAAc;IACd,iCAAmB,CAAA;IACnB,eAAe;IACf,mCAAqB,CAAA;AACvB,CAAC,EAPW,UAAU,0BAAV,UAAU,QAOrB;AAaD,oFAAoF;AACpF,IAAY,gCAOX;AAPD,WAAY,gCAAgC;IAC1C,cAAc;IACd,uDAAmB,CAAA;IACnB,UAAU;IACV,+CAAW,CAAA;IACX,WAAW;IACX,iDAAa,CAAA;AACf,CAAC,EAPW,gCAAgC,gDAAhC,gCAAgC,QAO3C;AAaD,0FAA0F;AAC1F,IAAY,sCAKX;AALD,WAAY,sCAAsC;IAChD,iBAAiB;IACjB,mEAAyB,CAAA;IACzB,aAAa;IACb,2DAAiB,CAAA;AACnB,CAAC,EALW,sCAAsC,sDAAtC,sCAAsC,QAKjD;AAYD,2FAA2F;AAC3F,IAAY,uCAOX;AAPD,WAAY,uCAAuC;IACjD,cAAc;IACd,8DAAmB,CAAA;IACnB,eAAe;IACf,gEAAqB,CAAA;IACrB,eAAe;IACf,gEAAqB,CAAA;AACvB,CAAC,EAPW,uCAAuC,uDAAvC,uCAAuC,QAOlD;AAaD,0EAA0E;AAC1E,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,cAAc;IACd,6CAAmB,CAAA;IACnB,eAAe;IACf,+CAAqB,CAAA;AACvB,CAAC,EALW,sBAAsB,sCAAtB,sBAAsB,QAKjC;AAYD,0EAA0E;AAC1E,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,eAAe;IACf,+CAAqB,CAAA;AACvB,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAWD,0EAA0E;AAC1E,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,yBAAyB;IACzB,mEAAyC,CAAA;AAC3C,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAWD,0FAA0F;AAC1F,IAAY,sCAKX;AALD,WAAY,sCAAsC;IAChD,cAAc;IACd,6DAAmB,CAAA;IACnB,gBAAgB;IAChB,iEAAuB,CAAA;AACzB,CAAC,EALW,sCAAsC,sDAAtC,sCAAsC,QAKjD;AAYD,2EAA2E;AAC3E,IAAY,uBAOX;AAPD,WAAY,uBAAuB;IACjC,kBAAkB;IAClB,sDAA2B,CAAA;IAC3B,wBAAwB;IACxB,kEAAuC,CAAA;IACvC,kBAAkB;IAClB,sDAA2B,CAAA;AAC7B,CAAC,EAPW,uBAAuB,uCAAvB,uBAAuB,QAOlC;AAaD,uFAAuF;AACvF,IAAY,mCAKX;AALD,WAAY,mCAAmC;IAC7C,2CAA2C;IAC3C,oDAAa,CAAA;IACb,8CAA8C;IAC9C,sDAAe,CAAA;AACjB,CAAC,EALW,mCAAmC,mDAAnC,mCAAmC,QAK9C;AAYD,gFAAgF;AAChF,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,UAAU;IACV,2CAAW,CAAA;IACX,+DAA+D;IAC/D,6CAAa,CAAA;AACf,CAAC,EALW,4BAA4B,4CAA5B,4BAA4B,QAKvC;AAYD,gFAAgF;AAChF,IAAY,4BA6UX;AA7UD,WAAY,4BAA4B;IACtC,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,cAAc;IACd,oDAAoB,CAAA;IACpB,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,sBAAsB;IACtB,sEAAsC,CAAA;IACtC,uBAAuB;IACvB,wEAAwC,CAAA;IACxC,uBAAuB;IACvB,wEAAwC,CAAA;IACxC,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,oBAAoB;IACpB,iEAAiC,CAAA;IACjC,mBAAmB;IACnB,+DAA+B,CAAA;IAC/B,iBAAiB;IACjB,0DAA0B,CAAA;IAC1B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,qBAAqB;IACrB,kEAAkC,CAAA;IAClC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,qBAAqB;IACrB,mEAAmC,CAAA;IACnC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,sBAAsB;IACtB,qEAAqC,CAAA;IACrC,uBAAuB;IACvB,uEAAuC,CAAA;IACvC,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,oBAAoB;IACpB,gEAAgC,CAAA;IAChC,qBAAqB;IACrB,kEAAkC,CAAA;IAClC,kBAAkB;IAClB,4DAA4B,CAAA;IAC5B,mBAAmB;IACnB,8DAA8B,CAAA;IAC9B,mBAAmB;IACnB,8DAA8B,CAAA;AAChC,CAAC,EA7UW,4BAA4B,4CAA5B,4BAA4B,QA6UvC;AAgLD,8EAA8E;AAC9E,IAAY,0BAGX;AAHD,WAAY,0BAA0B;IACpC,kBAAkB;IAClB,yDAA2B,CAAA;AAC7B,CAAC,EAHW,0BAA0B,0CAA1B,0BAA0B,QAGrC;AAWD,mEAAmE;AACnE,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,WAAW;IACX,gCAAa,CAAA;IACb,WAAW;IACX,gCAAa,CAAA;AACf,CAAC,EALW,eAAe,+BAAf,eAAe,QAK1B;AAYD,iFAAiF;AACjF,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,cAAc;IACd,oDAAmB,CAAA;IACnB,aAAa;IACb,kDAAiB,CAAA;AACnB,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC;AAYD,6EAA6E;AAC7E,IAAY,yBAKX;AALD,WAAY,yBAAyB;IACnC,SAAS;IACT,sCAAS,CAAA;IACT,SAAS;IACT,sCAAS,CAAA;AACX,CAAC,EALW,yBAAyB,yCAAzB,yBAAyB,QAKpC;AAYD,6EAA6E;AAC7E,IAAY,yBAWX;AAXD,WAAY,yBAAyB;IACnC,cAAc;IACd,gDAAmB,CAAA;IACnB,iBAAiB;IACjB,sDAAyB,CAAA;IACzB,aAAa;IACb,8CAAiB,CAAA;IACjB,gBAAgB;IAChB,oDAAuB,CAAA;IACvB,4BAA4B;IAC5B,4EAA+C,CAAA;AACjD,CAAC,EAXW,yBAAyB,yCAAzB,yBAAyB,QAWpC;AAeD,oFAAoF;AACpF,IAAY,gCAKX;AALD,WAAY,gCAAgC;IAC1C,eAAe;IACf,yDAAqB,CAAA;IACrB,YAAY;IACZ,mDAAe,CAAA;AACjB,CAAC,EALW,gCAAgC,gDAAhC,gCAAgC,QAK3C;AAYD,4EAA4E;AAC5E,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC,cAAc;IACd,+CAAmB,CAAA;IACnB,YAAY;IACZ,2CAAe,CAAA;AACjB,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAYD,mFAAmF;AACnF,IAAY,+BAOX;AAPD,WAAY,+BAA+B;IACzC,yEAAyE;IACzE,sGAAmE,CAAA;IACnE,uHAAuH;IACvH,sGAAmE,CAAA;IACnE,sJAAsJ;IACtJ,8HAA2F,CAAA;AAC7F,CAAC,EAPW,+BAA+B,+CAA/B,+BAA+B,QAO1C;AAaD,6EAA6E;AAC7E,IAAY,yBAOX;AAPD,WAAY,yBAAyB;IACnC,sBAAsB;IACtB,gEAAmC,CAAA;IACnC,2BAA2B;IAC3B,0EAA6C,CAAA;IAC7C,4BAA4B;IAC5B,4EAA+C,CAAA;AACjD,CAAC,EAPW,yBAAyB,yCAAzB,yBAAyB,QAOpC;AAaD,4EAA4E;AAC5E,IAAY,wBAWX;AAXD,WAAY,wBAAwB;IAClC,qBAAqB;IACrB,+CAAmB,CAAA;IACnB,4EAA4E;IAC5E,+CAAmB,CAAA;IACnB,+FAA+F;IAC/F,mDAAuB,CAAA;IACvB,6GAA6G;IAC7G,2DAA+B,CAAA;IAC/B,iGAAiG;IACjG,qFAAyD,CAAA;AAC3D,CAAC,EAXW,wBAAwB,wCAAxB,wBAAwB,QAWnC;AAeD,8EAA8E;AAC9E,IAAY,0BAGX;AAHD,WAAY,0BAA0B;IACpC,mBAAmB;IACnB,2DAA6B,CAAA;AAC/B,CAAC,EAHW,0BAA0B,0CAA1B,0BAA0B,QAGrC;AAWD,kGAAkG;AAClG,IAAY,8CAGX;AAHD,WAAY,8CAA8C;IACxD,mBAAmB;IACnB,+EAA6B,CAAA;AAC/B,CAAC,EAHW,8CAA8C,8DAA9C,8CAA8C,QAGzD;AAWD,6FAA6F;AAC7F,IAAY,yCAGX;AAHD,WAAY,yCAAyC;IACnD,mBAAmB;IACnB,0EAA6B,CAAA;AAC/B,CAAC,EAHW,yCAAyC,yDAAzC,yCAAyC,QAGpD;AAWD,4FAA4F;AAC5F,IAAY,wCAGX;AAHD,WAAY,wCAAwC;IAClD,oBAAoB;IACpB,2EAA+B,CAAA;AACjC,CAAC,EAHW,wCAAwC,wDAAxC,wCAAwC,QAGnD;AAWD,kFAAkF;AAClF,IAAY,8BAGX;AAHD,WAAY,8BAA8B;IACxC,mBAAmB;IACnB,+DAA6B,CAAA;AAC/B,CAAC,EAHW,8BAA8B,8CAA9B,8BAA8B,QAGzC;AAWD,2EAA2E;AAC3E,IAAY,uBAKX;AALD,WAAY,uBAAuB;IACjC,UAAU;IACV,sCAAW,CAAA;IACX,cAAc;IACd,8CAAmB,CAAA;AACrB,CAAC,EALW,uBAAuB,uCAAvB,uBAAuB,QAKlC;AAYD,qFAAqF;AACrF,IAAY,iCAGX;AAHD,WAAY,iCAAiC;IAC3C,eAAe;IACf,0DAAqB,CAAA;AACvB,CAAC,EAHW,iCAAiC,iDAAjC,iCAAiC,QAG5C;AAWD,kFAAkF;AAClF,IAAY,8BAKX;AALD,WAAY,8BAA8B;IACxC,uBAAuB;IACvB,uEAAqC,CAAA;IACrC,sDAAsD;IACtD,uFAAqD,CAAA;AACvD,CAAC,EALW,8BAA8B,8CAA9B,8BAA8B,QAKzC;AAYD,kFAAkF;AAClF,IAAY,8BAOX;AAPD,WAAY,8BAA8B;IACxC,iBAAiB;IACjB,2DAAyB,CAAA;IACzB,cAAc;IACd,qDAAmB,CAAA;IACnB,gBAAgB;IAChB,yDAAuB,CAAA;AACzB,CAAC,EAPW,8BAA8B,8CAA9B,8BAA8B,QAOzC;AAaD,4FAA4F;AAC5F,IAAY,wCAKX;AALD,WAAY,wCAAwC;IAClD,yDAAyD;IACzD,qEAAyB,CAAA;IACzB,wDAAwD;IACxD,mEAAuB,CAAA;AACzB,CAAC,EALW,wCAAwC,wDAAxC,wCAAwC,QAKnD;AAYD,wFAAwF;AACxF,IAAY,oCAKX;AALD,WAAY,oCAAoC;IAC9C,aAAa;IACb,yDAAiB,CAAA;IACjB,cAAc;IACd,2DAAmB,CAAA;AACrB,CAAC,EALW,oCAAoC,oDAApC,oCAAoC,QAK/C;AAYD,yEAAyE;AACzE,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,SAAS;IACT,kCAAS,CAAA;IACT,SAAS;IACT,kCAAS,CAAA;AACX,CAAC,EALW,qBAAqB,qCAArB,qBAAqB,QAKhC;AAYD,kFAAkF;AAClF,IAAY,8BASX;AATD,WAAY,8BAA8B;IACxC,cAAc;IACd,qDAAmB,CAAA;IACnB,eAAe;IACf,uDAAqB,CAAA;IACrB,iBAAiB;IACjB,2DAAyB,CAAA;IACzB,aAAa;IACb,mDAAiB,CAAA;AACnB,CAAC,EATW,8BAA8B,8CAA9B,8BAA8B,QASzC;AAcD,yEAAyE;AACzE,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,iCAAiC;IACjC,4CAAmB,CAAA;IACnB,qCAAqC;IACrC,oDAA2B,CAAA;AAC7B,CAAC,EALW,qBAAqB,qCAArB,qBAAqB,QAKhC;AAYD,uEAAuE;AACvE,IAAY,mBAeX;AAfD,WAAY,mBAAmB;IAC7B,cAAc;IACd,0CAAmB,CAAA;IACnB,cAAc;IACd,0CAAmB,CAAA;IACnB,cAAc;IACd,0CAAmB,CAAA;IACnB,aAAa;IACb,wCAAiB,CAAA;IACjB,gBAAgB;IAChB,8CAAuB,CAAA;IACvB,eAAe;IACf,4CAAqB,CAAA;IACrB,eAAe;IACf,4CAAqB,CAAA;AACvB,CAAC,EAfW,mBAAmB,mCAAnB,mBAAmB,QAe9B;AAiBD,6EAA6E;AAC7E,IAAY,yBAGX;AAHD,WAAY,yBAAyB;IACnC,mBAAmB;IACnB,0DAA6B,CAAA;AAC/B,CAAC,EAHW,yBAAyB,yCAAzB,yBAAyB,QAGpC;AAWD,mFAAmF;AACnF,IAAY,+BASX;AATD,WAAY,+BAA+B;IACzC,cAAc;IACd,sDAAmB,CAAA;IACnB,mBAAmB;IACnB,gEAA6B,CAAA;IAC7B,2BAA2B;IAC3B,gFAA6C,CAAA;IAC7C,uBAAuB;IACvB,wEAAqC,CAAA;AACvC,CAAC,EATW,+BAA+B,+CAA/B,+BAA+B,QAS1C;AAcD,6EAA6E;AAC7E,IAAY,yBAKX;AALD,WAAY,yBAAyB;IACnC,cAAc;IACd,gDAAmB,CAAA;IACnB,gBAAgB;IAChB,oDAAuB,CAAA;AACzB,CAAC,EALW,yBAAyB,yCAAzB,yBAAyB,QAKpC;AAYD,kFAAkF;AAClF,IAAY,8BAOX;AAPD,WAAY,8BAA8B;IACxC,iBAAiB;IACjB,2DAAyB,CAAA;IACzB,YAAY;IACZ,iDAAe,CAAA;IACf,aAAa;IACb,mDAAiB,CAAA;AACnB,CAAC,EAPW,8BAA8B,8CAA9B,8BAA8B,QAOzC;AAaD,0FAA0F;AAC1F,IAAY,sCAiBX;AAjBD,WAAY,sCAAsC;IAChD,eAAe;IACf,+DAAqB,CAAA;IACrB,eAAe;IACf,+DAAqB,CAAA;IACrB,mBAAmB;IACnB,uEAA6B,CAAA;IAC7B,kBAAkB;IAClB,qEAA2B,CAAA;IAC3B,kBAAkB;IAClB,qEAA2B,CAAA;IAC3B,iBAAiB;IACjB,mEAAyB,CAAA;IACzB,YAAY;IACZ,yDAAe,CAAA;IACf,cAAc;IACd,6DAAmB,CAAA;AACrB,CAAC,EAjBW,sCAAsC,sDAAtC,sCAAsC,QAiBjD;AAkBD,wFAAwF;AACxF,IAAY,oCAOX;AAPD,WAAY,oCAAoC;IAC9C,eAAe;IACf,6DAAqB,CAAA;IACrB,eAAe;IACf,6DAAqB,CAAA;IACrB,YAAY;IACZ,uDAAe,CAAA;AACjB,CAAC,EAPW,oCAAoC,oDAApC,oCAAoC,QAO/C;AAaD,iFAAiF;AACjF,IAAY,6BAaX;AAbD,WAAY,6BAA6B;IACvC,cAAc;IACd,oDAAmB,CAAA;IACnB,gBAAgB;IAChB,wDAAuB,CAAA;IACvB,eAAe;IACf,sDAAqB,CAAA;IACrB,cAAc;IACd,oDAAmB,CAAA;IACnB,aAAa;IACb,kDAAiB,CAAA;IACjB,gBAAgB;IAChB,wDAAuB,CAAA;AACzB,CAAC,EAbW,6BAA6B,6CAA7B,6BAA6B,QAaxC;AAgBD,+EAA+E;AAC/E,IAAY,2BAaX;AAbD,WAAY,2BAA2B;IACrC,cAAc;IACd,kDAAmB,CAAA;IACnB,gBAAgB;IAChB,sDAAuB,CAAA;IACvB,aAAa;IACb,gDAAiB,CAAA;IACjB,eAAe;IACf,oDAAqB,CAAA;IACrB,kBAAkB;IAClB,0DAA2B,CAAA;IAC3B,cAAc;IACd,kDAAmB,CAAA;AACrB,CAAC,EAbW,2BAA2B,2CAA3B,2BAA2B,QAatC;AAgBD,+FAA+F;AAC/F,IAAY,2CAOX;AAPD,WAAY,2CAA2C;IACrD,cAAc;IACd,kEAAmB,CAAA;IACnB,eAAe;IACf,oEAAqB,CAAA;IACrB,eAAe;IACf,oEAAqB,CAAA;AACvB,CAAC,EAPW,2CAA2C,2DAA3C,2CAA2C,QAOtD;AAaD,mGAAmG;AACnG,IAAY,+CASX;AATD,WAAY,+CAA+C;IACzD,gBAAgB;IAChB,0EAAuB,CAAA;IACvB,eAAe;IACf,wEAAqB,CAAA;IACrB,eAAe;IACf,wEAAqB,CAAA;IACrB,aAAa;IACb,oEAAiB,CAAA;AACnB,CAAC,EATW,+CAA+C,+DAA/C,+CAA+C,QAS1D;AAcD,8EAA8E;AAC9E,IAAY,0BAOX;AAPD,WAAY,0BAA0B;IACpC,2IAA2I;IAC3I,iGAAmE,CAAA;IACnE,4KAA4K;IAC5K,yHAA2F,CAAA;IAC3F,sGAAsG;IACtG,+GAAiF,CAAA;AACnF,CAAC,EAPW,0BAA0B,0CAA1B,0BAA0B,QAOrC;AAaD,sFAAsF;AACtF,IAAY,kCASX;AATD,WAAY,kCAAkC;IAC5C,qBAAqB;IACrB,uEAAiC,CAAA;IACjC,mBAAmB;IACnB,mEAA6B,CAAA;IAC7B,iCAAiC;IACjC,iGAA2D,CAAA;IAC3D,WAAW;IACX,mDAAa,CAAA;AACf,CAAC,EATW,kCAAkC,kDAAlC,kCAAkC,QAS7C;AAcD,qEAAqE;AACrE,IAAY,iBAKX;AALD,WAAY,iBAAiB;IAC3B,UAAU;IACV,gCAAW,CAAA;IACX,YAAY;IACZ,oCAAe,CAAA;AACjB,CAAC,EALW,iBAAiB,iCAAjB,iBAAiB,QAK5B;AAYD,gFAAgF;AAChF,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,qDAAqD;IACrD,iFAAiD,CAAA;IACjD,2EAA2E;IAC3E,mHAAmF,CAAA;AACrF,CAAC,EALW,4BAA4B,4CAA5B,4BAA4B,QAKvC;AAYD,yEAAyE;AACzE,IAAY,qBAuBX;AAvBD,WAAY,qBAAqB;IAC/B,+DAA+D;IAC/D,wCAAe,CAAA;IACf,qCAAqC;IACrC,0CAAiB,CAAA;IACjB,8GAA8G;IAC9G,gDAAuB,CAAA;IACvB,0HAA0H;IAC1H,0CAAiB,CAAA;IACjB,gHAAgH;IAChH,sCAAa,CAAA;IACb,iEAAiE;IACjE,4CAAmB,CAAA;IACnB,6GAA6G;IAC7G,0CAAiB,CAAA;IACjB,8JAA8J;IAC9J,gDAAuB,CAAA;IACvB,0ZAA0Z;IAC1Z,sDAA6B,CAAA;IAC7B,+SAA+S;IAC/S,sEAA6C,CAAA;IAC7C,sEAAsE;IACtE,oEAA2C,CAAA;AAC7C,CAAC,EAvBW,qBAAqB,qCAArB,qBAAqB,QAuBhC;AAqBD,uFAAuF;AACvF,IAAY,mCAKX;AALD,WAAY,mCAAmC;IAC7C,WAAW;IACX,oDAAa,CAAA;IACb,eAAe;IACf,4DAAqB,CAAA;AACvB,CAAC,EALW,mCAAmC,mDAAnC,mCAAmC,QAK9C;AAYD,kEAAkE;AAClE,IAAY,cAiBX;AAjBD,WAAY,cAAc;IACxB,8DAA8D;IAC9D,2CAAyB,CAAA;IACzB,sDAAsD;IACtD,uCAAqB,CAAA;IACrB,wDAAwD;IACxD,uCAAqB,CAAA;IACrB,iEAAiE;IACjE,mCAAiB,CAAA;IACjB,mEAAmE;IACnE,yCAAuB,CAAA;IACvB,qGAAqG;IACrG,qDAAmC,CAAA;IACnC,2EAA2E;IAC3E,iDAA+B,CAAA;IAC/B,0FAA0F;IAC1F,+CAA6B,CAAA;AAC/B,CAAC,EAjBW,cAAc,8BAAd,cAAc,QAiBzB;AAkBD,uEAAuE;AACvE,IAAY,mBAOX;AAPD,WAAY,mBAAmB;IAC7B,4JAA4J;IAC5J,0FAAmE,CAAA;IACnE,yGAAyG;IACzG,0FAAmE,CAAA;IACnE,wIAAwI;IACxI,kHAA2F,CAAA;AAC7F,CAAC,EAPW,mBAAmB,mCAAnB,mBAAmB,QAO9B;AAaD,4EAA4E;AAC5E,IAAY,wBAOX;AAPD,WAAY,wBAAwB;IAClC,gEAAgE;IAChE,iDAAqB,CAAA;IACrB,+FAA+F;IAC/F,yDAA6B,CAAA;IAC7B,mCAAmC;IACnC,+CAAmB,CAAA;AACrB,CAAC,EAPW,wBAAwB,wCAAxB,wBAAwB,QAOnC;AAaD,0EAA0E;AAC1E,IAAY,sBAWX;AAXD,WAAY,sBAAsB;IAChC,+GAA+G;IAC/G,yDAA+B,CAAA;IAC/B,wEAAwE;IACxE,4IAAkH,CAAA;IAClH,gHAAgH;IAChH,oHAA0F,CAAA;IAC1F,gHAAgH;IAChH,oHAA0F,CAAA;IAC1F,2GAA2G;IAC3G,0FAAgE,CAAA;AAClE,CAAC,EAXW,sBAAsB,sCAAtB,sBAAsB,QAWjC;AAeD,4EAA4E;AAC5E,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC,4QAA4Q;IAC5Q,+CAAmB,CAAA;IACnB,8PAA8P;IAC9P,iDAAqB,CAAA;AACvB,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAYD,2EAA2E;AAC3E,IAAY,uBAKX;AALD,WAAY,uBAAuB;IACjC,mNAAmN;IACnN,wEAA6C,CAAA;IAC7C,yFAAyF;IACzF,wCAAa,CAAA;AACf,CAAC,EALW,uBAAuB,uCAAvB,uBAAuB,QAKlC;AAYD,oFAAoF;AACpF,IAAY,gCAKX;AALD,WAAY,gCAAgC;IAC1C,+FAA+F;IAC/F,iDAAa,CAAA;IACb,wFAAwF;IACxF,2EAAuC,CAAA;AACzC,CAAC,EALW,gCAAgC,gDAAhC,gCAAgC,QAK3C;AAYD,gFAAgF;AAChF,IAAY,4BAeX;AAfD,WAAY,4BAA4B;IACtC,oGAAoG;IACpG,4DAA4B,CAAA;IAC5B,sGAAsG;IACtG,0DAA0B,CAAA;IAC1B,wHAAwH;IACxH,kEAAkC,CAAA;IAClC,mLAAmL;IACnL,4DAA4B,CAAA;IAC5B,gIAAgI;IAChI,0DAA0B,CAAA;IAC1B,wKAAwK;IACxK,kEAAkC,CAAA;IAClC,4KAA4K;IAC5K,8DAA8B,CAAA;AAChC,CAAC,EAfW,4BAA4B,4CAA5B,4BAA4B,QAevC;AAiBD,kFAAkF;AAClF,IAAY,8BAGX;AAHD,WAAY,8BAA8B;IACxC,gJAAgJ;IAChJ,2EAAyC,CAAA;AAC3C,CAAC,EAHW,8BAA8B,8CAA9B,8BAA8B,QAGzC;AAWD,oFAAoF;AACpF,IAAY,gCAOX;AAPD,WAAY,gCAAgC;IAC1C,6CAA6C;IAC7C,gEAA4B,CAAA;IAC5B,4CAA4C;IAC5C,8DAA0B,CAAA;IAC1B,sCAAsC;IACtC,gEAA4B,CAAA;AAC9B,CAAC,EAPW,gCAAgC,gDAAhC,gCAAgC,QAO3C;AAaD,oEAAoE;AACpE,IAAY,gBAOX;AAPD,WAAY,gBAAgB;IAC1B,WAAW;IACX,iCAAa,CAAA;IACb,WAAW;IACX,iCAAa,CAAA;IACb,YAAY;IACZ,mCAAe,CAAA;AACjB,CAAC,EAPW,gBAAgB,gCAAhB,gBAAgB,QAO3B;AAaD,mEAAmE;AACnE,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,4EAA4E;IAC5E,8BAAW,CAAA;IACX,gFAAgF;IAChF,gCAAa,CAAA;AACf,CAAC,EALW,eAAe,+BAAf,eAAe,QAK1B;AAYD,6EAA6E;AAC7E,IAAY,yBAGX;AAHD,WAAY,yBAAyB;IACnC,eAAe;IACf,kDAAqB,CAAA;AACvB,CAAC,EAHW,yBAAyB,yCAAzB,yBAAyB,QAGpC;AAWD,iFAAiF;AACjF,IAAY,6BAaX;AAbD,WAAY,6BAA6B;IACvC,eAAe;IACf,sDAAqB,CAAA;IACrB,eAAe;IACf,sDAAqB,CAAA;IACrB,aAAa;IACb,kDAAiB,CAAA;IACjB,gBAAgB;IAChB,wDAAuB,CAAA;IACvB,eAAe;IACf,sDAAqB,CAAA;IACrB,gBAAgB;IAChB,wDAAuB,CAAA;AACzB,CAAC,EAbW,6BAA6B,6CAA7B,6BAA6B,QAaxC;AAgBD,sFAAsF;AACtF,IAAY,kCAOX;AAPD,WAAY,kCAAkC;IAC5C,cAAc;IACd,yDAAmB,CAAA;IACnB,aAAa;IACb,uDAAiB,CAAA;IACjB,gBAAgB;IAChB,6DAAuB,CAAA;AACzB,CAAC,EAPW,kCAAkC,kDAAlC,kCAAkC,QAO7C;AAaD,iFAAiF;AACjF,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC,oBAAoB;IACpB,gEAA+B,CAAA;IAC/B,iBAAiB;IACjB,0DAAyB,CAAA;AAC3B,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC;AAYD,qEAAqE;AACrE,IAAY,iBASX;AATD,WAAY,iBAAiB;IAC3B,gBAAgB;IAChB,4CAAuB,CAAA;IACvB,iBAAiB;IACjB,8CAAyB,CAAA;IACzB,aAAa;IACb,sCAAiB,CAAA;IACjB,cAAc;IACd,wCAAmB,CAAA;AACrB,CAAC,EATW,iBAAiB,iCAAjB,iBAAiB,QAS5B;AAcD,kFAAkF;AAClF,IAAY,8BAOX;AAPD,WAAY,8BAA8B;IACxC,0BAA0B;IAC1B,6EAA2C,CAAA;IAC3C,gDAAgD;IAChD,yHAAuF,CAAA;IACvF,+BAA+B;IAC/B,uFAAqD,CAAA;AACvD,CAAC,EAPW,8BAA8B,8CAA9B,8BAA8B,QAOzC;AAaD,oEAAoE;AACpE,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,aAAa;IACb,qCAAiB,CAAA;IACjB,WAAW;IACX,iCAAa,CAAA;AACf,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B;AAYD,iFAAiF;AACjF,IAAY,6BAOX;AAPD,WAAY,6BAA6B;IACvC,WAAW;IACX,8CAAa,CAAA;IACb,eAAe;IACf,sDAAqB,CAAA;IACrB,gBAAgB;IAChB,wDAAuB,CAAA;AACzB,CAAC,EAPW,6BAA6B,6CAA7B,6BAA6B,QAOxC;AAaD,uEAAuE;AACvE,IAAY,mBAGX;AAHD,WAAY,mBAAmB;IAC7B,aAAa;IACb,wCAAiB,CAAA;AACnB,CAAC,EAHW,mBAAmB,mCAAnB,mBAAmB,QAG9B;AAWD,0EAA0E;AAC1E,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,kBAAkB;IAClB,qDAA2B,CAAA;AAC7B,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAWD,4EAA4E;AAC5E,IAAY,wBAGX;AAHD,WAAY,wBAAwB;IAClC,2BAA2B;IAC3B,0EAA8C,CAAA;AAChD,CAAC,EAHW,wBAAwB,wCAAxB,wBAAwB,QAGnC;AAWD,+FAA+F;AAC/F,IAAY,2CAKX;AALD,WAAY,2CAA2C;IACrD,WAAW;IACX,4DAAa,CAAA;IACb,YAAY;IACZ,8DAAe,CAAA;AACjB,CAAC,EALW,2CAA2C,2DAA3C,2CAA2C,QAKtD;AAYD,2EAA2E;AAC3E,IAAY,uBASX;AATD,WAAY,uBAAuB;IACjC,kBAAkB;IAClB,uDAA4B,CAAA;IAC5B,kBAAkB;IAClB,uDAA4B,CAAA;IAC5B,iBAAiB;IACjB,qDAA0B,CAAA;IAC1B,mBAAmB;IACnB,yDAA8B,CAAA;AAChC,CAAC,EATW,uBAAuB,uCAAvB,uBAAuB,QASlC;AAcD,qFAAqF;AACrF,IAAY,iCASX;AATD,WAAY,iCAAiC;IAC3C,uCAAuC;IACvC,0GAAqE,CAAA;IACrE,uBAAuB;IACvB,0EAAqC,CAAA;IACrC,uBAAuB;IACvB,0EAAqC,CAAA;IACrC,sBAAsB;IACtB,wEAAmC,CAAA;AACrC,CAAC,EATW,iCAAiC,iDAAjC,iCAAiC,QAS5C;AAcD,wEAAwE;AACxE,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,WAAW;IACX,qCAAa,CAAA;IACb,cAAc;IACd,2CAAmB,CAAA;AACrB,CAAC,EALW,oBAAoB,oCAApB,oBAAoB,QAK/B;AAYD,oFAAoF;AACpF,IAAY,gCAKX;AALD,WAAY,gCAAgC;IAC1C,eAAe;IACf,yDAAqB,CAAA;IACrB,cAAc;IACd,uDAAmB,CAAA;AACrB,CAAC,EALW,gCAAgC,gDAAhC,gCAAgC,QAK3C;AAYD,mFAAmF;AACnF,IAAY,+BASX;AATD,WAAY,+BAA+B;IACzC,kBAAkB;IAClB,+DAA4B,CAAA;IAC5B,kBAAkB;IAClB,+DAA4B,CAAA;IAC5B,qBAAqB;IACrB,qEAAkC,CAAA;IAClC,iBAAiB;IACjB,6DAA0B,CAAA;AAC5B,CAAC,EATW,+BAA+B,+CAA/B,+BAA+B,QAS1C;AAcD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,2QAA2Q;IAC3Q,uEAAwC,CAAA;IACxC,+FAA+F;IAC/F,yEAA0C,CAAA;AAC5C,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,mFAAmF;AACnF,IAAY,+BASX;AATD,WAAY,+BAA+B;IACzC,cAAc;IACd,sDAAmB,CAAA;IACnB,iBAAiB;IACjB,4DAAyB,CAAA;IACzB,gBAAgB;IAChB,0DAAuB,CAAA;IACvB,aAAa;IACb,oDAAiB,CAAA;AACnB,CAAC,EATW,+BAA+B,+CAA/B,+BAA+B,QAS1C;AAcD,yEAAyE;AACzE,IAAY,qBASX;AATD,WAAY,qBAAqB;IAC/B,cAAc;IACd,4CAAmB,CAAA;IACnB,kBAAkB;IAClB,oDAA2B,CAAA;IAC3B,gBAAgB;IAChB,gDAAuB,CAAA;IACvB,aAAa;IACb,0CAAiB,CAAA;AACnB,CAAC,EATW,qBAAqB,qCAArB,qBAAqB,QAShC;AAcD,+EAA+E;AAC/E,IAAY,2BAKX;AALD,WAAY,2BAA2B;IACrC,wBAAwB;IACxB,sEAAuC,CAAA;IACvC,mBAAmB;IACnB,4DAA6B,CAAA;AAC/B,CAAC,EALW,2BAA2B,2CAA3B,2BAA2B,QAKtC;AAYD,gFAAgF;AAChF,IAAY,4BASX;AATD,WAAY,4BAA4B;IACtC,YAAY;IACZ,+CAAe,CAAA;IACf,yBAAyB;IACzB,yEAAyC,CAAA;IACzC,0BAA0B;IAC1B,2EAA2C,CAAA;IAC3C,cAAc;IACd,mDAAmB,CAAA;AACrB,CAAC,EATW,4BAA4B,4CAA5B,4BAA4B,QASvC;AAcD,yEAAyE;AACzE,IAAY,qBAOX;AAPD,WAAY,qBAAqB;IAC/B,cAAc;IACd,4CAAmB,CAAA;IACnB,aAAa;IACb,0CAAiB,CAAA;IACjB,gBAAgB;IAChB,gDAAuB,CAAA;AACzB,CAAC,EAPW,qBAAqB,qCAArB,qBAAqB,QAOhC;AAaD,+EAA+E;AAC/E,IAAY,2BAOX;AAPD,WAAY,2BAA2B;IACrC,YAAY;IACZ,8CAAe,CAAA;IACf,cAAc;IACd,kDAAmB,CAAA;IACnB,eAAe;IACf,oDAAqB,CAAA;AACvB,CAAC,EAPW,2BAA2B,2CAA3B,2BAA2B,QAOtC;AAaD,uEAAuE;AACvE,IAAY,mBAKX;AALD,WAAY,mBAAmB;IAC7B,YAAY;IACZ,sCAAe,CAAA;IACf,WAAW;IACX,oCAAa,CAAA;AACf,CAAC,EALW,mBAAmB,mCAAnB,mBAAmB,QAK9B;AAYD,mFAAmF;AACnF,IAAY,+BAWX;AAXD,WAAY,+BAA+B;IACzC,2CAA2C;IAC3C,oDAAiB,CAAA;IACjB,wCAAwC;IACxC,8CAAW,CAAA;IACX,2CAA2C;IAC3C,oDAAiB,CAAA;IACjB,4CAA4C;IAC5C,sDAAmB,CAAA;IACnB,yCAAyC;IACzC,gDAAa,CAAA;AACf,CAAC,EAXW,+BAA+B,+CAA/B,+BAA+B,QAW1C;AAeD,oFAAoF;AACpF,IAAY,gCASX;AATD,WAAY,gCAAgC;IAC1C,UAAU;IACV,+CAAW,CAAA;IACX,aAAa;IACb,qDAAiB,CAAA;IACjB,YAAY;IACZ,mDAAe,CAAA;IACf,sBAAsB;IACtB,uEAAmC,CAAA;AACrC,CAAC,EATW,gCAAgC,gDAAhC,gCAAgC,QAS3C;AAcD,iFAAiF;AACjF,IAAY,6BAGX;AAHD,WAAY,6BAA6B;IACvC,aAAa;IACb,kDAAiB,CAAA;AACnB,CAAC,EAHW,6BAA6B,6CAA7B,6BAA6B,QAGxC;AAWD,gFAAgF;AAChF,IAAY,4BAOX;AAPD,WAAY,4BAA4B;IACtC,WAAW;IACX,6CAAa,CAAA;IACb,aAAa;IACb,iDAAiB,CAAA;IACjB,mBAAmB;IACnB,6DAA6B,CAAA;AAC/B,CAAC,EAPW,4BAA4B,4CAA5B,4BAA4B,QAOvC;AAaD,6EAA6E;AAC7E,IAAY,yBAKX;AALD,WAAY,yBAAyB;IACnC,iBAAiB;IACjB,sDAAyB,CAAA;IACzB,cAAc;IACd,gDAAmB,CAAA;AACrB,CAAC,EALW,yBAAyB,yCAAzB,yBAAyB,QAKpC;AAYD,gFAAgF;AAChF,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACtC,cAAc;IACd,mDAAmB,CAAA;IACnB,cAAc;IACd,mDAAmB,CAAA;AACrB,CAAC,EALW,4BAA4B,4CAA5B,4BAA4B,QAKvC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n// Code generated by Microsoft (R) AutoRest Code Generator.\n// Changes may cause incorrect behavior and will be lost if the code is regenerated.\n\nimport type * as coreClient from \"@azure/core-client\";\n\n/** A list of REST API operations supported by an Azure Resource Provider. It contains an URL link to get the next set of results. */\nexport interface OperationListResult {\n /**\n * List of operations supported by the resource provider\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly value?: Operation[];\n /**\n * URL to get the next set of operation list results (if there are any).\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly nextLink?: string;\n}\n\n/** Details of a REST API operation, returned from the Resource Provider Operations API */\nexport interface Operation {\n /**\n * The name of the operation, as per Resource-Based Access Control (RBAC). Examples: \"Microsoft.Compute/virtualMachines/write\", \"Microsoft.Compute/virtualMachines/capture/action\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Whether the operation applies to data-plane. This is \"true\" for data-plane operations and \"false\" for ARM/control-plane operations.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isDataAction?: boolean;\n /** Localized display information for this particular operation. */\n display?: OperationDisplay;\n /**\n * The intended executor of the operation; as in Resource Based Access Control (RBAC) and audit logs UX. Default value is \"user,system\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly origin?: Origin;\n /**\n * Enum. Indicates the action type. \"Internal\" refers to actions that are for internal only APIs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly actionType?: ActionType;\n}\n\n/** Localized display information for this particular operation. */\nexport interface OperationDisplay {\n /**\n * The localized friendly form of the resource provider name, e.g. \"Microsoft Monitoring Insights\" or \"Microsoft Compute\".\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provider?: string;\n /**\n * The localized friendly name of the resource type related to this operation. E.g. \"Virtual Machines\" or \"Job Schedule Collections\".\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resource?: string;\n /**\n * The concise, localized friendly name for the operation; suitable for dropdowns. E.g. \"Create or Update Virtual Machine\", \"Restart Virtual Machine\".\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly operation?: string;\n /**\n * The short, localized friendly description of the operation; suitable for tool tips and detailed views.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly description?: string;\n}\n\n/** An error response from the Compute service. */\nexport interface CloudError {\n /** Api error. */\n error?: ApiError;\n}\n\n/** Api error. */\nexport interface ApiError {\n /** The Api error details */\n details?: ApiErrorBase[];\n /** The Api inner error */\n innererror?: InnerError;\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Api error base. */\nexport interface ApiErrorBase {\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Inner error details. */\nexport interface InnerError {\n /** The exception type. */\n exceptiontype?: string;\n /** The internal error message or exception dump. */\n errordetail?: string;\n}\n\n/** The List Availability Set operation response. */\nexport interface AvailabilitySetListResult {\n /** The list of availability sets. */\n value: AvailabilitySet[];\n /** The URI to fetch the next page of AvailabilitySets. Call ListNext() with this URI to fetch the next page of AvailabilitySets. */\n nextLink?: string;\n}\n\nexport interface SubResource {\n /** Resource Id */\n id?: string;\n}\n\n/** Instance view status. */\nexport interface InstanceViewStatus {\n /** The status code. */\n code?: string;\n /** The level code. */\n level?: StatusLevelTypes;\n /** The short localizable label for the status. */\n displayStatus?: string;\n /** The detailed status message, including for alerts and error messages. */\n message?: string;\n /** The time of the status. */\n time?: Date;\n}\n\n/** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations. */\nexport interface ScheduledEventsPolicy {\n /** The configuration parameters used while creating userInitiatedRedeploy scheduled event setting creation. */\n userInitiatedRedeploy?: UserInitiatedRedeploy;\n /** The configuration parameters used while creating userInitiatedReboot scheduled event setting creation. */\n userInitiatedReboot?: UserInitiatedReboot;\n /** The configuration parameters used while publishing scheduledEventsAdditionalPublishingTargets. */\n scheduledEventsAdditionalPublishingTargets?: ScheduledEventsAdditionalPublishingTargets;\n /** The configuration parameters used while creating AllInstancesDown scheduled event setting creation. */\n allInstancesDown?: AllInstancesDown;\n}\n\n/** Specifies Redeploy related Scheduled Event related configurations. */\nexport interface UserInitiatedRedeploy {\n /** Specifies Redeploy Scheduled Event related configurations. */\n automaticallyApprove?: boolean;\n}\n\n/** Specifies Reboot related Scheduled Event related configurations. */\nexport interface UserInitiatedReboot {\n /** Specifies Reboot Scheduled Event related configurations. */\n automaticallyApprove?: boolean;\n}\n\nexport interface ScheduledEventsAdditionalPublishingTargets {\n /** The configuration parameters used while creating eventGridAndResourceGraph Scheduled Event setting. */\n eventGridAndResourceGraph?: EventGridAndResourceGraph;\n}\n\n/** Specifies eventGridAndResourceGraph related Scheduled Event related configurations. */\nexport interface EventGridAndResourceGraph {\n /** Specifies if event grid and resource graph is enabled for Scheduled event related configurations. */\n enable?: boolean;\n /** Specifies the api-version to determine which Scheduled Events configuration schema version will be delivered. */\n scheduledEventsApiVersion?: string;\n}\n\n/** Specifies if Scheduled Events should be auto-approved when all instances are down. */\nexport interface AllInstancesDown {\n /**\n * Specifies if Scheduled Events should be auto-approved when all instances are down.\n * its default value is true\n */\n automaticallyApprove?: boolean;\n}\n\n/** Describes the Availability Set properties related to migration to Flexible Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetMigrationInfo {\n /**\n * Indicates the target Virtual Machine ScaleSet properties upon triggering a seamless migration without downtime of the VMs via the ConvertToVirtualMachineScaleSet API.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly defaultVirtualMachineScaleSetInfo?: DefaultVirtualMachineScaleSetInfo;\n /**\n * Specifies the Virtual Machine Scale Set that the Availability Set is migrated to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly migrateToVirtualMachineScaleSet?: SubResource;\n}\n\n/** Indicates the target Virtual Machine ScaleSet properties upon triggering a seamless migration without downtime of the VMs via the ConvertToVirtualMachineScaleSet API. */\nexport interface DefaultVirtualMachineScaleSetInfo {\n /**\n * Indicates if the the maximum capacity of the default migrated Virtual Machine Scale Set after its migration will be constrained to a limited number of VMs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly constrainedMaximumCapacity?: boolean;\n /**\n * The default Virtual Machine ScaleSet Uri that the Availability Set will be moved to upon triggering a seamless migration via the ConvertToVirtualMachineScaleSet API.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly defaultVirtualMachineScaleSet?: SubResource;\n}\n\n/** Describes a virtual machine scale set sku. NOTE: If the new VM SKU is not supported on the hardware the scale set is currently on, you need to deallocate the VMs in the scale set before you modify the SKU name. */\nexport interface Sku {\n /** The sku name. */\n name?: string;\n /** Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of virtual machines in the scale set. */\n capacity?: number;\n}\n\n/** Common fields that are returned in the response for all Azure Resource Manager resources */\nexport interface Resource {\n /**\n * Fully qualified resource ID for the resource. Ex - /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * The name of the resource\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The type of the resource. E.g. \"Microsoft.Compute/virtualMachines\" or \"Microsoft.Storage/storageAccounts\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Azure Resource Manager metadata containing createdBy and modifiedBy information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly systemData?: SystemData;\n}\n\n/** Metadata pertaining to creation and last modification of the resource. */\nexport interface SystemData {\n /** The identity that created the resource. */\n createdBy?: string;\n /** The type of identity that created the resource. */\n createdByType?: CreatedByType;\n /** The timestamp of resource creation (UTC). */\n createdAt?: Date;\n /** The identity that last modified the resource. */\n lastModifiedBy?: string;\n /** The type of identity that last modified the resource. */\n lastModifiedByType?: CreatedByType;\n /** The timestamp of resource last modification (UTC) */\n lastModifiedAt?: Date;\n}\n\n/** The List capacity reservation group with resource group response. */\nexport interface CapacityReservationGroupListResult {\n /** The list of capacity reservation groups. */\n value: CapacityReservationGroup[];\n /** The URI to fetch the next page of capacity reservation groups. Call ListNext() with this URI to fetch the next page of capacity reservation groups. */\n nextLink?: string;\n}\n\nexport interface SubResourceReadOnly {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n}\n\nexport interface CapacityReservationGroupInstanceView {\n /**\n * List of instance view of the capacity reservations under the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacityReservations?: CapacityReservationInstanceViewWithName[];\n /**\n * List of the subscriptions that the capacity reservation group is shared with. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sharedSubscriptionIds?: SubResourceReadOnly[];\n}\n\n/** The instance view of a capacity reservation that provides as snapshot of the runtime properties of the capacity reservation that is managed by the platform and can change outside of control plane operations. */\nexport interface CapacityReservationInstanceView {\n /** Unutilized capacity of the capacity reservation. */\n utilizationInfo?: CapacityReservationUtilization;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** Represents the capacity reservation utilization in terms of resources allocated. */\nexport interface CapacityReservationUtilization {\n /**\n * The value provides the current capacity of the VM size which was reserved successfully and for which the customer is getting billed. Minimum api-version: 2022-08-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly currentCapacity?: number;\n /**\n * A list of all virtual machines resource ids allocated against the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAllocated?: SubResourceReadOnly[];\n}\n\nexport interface ResourceSharingProfile {\n /** Specifies an array of subscription resource IDs that capacity reservation group is shared with. Block Capacity Reservations does not support sharing across subscriptions. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details. */\n subscriptionIds?: SubResource[];\n}\n\n/** The List Dedicated Host Group with resource group response. */\nexport interface DedicatedHostGroupListResult {\n /** The list of dedicated host groups. */\n value: DedicatedHostGroup[];\n /** The URI to fetch the next page of Dedicated Host Groups. Call ListNext() with this URI to fetch the next page of Dedicated Host Groups. */\n nextLink?: string;\n}\n\nexport interface DedicatedHostGroupInstanceView {\n /** List of instance view of the dedicated hosts under the dedicated host group. */\n hosts?: DedicatedHostInstanceViewWithName[];\n}\n\n/** The instance view of a dedicated host. */\nexport interface DedicatedHostInstanceView {\n /**\n * Specifies the unique id of the dedicated physical machine on which the dedicated host resides.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assetId?: string;\n /** Unutilized capacity of the dedicated host. */\n availableCapacity?: DedicatedHostAvailableCapacity;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** Dedicated host unutilized capacity. */\nexport interface DedicatedHostAvailableCapacity {\n /** The unutilized capacity of the dedicated host represented in terms of each VM size that is allowed to be deployed to the dedicated host. */\n allocatableVMs?: DedicatedHostAllocatableVM[];\n}\n\n/** Represents the dedicated host unutilized capacity in terms of a specific VM size. */\nexport interface DedicatedHostAllocatableVM {\n /** VM size in terms of which the unutilized capacity is represented. */\n vmSize?: string;\n /** Maximum number of VMs of size vmSize that can fit in the dedicated host's remaining capacity. */\n count?: number;\n}\n\n/** Enables or disables a capability on the dedicated host group. Minimum api-version: 2022-03-01. */\nexport interface DedicatedHostGroupPropertiesAdditionalCapabilities {\n /** The flag that enables or disables a capability to have UltraSSD Enabled Virtual Machines on Dedicated Hosts of the Dedicated Host Group. For the Virtual Machines to be UltraSSD Enabled, UltraSSDEnabled flag for the resource needs to be set true as well. The value is defaulted to 'false' when not provided. Please refer to https://docs.microsoft.com/en-us/azure/virtual-machines/disks-enable-ultra-ssd for more details on Ultra SSD feature. **Note:** The ultraSSDEnabled setting can only be enabled for Host Groups that are created as zonal. Minimum api-version: 2022-03-01. */\n ultraSSDEnabled?: boolean;\n}\n\n/** The List Image operation response. */\nexport interface ImageListResult {\n /** The list of Images */\n value: Image[];\n /** The uri to fetch the next page of Images. Call ListNext() with this to fetch the next page of Images. */\n nextLink?: string;\n}\n\n/** Describes a storage profile. */\nexport interface ImageStorageProfile {\n /** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: ImageOSDisk;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: ImageDataDisk[];\n /** Specifies whether an image is zone resilient or not. Default is false. Zone resilient images can be created only in regions that provide Zone Redundant Storage (ZRS). */\n zoneResilient?: boolean;\n}\n\n/** Describes a image disk. */\nexport interface ImageDisk {\n /** The snapshot. */\n snapshot?: SubResource;\n /** The managedDisk. */\n managedDisk?: SubResource;\n /** The Virtual Hard Disk. */\n blobUri?: string;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The default values are: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies the size of empty data disks in gigabytes. This element can be used to overwrite the name of the disk in a virtual machine image. This value cannot be larger than 1023 GB. */\n diskSizeGB?: number;\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?: StorageAccountTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed image disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n}\n\n/** The complex type of the extended location. */\nexport interface ExtendedLocation {\n /** The name of the extended location. */\n name?: string;\n /** The type of the extended location. */\n type?: ExtendedLocationTypes;\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface PurchasePlan {\n /** The publisher ID. */\n publisher: string;\n /** The plan ID. */\n name: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n}\n\n/** Contains the os disk image information. */\nexport interface OSDiskImage {\n /** The operating system of the osDiskImage. */\n operatingSystem: OperatingSystemTypes;\n}\n\n/** Contains the data disk images information. */\nexport interface DataDiskImage {\n /**\n * Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lun?: number;\n}\n\n/** Describes automatic OS upgrade properties on the image. */\nexport interface AutomaticOSUpgradeProperties {\n /** Specifies whether automatic OS upgrade is supported on the image. */\n automaticOSUpgradeSupported: boolean;\n}\n\n/** Specifies the disallowed configuration for a virtual machine image. */\nexport interface DisallowedConfiguration {\n /** VM disk types which are disallowed. */\n vmDiskType?: VmDiskTypes;\n}\n\n/** Specifies additional capabilities supported by the image */\nexport interface VirtualMachineImageFeature {\n /** The name of the feature. */\n name?: string;\n /** The corresponding value for the feature. */\n value?: string;\n}\n\n/** Describes image deprecation status properties on the image. */\nexport interface ImageDeprecationStatus {\n /** Describes the state of the image. */\n imageState?: ImageState;\n /** The time, in future, at which this image will be marked as deprecated. This scheduled time is chosen by the Publisher. */\n scheduledDeprecationTime?: Date;\n /** Describes the alternative option specified by the Publisher for this image when this image is deprecated. */\n alternativeOption?: AlternativeOption;\n}\n\n/** Describes the alternative option specified by the Publisher for this image when this image is deprecated. */\nexport interface AlternativeOption {\n /** Describes the type of the alternative option. */\n type?: AlternativeType;\n /** Indicates the alternative option value specified by the Publisher. This is the Offer name when the type is Offer or the Plan name when the type is Plan. */\n value?: string;\n}\n\n/** The List VmImages in EdgeZone operation response. */\nexport interface VmImagesInEdgeZoneListResult {\n /** The list of VMImages in EdgeZone */\n value?: VirtualMachineImageResource[];\n /** The URI to fetch the next page of VMImages in EdgeZone. Call ListNext() with this URI to fetch the next page of VmImages. */\n nextLink?: string;\n}\n\n/** Api input base class for LogAnalytics Api. */\nexport interface LogAnalyticsInputBase {\n /** SAS Uri of the logging blob container to which LogAnalytics Api writes output logs to. */\n blobContainerSasUri: string;\n /** From time of the query */\n fromTime: Date;\n /** To time of the query */\n toTime: Date;\n /** Group query result by Throttle Policy applied. */\n groupByThrottlePolicy?: boolean;\n /** Group query result by Operation Name. */\n groupByOperationName?: boolean;\n /** Group query result by Resource Name. */\n groupByResourceName?: boolean;\n /** Group query result by Client Application ID. */\n groupByClientApplicationId?: boolean;\n /** Group query result by User Agent. */\n groupByUserAgent?: boolean;\n}\n\n/** LogAnalytics operation status response */\nexport interface LogAnalyticsOperationResult {\n /**\n * LogAnalyticsOutput\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly properties?: LogAnalyticsOutput;\n}\n\n/** LogAnalytics output properties */\nexport interface LogAnalyticsOutput {\n /**\n * Output file Uri path to blob container.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly output?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface RunCommandListResult {\n /** The list of virtual machine run commands. */\n value: RunCommandDocumentBase[];\n /** The uri to fetch the next page of run commands. Call ListNext() with this to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Describes the properties of a Run Command metadata. */\nexport interface RunCommandDocumentBase {\n /** The VM run command schema. */\n schema: string;\n /** The VM run command id. */\n id: string;\n /** The Operating System type. */\n osType: OperatingSystemTypes;\n /** The VM run command label. */\n label: string;\n /** The VM run command description. */\n description: string;\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandParameterDefinition {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter type. */\n type: string;\n /** The run command parameter default value. */\n defaultValue?: string;\n /** The run command parameter required. */\n required?: boolean;\n}\n\n/** The List Usages operation response. */\nexport interface ListUsagesResult {\n /** The list of compute resource usages. */\n value: Usage[];\n /** The URI to fetch the next page of compute resource usage information. Call ListNext() with this to fetch the next page of compute resource usage information. */\n nextLink?: string;\n}\n\n/** Describes Compute Resource Usage. */\nexport interface Usage {\n /** An enum describing the unit of usage measurement. */\n unit: \"Count\";\n /** The current usage of the resource. */\n currentValue: number;\n /** The maximum permitted usage of the resource. */\n limit: number;\n /** The name of the type of usage. */\n name: UsageName;\n}\n\n/** The Usage Names. */\nexport interface UsageName {\n /** The name of the resource. */\n value?: string;\n /** The localized name of the resource. */\n localizedValue?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListResult {\n /** The list of virtual machine scale sets. */\n value: VirtualMachineScaleSet[];\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of VMSS. */\n nextLink?: string;\n}\n\n/** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\nexport interface Plan {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product?: string;\n /** The promotion code. */\n promotionCode?: string;\n}\n\n/** Describes an upgrade policy - automatic, manual, or rolling. */\nexport interface UpgradePolicy {\n /** Specifies the mode of an upgrade to virtual machines in the scale set.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of updates to virtual machines in the scale set. You do this by using the manualUpgrade action.<br /><br /> **Automatic** - All virtual machines in the scale set are automatically updated at the same time. */\n mode?: UpgradeMode;\n /** The configuration parameters used while performing a rolling upgrade. */\n rollingUpgradePolicy?: RollingUpgradePolicy;\n /** Configuration parameters used for performing automatic OS Upgrade. */\n automaticOSUpgradePolicy?: AutomaticOSUpgradePolicy;\n}\n\n/** The configuration parameters used while performing a rolling upgrade. */\nexport interface RollingUpgradePolicy {\n /** The maximum percent of total virtual machine instances that will be upgraded simultaneously by the rolling upgrade in one batch. As this is a maximum, unhealthy instances in previous or future batches can cause the percentage of instances in a batch to decrease to ensure higher reliability. The default value for this parameter is 20%. */\n maxBatchInstancePercent?: number;\n /** The maximum percentage of the total virtual machine instances in the scale set that can be simultaneously unhealthy, either as a result of being upgraded, or by being found in an unhealthy state by the virtual machine health checks before the rolling upgrade aborts. This constraint will be checked prior to starting any batch. The default value for this parameter is 20%. */\n maxUnhealthyInstancePercent?: number;\n /** The maximum percentage of upgraded virtual machine instances that can be found to be in an unhealthy state. This check will happen after each batch is upgraded. If this percentage is ever exceeded, the rolling update aborts. The default value for this parameter is 20%. */\n maxUnhealthyUpgradedInstancePercent?: number;\n /** The wait time between completing the update for all virtual machines in one batch and starting the next batch. The time duration should be specified in ISO 8601 format. The default value is 0 seconds (PT0S). */\n pauseTimeBetweenBatches?: string;\n /** Allow VMSS to ignore AZ boundaries when constructing upgrade batches. Take into consideration the Update Domain and maxBatchInstancePercent to determine the batch size. */\n enableCrossZoneUpgrade?: boolean;\n /** Upgrade all unhealthy instances in a scale set before any healthy instances. */\n prioritizeUnhealthyInstances?: boolean;\n /** Rollback failed instances to previous model if the Rolling Upgrade policy is violated. */\n rollbackFailedInstancesOnPolicyBreach?: boolean;\n /** Create new virtual machines to upgrade the scale set, rather than updating the existing virtual machines. Existing virtual machines will be deleted once the new virtual machines are created for each batch. */\n maxSurge?: boolean;\n}\n\n/** The configuration parameters used for performing automatic OS upgrade. */\nexport interface AutomaticOSUpgradePolicy {\n /** Indicates whether OS upgrades should automatically be applied to scale set instances in a rolling fashion when a newer version of the OS image becomes available. Default value is false. If this is set to true for Windows based scale sets, [enableAutomaticUpdates](https://docs.microsoft.com/dotnet/api/microsoft.azure.management.compute.models.windowsconfiguration.enableautomaticupdates?view=azure-dotnet) is automatically set to false and cannot be set to true. */\n enableAutomaticOSUpgrade?: boolean;\n /** Whether OS image rollback feature should be disabled. Default value is false. */\n disableAutomaticRollback?: boolean;\n /** Indicates whether rolling upgrade policy should be used during Auto OS Upgrade. Default value is false. Auto OS Upgrade will fallback to the default policy if no policy is defined on the VMSS. */\n useRollingUpgradePolicy?: boolean;\n /** Indicates whether Auto OS Upgrade should undergo deferral. Deferred OS upgrades will send advanced notifications on a per-VM basis that an OS upgrade from rolling upgrades is incoming, via the IMDS tag 'Platform.PendingOSUpgrade'. The upgrade then defers until the upgrade is approved via an ApproveRollingUpgrade call. */\n osRollingUpgradeDeferral?: boolean;\n}\n\n/** Specifies the configuration parameters for automatic repairs on the virtual machine scale set. */\nexport interface AutomaticRepairsPolicy {\n /** Specifies whether automatic repairs should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n /** The amount of time for which automatic repairs are suspended due to a state change on VM. The grace time starts after the state change has completed. This helps avoid premature or accidental repairs. The time duration should be specified in ISO 8601 format. The minimum allowed grace period is 10 minutes (PT10M), which is also the default value. The maximum allowed grace period is 90 minutes (PT90M). */\n gracePeriod?: string;\n /** Type of repair action (replace, restart, reimage) that will be used for repairing unhealthy virtual machines in the scale set. Default value is replace. */\n repairAction?: RepairAction;\n}\n\n/** Describes a virtual machine scale set virtual machine profile. */\nexport interface VirtualMachineScaleSetVMProfile {\n /** Specifies the operating system settings for the virtual machines in the scale set. */\n osProfile?: VirtualMachineScaleSetOSProfile;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: VirtualMachineScaleSetStorageProfile;\n /** Specifies properties of the network interfaces of the virtual machines in the scale set. */\n networkProfile?: VirtualMachineScaleSetNetworkProfile;\n /** Specifies the Security related profile settings for the virtual machines in the scale set. */\n securityProfile?: SecurityProfile;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies a collection of settings for extensions installed on virtual machines in the scale set. */\n extensionProfile?: VirtualMachineScaleSetExtensionProfile;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies the priority for the virtual machines in the scale set. Minimum api-version: 2017-10-30-preview. */\n priority?: VirtualMachinePriorityTypes;\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: VirtualMachineEvictionPolicyTypes;\n /** Specifies the billing related details of a Azure Spot VMSS. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the virtual machines in the scale set, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01. */\n userData?: string;\n /** Specifies the capacity reservation related details of a scale set. Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfile;\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n applicationProfile?: ApplicationProfile;\n /** Specifies the hardware profile related details of a scale set. Minimum api-version: 2021-11-01. */\n hardwareProfile?: VirtualMachineScaleSetHardwareProfile;\n /** Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version. Minimum api-version: 2022-11-01 */\n serviceArtifactReference?: ServiceArtifactReference;\n /** Specifies the security posture to be used in the scale set. Minimum api-version: 2023-03-01 */\n securityPostureReference?: SecurityPostureReference;\n /**\n * Specifies the time in which this VM profile for the Virtual Machine Scale Set was created. This value will be added to VMSS Flex VM tags when creating/updating the VMSS VM Profile. Minimum API version for this property is 2023-09-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Describes a virtual machine scale set OS profile. */\nexport interface VirtualMachineScaleSetOSProfile {\n /** Specifies the computer name prefix for all of the virtual machines in the scale set. Computer name prefixes must be 1 to 15 characters long. */\n computerNamePrefix?: string;\n /** Specifies the name of the administrator account. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters */\n adminUsername?: string;\n /**\n * Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)\n * This value contains a credential. Consider obscuring before showing to users\n */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. For using cloud-init for your VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init) */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfiguration;\n /** Specifies the Linux operating system settings on the virtual machine. For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfiguration;\n /** Specifies set of certificates that should be installed onto the virtual machines in the scale set. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: VaultSecretGroup[];\n /** Specifies whether extension operations should be allowed on the virtual machine scale set. This may only be set to False when no extensions are present on the virtual machine scale set. */\n allowExtensionOperations?: boolean;\n /** Optional property which must either be set to True or omitted. */\n requireGuestProvisionSignal?: boolean;\n}\n\n/** Specifies Windows operating system settings on the virtual machine. */\nexport interface WindowsConfiguration {\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. When this property is not specified in the request body, it is set to true by default. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** Indicates whether Automatic Updates is enabled for the Windows virtual machine. Default value is true. For virtual machine scale sets, this property can be updated and updates will take effect on OS reprovisioning. */\n enableAutomaticUpdates?: boolean;\n /** Specifies the time zone of the virtual machine. e.g. \"Pacific Standard Time\". Possible values can be [TimeZoneInfo.Id](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.id?#System_TimeZoneInfo_Id) value from time zones returned by [TimeZoneInfo.GetSystemTimeZones](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.getsystemtimezones). */\n timeZone?: string;\n /** Specifies additional base-64 encoded XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. */\n additionalUnattendContent?: AdditionalUnattendContent[];\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Windows. */\n patchSettings?: PatchSettings;\n /** Specifies the Windows Remote Management listeners. This enables remote Windows PowerShell. */\n winRM?: WinRMConfiguration;\n /**\n * Indicates whether VMAgent Platform Updates are enabled for the Windows Virtual Machine.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** Specifies additional XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. Contents are defined by setting name, component name, and the pass in which the content is applied. */\nexport interface AdditionalUnattendContent {\n /** The pass name. Currently, the only allowable value is OobeSystem. */\n passName?: \"OobeSystem\";\n /** The component name. Currently, the only allowable value is Microsoft-Windows-Shell-Setup. */\n componentName?: \"Microsoft-Windows-Shell-Setup\";\n /** Specifies the name of the setting to which the content applies. Possible values are: FirstLogonCommands and AutoLogon. */\n settingName?: SettingNames;\n /** Specifies the XML formatted content that is added to the unattend.xml file for the specified path and component. The XML must be less than 4KB and must include the root element for the setting or feature that is being inserted. */\n content?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Windows. */\nexport interface PatchSettings {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of patches to a virtual machine. You do this by applying patches manually inside the VM. In this mode, automatic updates are disabled; the property WindowsConfiguration.enableAutomaticUpdates must be false<br /><br /> **AutomaticByOS** - The virtual machine will automatically be updated by the OS. The property WindowsConfiguration.enableAutomaticUpdates must be true. <br /><br /> **AutomaticByPlatform** - the virtual machine will automatically updated by the platform. The properties provisionVMAgent and WindowsConfiguration.enableAutomaticUpdates must be true */\n patchMode?: WindowsVMGuestPatchMode;\n /** Enables customers to patch their Azure VMs without requiring a reboot. For enableHotpatching, the 'provisionVMAgent' must be set to true and 'patchMode' must be set to 'AutomaticByPlatform'. */\n enableHotpatching?: boolean;\n /** Specifies the mode of VM Guest patch assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine.<br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: WindowsPatchAssessmentMode;\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Windows. */\n automaticByPlatformSettings?: WindowsVMGuestPatchAutomaticByPlatformSettings;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Windows patch settings. */\nexport interface WindowsVMGuestPatchAutomaticByPlatformSettings {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: WindowsVMGuestPatchAutomaticByPlatformRebootSetting;\n /** Enables customer to schedule patching without accidental upgrades */\n bypassPlatformSafetyChecksOnUserSchedule?: boolean;\n}\n\n/** Describes Windows Remote Management configuration of the VM */\nexport interface WinRMConfiguration {\n /** The list of Windows Remote Management listeners */\n listeners?: WinRMListener[];\n}\n\n/** Describes Protocol and thumbprint of Windows Remote Management listener */\nexport interface WinRMListener {\n /** Specifies the protocol of WinRM listener. Possible values are: **http,** **https.** */\n protocol?: ProtocolTypes;\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n}\n\n/** Specifies the Linux operating system settings on the virtual machine. For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\nexport interface LinuxConfiguration {\n /** Specifies whether password authentication should be disabled. */\n disablePasswordAuthentication?: boolean;\n /** Specifies the ssh key configuration for a Linux OS. */\n ssh?: SshConfiguration;\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. When this property is not specified in the request body, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Linux. */\n patchSettings?: LinuxPatchSettings;\n /** Indicates whether VMAgent Platform Updates is enabled for the Linux virtual machine. Default value is false. */\n enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** SSH configuration for Linux based VMs running on Azure */\nexport interface SshConfiguration {\n /** The list of SSH public keys used to authenticate with linux based VMs. */\n publicKeys?: SshPublicKey[];\n}\n\n/** Contains information about SSH certificate public key and the path on the Linux VM where the public key is placed. */\nexport interface SshPublicKey {\n /** Specifies the full path on the created VM where ssh public key is stored. If the file already exists, the specified key is appended to the file. Example: /home/user/.ssh/authorized_keys */\n path?: string;\n /** SSH public key certificate used to authenticate with the VM through ssh. The key needs to be at least 2048-bit and in ssh-rsa format. For creating ssh keys, see [Create SSH keys on Linux and Mac for Linux VMs in Azure]https://docs.microsoft.com/azure/virtual-machines/linux/create-ssh-keys-detailed). */\n keyData?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Linux. */\nexport interface LinuxPatchSettings {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - The virtual machine's default patching configuration is used. <br /><br /> **AutomaticByPlatform** - The virtual machine will be automatically updated by the platform. The property provisionVMAgent must be true */\n patchMode?: LinuxVMGuestPatchMode;\n /** Specifies the mode of VM Guest Patch Assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine. <br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: LinuxPatchAssessmentMode;\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Linux. */\n automaticByPlatformSettings?: LinuxVMGuestPatchAutomaticByPlatformSettings;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Linux patch settings. */\nexport interface LinuxVMGuestPatchAutomaticByPlatformSettings {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: LinuxVMGuestPatchAutomaticByPlatformRebootSetting;\n /** Enables customer to schedule patching without accidental upgrades */\n bypassPlatformSafetyChecksOnUserSchedule?: boolean;\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface VaultSecretGroup {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResource;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: VaultCertificate[];\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the VM. */\nexport interface VaultCertificate {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be It is the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n /** For Windows VMs, specifies the certificate store on the Virtual Machine to which the certificate should be added. The specified certificate store is implicitly in the LocalMachine account. For Linux VMs, the certificate file is placed under the /var/lib/waagent directory, with the file name <UppercaseThumbprint>.crt for the X509 certificate file and <UppercaseThumbprint>.prv for private key. Both of these files are .pem formatted. */\n certificateStore?: string;\n}\n\n/** Describes a virtual machine scale set storage profile. */\nexport interface VirtualMachineScaleSetStorageProfile {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReference;\n /** Specifies information about the operating system disk used by the virtual machines in the scale set. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: VirtualMachineScaleSetOSDisk;\n /** Specifies the parameters that are used to add data disks to the virtual machines in the scale set. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: VirtualMachineScaleSetDataDisk[];\n /** Specifies the disk controller type configured for the virtual machines in the scale set. Minimum api-version: 2022-08-01 */\n diskControllerType?: DiskControllerTypes;\n}\n\n/** Describes a virtual machine scale set operating system disk. */\nexport interface VirtualMachineScaleSetOSDisk {\n /** The disk name. */\n name?: string;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The default values are: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machines in the scale set should be created. The only allowed value is: **FromImage.** This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the ephemeral disk Settings for the operating system disk used by the virtual machine scale set. */\n diffDiskSettings?: DiffDiskSettings;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property 'diskSizeGB' is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** Specifies information about the unmanaged user image to base the scale set on. */\n image?: VirtualHardDisk;\n /** Specifies the container urls that are used to store operating system disks for the scale set. */\n vhdContainers?: string[];\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParameters;\n /** Specifies whether OS Disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only). <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the OS disk is retained after VMSS Flex VM is deleted. <br><br> The default value is set to **Delete**. For an Ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for Ephemeral OS Disk. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes the parameters of ephemeral disk settings that can be specified for operating system disk. **Note:** The ephemeral disk settings can only be specified for managed disk. */\nexport interface DiffDiskSettings {\n /** Specifies the ephemeral disk settings for operating system disk. */\n option?: DiffDiskOptions;\n /** Specifies the ephemeral disk placement for operating system disk. Possible values are: **CacheDisk,** **ResourceDisk,** **NvmeDisk.** The defaulting behavior is: **CacheDisk** if one is configured for the VM size otherwise **ResourceDisk** or **NvmeDisk** is used. Refer to the VM size documentation for Windows VM at https://docs.microsoft.com/azure/virtual-machines/windows/sizes and Linux VM at https://docs.microsoft.com/azure/virtual-machines/linux/sizes to check which VM sizes exposes a cache disk. Minimum api-version for NvmeDisk: 2024-03-01. */\n placement?: DiffDiskPlacement;\n}\n\n/** Describes the uri of a disk. */\nexport interface VirtualHardDisk {\n /** Specifies the virtual hard disk's uri. */\n uri?: string;\n}\n\n/** Describes the parameters of a ScaleSet managed disk. */\nexport interface VirtualMachineScaleSetManagedDiskParameters {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?: StorageAccountTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfile;\n}\n\n/** Specifies the security profile settings for the managed disk. **Note:** It can only be set for Confidential VMs. */\nexport interface VMDiskSecurityProfile {\n /** Specifies the EncryptionType of the managed disk. It is set to DiskWithVMGuestState for encryption of the managed disk along with VMGuestState blob, VMGuestStateOnly for encryption of just the VMGuestState blob, and NonPersistedTPM for not persisting firmware state in the VMGuestState blob.. **Note:** It can be set for only Confidential VMs. */\n securityEncryptionType?: SecurityEncryptionTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk that is used for Customer Managed Key encrypted ConfidentialVM OS Disk and VMGuest blob. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n}\n\n/** Describes a virtual machine scale set data disk. */\nexport interface VirtualMachineScaleSetDataDisk {\n /** The disk name. */\n name?: string;\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The default values are: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** The create option. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParameters;\n /** Specifies the Read-Write IOPS for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskIopsReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskMBpsReadWrite?: number;\n /** Specifies whether data disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only).<br><br> Possible values: <br><br> **Delete** If this value is used, the data disk is deleted when the VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the data disk is retained after VMSS Flex VM is deleted.<br><br> The default value is set to **Delete**. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes a virtual machine scale set network profile. */\nexport interface VirtualMachineScaleSetNetworkProfile {\n /** A reference to a load balancer probe used to determine the health of an instance in the virtual machine scale set. The reference will be in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'. */\n healthProbe?: ApiEntityReference;\n /** The list of network configurations. */\n networkInterfaceConfigurations?: VirtualMachineScaleSetNetworkConfiguration[];\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations for Virtual Machine Scale Set with orchestration mode 'Flexible' */\n networkApiVersion?: NetworkApiVersion;\n}\n\n/** The API entity reference. */\nexport interface ApiEntityReference {\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/... */\n id?: string;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetNetworkConfiguration {\n /** The network configuration name. */\n name: string;\n /** Resource tags applied to the networkInterface address created by this NetworkInterfaceConfiguration */\n tags?: { [propertyName: string]: string };\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResource;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettings;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations?: VirtualMachineScaleSetIPConfiguration[];\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** Specifies whether the Auxiliary mode is enabled for the Network Interface resource. */\n auxiliaryMode?: NetworkInterfaceAuxiliaryMode;\n /** Specifies whether the Auxiliary sku is enabled for the Network Interface resource. */\n auxiliarySku?: NetworkInterfaceAuxiliarySku;\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetNetworkConfigurationDnsSettings {\n /** List of DNS servers IP addresses */\n dnsServers?: string[];\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. */\nexport interface VirtualMachineScaleSetIPConfiguration {\n /** The IP configuration name. */\n name: string;\n /** Specifies the identifier of the subnet. */\n subnet?: ApiEntityReference;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetPublicIPAddressConfiguration;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: IPVersion;\n /** Specifies an array of references to backend address pools of application gateways. A scale set can reference backend address pools of multiple application gateways. Multiple scale sets cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: SubResource[];\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: SubResource[];\n /** Specifies an array of references to backend address pools of load balancers. A scale set can reference backend address pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerBackendAddressPools?: SubResource[];\n /** Specifies an array of references to inbound Nat pools of the load balancers. A scale set can reference inbound nat pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerInboundNatPools?: SubResource[];\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetPublicIPAddressConfiguration {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSku;\n /** Resource tags applied to the publicIP address created by this PublicIPAddressConfiguration */\n tags?: { [propertyName: string]: string };\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettings;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: VirtualMachineScaleSetIpTag[];\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResource;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: IPVersion;\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: DeleteOptions;\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettings {\n /** The Domain name label.The concatenation of the domain name label and vm index will be the domain name labels of the PublicIPAddress resources that will be created */\n domainNameLabel: string;\n /** The Domain name label scope.The concatenation of the hashed domain name label that generated according to the policy from domain name label scope and vm index will be the domain name labels of the PublicIPAddress resources that will be created */\n domainNameLabelScope?: DomainNameLabelScopeTypes;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineScaleSetIpTag {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\nexport interface PublicIPAddressSku {\n /** Specify public IP sku name */\n name?: PublicIPAddressSkuName;\n /** Specify public IP sku tier */\n tier?: PublicIPAddressSkuTier;\n}\n\n/** Specifies the Security profile settings for the virtual machine or virtual machine scale set. */\nexport interface SecurityProfile {\n /** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. Minimum api-version: 2020-12-01. */\n uefiSettings?: UefiSettings;\n /** This property can be used by user in the request to enable or disable the Host Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the disks including Resource/Temp disk at host itself. The default behavior is: The Encryption at host will be disabled unless this property is set to true for the resource. */\n encryptionAtHost?: boolean;\n /** Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings. The default behavior is: UefiSettings will not be enabled unless this property is set. */\n securityType?: SecurityTypes;\n /** Specifies the Managed Identity used by ADE to get access token for keyvault operations. */\n encryptionIdentity?: EncryptionIdentity;\n /** Specifies ProxyAgent settings while creating the virtual machine. Minimum api-version: 2023-09-01. */\n proxyAgentSettings?: ProxyAgentSettings;\n}\n\n/** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. Minimum api-version: 2020-12-01. */\nexport interface UefiSettings {\n /** Specifies whether secure boot should be enabled on the virtual machine. Minimum api-version: 2020-12-01. */\n secureBootEnabled?: boolean;\n /** Specifies whether vTPM should be enabled on the virtual machine. Minimum api-version: 2020-12-01. */\n vTpmEnabled?: boolean;\n}\n\n/** Specifies the Managed Identity used by ADE to get access token for keyvault operations. */\nexport interface EncryptionIdentity {\n /** Specifies ARM Resource ID of one of the user identities associated with the VM. */\n userAssignedIdentityResourceId?: string;\n}\n\n/** Specifies ProxyAgent settings for the virtual machine or virtual machine scale set. Minimum api-version: 2023-09-01. */\nexport interface ProxyAgentSettings {\n /** Specifies whether ProxyAgent feature should be enabled on the virtual machine or virtual machine scale set. */\n enabled?: boolean;\n /** Specifies the mode that ProxyAgent will execute on. Warning: this property has been deprecated, please specify 'mode' under particular hostendpoint setting. */\n mode?: Mode;\n /** Increase the value of this property allows users to reset the key used for securing communication channel between guest and host. */\n keyIncarnationId?: number;\n /** Specifies the Wire Server endpoint settings while creating the virtual machine or virtual machine scale set. Minimum api-version: 2024-03-01. */\n wireServer?: HostEndpointSettings;\n /** Specifies the IMDS endpoint settings while creating the virtual machine or virtual machine scale set. Minimum api-version: 2024-03-01. */\n imds?: HostEndpointSettings;\n /** Specify whether to implicitly install the ProxyAgent Extension. This option is currently applicable only for Linux Os. */\n addProxyAgentExtension?: boolean;\n}\n\n/** Specifies particular host endpoint settings. */\nexport interface HostEndpointSettings {\n /** Specifies the execution mode. In Audit mode, the system acts as if it is enforcing the access control policy, including emitting access denial entries in the logs but it does not actually deny any requests to host endpoints. In Enforce mode, the system will enforce the access control and it is the recommended mode of operation. */\n mode?: Modes;\n /** Specifies the InVMAccessControlProfileVersion resource id in the format of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/inVMAccessControlProfiles/{profile}/versions/{version} */\n inVMAccessControlProfileReferenceId?: string;\n}\n\n/** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\nexport interface DiagnosticsProfile {\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. **NOTE**: If storageUri is being specified then ensure that the storage account is in the same region and subscription as the VM. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnostics;\n}\n\n/** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\nexport interface BootDiagnostics {\n /** Whether boot diagnostics should be enabled on the Virtual Machine. */\n enabled?: boolean;\n /** Uri of the storage account to use for placing the console output and screenshot. If storageUri is not specified while enabling boot diagnostics, managed storage will be used. */\n storageUri?: string;\n}\n\n/** Describes a virtual machine scale set extension profile. */\nexport interface VirtualMachineScaleSetExtensionProfile {\n /** The virtual machine scale set child extension resources. */\n extensions?: VirtualMachineScaleSetExtension[];\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). Minimum api-version: 2020-06-01. */\n extensionsTimeBudget?: string;\n}\n\n/** Describes a reference to Key Vault Secret */\nexport interface KeyVaultSecretReference {\n /** The URL referencing a secret in a Key Vault. */\n secretUrl: string;\n /** The relative URL of the Key Vault containing the secret. */\n sourceVault: SubResource;\n}\n\n/** Specifies the billing related details of a Azure Spot VM or VMSS. Minimum api-version: 2019-03-01. */\nexport interface BillingProfile {\n /** Specifies the maximum price you are willing to pay for a Azure Spot VM/VMSS. This price is in US Dollars. <br><br> This price will be compared with the current Azure Spot price for the VM size. Also, the prices are compared at the time of create/update of Azure Spot VM/VMSS and the operation will only succeed if the maxPrice is greater than the current Azure Spot price. <br><br> The maxPrice will also be used for evicting a Azure Spot VM/VMSS if the current Azure Spot price goes beyond the maxPrice after creation of VM/VMSS. <br><br> Possible values are: <br><br> - Any decimal value greater than zero. Example: 0.01538 <br><br> -1 – indicates default price to be up-to on-demand. <br><br> You can set the maxPrice to -1 to indicate that the Azure Spot VM/VMSS should not be evicted for price reasons. Also, the default max price is -1 if it is not provided by you. <br><br>Minimum api-version: 2019-03-01. */\n maxPrice?: number;\n}\n\nexport interface ScheduledEventsProfile {\n /** Specifies Terminate Scheduled Event related configurations. */\n terminateNotificationProfile?: TerminateNotificationProfile;\n /** Specifies OS Image Scheduled Event related configurations. */\n osImageNotificationProfile?: OSImageNotificationProfile;\n}\n\nexport interface TerminateNotificationProfile {\n /** Configurable length of time a Virtual Machine being deleted will have to potentially approve the Terminate Scheduled Event before the event is auto approved (timed out). The configuration must be specified in ISO 8601 format, the default value is 5 minutes (PT5M) */\n notBeforeTimeout?: string;\n /** Specifies whether the Terminate Scheduled event is enabled or disabled. */\n enable?: boolean;\n}\n\nexport interface OSImageNotificationProfile {\n /** Length of time a Virtual Machine being reimaged or having its OS upgraded will have to potentially approve the OS Image Scheduled Event before the event is auto approved (timed out). The configuration is specified in ISO 8601 format, and the value must be 15 minutes (PT15M) */\n notBeforeTimeout?: string;\n /** Specifies whether the OS Image Scheduled event is enabled or disabled. */\n enable?: boolean;\n}\n\n/** The parameters of a capacity reservation Profile. */\nexport interface CapacityReservationProfile {\n /** Specifies the capacity reservation group resource id that should be used for allocating the virtual machine or scaleset vm instances provided enough capacity has been reserved. Please refer to https://aka.ms/CapacityReservation for more details. */\n capacityReservationGroup?: SubResource;\n}\n\n/** Contains the list of gallery applications that should be made available to the VM/VMSS */\nexport interface ApplicationProfile {\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n galleryApplications?: VMGalleryApplication[];\n}\n\n/** Specifies the required information to reference a compute gallery application version */\nexport interface VMGalleryApplication {\n /** Optional, Specifies a passthrough value for more generic context. */\n tags?: string;\n /** Optional, Specifies the order in which the packages have to be installed */\n order?: number;\n /** Specifies the GalleryApplicationVersion resource id on the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/applications/{application}/versions/{version} */\n packageReferenceId: string;\n /** Optional, Specifies the uri to an azure blob that will replace the default configuration for the package if provided */\n configurationReference?: string;\n /** Optional, If true, any failure for any operation in the VmApplication will fail the deployment */\n treatFailureAsDeploymentFailure?: boolean;\n /** If set to true, when a new Gallery Application version is available in PIR/SIG, it will be automatically updated for the VM/VMSS */\n enableAutomaticUpgrade?: boolean;\n}\n\n/** Specifies the hardware settings for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetHardwareProfile {\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-11-01. Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizeProperties;\n}\n\n/** Specifies VM Size Property settings on the virtual machine. */\nexport interface VMSizeProperties {\n /** Specifies the number of vCPUs available for the VM. When this property is not specified in the request body the default behavior is to set it to the value of vCPUs available for that VM size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list). */\n vCPUsAvailable?: number;\n /** Specifies the vCPU to physical core ratio. When this property is not specified in the request body the default behavior is set to the value of vCPUsPerCore for the VM Size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list). **Setting this property to 1 also means that hyper-threading is disabled.** */\n vCPUsPerCore?: number;\n}\n\n/** Specifies the service artifact reference id used to set same image version for all virtual machines in the scale set when using 'latest' image version. Minimum api-version: 2022-11-01 */\nexport interface ServiceArtifactReference {\n /** The service artifact reference id in the form of /subscriptions/{subscriptionId}/resourceGroups/{resourceGroup}/providers/Microsoft.Compute/galleries/{galleryName}/serviceArtifacts/{serviceArtifactName}/vmArtifactsProfiles/{vmArtifactsProfilesName} */\n id?: string;\n}\n\n/** Specifies the security posture to be used in the scale set. Minimum api-version: 2023-03-01 */\nexport interface SecurityPostureReference {\n /** The security posture reference id in the form of /CommunityGalleries/{communityGalleryName}/securityPostures/{securityPostureName}/versions/{major.minor.patch}|latest */\n id: string;\n /** The list of virtual machine extension names to exclude when applying the security posture. */\n excludeExtensions?: string[];\n /** Whether the security posture can be overridden by the user. */\n isOverridable?: boolean;\n}\n\n/** Enables or disables a capability on the virtual machine or virtual machine scale set. */\nexport interface AdditionalCapabilities {\n /** The flag that enables or disables a capability to have one or more managed data disks with UltraSSD_LRS storage account type on the VM or VMSS. Managed disks with storage account type UltraSSD_LRS can be added to a virtual machine or virtual machine scale set only if this property is enabled. */\n ultraSSDEnabled?: boolean;\n /** The flag that enables or disables hibernation capability on the VM. */\n hibernationEnabled?: boolean;\n /** The flag enables the usage of FIPS 140-3 compliant cryptography on the protectedSettings of an extension. Learn more at: https://aka.ms/linuxagentfipssupport. */\n enableFips1403Encryption?: boolean;\n}\n\n/** Describes a scale-in policy for a virtual machine scale set. */\nexport interface ScaleInPolicy {\n /** The rules to be followed when scaling-in a virtual machine scale set. <br><br> Possible values are: <br><br> **Default** When a virtual machine scale set is scaled in, the scale set will first be balanced across zones if it is a zonal scale set. Then, it will be balanced across Fault Domains as far as possible. Within each Fault Domain, the virtual machines chosen for removal will be the newest ones that are not protected from scale-in. <br><br> **OldestVM** When a virtual machine scale set is being scaled-in, the oldest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the oldest virtual machines that are not protected will be chosen for removal. <br><br> **NewestVM** When a virtual machine scale set is being scaled-in, the newest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the newest virtual machines that are not protected will be chosen for removal. <br><br> */\n rules?: VirtualMachineScaleSetScaleInRules[];\n /** This property allows you to specify if virtual machines chosen for removal have to be force deleted when a virtual machine scale set is being scaled-in.(Feature in Preview) */\n forceDeletion?: boolean;\n /** This property allows you to prioritize the deletion of unhealthy and inactive VMs when a virtual machine scale set is being scaled-in.(Feature in Preview) */\n prioritizeUnhealthyVMs?: boolean;\n}\n\n/** Specifies the Spot-Try-Restore properties for the virtual machine scale set. With this property customer can enable or disable automatic restore of the evicted Spot VMSS VM instances opportunistically based on capacity availability and pricing constraint. */\nexport interface SpotRestorePolicy {\n /** Enables the Spot-Try-Restore feature where evicted VMSS SPOT instances will be tried to be restored opportunistically based on capacity availability and pricing constraints */\n enabled?: boolean;\n /** Timeout value expressed as an ISO 8601 time duration after which the platform will not try to restore the VMSS SPOT instances */\n restoreTimeout?: string;\n}\n\n/** Specifies the target splits for Spot and Regular priority VMs within a scale set with flexible orchestration mode. With this property the customer is able to specify the base number of regular priority VMs created as the VMSS flex instance scales out and the split between Spot and Regular priority VMs after this base target has been reached. */\nexport interface PriorityMixPolicy {\n /** The base number of regular priority VMs that will be created in this scale set as it scales out. */\n baseRegularPriorityCount?: number;\n /** The percentage of VM instances, after the base regular priority count has been reached, that are expected to use regular priority. */\n regularPriorityPercentageAboveBase?: number;\n}\n\n/** Describes an resiliency policy - AutomaticZoneRebalancingPolicy, ResilientVMCreationPolicy and/or ResilientVMDeletionPolicy. */\nexport interface ResiliencyPolicy {\n /** The configuration parameters used while performing resilient VM creation. */\n resilientVMCreationPolicy?: ResilientVMCreationPolicy;\n /** The configuration parameters used while performing resilient VM deletion. */\n resilientVMDeletionPolicy?: ResilientVMDeletionPolicy;\n /** The configuration parameters used while performing automatic AZ balancing. */\n automaticZoneRebalancingPolicy?: AutomaticZoneRebalancingPolicy;\n /** The configuration parameters used while performing zone allocation. */\n zoneAllocationPolicy?: ZoneAllocationPolicy;\n}\n\n/** The configuration parameters used while performing resilient VM creation. */\nexport interface ResilientVMCreationPolicy {\n /** Specifies whether resilient VM creation should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n}\n\n/** The configuration parameters used while performing resilient VM deletion. */\nexport interface ResilientVMDeletionPolicy {\n /** Specifies whether resilient VM deletion should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n}\n\n/** The configuration parameters used while performing automatic AZ balancing. */\nexport interface AutomaticZoneRebalancingPolicy {\n /** Specifies whether Automatic AZ Balancing should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n /** Type of rebalance strategy that will be used for rebalancing virtual machines in the scale set across availability zones. Default and only supported value for now is Recreate. */\n rebalanceStrategy?: RebalanceStrategy;\n /** Type of rebalance behavior that will be used for recreating virtual machines in the scale set across availability zones. Default and only supported value for now is CreateBeforeDelete. */\n rebalanceBehavior?: RebalanceBehavior;\n}\n\n/** The configuration parameters for zone allocation of a virtual machine scale set. */\nexport interface ZoneAllocationPolicy {\n /** The maximum number of availability zones to use if the ZonePlacementPolicy is 'Auto'. If not specified, all availability zones will be used. */\n maxZoneCount?: number;\n /** The configuration parameters used to limit the number of virtual machines per availability zone in the virtual machine scale set. */\n maxInstancePercentPerZonePolicy?: MaxInstancePercentPerZonePolicy;\n}\n\n/** The configuration parameters used to limit the number of virtual machines per availability zone in the virtual machine scale set. */\nexport interface MaxInstancePercentPerZonePolicy {\n /** Specifies whether maxInstancePercentPerZonePolicy should be enabled on the virtual machine scale set. */\n enabled?: boolean;\n /** Limit on the number of instances in each zone as a percentage of the total capacity of the virtual machine scale set. */\n value?: number;\n}\n\n/** Specifies the sku profile for the virtual machine scale set. With this property the customer is able to specify a list of VM sizes and an allocation strategy. */\nexport interface SkuProfile {\n /** Specifies the VM sizes for the virtual machine scale set. */\n vmSizes?: SkuProfileVMSize[];\n /** Specifies the allocation strategy for the virtual machine scale set based on which the VMs will be allocated. */\n allocationStrategy?: AllocationStrategy;\n}\n\n/** Specifies the VM Size. */\nexport interface SkuProfileVMSize {\n /** Specifies the name of the VM Size. */\n name?: string;\n /** Specifies the rank (a.k.a priority) associated with the VM Size. */\n rank?: number;\n}\n\n/** Identity for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetIdentity {\n /**\n * The principal id of virtual machine scale set identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The tenant id associated with the virtual machine scale set. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine scale set. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine scale set. */\n type?: ResourceIdentityType;\n /** The list of user identities associated with the virtual machine scale set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\nexport interface UserAssignedIdentitiesValue {\n /**\n * The principal id of user assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The client id of user assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly clientId?: string;\n}\n\n/** Describes the user-defined constraints for resource hardware placement. */\nexport interface Placement {\n /** Specifies the policy for resource's placement in availability zone. Possible values are: **Any** (used for Virtual Machines), **Auto** (used for Virtual Machine Scale Sets) - An availability zone will be automatically picked by system as part of resource creation. */\n zonePlacementPolicy?: ZonePlacementPolicyType;\n /** This property supplements the 'zonePlacementPolicy' property. If 'zonePlacementPolicy' is set to 'Any'/'Auto', availability zone selected by the system must be present in the list of availability zones passed with 'includeZones'. If 'includeZones' is not provided, all availability zones in region will be considered for selection. */\n includeZones?: string[];\n /** This property supplements the 'zonePlacementPolicy' property. If 'zonePlacementPolicy' is set to 'Any'/'Auto', availability zone selected by the system must not be present in the list of availability zones passed with 'excludeZones'. If 'excludeZones' is not provided, all availability zones in region will be considered for selection. */\n excludeZones?: string[];\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineListResult {\n /** The list of virtual machines. */\n value: VirtualMachine[];\n /** The URI to fetch the next page of VMs. Call ListNext() with this URI to fetch the next page of Virtual Machines. */\n nextLink?: string;\n}\n\n/** Specifies the hardware settings for the virtual machine. */\nexport interface HardwareProfile {\n /** Specifies the size of the virtual machine. The enum data type is currently deprecated and will be removed by December 23rd 2023. The recommended way to get the list of available sizes is using these APIs: [List all available virtual machine sizes in an availability set](https://docs.microsoft.com/rest/api/compute/availabilitysets/listavailablesizes), [List all available virtual machine sizes in a region]( https://docs.microsoft.com/rest/api/compute/resourceskus/list), [List all available virtual machine sizes for resizing](https://docs.microsoft.com/rest/api/compute/virtualmachines/listavailablesizes). For more information about virtual machine sizes, see [Sizes for virtual machines](https://docs.microsoft.com/azure/virtual-machines/sizes). The available VM sizes depend on region and availability set. */\n vmSize?: VirtualMachineSizeTypes;\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-07-01. This feature is still in preview mode and is not supported for VirtualMachineScaleSet. Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizeProperties;\n}\n\n/** Specifies the storage settings for the virtual machine disks. */\nexport interface StorageProfile {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReference;\n /** Specifies information about the operating system disk used by the virtual machine. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: OSDisk;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: DataDisk[];\n /** Specifies the disk controller type configured for the VM. **Note:** This property will be set to the default disk controller type if not specified provided virtual machine is being created with 'hyperVGeneration' set to V2 based on the capabilities of the operating system disk and VM size from the the specified minimum api version. You need to deallocate the VM before updating its disk controller type unless you are updating the VM size in the VM configuration which implicitly deallocates and reallocates the VM. Minimum api-version: 2022-08-01. */\n diskControllerType?: DiskControllerTypes;\n /** Specifies whether the regional disks should be aligned/moved to the VM zone. This is applicable only for VMs with placement property set. Please note that this change is irreversible. Minimum api-version: 2024-11-01. */\n alignRegionalDisksToVMZone?: boolean;\n}\n\n/** Specifies information about the operating system disk used by the virtual machine. For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\nexport interface OSDisk {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** Specifies the encryption settings for the OS Disk. Minimum api-version: 2015-06-15. */\n encryptionSettings?: DiskEncryptionSettings;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDisk;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDisk;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The defaulting behavior is: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies the ephemeral Disk Settings for the operating system disk used by the virtual machine. */\n diffDiskSettings?: DiffDiskSettings;\n /** Specifies how the virtual machine disk should be created. Possible values are **Attach:** This value is used when you are using a specialized disk to create the virtual machine. **FromImage:** This value is used when you are using an image to create the virtual machine. If you are using a platform image, you should also use the imageReference element described above. If you are using a marketplace image, you should also use the plan element previously described. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property 'diskSizeGB' is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParameters;\n /** Specifies whether OS Disk should be deleted or detached upon VM deletion. Possible values are: **Delete.** If this value is used, the OS disk is deleted when VM is deleted. **Detach.** If this value is used, the os disk is retained after VM is deleted. The default value is set to **Detach**. For an ephemeral OS Disk, the default value is set to **Delete**. The user cannot change the delete option for an ephemeral OS Disk. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes a Encryption Settings for a Disk */\nexport interface DiskEncryptionSettings {\n /** Specifies the location of the disk encryption key, which is a Key Vault Secret. */\n diskEncryptionKey?: KeyVaultSecretReference;\n /** Specifies the location of the key encryption key in Key Vault. */\n keyEncryptionKey?: KeyVaultKeyReference;\n /** Specifies whether disk encryption should be enabled on the virtual machine. */\n enabled?: boolean;\n}\n\n/** Describes a reference to Key Vault Key */\nexport interface KeyVaultKeyReference {\n /** The URL referencing a key encryption key in Key Vault. */\n keyUrl: string;\n /** The relative URL of the Key Vault containing the key. */\n sourceVault: SubResource;\n}\n\n/** Describes a data disk. */\nexport interface DataDisk {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDisk;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDisk;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The defaulting behavior is: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machine disk should be created. Possible values are **Attach:** This value is used when you are using a specialized disk to create the virtual machine. **FromImage:** This value is used when you are using an image to create the virtual machine data disk. If you are using a platform image, you should also use the imageReference element described above. If you are using a marketplace image, you should also use the plan element previously described. **Empty:** This value is used when creating an empty data disk. **Copy:** This value is used to create a data disk from a snapshot or another disk. **Restore:** This value is used to create a data disk from a disk restore point. */\n createOption: DiskCreateOptionTypes;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. The property 'diskSizeGB' is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023. */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParameters;\n /** The source resource identifier. It can be a snapshot, or disk restore point from which to create a disk. */\n sourceResource?: ApiEntityReference;\n /** Specifies whether the data disk is in process of detachment from the VirtualMachine/VirtualMachineScaleset */\n toBeDetached?: boolean;\n /** Specifies the Read-Write IOPS for the managed disk when StorageAccountType is UltraSSD_LRS. */\n diskIopsReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk when StorageAccountType is UltraSSD_LRS. */\n diskMBpsReadWrite?: number;\n /** Specifies the detach behavior to be used while detaching a disk or which is already in the process of detachment from the virtual machine. Supported values: **ForceDetach.** detachOption: **ForceDetach** is applicable only for managed data disks. If a previous detachment attempt of the data disk did not complete due to an unexpected failure from the virtual machine and the disk is still not released then use force-detach as a last resort option to detach the disk forcibly from the VM. All writes might not have been flushed when using this detach behavior. **This feature is still in preview**. To force-detach a data disk update toBeDetached to 'true' along with setting detachOption: 'ForceDetach'. */\n detachOption?: DiskDetachOptionTypes;\n /** Specifies whether data disk should be deleted or detached upon VM deletion. Possible values are: **Delete.** If this value is used, the data disk is deleted when VM is deleted. **Detach.** If this value is used, the data disk is retained after VM is deleted. The default value is set to **Detach**. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Specifies the operating system settings for the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\nexport interface OSProfile {\n /** Specifies the host OS name of the virtual machine. This name cannot be updated after the VM is created. **Max-length (Windows):** 15 characters. **Max-length (Linux):** 64 characters. For naming conventions and restrictions see [Azure infrastructure services implementation guidelines](https://docs.microsoft.com/azure/azure-resource-manager/management/resource-name-rules). */\n computerName?: string;\n /** Specifies the name of the administrator account. <br><br> This property cannot be updated after the VM is created. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters. */\n adminUsername?: string;\n /**\n * Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)\n * This value contains a credential. Consider obscuring before showing to users\n */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. **Note: Do not pass any secrets or passwords in customData property.** This property cannot be updated after the VM is created. The property 'customData' is passed to the VM to be saved as a file, for more information see [Custom Data on Azure VMs](https://azure.microsoft.com/blog/custom-data-and-cloud-init-on-windows-azure/). For using cloud-init for your Linux VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init). */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfiguration;\n /** Specifies the Linux operating system settings on the virtual machine. For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfiguration;\n /** Specifies set of certificates that should be installed onto the virtual machine. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: VaultSecretGroup[];\n /** Specifies whether extension operations should be allowed on the virtual machine. This may only be set to False when no extensions are present on the virtual machine. */\n allowExtensionOperations?: boolean;\n /** Optional property which must either be set to True or omitted. */\n requireGuestProvisionSignal?: boolean;\n}\n\n/** Specifies the network interfaces or the networking configuration of the virtual machine. */\nexport interface NetworkProfile {\n /** Specifies the list of resource Ids for the network interfaces associated with the virtual machine. */\n networkInterfaces?: NetworkInterfaceReference[];\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations */\n networkApiVersion?: NetworkApiVersion;\n /** Specifies the networking configurations that will be used to create the virtual machine networking resources. */\n networkInterfaceConfigurations?: VirtualMachineNetworkInterfaceConfiguration[];\n}\n\n/** Describes a virtual machine network interface configurations. */\nexport interface VirtualMachineNetworkInterfaceConfiguration {\n /** The network interface configuration name. */\n name: string;\n /** Resource tags applied to the networkInterface address created by this NetworkInterfaceConfiguration */\n tags?: { [propertyName: string]: string };\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResource;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineNetworkInterfaceDnsSettingsConfiguration;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations?: VirtualMachineNetworkInterfaceIPConfiguration[];\n dscpConfiguration?: SubResource;\n /** Specifies whether the Auxiliary mode is enabled for the Network Interface resource. */\n auxiliaryMode?: NetworkInterfaceAuxiliaryMode;\n /** Specifies whether the Auxiliary sku is enabled for the Network Interface resource. */\n auxiliarySku?: NetworkInterfaceAuxiliarySku;\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachineNetworkInterfaceDnsSettingsConfiguration {\n /** List of DNS servers IP addresses */\n dnsServers?: string[];\n}\n\n/** Describes a virtual machine network profile's IP configuration. */\nexport interface VirtualMachineNetworkInterfaceIPConfiguration {\n /** The IP configuration name. */\n name: string;\n /** Specifies the identifier of the subnet. */\n subnet?: SubResource;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachinePublicIPAddressConfiguration;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: IPVersions;\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: SubResource[];\n /** Specifies an array of references to backend address pools of application gateways. A virtual machine can reference backend address pools of multiple application gateways. Multiple virtual machines cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: SubResource[];\n /** Specifies an array of references to backend address pools of load balancers. A virtual machine can reference backend address pools of one public and one internal load balancer. [Multiple virtual machines cannot use the same basic sku load balancer]. */\n loadBalancerBackendAddressPools?: SubResource[];\n}\n\n/** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachinePublicIPAddressConfiguration {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSku;\n /** Resource tags applied to the publicIP address created by this PublicIPAddressConfiguration */\n tags?: { [propertyName: string]: string };\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** Specify what happens to the public IP address when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachinePublicIPAddressDnsSettingsConfiguration;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: VirtualMachineIpTag[];\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResource;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: IPVersions;\n /** Specify the public IP allocation type */\n publicIPAllocationMethod?: PublicIPAllocationMethod;\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachinePublicIPAddressDnsSettingsConfiguration {\n /** The Domain name label prefix of the PublicIPAddress resources that will be created. The generated name label is the concatenation of the domain name label and vm network profile unique ID. */\n domainNameLabel: string;\n /** The Domain name label scope of the PublicIPAddress resources that will be created. The generated name label is the concatenation of the hashed domain name label with policy according to the domain name label scope and vm network profile unique ID. */\n domainNameLabelScope?: DomainNameLabelScopeTypes;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineIpTag {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** The instance view of a virtual machine. */\nexport interface VirtualMachineInstanceView {\n /** Specifies the update domain of the virtual machine. */\n platformUpdateDomain?: number;\n /** Specifies the fault domain of the virtual machine. */\n platformFaultDomain?: number;\n /** The computer name assigned to the virtual machine. */\n computerName?: string;\n /** The Operating System running on the virtual machine. */\n osName?: string;\n /** The version of Operating System running on the virtual machine. */\n osVersion?: string;\n /** Specifies the HyperVGeneration Type associated with a resource */\n hyperVGeneration?: HyperVGenerationType;\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceView;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatus;\n /** The virtual machine disk information. */\n disks?: DiskInstanceView[];\n /** The extensions information. */\n extensions?: VirtualMachineExtensionInstanceView[];\n /**\n * The health status for the VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmHealth?: VirtualMachineHealthStatus;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceView;\n /**\n * Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. Minimum api-version: 2020-06-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assignedHost?: string;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n /** [Preview Feature] The status of virtual machine patch operations. */\n patchStatus?: VirtualMachinePatchStatus;\n /**\n * [Preview Feature] Specifies whether the VM is currently in or out of the Standby Pool.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isVMInStandbyPool?: boolean;\n}\n\n/** The instance view of the VM Agent running on the virtual machine. */\nexport interface VirtualMachineAgentInstanceView {\n /** The VM Agent full version. */\n vmAgentVersion?: string;\n /** The virtual machine extension handler instance view. */\n extensionHandlers?: VirtualMachineExtensionHandlerInstanceView[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The instance view of a virtual machine extension handler. */\nexport interface VirtualMachineExtensionHandlerInstanceView {\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The extension handler status. */\n status?: InstanceViewStatus;\n}\n\n/** Maintenance Operation Status. */\nexport interface MaintenanceRedeployStatus {\n /** True, if customer is allowed to perform Maintenance. */\n isCustomerInitiatedMaintenanceAllowed?: boolean;\n /** Start Time for the Pre Maintenance Window. */\n preMaintenanceWindowStartTime?: Date;\n /** End Time for the Pre Maintenance Window. */\n preMaintenanceWindowEndTime?: Date;\n /** Start Time for the Maintenance Window. */\n maintenanceWindowStartTime?: Date;\n /** End Time for the Maintenance Window. */\n maintenanceWindowEndTime?: Date;\n /** The Last Maintenance Operation Result Code. */\n lastOperationResultCode?: MaintenanceOperationResultCodeTypes;\n /** Message returned for the last Maintenance Operation. */\n lastOperationMessage?: string;\n}\n\n/** The instance view of the disk. */\nexport interface DiskInstanceView {\n /** The disk name. */\n name?: string;\n /** Specifies the encryption settings for the OS Disk. <br><br> Minimum api-version: 2015-06-15 */\n encryptionSettings?: DiskEncryptionSettings[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The instance view of a virtual machine extension. */\nexport interface VirtualMachineExtensionInstanceView {\n /** The virtual machine extension name. */\n name?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The resource status information. */\n substatuses?: InstanceViewStatus[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The health status of the VM. */\nexport interface VirtualMachineHealthStatus {\n /**\n * The health status information for the VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: InstanceViewStatus;\n}\n\n/** The instance view of a virtual machine boot diagnostics. */\nexport interface BootDiagnosticsInstanceView {\n /**\n * The console screenshot blob URI. **Note:** This will **not** be set if boot diagnostics is currently enabled with managed storage.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly consoleScreenshotBlobUri?: string;\n /**\n * The serial console log blob Uri. **Note:** This will **not** be set if boot diagnostics is currently enabled with managed storage.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serialConsoleLogBlobUri?: string;\n /**\n * The boot diagnostics status information for the VM. **Note:** It will be set only if there are errors encountered in enabling boot diagnostics.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: InstanceViewStatus;\n}\n\n/** The status of virtual machine patch operations. */\nexport interface VirtualMachinePatchStatus {\n /** The available patch summary of the latest assessment operation for the virtual machine. */\n availablePatchSummary?: AvailablePatchSummary;\n /** The installation summary of the latest installation operation for the virtual machine. */\n lastPatchInstallationSummary?: LastPatchInstallationSummary;\n /**\n * The enablement status of the specified patchMode\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly configurationStatuses?: InstanceViewStatus[];\n}\n\n/** Describes the properties of an virtual machine instance view for available patch summary. */\nexport interface AvailablePatchSummary {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assessmentActivityId?: string;\n /**\n * The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootPending?: boolean;\n /**\n * The number of critical or security patches that have been detected as available and not yet installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly criticalAndSecurityPatchCount?: number;\n /**\n * The number of all available patches excluding critical and security.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly otherPatchCount?: number;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastModifiedTime?: Date;\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Describes the properties of the last installed patch summary. */\nexport interface LastPatchInstallationSummary {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installationActivityId?: string;\n /**\n * Describes whether the operation ran out of time before it completed all its intended actions\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maintenanceWindowExceeded?: boolean;\n /**\n * The number of all available patches but not going to be installed because it didn't match a classification or inclusion list entry.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly notSelectedPatchCount?: number;\n /**\n * The number of all available patches but excluded explicitly by a customer-specified exclusion list match.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly excludedPatchCount?: number;\n /**\n * The number of all available patches expected to be installed over the course of the patch installation operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly pendingPatchCount?: number;\n /**\n * The count of patches that successfully installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installedPatchCount?: number;\n /**\n * The count of patches that failed installation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedPatchCount?: number;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastModifiedTime?: Date;\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Identity for the virtual machine. */\nexport interface VirtualMachineIdentity {\n /**\n * The principal id of virtual machine identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The tenant id associated with the virtual machine. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine. */\n type?: ResourceIdentityType;\n /** The list of user identities associated with the Virtual Machine. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineSizeListResult {\n /** The list of virtual machine sizes. */\n value?: VirtualMachineSize[];\n /** The link to the next page of items. */\n nextLink?: string;\n}\n\n/** Describes the properties of a VM size. */\nexport interface VirtualMachineSize {\n /** The name of the virtual machine size. */\n name?: string;\n /** The number of cores supported by the virtual machine size. For Constrained vCPU capable VM sizes, this number represents the total vCPUs of quota that the VM uses. For accurate vCPU count, please refer to https://docs.microsoft.com/azure/virtual-machines/constrained-vcpu or https://docs.microsoft.com/rest/api/compute/resourceskus/list */\n numberOfCores?: number;\n /** The OS disk size, in MB, allowed by the virtual machine size. */\n osDiskSizeInMB?: number;\n /** The resource disk size, in MB, allowed by the virtual machine size. */\n resourceDiskSizeInMB?: number;\n /** The amount of memory, in MB, supported by the virtual machine size. */\n memoryInMB?: number;\n /** The maximum number of data disks that can be attached to the virtual machine size. */\n maxDataDiskCount?: number;\n}\n\n/** The List Proximity Placement Group operation response. */\nexport interface ProximityPlacementGroupListResult {\n /** The list of proximity placement groups. */\n value: ProximityPlacementGroup[];\n /** The URI to fetch the next page of proximity placement groups. */\n nextLink?: string;\n}\n\n/** Specifies the user intent of the proximity placement group. */\nexport interface ProximityPlacementGroupPropertiesIntent {\n /** Specifies possible sizes of virtual machines that can be created in the proximity placement group. */\n vmSizes?: string[];\n}\n\n/** The List restore point collection operation response. */\nexport interface RestorePointCollectionListResult {\n /** Gets the list of restore point collections. */\n value: RestorePointCollection[];\n /** The uri to fetch the next page of RestorePointCollections. Call ListNext() with this to fetch the next page of RestorePointCollections. */\n nextLink?: string;\n}\n\n/** The properties of the source resource that this restore point collection is created from. */\nexport interface RestorePointCollectionSourceProperties {\n /**\n * Location of the source resource used to create this restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** Resource Id of the source resource used to create this restore point collection */\n id?: string;\n}\n\n/** Describes the properties of the Virtual Machine for which the restore point was created. The properties provided are a subset and the snapshot of the overall Virtual Machine properties captured at the time of the restore point creation. */\nexport interface RestorePointSourceMetadata {\n /**\n * Gets the hardware profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hardwareProfile?: HardwareProfile;\n /** Gets the storage profile. */\n storageProfile?: RestorePointSourceVMStorageProfile;\n /**\n * Gets the OS profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly osProfile?: OSProfile;\n /**\n * Gets the diagnostics profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diagnosticsProfile?: DiagnosticsProfile;\n /**\n * Gets the license type, which is for bring your own license scenario.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly licenseType?: string;\n /**\n * Gets the virtual machine unique id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /**\n * Gets the security profile.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly securityProfile?: SecurityProfile;\n /**\n * Location of the VM from which the restore point was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * UserData associated with the source VM for which restore point is captured, which is a base-64 encoded value.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly userData?: string;\n /**\n * HyperVGeneration of the source VM for which restore point is captured.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hyperVGeneration?: HyperVGenerationTypes;\n}\n\n/** Describes the storage profile. */\nexport interface RestorePointSourceVMStorageProfile {\n /** Gets the OS disk of the VM captured at the time of the restore point creation. */\n osDisk?: RestorePointSourceVmosDisk;\n /** Gets the data disks of the VM captured at the time of the restore point creation. */\n dataDisks?: RestorePointSourceVMDataDisk[];\n /**\n * Gets the disk controller type of the VM captured at the time of the restore point creation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskControllerType?: DiskControllerTypes;\n}\n\n/** Describes an Operating System disk. */\nexport interface RestorePointSourceVmosDisk {\n /**\n * Gets the Operating System type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly osType?: OperatingSystemType;\n /**\n * Gets the disk encryption settings.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly encryptionSettings?: DiskEncryptionSettings;\n /**\n * Gets the disk name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Gets the caching type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly caching?: CachingTypes;\n /**\n * Gets the disk size in GB.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeGB?: number;\n /** Gets the managed disk details */\n managedDisk?: ManagedDiskParameters;\n /** Contains Disk Restore Point properties. */\n diskRestorePoint?: DiskRestorePointAttributes;\n /**\n * Shows true if the disk is write-accelerator enabled.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly writeAcceleratorEnabled?: boolean;\n}\n\n/** Encryption at rest settings for disk restore point. It is an optional property that can be specified in the input while creating a restore point. */\nexport interface RestorePointEncryption {\n /** Describes the parameter of customer managed disk encryption set resource id that can be specified for disk. **Note:** The disk encryption set resource id can only be specified for managed disk. Please refer https://aka.ms/mdssewithcmkoverview for more details. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** The type of key used to encrypt the data of the disk restore point. */\n type?: RestorePointEncryptionType;\n}\n\n/** Describes a data disk. */\nexport interface RestorePointSourceVMDataDisk {\n /**\n * Gets the logical unit number.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lun?: number;\n /**\n * Gets the disk name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Gets the caching type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly caching?: CachingTypes;\n /**\n * Gets the initial disk size in GB for blank data disks, and the new desired size for existing OS and Data disks.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeGB?: number;\n /** Contains the managed disk details. */\n managedDisk?: ManagedDiskParameters;\n /** Contains Disk Restore Point properties. */\n diskRestorePoint?: DiskRestorePointAttributes;\n /**\n * Shows true if the disk is write-accelerator enabled.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly writeAcceleratorEnabled?: boolean;\n}\n\n/** The instance view of a restore point. */\nexport interface RestorePointInstanceView {\n /** The disk restore points information. */\n diskRestorePoints?: DiskRestorePointInstanceView[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointInstanceView {\n /** Disk restore point Id. */\n id?: string;\n /** The state of snapshot which determines the access availability of the snapshot. */\n snapshotAccessState?: SnapshotAccessState;\n /** The disk restore point replication status information. */\n replicationStatus?: DiskRestorePointReplicationStatus;\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointReplicationStatus {\n /** The resource status information. */\n status?: InstanceViewStatus;\n /** Replication completion percentage. */\n completionPercent?: number;\n}\n\n/** The list SSH public keys operation response. */\nexport interface SshPublicKeysGroupListResult {\n /** The list of SSH public keys. */\n value: SshPublicKeyResource[];\n /** The URI to fetch the next page of SSH public keys. Call ListNext() with this URI to fetch the next page of SSH public keys. */\n nextLink?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListWithLinkResult {\n /** The list of virtual machine scale sets. */\n value: VirtualMachineScaleSet[];\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of Virtual Machine Scale Sets. */\n nextLink?: string;\n}\n\n/** The Update Resource model definition. */\nexport interface UpdateResource {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** Describes the Virtual Machine Scale Set to convert from Availability Set. */\nexport interface ConvertToVirtualMachineScaleSetInput {\n /** Specifies information about the Virtual Machine Scale Set that the Availability Set should be converted to. */\n virtualMachineScaleSetName?: string;\n}\n\n/** Describes the Virtual Machine Scale Set to migrate from Availability Set. */\nexport interface MigrateToVirtualMachineScaleSetInput {\n /** Specifies information about the Virtual Machine Scale Set that the Availability Set should be migrated to. Minimum api‐version: 2024‐11‐01. */\n virtualMachineScaleSetFlexible: SubResource;\n}\n\n/** The list capacity reservation operation response. */\nexport interface CapacityReservationListResult {\n /** The list of capacity reservations. */\n value: CapacityReservation[];\n /** The URI to fetch the next page of capacity reservations. Call ListNext() with this URI to fetch the next page of capacity reservations. */\n nextLink?: string;\n}\n\n/** Defines the schedule for Block-type capacity reservations. Specifies the schedule during which capacity reservation is active and VM or VMSS resource can be allocated using reservation. This property is required and only supported when the capacity reservation group type is 'Block'. The scheduleProfile, start, and end fields are immutable after creation. Minimum API version: 2025-04-01. Please refer to https://aka.ms/blockcapacityreservation for more details. */\nexport interface ScheduleProfile {\n /** The required start date for block capacity reservations. Must be today or within 56 days in the future. For same-day scheduling, requests must be submitted before 11:30 AM UTC. Example: 2025-06-27. */\n start?: string;\n /** The required end date for block capacity reservations. Must be after the start date, with a duration of either 1–14 whole days or 3–26 whole weeks. Example: 2025-06-28. */\n end?: string;\n}\n\n/** The list dedicated host operation response. */\nexport interface DedicatedHostListResult {\n /** The list of dedicated hosts. */\n value: DedicatedHost[];\n /** The URI to fetch the next page of dedicated hosts. Call ListNext() with this URI to fetch the next page of dedicated hosts. */\n nextLink?: string;\n}\n\n/** The List Dedicated Host sizes operation response. */\nexport interface DedicatedHostSizeListResult {\n /** The list of dedicated host sizes. */\n value?: string[];\n /** The link to the next page of items. */\n nextLink?: string;\n}\n\n/** Parameters for GenerateSshKeyPair. */\nexport interface SshGenerateKeyPairInputParameters {\n /** The encryption type of the SSH keys to be generated. See SshEncryptionTypes for possible set of values. If not provided, will default to RSA */\n encryptionType?: SshEncryptionTypes;\n}\n\n/** Response from generation of an SSH key pair. */\nexport interface SshPublicKeyGenerateKeyPairResult {\n /** Private key portion of the key pair used to authenticate to a virtual machine through ssh. The private key is returned in RFC3447 format and should be treated as a secret. */\n privateKey: string;\n /** Public key portion of the key pair used to authenticate to a virtual machine through ssh. The public key is in ssh-rsa format. */\n publicKey: string;\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/sshPublicKeys/{SshPublicKeyName} */\n id: string;\n}\n\n/** Describes a virtual machine scale set virtual machine profile. */\nexport interface VirtualMachineScaleSetUpdateVMProfile {\n /** The virtual machine scale set OS profile. */\n osProfile?: VirtualMachineScaleSetUpdateOSProfile;\n /** The virtual machine scale set storage profile. */\n storageProfile?: VirtualMachineScaleSetUpdateStorageProfile;\n /** The virtual machine scale set network profile. */\n networkProfile?: VirtualMachineScaleSetUpdateNetworkProfile;\n /** The virtual machine scale set security posture reference. */\n securityPostureReference?: SecurityPostureReferenceUpdate;\n /** The virtual machine scale set Security profile */\n securityProfile?: SecurityProfile;\n /** The virtual machine scale set diagnostics profile. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** The virtual machine scale set extension profile. */\n extensionProfile?: VirtualMachineScaleSetExtensionProfile;\n /** The license type, which is for bring your own license scenario. */\n licenseType?: string;\n /** Specifies the billing related details of a Azure Spot VMSS. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n /** Specifies the hardware profile related details of a scale set. Minimum api-version: 2021-11-01. */\n hardwareProfile?: VirtualMachineScaleSetHardwareProfile;\n}\n\n/** Describes a virtual machine scale set OS profile. */\nexport interface VirtualMachineScaleSetUpdateOSProfile {\n /** A base-64 encoded string of custom data. */\n customData?: string;\n /** The Windows Configuration of the OS profile. */\n windowsConfiguration?: WindowsConfiguration;\n /** The Linux Configuration of the OS profile. */\n linuxConfiguration?: LinuxConfiguration;\n /** The List of certificates for addition to the VM. */\n secrets?: VaultSecretGroup[];\n}\n\n/** Describes a virtual machine scale set storage profile. */\nexport interface VirtualMachineScaleSetUpdateStorageProfile {\n /** The image reference. */\n imageReference?: ImageReference;\n /** The OS disk. */\n osDisk?: VirtualMachineScaleSetUpdateOSDisk;\n /** The data disks. */\n dataDisks?: VirtualMachineScaleSetDataDisk[];\n /** Specifies the disk controller type configured for the virtual machines in the scale set. **Note:** You need to deallocate the virtual machines in the scale set before updating its disk controller type based on the upgrade mode configured for the scale set. Minimum api-version: 2022-08-01 */\n diskControllerType?: DiskControllerTypes;\n}\n\n/** Describes virtual machine scale set operating system disk Update Object. This should be used for Updating VMSS OS Disk. */\nexport interface VirtualMachineScaleSetUpdateOSDisk {\n /** The caching type. */\n caching?: CachingTypes;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies the ephemeral disk Settings for the operating system disk used by the virtual machine scale set. */\n diffDiskSettings?: DiffDiskSettings;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The Source User Image VirtualHardDisk. This VirtualHardDisk will be copied before using it to attach to the Virtual Machine. If SourceImage is provided, the destination VirtualHardDisk should not exist. */\n image?: VirtualHardDisk;\n /** The list of virtual hard disk container uris. */\n vhdContainers?: string[];\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParameters;\n /** Specifies whether OS Disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only). <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the OS disk is retained after VMSS Flex VM is deleted. <br><br> The default value is set to **Delete**. For an Ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for Ephemeral OS Disk. */\n deleteOption?: DiskDeleteOptionTypes;\n}\n\n/** Describes a virtual machine scale set network profile. */\nexport interface VirtualMachineScaleSetUpdateNetworkProfile {\n /** A reference to a load balancer probe used to determine the health of an instance in the virtual machine scale set. The reference will be in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'. */\n healthProbe?: ApiEntityReference;\n /** The list of network configurations. */\n networkInterfaceConfigurations?: VirtualMachineScaleSetUpdateNetworkConfiguration[];\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations for Virtual Machine Scale Set with orchestration mode 'Flexible' */\n networkApiVersion?: NetworkApiVersion;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetUpdateNetworkConfiguration {\n /** The network configuration name. */\n name?: string;\n /** Resource tags applied to the networkInterface address created by this NetworkInterfaceConfiguration */\n tags?: { [propertyName: string]: string };\n /** Whether this is a primary NIC on a virtual machine. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResource;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettings;\n /** The virtual machine scale set IP Configuration. */\n ipConfigurations?: VirtualMachineScaleSetUpdateIPConfiguration[];\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n /** Specifies whether the Auxiliary mode is enabled for the Network Interface resource. */\n auxiliaryMode?: NetworkInterfaceAuxiliaryMode;\n /** Specifies whether the Auxiliary sku is enabled for the Network Interface resource. */\n auxiliarySku?: NetworkInterfaceAuxiliarySku;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. NOTE: The subnet of a scale set may be modified as long as the original subnet and the new subnet are in the same virtual network */\nexport interface VirtualMachineScaleSetUpdateIPConfiguration {\n /** The IP configuration name. */\n name?: string;\n /** The subnet. */\n subnet?: ApiEntityReference;\n /** Specifies the primary IP Configuration in case the network interface has more than one IP Configuration. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetUpdatePublicIPAddressConfiguration;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: IPVersion;\n /** The application gateway backend address pools. */\n applicationGatewayBackendAddressPools?: SubResource[];\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: SubResource[];\n /** The load balancer backend address pools. */\n loadBalancerBackendAddressPools?: SubResource[];\n /** The load balancer inbound nat pools. */\n loadBalancerInboundNatPools?: SubResource[];\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetUpdatePublicIPAddressConfiguration {\n /** The publicIP address configuration name. */\n name?: string;\n /** Resource tags applied to the publicIP address created by this PublicIPAddressConfiguration */\n tags?: { [propertyName: string]: string };\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettings;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResource;\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: DeleteOptions;\n}\n\n/** Specifies the security posture to be used in the scale set. Minimum api-version: 2023-03-01 */\nexport interface SecurityPostureReferenceUpdate {\n /** The security posture reference id in the form of /CommunityGalleries/{communityGalleryName}/securityPostures/{securityPostureName}/versions/{major.minor.patch}|latest */\n id?: string;\n /** The list of virtual machine extension names to exclude when applying the security posture. */\n excludeExtensions?: string[];\n /** Whether the security posture can be overridden by the user. */\n isOverridable?: boolean;\n}\n\n/** Specifies a list of virtual machine instance IDs from the VM scale set. */\nexport interface VirtualMachineScaleSetVMInstanceIDs {\n /** The virtual machine scale set instance ids. Omitting the virtual machine scale set instance ids will result in the operation being performed on all virtual machines in the virtual machine scale set. */\n instanceIds?: string[];\n}\n\nexport interface VMScaleSetConvertToSinglePlacementGroupInput {\n /** Id of the placement group in which you want future virtual machine instances to be placed. To query placement group Id, please use Virtual Machine Scale Set VMs - Get API. If not provided, the platform will choose one with maximum number of virtual machine instances. */\n activePlacementGroupId?: string;\n}\n\n/** Specifies a list of virtual machine instance IDs from the VM scale set. */\nexport interface VirtualMachineScaleSetVMInstanceRequiredIDs {\n /** The virtual machine scale set instance ids. */\n instanceIds: string[];\n}\n\n/** The List VM scale set extension operation response. */\nexport interface VirtualMachineScaleSetExtensionListResult {\n /** The list of VM scale set extensions. */\n value: VirtualMachineScaleSetExtension[];\n /** The uri to fetch the next page of VM scale set extensions. Call ListNext() with this to fetch the next page of VM scale set extensions. */\n nextLink?: string;\n}\n\n/** Response after calling a manual recovery walk */\nexport interface RecoveryWalkResponse {\n /**\n * Whether the recovery walk was performed\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly walkPerformed?: boolean;\n /**\n * The next update domain that needs to be walked. Null means walk spanning all update domains has been completed\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly nextPlatformUpdateDomain?: number;\n}\n\n/** The instance view of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceView {\n /**\n * The instance view status summary for the virtual machine scale set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachine?: VirtualMachineScaleSetInstanceViewStatusesSummary;\n /**\n * The extensions information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly extensions?: VirtualMachineScaleSetVMExtensionsSummary[];\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n /**\n * The orchestration services information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly orchestrationServices?: OrchestrationServiceSummary[];\n}\n\n/** Instance view statuses summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceViewStatusesSummary {\n /**\n * The extensions information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statusesSummary?: VirtualMachineStatusCodeCount[];\n}\n\n/** The status code and count of the virtual machine scale set instance view status summary. */\nexport interface VirtualMachineStatusCodeCount {\n /**\n * The instance view status code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * The number of instances having a particular status code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly count?: number;\n}\n\n/** Extensions summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetVMExtensionsSummary {\n /**\n * The extension name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The extensions information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statusesSummary?: VirtualMachineStatusCodeCount[];\n}\n\n/** Summary for an orchestration service of a virtual machine scale set. */\nexport interface OrchestrationServiceSummary {\n /**\n * The name of the service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serviceName?: OrchestrationServiceNames;\n /**\n * The current state of the service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serviceState?: OrchestrationServiceState;\n /**\n * The latest operation status of the service. Minimum API version for this property is 2025-04-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly latestOperationStatus?: OrchestrationServiceOperationStatus;\n /**\n * The last UTC time when the operation status changed. Minimum API version for this property is 2025-04-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastStatusChangeTime?: Date;\n}\n\n/** List of Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface VirtualMachineScaleSetListOSUpgradeHistory {\n /** The list of OS upgrades performed on the virtual machine scale set. */\n value: UpgradeOperationHistoricalStatusInfo[];\n /** The uri to fetch the next page of OS Upgrade History. Call ListNext() with this to fetch the next page of history of upgrades. */\n nextLink?: string;\n}\n\n/** Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface UpgradeOperationHistoricalStatusInfo {\n /**\n * Information about the properties of the upgrade operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly properties?: UpgradeOperationHistoricalStatusInfoProperties;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n}\n\n/** Describes each OS upgrade on the Virtual Machine Scale Set. */\nexport interface UpgradeOperationHistoricalStatusInfoProperties {\n /**\n * Information about the overall status of the upgrade operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly runningStatus?: UpgradeOperationHistoryStatus;\n /**\n * Counts of the VMs in each state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly progress?: RollingUpgradeProgressInfo;\n /**\n * Error Details for this upgrade if there are any.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n /**\n * Invoker of the Upgrade Operation\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startedBy?: UpgradeOperationInvoker;\n /**\n * Image Reference details\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly targetImageReference?: ImageReference;\n /**\n * Information about OS rollback if performed\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rollbackInfo?: RollbackStatusInfo;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface UpgradeOperationHistoryStatus {\n /**\n * Code indicating the current status of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: UpgradeState;\n /**\n * Start time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * End time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly endTime?: Date;\n}\n\n/** Information about the number of virtual machine instances in each upgrade state. */\nexport interface RollingUpgradeProgressInfo {\n /**\n * The number of instances that have been successfully upgraded.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly successfulInstanceCount?: number;\n /**\n * The number of instances that have failed to be upgraded successfully.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedInstanceCount?: number;\n /**\n * The number of instances that are currently being upgraded.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly inProgressInstanceCount?: number;\n /**\n * The number of instances that have not yet begun to be upgraded.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly pendingInstanceCount?: number;\n}\n\n/** Information about rollback on failed VM instances after a OS Upgrade operation. */\nexport interface RollbackStatusInfo {\n /**\n * The number of instances which have been successfully rolled back.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly successfullyRolledbackInstanceCount?: number;\n /**\n * The number of instances which failed to rollback.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedRolledbackInstanceCount?: number;\n /**\n * Error details if OS rollback failed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rollbackError?: ApiError;\n}\n\n/** Parameters for Reimaging Virtual Machine. NOTE: Virtual Machine OS disk will always be reimaged */\nexport interface VirtualMachineReimageParameters {\n /** Specifies whether to reimage temp disk. Default value: false. Note: This temp disk reimage parameter is only supported for VM/VMSS with Ephemeral OS disk. */\n tempDisk?: boolean;\n /** Specifies in decimal number, the version the OS disk should be reimaged to. If exact version is not provided, the OS disk is reimaged to the existing version of OS Disk. */\n exactVersion?: string;\n /** Specifies information required for reimaging the non-ephemeral OS disk. */\n osProfile?: OSProfileProvisioningData;\n}\n\n/** Additional parameters for Reimaging Non-Ephemeral Virtual Machine. */\nexport interface OSProfileProvisioningData {\n /**\n * Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)\n * This value contains a credential. Consider obscuring before showing to users\n */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. **Note: Do not pass any secrets or passwords in customData property.** This property cannot be updated after the VM is created. The property customData is passed to the VM to be saved as a file, for more information see [Custom Data on Azure VMs](https://azure.microsoft.com/blog/custom-data-and-cloud-init-on-windows-azure/). If using cloud-init for your Linux VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init). */\n customData?: string;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface RollingUpgradeRunningStatus {\n /**\n * Code indicating the current status of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: RollingUpgradeStatusCode;\n /**\n * Start time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startTime?: Date;\n /**\n * The last action performed on the rolling upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastAction?: RollingUpgradeActionType;\n /**\n * Last action time of the upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastActionTime?: Date;\n}\n\n/** The input for ScaleOut */\nexport interface VMScaleSetScaleOutInput {\n /** Specifies the number of virtual machines in the scale set. */\n capacity: number;\n /** The input properties for ScaleOut */\n properties?: VMScaleSetScaleOutInputProperties;\n}\n\n/** The input properties for ScaleOut */\nexport interface VMScaleSetScaleOutInputProperties {\n /** The zone in which the scale out is requested for the virtual machine scale set. */\n zone?: string;\n}\n\n/** The input for OrchestrationServiceState */\nexport interface OrchestrationServiceStateInput {\n /** The name of the service. */\n serviceName: OrchestrationServiceNames;\n /** The action to be performed. */\n action: OrchestrationServiceStateAction;\n}\n\n/** The Virtual Machine Scale Set List Skus operation response. */\nexport interface VirtualMachineScaleSetListSkusResult {\n /** The list of skus available for the virtual machine scale set. */\n value: VirtualMachineScaleSetSku[];\n /** The uri to fetch the next page of Virtual Machine Scale Set Skus. Call ListNext() with this to fetch the next page of VMSS Skus. */\n nextLink?: string;\n}\n\n/** Describes an available virtual machine scale set sku. */\nexport interface VirtualMachineScaleSetSku {\n /**\n * The type of resource the sku applies to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resourceType?: string;\n /**\n * The Sku.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sku?: Sku;\n /**\n * Specifies the number of virtual machines in the scale set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacity?: VirtualMachineScaleSetSkuCapacity;\n}\n\n/** Describes scaling information of a sku. */\nexport interface VirtualMachineScaleSetSkuCapacity {\n /**\n * The minimum capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly minimum?: number;\n /**\n * The maximum capacity that can be set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maximum?: number;\n /**\n * The default capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly defaultCapacity?: number;\n /**\n * The scale type applicable to the sku.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly scaleType?: VirtualMachineScaleSetSkuScaleType;\n}\n\n/** The List Virtual Machine Scale Set VMs operation response. */\nexport interface VirtualMachineScaleSetVMListResult {\n /** The list of virtual machine scale sets VMs. */\n value: VirtualMachineScaleSetVM[];\n /** The uri to fetch the next page of Virtual Machine Scale Set VMs. Call ListNext() with this to fetch the next page of VMSS VMs. */\n nextLink?: string;\n}\n\n/** The instance view of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMInstanceView {\n /** The Update Domain count. */\n platformUpdateDomain?: number;\n /** The Fault Domain count. */\n platformFaultDomain?: number;\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceView;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatus;\n /** The disks information. */\n disks?: DiskInstanceView[];\n /** The extensions information. */\n extensions?: VirtualMachineExtensionInstanceView[];\n /**\n * The health status for the VM.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmHealth?: VirtualMachineHealthStatus;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. You can easily view the output of your console log. Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceView;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n /**\n * Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. Minimum api-version: 2020-06-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assignedHost?: string;\n /** The placement group in which the VM is running. If the VM is deallocated it will not have a placementGroupId. */\n placementGroupId?: string;\n /** Specifies the host OS name of the virtual machine. <br><br> This name cannot be updated after the VM is created. <br><br> **Max-length (Windows):** 15 characters <br><br> **Max-length (Linux):** 64 characters. <br><br> For naming conventions and restrictions see [Azure infrastructure services implementation guidelines](https://docs.microsoft.com/azure/virtual-machines/virtual-machines-linux-infrastructure-subscription-accounts-guidelines?toc=%2fazure%2fvirtual-machines%2flinux%2ftoc.json#1-naming-conventions). */\n computerName?: string;\n /** The Operating System running on the hybrid machine. */\n osName?: string;\n /** The version of Operating System running on the hybrid machine. */\n osVersion?: string;\n /** The hypervisor generation of the Virtual Machine [V1, V2] */\n hyperVGeneration?: HyperVGeneration;\n}\n\n/** Describes a virtual machine scale set VM network profile. */\nexport interface VirtualMachineScaleSetVMNetworkProfileConfiguration {\n /** The list of network configurations. */\n networkInterfaceConfigurations?: VirtualMachineScaleSetNetworkConfiguration[];\n}\n\n/** The protection policy of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMProtectionPolicy {\n /** Indicates that the virtual machine scale set VM shouldn't be considered for deletion during a scale-in operation. */\n protectFromScaleIn?: boolean;\n /** Indicates that model updates or actions (including scale-in) initiated on the virtual machine scale set should not be applied to the virtual machine scale set VM. */\n protectFromScaleSetActions?: boolean;\n}\n\n/** Specifies the input for attaching and detaching a list of managed data disks. */\nexport interface AttachDetachDataDisksRequest {\n /** The list of managed data disks to be attached. */\n dataDisksToAttach?: DataDisksToAttach[];\n /** The list of managed data disks to be detached. */\n dataDisksToDetach?: DataDisksToDetach[];\n}\n\n/** Describes the data disk to be attached. */\nexport interface DataDisksToAttach {\n /** ID of the managed data disk. */\n diskId: string;\n /** The logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. If not specified, lun would be auto assigned. */\n lun?: number;\n /** Specifies the caching requirements. Possible values are: **None,** **ReadOnly,** **ReadWrite.** The defaulting behavior is: **None for Standard storage. ReadOnly for Premium storage.** */\n caching?: CachingTypes;\n /** Specifies whether data disk should be deleted or detached upon VM deletion. Possible values are: **Delete.** If this value is used, the data disk is deleted when VM is deleted. **Detach.** If this value is used, the data disk is retained after VM is deleted. The default value is set to **Detach**. */\n deleteOption?: DiskDeleteOptionTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n}\n\n/** Describes the data disk to be detached. */\nexport interface DataDisksToDetach {\n /** ID of the managed data disk. */\n diskId: string;\n /** Supported options available for Detach of a disk from a VM. Refer to DetachOption object reference for more details. */\n detachOption?: DiskDetachOptionTypes;\n}\n\n/** The List VMSS VM Extension operation response */\nexport interface VirtualMachineScaleSetVMExtensionsListResult {\n /** The list of VMSS VM extensions */\n value?: VirtualMachineScaleSetVMExtension[];\n}\n\n/** The SAS URIs of the console screenshot and serial log blobs. */\nexport interface RetrieveBootDiagnosticsDataResult {\n /**\n * The console screenshot blob URI\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly consoleScreenshotBlobUri?: string;\n /**\n * The serial console log blob URI.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly serialConsoleLogBlobUri?: string;\n}\n\n/** Capture Virtual Machine parameters. */\nexport interface RunCommandInput {\n /** Specifies a commandId of predefined built-in script. Command IDs available for Linux are listed at https://aka.ms/RunCommandManagedLinux#available-commands, Windows at https://aka.ms/RunCommandManagedWindows#available-commands. */\n commandId: string;\n /** Optional. The script to be executed. When this value is given, the given script will override the default script of the command. */\n script?: string[];\n /** The run command parameters. */\n parameters?: RunCommandInputParameter[];\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandInputParameter {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter value. */\n value: string;\n}\n\nexport interface RunCommandResult {\n /** Run command operation response. */\n value?: InstanceViewStatus[];\n}\n\n/** The List run command operation response */\nexport interface VirtualMachineRunCommandsListResult {\n /** The list of run commands. */\n value: VirtualMachineRunCommand[];\n /** The uri to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Describes the script sources for run command. Use only one of these script sources: script, scriptUri, commandId, galleryScriptReferenceId. */\nexport interface VirtualMachineRunCommandScriptSource {\n /** Specifies the script content to be executed on the VM. */\n script?: string;\n /** Specifies the script download location. It can be either SAS URI of an Azure storage blob with read access or public URI. */\n scriptUri?: string;\n /** Specifies a commandId of predefined built-in script. Command IDs available for Linux are listed at https://aka.ms/RunCommandManagedLinux#available-commands, Windows at https://aka.ms/RunCommandManagedWindows#available-commands. */\n commandId?: string;\n /** User-assigned managed identity that has access to scriptUri in case of Azure storage blob. Use an empty object in case of system-assigned identity. Make sure the Azure storage blob exists, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged. */\n scriptUriManagedIdentity?: RunCommandManagedIdentity;\n /** Optional. Specify which shell to use for running the script. These values must match those expected by the extension. Currently supported only for Windows VMs, script uses Powershell 7 when specified. Powershell 7 must be already installed on the machine to use Powershell7 parameter value. */\n scriptShell?: ScriptShellTypes;\n /** The resource ID of a Gallery Script version that needs to be executed. Example ID looks like /subscriptions/{subId}/resourceGroups/{rgName}/providers/Microsoft.Compute/galleries/{galleryName}/scripts/{scriptName}/versions/{version}. */\n galleryScriptReferenceId?: string;\n}\n\n/** Contains clientId or objectId (use only one, not both) of a user-assigned managed identity that has access to storage blob used in Run Command. Use an empty RunCommandManagedIdentity object in case of system-assigned identity. Make sure the Azure storage blob exists in case of scriptUri, and managed identity has been given access to blob's container with 'Storage Blob Data Reader' role assignment with scriptUri blob and 'Storage Blob Data Contributor' for Append blobs(outputBlobUri, errorBlobUri). In case of user assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged. */\nexport interface RunCommandManagedIdentity {\n /** Client Id (GUID value) of the user-assigned managed identity. ObjectId should not be used if this is provided. */\n clientId?: string;\n /** Object Id (GUID value) of the user-assigned managed identity. ClientId should not be used if this is provided. */\n objectId?: string;\n}\n\n/** The instance view of a virtual machine run command. */\nexport interface VirtualMachineRunCommandInstanceView {\n /** Script execution status. */\n executionState?: ExecutionState;\n /** Communicate script configuration errors or execution messages. */\n executionMessage?: string;\n /** Exit code returned from script execution. */\n exitCode?: number;\n /** Script output stream. */\n output?: string;\n /** Script error stream. */\n error?: string;\n /** Script start time. */\n startTime?: Date;\n /** Script end time. */\n endTime?: Date;\n /** The resource status information. */\n statuses?: InstanceViewStatus[];\n}\n\n/** Describes the properties of an AssessPatches result. */\nexport interface VirtualMachineAssessPatchesResult {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assessmentActivityId?: string;\n /**\n * The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootPending?: boolean;\n /**\n * The number of critical or security patches that have been detected as available and not yet installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly criticalAndSecurityPatchCount?: number;\n /**\n * The number of all available patches excluding critical and security.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly otherPatchCount?: number;\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startDateTime?: Date;\n /**\n * The list of patches that have been detected as available for installation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly availablePatches?: VirtualMachineSoftwarePatchProperties[];\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Describes the properties of a Virtual Machine software patch. */\nexport interface VirtualMachineSoftwarePatchProperties {\n /**\n * A unique identifier for the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly patchId?: string;\n /**\n * The friendly name of the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The version number of the patch. This property applies only to Linux patches.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The KBID of the patch. Only applies to Windows patches.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly kbId?: string;\n /**\n * The classification(s) of the patch as provided by the patch publisher.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly classifications?: string[];\n /**\n * Describes the reboot requirements of the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootBehavior?: VMGuestPatchRebootBehavior;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly activityId?: string;\n /**\n * The UTC timestamp when the repository published this patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The UTC timestamp of the last update to this patch record.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastModifiedDateTime?: Date;\n /**\n * Describes the availability of a given patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly assessmentState?: PatchAssessmentState;\n}\n\n/** Capture Virtual Machine parameters. */\nexport interface VirtualMachineCaptureParameters {\n /** The captured virtual hard disk's name prefix. */\n vhdPrefix: string;\n /** The destination container name. */\n destinationContainerName: string;\n /** Specifies whether to overwrite the destination virtual hard disk, in case of conflict. */\n overwriteVhds: boolean;\n}\n\n/** The List Extension operation response */\nexport interface VirtualMachineExtensionsListResult {\n /** The list of extensions */\n value?: VirtualMachineExtension[];\n}\n\n/** Input for InstallPatches as directly received by the API */\nexport interface VirtualMachineInstallPatchesParameters {\n /** Specifies the maximum amount of time that the operation will run. It must be an ISO 8601-compliant duration string such as PT4H (4 hours) */\n maximumDuration?: string;\n /** Defines when it is acceptable to reboot a VM during a software update operation. */\n rebootSetting: VMGuestPatchRebootSetting;\n /** Input for InstallPatches on a Windows VM, as directly received by the API */\n windowsParameters?: WindowsParameters;\n /** Input for InstallPatches on a Linux VM, as directly received by the API */\n linuxParameters?: LinuxParameters;\n}\n\n/** Input for InstallPatches on a Windows VM, as directly received by the API */\nexport interface WindowsParameters {\n /** The update classifications to select when installing patches for Windows. */\n classificationsToInclude?: VMGuestPatchClassificationWindows[];\n /** Kbs to include in the patch operation */\n kbNumbersToInclude?: string[];\n /** Kbs to exclude in the patch operation */\n kbNumbersToExclude?: string[];\n /** Filters out Kbs that don't have an InstallationRebootBehavior of 'NeverReboots' when this is set to true. */\n excludeKbsRequiringReboot?: boolean;\n /** This is used to install patches that were published on or before this given max published date. */\n maxPatchPublishDate?: Date;\n /** This is used to include patches that match the given patch name masks. Alphanumeric strings and wildcard expressions consisting of * and ? are only supported as input values in the list. Null, empty and only whitespaces strings as inputs values are not supported. */\n patchNameMasksToInclude?: string[];\n /** This is used to exclude patches that match the given patch name masks. Alphanumeric strings and wildcard expressions consisting of * and ? are only supported as input values in the list. Null, empty and only whitespaces strings as inputs values are not supported. */\n patchNameMasksToExclude?: string[];\n}\n\n/** Input for InstallPatches on a Linux VM, as directly received by the API */\nexport interface LinuxParameters {\n /** The update classifications to select when installing patches for Linux. */\n classificationsToInclude?: VMGuestPatchClassificationLinux[];\n /** packages to include in the patch operation. Format: packageName_packageVersion */\n packageNameMasksToInclude?: string[];\n /** packages to exclude in the patch operation. Format: packageName_packageVersion */\n packageNameMasksToExclude?: string[];\n /** This is used as a maintenance run identifier for Auto VM Guest Patching in Linux. */\n maintenanceRunId?: string;\n}\n\n/** The result summary of an installation operation. */\nexport interface VirtualMachineInstallPatchesResult {\n /**\n * The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Failed\", \"Succeeded\", \"Unknown\" or \"CompletedWithWarnings.\"\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: PatchOperationStatus;\n /**\n * The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installationActivityId?: string;\n /**\n * The reboot state of the VM following completion of the operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly rebootStatus?: VMGuestPatchRebootStatus;\n /**\n * Whether the operation ran out of time before it completed all its intended actions.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maintenanceWindowExceeded?: boolean;\n /**\n * The number of patches that were not installed due to the user blocking their installation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly excludedPatchCount?: number;\n /**\n * The number of patches that were detected as available for install, but did not meet the operation's criteria.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly notSelectedPatchCount?: number;\n /**\n * The number of patches that were identified as meeting the installation criteria, but were not able to be installed. Typically this happens when maintenanceWindowExceeded == true.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly pendingPatchCount?: number;\n /**\n * The number of patches successfully installed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installedPatchCount?: number;\n /**\n * The number of patches that could not be installed due to some issue. See errors for details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly failedPatchCount?: number;\n /**\n * The patches that were installed during the operation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly patches?: PatchInstallationDetail[];\n /**\n * The UTC timestamp when the operation began.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly startDateTime?: Date;\n /**\n * The errors that were encountered during execution of the operation. The details array contains the list of them.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Information about a specific patch that was encountered during an installation action. */\nexport interface PatchInstallationDetail {\n /**\n * A unique identifier for the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly patchId?: string;\n /**\n * The friendly name of the patch.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The version string of the package. It may conform to Semantic Versioning. Only applies to Linux.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The KBID of the patch. Only applies to Windows patches.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly kbId?: string;\n /**\n * The classification(s) of the patch as provided by the patch publisher.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly classifications?: string[];\n /**\n * The state of the patch after the installation operation completed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly installationState?: PatchInstallationState;\n}\n\n/** The input of virtual machine migration from Availability Set to Flexible Virtual Machine Scale Set. */\nexport interface MigrateVMToVirtualMachineScaleSetInput {\n /** The target zone of VM migration to Flexible Virtual Machine Scale Set. */\n targetZone?: string;\n /** The target compute fault domain of VM migration to Flexible Virtual Machine Scale Set. */\n targetFaultDomain?: number;\n /** The target Virtual Machine size of VM migration to Flexible Virtual Machine Scale Set. */\n targetVMSize?: string;\n}\n\n/** The List disk access operation response. */\nexport interface DiskAccessList {\n /** The DiskAccess items on this page */\n value: DiskAccess[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** The Private Endpoint resource. */\nexport interface PrivateEndpoint {\n /**\n * The ARM identifier for Private Endpoint\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n}\n\n/** A collection of information about the state of the connection between service consumer and provider. */\nexport interface PrivateLinkServiceConnectionState {\n /** Indicates whether the connection has been Approved/Rejected/Removed by the owner of the service. */\n status?: PrivateEndpointServiceConnectionStatus;\n /** The reason for approval/rejection of the connection. */\n description?: string;\n /** A message indicating if changes on the service provider require any updates on the consumer. */\n actionsRequired?: string;\n}\n\n/** The List disk encryption set operation response. */\nexport interface DiskEncryptionSetList {\n /** The DiskEncryptionSet items on this page */\n value: DiskEncryptionSet[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Key Vault Key Url to be used for server side encryption of Managed Disks and Snapshots */\nexport interface KeyForDiskEncryptionSet {\n /** Resource id of the KeyVault containing the key or secret. This property is optional and cannot be used if the KeyVault subscription is not the same as the Disk Encryption Set subscription. */\n sourceVault?: SourceVault;\n /** Fully versioned Key Url pointing to a key in KeyVault. Version segment of the Url is required regardless of rotationToLatestKeyVersionEnabled value. */\n keyUrl: string;\n}\n\n/** The vault id is an Azure Resource Manager Resource id in the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.KeyVault/vaults/{vaultName} */\nexport interface SourceVault {\n /** Resource Id */\n id?: string;\n}\n\n/** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\nexport interface EncryptionSetIdentity {\n /** The type of Managed Identity used by the DiskEncryptionSet. Only SystemAssigned is supported for new creations. Disk Encryption Sets can be updated with Identity type None during migration of subscription to a new Azure Active Directory tenant; it will cause the encrypted resources to lose access to the keys. */\n type?: DiskEncryptionSetIdentityType;\n /**\n * The object id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-identity-principal-id header in the PUT request if the resource has a systemAssigned(implicit) identity\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The tenant id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-client-tenant-id header in the PUT request if the resource has a systemAssigned(implicit) identity\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The list of user identities associated with the disk encryption set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\n/** The List Disks operation response. */\nexport interface DiskList {\n /** The Disk items on this page */\n value: Disk[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface DiskPurchasePlan {\n /** The plan ID. */\n name: string;\n /** The publisher ID. */\n publisher: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n /** The Offer Promotion Code. */\n promotionCode?: string;\n}\n\n/** List of supported capabilities persisted on the disk resource for VM use. */\nexport interface SupportedCapabilities {\n /** The disk controllers that an OS disk supports. If set it can be SCSI or SCSI, NVME or NVME, SCSI. */\n diskControllerTypes?: string;\n /** True if the image from which the OS disk is created supports accelerated networking. */\n acceleratedNetwork?: boolean;\n /** CPU architecture supported by an OS disk. */\n architecture?: Architecture;\n /** Refers to the security capability of the disk supported to create a Trusted launch or Confidential VM */\n supportedSecurityOption?: SupportedSecurityOption;\n}\n\n/** Data used when creating a disk. */\nexport interface CreationData {\n /** This enumerates the possible sources of a disk's creation. */\n createOption: DiskCreateOption;\n /** Required if createOption is Import. The Azure Resource Manager identifier of the storage account containing the blob to import as a disk. */\n storageAccountId?: string;\n /** Disk source information for PIR or user images. */\n imageReference?: ImageDiskReference;\n /** Required if creating from a Gallery Image. The id/sharedGalleryImageId/communityGalleryImageId of the ImageDiskReference will be the ARM id of the shared galley image version from which to create a disk. */\n galleryImageReference?: ImageDiskReference;\n /** If createOption is Import, this is the URI of a blob to be imported into a managed disk. */\n sourceUri?: string;\n /** If createOption is Copy, this is the ARM id of the source snapshot or disk. */\n sourceResourceId?: string;\n /**\n * If this field is set, this is the unique id identifying the source of this resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceUniqueId?: string;\n /** If createOption is Upload, this is the size of the contents of the upload including the VHD footer. This value should be between 20972032 (20 MiB + 512 bytes for the VHD footer) and 35183298347520 bytes (32 TiB + 512 bytes for the VHD footer). */\n uploadSizeBytes?: number;\n /** Logical sector size in bytes for Ultra disks. Supported values are 512 ad 4096. 4096 is the default. */\n logicalSectorSize?: number;\n /** If createOption is ImportSecure, this is the URI of a blob to be imported into VM guest state. */\n securityDataUri?: string;\n /** If createOption is ImportSecure, this is the URI of a blob to be imported into VM metadata for Confidential VM. */\n securityMetadataUri?: string;\n /** Set this flag to true to get a boost on the performance target of the disk deployed, see here on the respective performance target. This flag can only be set on disk creation time and cannot be disabled after enabled. */\n performancePlus?: boolean;\n /** Required if createOption is CopyFromSanSnapshot. This is the ARM id of the source elastic san volume snapshot. */\n elasticSanResourceId?: string;\n /** If this field is set on a snapshot and createOption is CopyStart, the snapshot will be copied at a quicker speed. */\n provisionedBandwidthCopySpeed?: ProvisionedBandwidthCopyOption;\n /** For snapshots created from Premium SSD v2 or Ultra disk, this property determines the time in minutes the snapshot is retained for instant access to enable faster restore. */\n instantAccessDurationMinutes?: number;\n}\n\n/** The source image used for creating the disk. */\nexport interface ImageDiskReference {\n /** A relative uri containing either a Platform Image Repository, user image, or Azure Compute Gallery image reference. */\n id?: string;\n /** A relative uri containing a direct shared Azure Compute Gallery image reference. */\n sharedGalleryImageId?: string;\n /** A relative uri containing a community Azure Compute Gallery image reference. */\n communityGalleryImageId?: string;\n /** If the disk is created from an image's data disk, this is an index that indicates which of the data disks in the image to use. For OS disks, this field is null. */\n lun?: number;\n}\n\n/** Encryption settings for disk or snapshot */\nexport interface EncryptionSettingsCollection {\n /** Set this flag to true and provide DiskEncryptionKey and optional KeyEncryptionKey to enable encryption. Set this flag to false and remove DiskEncryptionKey and KeyEncryptionKey to disable encryption. If EncryptionSettings is null in the request object, the existing settings remain unchanged. */\n enabled: boolean;\n /** A collection of encryption settings, one for each disk volume. */\n encryptionSettings?: EncryptionSettingsElement[];\n /** Describes what type of encryption is used for the disks. Once this field is set, it cannot be overwritten. '1.0' corresponds to Azure Disk Encryption with AAD app.'1.1' corresponds to Azure Disk Encryption. */\n encryptionSettingsVersion?: string;\n}\n\n/** Encryption settings for one disk volume. */\nexport interface EncryptionSettingsElement {\n /** Key Vault Secret Url and vault id of the disk encryption key */\n diskEncryptionKey?: KeyVaultAndSecretReference;\n /** Key Vault Key Url and vault id of the key encryption key. KeyEncryptionKey is optional and when provided is used to unwrap the disk encryption key. */\n keyEncryptionKey?: KeyVaultAndKeyReference;\n}\n\n/** Key Vault Secret Url and vault id of the encryption key */\nexport interface KeyVaultAndSecretReference {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVault;\n /** Url pointing to a key or secret in KeyVault */\n secretUrl: string;\n}\n\n/** Key Vault Key Url and vault id of KeK, KeK is optional and when provided is used to unwrap the encryptionKey */\nexport interface KeyVaultAndKeyReference {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVault;\n /** Url pointing to a key or secret in KeyVault */\n keyUrl: string;\n}\n\n/** Encryption at rest settings for disk or snapshot */\nexport interface Encryption {\n /** ResourceId of the disk encryption set to use for enabling encryption at rest. */\n diskEncryptionSetId?: string;\n /** The type of key used to encrypt the data of the disk. */\n type?: EncryptionType;\n}\n\nexport interface ShareInfoElement {\n /**\n * A relative URI containing the ID of the VM that has the disk attached.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmUri?: string;\n}\n\n/** Properties of the disk for which update is pending. */\nexport interface PropertyUpdatesInProgress {\n /** The target performance tier of the disk if a tier change operation is in progress. */\n targetTier?: string;\n}\n\n/** Contains the security related information for the resource. */\nexport interface DiskSecurityProfile {\n /** Specifies the SecurityType of the VM. Applicable for OS disks only. */\n securityType?: DiskSecurityTypes;\n /** ResourceId of the disk encryption set associated to Confidential VM supported disk encrypted with customer managed key */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** In the case of an availability or connectivity issue with the data disk, specify the behavior of your VM */\nexport interface AvailabilityPolicy {\n /** Determines on how to handle disks with slow I/O. */\n actionOnDiskDelay?: AvailabilityPolicyDiskDelay;\n}\n\n/** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\nexport interface DiskSku {\n /** The sku name. */\n name?: DiskStorageAccountTypes;\n /**\n * The sku tier.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n}\n\n/** The List Snapshots operation response. */\nexport interface SnapshotList {\n /** A list of snapshots. */\n value: Snapshot[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\nexport interface CopyCompletionError {\n /** Indicates the error code if the background copy of a resource created via the CopyStart operation fails. */\n errorCode: CopyCompletionErrorReason;\n /** Indicates the error message if the background copy of a resource created via the CopyStart operation fails. */\n errorMessage: string;\n}\n\n/** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\nexport interface SnapshotSku {\n /** The sku name. */\n name?: SnapshotStorageAccountTypes;\n /**\n * The sku tier.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n}\n\n/** Used for updating a disk access resource. */\nexport interface DiskAccessUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** A list of private link resources */\nexport interface PrivateEndpointConnectionListResult {\n /** The PrivateEndpointConnection items on this page */\n value: PrivateEndpointConnection[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** A list of private link resources */\nexport interface PrivateLinkResourceListResult {\n /** Array of private link resources */\n value?: PrivateLinkResource[];\n}\n\n/** A private link resource */\nexport interface PrivateLinkResource {\n /**\n * private link resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * private link resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * private link resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * The private link resource group id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly groupId?: string;\n /**\n * The private link resource required member names.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly requiredMembers?: string[];\n /** The private link resource DNS zone name. */\n requiredZoneNames?: string[];\n}\n\n/** disk encryption set update resource. */\nexport interface DiskEncryptionSetUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n /** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\n identity?: EncryptionSetIdentity;\n /** The type of key used to encrypt the data of the disk. */\n encryptionType?: DiskEncryptionSetType;\n /** Key Vault Key Url to be used for server side encryption of Managed Disks and Snapshots */\n activeKey?: KeyForDiskEncryptionSet;\n /** Set this flag to true to enable auto-updating of this disk encryption set to the latest key version. */\n rotationToLatestKeyVersionEnabled?: boolean;\n /** Multi-tenant application client id to access key vault in a different tenant. Setting the value to 'None' will clear the property. */\n federatedClientId?: string;\n}\n\n/** The List resources which are encrypted with the disk encryption set. */\nexport interface ResourceUriList {\n /** A list of IDs or Owner IDs of resources which are encrypted with the disk encryption set. */\n value: string[];\n /** The uri to fetch the next page of encrypted resources. Call ListNext() with this to fetch the next page of encrypted resources. */\n nextLink?: string;\n}\n\n/** Disk update resource. */\nexport interface DiskUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n /** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\n sku?: DiskSku;\n /** the Operating System type. */\n osType?: OperatingSystemTypes;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /** The number of IOPS allowed for this disk; only settable for UltraSSD disks. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadWrite?: number;\n /** The bandwidth allowed for this disk; only settable for UltraSSD disks. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadWrite?: number;\n /** The total number of IOPS that will be allowed across all VMs mounting the shared disk as ReadOnly. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadOnly?: number;\n /** The total throughput (MBps) that will be allowed across all VMs mounting the shared disk as ReadOnly. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadOnly?: number;\n /** The maximum number of VMs that can attach to the disk at the same time. Value greater than one indicates a disk that can be mounted on multiple VMs at the same time. */\n maxShares?: number;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Performance tier of the disk (e.g, P4, S10) as described here: https://azure.microsoft.com/en-us/pricing/details/managed-disks/. Does not apply to Ultra disks. */\n tier?: string;\n /** Set to true to enable bursting beyond the provisioned performance target of the disk. Bursting is disabled by default. Does not apply to Ultra disks. */\n burstingEnabled?: boolean;\n /** Purchase plan information to be added on the OS disk */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities to be added on the OS disk. */\n supportedCapabilities?: SupportedCapabilities;\n /**\n * Properties of the disk for which update is pending.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly propertyUpdatesInProgress?: PropertyUpdatesInProgress;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /** Setting this property to true improves reliability and performance of data disks that are frequently (more than 5 times a day) by detached from one virtual machine and attached to another. This property should not be set for disks that are not detached and attached frequently as it causes the disks to not align with the fault domain of the virtual machine. */\n optimizedForFrequentAttach?: boolean;\n /** Determines how platform treats disk failures */\n availabilityPolicy?: AvailabilityPolicy;\n}\n\n/** Data used for requesting a SAS. */\nexport interface GrantAccessData {\n /** The Access Level, accepted values include None, Read, Write. */\n access: AccessLevel;\n /** Time duration in seconds until the SAS access expires. */\n durationInSeconds: number;\n /** Set this flag to true to get additional SAS for VM guest state */\n getSecureVMGuestStateSAS?: boolean;\n /** Used to specify the file format when making request for SAS on a VHDX file format snapshot */\n fileFormat?: FileFormat;\n}\n\n/** A disk access SAS uri. */\nexport interface AccessUri {\n /**\n * A SAS uri for accessing a disk.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly accessSAS?: string;\n /**\n * A SAS uri for accessing a VM guest state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly securityDataAccessSAS?: string;\n /**\n * A SAS uri for accessing a VM metadata.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly securityMetadataAccessSAS?: string;\n}\n\n/** The List Disk Restore Points operation response. */\nexport interface DiskRestorePointList {\n /** The DiskRestorePoint items on this page */\n value: DiskRestorePoint[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Snapshot update resource. */\nexport interface SnapshotUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n /** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\n sku?: SnapshotSku;\n /** the Operating System type. */\n osType?: OperatingSystemTypes;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Indicates the OS on a snapshot supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilities;\n /**\n * The state of snapshot which determines the access availability of the snapshot.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly snapshotAccessState?: SnapshotAccessState;\n}\n\n/** The List Resource Skus operation response. */\nexport interface ResourceSkusResult {\n /** The ResourceSku items on this page */\n value: ResourceSku[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Describes an available Compute SKU. */\nexport interface ResourceSku {\n /**\n * The type of resource the SKU applies to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resourceType?: string;\n /**\n * The name of SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic**\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n /**\n * The Size of the SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly size?: string;\n /**\n * The Family of this particular SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly family?: string;\n /**\n * The Kind of resources that are supported in this SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly kind?: string;\n /**\n * Specifies the number of virtual machines in the scale set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacity?: ResourceSkuCapacity;\n /**\n * The set of locations that the SKU is available.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly locations?: string[];\n /**\n * A list of locations and availability zones in those locations where the SKU is available.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly locationInfo?: ResourceSkuLocationInfo[];\n /**\n * The api versions that support this SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly apiVersions?: string[];\n /**\n * Metadata for retrieving price info.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly costs?: ResourceSkuCosts[];\n /**\n * A name value pair to describe the capability.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capabilities?: ResourceSkuCapabilities[];\n /**\n * The restrictions because of which SKU cannot be used. This is empty if there are no restrictions.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restrictions?: ResourceSkuRestrictions[];\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuCapacity {\n /**\n * The minimum capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly minimum?: number;\n /**\n * The maximum capacity that can be set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly maximum?: number;\n /**\n * The default capacity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly default?: number;\n /**\n * The scale type applicable to the sku.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly scaleType?: ResourceSkuCapacityScaleType;\n}\n\n/** Describes an available Compute SKU Location Information. */\nexport interface ResourceSkuLocationInfo {\n /**\n * Location of the SKU\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * List of availability zones where the SKU is supported.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zones?: string[];\n /**\n * Details of capabilities available to a SKU in specific zones.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zoneDetails?: ResourceSkuZoneDetails[];\n /**\n * The names of extended locations.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly extendedLocations?: string[];\n /**\n * The type of the extended location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: ExtendedLocationType;\n}\n\n/** Describes The zonal capabilities of a SKU. */\nexport interface ResourceSkuZoneDetails {\n /**\n * The set of zones that the SKU is available in with the specified capabilities.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string[];\n /**\n * A list of capabilities that are available for the SKU in the specified list of zones.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capabilities?: ResourceSkuCapabilities[];\n}\n\n/** Describes The SKU capabilities object. */\nexport interface ResourceSkuCapabilities {\n /**\n * An invariant to describe the feature.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * An invariant if the feature is measured by quantity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly value?: string;\n}\n\n/** Describes metadata for retrieving price info. */\nexport interface ResourceSkuCosts {\n /**\n * Used for querying price from commerce.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly meterID?: string;\n /**\n * The multiplier is needed to extend the base metered cost.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly quantity?: number;\n /**\n * An invariant to show the extended unit.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly extendedUnit?: string;\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuRestrictions {\n /**\n * The type of restrictions.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: ResourceSkuRestrictionsType;\n /**\n * The value of restrictions. If the restriction type is set to location. This would be different locations where the SKU is restricted.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly values?: string[];\n /**\n * The information about the restriction where the SKU cannot be used.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restrictionInfo?: ResourceSkuRestrictionInfo;\n /**\n * The reason for restriction.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reasonCode?: ResourceSkuRestrictionsReasonCode;\n}\n\n/** Describes an available Compute SKU Restriction Information. */\nexport interface ResourceSkuRestrictionInfo {\n /**\n * Locations where the SKU is restricted\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly locations?: string[];\n /**\n * List of availability zones where the SKU is restricted.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zones?: string[];\n}\n\n/** Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). */\nexport interface ErrorResponse {\n /** The error object. */\n error?: ErrorDetail;\n}\n\n/** The error detail. */\nexport interface ErrorDetail {\n /**\n * The error code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * The error message.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly message?: string;\n /**\n * The error target.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly target?: string;\n /**\n * The error details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly details?: ErrorDetail[];\n /**\n * The error additional info.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly additionalInfo?: ErrorAdditionalInfo[];\n}\n\n/** The resource management error additional info. */\nexport interface ErrorAdditionalInfo {\n /**\n * The additional info type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * The additional info.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly info?: any;\n}\n\n/** The List Galleries operation response. */\nexport interface GalleryList {\n /** A list of galleries. */\n value: Gallery[];\n /** The uri to fetch the next page of galleries. Call ListNext() with this to fetch the next page of galleries. */\n nextLink?: string;\n /** The security profile of a gallery image version */\n securityProfile?: ImageVersionSecurityProfile;\n}\n\n/** Describes the gallery unique name. */\nexport interface GalleryIdentifier {\n /**\n * The unique name of the Shared Image Gallery. This name is generated automatically by Azure.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueName?: string;\n}\n\n/** Profile for gallery sharing to subscription or tenant */\nexport interface SharingProfile {\n /** This property allows you to specify the permission of sharing gallery. Possible values are: **Private,** **Groups,** **Community.** */\n permissions?: GallerySharingPermissionTypes;\n /**\n * A list of sharing profile groups.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly groups?: SharingProfileGroup[];\n /** Information of community gallery if current gallery is shared to community. */\n communityGalleryInfo?: CommunityGalleryInfo;\n}\n\n/** Group of the gallery sharing profile */\nexport interface SharingProfileGroup {\n /** This property allows you to specify the type of sharing group. Possible values are: **Subscriptions,** **AADTenants.** */\n type?: SharingProfileGroupTypes;\n /** A list of subscription/tenant ids the gallery is aimed to be shared to. */\n ids?: string[];\n}\n\n/** Information of community gallery if current gallery is shared to community */\nexport interface CommunityGalleryInfo {\n /** The link to the publisher website. Visible to all users. */\n publisherUri?: string;\n /** Community gallery publisher support email. The email address of the publisher. Visible to all users. */\n publisherContact?: string;\n /** End-user license agreement for community gallery image. */\n eula?: string;\n /** The prefix of the gallery name that will be displayed publicly. Visible to all users. */\n publicNamePrefix?: string;\n /**\n * Contains info about whether community gallery sharing is enabled.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly communityGalleryEnabled?: boolean;\n /**\n * Community gallery public name list.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publicNames?: string[];\n}\n\n/** Contains information about the soft deletion policy of the gallery. */\nexport interface SoftDeletePolicy {\n /** Enables soft-deletion for resources in this gallery, allowing them to be recovered within retention time. */\n isSoftDeleteEnabled?: boolean;\n}\n\n/** Sharing status of current gallery. */\nexport interface SharingStatus {\n /**\n * Aggregated sharing state of current gallery.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly aggregatedState?: SharingState;\n /** Summary of all regional sharing status. */\n summary?: RegionalSharingStatus[];\n}\n\n/** Gallery regional sharing status */\nexport interface RegionalSharingStatus {\n /** Region name */\n region?: string;\n /**\n * Gallery sharing state in current region\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly state?: SharingState;\n /** Details of gallery regional sharing failure. */\n details?: string;\n}\n\n/** Identity for the virtual machine. */\nexport interface GalleryIdentity {\n /**\n * The principal id of the gallery identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly principalId?: string;\n /**\n * The AAD tenant id of the gallery identity. This property will only be provided for a system assigned identity.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tenantId?: string;\n /** The type of identity used for the gallery. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove all identities from the gallery. */\n type?: ResourceIdentityType;\n /** The list of user identities associated with the gallery. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: {\n [propertyName: string]: UserAssignedIdentitiesValue;\n };\n}\n\n/** The security profile of a gallery image version */\nexport interface ImageVersionSecurityProfile {\n /** Contains UEFI settings for the image version. */\n uefiSettings?: GalleryImageVersionUefiSettings;\n}\n\n/** Contains UEFI settings for the image version. */\nexport interface GalleryImageVersionUefiSettings {\n /** The name of the template(s) that contains default UEFI key signatures that will be added to the image. */\n signatureTemplateNames?: UefiSignatureTemplateName[];\n /** Additional UEFI key signatures that will be added to the image in addition to the signature templates */\n additionalSignatures?: UefiKeySignatures;\n}\n\n/** Additional UEFI key signatures that will be added to the image in addition to the signature templates */\nexport interface UefiKeySignatures {\n /** The Platform Key of this image version. */\n pk?: UefiKey;\n /** The Key Encryption Keys of this image version. */\n kek?: UefiKey[];\n /** The database of UEFI keys for this image version. */\n db?: UefiKey[];\n /** The database of revoked UEFI keys for this image version. */\n dbx?: UefiKey[];\n}\n\n/** A UEFI key signature. */\nexport interface UefiKey {\n /** The type of key signature. */\n type?: UefiKeyType;\n /** The value of the key signature. */\n value?: string[];\n}\n\n/** The metadata of community gallery. */\nexport interface CommunityGalleryMetadata {\n /** The publisher URI of this community gallery. */\n publisherUri?: string;\n /** The publisher email id of this community gallery. */\n publisherContact: string;\n /** The end-user license agreement for this community gallery. */\n eula?: string;\n /** A list of public names the gallery has. */\n publicNames: string[];\n /** The link for the privacy statement of this community gallery from the gallery publisher. */\n privacyStatementUri?: string;\n}\n\n/** Base information about the community gallery resource in azure compute gallery. */\nexport interface PirCommunityGalleryResource {\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** The unique id of this community gallery. */\n uniqueId?: string;\n}\n\n/** The List Community Gallery Images operation response. */\nexport interface CommunityGalleryImageList {\n /** A list of community gallery images. */\n value: CommunityGalleryImage[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** This is the community gallery image definition identifier. */\nexport interface CommunityGalleryImageIdentifier {\n /** The name of the gallery image definition publisher. */\n publisher?: string;\n /** The name of the gallery image definition offer. */\n offer?: string;\n /** The name of the gallery image definition SKU. */\n sku?: string;\n}\n\n/** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\nexport interface RecommendedMachineConfiguration {\n /** Describes the resource range. */\n vCPUs?: ResourceRange;\n /** Describes the resource range. */\n memory?: ResourceRange;\n}\n\n/** Describes the resource range. */\nexport interface ResourceRange {\n /** The minimum number of the resource. */\n min?: number;\n /** The maximum number of the resource. */\n max?: number;\n}\n\n/** Describes the disallowed disk types. */\nexport interface Disallowed {\n /** A list of disk types. */\n diskTypes?: string[];\n}\n\n/** A feature for gallery image. */\nexport interface GalleryImageFeature {\n /** The name of the gallery image feature. */\n name?: string;\n /** The value of the gallery image feature. */\n value?: string;\n /** The minimum gallery image version which supports this feature. */\n startsAtVersion?: string;\n}\n\n/** Describes the gallery image definition purchase plan. This is used by marketplace images. */\nexport interface ImagePurchasePlan {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** The product ID. */\n product?: string;\n}\n\n/** The List Community Gallery Image versions operation response. */\nexport interface CommunityGalleryImageVersionList {\n /** A list of community gallery image versions. */\n value: CommunityGalleryImageVersion[];\n /** The URI to fetch the next page of community gallery image versions. Call ListNext() with this to fetch the next page of community gallery image versions. */\n nextLink?: string;\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface SharedGalleryImageVersionStorageProfile {\n /** This is the OS disk image. */\n osDiskImage?: SharedGalleryOSDiskImage;\n /** A list of data disk images. */\n dataDiskImages?: SharedGalleryDataDiskImage[];\n}\n\n/** This is the disk image base class. */\nexport interface SharedGalleryDiskImage {\n /**\n * This property indicates the size of the VHD to be created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: SharedGalleryHostCaching;\n}\n\n/** The List Shared Galleries operation response. */\nexport interface SharedGalleryList {\n /** A list of shared galleries. */\n value: SharedGallery[];\n /** The uri to fetch the next page of shared galleries. Call ListNext() with this to fetch the next page of shared galleries. */\n nextLink?: string;\n}\n\n/** The Resource model definition. */\nexport interface PirResource {\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n}\n\n/** The List Shared Gallery Images operation response. */\nexport interface SharedGalleryImageList {\n /** A list of shared gallery images. */\n value: SharedGalleryImage[];\n /** The uri to fetch the next page of shared gallery images. Call ListNext() with this to fetch the next page of shared gallery images. */\n nextLink?: string;\n}\n\n/** This is the gallery image definition identifier. */\nexport interface GalleryImageIdentifier {\n /** The name of the gallery image definition publisher. */\n publisher: string;\n /** The name of the gallery image definition offer. */\n offer: string;\n /** The name of the gallery image definition SKU. */\n sku: string;\n}\n\n/** The List Shared Gallery Image versions operation response. */\nexport interface SharedGalleryImageVersionList {\n /** The SharedGalleryImageVersion items on this page */\n value: SharedGalleryImageVersion[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** The Update Resource model definition. */\nexport interface UpdateResourceDefinition {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** The List Gallery Applications operation response. */\nexport interface GalleryApplicationList {\n /** The GalleryApplication items on this page */\n value: GalleryApplication[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** A custom action that can be performed with a Gallery Application Version. */\nexport interface GalleryApplicationCustomAction {\n /** The name of the custom action. Must be unique within the Gallery Application Version. */\n name: string;\n /** The script to run when executing this custom action. */\n script: string;\n /** Description to help the users understand what this custom action does. */\n description?: string;\n /** The parameters that this custom action uses */\n parameters?: GalleryApplicationCustomActionParameter[];\n}\n\n/** The definition of a parameter that can be passed to a custom action of a Gallery Application Version. */\nexport interface GalleryApplicationCustomActionParameter {\n /** The name of the custom action. Must be unique within the Gallery Application Version. */\n name: string;\n /** Indicates whether this parameter must be passed when running the custom action. */\n required?: boolean;\n /** Specifies the type of the custom action parameter. Possible values are: String, ConfigurationDataBlob or LogOutputBlob */\n type?: GalleryApplicationCustomActionParameterType;\n /** The default value of the parameter. Only applies to string types */\n defaultValue?: string;\n /** A description to help users understand what this parameter means */\n description?: string;\n}\n\n/** The List Gallery Application version operation response. */\nexport interface GalleryApplicationVersionList {\n /** A list of gallery Application Versions. */\n value: GalleryApplicationVersion[];\n /** The uri to fetch the next page of gallery Application Versions. Call ListNext() with this to fetch the next page of gallery Application Versions. */\n nextLink?: string;\n}\n\n/** The source image from which the Image Version is going to be created. */\nexport interface UserArtifactSource {\n /** Required. The mediaLink of the artifact, must be a readable storage page blob. */\n mediaLink: string;\n /** Optional. The defaultConfigurationLink of the artifact, must be a readable storage page blob. */\n defaultConfigurationLink?: string;\n}\n\nexport interface UserArtifactManage {\n /** Required. The path and arguments to install the gallery application. This is limited to 4096 characters. */\n install: string;\n /** Required. The path and arguments to remove the gallery application. This is limited to 4096 characters. */\n remove: string;\n /** Optional. The path and arguments to update the gallery application. If not present, then update operation will invoke remove command on the previous version and install command on the current version of the gallery application. This is limited to 4096 characters. */\n update?: string;\n}\n\n/** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\nexport interface UserArtifactSettings {\n /** Optional. The name to assign the downloaded package file on the VM. This is limited to 4096 characters. If not specified, the package file will be named the same as the Gallery Application name. */\n packageFileName?: string;\n /** Optional. The name to assign the downloaded config file on the VM. This is limited to 4096 characters. If not specified, the config file will be named the Gallery Application name appended with \"_config\". */\n configFileName?: string;\n /** Optional. The action to be taken with regards to install/update/remove of the gallery application in the event of a reboot. */\n scriptBehaviorAfterReboot?: GalleryApplicationScriptRebootBehavior;\n}\n\n/** Describes the basic gallery artifact publishing profile. */\nexport interface GalleryArtifactPublishingProfileBase {\n /** The target regions where the Image Version is going to be replicated to. This property is updatable. */\n targetRegions?: TargetRegion[];\n /** The number of replicas of the Image Version to be created per region. This property would take effect for a region when regionalReplicaCount is not specified. This property is updatable. */\n replicaCount?: number;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the gallery image version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /** The end of life date of the gallery image version. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** Specifies the storage account type to be used to store the image. Cannot be specified along with storageAccountStrategy. This property is not updatable. */\n storageAccountType?: StorageAccountType;\n /** Optional parameter which specifies the mode to be used for replication. This property is not updatable. */\n replicationMode?: ReplicationMode;\n /** The target extended locations where the Image Version is going to be replicated to. This property is updatable. */\n targetExtendedLocations?: GalleryTargetExtendedLocation[];\n /** Specifies the strategy to be used when selecting the storage account type. Cannot be specified along with storageAccountType, but can be overridden per region by specifying targetRegions[].storageAccountType. This property is not updatable. */\n storageAccountStrategy?: StorageAccountStrategy;\n}\n\n/** Describes the target region information. */\nexport interface TargetRegion {\n /** The name of the region. */\n name: string;\n /** The number of replicas of the Image Version to be created per region. This property is updatable. */\n regionalReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: StorageAccountType;\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImages;\n /** Contains the flag setting to hide an image when users specify version='latest' */\n excludeFromLatest?: boolean;\n /** List of storage sku with replica count to create direct drive replicas. */\n additionalReplicaSets?: AdditionalReplicaSet[];\n}\n\n/** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\nexport interface EncryptionImages {\n /** Contains encryption settings for an OS disk image. */\n osDiskImage?: OSDiskImageEncryption;\n /** A list of encryption specifications for data disk images. */\n dataDiskImages?: DataDiskImageEncryption[];\n}\n\n/** Contains security profile for an OS disk image. */\nexport interface OSDiskImageSecurityProfile {\n /** confidential VM encryption types */\n confidentialVMEncryptionType?: ConfidentialVMEncryptionType;\n /** secure VM disk encryption set id */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** This is the disk image encryption base class. */\nexport interface DiskImageEncryption {\n /** A relative URI containing the resource ID of the disk encryption set. */\n diskEncryptionSetId?: string;\n}\n\n/** Describes the additional replica set information. */\nexport interface AdditionalReplicaSet {\n /** Specifies the storage account type to be used to create the direct drive replicas */\n storageAccountType?: StorageAccountType;\n /** The number of direct drive replicas of the Image Version to be created.This Property is updatable */\n regionalReplicaCount?: number;\n}\n\nexport interface GalleryTargetExtendedLocation {\n /** The name of the region. */\n name?: string;\n /** The name of the extended location. */\n extendedLocation?: GalleryExtendedLocation;\n /** The number of replicas of the Image Version to be created per extended location. This property is updatable. */\n extendedLocationReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: EdgeZoneStorageAccountType;\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImages;\n}\n\n/** The name of the extended location. */\nexport interface GalleryExtendedLocation {\n name?: string;\n /** It is type of the extended location. */\n type?: GalleryExtendedLocationType;\n}\n\n/** This is the safety profile of the Gallery Artifact Version. */\nexport interface GalleryArtifactSafetyProfileBase {\n /** Indicates whether or not removing this Gallery Image Version from replicated regions is allowed. */\n allowDeletionOfReplicatedLocations?: boolean;\n}\n\n/** This is the replication status of the gallery image version. */\nexport interface ReplicationStatus {\n /**\n * This is the aggregated replication status based on all the regional replication status flags.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly aggregatedState?: AggregatedReplicationState;\n /**\n * This is a summary of replication status for each region.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly summary?: RegionalReplicationStatus[];\n}\n\n/** This is the regional replication status. */\nexport interface RegionalReplicationStatus {\n /**\n * The region to which the gallery image version is being replicated to.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly region?: string;\n /**\n * This is the regional replication state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly state?: ReplicationState;\n /**\n * The details of the replication status.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly details?: string;\n /**\n * It indicates progress of the replication job.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly progress?: number;\n}\n\n/** The List Gallery Images operation response. */\nexport interface GalleryImageList {\n /** A list of Shared Image Gallery images. */\n value: GalleryImage[];\n /** The uri to fetch the next page of Image Definitions in the Shared Image Gallery. Call ListNext() with this to fetch the next page of gallery image definitions. */\n nextLink?: string;\n}\n\n/** The List Gallery Image version operation response. */\nexport interface GalleryImageVersionList {\n /** A list of gallery image versions. */\n value: GalleryImageVersion[];\n /** The uri to fetch the next page of gallery image versions. Call ListNext() with this to fetch the next page of gallery image versions. */\n nextLink?: string;\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface GalleryImageVersionStorageProfile {\n /** The source of the gallery artifact version. */\n source?: GalleryArtifactVersionFullSource;\n /** This is the OS disk image. */\n osDiskImage?: GalleryOSDiskImage;\n /** A list of data disk images. */\n dataDiskImages?: GalleryDataDiskImage[];\n}\n\n/** The gallery artifact version source. */\nexport interface GalleryArtifactVersionSource {\n /** The id of the gallery artifact version source. */\n id?: string;\n}\n\n/** This is the disk image base class. */\nexport interface GalleryDiskImage {\n /**\n * This property indicates the size of the VHD to be created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sizeInGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: HostCaching;\n /** The source for the disk image. */\n source?: GalleryDiskImageSource;\n}\n\n/** A policy violation reported against a gallery artifact. */\nexport interface PolicyViolation {\n /** Describes the nature of the policy violation. */\n category?: PolicyViolationCategory;\n /** Describes specific details about why this policy violation was reported. */\n details?: string;\n}\n\n/** This is the validations profile of a Gallery Image Version. */\nexport interface ValidationsProfile {\n /** The published time of the image version */\n validationEtag?: string;\n executedValidations?: ExecutedValidation[];\n /** This specifies the pub, offer, sku and version of the image version metadata */\n platformAttributes?: PlatformAttribute[];\n}\n\n/** This is the executed Validation. */\nexport interface ExecutedValidation {\n /** This property specifies the type of image version validation. */\n type?: string;\n /**\n * This property specifies the status of the validationProfile of the image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly status?: ValidationStatus;\n /** This property specifies the valid version of the validation. */\n version?: string;\n /** This property specifies the starting timestamp. */\n executionTime?: Date;\n}\n\n/** This is the platform attribute of the image version. */\nexport interface PlatformAttribute {\n /**\n * This property specifies the name of the platformAttribute. It is read-only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * This property specifies the value of the corresponding name property. It is read-only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly value?: string;\n}\n\n/** The List Gallery InVMAccessControlProfiles operation response. */\nexport interface GalleryInVMAccessControlProfileList {\n /** The GalleryInVMAccessControlProfile items on this page */\n value: GalleryInVMAccessControlProfile[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** The properties of a gallery ResourceProfile. */\nexport interface GalleryResourceProfilePropertiesBase {\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n}\n\n/** The List Gallery InVMAccessControlProfile Versions operation response. */\nexport interface GalleryInVMAccessControlProfileVersionList {\n /** The GalleryInVMAccessControlProfileVersion items on this page */\n value: GalleryInVMAccessControlProfileVersion[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\nexport interface AccessControlRules {\n /** A list of privileges. */\n privileges?: AccessControlRulesPrivilege[];\n /** A list of roles. */\n roles?: AccessControlRulesRole[];\n /** A list of identities. */\n identities?: AccessControlRulesIdentity[];\n /** A list of role assignments. */\n roleAssignments?: AccessControlRulesRoleAssignment[];\n}\n\n/** The properties of an Access Control Rule Privilege. */\nexport interface AccessControlRulesPrivilege {\n /** The name of the privilege. */\n name: string;\n /** The HTTP path corresponding to the privilege. */\n path: string;\n /** The query parameters to match in the path. */\n queryParameters?: { [propertyName: string]: string };\n}\n\n/** The properties of an Access Control Rule Role. */\nexport interface AccessControlRulesRole {\n /** The name of the role. */\n name: string;\n /** A list of privileges needed by this role. */\n privileges: string[];\n}\n\n/** The properties of an Access Control Rule Identity. */\nexport interface AccessControlRulesIdentity {\n /** The name of the identity. */\n name: string;\n /** The username corresponding to this identity. */\n userName?: string;\n /** The groupName corresponding to this identity. */\n groupName?: string;\n /** The path to the executable. */\n exePath?: string;\n /** The process name of the executable. */\n processName?: string;\n}\n\n/** The properties of an Access Control Rule RoleAssignment. */\nexport interface AccessControlRulesRoleAssignment {\n /** The name of the role. */\n role: string;\n /** A list of identities that can access the privileges defined by the role. */\n identities: string[];\n}\n\n/** The properties of a gallery ResourceProfile version. */\nexport interface GalleryResourceProfileVersionPropertiesBase {\n /** The target regions where the Resource Profile version is going to be replicated to. This property is updatable. */\n targetLocations?: TargetRegion[];\n /** If set to true, Virtual Machines deployed from the latest version of the Resource Profile won't use this Profile version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the Resource Profile Version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** The List Gallery Script operation response. */\nexport interface GalleryScriptList {\n /** The GalleryScript items on this page */\n value: GalleryScript[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Describes the properties of a gallery script definition. */\nexport interface GalleryScriptProperties {\n /** The description of this gallery script definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement (End User License Agreement) for the gallery Script Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Script Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This property allows you to specify the supported type of the OS that application is built for. Possible values are: **Windows,** **Linux.** */\n supportedOSType: OperatingSystemTypes;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n}\n\n/** Paged collection of GalleryScriptVersion items */\nexport interface GalleryScriptVersionList {\n /** The GalleryScriptVersion items on this page */\n value: GalleryScriptVersion[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Describes the properties of a gallery script version. */\nexport interface GalleryScriptVersionProperties {\n /** The publishing profile of a gallery image version. */\n publishingProfile: GalleryScriptVersionPublishingProfile;\n /** The safety profile of the Gallery Script Version. */\n safetyProfile?: GalleryScriptVersionSafetyProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** The source script from which the Script Version is going to be created. */\nexport interface ScriptSource {\n /** Required. The link of the source script, it must be a readable storage blob with SAS URI or publicly accessible URI or managed identity enabled. */\n scriptLink: string;\n /** Optional. Any input parameters that needs to passed to the script and are accessed within the script for its execution. */\n parameters?: GalleryScriptParameter[];\n}\n\n/** The definition of a generic gallery parameter. */\nexport interface GenericGalleryParameter {\n /** The name of the parameter. */\n name: string;\n /** Indicates whether this parameter must be passed. */\n required?: boolean;\n /** The default value of the parameter, only applies to string types. */\n defaultValue?: string;\n /** A description to help users understand what this parameter means */\n description?: string;\n}\n\n/** Specifies information about the gallery sharing profile update. */\nexport interface SharingUpdate {\n /** This property allows you to specify the operation type of gallery sharing update. Possible values are: **Add,** **Remove,** **Reset.** */\n operationType: SharingUpdateOperationTypes;\n /** A list of sharing profile groups. */\n groups?: SharingProfileGroup[];\n}\n\n/** The List Soft-deleted Resources operation response. */\nexport interface GallerySoftDeletedResourceList {\n /** The GallerySoftDeletedResource items on this page */\n value: GallerySoftDeletedResource[];\n /** The link to the next page of items */\n nextLink?: string;\n}\n\n/** Describes the cloud service role instance. */\nexport interface RoleInstance {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource Name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource Type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource Location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /**\n * Resource tags.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tags?: { [propertyName: string]: string };\n /** The role instance SKU. */\n sku?: InstanceSku;\n /** Role instance properties. */\n properties?: RoleInstanceProperties;\n}\n\n/** The role instance SKU. */\nexport interface InstanceSku {\n /**\n * The sku name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The tier of the cloud service role instance.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly tier?: string;\n}\n\n/** Role instance properties. */\nexport interface RoleInstanceProperties {\n /** Describes the network profile for the role instance. */\n networkProfile?: RoleInstanceNetworkProfile;\n /** The instance view of the role instance. */\n instanceView?: RoleInstanceView;\n}\n\n/** Describes the network profile for the role instance. */\nexport interface RoleInstanceNetworkProfile {\n /**\n * Specifies the list of resource Ids for the network interfaces associated with the role instance.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly networkInterfaces?: SubResource[];\n}\n\n/** The instance view of the role instance. */\nexport interface RoleInstanceView {\n /**\n * The Update Domain.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformUpdateDomain?: number;\n /**\n * The Fault Domain.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformFaultDomain?: number;\n /**\n * Specifies a unique identifier generated internally for the cloud service associated with this role instance. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateId?: string;\n /** NOTE: This property will not be serialized. It can only be populated by the server. */\n readonly statuses?: ResourceInstanceViewStatus[];\n}\n\n/** Instance view status. */\nexport interface ResourceInstanceViewStatus {\n /**\n * The status code.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * The short localizable label for the status.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly displayStatus?: string;\n /**\n * The detailed status message, including for alerts and error messages.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly message?: string;\n /**\n * The time of the status.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly time?: Date;\n /** The level code. */\n level?: StatusLevelTypes;\n}\n\n/** The list operation result. */\nexport interface RoleInstanceListResult {\n /** The list of resources. */\n value: RoleInstance[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a role of the cloud service. */\nexport interface CloudServiceRole {\n /**\n * Resource id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSku;\n /** The cloud service role properties. */\n properties?: CloudServiceRoleProperties;\n}\n\n/** Describes the cloud service role sku. */\nexport interface CloudServiceRoleSku {\n /** The sku name. NOTE: If the new SKU is not supported on the hardware the cloud service is currently on, you need to delete and recreate the cloud service or move back to the old sku. */\n name?: string;\n /** Specifies the tier of the cloud service. Possible Values are <br /><br /> **Standard** <br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of role instances in the cloud service. */\n capacity?: number;\n}\n\n/** The cloud service role properties. */\nexport interface CloudServiceRoleProperties {\n /**\n * Specifies the ID which uniquely identifies a cloud service role.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n}\n\n/** The list operation result. */\nexport interface CloudServiceRoleListResult {\n /** The list of resources. */\n value: CloudServiceRole[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes the cloud service. */\nexport interface CloudService {\n /**\n * Resource Id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource location. */\n location: string;\n /** Resource tags. */\n tags?: { [propertyName: string]: string };\n /** Cloud service properties */\n properties?: CloudServiceProperties;\n /**\n * Metadata pertaining to creation and last modification of the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly systemData?: SystemData;\n /** List of logical availability zone of the resource. List should contain only 1 zone where cloud service should be provisioned. This field is optional. */\n zones?: string[];\n}\n\n/** Cloud service properties */\nexport interface CloudServiceProperties {\n /**\n * Specifies a URL that refers to the location of the service package in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n packageUrl?: string;\n /** Specifies the XML service configuration (.cscfg) for the cloud service. */\n configuration?: string;\n /**\n * Specifies a URL that refers to the location of the service configuration in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n configurationUrl?: string;\n /**\n * (Optional) Indicates whether to start the cloud service immediately after it is created. The default value is `true`.\n * If false, the service model is still deployed, but the code is not run immediately. Instead, the service is PoweredOff until you call Start, at which time the service will be started. A deployed service still incurs charges, even if it is poweredoff.\n */\n startCloudService?: boolean;\n /**\n * (Optional) Indicates whether the role sku properties (roleProfile.roles.sku) specified in the model/template should override the role instance count and vm size specified in the .cscfg and .csdef respectively.\n * The default value is `false`.\n */\n allowModelOverride?: boolean;\n /**\n * Update mode for the cloud service. Role instances are allocated to update domains when the service is deployed. Updates can be initiated manually in each update domain or initiated automatically in all update domains.\n * Possible Values are <br /><br />**Auto**<br /><br />**Manual** <br /><br />**Simultaneous**<br /><br />\n * If not specified, the default value is Auto. If set to Manual, PUT UpdateDomain must be called to apply the update. If set to Auto, the update is automatically applied to each update domain in sequence.\n */\n upgradeMode?: CloudServiceUpgradeMode;\n /** Describes the role profile for the cloud service. */\n roleProfile?: CloudServiceRoleProfile;\n /** Describes the OS profile for the cloud service. */\n osProfile?: CloudServiceOsProfile;\n /** Network Profile for the cloud service. */\n networkProfile?: CloudServiceNetworkProfile;\n /** Describes a cloud service extension profile. */\n extensionProfile?: CloudServiceExtensionProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The unique identifier for the cloud service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n}\n\n/** Describes the role profile for the cloud service. */\nexport interface CloudServiceRoleProfile {\n /** List of roles for the cloud service. */\n roles?: CloudServiceRoleProfileProperties[];\n}\n\n/** Describes the role properties. */\nexport interface CloudServiceRoleProfileProperties {\n /** Resource name. */\n name?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSku;\n}\n\n/** Describes the OS profile for the cloud service. */\nexport interface CloudServiceOsProfile {\n /** Specifies set of certificates that should be installed onto the role instances. */\n secrets?: CloudServiceVaultSecretGroup[];\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface CloudServiceVaultSecretGroup {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResource;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: CloudServiceVaultCertificate[];\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the role instance. */\nexport interface CloudServiceVaultCertificate {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. */\n certificateUrl?: string;\n /** Flag indicating if the certificate provided is a bootstrap certificate to be used by the Key Vault Extension to fetch the remaining certificates. */\n isBootstrapCertificate?: boolean;\n}\n\n/** Network Profile for the cloud service. */\nexport interface CloudServiceNetworkProfile {\n /** List of Load balancer configurations. Cloud service can have up to two load balancer configurations, corresponding to a Public Load Balancer and an Internal Load Balancer. */\n loadBalancerConfigurations?: LoadBalancerConfiguration[];\n /**\n * Slot type for the cloud service.\n * Possible values are <br /><br />**Production**<br /><br />**Staging**<br /><br />\n * If not specified, the default value is Production.\n */\n slotType?: CloudServiceSlotType;\n /** The id reference of the cloud service containing the target IP with which the subject cloud service can perform a swap. This property cannot be updated once it is set. The swappable cloud service referred by this id must be present otherwise an error will be thrown. */\n swappableCloudService?: SubResource;\n}\n\n/** Describes the load balancer configuration. */\nexport interface LoadBalancerConfiguration {\n /** Resource Id */\n id?: string;\n /** The name of the Load balancer */\n name: string;\n /** Properties of the load balancer configuration. */\n properties: LoadBalancerConfigurationProperties;\n}\n\n/** Describes the properties of the load balancer configuration. */\nexport interface LoadBalancerConfigurationProperties {\n /** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\n frontendIpConfigurations: LoadBalancerFrontendIpConfiguration[];\n}\n\n/** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\nexport interface LoadBalancerFrontendIpConfiguration {\n /** The name of the resource that is unique within the set of frontend IP configurations used by the load balancer. This name can be used to access the resource. */\n name: string;\n /** Properties of load balancer frontend ip configuration. */\n properties: LoadBalancerFrontendIpConfigurationProperties;\n}\n\n/** Describes a cloud service IP Configuration */\nexport interface LoadBalancerFrontendIpConfigurationProperties {\n /** The reference to the public ip address resource. */\n publicIPAddress?: SubResource;\n /** The reference to the virtual network subnet resource. */\n subnet?: SubResource;\n /** The virtual network private IP address of the IP configuration. */\n privateIPAddress?: string;\n}\n\n/** Describes a cloud service extension profile. */\nexport interface CloudServiceExtensionProfile {\n /** List of extensions for the cloud service. */\n extensions?: Extension[];\n}\n\n/** Describes a cloud service Extension. */\nexport interface Extension {\n /** The name of the extension. */\n name?: string;\n /** Extension Properties. */\n properties?: CloudServiceExtensionProperties;\n}\n\n/** Extension Properties. */\nexport interface CloudServiceExtensionProperties {\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension. */\n type?: string;\n /** Specifies the version of the extension. Specifies the version of the extension. If this element is not specified or an asterisk (*) is used as the value, the latest version of the extension is used. If the value is specified with a major version number and an asterisk as the minor version number (X.), the latest minor version of the specified major version is selected. If a major version number and a minor version number are specified (X.Y), the specific extension version is selected. If a version is specified, an auto-upgrade is performed on the role instance. */\n typeHandlerVersion?: string;\n /** Explicitly specify whether platform can automatically upgrade typeHandlerVersion to higher minor versions when they become available. */\n autoUpgradeMinorVersion?: boolean;\n /** Public settings for the extension. For JSON extensions, this is the JSON settings for the extension. For XML Extension (like RDP), this is the XML setting for the extension. */\n settings?: any;\n /** Protected settings for the extension which are encrypted before sent to the role instance. */\n protectedSettings?: any;\n /** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\n protectedSettingsFromKeyVault?: CloudServiceVaultAndSecretReference;\n /**\n * Tag to force apply the provided public and protected settings.\n * Changing the tag value allows for re-running the extension without changing any of the public or protected settings.\n * If forceUpdateTag is not changed, updates to public or protected settings would still be applied by the handler.\n * If neither forceUpdateTag nor any of public or protected settings change, extension would flow to the role instance with the same sequence-number, and\n * it is up to handler implementation whether to re-run it or not\n */\n forceUpdateTag?: string;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Optional list of roles to apply this extension. If property is not specified or '*' is specified, extension is applied to all roles in the cloud service. */\n rolesAppliedTo?: string[];\n}\n\n/** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\nexport interface CloudServiceVaultAndSecretReference {\n /** The ARM Resource ID of the Key Vault */\n sourceVault?: SubResource;\n /** Secret URL which contains the protected settings of the extension */\n secretUrl?: string;\n}\n\nexport interface CloudServiceUpdate {\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** InstanceView of CloudService as a whole */\nexport interface CloudServiceInstanceView {\n /** Instance view statuses. */\n roleInstance?: InstanceViewStatusesSummary;\n /**\n * The version of the SDK that was used to generate the package for the cloud service.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sdkVersion?: string;\n /**\n * Specifies a list of unique identifiers generated internally for the cloud service. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateIds?: string[];\n /** NOTE: This property will not be serialized. It can only be populated by the server. */\n readonly statuses?: ResourceInstanceViewStatus[];\n}\n\n/** Instance view statuses. */\nexport interface InstanceViewStatusesSummary {\n /**\n * The summary.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statusesSummary?: StatusCodeCount[];\n}\n\n/** The status code and count of the cloud service instance view statuses */\nexport interface StatusCodeCount {\n /**\n * The instance view status code\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly code?: string;\n /**\n * Number of instances having this status code\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly count?: number;\n}\n\n/** The list operation result. */\nexport interface CloudServiceListResult {\n /** The list of resources. */\n value: CloudService[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Specifies a list of role instances from the cloud service. */\nexport interface RoleInstances {\n /** List of cloud service role instance names. Value of '*' will signify all role instances of the cloud service. */\n roleInstances: string[];\n}\n\n/** Defines an update domain for the cloud service. */\nexport interface UpdateDomain {\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource Name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n}\n\n/** The list operation result. */\nexport interface UpdateDomainListResult {\n /** The list of resources. */\n value: UpdateDomain[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS version. */\nexport interface OSVersion {\n /**\n * Resource Id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** OS version properties. */\n properties?: OSVersionProperties;\n}\n\n/** OS version properties. */\nexport interface OSVersionProperties {\n /**\n * The family of this OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly family?: string;\n /**\n * The family label of this OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly familyLabel?: string;\n /**\n * The OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The OS version label.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly label?: string;\n /**\n * Specifies whether this is the default OS version for its family.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isDefault?: boolean;\n /**\n * Specifies whether this OS version is active.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSVersionListResult {\n /** The list of resources. */\n value: OSVersion[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS family. */\nexport interface OSFamily {\n /**\n * Resource Id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource location.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly location?: string;\n /** OS family properties. */\n properties?: OSFamilyProperties;\n}\n\n/** OS family properties. */\nexport interface OSFamilyProperties {\n /**\n * The OS family name.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * The OS family label.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly label?: string;\n /**\n * List of OS versions belonging to this family.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly versions?: OSVersionPropertiesBase[];\n}\n\n/** Configuration view of an OS version. */\nexport interface OSVersionPropertiesBase {\n /**\n * The OS version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly version?: string;\n /**\n * The OS version label.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly label?: string;\n /**\n * Specifies whether this is the default OS version for its family.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isDefault?: boolean;\n /**\n * Specifies whether this OS version is active.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSFamilyListResult {\n /** The list of resources. */\n value: OSFamily[];\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** The Resource model definition with location property as optional. */\nexport interface ResourceWithOptionalLocation {\n /** Resource location */\n location?: string;\n /**\n * Resource Id\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly id?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource tags */\n tags?: { [propertyName: string]: string };\n}\n\n/** Describes the parameter of customer managed disk encryption set resource id that can be specified for disk. **Note:** The disk encryption set resource id can only be specified for managed disk. Please refer https://aka.ms/mdssewithcmkoverview for more details. */\nexport interface DiskEncryptionSetParameters extends SubResource {}\n\n/** Virtual machine image resource information. */\nexport interface VirtualMachineImageResource extends SubResource {\n /** The name of the resource. */\n name: string;\n /** The supported Azure location of the resource. */\n location: string;\n /** Specifies the tags that are assigned to the virtual machine. For more information about using tags, see [Using tags to organize your Azure resources](https://docs.microsoft.com/azure/azure-resource-manager/resource-group-using-tags.md). */\n tags?: { [propertyName: string]: string };\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocation;\n}\n\n/** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. NOTE: Image reference publisher and offer can only be set when you create the scale set. */\nexport interface ImageReference extends SubResource {\n /** The image publisher. */\n publisher?: string;\n /** Specifies the offer of the platform image or marketplace image used to create the virtual machine. */\n offer?: string;\n /** The image SKU. */\n sku?: string;\n /** Specifies the version of the platform image or marketplace image used to create the virtual machine. The allowed formats are Major.Minor.Build or 'latest'. Major, Minor, and Build are decimal numbers. Specify 'latest' to use the latest version of an image available at deploy time. Even if you use 'latest', the VM image will not automatically update after deploy time even if a new version becomes available. Please do not use field 'version' for gallery image deployment, gallery image should always use 'id' field for deployment, to use 'latest' version of gallery image, just set '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/images/{imageName}' in the 'id' field without version input. */\n version?: string;\n /**\n * Specifies in decimal numbers, the version of platform image or marketplace image used to create the virtual machine. This readonly field differs from 'version', only if the value specified in 'version' field is 'latest'.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly exactVersion?: string;\n /** Specified the shared gallery image unique id for vm deployment. This can be fetched from shared gallery image GET call. */\n sharedGalleryImageId?: string;\n /** Specified the community gallery image unique id for vm deployment. This can be fetched from community gallery image GET call. */\n communityGalleryImageId?: string;\n}\n\n/** The parameters of a managed disk. */\nexport interface ManagedDiskParameters extends SubResource {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?: StorageAccountTypes;\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParameters;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfile;\n}\n\n/** Describes a network interface reference. */\nexport interface NetworkInterfaceReference extends SubResource {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: DeleteOptions;\n}\n\nexport interface SubResourceWithColocationStatus extends SubResource {\n /** Describes colocation status of a resource in the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatus;\n}\n\n/** Output of virtual machine capture operation. */\nexport interface VirtualMachineCaptureResult extends SubResource {\n /**\n * the schema of the captured virtual machine\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly schema?: string;\n /**\n * the version of the content\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly contentVersion?: string;\n /**\n * parameters of the captured virtual machine\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly parameters?: any;\n /**\n * a list of resource items of the captured virtual machine\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resources?: any[];\n}\n\n/** The resource model definition for an Azure Resource Manager tracked top level resource which has 'tags' and a 'location' */\nexport interface TrackedResource extends Resource {\n /** Resource tags. */\n tags?: { [propertyName: string]: string };\n /** The geo-location where the resource lives */\n location: string;\n}\n\n/** The resource model definition for a Azure Resource Manager proxy resource. It will not have tags and a location */\nexport interface ProxyResource extends Resource {}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtension extends SubResourceReadOnly {\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** Resource name */\n name?: string;\n /** If a value is provided and is different from the previous value, the extension handler will be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** Disk Restore Point details. */\nexport interface DiskRestorePointAttributes extends SubResourceReadOnly {\n /** Encryption at rest settings for disk restore point. It is an optional property that can be specified in the input while creating a restore point. */\n encryption?: RestorePointEncryption;\n /** Resource Id of the source disk restore point. */\n sourceDiskRestorePoint?: ApiEntityReference;\n}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionUpdate extends SubResourceReadOnly {\n /**\n * The name of the extension.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** If a value is provided and is different from the previous value, the extension handler will be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtension extends SubResourceReadOnly {\n /** The location of the extension. */\n location?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /**\n * Resource name\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** The virtual machine extension instance view. */\n instanceView?: VirtualMachineExtensionInstanceView;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtensionUpdate extends SubResourceReadOnly {\n /**\n * The name of the extension.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n /**\n * Resource type\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly type?: string;\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** The instance view of a capacity reservation that includes the name of the capacity reservation. It is used for the response to the instance view of a capacity reservation group. */\nexport interface CapacityReservationInstanceViewWithName extends CapacityReservationInstanceView {\n /**\n * The name of the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n}\n\n/** The instance view of a dedicated host that includes the name of the dedicated host. It is used for the response to the instance view of a dedicated host group. */\nexport interface DedicatedHostInstanceViewWithName extends DedicatedHostInstanceView {\n /**\n * The name of the dedicated host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly name?: string;\n}\n\n/** Describes an Operating System disk. */\nexport interface ImageOSDisk extends ImageDisk {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from a custom image. Possible values are: **Windows,** **Linux.** */\n osType: OperatingSystemTypes;\n /** The OS State. For managed images, use Generalized. */\n osState: OperatingSystemStateTypes;\n}\n\n/** Describes a data disk. */\nexport interface ImageDataDisk extends ImageDisk {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n}\n\n/** Api request input for LogAnalytics getRequestRateByInterval Api. */\nexport interface RequestRateByIntervalInput extends LogAnalyticsInputBase {\n /** Interval value in minutes used to create LogAnalytics call rate logs. */\n intervalLength: IntervalInMins;\n}\n\n/** Api request input for LogAnalytics getThrottledRequests Api. */\nexport interface ThrottledRequestsInput extends LogAnalyticsInputBase {}\n\n/** Describes the properties of a Run Command. */\nexport interface RunCommandDocument extends RunCommandDocumentBase {\n /** The script to be executed. */\n script: string[];\n /** The parameters used by the script. */\n parameters?: RunCommandParameterDefinition[];\n}\n\n/** Specifies information about the availability set that the virtual machine should be assigned to. Only tags may be updated. */\nexport interface AvailabilitySetUpdate extends UpdateResource {\n /** Sku of the availability set */\n sku?: Sku;\n /** Update Domain count. */\n platformUpdateDomainCount?: number;\n /** Fault Domain count. */\n platformFaultDomainCount?: number;\n /** A list of references to all virtual machines in the availability set. */\n virtualMachines?: SubResource[];\n /** Specifies information about the proximity placement group that the availability set should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /**\n * The resource status information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statuses?: InstanceViewStatus[];\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the availability set. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /**\n * Describes the migration properties on the Availability Set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachineScaleSetMigrationInfo?: VirtualMachineScaleSetMigrationInfo;\n}\n\n/** Specifies information about the capacity reservation group. Only tags can be updated. */\nexport interface CapacityReservationGroupUpdate extends UpdateResource {\n /**\n * A list of all capacity reservation resource ids that belong to capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacityReservations?: SubResourceReadOnly[];\n /**\n * A list of references to all virtual machines associated to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The capacity reservation group instance view which has the list of instance views for all the capacity reservations that belong to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationGroupInstanceView;\n /** Specifies the settings to enable sharing across subscriptions for the capacity reservation group resource. The capacity reservation group resource can generally be shared across subscriptions belonging to a single Azure AAD tenant or across AAD tenants if there is a trust relationship established between the tenants. Block capacity reservation does not support sharing across subscriptions. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details. */\n sharingProfile?: ResourceSharingProfile;\n /** Indicates the type of capacity reservation. Allowed values are 'Block' for block capacity reservations and 'Targeted' for reservations that enable a VM to consume a specific capacity reservation when a capacity reservation group is provided. The reservation type is immutable and cannot be changed after it is assigned. */\n reservationType?: ReservationType;\n}\n\n/** Specifies information about the capacity reservation. sku.capacity cannot be updated for Block Capacity Reservation. Tags can be update for all Capacity Reservation Types. */\nexport interface CapacityReservationUpdate extends UpdateResource {\n /** SKU of the resource for which capacity needs be reserved. The SKU name and capacity is required to be set. Currently VM Skus with the capability called 'CapacityReservationSupported' set to true are supported. When 'CapacityReservationSupported' is true, the SKU capability also specifies the 'SupportedCapacityReservationTypes', which lists the types of capacity reservations (such as Targeted or Block) that the SKU supports. Refer to List Microsoft.Compute SKUs in a region (https://docs.microsoft.com/rest/api/compute/resourceskus/list) for supported values. **Note:** The SKU name and capacity cannot be updated for Block capacity reservations. */\n sku?: Sku;\n /**\n * A unique id generated and assigned to the capacity reservation by the platform which does not change throughout the lifetime of the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reservationId?: string;\n /**\n * Specifies the value of fault domain count that Capacity Reservation supports for requested VM size. **Note:** The fault domain count specified for a resource (like virtual machines scale set) must be less than or equal to this value if it deploys using capacity reservation. Minimum api-version: 2022-08-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformFaultDomainCount?: number;\n /**\n * A list of all virtual machine resource ids that are associated with the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The date time when the capacity reservation was last updated.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The Capacity reservation instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationInstanceView;\n /**\n * Specifies the time at which the Capacity Reservation resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** Defines the schedule for Block-type capacity reservations. Specifies the schedule during which capacity reservation is active and VM or VMSS resource can be allocated using reservation. This property is required and only supported when the capacity reservation group type is 'Block'. The scheduleProfile, start, and end fields are immutable after creation. Minimum API version: 2025-04-01. Please refer to https://aka.ms/blockcapacityreservation for more details. */\n scheduleProfile?: ScheduleProfile;\n}\n\n/** Specifies information about the dedicated host group that the dedicated host should be assigned to. Only tags may be updated. */\nexport interface DedicatedHostGroupUpdate extends UpdateResource {\n /** Availability Zone to use for this host group. Only single zone is supported. The zone can be assigned only during creation. If not provided, the group supports all zones in the region. If provided, enforces each host in the group to be in the same zone. */\n zones?: string[];\n /** Number of fault domains that the host group can span. */\n platformFaultDomainCount?: number;\n /**\n * A list of references to all dedicated hosts in the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hosts?: SubResourceReadOnly[];\n /**\n * The dedicated host group instance view, which has the list of instance view of the dedicated hosts under the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostGroupInstanceView;\n /** Specifies whether virtual machines or virtual machine scale sets can be placed automatically on the dedicated host group. Automatic placement means resources are allocated on dedicated hosts, that are chosen by Azure, under the dedicated host group. The value is defaulted to 'false' when not provided. Minimum api-version: 2020-06-01. */\n supportAutomaticPlacement?: boolean;\n /** Enables or disables a capability on the dedicated host group. Minimum api-version: 2022-03-01. */\n additionalCapabilities?: DedicatedHostGroupPropertiesAdditionalCapabilities;\n}\n\n/** Specifies information about the dedicated host. Only tags, autoReplaceOnFailure and licenseType may be updated. */\nexport interface DedicatedHostUpdate extends UpdateResource {\n /** [List all available dedicated host sizes for resizing] (https://docs.microsoft.com/rest/api/compute/dedicated-hosts/listavailablesizes). Resizing can be only used to scale up DedicatedHost. Only name is required to be set. */\n sku?: Sku;\n /** Fault domain of the dedicated host within a dedicated host group. */\n platformFaultDomain?: number;\n /** Specifies whether the dedicated host should be replaced automatically in case of a failure. The value is defaulted to 'true' when not provided. */\n autoReplaceOnFailure?: boolean;\n /**\n * A unique id generated and assigned to the dedicated host by the platform. Does not change throughout the lifetime of the host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hostId?: string;\n /**\n * A list of references to all virtual machines in the Dedicated Host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachines?: SubResourceReadOnly[];\n /** Specifies the software license type that will be applied to the VMs deployed on the dedicated host. Possible values are: **None,** **Windows_Server_Hybrid,** **Windows_Server_Perpetual.** The default value is: **None.** */\n licenseType?: DedicatedHostLicenseTypes;\n /**\n * The date when the host was first provisioned.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The dedicated host instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostInstanceView;\n /**\n * Specifies the time at which the Dedicated Host resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** The source user image virtual hard disk. Only tags may be updated. */\nexport interface ImageUpdate extends UpdateResource {\n /** The source virtual machine from which Image is created. */\n sourceVirtualMachine?: SubResource;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: ImageStorageProfile;\n /**\n * The provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies the HyperVGenerationType of the VirtualMachine created from the image. From API Version 2019-03-01 if the image source is a blob, then we need the user to specify the value, if the source is managed resource like disk or snapshot, we may require the user to specify the property if we cannot deduce it from the source managed resource. */\n hyperVGeneration?: HyperVGenerationTypes;\n}\n\n/** Specifies information about the proximity placement group. */\nexport interface ProximityPlacementGroupUpdate extends UpdateResource {}\n\n/** Update Restore Point collection parameters. */\nexport interface RestorePointCollectionUpdate extends UpdateResource {\n /** The properties of the source resource that this restore point collection is created from. */\n source?: RestorePointCollectionSourceProperties;\n /**\n * The provisioning state of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The unique id of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePointCollectionId?: string;\n /**\n * A list containing all restore points created under this restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePoints?: RestorePoint[];\n /** This property determines whether instant access snapshot is enabled for restore points created under this restore point collection for Premium SSD v2 or Ultra disk. Instant access snapshot for Premium SSD v2 or Ultra disk is instantaneously available for restoring disk with fast restore performance. */\n instantAccess?: boolean;\n}\n\n/** Specifies information about the SSH public key. */\nexport interface SshPublicKeyUpdateResource extends UpdateResource {\n /** SSH public key used to authenticate to a virtual machine through ssh. If this property is not initially provided when the resource is created, the publicKey property will be populated when generateKeyPair is called. If the public key is provided upon resource creation, the provided public key needs to be at least 2048-bit and in ssh-rsa format. */\n publicKey?: string;\n}\n\n/** Describes a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetUpdate extends UpdateResource {\n /** The virtual machine scale set sku. */\n sku?: Sku;\n /** The purchase plan when deploying a virtual machine scale set from VM Marketplace images. */\n plan?: Plan;\n /** The identity of the virtual machine scale set, if configured. */\n identity?: VirtualMachineScaleSetIdentity;\n /** The virtual machine scale set zones. */\n zones?: string[];\n /** The upgrade policy. */\n upgradePolicy?: UpgradePolicy;\n /** Policy for automatic repairs. */\n automaticRepairsPolicy?: AutomaticRepairsPolicy;\n /** The virtual machine profile. */\n virtualMachineProfile?: VirtualMachineScaleSetUpdateVMProfile;\n /** Specifies whether the Virtual Machine Scale Set should be overprovisioned. */\n overprovision?: boolean;\n /** When Overprovision is enabled, extensions are launched only on the requested number of VMs which are finally kept. This property will hence ensure that the extensions do not run on the extra overprovisioned VMs. */\n doNotRunExtensionsOnOverprovisionedVMs?: boolean;\n /** When true this limits the scale set to a single placement group, of max size 100 virtual machines. NOTE: If singlePlacementGroup is true, it may be modified to false. However, if singlePlacementGroup is false, it may not be modified to true. */\n singlePlacementGroup?: boolean;\n /** Specifies additional capabilities enabled or disabled on the Virtual Machines in the Virtual Machine Scale Set. For instance: whether the Virtual Machines have the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the policies applied when scaling in Virtual Machines in the Virtual Machine Scale Set. */\n scaleInPolicy?: ScaleInPolicy;\n /** Specifies information about the proximity placement group that the virtual machine scale set should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies the desired targets for mixing Spot and Regular priority VMs within the same VMSS Flex instance. */\n priorityMixPolicy?: PriorityMixPolicy;\n /** Specifies the Spot Restore properties for the virtual machine scale set. */\n spotRestorePolicy?: SpotRestorePolicy;\n /** Policy for Resiliency */\n resiliencyPolicy?: ResiliencyPolicy;\n /** Specifies the align mode between Virtual Machine Scale Set compute and storage Fault Domain count. */\n zonalPlatformFaultDomainAlignMode?: ZonalPlatformFaultDomainAlignMode;\n /** Specifies the sku profile for the virtual machine scale set. */\n skuProfile?: SkuProfile;\n}\n\n/** Describes a Virtual Machine run command. */\nexport interface VirtualMachineRunCommandUpdate extends UpdateResource {\n /** The source of the run command script. */\n source?: VirtualMachineRunCommandScriptSource;\n /** The parameters used by the script. */\n parameters?: RunCommandInputParameter[];\n /** The parameters used by the script. */\n protectedParameters?: RunCommandInputParameter[];\n /** Optional. If set to true, provisioning will complete as soon as the script starts and will not wait for script to complete. */\n asyncExecution?: boolean;\n /** Specifies the user account on the VM when executing the run command. */\n runAsUser?: string;\n /** Specifies the user account password on the VM when executing the run command. */\n runAsPassword?: string;\n /** The timeout in seconds to execute the run command. */\n timeoutInSeconds?: number;\n /** Specifies the Azure storage blob where script output stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer outputBlobManagedIdentity parameter. */\n outputBlobUri?: string;\n /** Specifies the Azure storage blob where script error stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer errorBlobManagedIdentity parameter. */\n errorBlobUri?: string;\n /** User-assigned managed identity that has access to outputBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n outputBlobManagedIdentity?: RunCommandManagedIdentity;\n /** User-assigned managed identity that has access to errorBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n errorBlobManagedIdentity?: RunCommandManagedIdentity;\n /**\n * The provisioning state, which only appears in the response. If treatFailureAsDeploymentFailure set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If treatFailureAsDeploymentFailure set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine run command instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineRunCommandInstanceView;\n /** Optional. If set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results */\n treatFailureAsDeploymentFailure?: boolean;\n}\n\n/** Describes a Virtual Machine Update. */\nexport interface VirtualMachineUpdate extends UpdateResource {\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentity;\n /** The virtual machine zones. */\n zones?: string[];\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfile;\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the virtual machine. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfile;\n /** Specifies additional capabilities enabled or disabled on the virtual machine. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the operating system settings used while creating the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\n osProfile?: OSProfile;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfile;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfile;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to availability set at creation time. The availability set to which the VM is being added should be under the same resource group as the availability set resource. An existing VM cannot be added to an availability set. This property cannot exist along with a non-null properties.virtualMachineScaleSet reference. */\n availabilitySet?: SubResource;\n /** Specifies information about the virtual machine scale set that the virtual machine should be assigned to. Virtual machines specified in the same virtual machine scale set are allocated to different nodes to maximize availability. Currently, a VM can only be added to virtual machine scale set at creation time. An existing VM cannot be added to a virtual machine scale set. This property cannot exist along with a non-null properties.availabilitySet reference. Minimum api‐version: 2019‐03‐01. */\n virtualMachineScaleSet?: SubResource;\n /** Specifies information about the proximity placement group that the virtual machine should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies the priority for the virtual machine. Minimum api-version: 2019-03-01 */\n priority?: VirtualMachinePriorityTypes;\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: VirtualMachineEvictionPolicyTypes;\n /** Specifies the billing related details of a Azure Spot virtual machine. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies information about the dedicated host that the virtual machine resides in. Minimum api-version: 2018-10-01. */\n host?: SubResource;\n /** Specifies information about the dedicated host group that the virtual machine resides in. **Note:** User cannot specify both host and hostGroup properties. Minimum api-version: 2020-06-01. */\n hostGroup?: SubResource;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineInstanceView;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /**\n * Specifies the VM unique ID which is a 128-bits identifier that is encoded and stored in all Azure IaaS VMs SMBIOS and can be read using platform BIOS commands.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). Minimum api-version: 2020-06-01. */\n extensionsTimeBudget?: string;\n /** Specifies the scale set logical fault domain into which the Virtual Machine will be created. By default, the Virtual Machine will by automatically assigned to a fault domain that best maintains balance across available fault domains. This is applicable only if the 'virtualMachineScaleSet' property of this Virtual Machine is set. The Virtual Machine Scale Set that is referenced, must have 'platformFaultDomainCount' greater than 1. This property cannot be updated once the Virtual Machine is created. Fault domain assignment can be viewed in the Virtual Machine Instance View. Minimum api‐version: 2020‐12‐01. */\n platformFaultDomain?: number;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01. */\n userData?: string;\n /** Specifies information about the capacity reservation that is used to allocate virtual machine. Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfile;\n /** Specifies the gallery applications that should be made available to the VM/VMSS. */\n applicationProfile?: ApplicationProfile;\n /**\n * Specifies the time at which the Virtual Machine resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Describes a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionUpdate extends UpdateResource {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n}\n\n/** Describes a Virtual Machine Scale Set VM Reimage Parameters. */\nexport interface VirtualMachineScaleSetVMReimageParameters extends VirtualMachineReimageParameters {\n /** Parameter to force update ephemeral OS disk for a virtual machine scale set VM */\n forceUpdateOSDiskForEphemeral?: boolean;\n}\n\n/** Specifies information about the Community Gallery that you want to create or update. */\nexport interface CommunityGallery extends PirCommunityGalleryResource {\n /** The disclaimer for a community gallery resource. */\n disclaimer?: string;\n /** The artifact tags of a community gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n /** The metadata of community gallery. */\n communityMetadata?: CommunityGalleryMetadata;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface CommunityGalleryImage extends PirCommunityGalleryResource {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the community gallery image definition identifier. */\n identifier?: CommunityGalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Privacy statement URI for the current community gallery image. */\n privacyStatementUri?: string;\n /** The end-user license agreement for the current community gallery image. */\n eula?: string;\n /** The disclaimer for a community gallery resource. */\n disclaimer?: string;\n /** The artifact tags of a community gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface CommunityGalleryImageVersion extends PirCommunityGalleryResource {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: Date;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfile;\n /** The disclaimer for a community gallery resource. */\n disclaimer?: string;\n /** The artifact tags of a community gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** This is the OS disk image. */\nexport interface SharedGalleryOSDiskImage extends SharedGalleryDiskImage {}\n\n/** This is the data disk image. */\nexport interface SharedGalleryDataDiskImage extends SharedGalleryDiskImage {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** Base information about the shared gallery resource in pir. */\nexport interface PirSharedGalleryResource extends PirResource {\n /** The unique id of this shared gallery. */\n uniqueId?: string;\n}\n\n/** Specifies information about the Shared Image Gallery that you want to update. */\nexport interface GalleryUpdate extends UpdateResourceDefinition {\n /** The identity of the gallery, if configured. */\n identity?: GalleryIdentity;\n /** The description of this Shared Image Gallery resource. This property is updatable. */\n description?: string;\n /** Describes the gallery unique name. */\n identifier?: GalleryIdentifier;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** Profile for gallery sharing to subscription or tenant */\n sharingProfile?: SharingProfile;\n /** Contains information about the soft deletion policy of the gallery. */\n softDeletePolicy?: SoftDeletePolicy;\n /**\n * Sharing status of current gallery.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sharingStatus?: SharingStatus;\n}\n\n/** Specifies information about the gallery Application Definition that you want to update. */\nexport interface GalleryApplicationUpdate extends UpdateResourceDefinition {\n /** The description of this gallery Application Definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery Application Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Application Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This property allows you to specify the supported type of the OS that application is built for. Possible values are: **Windows,** **Linux.** */\n supportedOSType?: OperatingSystemTypes;\n /** A list of custom actions that can be performed with all of the Gallery Application Versions within this Gallery Application. */\n customActions?: GalleryApplicationCustomAction[];\n}\n\n/** Specifies information about the gallery Application Version that you want to update. */\nexport interface GalleryApplicationVersionUpdate extends UpdateResourceDefinition {\n /** The publishing profile of a gallery image version. */\n publishingProfile?: GalleryApplicationVersionPublishingProfile;\n /** The safety profile of the Gallery Application Version. */\n safetyProfile?: GalleryApplicationVersionSafetyProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** Specifies information about the gallery image definition that you want to update. */\nexport interface GalleryImageUpdate extends UpdateResourceDefinition {\n /** The description of this gallery image definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery image definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the gallery image definition identifier. */\n identifier?: GalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Optional. Must be set to true if the gallery image features are being updated. */\n allowUpdateImage?: boolean;\n}\n\n/** Specifies information about the gallery image version that you want to update. */\nexport interface GalleryImageVersionUpdate extends UpdateResourceDefinition {\n /** The publishing profile of a gallery image Version. */\n publishingProfile?: GalleryImageVersionPublishingProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** This is the storage profile of a Gallery Image Version. */\n storageProfile?: GalleryImageVersionStorageProfile;\n /** This is the safety profile of the Gallery Image Version. */\n safetyProfile?: GalleryImageVersionSafetyProfile;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** The security profile of a gallery image version */\n securityProfile?: ImageVersionSecurityProfile;\n /** Indicates if this is a soft-delete resource restoration request. */\n restore?: boolean;\n /**\n * This is the validations profile of a Gallery Image Version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly validationsProfile?: ValidationsProfile;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile that you want to update. */\nexport interface GalleryInVMAccessControlProfileUpdate extends UpdateResourceDefinition {\n /** Describes the properties of a gallery inVMAccessControlProfile. */\n properties?: GalleryInVMAccessControlProfileProperties;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile version that you want to update. */\nexport interface GalleryInVMAccessControlProfileVersionUpdate extends UpdateResourceDefinition {\n /** The target regions where the Resource Profile version is going to be replicated to. This property is updatable. */\n targetLocations?: TargetRegion[];\n /** If set to true, Virtual Machines deployed from the latest version of the Resource Profile won't use this Profile version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the Resource Profile Version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** This property allows you to specify whether the access control rules are in Audit mode, in Enforce mode or Disabled. Possible values are: 'Audit', 'Enforce' or 'Disabled'. */\n mode?: AccessControlRulesMode;\n /** This property allows you to specify if the requests will be allowed to access the host endpoints. Possible values are: 'Allow', 'Deny'. */\n defaultAccess?: EndpointAccess;\n /** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\n rules?: AccessControlRules;\n}\n\n/** Specifies information about the gallery Script Definition that you want to update. */\nexport interface GalleryScriptUpdate extends UpdateResourceDefinition {\n /** The description of this gallery script definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement (End User License Agreement) for the gallery Script Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Script Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This property allows you to specify the supported type of the OS that application is built for. Possible values are: **Windows,** **Linux.** */\n supportedOSType?: OperatingSystemTypes;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n}\n\n/** Specifies information about the gallery Script Version that you want to update. */\nexport interface GalleryScriptVersionUpdate extends UpdateResourceDefinition {\n /** The publishing profile of a gallery image version. */\n publishingProfile?: GalleryScriptVersionPublishingProfile;\n /** The safety profile of the Gallery Script Version. */\n safetyProfile?: GalleryScriptVersionSafetyProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** The publishing profile of a gallery image version. */\nexport interface GalleryApplicationVersionPublishingProfile extends GalleryArtifactPublishingProfileBase {\n /** The source image from which the Image Version is going to be created. */\n source: UserArtifactSource;\n manageActions?: UserArtifactManage;\n /** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\n settings?: UserArtifactSettings;\n /** Optional. Additional settings to pass to the vm-application-manager extension. For advanced use only. */\n advancedSettings?: { [propertyName: string]: string };\n /** Optional. Whether or not this application reports health. */\n enableHealthCheck?: boolean;\n /** A list of custom actions that can be performed with this Gallery Application Version. */\n customActions?: GalleryApplicationCustomAction[];\n}\n\n/** The publishing profile of a gallery image Version. */\nexport interface GalleryImageVersionPublishingProfile extends GalleryArtifactPublishingProfileBase {}\n\n/** The publishing profile of a gallery image version. */\nexport interface GalleryScriptVersionPublishingProfile extends GalleryArtifactPublishingProfileBase {\n /** The source script from which the Script Version is going to be created. */\n source: ScriptSource;\n}\n\n/** Contains encryption settings for an OS disk image. */\nexport interface OSDiskImageEncryption extends DiskImageEncryption {\n /** This property specifies the security profile of an OS disk image. */\n securityProfile?: OSDiskImageSecurityProfile;\n}\n\n/** Contains encryption settings for a data disk image. */\nexport interface DataDiskImageEncryption extends DiskImageEncryption {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** The safety profile of the Gallery Application Version. */\nexport interface GalleryApplicationVersionSafetyProfile extends GalleryArtifactSafetyProfileBase {}\n\n/** This is the safety profile of the Gallery Image Version. */\nexport interface GalleryImageVersionSafetyProfile extends GalleryArtifactSafetyProfileBase {\n /**\n * Indicates whether this image has been reported as violating Microsoft's policies.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reportedForPolicyViolation?: boolean;\n /**\n * A list of Policy Violations that have been reported for this Gallery Image Version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly policyViolations?: PolicyViolation[];\n /** Indicates whether or not the deletion is blocked for this Gallery Image Version if its End Of Life has not expired. */\n blockDeletionBeforeEndOfLife?: boolean;\n}\n\n/** The safety profile of the Gallery Script Version. */\nexport interface GalleryScriptVersionSafetyProfile extends GalleryArtifactSafetyProfileBase {}\n\n/** The source of the gallery artifact version. */\nexport interface GalleryArtifactVersionFullSource extends GalleryArtifactVersionSource {\n /** The resource Id of the source Community Gallery Image. Only required when using Community Gallery Image as a source. */\n communityGalleryImageId?: string;\n /** The resource Id of the source virtual machine. Only required when capturing a virtual machine to source this Gallery Image Version. */\n virtualMachineId?: string;\n}\n\n/** The source for the disk image. */\nexport interface GalleryDiskImageSource extends GalleryArtifactVersionSource {\n /** The uri of the gallery artifact version source. Currently used to specify vhd/blob source. */\n uri?: string;\n /** The Storage Account Id that contains the vhd blob being used as a source for this artifact version. */\n storageAccountId?: string;\n}\n\n/** This is the OS disk image. */\nexport interface GalleryOSDiskImage extends GalleryDiskImage {}\n\n/** This is the data disk image. */\nexport interface GalleryDataDiskImage extends GalleryDiskImage {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** Describes the properties of a gallery inVMAccessControlProfile. */\nexport interface GalleryInVMAccessControlProfileProperties extends GalleryResourceProfilePropertiesBase {\n /** The description of this gallery inVMAccessControlProfile resources. This property is updatable. */\n description?: string;\n /** This property allows you to specify the OS type of the VMs/VMSS for which this profile can be used against. Possible values are: 'Windows' or 'Linux' */\n osType: OperatingSystemTypes;\n /** This property allows you to specify the Endpoint type for which this profile is defining the access control for. Possible values are: 'WireServer' or 'IMDS' */\n applicableHostEndpoint: EndpointTypes;\n}\n\n/** Describes the properties of an inVMAccessControlProfile version. */\nexport interface GalleryInVMAccessControlProfileVersionProperties extends GalleryResourceProfileVersionPropertiesBase {\n /** This property allows you to specify whether the access control rules are in Audit mode, in Enforce mode or Disabled. Possible values are: 'Audit', 'Enforce' or 'Disabled'. */\n mode: AccessControlRulesMode;\n /** This property allows you to specify if the requests will be allowed to access the host endpoints. Possible values are: 'Allow', 'Deny'. */\n defaultAccess: EndpointAccess;\n /** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\n rules?: AccessControlRules;\n}\n\n/** The definition of a parameter that can be passed to a script of a Gallery Script Version. */\nexport interface GalleryScriptParameter extends GenericGalleryParameter {\n /** Specifies the type of the Gallery Script parameter. Possible values are: String, Int, Double, Boolean, Enum */\n type?: GalleryScriptParameterType;\n /** The minimum value of parameter. */\n minValue?: string;\n /** The minimum value of parameter. */\n maxValue?: string;\n /** A list of permissible values. Only applicable values are from 'enum' values defined in 'GalleryScriptParameter'. */\n enumValues?: string[];\n}\n\n/** Describes a Virtual Machine Image. */\nexport interface VirtualMachineImage extends VirtualMachineImageResource {\n /** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\n plan?: PurchasePlan;\n /** Contains the os disk image information. */\n osDiskImage?: OSDiskImage;\n /** The list of data disk images information. */\n dataDiskImages?: DataDiskImage[];\n /** Describes automatic OS upgrade properties on the image. */\n automaticOSUpgradeProperties?: AutomaticOSUpgradeProperties;\n /** Specifies the HyperVGeneration Type */\n hyperVGeneration?: HyperVGenerationTypes;\n /** Specifies disallowed configuration for the VirtualMachine created from the image */\n disallowed?: DisallowedConfiguration;\n features?: VirtualMachineImageFeature[];\n /** Specifies the Architecture Type */\n architecture?: ArchitectureTypes;\n /** Describes image deprecation status properties on the image. */\n imageDeprecationStatus?: ImageDeprecationStatus;\n}\n\n/** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to an availability set at creation time. An existing VM cannot be added to an availability set. */\nexport interface AvailabilitySet extends TrackedResource {\n /** Sku of the availability set, only name is required to be set. See AvailabilitySetSkuTypes for possible set of values. Use 'Aligned' for virtual machines with managed disks and 'Classic' for virtual machines with unmanaged disks. Default value is 'Classic'. */\n sku?: Sku;\n /** Update Domain count. */\n platformUpdateDomainCount?: number;\n /** Fault Domain count. */\n platformFaultDomainCount?: number;\n /** A list of references to all virtual machines in the availability set. */\n virtualMachines?: SubResource[];\n /** Specifies information about the proximity placement group that the availability set should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /**\n * The resource status information.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly statuses?: InstanceViewStatus[];\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the availability set. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /**\n * Describes the migration properties on the Availability Set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachineScaleSetMigrationInfo?: VirtualMachineScaleSetMigrationInfo;\n}\n\n/** Specifies information about the capacity reservation group that the capacity reservations should be assigned to. Currently, a capacity reservation can only be added to a capacity reservation group at creation time. An existing capacity reservation cannot be added or moved to another capacity reservation group. */\nexport interface CapacityReservationGroup extends TrackedResource {\n /** The availability zones. */\n zones?: string[];\n /**\n * A list of all capacity reservation resource ids that belong to capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly capacityReservations?: SubResourceReadOnly[];\n /**\n * A list of references to all virtual machines associated to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The capacity reservation group instance view which has the list of instance views for all the capacity reservations that belong to the capacity reservation group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationGroupInstanceView;\n /** Specifies the settings to enable sharing across subscriptions for the capacity reservation group resource. The capacity reservation group resource can generally be shared across subscriptions belonging to a single Azure AAD tenant or across AAD tenants if there is a trust relationship established between the tenants. Block capacity reservation does not support sharing across subscriptions. **Note:** Minimum api-version: 2023-09-01. Please refer to https://aka.ms/computereservationsharing for more details. */\n sharingProfile?: ResourceSharingProfile;\n /** Indicates the type of capacity reservation. Allowed values are 'Block' for block capacity reservations and 'Targeted' for reservations that enable a VM to consume a specific capacity reservation when a capacity reservation group is provided. The reservation type is immutable and cannot be changed after it is assigned. */\n reservationType?: ReservationType;\n}\n\n/** Specifies information about the dedicated host group that the dedicated hosts should be assigned to. Currently, a dedicated host can only be added to a dedicated host group at creation time. An existing dedicated host cannot be added to another dedicated host group. */\nexport interface DedicatedHostGroup extends TrackedResource {\n /** The availability zones. */\n zones?: string[];\n /** Number of fault domains that the host group can span. */\n platformFaultDomainCount?: number;\n /**\n * A list of references to all dedicated hosts in the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hosts?: SubResourceReadOnly[];\n /**\n * The dedicated host group instance view, which has the list of instance view of the dedicated hosts under the dedicated host group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostGroupInstanceView;\n /** Specifies whether virtual machines or virtual machine scale sets can be placed automatically on the dedicated host group. Automatic placement means resources are allocated on dedicated hosts, that are chosen by Azure, under the dedicated host group. The value is defaulted to 'false' when not provided. Minimum api-version: 2020-06-01. */\n supportAutomaticPlacement?: boolean;\n /** Enables or disables a capability on the dedicated host group. Minimum api-version: 2022-03-01. */\n additionalCapabilities?: DedicatedHostGroupPropertiesAdditionalCapabilities;\n}\n\n/** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\nexport interface Image extends TrackedResource {\n /** The extended location of the Image. */\n extendedLocation?: ExtendedLocation;\n /** The source virtual machine from which Image is created. */\n sourceVirtualMachine?: SubResource;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: ImageStorageProfile;\n /**\n * The provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies the HyperVGenerationType of the VirtualMachine created from the image. From API Version 2019-03-01 if the image source is a blob, then we need the user to specify the value, if the source is managed resource like disk or snapshot, we may require the user to specify the property if we cannot deduce it from the source managed resource. */\n hyperVGeneration?: HyperVGenerationTypes;\n}\n\n/** Describes a Virtual Machine Extension Image. */\nexport interface VirtualMachineExtensionImage extends TrackedResource {\n /** The operating system this extension supports. */\n operatingSystem?: string;\n /** The type of role (IaaS or PaaS) this extension supports. */\n computeRole?: string;\n /** The schema defined by publisher, where extension consumers should provide settings in a matching schema. */\n handlerSchema?: string;\n /** Whether the extension can be used on xRP VMScaleSets. By default existing extensions are usable on scalesets, but there might be cases where a publisher wants to explicitly indicate the extension is only enabled for CRP VMs but not VMSS. */\n vmScaleSetEnabled?: boolean;\n /** Whether the handler can support multiple extensions. */\n supportsMultipleExtensions?: boolean;\n}\n\n/** Describes a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSet extends TrackedResource {\n /** The virtual machine scale set sku. */\n sku?: Sku;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /** The identity of the virtual machine scale set, if configured. */\n identity?: VirtualMachineScaleSetIdentity;\n /** The availability zones. */\n zones?: string[];\n /** The extended location of the Virtual Machine Scale Set. */\n extendedLocation?: ExtendedLocation;\n /**\n * Etag is property returned in Create/Update/Get response of the VMSS, so that customer can supply it in the header to ensure optimistic updates\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly etag?: string;\n /** Placement section specifies the user-defined constraints for virtual machine scale set hardware placement. This property cannot be changed once VMSS is provisioned. Minimum api-version: 2025-04-01. */\n placement?: Placement;\n /** The upgrade policy. */\n upgradePolicy?: UpgradePolicy;\n /** The ScheduledEventsPolicy. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /** Policy for automatic repairs. */\n automaticRepairsPolicy?: AutomaticRepairsPolicy;\n /** The virtual machine profile. */\n virtualMachineProfile?: VirtualMachineScaleSetVMProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies whether the Virtual Machine Scale Set should be overprovisioned. */\n overprovision?: boolean;\n /** When Overprovision is enabled, extensions are launched only on the requested number of VMs which are finally kept. This property will hence ensure that the extensions do not run on the extra overprovisioned VMs. */\n doNotRunExtensionsOnOverprovisionedVMs?: boolean;\n /**\n * Specifies the ID which uniquely identifies a Virtual Machine Scale Set.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n /** When true this limits the scale set to a single placement group, of max size 100 virtual machines. NOTE: If singlePlacementGroup is true, it may be modified to false. However, if singlePlacementGroup is false, it may not be modified to true. */\n singlePlacementGroup?: boolean;\n /** Whether to force strictly even Virtual Machine distribution cross x-zones in case there is zone outage. zoneBalance property can only be set if the zones property of the scale set contains more than one zone. If there are no zones or only one zone specified, then zoneBalance property should not be set. */\n zoneBalance?: boolean;\n /** Fault Domain count for each placement group. */\n platformFaultDomainCount?: number;\n /** Specifies information about the proximity placement group that the virtual machine scale set should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies information about the dedicated host group that the virtual machine scale set resides in. Minimum api-version: 2020-06-01. */\n hostGroup?: SubResource;\n /** Specifies additional capabilities enabled or disabled on the Virtual Machines in the Virtual Machine Scale Set. For instance: whether the Virtual Machines have the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the policies applied when scaling in Virtual Machines in the Virtual Machine Scale Set. */\n scaleInPolicy?: ScaleInPolicy;\n /** Specifies the orchestration mode for the virtual machine scale set. */\n orchestrationMode?: OrchestrationMode;\n /** Specifies the Spot Restore properties for the virtual machine scale set. */\n spotRestorePolicy?: SpotRestorePolicy;\n /** Specifies the desired targets for mixing Spot and Regular priority VMs within the same VMSS Flex instance. */\n priorityMixPolicy?: PriorityMixPolicy;\n /**\n * Specifies the time at which the Virtual Machine Scale Set resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** Optional property which must either be set to True or omitted. */\n constrainedMaximumCapacity?: boolean;\n /** Policy for Resiliency */\n resiliencyPolicy?: ResiliencyPolicy;\n /** Specifies the align mode between Virtual Machine Scale Set compute and storage Fault Domain count. */\n zonalPlatformFaultDomainAlignMode?: ZonalPlatformFaultDomainAlignMode;\n /** Specifies the sku profile for the virtual machine scale set. */\n skuProfile?: SkuProfile;\n /** Specifies the high speed interconnect placement for the virtual machine scale set. */\n highSpeedInterconnectPlacement?: HighSpeedInterconnectPlacement;\n}\n\n/** Describes a Virtual Machine Extension. */\nexport interface VirtualMachineExtension extends TrackedResource {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n typePropertiesType?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** The virtual machine extension instance view. */\n instanceView?: VirtualMachineExtensionInstanceView;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReference;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: string[];\n}\n\n/** Describes a Virtual Machine. */\nexport interface VirtualMachine extends TrackedResource {\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /**\n * The virtual machine child extension resources.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resources?: VirtualMachineExtension[];\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentity;\n /** The availability zones. */\n zones?: string[];\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocation;\n /**\n * ManagedBy is set to Virtual Machine Scale Set(VMSS) flex ARM resourceID, if the VM is part of the VMSS. This property is used by platform for internal resource group delete optimization.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedBy?: string;\n /**\n * Etag is property returned in Create/Update/Get response of the VM, so that customer can supply it in the header to ensure optimistic updates.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly etag?: string;\n /** Placement section specifies the user-defined constraints for virtual machine hardware placement. This property cannot be changed once VM is provisioned. Minimum api-version: 2024-11-01. */\n placement?: Placement;\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfile;\n /** Specifies Redeploy, Reboot and ScheduledEventsAdditionalPublishingTargets Scheduled Event related configurations for the virtual machine. */\n scheduledEventsPolicy?: ScheduledEventsPolicy;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfile;\n /** Specifies additional capabilities enabled or disabled on the virtual machine. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the operating system settings used while creating the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\n osProfile?: OSProfile;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfile;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfile;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to availability set at creation time. The availability set to which the VM is being added should be under the same resource group as the availability set resource. An existing VM cannot be added to an availability set. This property cannot exist along with a non-null properties.virtualMachineScaleSet reference. */\n availabilitySet?: SubResource;\n /** Specifies information about the virtual machine scale set that the virtual machine should be assigned to. Virtual machines specified in the same virtual machine scale set are allocated to different nodes to maximize availability. Currently, a VM can only be added to virtual machine scale set at creation time. An existing VM cannot be added to a virtual machine scale set. This property cannot exist along with a non-null properties.availabilitySet reference. Minimum api‐version: 2019‐03‐01. */\n virtualMachineScaleSet?: SubResource;\n /** Specifies information about the proximity placement group that the virtual machine should be assigned to. Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResource;\n /** Specifies the priority for the virtual machine. Minimum api-version: 2019-03-01 */\n priority?: VirtualMachinePriorityTypes;\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: VirtualMachineEvictionPolicyTypes;\n /** Specifies the billing related details of a Azure Spot virtual machine. Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfile;\n /** Specifies information about the dedicated host that the virtual machine resides in. Minimum api-version: 2018-10-01. */\n host?: SubResource;\n /** Specifies information about the dedicated host group that the virtual machine resides in. **Note:** User cannot specify both host and hostGroup properties. Minimum api-version: 2020-06-01. */\n hostGroup?: SubResource;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineInstanceView;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /**\n * Specifies the VM unique ID which is a 128-bits identifier that is encoded and stored in all Azure IaaS VMs SMBIOS and can be read using platform BIOS commands.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). Minimum api-version: 2020-06-01. */\n extensionsTimeBudget?: string;\n /** Specifies the scale set logical fault domain into which the Virtual Machine will be created. By default, the Virtual Machine will by automatically assigned to a fault domain that best maintains balance across available fault domains. This is applicable only if the 'virtualMachineScaleSet' property of this Virtual Machine is set. The Virtual Machine Scale Set that is referenced, must have 'platformFaultDomainCount' greater than 1. This property cannot be updated once the Virtual Machine is created. Fault domain assignment can be viewed in the Virtual Machine Instance View. Minimum api‐version: 2020‐12‐01. */\n platformFaultDomain?: number;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfile;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01. */\n userData?: string;\n /** Specifies information about the capacity reservation that is used to allocate virtual machine. Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfile;\n /** Specifies the gallery applications that should be made available to the VM/VMSS. */\n applicationProfile?: ApplicationProfile;\n /**\n * Specifies the time at which the Virtual Machine resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Specifies information about the proximity placement group. */\nexport interface ProximityPlacementGroup extends TrackedResource {\n /** The availability zones. */\n zones?: string[];\n /** Specifies the type of the proximity placement group. Possible values are: **Standard** : Co-locate resources within an Azure region or Availability Zone. **Ultra** : For future use. */\n proximityPlacementGroupType?: ProximityPlacementGroupType;\n /**\n * A list of references to all virtual machines in the proximity placement group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachines?: SubResourceWithColocationStatus[];\n /**\n * A list of references to all virtual machine scale sets in the proximity placement group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachineScaleSets?: SubResourceWithColocationStatus[];\n /**\n * A list of references to all availability sets in the proximity placement group.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly availabilitySets?: SubResourceWithColocationStatus[];\n /** Describes colocation status of the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatus;\n /** Specifies the user intent of the proximity placement group. */\n intent?: ProximityPlacementGroupPropertiesIntent;\n}\n\n/** Create or update Restore Point collection parameters. */\nexport interface RestorePointCollection extends TrackedResource {\n /** The properties of the source resource that this restore point collection is created from. */\n source?: RestorePointCollectionSourceProperties;\n /**\n * The provisioning state of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The unique id of the restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePointCollectionId?: string;\n /**\n * A list containing all restore points created under this restore point collection.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly restorePoints?: RestorePoint[];\n /** This property determines whether instant access snapshot is enabled for restore points created under this restore point collection for Premium SSD v2 or Ultra disk. Instant access snapshot for Premium SSD v2 or Ultra disk is instantaneously available for restoring disk with fast restore performance. */\n instantAccess?: boolean;\n}\n\n/** Specifies information about the SSH public key. */\nexport interface SshPublicKeyResource extends TrackedResource {\n /** SSH public key used to authenticate to a virtual machine through ssh. If this property is not initially provided when the resource is created, the publicKey property will be populated when generateKeyPair is called. If the public key is provided upon resource creation, the provided public key needs to be at least 2048-bit and in ssh-rsa format. */\n publicKey?: string;\n}\n\n/** Specifies information about the capacity reservation. */\nexport interface CapacityReservation extends TrackedResource {\n /** SKU of the resource for which capacity needs be reserved. The SKU name and capacity is required to be set. For Block capacity reservations, sku.capacity can only accept values 1, 2, 4, 8, 16, 32, 64. Currently VM Skus with the capability called 'CapacityReservationSupported' set to true are supported. When 'CapacityReservationSupported' is true, the SKU capability also specifies the 'SupportedCapacityReservationTypes', which lists the types of capacity reservations (such as Targeted or Block) that the SKU supports. Refer to List Microsoft.Compute SKUs in a region (https://docs.microsoft.com/rest/api/compute/resourceskus/list) for supported values. */\n sku: Sku;\n /** The availability zones. */\n zones?: string[];\n /**\n * A unique id generated and assigned to the capacity reservation by the platform which does not change throughout the lifetime of the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly reservationId?: string;\n /**\n * Specifies the value of fault domain count that Capacity Reservation supports for requested VM size. **Note:** The fault domain count specified for a resource (like virtual machines scale set) must be less than or equal to this value if it deploys using capacity reservation. Minimum api-version: 2022-08-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly platformFaultDomainCount?: number;\n /**\n * A list of all virtual machine resource ids that are associated with the capacity reservation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachinesAssociated?: SubResourceReadOnly[];\n /**\n * The date time when the capacity reservation was last updated.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The Capacity reservation instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: CapacityReservationInstanceView;\n /**\n * Specifies the time at which the Capacity Reservation resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** Defines the schedule for Block-type capacity reservations. Specifies the schedule during which capacity reservation is active and VM or VMSS resource can be allocated using reservation. This property is required and only supported when the capacity reservation group type is 'Block'. The scheduleProfile, start, and end fields are immutable after creation. Minimum API version: 2025-04-01. Please refer to https://aka.ms/blockcapacityreservation for more details. */\n scheduleProfile?: ScheduleProfile;\n}\n\n/** Specifies information about the Dedicated host. */\nexport interface DedicatedHost extends TrackedResource {\n /** SKU of the dedicated host for Hardware Generation and VM family. Only name is required to be set. List Microsoft.Compute SKUs for a list of possible values. */\n sku: Sku;\n /** Fault domain of the dedicated host within a dedicated host group. */\n platformFaultDomain?: number;\n /** Specifies whether the dedicated host should be replaced automatically in case of a failure. The value is defaulted to 'true' when not provided. */\n autoReplaceOnFailure?: boolean;\n /**\n * A unique id generated and assigned to the dedicated host by the platform. Does not change throughout the lifetime of the host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly hostId?: string;\n /**\n * A list of references to all virtual machines in the Dedicated Host.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly virtualMachines?: SubResourceReadOnly[];\n /** Specifies the software license type that will be applied to the VMs deployed on the dedicated host. Possible values are: **None,** **Windows_Server_Hybrid,** **Windows_Server_Perpetual.** The default value is: **None.** */\n licenseType?: DedicatedHostLicenseTypes;\n /**\n * The date when the host was first provisioned.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningTime?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The dedicated host instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: DedicatedHostInstanceView;\n /**\n * Specifies the time at which the Dedicated Host resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** The status of the latest virtual machine scale set rolling upgrade. */\nexport interface RollingUpgradeStatusInfo extends TrackedResource {\n /**\n * The rolling upgrade policies applied for this upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly policy?: RollingUpgradePolicy;\n /**\n * Information about the current running state of the overall upgrade.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly runningStatus?: RollingUpgradeRunningStatus;\n /**\n * Information about the number of virtual machine instances in each upgrade state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly progress?: RollingUpgradeProgressInfo;\n /**\n * Error details for this upgrade, if there are any.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly error?: ApiError;\n}\n\n/** Describes a virtual machine scale set virtual machine. */\nexport interface VirtualMachineScaleSetVM extends TrackedResource {\n /**\n * The virtual machine instance ID.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceId?: string;\n /**\n * The virtual machine SKU.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sku?: Sku;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: Plan;\n /**\n * The virtual machine child extension resources.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly resources?: VirtualMachineExtension[];\n /**\n * The virtual machine zones.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly zones?: string[];\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentity;\n /**\n * Etag is property returned in Update/Get response of the VMSS VM, so that customer can supply it in the header to ensure optimistic updates.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly etag?: string;\n /**\n * Specifies whether the latest model has been applied to the virtual machine.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly latestModelApplied?: boolean;\n /**\n * Azure VM unique ID.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly vmId?: string;\n /**\n * The virtual machine instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineScaleSetVMInstanceView;\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfile;\n /** Specifies the resilient VM deletion status for the virtual machine. */\n resilientVMDeletionStatus?: ResilientVMDeletionStatus;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfile;\n /** Specifies additional capabilities enabled or disabled on the virtual machine in the scale set. For instance: whether the virtual machine has the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilities;\n /** Specifies the operating system settings for the virtual machine. */\n osProfile?: OSProfile;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfile;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfile;\n /** Specifies the network profile configuration of the virtual machine. */\n networkProfileConfiguration?: VirtualMachineScaleSetVMNetworkProfileConfiguration;\n /** Specifies the boot diagnostic settings state. Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfile;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates). Currently, a VM can only be added to availability set at creation time. An existing VM cannot be added to an availability set. */\n availabilitySet?: SubResource;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /**\n * Specifies whether the model applied to the virtual machine is the model of the virtual machine scale set or the customized model for the virtual machine.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly modelDefinitionApplied?: string;\n /** Specifies the protection policy of the virtual machine. */\n protectionPolicy?: VirtualMachineScaleSetVMProtectionPolicy;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. Minimum api-version: 2021-03-01 */\n userData?: string;\n /**\n * Specifies the time at which the Virtual Machine resource was created. Minimum api-version: 2021-11-01.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** Describes a Virtual Machine run command. */\nexport interface VirtualMachineRunCommand extends TrackedResource {\n /** The source of the run command script. */\n source?: VirtualMachineRunCommandScriptSource;\n /** The parameters used by the script. */\n parameters?: RunCommandInputParameter[];\n /** The parameters used by the script. */\n protectedParameters?: RunCommandInputParameter[];\n /** Optional. If set to true, provisioning will complete as soon as the script starts and will not wait for script to complete. */\n asyncExecution?: boolean;\n /** Specifies the user account on the VM when executing the run command. */\n runAsUser?: string;\n /** Specifies the user account password on the VM when executing the run command. */\n runAsPassword?: string;\n /** The timeout in seconds to execute the run command. */\n timeoutInSeconds?: number;\n /** Specifies the Azure storage blob where script output stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer outputBlobManagedIdentity parameter. */\n outputBlobUri?: string;\n /** Specifies the Azure storage blob where script error stream will be uploaded. Use a SAS URI with read, append, create, write access OR use managed identity to provide the VM access to the blob. Refer errorBlobManagedIdentity parameter. */\n errorBlobUri?: string;\n /** User-assigned managed identity that has access to outputBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n outputBlobManagedIdentity?: RunCommandManagedIdentity;\n /** User-assigned managed identity that has access to errorBlobUri storage blob. Use an empty object in case of system-assigned identity. Make sure managed identity has been given access to blob's container with 'Storage Blob Data Contributor' role assignment. In case of user-assigned identity, make sure you add it under VM's identity. For more info on managed identity and Run Command, refer https://aka.ms/ManagedIdentity and https://aka.ms/RunCommandManaged */\n errorBlobManagedIdentity?: RunCommandManagedIdentity;\n /**\n * The provisioning state, which only appears in the response. If treatFailureAsDeploymentFailure set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If treatFailureAsDeploymentFailure set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The virtual machine run command instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: VirtualMachineRunCommandInstanceView;\n /** Optional. If set to true, any failure in the script will fail the deployment and ProvisioningState will be marked as Failed. If set to false, ProvisioningState would only reflect whether the run command was run or not by the extensions platform, it would not indicate whether script failed in case of script failures. See instance view of run command in case of script failures to see executionMessage, output, error: https://aka.ms/runcommandmanaged#get-execution-status-and-results */\n treatFailureAsDeploymentFailure?: boolean;\n}\n\n/** disk access resource. */\nexport interface DiskAccess extends TrackedResource {\n /** The extended location where the disk access will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocation;\n /**\n * A readonly collection of private endpoint connections created on the disk. Currently only one endpoint connection is supported.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateEndpointConnections?: PrivateEndpointConnection[];\n /**\n * The disk access resource provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /**\n * The time when the disk access was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n}\n\n/** disk encryption set resource. */\nexport interface DiskEncryptionSet extends TrackedResource {\n /** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\n identity?: EncryptionSetIdentity;\n /** The type of key used to encrypt the data of the disk. */\n encryptionType?: DiskEncryptionSetType;\n /** The key vault key which is currently used by this disk encryption set. */\n activeKey?: KeyForDiskEncryptionSet;\n /**\n * A readonly collection of key vault keys previously used by this disk encryption set while a key rotation is in progress. It will be empty if there is no ongoing key rotation.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly previousKeys?: KeyForDiskEncryptionSet[];\n /**\n * The disk encryption set provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Set this flag to true to enable auto-updating of this disk encryption set to the latest key version. */\n rotationToLatestKeyVersionEnabled?: boolean;\n /**\n * The time when the active key of this disk encryption set was updated.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastKeyRotationTimestamp?: Date;\n /**\n * The error that was encountered during auto-key rotation. If an error is present, then auto-key rotation will not be attempted until the error on this disk encryption set is fixed.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly autoKeyRotationError?: ApiError;\n /** Multi-tenant application client id to access key vault in a different tenant. Setting the value to 'None' will clear the property. */\n federatedClientId?: string;\n}\n\n/** Disk resource. */\nexport interface Disk extends TrackedResource {\n /**\n * A relative URI containing the ID of the VM that has the disk attached.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedBy?: string;\n /**\n * List of relative URIs containing the IDs of the VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedByExtended?: string[];\n /** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\n sku?: DiskSku;\n /** The Logical zone list for Disk. */\n zones?: string[];\n /** The extended location where the disk will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocation;\n /**\n * The time when the disk was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** The Operating System type. */\n osType?: OperatingSystemTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** Purchase plan information for the the image from which the OS disk was created. E.g. - {name: 2019-Datacenter, publisher: MicrosoftWindowsServer, product: WindowsServer} */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilities;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData?: CreationData;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /**\n * The size of the disk in bytes. This field is read only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeBytes?: number;\n /**\n * Unique Guid identifying the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n /** Encryption settings collection used for Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /**\n * The disk provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** The number of IOPS allowed for this disk; only settable for UltraSSD disks. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadWrite?: number;\n /** The bandwidth allowed for this disk; only settable for UltraSSD disks. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadWrite?: number;\n /** The total number of IOPS that will be allowed across all VMs mounting the shared disk as ReadOnly. One operation can transfer between 4k and 256k bytes. */\n diskIopsReadOnly?: number;\n /** The total throughput (MBps) that will be allowed across all VMs mounting the shared disk as ReadOnly. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadOnly?: number;\n /**\n * The state of the disk.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskState?: DiskState;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** The maximum number of VMs that can attach to the disk at the same time. Value greater than one indicates a disk that can be mounted on multiple VMs at the same time. */\n maxShares?: number;\n /**\n * Details of the list of all VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly shareInfo?: ShareInfoElement[];\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /**\n * Latest time when bursting was last enabled on a disk.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly burstingEnabledTime?: Date;\n /** Performance tier of the disk (e.g, P4, S10) as described here: https://azure.microsoft.com/en-us/pricing/details/managed-disks/. Does not apply to Ultra disks. */\n tier?: string;\n /** Set to true to enable bursting beyond the provisioned performance target of the disk. Bursting is disabled by default. Does not apply to Ultra disks. */\n burstingEnabled?: boolean;\n /**\n * Properties of the disk for which update is pending.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly propertyUpdatesInProgress?: PropertyUpdatesInProgress;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfile;\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /** Setting this property to true improves reliability and performance of data disks that are frequently (more than 5 times a day) by detached from one virtual machine and attached to another. This property should not be set for disks that are not detached and attached frequently as it causes the disks to not align with the fault domain of the virtual machine. */\n optimizedForFrequentAttach?: boolean;\n /**\n * The UTC time when the ownership state of the disk was last changed i.e., the time the disk was last attached or detached from a VM or the time when the VM to which the disk was attached was deallocated or started.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly lastOwnershipUpdateTime?: Date;\n /** Determines how platform treats disk failures */\n availabilityPolicy?: AvailabilityPolicy;\n}\n\n/** Snapshot resource. */\nexport interface Snapshot extends TrackedResource {\n /**\n * Unused. Always Null.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly managedBy?: string;\n /** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\n sku?: SnapshotSku;\n /** The extended location where the snapshot will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocation;\n /**\n * The time when the snapshot was created.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /** The Operating System type. */\n osType?: OperatingSystemTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** Purchase plan information for the image from which the source disk for the snapshot was originally created. */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities for the image from which the source disk from the snapshot was originally created. */\n supportedCapabilities?: SupportedCapabilities;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData?: CreationData;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /**\n * The size of the disk in bytes. This field is read only.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskSizeBytes?: number;\n /**\n * The state of the snapshot.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly diskState?: DiskState;\n /**\n * Unique Guid identifying the resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly uniqueId?: string;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollection;\n /**\n * The disk provisioning state.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** Whether a snapshot is incremental. Incremental snapshots on the same disk occupy less space than full snapshots and can be diffed. */\n incremental?: boolean;\n /**\n * Incremental snapshots for a disk share an incremental snapshot family id. The Get Page Range Diff API can only be called on incremental snapshots with the same family id.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly incrementalSnapshotFamilyId?: string;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: Encryption;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfile;\n /** Indicates the OS on a snapshot supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\n copyCompletionError?: CopyCompletionError;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: DataAccessAuthMode;\n /**\n * The state of snapshot which determines the access availability of the snapshot.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly snapshotAccessState?: SnapshotAccessState;\n}\n\n/** Specifies information about the Shared Image Gallery that you want to create or update. */\nexport interface Gallery extends TrackedResource {\n /** The identity of the gallery, if configured. */\n identity?: GalleryIdentity;\n /** The description of this Shared Image Gallery resource. This property is updatable. */\n description?: string;\n /** Describes the gallery unique name. */\n identifier?: GalleryIdentifier;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** Profile for gallery sharing to subscription or tenant */\n sharingProfile?: SharingProfile;\n /** Contains information about the soft deletion policy of the gallery. */\n softDeletePolicy?: SoftDeletePolicy;\n /**\n * Sharing status of current gallery.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sharingStatus?: SharingStatus;\n}\n\n/** Specifies information about the gallery Application Definition that you want to create or update. */\nexport interface GalleryApplication extends TrackedResource {\n /** The description of this gallery Application Definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery Application Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Application Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This property allows you to specify the supported type of the OS that application is built for. Possible values are: **Windows,** **Linux.** */\n supportedOSType?: OperatingSystemTypes;\n /** A list of custom actions that can be performed with all of the Gallery Application Versions within this Gallery Application. */\n customActions?: GalleryApplicationCustomAction[];\n}\n\n/** Specifies information about the gallery Application Version that you want to create or update. */\nexport interface GalleryApplicationVersion extends TrackedResource {\n /** The publishing profile of a gallery image version. */\n publishingProfile?: GalleryApplicationVersionPublishingProfile;\n /** The safety profile of the Gallery Application Version. */\n safetyProfile?: GalleryApplicationVersionSafetyProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface GalleryImage extends TrackedResource {\n /** The description of this gallery image definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery image definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the gallery image definition identifier. */\n identifier?: GalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Optional. Must be set to true if the gallery image features are being updated. */\n allowUpdateImage?: boolean;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface GalleryImageVersion extends TrackedResource {\n /** The publishing profile of a gallery image Version. */\n publishingProfile?: GalleryImageVersionPublishingProfile;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /** This is the storage profile of a Gallery Image Version. */\n storageProfile?: GalleryImageVersionStorageProfile;\n /** This is the safety profile of the Gallery Image Version. */\n safetyProfile?: GalleryImageVersionSafetyProfile;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** The security profile of a gallery image version */\n securityProfile?: ImageVersionSecurityProfile;\n /** Indicates if this is a soft-delete resource restoration request. */\n restore?: boolean;\n /**\n * This is the validations profile of a Gallery Image Version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly validationsProfile?: ValidationsProfile;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile that you want to create or update. */\nexport interface GalleryInVMAccessControlProfile extends TrackedResource {\n /** Describes the properties of a gallery inVMAccessControlProfile. */\n properties?: GalleryInVMAccessControlProfileProperties;\n}\n\n/** Specifies information about the gallery inVMAccessControlProfile version that you want to create or update. */\nexport interface GalleryInVMAccessControlProfileVersion extends TrackedResource {\n /** The target regions where the Resource Profile version is going to be replicated to. This property is updatable. */\n targetLocations?: TargetRegion[];\n /** If set to true, Virtual Machines deployed from the latest version of the Resource Profile won't use this Profile version. */\n excludeFromLatest?: boolean;\n /**\n * The timestamp for when the Resource Profile Version is published.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly publishedDate?: Date;\n /**\n * The provisioning state, which only appears in the response.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: GalleryProvisioningState;\n /**\n * This is the replication status of the gallery image version.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationStatus?: ReplicationStatus;\n /** This property allows you to specify whether the access control rules are in Audit mode, in Enforce mode or Disabled. Possible values are: 'Audit', 'Enforce' or 'Disabled'. */\n mode?: AccessControlRulesMode;\n /** This property allows you to specify if the requests will be allowed to access the host endpoints. Possible values are: 'Allow', 'Deny'. */\n defaultAccess?: EndpointAccess;\n /** This is the Access Control Rules specification for an inVMAccessControlProfile version. */\n rules?: AccessControlRules;\n}\n\n/** Specifies information about the gallery Script Definition that you want to create or update. */\nexport interface GalleryScript extends TrackedResource {\n /** Describes the properties of a gallery Script Definition. */\n properties?: GalleryScriptProperties;\n}\n\n/** Concrete tracked resource types can be created by aliasing this type using a specific property type. */\nexport interface GalleryScriptVersion extends TrackedResource {\n /** Describes the properties of a gallery Script Version. */\n properties?: GalleryScriptVersionProperties;\n}\n\n/** The details information of soft-deleted resource. */\nexport interface GallerySoftDeletedResource extends TrackedResource {\n /** arm id of the soft-deleted resource */\n resourceArmId?: string;\n /** artifact type of the soft-deleted resource */\n softDeletedArtifactType?: SoftDeletedArtifactTypes;\n /** The timestamp for when the resource is soft-deleted. In dateTime offset format. */\n softDeletedTime?: string;\n}\n\n/** Restore Point details. */\nexport interface RestorePoint extends ProxyResource {\n /** List of disk resource ids that the customer wishes to exclude from the restore point. If no disks are specified, all disks will be included. */\n excludeDisks?: ApiEntityReference[];\n /** Gets the details of the VM captured at the time of the restore point creation. */\n sourceMetadata?: RestorePointSourceMetadata;\n /**\n * Gets the provisioning state of the restore point.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: string;\n /** ConsistencyMode of the RestorePoint. Can be specified in the input while creating a restore point. For now, only CrashConsistent is accepted as a valid input. Please refer to https://aka.ms/RestorePoints for more details. */\n consistencyMode?: ConsistencyModeTypes;\n /** Gets the creation time of the restore point. */\n timeCreated?: Date;\n /** Resource Id of the source restore point from which a copy needs to be created. */\n sourceRestorePoint?: ApiEntityReference;\n /**\n * The restore point instance view.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly instanceView?: RestorePointInstanceView;\n /** This property determines the time in minutes the snapshot is retained as instant access for restoring Premium SSD v2 or Ultra disk with fast restore performance in this restore point. */\n instantAccessDurationMinutes?: number;\n}\n\n/** The Private Endpoint Connection resource. */\nexport interface PrivateEndpointConnection extends ProxyResource {\n /**\n * The resource of private end point.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly privateEndpoint?: PrivateEndpoint;\n /** A collection of information about the state of the connection between DiskAccess and Virtual Network. */\n privateLinkServiceConnectionState?: PrivateLinkServiceConnectionState;\n /**\n * The provisioning state of the private endpoint connection resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly provisioningState?: PrivateEndpointConnectionProvisioningState;\n}\n\n/** Properties of disk restore point */\nexport interface DiskRestorePoint extends ProxyResource {\n /**\n * The timestamp of restorePoint creation\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly timeCreated?: Date;\n /**\n * arm id of source disk or source disk restore point.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceResourceId?: string;\n /**\n * The Operating System type.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly osType?: OperatingSystemTypes;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** Purchase plan information for the the image from which the OS disk was created. */\n purchasePlan?: DiskPurchasePlan;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilities;\n /**\n * id of the backing snapshot's MIS family\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly familyId?: string;\n /**\n * unique incarnation id of the source disk\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceUniqueId?: string;\n /**\n * Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly encryption?: Encryption;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: NetworkAccessPolicy;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: PublicNetworkAccess;\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Percentage complete for the background copy of disk restore point when source resource is from a different region. */\n completionPercent?: number;\n /**\n * Replication state of disk restore point when source resource is from a different region.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly replicationState?: string;\n /**\n * Location of source disk or source disk restore point when source resource is from a different region.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly sourceResourceLocation?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfile;\n /**\n * Logical sector size in bytes for disk restore points of UltraSSD_LRS and PremiumV2_LRS disks. Supported values are 512 and 4096. 4096 is the default.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly logicalSectorSize?: number;\n}\n\n/** Describes a Virtual Machine Scale Set VM Reimage Parameters. */\nexport interface VirtualMachineScaleSetReimageParameters extends VirtualMachineScaleSetVMReimageParameters {\n /** The virtual machine scale set instance ids. Omitting the virtual machine scale set instance ids will result in the operation being performed on all virtual machines in the virtual machine scale set. */\n instanceIds?: string[];\n}\n\n/** Specifies information about the Shared Gallery that you want to create or update. */\nexport interface SharedGallery extends PirSharedGalleryResource {\n /**\n * The artifact tags of a shared gallery resource.\n * NOTE: This property will not be serialized. It can only be populated by the server.\n */\n readonly artifactTags?: { [propertyName: string]: string };\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface SharedGalleryImage extends PirSharedGalleryResource {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. Possible values are: **Windows,** **Linux.** */\n osType?: OperatingSystemTypes;\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState?: OperatingSystemStateTypes;\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** This is the gallery image definition identifier. */\n identifier?: GalleryImageIdentifier;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfiguration;\n /** Describes the disallowed disk types. */\n disallowed?: Disallowed;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: HyperVGeneration;\n /** A list of gallery image features. */\n features?: GalleryImageFeature[];\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlan;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: Architecture;\n /** Privacy statement uri for the current community gallery image. */\n privacyStatementUri?: string;\n /** End-user license agreement for the current community gallery image. */\n eula?: string;\n /** The artifact tags of a shared gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface SharedGalleryImageVersion extends PirSharedGalleryResource {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: Date;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: Date;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfile;\n /** The artifact tags of a shared gallery resource. */\n artifactTags?: { [propertyName: string]: string };\n}\n\n/** Defines headers for AvailabilitySets_convertToVirtualMachineScaleSet operation. */\nexport interface AvailabilitySetsConvertToVirtualMachineScaleSetHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Images_createOrUpdate operation. */\nexport interface ImagesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Images_update operation. */\nexport interface ImagesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Images_delete operation. */\nexport interface ImagesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for LogAnalytics_exportRequestRateByInterval operation. */\nexport interface LogAnalyticsExportRequestRateByIntervalHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for LogAnalytics_exportThrottledRequests operation. */\nexport interface LogAnalyticsExportThrottledRequestsHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineRunCommands_createOrUpdate operation. */\nexport interface VirtualMachineRunCommandsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineRunCommands_update operation. */\nexport interface VirtualMachineRunCommandsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineRunCommands_delete operation. */\nexport interface VirtualMachineRunCommandsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_update operation. */\nexport interface VirtualMachineScaleSetsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_delete operation. */\nexport interface VirtualMachineScaleSetsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_approveRollingUpgrade operation. */\nexport interface VirtualMachineScaleSetsApproveRollingUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_deallocate operation. */\nexport interface VirtualMachineScaleSetsDeallocateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_deleteInstances operation. */\nexport interface VirtualMachineScaleSetsDeleteInstancesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_updateInstances operation. */\nexport interface VirtualMachineScaleSetsUpdateInstancesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_performMaintenance operation. */\nexport interface VirtualMachineScaleSetsPerformMaintenanceHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_powerOff operation. */\nexport interface VirtualMachineScaleSetsPowerOffHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_reapply operation. */\nexport interface VirtualMachineScaleSetsReapplyHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_redeploy operation. */\nexport interface VirtualMachineScaleSetsRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_reimage operation. */\nexport interface VirtualMachineScaleSetsReimageHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_reimageAll operation. */\nexport interface VirtualMachineScaleSetsReimageAllHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_restart operation. */\nexport interface VirtualMachineScaleSetsRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_scaleOut operation. */\nexport interface VirtualMachineScaleSetsScaleOutHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_setOrchestrationServiceState operation. */\nexport interface VirtualMachineScaleSetsSetOrchestrationServiceStateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSets_start operation. */\nexport interface VirtualMachineScaleSetsStartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_createOrUpdate operation. */\nexport interface VirtualMachinesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_update operation. */\nexport interface VirtualMachinesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_delete operation. */\nexport interface VirtualMachinesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_assessPatches operation. */\nexport interface VirtualMachinesAssessPatchesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_attachDetachDataDisks operation. */\nexport interface VirtualMachinesAttachDetachDataDisksHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_capture operation. */\nexport interface VirtualMachinesCaptureHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_convertToManagedDisks operation. */\nexport interface VirtualMachinesConvertToManagedDisksHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_deallocate operation. */\nexport interface VirtualMachinesDeallocateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_installPatches operation. */\nexport interface VirtualMachinesInstallPatchesHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_migrateToVMScaleSet operation. */\nexport interface VirtualMachinesMigrateToVMScaleSetHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_performMaintenance operation. */\nexport interface VirtualMachinesPerformMaintenanceHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_powerOff operation. */\nexport interface VirtualMachinesPowerOffHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_reapply operation. */\nexport interface VirtualMachinesReapplyHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_redeploy operation. */\nexport interface VirtualMachinesRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_reimage operation. */\nexport interface VirtualMachinesReimageHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_restart operation. */\nexport interface VirtualMachinesRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_runCommand operation. */\nexport interface VirtualMachinesRunCommandHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachines_start operation. */\nexport interface VirtualMachinesStartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for RestorePointCollections_delete operation. */\nexport interface RestorePointCollectionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for CapacityReservations_createOrUpdate operation. */\nexport interface CapacityReservationsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for CapacityReservations_update operation. */\nexport interface CapacityReservationsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for CapacityReservations_delete operation. */\nexport interface CapacityReservationsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_createOrUpdate operation. */\nexport interface DedicatedHostsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_update operation. */\nexport interface DedicatedHostsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_delete operation. */\nexport interface DedicatedHostsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_redeploy operation. */\nexport interface DedicatedHostsRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DedicatedHosts_restart operation. */\nexport interface DedicatedHostsRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for RestorePoints_create operation. */\nexport interface RestorePointsCreateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for RestorePoints_delete operation. */\nexport interface RestorePointsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetRollingUpgrades_startExtensionUpgrade operation. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartExtensionUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetRollingUpgrades_startOSUpgrade operation. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartOSUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetRollingUpgrades_cancel operation. */\nexport interface VirtualMachineScaleSetRollingUpgradesCancelHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetExtensions_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetExtensionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetExtensions_update operation. */\nexport interface VirtualMachineScaleSetExtensionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetExtensions_delete operation. */\nexport interface VirtualMachineScaleSetExtensionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_update operation. */\nexport interface VirtualMachineScaleSetVMsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_delete operation. */\nexport interface VirtualMachineScaleSetVMsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_approveRollingUpgrade operation. */\nexport interface VirtualMachineScaleSetVMsApproveRollingUpgradeHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_attachDetachDataDisks operation. */\nexport interface VirtualMachineScaleSetVMsAttachDetachDataDisksHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_deallocate operation. */\nexport interface VirtualMachineScaleSetVMsDeallocateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_performMaintenance operation. */\nexport interface VirtualMachineScaleSetVMsPerformMaintenanceHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_powerOff operation. */\nexport interface VirtualMachineScaleSetVMsPowerOffHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_redeploy operation. */\nexport interface VirtualMachineScaleSetVMsRedeployHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_reimage operation. */\nexport interface VirtualMachineScaleSetVMsReimageHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_reimageAll operation. */\nexport interface VirtualMachineScaleSetVMsReimageAllHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_restart operation. */\nexport interface VirtualMachineScaleSetVMsRestartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_runCommand operation. */\nexport interface VirtualMachineScaleSetVMsRunCommandHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMs_start operation. */\nexport interface VirtualMachineScaleSetVMsStartHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMExtensions_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetVMExtensionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMExtensions_update operation. */\nexport interface VirtualMachineScaleSetVMExtensionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMExtensions_delete operation. */\nexport interface VirtualMachineScaleSetVMExtensionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMRunCommands_createOrUpdate operation. */\nexport interface VirtualMachineScaleSetVMRunCommandsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMRunCommands_update operation. */\nexport interface VirtualMachineScaleSetVMRunCommandsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineScaleSetVMRunCommands_delete operation. */\nexport interface VirtualMachineScaleSetVMRunCommandsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineExtensions_createOrUpdate operation. */\nexport interface VirtualMachineExtensionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineExtensions_update operation. */\nexport interface VirtualMachineExtensionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for VirtualMachineExtensions_delete operation. */\nexport interface VirtualMachineExtensionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_createOrUpdate operation. */\nexport interface DiskAccessesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_update operation. */\nexport interface DiskAccessesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_delete operation. */\nexport interface DiskAccessesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_updateAPrivateEndpointConnection operation. */\nexport interface DiskAccessesUpdateAPrivateEndpointConnectionHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskAccesses_deleteAPrivateEndpointConnection operation. */\nexport interface DiskAccessesDeleteAPrivateEndpointConnectionHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskEncryptionSets_createOrUpdate operation. */\nexport interface DiskEncryptionSetsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskEncryptionSets_update operation. */\nexport interface DiskEncryptionSetsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskEncryptionSets_delete operation. */\nexport interface DiskEncryptionSetsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_createOrUpdate operation. */\nexport interface DisksCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_update operation. */\nexport interface DisksUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_delete operation. */\nexport interface DisksDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_grantAccess operation. */\nexport interface DisksGrantAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Disks_revokeAccess operation. */\nexport interface DisksRevokeAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_createOrUpdate operation. */\nexport interface SnapshotsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_update operation. */\nexport interface SnapshotsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_delete operation. */\nexport interface SnapshotsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_grantAccess operation. */\nexport interface SnapshotsGrantAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Snapshots_revokeAccess operation. */\nexport interface SnapshotsRevokeAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskRestorePoint_grantAccess operation. */\nexport interface DiskRestorePointGrantAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for DiskRestorePoint_revokeAccess operation. */\nexport interface DiskRestorePointRevokeAccessHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Galleries_createOrUpdate operation. */\nexport interface GalleriesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Galleries_update operation. */\nexport interface GalleriesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for Galleries_delete operation. */\nexport interface GalleriesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplications_createOrUpdate operation. */\nexport interface GalleryApplicationsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplications_update operation. */\nexport interface GalleryApplicationsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplications_delete operation. */\nexport interface GalleryApplicationsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplicationVersions_createOrUpdate operation. */\nexport interface GalleryApplicationVersionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplicationVersions_update operation. */\nexport interface GalleryApplicationVersionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryApplicationVersions_delete operation. */\nexport interface GalleryApplicationVersionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImages_createOrUpdate operation. */\nexport interface GalleryImagesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImages_update operation. */\nexport interface GalleryImagesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImages_delete operation. */\nexport interface GalleryImagesDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImageVersions_createOrUpdate operation. */\nexport interface GalleryImageVersionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImageVersions_update operation. */\nexport interface GalleryImageVersionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryImageVersions_delete operation. */\nexport interface GalleryImageVersionsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfiles_createOrUpdate operation. */\nexport interface GalleryInVMAccessControlProfilesCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfiles_update operation. */\nexport interface GalleryInVMAccessControlProfilesUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfiles_delete operation. */\nexport interface GalleryInVMAccessControlProfilesDeleteHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfileVersions_createOrUpdate operation. */\nexport interface GalleryInVMAccessControlProfileVersionsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfileVersions_update operation. */\nexport interface GalleryInVMAccessControlProfileVersionsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryInVMAccessControlProfileVersions_delete operation. */\nexport interface GalleryInVMAccessControlProfileVersionsDeleteHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n}\n\n/** Defines headers for GalleryScripts_createOrUpdate operation. */\nexport interface GalleryScriptsCreateOrUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryScripts_update operation. */\nexport interface GalleryScriptsUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryScripts_delete operation. */\nexport interface GalleryScriptsDeleteHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryScriptVersions_createOrUpdate operation. */\nexport interface GalleryScriptVersionsCreateOrUpdateHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryScriptVersions_update operation. */\nexport interface GalleryScriptVersionsUpdateHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GalleryScriptVersions_delete operation. */\nexport interface GalleryScriptVersionsDeleteHeaders {\n /** A link to the status monitor */\n azureAsyncOperation?: string;\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Defines headers for GallerySharingProfile_update operation. */\nexport interface GallerySharingProfileUpdateHeaders {\n /** The Location header contains the URL where the status of the long running operation can be checked. */\n location?: string;\n /** The Retry-After header can indicate how long the client should wait before polling the operation status. */\n retryAfter?: number;\n}\n\n/** Known values of {@link Origin} that the service accepts. */\nexport enum KnownOrigin {\n /** User */\n User = \"user\",\n /** System */\n System = \"system\",\n /** UserSystem */\n UserSystem = \"user,system\",\n}\n\n/**\n * Defines values for Origin. \\\n * {@link KnownOrigin} can be used interchangeably with Origin,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **user** \\\n * **system** \\\n * **user,system**\n */\nexport type Origin = string;\n\n/** Known values of {@link ActionType} that the service accepts. */\nexport enum KnownActionType {\n /** Internal */\n Internal = \"Internal\",\n}\n\n/**\n * Defines values for ActionType. \\\n * {@link KnownActionType} can be used interchangeably with ActionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Internal**\n */\nexport type ActionType = string;\n\n/** Known values of {@link CreatedByType} that the service accepts. */\nexport enum KnownCreatedByType {\n /** User */\n User = \"User\",\n /** Application */\n Application = \"Application\",\n /** ManagedIdentity */\n ManagedIdentity = \"ManagedIdentity\",\n /** Key */\n Key = \"Key\",\n}\n\n/**\n * Defines values for CreatedByType. \\\n * {@link KnownCreatedByType} can be used interchangeably with CreatedByType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **User** \\\n * **Application** \\\n * **ManagedIdentity** \\\n * **Key**\n */\nexport type CreatedByType = string;\n\n/** Known values of {@link ExpandTypesForGetCapacityReservationGroups} that the service accepts. */\nexport enum KnownExpandTypesForGetCapacityReservationGroups {\n /** VirtualMachineScaleSetVMsRef */\n VirtualMachineScaleSetVMsRef = \"virtualMachineScaleSetVMs/$ref\",\n /** VirtualMachinesRef */\n VirtualMachinesRef = \"virtualMachines/$ref\",\n}\n\n/**\n * Defines values for ExpandTypesForGetCapacityReservationGroups. \\\n * {@link KnownExpandTypesForGetCapacityReservationGroups} can be used interchangeably with ExpandTypesForGetCapacityReservationGroups,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **virtualMachineScaleSetVMs\\/$ref** \\\n * **virtualMachines\\/$ref**\n */\nexport type ExpandTypesForGetCapacityReservationGroups = string;\n\n/** Known values of {@link ResourceIdOptionsForGetCapacityReservationGroups} that the service accepts. */\nexport enum KnownResourceIdOptionsForGetCapacityReservationGroups {\n /** CreatedInSubscription */\n CreatedInSubscription = \"CreatedInSubscription\",\n /** SharedWithSubscription */\n SharedWithSubscription = \"SharedWithSubscription\",\n /** All */\n All = \"All\",\n}\n\n/**\n * Defines values for ResourceIdOptionsForGetCapacityReservationGroups. \\\n * {@link KnownResourceIdOptionsForGetCapacityReservationGroups} can be used interchangeably with ResourceIdOptionsForGetCapacityReservationGroups,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CreatedInSubscription** \\\n * **SharedWithSubscription** \\\n * **All**\n */\nexport type ResourceIdOptionsForGetCapacityReservationGroups = string;\n\n/** Known values of {@link ReservationType} that the service accepts. */\nexport enum KnownReservationType {\n /** To consume on demand allocated capacity reservation when a capacity reservation group is provided. */\n Targeted = \"Targeted\",\n /** To consume scheduled allocated block capacity reservation when a capacity reservation group is provided. */\n Block = \"Block\",\n}\n\n/**\n * Defines values for ReservationType. \\\n * {@link KnownReservationType} can be used interchangeably with ReservationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Targeted**: To consume on demand allocated capacity reservation when a capacity reservation group is provided. \\\n * **Block**: To consume scheduled allocated block capacity reservation when a capacity reservation group is provided.\n */\nexport type ReservationType = string;\n\n/** Known values of {@link StorageAccountTypes} that the service accepts. */\nexport enum KnownStorageAccountTypes {\n /** StandardLRS */\n StandardLRS = \"Standard_LRS\",\n /** PremiumLRS */\n PremiumLRS = \"Premium_LRS\",\n /** StandardSSDLRS */\n StandardSSDLRS = \"StandardSSD_LRS\",\n /** UltraSSDLRS */\n UltraSSDLRS = \"UltraSSD_LRS\",\n /** PremiumZRS */\n PremiumZRS = \"Premium_ZRS\",\n /** StandardSSDZRS */\n StandardSSDZRS = \"StandardSSD_ZRS\",\n /** PremiumV2LRS */\n PremiumV2LRS = \"PremiumV2_LRS\",\n}\n\n/**\n * Defines values for StorageAccountTypes. \\\n * {@link KnownStorageAccountTypes} can be used interchangeably with StorageAccountTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS** \\\n * **Premium_LRS** \\\n * **StandardSSD_LRS** \\\n * **UltraSSD_LRS** \\\n * **Premium_ZRS** \\\n * **StandardSSD_ZRS** \\\n * **PremiumV2_LRS**\n */\nexport type StorageAccountTypes = string;\n\n/** Known values of {@link HyperVGenerationTypes} that the service accepts. */\nexport enum KnownHyperVGenerationTypes {\n /** V1 */\n V1 = \"V1\",\n /** V2 */\n V2 = \"V2\",\n}\n\n/**\n * Defines values for HyperVGenerationTypes. \\\n * {@link KnownHyperVGenerationTypes} can be used interchangeably with HyperVGenerationTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **V1** \\\n * **V2**\n */\nexport type HyperVGenerationTypes = string;\n\n/** Known values of {@link ExtendedLocationTypes} that the service accepts. */\nexport enum KnownExtendedLocationTypes {\n /** EdgeZone */\n EdgeZone = \"EdgeZone\",\n}\n\n/**\n * Defines values for ExtendedLocationTypes. \\\n * {@link KnownExtendedLocationTypes} can be used interchangeably with ExtendedLocationTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EdgeZone**\n */\nexport type ExtendedLocationTypes = string;\n\n/** Known values of {@link VmDiskTypes} that the service accepts. */\nexport enum KnownVmDiskTypes {\n /** None */\n None = \"None\",\n /** Unmanaged */\n Unmanaged = \"Unmanaged\",\n}\n\n/**\n * Defines values for VmDiskTypes. \\\n * {@link KnownVmDiskTypes} can be used interchangeably with VmDiskTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Unmanaged**\n */\nexport type VmDiskTypes = string;\n\n/** Known values of {@link ArchitectureTypes} that the service accepts. */\nexport enum KnownArchitectureTypes {\n /** X64 */\n X64 = \"x64\",\n /** Arm64 */\n Arm64 = \"Arm64\",\n}\n\n/**\n * Defines values for ArchitectureTypes. \\\n * {@link KnownArchitectureTypes} can be used interchangeably with ArchitectureTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **x64** \\\n * **Arm64**\n */\nexport type ArchitectureTypes = string;\n\n/** Known values of {@link ImageState} that the service accepts. */\nexport enum KnownImageState {\n /** Active */\n Active = \"Active\",\n /** ScheduledForDeprecation */\n ScheduledForDeprecation = \"ScheduledForDeprecation\",\n /** Deprecated */\n Deprecated = \"Deprecated\",\n}\n\n/**\n * Defines values for ImageState. \\\n * {@link KnownImageState} can be used interchangeably with ImageState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Active** \\\n * **ScheduledForDeprecation** \\\n * **Deprecated**\n */\nexport type ImageState = string;\n\n/** Known values of {@link AlternativeType} that the service accepts. */\nexport enum KnownAlternativeType {\n /** None */\n None = \"None\",\n /** Offer */\n Offer = \"Offer\",\n /** Plan */\n Plan = \"Plan\",\n}\n\n/**\n * Defines values for AlternativeType. \\\n * {@link KnownAlternativeType} can be used interchangeably with AlternativeType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Offer** \\\n * **Plan**\n */\nexport type AlternativeType = string;\n\n/** Known values of {@link RepairAction} that the service accepts. */\nexport enum KnownRepairAction {\n /** Replace */\n Replace = \"Replace\",\n /** Restart */\n Restart = \"Restart\",\n /** Reimage */\n Reimage = \"Reimage\",\n}\n\n/**\n * Defines values for RepairAction. \\\n * {@link KnownRepairAction} can be used interchangeably with RepairAction,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Replace** \\\n * **Restart** \\\n * **Reimage**\n */\nexport type RepairAction = string;\n\n/** Known values of {@link WindowsVMGuestPatchMode} that the service accepts. */\nexport enum KnownWindowsVMGuestPatchMode {\n /** Manual */\n Manual = \"Manual\",\n /** AutomaticByOS */\n AutomaticByOS = \"AutomaticByOS\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for WindowsVMGuestPatchMode. \\\n * {@link KnownWindowsVMGuestPatchMode} can be used interchangeably with WindowsVMGuestPatchMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Manual** \\\n * **AutomaticByOS** \\\n * **AutomaticByPlatform**\n */\nexport type WindowsVMGuestPatchMode = string;\n\n/** Known values of {@link WindowsPatchAssessmentMode} that the service accepts. */\nexport enum KnownWindowsPatchAssessmentMode {\n /** ImageDefault */\n ImageDefault = \"ImageDefault\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for WindowsPatchAssessmentMode. \\\n * {@link KnownWindowsPatchAssessmentMode} can be used interchangeably with WindowsPatchAssessmentMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ImageDefault** \\\n * **AutomaticByPlatform**\n */\nexport type WindowsPatchAssessmentMode = string;\n\n/** Known values of {@link WindowsVMGuestPatchAutomaticByPlatformRebootSetting} that the service accepts. */\nexport enum KnownWindowsVMGuestPatchAutomaticByPlatformRebootSetting {\n /** Unknown */\n Unknown = \"Unknown\",\n /** IfRequired */\n IfRequired = \"IfRequired\",\n /** Never */\n Never = \"Never\",\n /** Always */\n Always = \"Always\",\n}\n\n/**\n * Defines values for WindowsVMGuestPatchAutomaticByPlatformRebootSetting. \\\n * {@link KnownWindowsVMGuestPatchAutomaticByPlatformRebootSetting} can be used interchangeably with WindowsVMGuestPatchAutomaticByPlatformRebootSetting,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **IfRequired** \\\n * **Never** \\\n * **Always**\n */\nexport type WindowsVMGuestPatchAutomaticByPlatformRebootSetting = string;\n\n/** Known values of {@link LinuxVMGuestPatchMode} that the service accepts. */\nexport enum KnownLinuxVMGuestPatchMode {\n /** ImageDefault */\n ImageDefault = \"ImageDefault\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for LinuxVMGuestPatchMode. \\\n * {@link KnownLinuxVMGuestPatchMode} can be used interchangeably with LinuxVMGuestPatchMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ImageDefault** \\\n * **AutomaticByPlatform**\n */\nexport type LinuxVMGuestPatchMode = string;\n\n/** Known values of {@link LinuxPatchAssessmentMode} that the service accepts. */\nexport enum KnownLinuxPatchAssessmentMode {\n /** ImageDefault */\n ImageDefault = \"ImageDefault\",\n /** AutomaticByPlatform */\n AutomaticByPlatform = \"AutomaticByPlatform\",\n}\n\n/**\n * Defines values for LinuxPatchAssessmentMode. \\\n * {@link KnownLinuxPatchAssessmentMode} can be used interchangeably with LinuxPatchAssessmentMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ImageDefault** \\\n * **AutomaticByPlatform**\n */\nexport type LinuxPatchAssessmentMode = string;\n\n/** Known values of {@link LinuxVMGuestPatchAutomaticByPlatformRebootSetting} that the service accepts. */\nexport enum KnownLinuxVMGuestPatchAutomaticByPlatformRebootSetting {\n /** Unknown */\n Unknown = \"Unknown\",\n /** IfRequired */\n IfRequired = \"IfRequired\",\n /** Never */\n Never = \"Never\",\n /** Always */\n Always = \"Always\",\n}\n\n/**\n * Defines values for LinuxVMGuestPatchAutomaticByPlatformRebootSetting. \\\n * {@link KnownLinuxVMGuestPatchAutomaticByPlatformRebootSetting} can be used interchangeably with LinuxVMGuestPatchAutomaticByPlatformRebootSetting,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **IfRequired** \\\n * **Never** \\\n * **Always**\n */\nexport type LinuxVMGuestPatchAutomaticByPlatformRebootSetting = string;\n\n/** Known values of {@link DiskCreateOptionTypes} that the service accepts. */\nexport enum KnownDiskCreateOptionTypes {\n /** FromImage */\n FromImage = \"FromImage\",\n /** Empty */\n Empty = \"Empty\",\n /** Attach */\n Attach = \"Attach\",\n /** Copy */\n Copy = \"Copy\",\n /** Restore */\n Restore = \"Restore\",\n}\n\n/**\n * Defines values for DiskCreateOptionTypes. \\\n * {@link KnownDiskCreateOptionTypes} can be used interchangeably with DiskCreateOptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **FromImage** \\\n * **Empty** \\\n * **Attach** \\\n * **Copy** \\\n * **Restore**\n */\nexport type DiskCreateOptionTypes = string;\n\n/** Known values of {@link DiffDiskOptions} that the service accepts. */\nexport enum KnownDiffDiskOptions {\n /** Local */\n Local = \"Local\",\n}\n\n/**\n * Defines values for DiffDiskOptions. \\\n * {@link KnownDiffDiskOptions} can be used interchangeably with DiffDiskOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Local**\n */\nexport type DiffDiskOptions = string;\n\n/** Known values of {@link DiffDiskPlacement} that the service accepts. */\nexport enum KnownDiffDiskPlacement {\n /** CacheDisk */\n CacheDisk = \"CacheDisk\",\n /** ResourceDisk */\n ResourceDisk = \"ResourceDisk\",\n /** NvmeDisk */\n NvmeDisk = \"NvmeDisk\",\n}\n\n/**\n * Defines values for DiffDiskPlacement. \\\n * {@link KnownDiffDiskPlacement} can be used interchangeably with DiffDiskPlacement,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CacheDisk** \\\n * **ResourceDisk** \\\n * **NvmeDisk**\n */\nexport type DiffDiskPlacement = string;\n\n/** Known values of {@link SecurityEncryptionTypes} that the service accepts. */\nexport enum KnownSecurityEncryptionTypes {\n /** VMGuestStateOnly */\n VMGuestStateOnly = \"VMGuestStateOnly\",\n /** DiskWithVMGuestState */\n DiskWithVMGuestState = \"DiskWithVMGuestState\",\n /** NonPersistedTPM */\n NonPersistedTPM = \"NonPersistedTPM\",\n}\n\n/**\n * Defines values for SecurityEncryptionTypes. \\\n * {@link KnownSecurityEncryptionTypes} can be used interchangeably with SecurityEncryptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **VMGuestStateOnly** \\\n * **DiskWithVMGuestState** \\\n * **NonPersistedTPM**\n */\nexport type SecurityEncryptionTypes = string;\n\n/** Known values of {@link DiskDeleteOptionTypes} that the service accepts. */\nexport enum KnownDiskDeleteOptionTypes {\n /** Delete */\n Delete = \"Delete\",\n /** Detach */\n Detach = \"Detach\",\n}\n\n/**\n * Defines values for DiskDeleteOptionTypes. \\\n * {@link KnownDiskDeleteOptionTypes} can be used interchangeably with DiskDeleteOptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Delete** \\\n * **Detach**\n */\nexport type DiskDeleteOptionTypes = string;\n\n/** Known values of {@link DiskControllerTypes} that the service accepts. */\nexport enum KnownDiskControllerTypes {\n /** Scsi */\n Scsi = \"SCSI\",\n /** NVMe */\n NVMe = \"NVMe\",\n}\n\n/**\n * Defines values for DiskControllerTypes. \\\n * {@link KnownDiskControllerTypes} can be used interchangeably with DiskControllerTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **SCSI** \\\n * **NVMe**\n */\nexport type DiskControllerTypes = string;\n\n/** Known values of {@link DomainNameLabelScopeTypes} that the service accepts. */\nexport enum KnownDomainNameLabelScopeTypes {\n /** TenantReuse */\n TenantReuse = \"TenantReuse\",\n /** SubscriptionReuse */\n SubscriptionReuse = \"SubscriptionReuse\",\n /** ResourceGroupReuse */\n ResourceGroupReuse = \"ResourceGroupReuse\",\n /** NoReuse */\n NoReuse = \"NoReuse\",\n}\n\n/**\n * Defines values for DomainNameLabelScopeTypes. \\\n * {@link KnownDomainNameLabelScopeTypes} can be used interchangeably with DomainNameLabelScopeTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TenantReuse** \\\n * **SubscriptionReuse** \\\n * **ResourceGroupReuse** \\\n * **NoReuse**\n */\nexport type DomainNameLabelScopeTypes = string;\n\n/** Known values of {@link IPVersion} that the service accepts. */\nexport enum KnownIPVersion {\n /** IPv4 */\n IPv4 = \"IPv4\",\n /** IPv6 */\n IPv6 = \"IPv6\",\n}\n\n/**\n * Defines values for IPVersion. \\\n * {@link KnownIPVersion} can be used interchangeably with IPVersion,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **IPv4** \\\n * **IPv6**\n */\nexport type IPVersion = string;\n\n/** Known values of {@link DeleteOptions} that the service accepts. */\nexport enum KnownDeleteOptions {\n /** Delete */\n Delete = \"Delete\",\n /** Detach */\n Detach = \"Detach\",\n}\n\n/**\n * Defines values for DeleteOptions. \\\n * {@link KnownDeleteOptions} can be used interchangeably with DeleteOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Delete** \\\n * **Detach**\n */\nexport type DeleteOptions = string;\n\n/** Known values of {@link PublicIPAddressSkuName} that the service accepts. */\nexport enum KnownPublicIPAddressSkuName {\n /** Basic */\n Basic = \"Basic\",\n /** Standard */\n Standard = \"Standard\",\n}\n\n/**\n * Defines values for PublicIPAddressSkuName. \\\n * {@link KnownPublicIPAddressSkuName} can be used interchangeably with PublicIPAddressSkuName,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Basic** \\\n * **Standard**\n */\nexport type PublicIPAddressSkuName = string;\n\n/** Known values of {@link PublicIPAddressSkuTier} that the service accepts. */\nexport enum KnownPublicIPAddressSkuTier {\n /** Regional */\n Regional = \"Regional\",\n /** Global */\n Global = \"Global\",\n}\n\n/**\n * Defines values for PublicIPAddressSkuTier. \\\n * {@link KnownPublicIPAddressSkuTier} can be used interchangeably with PublicIPAddressSkuTier,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Regional** \\\n * **Global**\n */\nexport type PublicIPAddressSkuTier = string;\n\n/** Known values of {@link NetworkInterfaceAuxiliaryMode} that the service accepts. */\nexport enum KnownNetworkInterfaceAuxiliaryMode {\n /** None */\n None = \"None\",\n /** AcceleratedConnections */\n AcceleratedConnections = \"AcceleratedConnections\",\n /** Floating */\n Floating = \"Floating\",\n}\n\n/**\n * Defines values for NetworkInterfaceAuxiliaryMode. \\\n * {@link KnownNetworkInterfaceAuxiliaryMode} can be used interchangeably with NetworkInterfaceAuxiliaryMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **AcceleratedConnections** \\\n * **Floating**\n */\nexport type NetworkInterfaceAuxiliaryMode = string;\n\n/** Known values of {@link NetworkInterfaceAuxiliarySku} that the service accepts. */\nexport enum KnownNetworkInterfaceAuxiliarySku {\n /** None */\n None = \"None\",\n /** A1 */\n A1 = \"A1\",\n /** A2 */\n A2 = \"A2\",\n /** A4 */\n A4 = \"A4\",\n /** A8 */\n A8 = \"A8\",\n}\n\n/**\n * Defines values for NetworkInterfaceAuxiliarySku. \\\n * {@link KnownNetworkInterfaceAuxiliarySku} can be used interchangeably with NetworkInterfaceAuxiliarySku,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **A1** \\\n * **A2** \\\n * **A4** \\\n * **A8**\n */\nexport type NetworkInterfaceAuxiliarySku = string;\n\n/** Known values of {@link NetworkApiVersion} that the service accepts. */\nexport enum KnownNetworkApiVersion {\n /** TwoThousandTwenty1101 */\n TwoThousandTwenty1101 = \"2020-11-01\",\n /** TwoThousandTwentyTwo1101 */\n TwoThousandTwentyTwo1101 = \"2022-11-01\",\n}\n\n/**\n * Defines values for NetworkApiVersion. \\\n * {@link KnownNetworkApiVersion} can be used interchangeably with NetworkApiVersion,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **2020-11-01** \\\n * **2022-11-01**\n */\nexport type NetworkApiVersion = string;\n\n/** Known values of {@link SecurityTypes} that the service accepts. */\nexport enum KnownSecurityTypes {\n /** TrustedLaunch */\n TrustedLaunch = \"TrustedLaunch\",\n /** ConfidentialVM */\n ConfidentialVM = \"ConfidentialVM\",\n}\n\n/**\n * Defines values for SecurityTypes. \\\n * {@link KnownSecurityTypes} can be used interchangeably with SecurityTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TrustedLaunch** \\\n * **ConfidentialVM**\n */\nexport type SecurityTypes = string;\n\n/** Known values of {@link Mode} that the service accepts. */\nexport enum KnownMode {\n /** Audit */\n Audit = \"Audit\",\n /** Enforce */\n Enforce = \"Enforce\",\n}\n\n/**\n * Defines values for Mode. \\\n * {@link KnownMode} can be used interchangeably with Mode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Audit** \\\n * **Enforce**\n */\nexport type Mode = string;\n\n/** Known values of {@link Modes} that the service accepts. */\nexport enum KnownModes {\n /** Audit */\n Audit = \"Audit\",\n /** Enforce */\n Enforce = \"Enforce\",\n /** Disabled */\n Disabled = \"Disabled\",\n}\n\n/**\n * Defines values for Modes. \\\n * {@link KnownModes} can be used interchangeably with Modes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Audit** \\\n * **Enforce** \\\n * **Disabled**\n */\nexport type Modes = string;\n\n/** Known values of {@link VirtualMachinePriorityTypes} that the service accepts. */\nexport enum KnownVirtualMachinePriorityTypes {\n /** Regular */\n Regular = \"Regular\",\n /** Low */\n Low = \"Low\",\n /** Spot */\n Spot = \"Spot\",\n}\n\n/**\n * Defines values for VirtualMachinePriorityTypes. \\\n * {@link KnownVirtualMachinePriorityTypes} can be used interchangeably with VirtualMachinePriorityTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Regular** \\\n * **Low** \\\n * **Spot**\n */\nexport type VirtualMachinePriorityTypes = string;\n\n/** Known values of {@link VirtualMachineEvictionPolicyTypes} that the service accepts. */\nexport enum KnownVirtualMachineEvictionPolicyTypes {\n /** Deallocate */\n Deallocate = \"Deallocate\",\n /** Delete */\n Delete = \"Delete\",\n}\n\n/**\n * Defines values for VirtualMachineEvictionPolicyTypes. \\\n * {@link KnownVirtualMachineEvictionPolicyTypes} can be used interchangeably with VirtualMachineEvictionPolicyTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Deallocate** \\\n * **Delete**\n */\nexport type VirtualMachineEvictionPolicyTypes = string;\n\n/** Known values of {@link VirtualMachineScaleSetScaleInRules} that the service accepts. */\nexport enum KnownVirtualMachineScaleSetScaleInRules {\n /** Default */\n Default = \"Default\",\n /** OldestVM */\n OldestVM = \"OldestVM\",\n /** NewestVM */\n NewestVM = \"NewestVM\",\n}\n\n/**\n * Defines values for VirtualMachineScaleSetScaleInRules. \\\n * {@link KnownVirtualMachineScaleSetScaleInRules} can be used interchangeably with VirtualMachineScaleSetScaleInRules,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Default** \\\n * **OldestVM** \\\n * **NewestVM**\n */\nexport type VirtualMachineScaleSetScaleInRules = string;\n\n/** Known values of {@link OrchestrationMode} that the service accepts. */\nexport enum KnownOrchestrationMode {\n /** Uniform */\n Uniform = \"Uniform\",\n /** Flexible */\n Flexible = \"Flexible\",\n}\n\n/**\n * Defines values for OrchestrationMode. \\\n * {@link KnownOrchestrationMode} can be used interchangeably with OrchestrationMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Uniform** \\\n * **Flexible**\n */\nexport type OrchestrationMode = string;\n\n/** Known values of {@link RebalanceStrategy} that the service accepts. */\nexport enum KnownRebalanceStrategy {\n /** Recreate */\n Recreate = \"Recreate\",\n}\n\n/**\n * Defines values for RebalanceStrategy. \\\n * {@link KnownRebalanceStrategy} can be used interchangeably with RebalanceStrategy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Recreate**\n */\nexport type RebalanceStrategy = string;\n\n/** Known values of {@link RebalanceBehavior} that the service accepts. */\nexport enum KnownRebalanceBehavior {\n /** CreateBeforeDelete */\n CreateBeforeDelete = \"CreateBeforeDelete\",\n}\n\n/**\n * Defines values for RebalanceBehavior. \\\n * {@link KnownRebalanceBehavior} can be used interchangeably with RebalanceBehavior,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CreateBeforeDelete**\n */\nexport type RebalanceBehavior = string;\n\n/** Known values of {@link ZonalPlatformFaultDomainAlignMode} that the service accepts. */\nexport enum KnownZonalPlatformFaultDomainAlignMode {\n /** Aligned */\n Aligned = \"Aligned\",\n /** Unaligned */\n Unaligned = \"Unaligned\",\n}\n\n/**\n * Defines values for ZonalPlatformFaultDomainAlignMode. \\\n * {@link KnownZonalPlatformFaultDomainAlignMode} can be used interchangeably with ZonalPlatformFaultDomainAlignMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Aligned** \\\n * **Unaligned**\n */\nexport type ZonalPlatformFaultDomainAlignMode = string;\n\n/** Known values of {@link AllocationStrategy} that the service accepts. */\nexport enum KnownAllocationStrategy {\n /** LowestPrice */\n LowestPrice = \"LowestPrice\",\n /** CapacityOptimized */\n CapacityOptimized = \"CapacityOptimized\",\n /** Prioritized */\n Prioritized = \"Prioritized\",\n}\n\n/**\n * Defines values for AllocationStrategy. \\\n * {@link KnownAllocationStrategy} can be used interchangeably with AllocationStrategy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **LowestPrice** \\\n * **CapacityOptimized** \\\n * **Prioritized**\n */\nexport type AllocationStrategy = string;\n\n/** Known values of {@link HighSpeedInterconnectPlacement} that the service accepts. */\nexport enum KnownHighSpeedInterconnectPlacement {\n /** No high speed interconnect placement */\n None = \"None\",\n /** Trunk high speed interconnect placement */\n Trunk = \"Trunk\",\n}\n\n/**\n * Defines values for HighSpeedInterconnectPlacement. \\\n * {@link KnownHighSpeedInterconnectPlacement} can be used interchangeably with HighSpeedInterconnectPlacement,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None**: No high speed interconnect placement \\\n * **Trunk**: Trunk high speed interconnect placement\n */\nexport type HighSpeedInterconnectPlacement = string;\n\n/** Known values of {@link ZonePlacementPolicyType} that the service accepts. */\nexport enum KnownZonePlacementPolicyType {\n /** Any */\n Any = \"Any\",\n /** Automatic zone placement in a Virtual Machine Scale Set. */\n Auto = \"Auto\",\n}\n\n/**\n * Defines values for ZonePlacementPolicyType. \\\n * {@link KnownZonePlacementPolicyType} can be used interchangeably with ZonePlacementPolicyType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Any** \\\n * **Auto**: Automatic zone placement in a Virtual Machine Scale Set.\n */\nexport type ZonePlacementPolicyType = string;\n\n/** Known values of {@link VirtualMachineSizeTypes} that the service accepts. */\nexport enum KnownVirtualMachineSizeTypes {\n /** BasicA0 */\n BasicA0 = \"Basic_A0\",\n /** BasicA1 */\n BasicA1 = \"Basic_A1\",\n /** BasicA2 */\n BasicA2 = \"Basic_A2\",\n /** BasicA3 */\n BasicA3 = \"Basic_A3\",\n /** BasicA4 */\n BasicA4 = \"Basic_A4\",\n /** StandardA0 */\n StandardA0 = \"Standard_A0\",\n /** StandardA1 */\n StandardA1 = \"Standard_A1\",\n /** StandardA2 */\n StandardA2 = \"Standard_A2\",\n /** StandardA3 */\n StandardA3 = \"Standard_A3\",\n /** StandardA4 */\n StandardA4 = \"Standard_A4\",\n /** StandardA5 */\n StandardA5 = \"Standard_A5\",\n /** StandardA6 */\n StandardA6 = \"Standard_A6\",\n /** StandardA7 */\n StandardA7 = \"Standard_A7\",\n /** StandardA8 */\n StandardA8 = \"Standard_A8\",\n /** StandardA9 */\n StandardA9 = \"Standard_A9\",\n /** StandardA10 */\n StandardA10 = \"Standard_A10\",\n /** StandardA11 */\n StandardA11 = \"Standard_A11\",\n /** StandardA1V2 */\n StandardA1V2 = \"Standard_A1_v2\",\n /** StandardA2V2 */\n StandardA2V2 = \"Standard_A2_v2\",\n /** StandardA4V2 */\n StandardA4V2 = \"Standard_A4_v2\",\n /** StandardA8V2 */\n StandardA8V2 = \"Standard_A8_v2\",\n /** StandardA2MV2 */\n StandardA2MV2 = \"Standard_A2m_v2\",\n /** StandardA4MV2 */\n StandardA4MV2 = \"Standard_A4m_v2\",\n /** StandardA8MV2 */\n StandardA8MV2 = \"Standard_A8m_v2\",\n /** StandardB1S */\n StandardB1S = \"Standard_B1s\",\n /** StandardB1Ms */\n StandardB1Ms = \"Standard_B1ms\",\n /** StandardB2S */\n StandardB2S = \"Standard_B2s\",\n /** StandardB2Ms */\n StandardB2Ms = \"Standard_B2ms\",\n /** StandardB4Ms */\n StandardB4Ms = \"Standard_B4ms\",\n /** StandardB8Ms */\n StandardB8Ms = \"Standard_B8ms\",\n /** StandardD1 */\n StandardD1 = \"Standard_D1\",\n /** StandardD2 */\n StandardD2 = \"Standard_D2\",\n /** StandardD3 */\n StandardD3 = \"Standard_D3\",\n /** StandardD4 */\n StandardD4 = \"Standard_D4\",\n /** StandardD11 */\n StandardD11 = \"Standard_D11\",\n /** StandardD12 */\n StandardD12 = \"Standard_D12\",\n /** StandardD13 */\n StandardD13 = \"Standard_D13\",\n /** StandardD14 */\n StandardD14 = \"Standard_D14\",\n /** StandardD1V2 */\n StandardD1V2 = \"Standard_D1_v2\",\n /** StandardD2V2 */\n StandardD2V2 = \"Standard_D2_v2\",\n /** StandardD3V2 */\n StandardD3V2 = \"Standard_D3_v2\",\n /** StandardD4V2 */\n StandardD4V2 = \"Standard_D4_v2\",\n /** StandardD5V2 */\n StandardD5V2 = \"Standard_D5_v2\",\n /** StandardD2V3 */\n StandardD2V3 = \"Standard_D2_v3\",\n /** StandardD4V3 */\n StandardD4V3 = \"Standard_D4_v3\",\n /** StandardD8V3 */\n StandardD8V3 = \"Standard_D8_v3\",\n /** StandardD16V3 */\n StandardD16V3 = \"Standard_D16_v3\",\n /** StandardD32V3 */\n StandardD32V3 = \"Standard_D32_v3\",\n /** StandardD64V3 */\n StandardD64V3 = \"Standard_D64_v3\",\n /** StandardD2SV3 */\n StandardD2SV3 = \"Standard_D2s_v3\",\n /** StandardD4SV3 */\n StandardD4SV3 = \"Standard_D4s_v3\",\n /** StandardD8SV3 */\n StandardD8SV3 = \"Standard_D8s_v3\",\n /** StandardD16SV3 */\n StandardD16SV3 = \"Standard_D16s_v3\",\n /** StandardD32SV3 */\n StandardD32SV3 = \"Standard_D32s_v3\",\n /** StandardD64SV3 */\n StandardD64SV3 = \"Standard_D64s_v3\",\n /** StandardD11V2 */\n StandardD11V2 = \"Standard_D11_v2\",\n /** StandardD12V2 */\n StandardD12V2 = \"Standard_D12_v2\",\n /** StandardD13V2 */\n StandardD13V2 = \"Standard_D13_v2\",\n /** StandardD14V2 */\n StandardD14V2 = \"Standard_D14_v2\",\n /** StandardD15V2 */\n StandardD15V2 = \"Standard_D15_v2\",\n /** StandardDS1 */\n StandardDS1 = \"Standard_DS1\",\n /** StandardDS2 */\n StandardDS2 = \"Standard_DS2\",\n /** StandardDS3 */\n StandardDS3 = \"Standard_DS3\",\n /** StandardDS4 */\n StandardDS4 = \"Standard_DS4\",\n /** StandardDS11 */\n StandardDS11 = \"Standard_DS11\",\n /** StandardDS12 */\n StandardDS12 = \"Standard_DS12\",\n /** StandardDS13 */\n StandardDS13 = \"Standard_DS13\",\n /** StandardDS14 */\n StandardDS14 = \"Standard_DS14\",\n /** StandardDS1V2 */\n StandardDS1V2 = \"Standard_DS1_v2\",\n /** StandardDS2V2 */\n StandardDS2V2 = \"Standard_DS2_v2\",\n /** StandardDS3V2 */\n StandardDS3V2 = \"Standard_DS3_v2\",\n /** StandardDS4V2 */\n StandardDS4V2 = \"Standard_DS4_v2\",\n /** StandardDS5V2 */\n StandardDS5V2 = \"Standard_DS5_v2\",\n /** StandardDS11V2 */\n StandardDS11V2 = \"Standard_DS11_v2\",\n /** StandardDS12V2 */\n StandardDS12V2 = \"Standard_DS12_v2\",\n /** StandardDS13V2 */\n StandardDS13V2 = \"Standard_DS13_v2\",\n /** StandardDS14V2 */\n StandardDS14V2 = \"Standard_DS14_v2\",\n /** StandardDS15V2 */\n StandardDS15V2 = \"Standard_DS15_v2\",\n /** StandardDS134V2 */\n StandardDS134V2 = \"Standard_DS13-4_v2\",\n /** StandardDS132V2 */\n StandardDS132V2 = \"Standard_DS13-2_v2\",\n /** StandardDS148V2 */\n StandardDS148V2 = \"Standard_DS14-8_v2\",\n /** StandardDS144V2 */\n StandardDS144V2 = \"Standard_DS14-4_v2\",\n /** StandardE2V3 */\n StandardE2V3 = \"Standard_E2_v3\",\n /** StandardE4V3 */\n StandardE4V3 = \"Standard_E4_v3\",\n /** StandardE8V3 */\n StandardE8V3 = \"Standard_E8_v3\",\n /** StandardE16V3 */\n StandardE16V3 = \"Standard_E16_v3\",\n /** StandardE32V3 */\n StandardE32V3 = \"Standard_E32_v3\",\n /** StandardE64V3 */\n StandardE64V3 = \"Standard_E64_v3\",\n /** StandardE2SV3 */\n StandardE2SV3 = \"Standard_E2s_v3\",\n /** StandardE4SV3 */\n StandardE4SV3 = \"Standard_E4s_v3\",\n /** StandardE8SV3 */\n StandardE8SV3 = \"Standard_E8s_v3\",\n /** StandardE16SV3 */\n StandardE16SV3 = \"Standard_E16s_v3\",\n /** StandardE32SV3 */\n StandardE32SV3 = \"Standard_E32s_v3\",\n /** StandardE64SV3 */\n StandardE64SV3 = \"Standard_E64s_v3\",\n /** StandardE3216V3 */\n StandardE3216V3 = \"Standard_E32-16_v3\",\n /** StandardE328SV3 */\n StandardE328SV3 = \"Standard_E32-8s_v3\",\n /** StandardE6432SV3 */\n StandardE6432SV3 = \"Standard_E64-32s_v3\",\n /** StandardE6416SV3 */\n StandardE6416SV3 = \"Standard_E64-16s_v3\",\n /** StandardF1 */\n StandardF1 = \"Standard_F1\",\n /** StandardF2 */\n StandardF2 = \"Standard_F2\",\n /** StandardF4 */\n StandardF4 = \"Standard_F4\",\n /** StandardF8 */\n StandardF8 = \"Standard_F8\",\n /** StandardF16 */\n StandardF16 = \"Standard_F16\",\n /** StandardF1S */\n StandardF1S = \"Standard_F1s\",\n /** StandardF2S */\n StandardF2S = \"Standard_F2s\",\n /** StandardF4S */\n StandardF4S = \"Standard_F4s\",\n /** StandardF8S */\n StandardF8S = \"Standard_F8s\",\n /** StandardF16S */\n StandardF16S = \"Standard_F16s\",\n /** StandardF2SV2 */\n StandardF2SV2 = \"Standard_F2s_v2\",\n /** StandardF4SV2 */\n StandardF4SV2 = \"Standard_F4s_v2\",\n /** StandardF8SV2 */\n StandardF8SV2 = \"Standard_F8s_v2\",\n /** StandardF16SV2 */\n StandardF16SV2 = \"Standard_F16s_v2\",\n /** StandardF32SV2 */\n StandardF32SV2 = \"Standard_F32s_v2\",\n /** StandardF64SV2 */\n StandardF64SV2 = \"Standard_F64s_v2\",\n /** StandardF72SV2 */\n StandardF72SV2 = \"Standard_F72s_v2\",\n /** StandardG1 */\n StandardG1 = \"Standard_G1\",\n /** StandardG2 */\n StandardG2 = \"Standard_G2\",\n /** StandardG3 */\n StandardG3 = \"Standard_G3\",\n /** StandardG4 */\n StandardG4 = \"Standard_G4\",\n /** StandardG5 */\n StandardG5 = \"Standard_G5\",\n /** StandardGS1 */\n StandardGS1 = \"Standard_GS1\",\n /** StandardGS2 */\n StandardGS2 = \"Standard_GS2\",\n /** StandardGS3 */\n StandardGS3 = \"Standard_GS3\",\n /** StandardGS4 */\n StandardGS4 = \"Standard_GS4\",\n /** StandardGS5 */\n StandardGS5 = \"Standard_GS5\",\n /** StandardGS48 */\n StandardGS48 = \"Standard_GS4-8\",\n /** StandardGS44 */\n StandardGS44 = \"Standard_GS4-4\",\n /** StandardGS516 */\n StandardGS516 = \"Standard_GS5-16\",\n /** StandardGS58 */\n StandardGS58 = \"Standard_GS5-8\",\n /** StandardH8 */\n StandardH8 = \"Standard_H8\",\n /** StandardH16 */\n StandardH16 = \"Standard_H16\",\n /** StandardH8M */\n StandardH8M = \"Standard_H8m\",\n /** StandardH16M */\n StandardH16M = \"Standard_H16m\",\n /** StandardH16R */\n StandardH16R = \"Standard_H16r\",\n /** StandardH16Mr */\n StandardH16Mr = \"Standard_H16mr\",\n /** StandardL4S */\n StandardL4S = \"Standard_L4s\",\n /** StandardL8S */\n StandardL8S = \"Standard_L8s\",\n /** StandardL16S */\n StandardL16S = \"Standard_L16s\",\n /** StandardL32S */\n StandardL32S = \"Standard_L32s\",\n /** StandardM64S */\n StandardM64S = \"Standard_M64s\",\n /** StandardM64Ms */\n StandardM64Ms = \"Standard_M64ms\",\n /** StandardM128S */\n StandardM128S = \"Standard_M128s\",\n /** StandardM128Ms */\n StandardM128Ms = \"Standard_M128ms\",\n /** StandardM6432Ms */\n StandardM6432Ms = \"Standard_M64-32ms\",\n /** StandardM6416Ms */\n StandardM6416Ms = \"Standard_M64-16ms\",\n /** StandardM12864Ms */\n StandardM12864Ms = \"Standard_M128-64ms\",\n /** StandardM12832Ms */\n StandardM12832Ms = \"Standard_M128-32ms\",\n /** StandardNC6 */\n StandardNC6 = \"Standard_NC6\",\n /** StandardNC12 */\n StandardNC12 = \"Standard_NC12\",\n /** StandardNC24 */\n StandardNC24 = \"Standard_NC24\",\n /** StandardNC24R */\n StandardNC24R = \"Standard_NC24r\",\n /** StandardNC6SV2 */\n StandardNC6SV2 = \"Standard_NC6s_v2\",\n /** StandardNC12SV2 */\n StandardNC12SV2 = \"Standard_NC12s_v2\",\n /** StandardNC24SV2 */\n StandardNC24SV2 = \"Standard_NC24s_v2\",\n /** StandardNC24RsV2 */\n StandardNC24RsV2 = \"Standard_NC24rs_v2\",\n /** StandardNC6SV3 */\n StandardNC6SV3 = \"Standard_NC6s_v3\",\n /** StandardNC12SV3 */\n StandardNC12SV3 = \"Standard_NC12s_v3\",\n /** StandardNC24SV3 */\n StandardNC24SV3 = \"Standard_NC24s_v3\",\n /** StandardNC24RsV3 */\n StandardNC24RsV3 = \"Standard_NC24rs_v3\",\n /** StandardND6S */\n StandardND6S = \"Standard_ND6s\",\n /** StandardND12S */\n StandardND12S = \"Standard_ND12s\",\n /** StandardND24S */\n StandardND24S = \"Standard_ND24s\",\n /** StandardND24Rs */\n StandardND24Rs = \"Standard_ND24rs\",\n /** StandardNV6 */\n StandardNV6 = \"Standard_NV6\",\n /** StandardNV12 */\n StandardNV12 = \"Standard_NV12\",\n /** StandardNV24 */\n StandardNV24 = \"Standard_NV24\",\n}\n\n/**\n * Defines values for VirtualMachineSizeTypes. \\\n * {@link KnownVirtualMachineSizeTypes} can be used interchangeably with VirtualMachineSizeTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Basic_A0** \\\n * **Basic_A1** \\\n * **Basic_A2** \\\n * **Basic_A3** \\\n * **Basic_A4** \\\n * **Standard_A0** \\\n * **Standard_A1** \\\n * **Standard_A2** \\\n * **Standard_A3** \\\n * **Standard_A4** \\\n * **Standard_A5** \\\n * **Standard_A6** \\\n * **Standard_A7** \\\n * **Standard_A8** \\\n * **Standard_A9** \\\n * **Standard_A10** \\\n * **Standard_A11** \\\n * **Standard_A1_v2** \\\n * **Standard_A2_v2** \\\n * **Standard_A4_v2** \\\n * **Standard_A8_v2** \\\n * **Standard_A2m_v2** \\\n * **Standard_A4m_v2** \\\n * **Standard_A8m_v2** \\\n * **Standard_B1s** \\\n * **Standard_B1ms** \\\n * **Standard_B2s** \\\n * **Standard_B2ms** \\\n * **Standard_B4ms** \\\n * **Standard_B8ms** \\\n * **Standard_D1** \\\n * **Standard_D2** \\\n * **Standard_D3** \\\n * **Standard_D4** \\\n * **Standard_D11** \\\n * **Standard_D12** \\\n * **Standard_D13** \\\n * **Standard_D14** \\\n * **Standard_D1_v2** \\\n * **Standard_D2_v2** \\\n * **Standard_D3_v2** \\\n * **Standard_D4_v2** \\\n * **Standard_D5_v2** \\\n * **Standard_D2_v3** \\\n * **Standard_D4_v3** \\\n * **Standard_D8_v3** \\\n * **Standard_D16_v3** \\\n * **Standard_D32_v3** \\\n * **Standard_D64_v3** \\\n * **Standard_D2s_v3** \\\n * **Standard_D4s_v3** \\\n * **Standard_D8s_v3** \\\n * **Standard_D16s_v3** \\\n * **Standard_D32s_v3** \\\n * **Standard_D64s_v3** \\\n * **Standard_D11_v2** \\\n * **Standard_D12_v2** \\\n * **Standard_D13_v2** \\\n * **Standard_D14_v2** \\\n * **Standard_D15_v2** \\\n * **Standard_DS1** \\\n * **Standard_DS2** \\\n * **Standard_DS3** \\\n * **Standard_DS4** \\\n * **Standard_DS11** \\\n * **Standard_DS12** \\\n * **Standard_DS13** \\\n * **Standard_DS14** \\\n * **Standard_DS1_v2** \\\n * **Standard_DS2_v2** \\\n * **Standard_DS3_v2** \\\n * **Standard_DS4_v2** \\\n * **Standard_DS5_v2** \\\n * **Standard_DS11_v2** \\\n * **Standard_DS12_v2** \\\n * **Standard_DS13_v2** \\\n * **Standard_DS14_v2** \\\n * **Standard_DS15_v2** \\\n * **Standard_DS13-4_v2** \\\n * **Standard_DS13-2_v2** \\\n * **Standard_DS14-8_v2** \\\n * **Standard_DS14-4_v2** \\\n * **Standard_E2_v3** \\\n * **Standard_E4_v3** \\\n * **Standard_E8_v3** \\\n * **Standard_E16_v3** \\\n * **Standard_E32_v3** \\\n * **Standard_E64_v3** \\\n * **Standard_E2s_v3** \\\n * **Standard_E4s_v3** \\\n * **Standard_E8s_v3** \\\n * **Standard_E16s_v3** \\\n * **Standard_E32s_v3** \\\n * **Standard_E64s_v3** \\\n * **Standard_E32-16_v3** \\\n * **Standard_E32-8s_v3** \\\n * **Standard_E64-32s_v3** \\\n * **Standard_E64-16s_v3** \\\n * **Standard_F1** \\\n * **Standard_F2** \\\n * **Standard_F4** \\\n * **Standard_F8** \\\n * **Standard_F16** \\\n * **Standard_F1s** \\\n * **Standard_F2s** \\\n * **Standard_F4s** \\\n * **Standard_F8s** \\\n * **Standard_F16s** \\\n * **Standard_F2s_v2** \\\n * **Standard_F4s_v2** \\\n * **Standard_F8s_v2** \\\n * **Standard_F16s_v2** \\\n * **Standard_F32s_v2** \\\n * **Standard_F64s_v2** \\\n * **Standard_F72s_v2** \\\n * **Standard_G1** \\\n * **Standard_G2** \\\n * **Standard_G3** \\\n * **Standard_G4** \\\n * **Standard_G5** \\\n * **Standard_GS1** \\\n * **Standard_GS2** \\\n * **Standard_GS3** \\\n * **Standard_GS4** \\\n * **Standard_GS5** \\\n * **Standard_GS4-8** \\\n * **Standard_GS4-4** \\\n * **Standard_GS5-16** \\\n * **Standard_GS5-8** \\\n * **Standard_H8** \\\n * **Standard_H16** \\\n * **Standard_H8m** \\\n * **Standard_H16m** \\\n * **Standard_H16r** \\\n * **Standard_H16mr** \\\n * **Standard_L4s** \\\n * **Standard_L8s** \\\n * **Standard_L16s** \\\n * **Standard_L32s** \\\n * **Standard_M64s** \\\n * **Standard_M64ms** \\\n * **Standard_M128s** \\\n * **Standard_M128ms** \\\n * **Standard_M64-32ms** \\\n * **Standard_M64-16ms** \\\n * **Standard_M128-64ms** \\\n * **Standard_M128-32ms** \\\n * **Standard_NC6** \\\n * **Standard_NC12** \\\n * **Standard_NC24** \\\n * **Standard_NC24r** \\\n * **Standard_NC6s_v2** \\\n * **Standard_NC12s_v2** \\\n * **Standard_NC24s_v2** \\\n * **Standard_NC24rs_v2** \\\n * **Standard_NC6s_v3** \\\n * **Standard_NC12s_v3** \\\n * **Standard_NC24s_v3** \\\n * **Standard_NC24rs_v3** \\\n * **Standard_ND6s** \\\n * **Standard_ND12s** \\\n * **Standard_ND24s** \\\n * **Standard_ND24rs** \\\n * **Standard_NV6** \\\n * **Standard_NV12** \\\n * **Standard_NV24**\n */\nexport type VirtualMachineSizeTypes = string;\n\n/** Known values of {@link DiskDetachOptionTypes} that the service accepts. */\nexport enum KnownDiskDetachOptionTypes {\n /** ForceDetach */\n ForceDetach = \"ForceDetach\",\n}\n\n/**\n * Defines values for DiskDetachOptionTypes. \\\n * {@link KnownDiskDetachOptionTypes} can be used interchangeably with DiskDetachOptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ForceDetach**\n */\nexport type DiskDetachOptionTypes = string;\n\n/** Known values of {@link IPVersions} that the service accepts. */\nexport enum KnownIPVersions {\n /** IPv4 */\n IPv4 = \"IPv4\",\n /** IPv6 */\n IPv6 = \"IPv6\",\n}\n\n/**\n * Defines values for IPVersions. \\\n * {@link KnownIPVersions} can be used interchangeably with IPVersions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **IPv4** \\\n * **IPv6**\n */\nexport type IPVersions = string;\n\n/** Known values of {@link PublicIPAllocationMethod} that the service accepts. */\nexport enum KnownPublicIPAllocationMethod {\n /** Dynamic */\n Dynamic = \"Dynamic\",\n /** Static */\n Static = \"Static\",\n}\n\n/**\n * Defines values for PublicIPAllocationMethod. \\\n * {@link KnownPublicIPAllocationMethod} can be used interchangeably with PublicIPAllocationMethod,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Dynamic** \\\n * **Static**\n */\nexport type PublicIPAllocationMethod = string;\n\n/** Known values of {@link HyperVGenerationType} that the service accepts. */\nexport enum KnownHyperVGenerationType {\n /** V1 */\n V1 = \"V1\",\n /** V2 */\n V2 = \"V2\",\n}\n\n/**\n * Defines values for HyperVGenerationType. \\\n * {@link KnownHyperVGenerationType} can be used interchangeably with HyperVGenerationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **V1** \\\n * **V2**\n */\nexport type HyperVGenerationType = string;\n\n/** Known values of {@link PatchOperationStatus} that the service accepts. */\nexport enum KnownPatchOperationStatus {\n /** Unknown */\n Unknown = \"Unknown\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** CompletedWithWarnings */\n CompletedWithWarnings = \"CompletedWithWarnings\",\n}\n\n/**\n * Defines values for PatchOperationStatus. \\\n * {@link KnownPatchOperationStatus} can be used interchangeably with PatchOperationStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **InProgress** \\\n * **Failed** \\\n * **Succeeded** \\\n * **CompletedWithWarnings**\n */\nexport type PatchOperationStatus = string;\n\n/** Known values of {@link ProximityPlacementGroupType} that the service accepts. */\nexport enum KnownProximityPlacementGroupType {\n /** Standard */\n Standard = \"Standard\",\n /** Ultra */\n Ultra = \"Ultra\",\n}\n\n/**\n * Defines values for ProximityPlacementGroupType. \\\n * {@link KnownProximityPlacementGroupType} can be used interchangeably with ProximityPlacementGroupType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard** \\\n * **Ultra**\n */\nexport type ProximityPlacementGroupType = string;\n\n/** Known values of {@link OperatingSystemType} that the service accepts. */\nexport enum KnownOperatingSystemType {\n /** Windows */\n Windows = \"Windows\",\n /** Linux */\n Linux = \"Linux\",\n}\n\n/**\n * Defines values for OperatingSystemType. \\\n * {@link KnownOperatingSystemType} can be used interchangeably with OperatingSystemType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Windows** \\\n * **Linux**\n */\nexport type OperatingSystemType = string;\n\n/** Known values of {@link RestorePointEncryptionType} that the service accepts. */\nexport enum KnownRestorePointEncryptionType {\n /** Disk Restore Point is encrypted at rest with Platform managed key. */\n EncryptionAtRestWithPlatformKey = \"EncryptionAtRestWithPlatformKey\",\n /** Disk Restore Point is encrypted at rest with Customer managed key that can be changed and revoked by a customer. */\n EncryptionAtRestWithCustomerKey = \"EncryptionAtRestWithCustomerKey\",\n /** Disk Restore Point is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed. */\n EncryptionAtRestWithPlatformAndCustomerKeys = \"EncryptionAtRestWithPlatformAndCustomerKeys\",\n}\n\n/**\n * Defines values for RestorePointEncryptionType. \\\n * {@link KnownRestorePointEncryptionType} can be used interchangeably with RestorePointEncryptionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptionAtRestWithPlatformKey**: Disk Restore Point is encrypted at rest with Platform managed key. \\\n * **EncryptionAtRestWithCustomerKey**: Disk Restore Point is encrypted at rest with Customer managed key that can be changed and revoked by a customer. \\\n * **EncryptionAtRestWithPlatformAndCustomerKeys**: Disk Restore Point is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed.\n */\nexport type RestorePointEncryptionType = string;\n\n/** Known values of {@link ConsistencyModeTypes} that the service accepts. */\nexport enum KnownConsistencyModeTypes {\n /** CrashConsistent */\n CrashConsistent = \"CrashConsistent\",\n /** FileSystemConsistent */\n FileSystemConsistent = \"FileSystemConsistent\",\n /** ApplicationConsistent */\n ApplicationConsistent = \"ApplicationConsistent\",\n}\n\n/**\n * Defines values for ConsistencyModeTypes. \\\n * {@link KnownConsistencyModeTypes} can be used interchangeably with ConsistencyModeTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CrashConsistent** \\\n * **FileSystemConsistent** \\\n * **ApplicationConsistent**\n */\nexport type ConsistencyModeTypes = string;\n\n/** Known values of {@link SnapshotAccessState} that the service accepts. */\nexport enum KnownSnapshotAccessState {\n /** Default value. */\n Unknown = \"Unknown\",\n /** The snapshot cannot be used for restore, copy or download to offline. */\n Pending = \"Pending\",\n /** The snapshot can be used for restore, copy to different region, and download to offline. */\n Available = \"Available\",\n /** The snapshot can be used for restoring disks with fast performance but cannot be copied or downloaded. */\n InstantAccess = \"InstantAccess\",\n /** The snapshot can be used for restoring disks with fast performance, copied and downloaded. */\n AvailableWithInstantAccess = \"AvailableWithInstantAccess\",\n}\n\n/**\n * Defines values for SnapshotAccessState. \\\n * {@link KnownSnapshotAccessState} can be used interchangeably with SnapshotAccessState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown**: Default value. \\\n * **Pending**: The snapshot cannot be used for restore, copy or download to offline. \\\n * **Available**: The snapshot can be used for restore, copy to different region, and download to offline. \\\n * **InstantAccess**: The snapshot can be used for restoring disks with fast performance but cannot be copied or downloaded. \\\n * **AvailableWithInstantAccess**: The snapshot can be used for restoring disks with fast performance, copied and downloaded.\n */\nexport type SnapshotAccessState = string;\n\n/** Known values of {@link ExpandTypesForListVMs} that the service accepts. */\nexport enum KnownExpandTypesForListVMs {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for ExpandTypesForListVMs. \\\n * {@link KnownExpandTypesForListVMs} can be used interchangeably with ExpandTypesForListVMs,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type ExpandTypesForListVMs = string;\n\n/** Known values of {@link CapacityReservationGroupInstanceViewTypes} that the service accepts. */\nexport enum KnownCapacityReservationGroupInstanceViewTypes {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for CapacityReservationGroupInstanceViewTypes. \\\n * {@link KnownCapacityReservationGroupInstanceViewTypes} can be used interchangeably with CapacityReservationGroupInstanceViewTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type CapacityReservationGroupInstanceViewTypes = string;\n\n/** Known values of {@link CapacityReservationInstanceViewTypes} that the service accepts. */\nexport enum KnownCapacityReservationInstanceViewTypes {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for CapacityReservationInstanceViewTypes. \\\n * {@link KnownCapacityReservationInstanceViewTypes} can be used interchangeably with CapacityReservationInstanceViewTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type CapacityReservationInstanceViewTypes = string;\n\n/** Known values of {@link RestorePointCollectionExpandOptions} that the service accepts. */\nexport enum KnownRestorePointCollectionExpandOptions {\n /** RestorePoints */\n RestorePoints = \"restorePoints\",\n}\n\n/**\n * Defines values for RestorePointCollectionExpandOptions. \\\n * {@link KnownRestorePointCollectionExpandOptions} can be used interchangeably with RestorePointCollectionExpandOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **restorePoints**\n */\nexport type RestorePointCollectionExpandOptions = string;\n\n/** Known values of {@link RestorePointExpandOptions} that the service accepts. */\nexport enum KnownRestorePointExpandOptions {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for RestorePointExpandOptions. \\\n * {@link KnownRestorePointExpandOptions} can be used interchangeably with RestorePointExpandOptions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type RestorePointExpandOptions = string;\n\n/** Known values of {@link SshEncryptionTypes} that the service accepts. */\nexport enum KnownSshEncryptionTypes {\n /** RSA */\n RSA = \"RSA\",\n /** Ed25519 */\n Ed25519 = \"Ed25519\",\n}\n\n/**\n * Defines values for SshEncryptionTypes. \\\n * {@link KnownSshEncryptionTypes} can be used interchangeably with SshEncryptionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **RSA** \\\n * **Ed25519**\n */\nexport type SshEncryptionTypes = string;\n\n/** Known values of {@link ExpandTypesForGetVMScaleSets} that the service accepts. */\nexport enum KnownExpandTypesForGetVMScaleSets {\n /** UserData */\n UserData = \"userData\",\n}\n\n/**\n * Defines values for ExpandTypesForGetVMScaleSets. \\\n * {@link KnownExpandTypesForGetVMScaleSets} can be used interchangeably with ExpandTypesForGetVMScaleSets,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **userData**\n */\nexport type ExpandTypesForGetVMScaleSets = string;\n\n/** Known values of {@link OrchestrationServiceNames} that the service accepts. */\nexport enum KnownOrchestrationServiceNames {\n /** AutomaticRepairs */\n AutomaticRepairs = \"AutomaticRepairs\",\n /** AutomaticZoneRebalancing orchestration service. */\n AutomaticZoneRebalancing = \"AutomaticZoneRebalancing\",\n}\n\n/**\n * Defines values for OrchestrationServiceNames. \\\n * {@link KnownOrchestrationServiceNames} can be used interchangeably with OrchestrationServiceNames,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **AutomaticRepairs** \\\n * **AutomaticZoneRebalancing**: AutomaticZoneRebalancing orchestration service.\n */\nexport type OrchestrationServiceNames = string;\n\n/** Known values of {@link OrchestrationServiceState} that the service accepts. */\nexport enum KnownOrchestrationServiceState {\n /** NotRunning */\n NotRunning = \"NotRunning\",\n /** Running */\n Running = \"Running\",\n /** Suspended */\n Suspended = \"Suspended\",\n}\n\n/**\n * Defines values for OrchestrationServiceState. \\\n * {@link KnownOrchestrationServiceState} can be used interchangeably with OrchestrationServiceState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **NotRunning** \\\n * **Running** \\\n * **Suspended**\n */\nexport type OrchestrationServiceState = string;\n\n/** Known values of {@link OrchestrationServiceOperationStatus} that the service accepts. */\nexport enum KnownOrchestrationServiceOperationStatus {\n /** InProgress orchestration service operation status. */\n InProgress = \"InProgress\",\n /** Completed orchestration service operation status. */\n Completed = \"Completed\",\n}\n\n/**\n * Defines values for OrchestrationServiceOperationStatus. \\\n * {@link KnownOrchestrationServiceOperationStatus} can be used interchangeably with OrchestrationServiceOperationStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **InProgress**: InProgress orchestration service operation status. \\\n * **Completed**: Completed orchestration service operation status.\n */\nexport type OrchestrationServiceOperationStatus = string;\n\n/** Known values of {@link OrchestrationServiceStateAction} that the service accepts. */\nexport enum KnownOrchestrationServiceStateAction {\n /** Resume */\n Resume = \"Resume\",\n /** Suspend */\n Suspend = \"Suspend\",\n}\n\n/**\n * Defines values for OrchestrationServiceStateAction. \\\n * {@link KnownOrchestrationServiceStateAction} can be used interchangeably with OrchestrationServiceStateAction,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Resume** \\\n * **Suspend**\n */\nexport type OrchestrationServiceStateAction = string;\n\n/** Known values of {@link HyperVGeneration} that the service accepts. */\nexport enum KnownHyperVGeneration {\n /** V1 */\n V1 = \"V1\",\n /** V2 */\n V2 = \"V2\",\n}\n\n/**\n * Defines values for HyperVGeneration. \\\n * {@link KnownHyperVGeneration} can be used interchangeably with HyperVGeneration,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **V1** \\\n * **V2**\n */\nexport type HyperVGeneration = string;\n\n/** Known values of {@link ResilientVMDeletionStatus} that the service accepts. */\nexport enum KnownResilientVMDeletionStatus {\n /** Enabled */\n Enabled = \"Enabled\",\n /** Disabled */\n Disabled = \"Disabled\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for ResilientVMDeletionStatus. \\\n * {@link KnownResilientVMDeletionStatus} can be used interchangeably with ResilientVMDeletionStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Enabled** \\\n * **Disabled** \\\n * **InProgress** \\\n * **Failed**\n */\nexport type ResilientVMDeletionStatus = string;\n\n/** Known values of {@link ScriptShellTypes} that the service accepts. */\nexport enum KnownScriptShellTypes {\n /** Default script shell type. */\n Default = \"Default\",\n /** Powershell7 script shell type. */\n Powershell7 = \"Powershell7\",\n}\n\n/**\n * Defines values for ScriptShellTypes. \\\n * {@link KnownScriptShellTypes} can be used interchangeably with ScriptShellTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Default**: Default script shell type. \\\n * **Powershell7**: Powershell7 script shell type.\n */\nexport type ScriptShellTypes = string;\n\n/** Known values of {@link ExecutionState} that the service accepts. */\nexport enum KnownExecutionState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Pending */\n Pending = \"Pending\",\n /** Running */\n Running = \"Running\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** TimedOut */\n TimedOut = \"TimedOut\",\n /** Canceled */\n Canceled = \"Canceled\",\n}\n\n/**\n * Defines values for ExecutionState. \\\n * {@link KnownExecutionState} can be used interchangeably with ExecutionState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Pending** \\\n * **Running** \\\n * **Failed** \\\n * **Succeeded** \\\n * **TimedOut** \\\n * **Canceled**\n */\nexport type ExecutionState = string;\n\n/** Known values of {@link ExpandTypeForListVMs} that the service accepts. */\nexport enum KnownExpandTypeForListVMs {\n /** InstanceView */\n InstanceView = \"instanceView\",\n}\n\n/**\n * Defines values for ExpandTypeForListVMs. \\\n * {@link KnownExpandTypeForListVMs} can be used interchangeably with ExpandTypeForListVMs,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **instanceView**\n */\nexport type ExpandTypeForListVMs = string;\n\n/** Known values of {@link VMGuestPatchRebootBehavior} that the service accepts. */\nexport enum KnownVMGuestPatchRebootBehavior {\n /** Unknown */\n Unknown = \"Unknown\",\n /** NeverReboots */\n NeverReboots = \"NeverReboots\",\n /** AlwaysRequiresReboot */\n AlwaysRequiresReboot = \"AlwaysRequiresReboot\",\n /** CanRequestReboot */\n CanRequestReboot = \"CanRequestReboot\",\n}\n\n/**\n * Defines values for VMGuestPatchRebootBehavior. \\\n * {@link KnownVMGuestPatchRebootBehavior} can be used interchangeably with VMGuestPatchRebootBehavior,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **NeverReboots** \\\n * **AlwaysRequiresReboot** \\\n * **CanRequestReboot**\n */\nexport type VMGuestPatchRebootBehavior = string;\n\n/** Known values of {@link PatchAssessmentState} that the service accepts. */\nexport enum KnownPatchAssessmentState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Available */\n Available = \"Available\",\n}\n\n/**\n * Defines values for PatchAssessmentState. \\\n * {@link KnownPatchAssessmentState} can be used interchangeably with PatchAssessmentState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Available**\n */\nexport type PatchAssessmentState = string;\n\n/** Known values of {@link VMGuestPatchRebootSetting} that the service accepts. */\nexport enum KnownVMGuestPatchRebootSetting {\n /** IfRequired */\n IfRequired = \"IfRequired\",\n /** Never */\n Never = \"Never\",\n /** Always */\n Always = \"Always\",\n}\n\n/**\n * Defines values for VMGuestPatchRebootSetting. \\\n * {@link KnownVMGuestPatchRebootSetting} can be used interchangeably with VMGuestPatchRebootSetting,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **IfRequired** \\\n * **Never** \\\n * **Always**\n */\nexport type VMGuestPatchRebootSetting = string;\n\n/** Known values of {@link VMGuestPatchClassificationWindows} that the service accepts. */\nexport enum KnownVMGuestPatchClassificationWindows {\n /** Critical */\n Critical = \"Critical\",\n /** Security */\n Security = \"Security\",\n /** UpdateRollUp */\n UpdateRollUp = \"UpdateRollUp\",\n /** FeaturePack */\n FeaturePack = \"FeaturePack\",\n /** ServicePack */\n ServicePack = \"ServicePack\",\n /** Definition */\n Definition = \"Definition\",\n /** Tools */\n Tools = \"Tools\",\n /** Updates */\n Updates = \"Updates\",\n}\n\n/**\n * Defines values for VMGuestPatchClassificationWindows. \\\n * {@link KnownVMGuestPatchClassificationWindows} can be used interchangeably with VMGuestPatchClassificationWindows,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Critical** \\\n * **Security** \\\n * **UpdateRollUp** \\\n * **FeaturePack** \\\n * **ServicePack** \\\n * **Definition** \\\n * **Tools** \\\n * **Updates**\n */\nexport type VMGuestPatchClassificationWindows = string;\n\n/** Known values of {@link VMGuestPatchClassificationLinux} that the service accepts. */\nexport enum KnownVMGuestPatchClassificationLinux {\n /** Critical */\n Critical = \"Critical\",\n /** Security */\n Security = \"Security\",\n /** Other */\n Other = \"Other\",\n}\n\n/**\n * Defines values for VMGuestPatchClassificationLinux. \\\n * {@link KnownVMGuestPatchClassificationLinux} can be used interchangeably with VMGuestPatchClassificationLinux,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Critical** \\\n * **Security** \\\n * **Other**\n */\nexport type VMGuestPatchClassificationLinux = string;\n\n/** Known values of {@link VMGuestPatchRebootStatus} that the service accepts. */\nexport enum KnownVMGuestPatchRebootStatus {\n /** Unknown */\n Unknown = \"Unknown\",\n /** NotNeeded */\n NotNeeded = \"NotNeeded\",\n /** Required */\n Required = \"Required\",\n /** Started */\n Started = \"Started\",\n /** Failed */\n Failed = \"Failed\",\n /** Completed */\n Completed = \"Completed\",\n}\n\n/**\n * Defines values for VMGuestPatchRebootStatus. \\\n * {@link KnownVMGuestPatchRebootStatus} can be used interchangeably with VMGuestPatchRebootStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **NotNeeded** \\\n * **Required** \\\n * **Started** \\\n * **Failed** \\\n * **Completed**\n */\nexport type VMGuestPatchRebootStatus = string;\n\n/** Known values of {@link PatchInstallationState} that the service accepts. */\nexport enum KnownPatchInstallationState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Installed */\n Installed = \"Installed\",\n /** Failed */\n Failed = \"Failed\",\n /** Excluded */\n Excluded = \"Excluded\",\n /** NotSelected */\n NotSelected = \"NotSelected\",\n /** Pending */\n Pending = \"Pending\",\n}\n\n/**\n * Defines values for PatchInstallationState. \\\n * {@link KnownPatchInstallationState} can be used interchangeably with PatchInstallationState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Installed** \\\n * **Failed** \\\n * **Excluded** \\\n * **NotSelected** \\\n * **Pending**\n */\nexport type PatchInstallationState = string;\n\n/** Known values of {@link PrivateEndpointServiceConnectionStatus} that the service accepts. */\nexport enum KnownPrivateEndpointServiceConnectionStatus {\n /** Pending */\n Pending = \"Pending\",\n /** Approved */\n Approved = \"Approved\",\n /** Rejected */\n Rejected = \"Rejected\",\n}\n\n/**\n * Defines values for PrivateEndpointServiceConnectionStatus. \\\n * {@link KnownPrivateEndpointServiceConnectionStatus} can be used interchangeably with PrivateEndpointServiceConnectionStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Pending** \\\n * **Approved** \\\n * **Rejected**\n */\nexport type PrivateEndpointServiceConnectionStatus = string;\n\n/** Known values of {@link PrivateEndpointConnectionProvisioningState} that the service accepts. */\nexport enum KnownPrivateEndpointConnectionProvisioningState {\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** Creating */\n Creating = \"Creating\",\n /** Deleting */\n Deleting = \"Deleting\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for PrivateEndpointConnectionProvisioningState. \\\n * {@link KnownPrivateEndpointConnectionProvisioningState} can be used interchangeably with PrivateEndpointConnectionProvisioningState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Succeeded** \\\n * **Creating** \\\n * **Deleting** \\\n * **Failed**\n */\nexport type PrivateEndpointConnectionProvisioningState = string;\n\n/** Known values of {@link DiskEncryptionSetType} that the service accepts. */\nexport enum KnownDiskEncryptionSetType {\n /** Resource using diskEncryptionSet would be encrypted at rest with Customer managed key that can be changed and revoked by a customer. */\n EncryptionAtRestWithCustomerKey = \"EncryptionAtRestWithCustomerKey\",\n /** Resource using diskEncryptionSet would be encrypted at rest with two layers of encryption. One of the keys is Customer managed and the other key is Platform managed. */\n EncryptionAtRestWithPlatformAndCustomerKeys = \"EncryptionAtRestWithPlatformAndCustomerKeys\",\n /** Confidential VM supported disk and VM guest state would be encrypted with customer managed key. */\n ConfidentialVmEncryptedWithCustomerKey = \"ConfidentialVmEncryptedWithCustomerKey\",\n}\n\n/**\n * Defines values for DiskEncryptionSetType. \\\n * {@link KnownDiskEncryptionSetType} can be used interchangeably with DiskEncryptionSetType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptionAtRestWithCustomerKey**: Resource using diskEncryptionSet would be encrypted at rest with Customer managed key that can be changed and revoked by a customer. \\\n * **EncryptionAtRestWithPlatformAndCustomerKeys**: Resource using diskEncryptionSet would be encrypted at rest with two layers of encryption. One of the keys is Customer managed and the other key is Platform managed. \\\n * **ConfidentialVmEncryptedWithCustomerKey**: Confidential VM supported disk and VM guest state would be encrypted with customer managed key.\n */\nexport type DiskEncryptionSetType = string;\n\n/** Known values of {@link DiskEncryptionSetIdentityType} that the service accepts. */\nexport enum KnownDiskEncryptionSetIdentityType {\n /** SystemAssigned */\n SystemAssigned = \"SystemAssigned\",\n /** UserAssigned */\n UserAssigned = \"UserAssigned\",\n /** SystemAssignedUserAssigned */\n SystemAssignedUserAssigned = \"SystemAssigned, UserAssigned\",\n /** None */\n None = \"None\",\n}\n\n/**\n * Defines values for DiskEncryptionSetIdentityType. \\\n * {@link KnownDiskEncryptionSetIdentityType} can be used interchangeably with DiskEncryptionSetIdentityType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **SystemAssigned** \\\n * **UserAssigned** \\\n * **SystemAssigned, UserAssigned** \\\n * **None**\n */\nexport type DiskEncryptionSetIdentityType = string;\n\n/** Known values of {@link Architecture} that the service accepts. */\nexport enum KnownArchitecture {\n /** X64 */\n X64 = \"x64\",\n /** Arm64 */\n Arm64 = \"Arm64\",\n}\n\n/**\n * Defines values for Architecture. \\\n * {@link KnownArchitecture} can be used interchangeably with Architecture,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **x64** \\\n * **Arm64**\n */\nexport type Architecture = string;\n\n/** Known values of {@link SupportedSecurityOption} that the service accepts. */\nexport enum KnownSupportedSecurityOption {\n /** The disk supports creating Trusted Launch VMs. */\n TrustedLaunchSupported = \"TrustedLaunchSupported\",\n /** The disk supports creating both Trusted Launch and Confidential VMs. */\n TrustedLaunchAndConfidentialVMSupported = \"TrustedLaunchAndConfidentialVMSupported\",\n}\n\n/**\n * Defines values for SupportedSecurityOption. \\\n * {@link KnownSupportedSecurityOption} can be used interchangeably with SupportedSecurityOption,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TrustedLaunchSupported**: The disk supports creating Trusted Launch VMs. \\\n * **TrustedLaunchAndConfidentialVMSupported**: The disk supports creating both Trusted Launch and Confidential VMs.\n */\nexport type SupportedSecurityOption = string;\n\n/** Known values of {@link DiskCreateOption} that the service accepts. */\nexport enum KnownDiskCreateOption {\n /** Create an empty data disk of a size given by diskSizeGB. */\n Empty = \"Empty\",\n /** Disk will be attached to a VM. */\n Attach = \"Attach\",\n /** Create a new disk from a platform image specified by the given imageReference or galleryImageReference. */\n FromImage = \"FromImage\",\n /** Create a disk by importing from a blob specified by a sourceUri in a storage account specified by storageAccountId. */\n Import = \"Import\",\n /** Create a new disk or snapshot by copying from a disk or snapshot specified by the given sourceResourceId. */\n Copy = \"Copy\",\n /** Create a new disk by copying from a backup recovery point. */\n Restore = \"Restore\",\n /** Create a new disk by obtaining a write token and using it to directly upload the contents of the disk. */\n Upload = \"Upload\",\n /** Create a new disk by using a deep copy process, where the resource creation is considered complete only after all data has been copied from the source. */\n CopyStart = \"CopyStart\",\n /** Similar to Import create option. Create a new Trusted Launch VM or Confidential VM supported disk by importing additional blobs for VM guest state specified by securityDataUri and VM metadata specified by securityMetadataUri in storage account specified by storageAccountId. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. */\n ImportSecure = \"ImportSecure\",\n /** Similar to Upload create option. Create a new Trusted Launch VM or Confidential VM supported disk and upload using write token in disk, VM guest state and VM metadata. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. */\n UploadPreparedSecure = \"UploadPreparedSecure\",\n /** Create a new disk by exporting from elastic san volume snapshot */\n CopyFromSanSnapshot = \"CopyFromSanSnapshot\",\n}\n\n/**\n * Defines values for DiskCreateOption. \\\n * {@link KnownDiskCreateOption} can be used interchangeably with DiskCreateOption,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Empty**: Create an empty data disk of a size given by diskSizeGB. \\\n * **Attach**: Disk will be attached to a VM. \\\n * **FromImage**: Create a new disk from a platform image specified by the given imageReference or galleryImageReference. \\\n * **Import**: Create a disk by importing from a blob specified by a sourceUri in a storage account specified by storageAccountId. \\\n * **Copy**: Create a new disk or snapshot by copying from a disk or snapshot specified by the given sourceResourceId. \\\n * **Restore**: Create a new disk by copying from a backup recovery point. \\\n * **Upload**: Create a new disk by obtaining a write token and using it to directly upload the contents of the disk. \\\n * **CopyStart**: Create a new disk by using a deep copy process, where the resource creation is considered complete only after all data has been copied from the source. \\\n * **ImportSecure**: Similar to Import create option. Create a new Trusted Launch VM or Confidential VM supported disk by importing additional blobs for VM guest state specified by securityDataUri and VM metadata specified by securityMetadataUri in storage account specified by storageAccountId. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. \\\n * **UploadPreparedSecure**: Similar to Upload create option. Create a new Trusted Launch VM or Confidential VM supported disk and upload using write token in disk, VM guest state and VM metadata. The VM metadata is optional and only required for certain Confidential VM configurations and not required for Trusted Launch VM. \\\n * **CopyFromSanSnapshot**: Create a new disk by exporting from elastic san volume snapshot\n */\nexport type DiskCreateOption = string;\n\n/** Known values of {@link ProvisionedBandwidthCopyOption} that the service accepts. */\nexport enum KnownProvisionedBandwidthCopyOption {\n /** None */\n None = \"None\",\n /** Enhanced */\n Enhanced = \"Enhanced\",\n}\n\n/**\n * Defines values for ProvisionedBandwidthCopyOption. \\\n * {@link KnownProvisionedBandwidthCopyOption} can be used interchangeably with ProvisionedBandwidthCopyOption,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Enhanced**\n */\nexport type ProvisionedBandwidthCopyOption = string;\n\n/** Known values of {@link DiskState} that the service accepts. */\nexport enum KnownDiskState {\n /** The disk is not being used and can be attached to a VM. */\n Unattached = \"Unattached\",\n /** The disk is currently attached to a running VM. */\n Attached = \"Attached\",\n /** The disk is attached to a stopped-deallocated VM. */\n Reserved = \"Reserved\",\n /** The disk is attached to a VM which is in hibernated state. */\n Frozen = \"Frozen\",\n /** The disk currently has an Active SAS Uri associated with it. */\n ActiveSAS = \"ActiveSAS\",\n /** The disk is attached to a VM in hibernated state and has an active SAS URI associated with it. */\n ActiveSASFrozen = \"ActiveSASFrozen\",\n /** A disk is ready to be created by upload by requesting a write token. */\n ReadyToUpload = \"ReadyToUpload\",\n /** A disk is created for upload and a write token has been issued for uploading to it. */\n ActiveUpload = \"ActiveUpload\",\n}\n\n/**\n * Defines values for DiskState. \\\n * {@link KnownDiskState} can be used interchangeably with DiskState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unattached**: The disk is not being used and can be attached to a VM. \\\n * **Attached**: The disk is currently attached to a running VM. \\\n * **Reserved**: The disk is attached to a stopped-deallocated VM. \\\n * **Frozen**: The disk is attached to a VM which is in hibernated state. \\\n * **ActiveSAS**: The disk currently has an Active SAS Uri associated with it. \\\n * **ActiveSASFrozen**: The disk is attached to a VM in hibernated state and has an active SAS URI associated with it. \\\n * **ReadyToUpload**: A disk is ready to be created by upload by requesting a write token. \\\n * **ActiveUpload**: A disk is created for upload and a write token has been issued for uploading to it.\n */\nexport type DiskState = string;\n\n/** Known values of {@link EncryptionType} that the service accepts. */\nexport enum KnownEncryptionType {\n /** Disk is encrypted at rest with Platform managed key. It is the default encryption type. This is not a valid encryption type for disk encryption sets. */\n EncryptionAtRestWithPlatformKey = \"EncryptionAtRestWithPlatformKey\",\n /** Disk is encrypted at rest with Customer managed key that can be changed and revoked by a customer. */\n EncryptionAtRestWithCustomerKey = \"EncryptionAtRestWithCustomerKey\",\n /** Disk is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed. */\n EncryptionAtRestWithPlatformAndCustomerKeys = \"EncryptionAtRestWithPlatformAndCustomerKeys\",\n}\n\n/**\n * Defines values for EncryptionType. \\\n * {@link KnownEncryptionType} can be used interchangeably with EncryptionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptionAtRestWithPlatformKey**: Disk is encrypted at rest with Platform managed key. It is the default encryption type. This is not a valid encryption type for disk encryption sets. \\\n * **EncryptionAtRestWithCustomerKey**: Disk is encrypted at rest with Customer managed key that can be changed and revoked by a customer. \\\n * **EncryptionAtRestWithPlatformAndCustomerKeys**: Disk is encrypted at rest with 2 layers of encryption. One of the keys is Customer managed and the other key is Platform managed.\n */\nexport type EncryptionType = string;\n\n/** Known values of {@link NetworkAccessPolicy} that the service accepts. */\nexport enum KnownNetworkAccessPolicy {\n /** The disk can be exported or uploaded to from any network. */\n AllowAll = \"AllowAll\",\n /** The disk can be exported or uploaded to using a DiskAccess resource's private endpoints. */\n AllowPrivate = \"AllowPrivate\",\n /** The disk cannot be exported. */\n DenyAll = \"DenyAll\",\n}\n\n/**\n * Defines values for NetworkAccessPolicy. \\\n * {@link KnownNetworkAccessPolicy} can be used interchangeably with NetworkAccessPolicy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **AllowAll**: The disk can be exported or uploaded to from any network. \\\n * **AllowPrivate**: The disk can be exported or uploaded to using a DiskAccess resource's private endpoints. \\\n * **DenyAll**: The disk cannot be exported.\n */\nexport type NetworkAccessPolicy = string;\n\n/** Known values of {@link DiskSecurityTypes} that the service accepts. */\nexport enum KnownDiskSecurityTypes {\n /** Trusted Launch provides security features such as secure boot and virtual Trusted Platform Module (vTPM) */\n TrustedLaunch = \"TrustedLaunch\",\n /** Indicates Confidential VM disk with only VM guest state encrypted */\n ConfidentialVMVmguestStateOnlyEncryptedWithPlatformKey = \"ConfidentialVM_VMGuestStateOnlyEncryptedWithPlatformKey\",\n /** Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a platform managed key */\n ConfidentialVMDiskEncryptedWithPlatformKey = \"ConfidentialVM_DiskEncryptedWithPlatformKey\",\n /** Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a customer managed key */\n ConfidentialVMDiskEncryptedWithCustomerKey = \"ConfidentialVM_DiskEncryptedWithCustomerKey\",\n /** Indicates Confidential VM disk with a ephemeral vTPM. vTPM state is not persisted across VM reboots. */\n ConfidentialVMNonPersistedTPM = \"ConfidentialVM_NonPersistedTPM\",\n}\n\n/**\n * Defines values for DiskSecurityTypes. \\\n * {@link KnownDiskSecurityTypes} can be used interchangeably with DiskSecurityTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **TrustedLaunch**: Trusted Launch provides security features such as secure boot and virtual Trusted Platform Module (vTPM) \\\n * **ConfidentialVM_VMGuestStateOnlyEncryptedWithPlatformKey**: Indicates Confidential VM disk with only VM guest state encrypted \\\n * **ConfidentialVM_DiskEncryptedWithPlatformKey**: Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a platform managed key \\\n * **ConfidentialVM_DiskEncryptedWithCustomerKey**: Indicates Confidential VM disk with both OS disk and VM guest state encrypted with a customer managed key \\\n * **ConfidentialVM_NonPersistedTPM**: Indicates Confidential VM disk with a ephemeral vTPM. vTPM state is not persisted across VM reboots.\n */\nexport type DiskSecurityTypes = string;\n\n/** Known values of {@link PublicNetworkAccess} that the service accepts. */\nexport enum KnownPublicNetworkAccess {\n /** You can generate a SAS URI to access the underlying data of the disk publicly on the internet when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate. */\n Enabled = \"Enabled\",\n /** You cannot access the underlying data of the disk publicly on the internet even when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate. */\n Disabled = \"Disabled\",\n}\n\n/**\n * Defines values for PublicNetworkAccess. \\\n * {@link KnownPublicNetworkAccess} can be used interchangeably with PublicNetworkAccess,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Enabled**: You can generate a SAS URI to access the underlying data of the disk publicly on the internet when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate. \\\n * **Disabled**: You cannot access the underlying data of the disk publicly on the internet even when NetworkAccessPolicy is set to AllowAll. You can access the data via the SAS URI only from your trusted Azure VNET when NetworkAccessPolicy is set to AllowPrivate.\n */\nexport type PublicNetworkAccess = string;\n\n/** Known values of {@link DataAccessAuthMode} that the service accepts. */\nexport enum KnownDataAccessAuthMode {\n /** When export\\/upload URL is used, the system checks if the user has an identity in Azure Active Directory and has necessary permissions to export\\/upload the data. Please refer to aka.ms\\/DisksAzureADAuth. */\n AzureActiveDirectory = \"AzureActiveDirectory\",\n /** No additional authentication would be performed when accessing export\\/upload URL. */\n None = \"None\",\n}\n\n/**\n * Defines values for DataAccessAuthMode. \\\n * {@link KnownDataAccessAuthMode} can be used interchangeably with DataAccessAuthMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **AzureActiveDirectory**: When export\\/upload URL is used, the system checks if the user has an identity in Azure Active Directory and has necessary permissions to export\\/upload the data. Please refer to aka.ms\\/DisksAzureADAuth. \\\n * **None**: No additional authentication would be performed when accessing export\\/upload URL.\n */\nexport type DataAccessAuthMode = string;\n\n/** Known values of {@link AvailabilityPolicyDiskDelay} that the service accepts. */\nexport enum KnownAvailabilityPolicyDiskDelay {\n /** Defaults to behavior without av policy specified, which is VM restart upon slow disk io. */\n None = \"None\",\n /** Upon a disk io failure or slow response, try detaching then reattaching the disk. */\n AutomaticReattach = \"AutomaticReattach\",\n}\n\n/**\n * Defines values for AvailabilityPolicyDiskDelay. \\\n * {@link KnownAvailabilityPolicyDiskDelay} can be used interchangeably with AvailabilityPolicyDiskDelay,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None**: Defaults to behavior without av policy specified, which is VM restart upon slow disk io. \\\n * **AutomaticReattach**: Upon a disk io failure or slow response, try detaching then reattaching the disk.\n */\nexport type AvailabilityPolicyDiskDelay = string;\n\n/** Known values of {@link DiskStorageAccountTypes} that the service accepts. */\nexport enum KnownDiskStorageAccountTypes {\n /** Standard HDD locally redundant storage. Best for backup, non-critical, and infrequent access. */\n StandardLRS = \"Standard_LRS\",\n /** Premium SSD locally redundant storage. Best for production and performance sensitive workloads. */\n PremiumLRS = \"Premium_LRS\",\n /** Standard SSD locally redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test. */\n StandardSSDLRS = \"StandardSSD_LRS\",\n /** Ultra SSD locally redundant storage. Best for IO-intensive workloads such as SAP HANA, top tier databases (for example, SQL, Oracle), and other transaction-heavy workloads. */\n UltraSSDLRS = \"UltraSSD_LRS\",\n /** Premium SSD zone redundant storage. Best for the production workloads that need storage resiliency against zone failures. */\n PremiumZRS = \"Premium_ZRS\",\n /** Standard SSD zone redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test that need storage resiliency against zone failures. */\n StandardSSDZRS = \"StandardSSD_ZRS\",\n /** Premium SSD v2 locally redundant storage. Best for production and performance-sensitive workloads that consistently require low latency and high IOPS and throughput. */\n PremiumV2LRS = \"PremiumV2_LRS\",\n}\n\n/**\n * Defines values for DiskStorageAccountTypes. \\\n * {@link KnownDiskStorageAccountTypes} can be used interchangeably with DiskStorageAccountTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS**: Standard HDD locally redundant storage. Best for backup, non-critical, and infrequent access. \\\n * **Premium_LRS**: Premium SSD locally redundant storage. Best for production and performance sensitive workloads. \\\n * **StandardSSD_LRS**: Standard SSD locally redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test. \\\n * **UltraSSD_LRS**: Ultra SSD locally redundant storage. Best for IO-intensive workloads such as SAP HANA, top tier databases (for example, SQL, Oracle), and other transaction-heavy workloads. \\\n * **Premium_ZRS**: Premium SSD zone redundant storage. Best for the production workloads that need storage resiliency against zone failures. \\\n * **StandardSSD_ZRS**: Standard SSD zone redundant storage. Best for web servers, lightly used enterprise applications and dev\\/test that need storage resiliency against zone failures. \\\n * **PremiumV2_LRS**: Premium SSD v2 locally redundant storage. Best for production and performance-sensitive workloads that consistently require low latency and high IOPS and throughput.\n */\nexport type DiskStorageAccountTypes = string;\n\n/** Known values of {@link CopyCompletionErrorReason} that the service accepts. */\nexport enum KnownCopyCompletionErrorReason {\n /** Indicates that the source snapshot was deleted while the background copy of the resource created via CopyStart operation was in progress. */\n CopySourceNotFound = \"CopySourceNotFound\",\n}\n\n/**\n * Defines values for CopyCompletionErrorReason. \\\n * {@link KnownCopyCompletionErrorReason} can be used interchangeably with CopyCompletionErrorReason,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **CopySourceNotFound**: Indicates that the source snapshot was deleted while the background copy of the resource created via CopyStart operation was in progress.\n */\nexport type CopyCompletionErrorReason = string;\n\n/** Known values of {@link SnapshotStorageAccountTypes} that the service accepts. */\nexport enum KnownSnapshotStorageAccountTypes {\n /** Standard HDD locally redundant storage */\n StandardLRS = \"Standard_LRS\",\n /** Premium SSD locally redundant storage */\n PremiumLRS = \"Premium_LRS\",\n /** Standard zone redundant storage */\n StandardZRS = \"Standard_ZRS\",\n}\n\n/**\n * Defines values for SnapshotStorageAccountTypes. \\\n * {@link KnownSnapshotStorageAccountTypes} can be used interchangeably with SnapshotStorageAccountTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS**: Standard HDD locally redundant storage \\\n * **Premium_LRS**: Premium SSD locally redundant storage \\\n * **Standard_ZRS**: Standard zone redundant storage\n */\nexport type SnapshotStorageAccountTypes = string;\n\n/** Known values of {@link AccessLevel} that the service accepts. */\nexport enum KnownAccessLevel {\n /** None */\n None = \"None\",\n /** Read */\n Read = \"Read\",\n /** Write */\n Write = \"Write\",\n}\n\n/**\n * Defines values for AccessLevel. \\\n * {@link KnownAccessLevel} can be used interchangeably with AccessLevel,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Read** \\\n * **Write**\n */\nexport type AccessLevel = string;\n\n/** Known values of {@link FileFormat} that the service accepts. */\nexport enum KnownFileFormat {\n /** A VHD file is a disk image file in the Virtual Hard Disk file format. */\n VHD = \"VHD\",\n /** A VHDX file is a disk image file in the Virtual Hard Disk v2 file format. */\n Vhdx = \"VHDX\",\n}\n\n/**\n * Defines values for FileFormat. \\\n * {@link KnownFileFormat} can be used interchangeably with FileFormat,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **VHD**: A VHD file is a disk image file in the Virtual Hard Disk file format. \\\n * **VHDX**: A VHDX file is a disk image file in the Virtual Hard Disk v2 file format.\n */\nexport type FileFormat = string;\n\n/** Known values of {@link ExtendedLocationType} that the service accepts. */\nexport enum KnownExtendedLocationType {\n /** EdgeZone */\n EdgeZone = \"EdgeZone\",\n}\n\n/**\n * Defines values for ExtendedLocationType. \\\n * {@link KnownExtendedLocationType} can be used interchangeably with ExtendedLocationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EdgeZone**\n */\nexport type ExtendedLocationType = string;\n\n/** Known values of {@link GalleryProvisioningState} that the service accepts. */\nexport enum KnownGalleryProvisioningState {\n /** Creating */\n Creating = \"Creating\",\n /** Updating */\n Updating = \"Updating\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** Deleting */\n Deleting = \"Deleting\",\n /** Migrating */\n Migrating = \"Migrating\",\n}\n\n/**\n * Defines values for GalleryProvisioningState. \\\n * {@link KnownGalleryProvisioningState} can be used interchangeably with GalleryProvisioningState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Creating** \\\n * **Updating** \\\n * **Failed** \\\n * **Succeeded** \\\n * **Deleting** \\\n * **Migrating**\n */\nexport type GalleryProvisioningState = string;\n\n/** Known values of {@link GallerySharingPermissionTypes} that the service accepts. */\nexport enum KnownGallerySharingPermissionTypes {\n /** Private */\n Private = \"Private\",\n /** Groups */\n Groups = \"Groups\",\n /** Community */\n Community = \"Community\",\n}\n\n/**\n * Defines values for GallerySharingPermissionTypes. \\\n * {@link KnownGallerySharingPermissionTypes} can be used interchangeably with GallerySharingPermissionTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Private** \\\n * **Groups** \\\n * **Community**\n */\nexport type GallerySharingPermissionTypes = string;\n\n/** Known values of {@link SharingProfileGroupTypes} that the service accepts. */\nexport enum KnownSharingProfileGroupTypes {\n /** Subscriptions */\n Subscriptions = \"Subscriptions\",\n /** AADTenants */\n AADTenants = \"AADTenants\",\n}\n\n/**\n * Defines values for SharingProfileGroupTypes. \\\n * {@link KnownSharingProfileGroupTypes} can be used interchangeably with SharingProfileGroupTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Subscriptions** \\\n * **AADTenants**\n */\nexport type SharingProfileGroupTypes = string;\n\n/** Known values of {@link SharingState} that the service accepts. */\nexport enum KnownSharingState {\n /** Succeeded */\n Succeeded = \"Succeeded\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Failed */\n Failed = \"Failed\",\n /** Unknown */\n Unknown = \"Unknown\",\n}\n\n/**\n * Defines values for SharingState. \\\n * {@link KnownSharingState} can be used interchangeably with SharingState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Succeeded** \\\n * **InProgress** \\\n * **Failed** \\\n * **Unknown**\n */\nexport type SharingState = string;\n\n/** Known values of {@link UefiSignatureTemplateName} that the service accepts. */\nexport enum KnownUefiSignatureTemplateName {\n /** NoSignatureTemplate */\n NoSignatureTemplate = \"NoSignatureTemplate\",\n /** MicrosoftUefiCertificateAuthorityTemplate */\n MicrosoftUefiCertificateAuthorityTemplate = \"MicrosoftUefiCertificateAuthorityTemplate\",\n /** MicrosoftWindowsTemplate */\n MicrosoftWindowsTemplate = \"MicrosoftWindowsTemplate\",\n}\n\n/**\n * Defines values for UefiSignatureTemplateName. \\\n * {@link KnownUefiSignatureTemplateName} can be used interchangeably with UefiSignatureTemplateName,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **NoSignatureTemplate** \\\n * **MicrosoftUefiCertificateAuthorityTemplate** \\\n * **MicrosoftWindowsTemplate**\n */\nexport type UefiSignatureTemplateName = string;\n\n/** Known values of {@link UefiKeyType} that the service accepts. */\nexport enum KnownUefiKeyType {\n /** Sha256 */\n Sha256 = \"sha256\",\n /** X509 */\n X509 = \"x509\",\n}\n\n/**\n * Defines values for UefiKeyType. \\\n * {@link KnownUefiKeyType} can be used interchangeably with UefiKeyType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **sha256** \\\n * **x509**\n */\nexport type UefiKeyType = string;\n\n/** Known values of {@link SharedGalleryHostCaching} that the service accepts. */\nexport enum KnownSharedGalleryHostCaching {\n /** None */\n None = \"None\",\n /** ReadOnly */\n ReadOnly = \"ReadOnly\",\n /** ReadWrite */\n ReadWrite = \"ReadWrite\",\n}\n\n/**\n * Defines values for SharedGalleryHostCaching. \\\n * {@link KnownSharedGalleryHostCaching} can be used interchangeably with SharedGalleryHostCaching,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **ReadOnly** \\\n * **ReadWrite**\n */\nexport type SharedGalleryHostCaching = string;\n\n/** Known values of {@link SharedToValues} that the service accepts. */\nexport enum KnownSharedToValues {\n /** Tenant */\n Tenant = \"tenant\",\n}\n\n/**\n * Defines values for SharedToValues. \\\n * {@link KnownSharedToValues} can be used interchangeably with SharedToValues,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **tenant**\n */\nexport type SharedToValues = string;\n\n/** Known values of {@link SelectPermissions} that the service accepts. */\nexport enum KnownSelectPermissions {\n /** Permissions */\n Permissions = \"Permissions\",\n}\n\n/**\n * Defines values for SelectPermissions. \\\n * {@link KnownSelectPermissions} can be used interchangeably with SelectPermissions,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Permissions**\n */\nexport type SelectPermissions = string;\n\n/** Known values of {@link GalleryExpandParams} that the service accepts. */\nexport enum KnownGalleryExpandParams {\n /** SharingProfileGroups */\n SharingProfileGroups = \"SharingProfile/Groups\",\n}\n\n/**\n * Defines values for GalleryExpandParams. \\\n * {@link KnownGalleryExpandParams} can be used interchangeably with GalleryExpandParams,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **SharingProfile\\/Groups**\n */\nexport type GalleryExpandParams = string;\n\n/** Known values of {@link GalleryApplicationScriptRebootBehavior} that the service accepts. */\nexport enum KnownGalleryApplicationScriptRebootBehavior {\n /** None */\n None = \"None\",\n /** Rerun */\n Rerun = \"Rerun\",\n}\n\n/**\n * Defines values for GalleryApplicationScriptRebootBehavior. \\\n * {@link KnownGalleryApplicationScriptRebootBehavior} can be used interchangeably with GalleryApplicationScriptRebootBehavior,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **None** \\\n * **Rerun**\n */\nexport type GalleryApplicationScriptRebootBehavior = string;\n\n/** Known values of {@link StorageAccountType} that the service accepts. */\nexport enum KnownStorageAccountType {\n /** StandardLRS */\n StandardLRS = \"Standard_LRS\",\n /** StandardZRS */\n StandardZRS = \"Standard_ZRS\",\n /** PremiumLRS */\n PremiumLRS = \"Premium_LRS\",\n /** PremiumV2LRS */\n PremiumV2LRS = \"PremiumV2_LRS\",\n}\n\n/**\n * Defines values for StorageAccountType. \\\n * {@link KnownStorageAccountType} can be used interchangeably with StorageAccountType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS** \\\n * **Standard_ZRS** \\\n * **Premium_LRS** \\\n * **PremiumV2_LRS**\n */\nexport type StorageAccountType = string;\n\n/** Known values of {@link ConfidentialVMEncryptionType} that the service accepts. */\nexport enum KnownConfidentialVMEncryptionType {\n /** EncryptedVMGuestStateOnlyWithPmk */\n EncryptedVMGuestStateOnlyWithPmk = \"EncryptedVMGuestStateOnlyWithPmk\",\n /** EncryptedWithPmk */\n EncryptedWithPmk = \"EncryptedWithPmk\",\n /** EncryptedWithCmk */\n EncryptedWithCmk = \"EncryptedWithCmk\",\n /** NonPersistedTPM */\n NonPersistedTPM = \"NonPersistedTPM\",\n}\n\n/**\n * Defines values for ConfidentialVMEncryptionType. \\\n * {@link KnownConfidentialVMEncryptionType} can be used interchangeably with ConfidentialVMEncryptionType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EncryptedVMGuestStateOnlyWithPmk** \\\n * **EncryptedWithPmk** \\\n * **EncryptedWithCmk** \\\n * **NonPersistedTPM**\n */\nexport type ConfidentialVMEncryptionType = string;\n\n/** Known values of {@link ReplicationMode} that the service accepts. */\nexport enum KnownReplicationMode {\n /** Full */\n Full = \"Full\",\n /** Shallow */\n Shallow = \"Shallow\",\n}\n\n/**\n * Defines values for ReplicationMode. \\\n * {@link KnownReplicationMode} can be used interchangeably with ReplicationMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Full** \\\n * **Shallow**\n */\nexport type ReplicationMode = string;\n\n/** Known values of {@link GalleryExtendedLocationType} that the service accepts. */\nexport enum KnownGalleryExtendedLocationType {\n /** EdgeZone */\n EdgeZone = \"EdgeZone\",\n /** Unknown */\n Unknown = \"Unknown\",\n}\n\n/**\n * Defines values for GalleryExtendedLocationType. \\\n * {@link KnownGalleryExtendedLocationType} can be used interchangeably with GalleryExtendedLocationType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **EdgeZone** \\\n * **Unknown**\n */\nexport type GalleryExtendedLocationType = string;\n\n/** Known values of {@link EdgeZoneStorageAccountType} that the service accepts. */\nexport enum KnownEdgeZoneStorageAccountType {\n /** StandardLRS */\n StandardLRS = \"Standard_LRS\",\n /** StandardZRS */\n StandardZRS = \"Standard_ZRS\",\n /** StandardSSDLRS */\n StandardSSDLRS = \"StandardSSD_LRS\",\n /** PremiumLRS */\n PremiumLRS = \"Premium_LRS\",\n}\n\n/**\n * Defines values for EdgeZoneStorageAccountType. \\\n * {@link KnownEdgeZoneStorageAccountType} can be used interchangeably with EdgeZoneStorageAccountType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Standard_LRS** \\\n * **Standard_ZRS** \\\n * **StandardSSD_LRS** \\\n * **Premium_LRS**\n */\nexport type EdgeZoneStorageAccountType = string;\n\n/** Known values of {@link StorageAccountStrategy} that the service accepts. */\nexport enum KnownStorageAccountStrategy {\n /** Choose Standard_ZRS storage if the region supports it, else choose Standard_LRS storage, unless overridden by specifying regional storageAccountType. If no storageAccountStrategy is specified, this is the default strategy (from API version 2025-03-03 onwards). */\n PreferStandardZRS = \"PreferStandard_ZRS\",\n /** Choose Standard_LRS storage unless overridden by specifying regional storageAccountType. */\n DefaultStandardLRS = \"DefaultStandard_LRS\",\n}\n\n/**\n * Defines values for StorageAccountStrategy. \\\n * {@link KnownStorageAccountStrategy} can be used interchangeably with StorageAccountStrategy,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **PreferStandard_ZRS**: Choose Standard_ZRS storage if the region supports it, else choose Standard_LRS storage, unless overridden by specifying regional storageAccountType. If no storageAccountStrategy is specified, this is the default strategy (from API version 2025-03-03 onwards). \\\n * **DefaultStandard_LRS**: Choose Standard_LRS storage unless overridden by specifying regional storageAccountType.\n */\nexport type StorageAccountStrategy = string;\n\n/** Known values of {@link AggregatedReplicationState} that the service accepts. */\nexport enum KnownAggregatedReplicationState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** InProgress */\n InProgress = \"InProgress\",\n /** Completed */\n Completed = \"Completed\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for AggregatedReplicationState. \\\n * {@link KnownAggregatedReplicationState} can be used interchangeably with AggregatedReplicationState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **InProgress** \\\n * **Completed** \\\n * **Failed**\n */\nexport type AggregatedReplicationState = string;\n\n/** Known values of {@link ReplicationState} that the service accepts. */\nexport enum KnownReplicationState {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Replicating */\n Replicating = \"Replicating\",\n /** Completed */\n Completed = \"Completed\",\n /** Failed */\n Failed = \"Failed\",\n}\n\n/**\n * Defines values for ReplicationState. \\\n * {@link KnownReplicationState} can be used interchangeably with ReplicationState,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Replicating** \\\n * **Completed** \\\n * **Failed**\n */\nexport type ReplicationState = string;\n\n/** Known values of {@link ReplicationStatusTypes} that the service accepts. */\nexport enum KnownReplicationStatusTypes {\n /** ReplicationStatus */\n ReplicationStatus = \"ReplicationStatus\",\n /** UefiSettings */\n UefiSettings = \"UefiSettings\",\n}\n\n/**\n * Defines values for ReplicationStatusTypes. \\\n * {@link KnownReplicationStatusTypes} can be used interchangeably with ReplicationStatusTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **ReplicationStatus** \\\n * **UefiSettings**\n */\nexport type ReplicationStatusTypes = string;\n\n/** Known values of {@link PolicyViolationCategory} that the service accepts. */\nexport enum KnownPolicyViolationCategory {\n /** Other */\n Other = \"Other\",\n /** ImageFlaggedUnsafe */\n ImageFlaggedUnsafe = \"ImageFlaggedUnsafe\",\n /** CopyrightValidation */\n CopyrightValidation = \"CopyrightValidation\",\n /** IpTheft */\n IpTheft = \"IpTheft\",\n}\n\n/**\n * Defines values for PolicyViolationCategory. \\\n * {@link KnownPolicyViolationCategory} can be used interchangeably with PolicyViolationCategory,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Other** \\\n * **ImageFlaggedUnsafe** \\\n * **CopyrightValidation** \\\n * **IpTheft**\n */\nexport type PolicyViolationCategory = string;\n\n/** Known values of {@link ValidationStatus} that the service accepts. */\nexport enum KnownValidationStatus {\n /** Unknown */\n Unknown = \"Unknown\",\n /** Failed */\n Failed = \"Failed\",\n /** Succeeded */\n Succeeded = \"Succeeded\",\n}\n\n/**\n * Defines values for ValidationStatus. \\\n * {@link KnownValidationStatus} can be used interchangeably with ValidationStatus,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Unknown** \\\n * **Failed** \\\n * **Succeeded**\n */\nexport type ValidationStatus = string;\n\n/** Known values of {@link AccessControlRulesMode} that the service accepts. */\nexport enum KnownAccessControlRulesMode {\n /** Audit */\n Audit = \"Audit\",\n /** Enforce */\n Enforce = \"Enforce\",\n /** Disabled */\n Disabled = \"Disabled\",\n}\n\n/**\n * Defines values for AccessControlRulesMode. \\\n * {@link KnownAccessControlRulesMode} can be used interchangeably with AccessControlRulesMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Audit** \\\n * **Enforce** \\\n * **Disabled**\n */\nexport type AccessControlRulesMode = string;\n\n/** Known values of {@link EndpointAccess} that the service accepts. */\nexport enum KnownEndpointAccess {\n /** Allow */\n Allow = \"Allow\",\n /** Deny */\n Deny = \"Deny\",\n}\n\n/**\n * Defines values for EndpointAccess. \\\n * {@link KnownEndpointAccess} can be used interchangeably with EndpointAccess,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Allow** \\\n * **Deny**\n */\nexport type EndpointAccess = string;\n\n/** Known values of {@link GalleryScriptParameterType} that the service accepts. */\nexport enum KnownGalleryScriptParameterType {\n /** String gallery script parameter type */\n String = \"String\",\n /** Int gallery script parameter type */\n Int = \"Int\",\n /** Double gallery script parameter type */\n Double = \"Double\",\n /** Boolean gallery script parameter type */\n Boolean = \"Boolean\",\n /** Enum gallery script parameter type */\n Enum = \"Enum\",\n}\n\n/**\n * Defines values for GalleryScriptParameterType. \\\n * {@link KnownGalleryScriptParameterType} can be used interchangeably with GalleryScriptParameterType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **String**: String gallery script parameter type \\\n * **Int**: Int gallery script parameter type \\\n * **Double**: Double gallery script parameter type \\\n * **Boolean**: Boolean gallery script parameter type \\\n * **Enum**: Enum gallery script parameter type\n */\nexport type GalleryScriptParameterType = string;\n\n/** Known values of {@link SharingUpdateOperationTypes} that the service accepts. */\nexport enum KnownSharingUpdateOperationTypes {\n /** Add */\n Add = \"Add\",\n /** Remove */\n Remove = \"Remove\",\n /** Reset */\n Reset = \"Reset\",\n /** EnableCommunity */\n EnableCommunity = \"EnableCommunity\",\n}\n\n/**\n * Defines values for SharingUpdateOperationTypes. \\\n * {@link KnownSharingUpdateOperationTypes} can be used interchangeably with SharingUpdateOperationTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Add** \\\n * **Remove** \\\n * **Reset** \\\n * **EnableCommunity**\n */\nexport type SharingUpdateOperationTypes = string;\n\n/** Known values of {@link SoftDeletedArtifactTypes} that the service accepts. */\nexport enum KnownSoftDeletedArtifactTypes {\n /** Images */\n Images = \"Images\",\n}\n\n/**\n * Defines values for SoftDeletedArtifactTypes. \\\n * {@link KnownSoftDeletedArtifactTypes} can be used interchangeably with SoftDeletedArtifactTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Images**\n */\nexport type SoftDeletedArtifactTypes = string;\n\n/** Known values of {@link CloudServiceUpgradeMode} that the service accepts. */\nexport enum KnownCloudServiceUpgradeMode {\n /** Auto */\n Auto = \"Auto\",\n /** Manual */\n Manual = \"Manual\",\n /** Simultaneous */\n Simultaneous = \"Simultaneous\",\n}\n\n/**\n * Defines values for CloudServiceUpgradeMode. \\\n * {@link KnownCloudServiceUpgradeMode} can be used interchangeably with CloudServiceUpgradeMode,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Auto** \\\n * **Manual** \\\n * **Simultaneous**\n */\nexport type CloudServiceUpgradeMode = string;\n\n/** Known values of {@link CloudServiceSlotType} that the service accepts. */\nexport enum KnownCloudServiceSlotType {\n /** Production */\n Production = \"Production\",\n /** Staging */\n Staging = \"Staging\",\n}\n\n/**\n * Defines values for CloudServiceSlotType. \\\n * {@link KnownCloudServiceSlotType} can be used interchangeably with CloudServiceSlotType,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Production** \\\n * **Staging**\n */\nexport type CloudServiceSlotType = string;\n\n/** Known values of {@link AvailabilitySetSkuTypes} that the service accepts. */\nexport enum KnownAvailabilitySetSkuTypes {\n /** Classic */\n Classic = \"Classic\",\n /** Aligned */\n Aligned = \"Aligned\",\n}\n\n/**\n * Defines values for AvailabilitySetSkuTypes. \\\n * {@link KnownAvailabilitySetSkuTypes} can be used interchangeably with AvailabilitySetSkuTypes,\n * this enum contains the known values that the service supports.\n * ### Known values supported by the service\n * **Classic** \\\n * **Aligned**\n */\nexport type AvailabilitySetSkuTypes = string;\n/** Defines values for StatusLevelTypes. */\nexport type StatusLevelTypes = \"Info\" | \"Warning\" | \"Error\";\n/** Defines values for OperatingSystemTypes. */\nexport type OperatingSystemTypes = \"Windows\" | \"Linux\";\n/** Defines values for OperatingSystemStateTypes. */\nexport type OperatingSystemStateTypes = \"Generalized\" | \"Specialized\";\n/** Defines values for CachingTypes. */\nexport type CachingTypes = \"None\" | \"ReadOnly\" | \"ReadWrite\";\n/** Defines values for IntervalInMins. */\nexport type IntervalInMins = \"ThreeMins\" | \"FiveMins\" | \"ThirtyMins\" | \"SixtyMins\";\n/** Defines values for UpgradeMode. */\nexport type UpgradeMode = \"Automatic\" | \"Manual\" | \"Rolling\";\n/** Defines values for SettingNames. */\nexport type SettingNames = \"AutoLogon\" | \"FirstLogonCommands\";\n/** Defines values for ProtocolTypes. */\nexport type ProtocolTypes = \"Http\" | \"Https\";\n/** Defines values for ResourceIdentityType. */\nexport type ResourceIdentityType =\n | \"SystemAssigned\"\n | \"UserAssigned\"\n | \"SystemAssigned, UserAssigned\"\n | \"None\";\n/** Defines values for MaintenanceOperationResultCodeTypes. */\nexport type MaintenanceOperationResultCodeTypes =\n | \"None\"\n | \"RetryLater\"\n | \"MaintenanceAborted\"\n | \"MaintenanceCompleted\";\n/** Defines values for InstanceViewTypes. */\nexport type InstanceViewTypes = \"instanceView\" | \"userData\" | \"resiliencyView\";\n/** Defines values for DedicatedHostLicenseTypes. */\nexport type DedicatedHostLicenseTypes =\n | \"None\"\n | \"Windows_Server_Hybrid\"\n | \"Windows_Server_Perpetual\";\n/** Defines values for UpgradeState. */\nexport type UpgradeState = \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n/** Defines values for UpgradeOperationInvoker. */\nexport type UpgradeOperationInvoker = \"Unknown\" | \"User\" | \"Platform\";\n/** Defines values for RollingUpgradeStatusCode. */\nexport type RollingUpgradeStatusCode = \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n/** Defines values for RollingUpgradeActionType. */\nexport type RollingUpgradeActionType = \"Start\" | \"Cancel\";\n/** Defines values for VirtualMachineScaleSetSkuScaleType. */\nexport type VirtualMachineScaleSetSkuScaleType = \"Automatic\" | \"None\";\n/** Defines values for ResourceSkuCapacityScaleType. */\nexport type ResourceSkuCapacityScaleType = \"Automatic\" | \"Manual\" | \"None\";\n/** Defines values for ResourceSkuRestrictionsType. */\nexport type ResourceSkuRestrictionsType = \"Location\" | \"Zone\";\n/** Defines values for ResourceSkuRestrictionsReasonCode. */\nexport type ResourceSkuRestrictionsReasonCode = \"QuotaId\" | \"NotAvailableForSubscription\";\n/** Defines values for GalleryApplicationCustomActionParameterType. */\nexport type GalleryApplicationCustomActionParameterType =\n | \"String\"\n | \"ConfigurationDataBlob\"\n | \"LogOutputBlob\";\n/** Defines values for HostCaching. */\nexport type HostCaching = \"None\" | \"ReadOnly\" | \"ReadWrite\";\n/** Defines values for EndpointTypes. */\nexport type EndpointTypes = \"WireServer\" | \"IMDS\";\n\n/** Optional parameters. */\nexport interface OperationsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type OperationsListResponse = OperationListResult;\n\n/** Optional parameters. */\nexport interface OperationsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type OperationsListNextResponse = OperationListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. Allowed values are 'instanceView'. */\n expand?: string;\n}\n\n/** Contains response data for the listBySubscription operation. */\nexport type AvailabilitySetsListBySubscriptionResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type AvailabilitySetsListResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type AvailabilitySetsGetResponse = AvailabilitySet;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type AvailabilitySetsCreateOrUpdateResponse = AvailabilitySet;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type AvailabilitySetsUpdateResponse = AvailabilitySet;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsCancelMigrationToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsConvertToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {\n /** Parameters supplied to the migrate operation on the availability set. */\n parameters?: ConvertToVirtualMachineScaleSetInput;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the convertToVirtualMachineScaleSet operation. */\nexport type AvailabilitySetsConvertToVirtualMachineScaleSetResponse =\n AvailabilitySetsConvertToVirtualMachineScaleSetHeaders;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsStartMigrationToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsValidateMigrationToVirtualMachineScaleSetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListAvailableSizesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizes operation. */\nexport type AvailabilitySetsListAvailableSizesResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type AvailabilitySetsListBySubscriptionNextResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type AvailabilitySetsListNextResponse = AvailabilitySetListResult;\n\n/** Optional parameters. */\nexport interface AvailabilitySetsListAvailableSizesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizesNext operation. */\nexport type AvailabilitySetsListAvailableSizesNextResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. Based on the expand param(s) specified we return Virtual Machine or ScaleSet VM Instance or both resource Ids which are associated to capacity reservation group in the response. */\n expand?: ExpandTypesForGetCapacityReservationGroups;\n /** The query option to fetch Capacity Reservation Group Resource Ids. <br> 'CreatedInSubscription' enables fetching Resource Ids for all capacity reservation group resources created in the subscription. <br> 'SharedWithSubscription' enables fetching Resource Ids for all capacity reservation group resources shared with the subscription. <br> 'All' enables fetching Resource Ids for all capacity reservation group resources shared with the subscription and created in the subscription. */\n resourceIdsOnly?: ResourceIdOptionsForGetCapacityReservationGroups;\n}\n\n/** Contains response data for the listBySubscription operation. */\nexport type CapacityReservationGroupsListBySubscriptionResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. Based on the expand param(s) specified we return Virtual Machine or ScaleSet VM Instance or both resource Ids which are associated to capacity reservation group in the response. */\n expand?: ExpandTypesForGetCapacityReservationGroups;\n}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type CapacityReservationGroupsListByResourceGroupResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the list of instance views of the capacity reservations under the capacity reservation group which is a snapshot of the runtime properties of a capacity reservation that is managed by the platform and can change outside of control plane operations. */\n expand?: CapacityReservationGroupInstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type CapacityReservationGroupsGetResponse = CapacityReservationGroup;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type CapacityReservationGroupsCreateOrUpdateResponse = CapacityReservationGroup;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type CapacityReservationGroupsUpdateResponse = CapacityReservationGroup;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsDeleteOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type CapacityReservationGroupsListBySubscriptionNextResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationGroupsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type CapacityReservationGroupsListByResourceGroupNextResponse =\n CapacityReservationGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscription operation. */\nexport type DedicatedHostGroupsListBySubscriptionResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DedicatedHostGroupsListByResourceGroupResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the list of instance views of the dedicated hosts under the dedicated host group. 'UserData' is not supported for dedicated host group. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type DedicatedHostGroupsGetResponse = DedicatedHostGroup;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DedicatedHostGroupsCreateOrUpdateResponse = DedicatedHostGroup;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type DedicatedHostGroupsUpdateResponse = DedicatedHostGroup;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type DedicatedHostGroupsListBySubscriptionNextResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostGroupsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DedicatedHostGroupsListByResourceGroupNextResponse = DedicatedHostGroupListResult;\n\n/** Optional parameters. */\nexport interface ImagesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type ImagesListResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface ImagesListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type ImagesListByResourceGroupResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface ImagesGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type ImagesGetResponse = Image;\n\n/** Optional parameters. */\nexport interface ImagesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type ImagesCreateOrUpdateResponse = Image;\n\n/** Optional parameters. */\nexport interface ImagesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type ImagesUpdateResponse = Image;\n\n/** Optional parameters. */\nexport interface ImagesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface ImagesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type ImagesListNextResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface ImagesListByResourceGroupNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type ImagesListByResourceGroupNextResponse = ImageListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListPublishersOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPublishers operation. */\nexport type VirtualMachineImagesEdgeZoneListPublishersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListOffersOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOffers operation. */\nexport type VirtualMachineImagesEdgeZoneListOffersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListSkusOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkus operation. */\nexport type VirtualMachineImagesEdgeZoneListSkusResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneListOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineImagesEdgeZoneListResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesEdgeZoneGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineImagesEdgeZoneGetResponse = VirtualMachineImage;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListByEdgeZoneOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByEdgeZone operation. */\nexport type VirtualMachineImagesListByEdgeZoneResponse = VmImagesInEdgeZoneListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListPublishersOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPublishers operation. */\nexport type VirtualMachineImagesListPublishersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListOffersOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOffers operation. */\nexport type VirtualMachineImagesListOffersResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListSkusOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkus operation. */\nexport type VirtualMachineImagesListSkusResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineImagesListResponse = VirtualMachineImageResource[];\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineImagesGetResponse = VirtualMachineImage;\n\n/** Optional parameters. */\nexport interface VirtualMachineImagesListWithPropertiesOptionalParams\n extends coreClient.OperationOptions {\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n}\n\n/** Contains response data for the listWithProperties operation. */\nexport type VirtualMachineImagesListWithPropertiesResponse = VirtualMachineImage[];\n\n/** Optional parameters. */\nexport interface LogAnalyticsExportRequestRateByIntervalOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the exportRequestRateByInterval operation. */\nexport type LogAnalyticsExportRequestRateByIntervalResponse = LogAnalyticsOperationResult;\n\n/** Optional parameters. */\nexport interface LogAnalyticsExportThrottledRequestsOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the exportThrottledRequests operation. */\nexport type LogAnalyticsExportThrottledRequestsResponse = LogAnalyticsOperationResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionImagesListTypesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listTypes operation. */\nexport type VirtualMachineExtensionImagesListTypesResponse = VirtualMachineExtensionImage[];\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionImagesListVersionsOptionalParams\n extends coreClient.OperationOptions {\n /** An integer value specifying the number of images to return that matches supplied values. */\n top?: number;\n /** Specifies the order of the results returned. Formatted as an OData query. */\n orderby?: string;\n /** The filter to apply on the operation. */\n filter?: string;\n}\n\n/** Contains response data for the listVersions operation. */\nexport type VirtualMachineExtensionImagesListVersionsResponse = VirtualMachineExtensionImage[];\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionImagesGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineExtensionImagesGetResponse = VirtualMachineExtensionImage;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineRunCommandsListResponse = RunCommandListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineRunCommandsGetResponse = RunCommandDocument;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListByVirtualMachineOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the listByVirtualMachine operation. */\nexport type VirtualMachineRunCommandsListByVirtualMachineResponse =\n VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsGetByVirtualMachineOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the getByVirtualMachine operation. */\nexport type VirtualMachineRunCommandsGetByVirtualMachineResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineRunCommandsCreateOrUpdateResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineRunCommandsUpdateResponse = VirtualMachineRunCommandsUpdateHeaders &\n VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineRunCommandsListNextResponse = RunCommandListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineRunCommandsListByVirtualMachineNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByVirtualMachineNext operation. */\nexport type VirtualMachineRunCommandsListByVirtualMachineNextResponse =\n VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface UsageListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type UsageListResponse = ListUsagesResult;\n\n/** Optional parameters. */\nexport interface UsageListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type UsageListNextResponse = ListUsagesResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListByLocationOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocation operation. */\nexport type VirtualMachineScaleSetsListByLocationResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListAllOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAll operation. */\nexport type VirtualMachineScaleSetsListAllResponse = VirtualMachineScaleSetListWithLinkResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetsListResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'UserData' retrieves the UserData property of the VM scale set that was provided by the user during the VM scale set Create/Update operation */\n expand?: ExpandTypesForGetVMScaleSets;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetsGetResponse = VirtualMachineScaleSet;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetsCreateOrUpdateResponse = VirtualMachineScaleSet;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetsUpdateResponse = VirtualMachineScaleSetsUpdateHeaders &\n VirtualMachineScaleSet;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to force delete a VM scale set. (Feature in Preview) */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsApproveRollingUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the approveRollingUpgrade operation. */\nexport type VirtualMachineScaleSetsApproveRollingUpgradeResponse =\n VirtualMachineScaleSetsApproveRollingUpgradeHeaders;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsConvertToSinglePlacementGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsDeallocateOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Optional parameter to hibernate a virtual machine from the VM scale set. (This feature is available for VMSS with Flexible OrchestrationMode only) */\n hibernate?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsDeleteInstancesOptionalParams\n extends coreClient.OperationOptions {\n /** Optional parameter to force delete virtual machines from the VM scale set. (Feature in Preview) */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsForceRecoveryServiceFabricPlatformUpdateDomainWalkOptionalParams\n extends coreClient.OperationOptions {\n /** The zone in which the manual recovery walk is requested for cross zone virtual machine scale set */\n zone?: string;\n /** The placement group id for which the manual recovery walk is requested. */\n placementGroupId?: string;\n}\n\n/** Contains response data for the forceRecoveryServiceFabricPlatformUpdateDomainWalk operation. */\nexport type VirtualMachineScaleSetsForceRecoveryServiceFabricPlatformUpdateDomainWalkResponse =\n RecoveryWalkResponse;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetInstanceViewOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type VirtualMachineScaleSetsGetInstanceViewResponse = VirtualMachineScaleSetInstanceView;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsUpdateInstancesOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetOSUpgradeHistoryOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSUpgradeHistory operation. */\nexport type VirtualMachineScaleSetsGetOSUpgradeHistoryResponse =\n VirtualMachineScaleSetListOSUpgradeHistory;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsPerformMaintenanceOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsPowerOffOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified */\n skipShutdown?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsReapplyOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsRedeployOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsReimageOptionalParams extends coreClient.OperationOptions {\n /** Parameters for Reimaging VM ScaleSet. */\n vmScaleSetReimageInput?: VirtualMachineScaleSetReimageParameters;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsReimageAllOptionalParams\n extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsRestartOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsScaleOutOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsSetOrchestrationServiceStateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListSkusOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkus operation. */\nexport type VirtualMachineScaleSetsListSkusResponse = VirtualMachineScaleSetListSkusResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsStartOptionalParams extends coreClient.OperationOptions {\n /** A list of virtual machine instance IDs from the VM scale set. */\n vmInstanceIDs?: VirtualMachineScaleSetVMInstanceIDs;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListByLocationNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocationNext operation. */\nexport type VirtualMachineScaleSetsListByLocationNextResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListAllNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type VirtualMachineScaleSetsListAllNextResponse = VirtualMachineScaleSetListWithLinkResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetsListNextResponse = VirtualMachineScaleSetListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsGetOSUpgradeHistoryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSUpgradeHistoryNext operation. */\nexport type VirtualMachineScaleSetsGetOSUpgradeHistoryNextResponse =\n VirtualMachineScaleSetListOSUpgradeHistory;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetsListSkusNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listSkusNext operation. */\nexport type VirtualMachineScaleSetsListSkusNextResponse = VirtualMachineScaleSetListSkusResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListByLocationOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocation operation. */\nexport type VirtualMachinesListByLocationResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAllOptionalParams extends coreClient.OperationOptions {\n /** The system query option to filter VMs returned in the response. Allowed value is 'virtualMachineScaleSet/id' eq /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{vmssName}' */\n filter?: string;\n /** statusOnly=true enables fetching run time status of all Virtual Machines in the subscription. */\n statusOnly?: string;\n /** The expand expression to apply on operation. 'instanceView' enables fetching run time status of all Virtual Machines, this can only be specified if a valid $filter option is specified */\n expand?: ExpandTypesForListVMs;\n}\n\n/** Contains response data for the listAll operation. */\nexport type VirtualMachinesListAllResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListOptionalParams extends coreClient.OperationOptions {\n /** The system query option to filter VMs returned in the response. Allowed value is 'virtualMachineScaleSet/id' eq /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{vmssName}' */\n filter?: string;\n /** The expand expression to apply on operation. 'instanceView' enables fetching run time status of all Virtual Machines, this can only be specified if a valid $filter option is specified */\n expand?: ExpandTypeForListVMs;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachinesListResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' retrieves a snapshot of the runtime properties of the virtual machine that is managed by the platform and can change outside of control plane operations. 'UserData' retrieves the UserData property as part of the VM model view that was provided by the user during the VM Create/Update operation. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachinesGetResponse = VirtualMachine;\n\n/** Optional parameters. */\nexport interface VirtualMachinesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachinesCreateOrUpdateResponse = VirtualMachine;\n\n/** Optional parameters. */\nexport interface VirtualMachinesUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachinesUpdateResponse = VirtualMachinesUpdateHeaders & VirtualMachine;\n\n/** Optional parameters. */\nexport interface VirtualMachinesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to force delete virtual machines. */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesAssessPatchesOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the assessPatches operation. */\nexport type VirtualMachinesAssessPatchesResponse = VirtualMachineAssessPatchesResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesAttachDetachDataDisksOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the attachDetachDataDisks operation. */\nexport type VirtualMachinesAttachDetachDataDisksResponse = StorageProfile;\n\n/** Optional parameters. */\nexport interface VirtualMachinesCaptureOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the capture operation. */\nexport type VirtualMachinesCaptureResponse = VirtualMachineCaptureResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesConvertToManagedDisksOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesDeallocateOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to hibernate a virtual machine. */\n hibernate?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesGeneralizeOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachinesInstallPatchesOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the installPatches operation. */\nexport type VirtualMachinesInstallPatchesResponse = VirtualMachineInstallPatchesResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesInstanceViewOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the instanceView operation. */\nexport type VirtualMachinesInstanceViewResponse = VirtualMachineInstanceView;\n\n/** Optional parameters. */\nexport interface VirtualMachinesMigrateToVMScaleSetOptionalParams\n extends coreClient.OperationOptions {\n /** Parameters supplied to the Migrate Virtual Machine operation. */\n parameters?: MigrateVMToVirtualMachineScaleSetInput;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the migrateToVMScaleSet operation. */\nexport type VirtualMachinesMigrateToVMScaleSetResponse = VirtualMachinesMigrateToVMScaleSetHeaders;\n\n/** Optional parameters. */\nexport interface VirtualMachinesPerformMaintenanceOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesPowerOffOptionalParams extends coreClient.OperationOptions {\n /** The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified */\n skipShutdown?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesReapplyOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesRedeployOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesReimageOptionalParams extends coreClient.OperationOptions {\n /** Parameters supplied to the Reimage Virtual Machine operation. */\n parameters?: VirtualMachineReimageParameters;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesRestartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesRetrieveBootDiagnosticsDataOptionalParams\n extends coreClient.OperationOptions {\n /** Expiration duration in minutes for the SAS URIs with a value between 1 to 1440 minutes. **Note:** If not specified, SAS URIs will be generated with a default expiration duration of 120 minutes. */\n sasUriExpirationTimeInMinutes?: number;\n}\n\n/** Contains response data for the retrieveBootDiagnosticsData operation. */\nexport type VirtualMachinesRetrieveBootDiagnosticsDataResponse = RetrieveBootDiagnosticsDataResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesRunCommandOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the runCommand operation. */\nexport type VirtualMachinesRunCommandResponse = RunCommandResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesSimulateEvictionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachinesStartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAvailableSizesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizes operation. */\nexport type VirtualMachinesListAvailableSizesResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListByLocationNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByLocationNext operation. */\nexport type VirtualMachinesListByLocationNextResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAllNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type VirtualMachinesListAllNextResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachinesListNextResponse = VirtualMachineListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachinesListAvailableSizesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizesNext operation. */\nexport type VirtualMachinesListAvailableSizesNextResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineSizesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineSizesListResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineSizesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineSizesListNextResponse = VirtualMachineSizeListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscription operation. */\nexport type ProximityPlacementGroupsListBySubscriptionResponse = ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type ProximityPlacementGroupsListByResourceGroupResponse = ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsGetOptionalParams extends coreClient.OperationOptions {\n /** includeColocationStatus=true enables fetching the colocation status of all the resources in the proximity placement group. */\n includeColocationStatus?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type ProximityPlacementGroupsGetResponse = ProximityPlacementGroup;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type ProximityPlacementGroupsCreateOrUpdateResponse = ProximityPlacementGroup;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type ProximityPlacementGroupsUpdateResponse = ProximityPlacementGroup;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type ProximityPlacementGroupsListBySubscriptionNextResponse =\n ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface ProximityPlacementGroupsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type ProximityPlacementGroupsListByResourceGroupNextResponse =\n ProximityPlacementGroupListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListAllOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAll operation. */\nexport type RestorePointCollectionsListAllResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type RestorePointCollectionsListResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. If expand=restorePoints, server will return all contained restore points in the restorePointCollection. */\n expand?: RestorePointCollectionExpandOptions;\n}\n\n/** Contains response data for the get operation. */\nexport type RestorePointCollectionsGetResponse = RestorePointCollection;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type RestorePointCollectionsCreateOrUpdateResponse = RestorePointCollection;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type RestorePointCollectionsUpdateResponse = RestorePointCollection;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListAllNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type RestorePointCollectionsListAllNextResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface RestorePointCollectionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type RestorePointCollectionsListNextResponse = RestorePointCollectionListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListBySubscriptionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscription operation. */\nexport type SshPublicKeysListBySubscriptionResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type SshPublicKeysListByResourceGroupResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SshPublicKeysGetResponse = SshPublicKeyResource;\n\n/** Optional parameters. */\nexport interface SshPublicKeysCreateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the create operation. */\nexport type SshPublicKeysCreateResponse = SshPublicKeyResource;\n\n/** Optional parameters. */\nexport interface SshPublicKeysUpdateOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the update operation. */\nexport type SshPublicKeysUpdateResponse = SshPublicKeyResource;\n\n/** Optional parameters. */\nexport interface SshPublicKeysDeleteOptionalParams extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface SshPublicKeysGenerateKeyPairOptionalParams extends coreClient.OperationOptions {\n /** Parameters supplied to generate the SSH public key. */\n parameters?: SshGenerateKeyPairInputParameters;\n}\n\n/** Contains response data for the generateKeyPair operation. */\nexport type SshPublicKeysGenerateKeyPairResponse = SshPublicKeyGenerateKeyPairResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListBySubscriptionNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listBySubscriptionNext operation. */\nexport type SshPublicKeysListBySubscriptionNextResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface SshPublicKeysListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type SshPublicKeysListByResourceGroupNextResponse = SshPublicKeysGroupListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationsListByCapacityReservationGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByCapacityReservationGroup operation. */\nexport type CapacityReservationsListByCapacityReservationGroupResponse =\n CapacityReservationListResult;\n\n/** Optional parameters. */\nexport interface CapacityReservationsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' retrieves a snapshot of the runtime properties of the capacity reservation that is managed by the platform and can change outside of control plane operations. */\n expand?: CapacityReservationInstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type CapacityReservationsGetResponse = CapacityReservation;\n\n/** Optional parameters. */\nexport interface CapacityReservationsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type CapacityReservationsCreateOrUpdateResponse = CapacityReservation;\n\n/** Optional parameters. */\nexport interface CapacityReservationsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type CapacityReservationsUpdateResponse = CapacityReservation;\n\n/** Optional parameters. */\nexport interface CapacityReservationsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CapacityReservationsListByCapacityReservationGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByCapacityReservationGroupNext operation. */\nexport type CapacityReservationsListByCapacityReservationGroupNextResponse =\n CapacityReservationListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsListByHostGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByHostGroup operation. */\nexport type DedicatedHostsListByHostGroupResponse = DedicatedHostListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the list of instance views of the dedicated host. 'UserData' is not supported for dedicated host. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type DedicatedHostsGetResponse = DedicatedHost;\n\n/** Optional parameters. */\nexport interface DedicatedHostsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DedicatedHostsCreateOrUpdateResponse = DedicatedHost;\n\n/** Optional parameters. */\nexport interface DedicatedHostsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DedicatedHostsUpdateResponse = DedicatedHostsUpdateHeaders & DedicatedHost;\n\n/** Optional parameters. */\nexport interface DedicatedHostsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DedicatedHostsListAvailableSizesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizes operation. */\nexport type DedicatedHostsListAvailableSizesResponse = DedicatedHostSizeListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsRedeployOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the redeploy operation. */\nexport type DedicatedHostsRedeployResponse = DedicatedHostsRedeployHeaders;\n\n/** Optional parameters. */\nexport interface DedicatedHostsRestartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the restart operation. */\nexport type DedicatedHostsRestartResponse = DedicatedHostsRestartHeaders;\n\n/** Optional parameters. */\nexport interface DedicatedHostsListByHostGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByHostGroupNext operation. */\nexport type DedicatedHostsListByHostGroupNextResponse = DedicatedHostListResult;\n\n/** Optional parameters. */\nexport interface DedicatedHostsListAvailableSizesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAvailableSizesNext operation. */\nexport type DedicatedHostsListAvailableSizesNextResponse = DedicatedHostSizeListResult;\n\n/** Optional parameters. */\nexport interface RestorePointsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' retrieves information about the run-time state of a restore point. */\n expand?: RestorePointExpandOptions;\n}\n\n/** Contains response data for the get operation. */\nexport type RestorePointsGetResponse = RestorePoint;\n\n/** Optional parameters. */\nexport interface RestorePointsCreateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the create operation. */\nexport type RestorePointsCreateResponse = RestorePointsCreateHeaders & RestorePoint;\n\n/** Optional parameters. */\nexport interface RestorePointsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartExtensionUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesStartOSUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesCancelOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetRollingUpgradesGetLatestOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getLatest operation. */\nexport type VirtualMachineScaleSetRollingUpgradesGetLatestResponse = RollingUpgradeStatusInfo;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsListOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetExtensionsListResponse =\n VirtualMachineScaleSetExtensionListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsGetOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetExtensionsGetResponse = VirtualMachineScaleSetExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetExtensionsCreateOrUpdateResponse =\n VirtualMachineScaleSetExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetExtensionsUpdateResponse = VirtualMachineScaleSetExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetExtensionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetExtensionsListNextResponse =\n VirtualMachineScaleSetExtensionListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. Allowed values are 'instanceView'. */\n expand?: string;\n /** The filter to apply to the operation. Allowed values are 'startswith(instanceView/statuses/code, 'PowerState') eq true', 'properties/latestModelApplied eq true', 'properties/latestModelApplied eq false'. */\n filter?: string;\n /** The list parameters. Allowed values are 'instanceView', 'instanceView/statuses'. */\n select?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetVMsListResponse = VirtualMachineScaleSetVMListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. 'InstanceView' will retrieve the instance view of the virtual machine. 'UserData' will retrieve the UserData of the virtual machine. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetVMsGetResponse = VirtualMachineScaleSetVM;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsUpdateOptionalParams extends coreClient.OperationOptions {\n /** The ETag of the transformation. Omit this value to always overwrite the current resource. Specify the last-seen ETag value to prevent accidentally overwriting concurrent changes. */\n ifMatch?: string;\n /** Set to '*' to allow a new record set to be created, but to prevent updating an existing record set. Other values will result in error from server as they are not supported. */\n ifNoneMatch?: string;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetVMsUpdateResponse = VirtualMachineScaleSetVM;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Optional parameter to force delete a virtual machine from a VM scale set. (Feature in Preview) */\n forceDeletion?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsApproveRollingUpgradeOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the approveRollingUpgrade operation. */\nexport type VirtualMachineScaleSetVMsApproveRollingUpgradeResponse =\n VirtualMachineScaleSetVMsApproveRollingUpgradeHeaders;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsAttachDetachDataDisksOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the attachDetachDataDisks operation. */\nexport type VirtualMachineScaleSetVMsAttachDetachDataDisksResponse = StorageProfile;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsDeallocateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsGetInstanceViewOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type VirtualMachineScaleSetVMsGetInstanceViewResponse = VirtualMachineScaleSetVMInstanceView;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsPerformMaintenanceOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsPowerOffOptionalParams\n extends coreClient.OperationOptions {\n /** The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified */\n skipShutdown?: boolean;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRedeployOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsReimageOptionalParams\n extends coreClient.OperationOptions {\n /** Parameters for the Reimaging Virtual machine in ScaleSet. */\n vmScaleSetVMReimageInput?: VirtualMachineScaleSetVMReimageParameters;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsReimageAllOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRestartOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRetrieveBootDiagnosticsDataOptionalParams\n extends coreClient.OperationOptions {\n /** Expiration duration in minutes for the SAS URIs with a value between 1 to 1440 minutes. **Note:** If not specified, SAS URIs will be generated with a default expiration duration of 120 minutes. */\n sasUriExpirationTimeInMinutes?: number;\n}\n\n/** Contains response data for the retrieveBootDiagnosticsData operation. */\nexport type VirtualMachineScaleSetVMsRetrieveBootDiagnosticsDataResponse =\n RetrieveBootDiagnosticsDataResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsRunCommandOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the runCommand operation. */\nexport type VirtualMachineScaleSetVMsRunCommandResponse = RunCommandResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsSimulateEvictionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsStartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetVMsListNextResponse = VirtualMachineScaleSetVMListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsListOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetVMExtensionsListResponse =\n VirtualMachineScaleSetVMExtensionsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsGetOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetVMExtensionsGetResponse = VirtualMachineScaleSetVMExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetVMExtensionsCreateOrUpdateResponse =\n VirtualMachineScaleSetVMExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetVMExtensionsUpdateResponse =\n VirtualMachineScaleSetVMExtensionsUpdateHeaders & VirtualMachineScaleSetVMExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMExtensionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsListOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineScaleSetVMRunCommandsListResponse = VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsGetOptionalParams\n extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineScaleSetVMRunCommandsGetResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineScaleSetVMRunCommandsCreateOrUpdateResponse = VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineScaleSetVMRunCommandsUpdateResponse =\n VirtualMachineScaleSetVMRunCommandsUpdateHeaders & VirtualMachineRunCommand;\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface VirtualMachineScaleSetVMRunCommandsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type VirtualMachineScaleSetVMRunCommandsListNextResponse =\n VirtualMachineRunCommandsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type VirtualMachineExtensionsListResponse = VirtualMachineExtensionsListResult;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: string;\n}\n\n/** Contains response data for the get operation. */\nexport type VirtualMachineExtensionsGetResponse = VirtualMachineExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type VirtualMachineExtensionsCreateOrUpdateResponse = VirtualMachineExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type VirtualMachineExtensionsUpdateResponse = VirtualMachineExtensionsUpdateHeaders &\n VirtualMachineExtension;\n\n/** Optional parameters. */\nexport interface VirtualMachineExtensionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskAccessesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type DiskAccessesListResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DiskAccessesListByResourceGroupResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DiskAccessesGetResponse = DiskAccess;\n\n/** Optional parameters. */\nexport interface DiskAccessesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DiskAccessesCreateOrUpdateResponse = DiskAccess;\n\n/** Optional parameters. */\nexport interface DiskAccessesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DiskAccessesUpdateResponse = DiskAccess;\n\n/** Optional parameters. */\nexport interface DiskAccessesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskAccessesListPrivateEndpointConnectionsOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPrivateEndpointConnections operation. */\nexport type DiskAccessesListPrivateEndpointConnectionsResponse =\n PrivateEndpointConnectionListResult;\n\n/** Optional parameters. */\nexport interface DiskAccessesGetAPrivateEndpointConnectionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getAPrivateEndpointConnection operation. */\nexport type DiskAccessesGetAPrivateEndpointConnectionResponse = PrivateEndpointConnection;\n\n/** Optional parameters. */\nexport interface DiskAccessesUpdateAPrivateEndpointConnectionOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the updateAPrivateEndpointConnection operation. */\nexport type DiskAccessesUpdateAPrivateEndpointConnectionResponse = PrivateEndpointConnection;\n\n/** Optional parameters. */\nexport interface DiskAccessesDeleteAPrivateEndpointConnectionOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskAccessesGetPrivateLinkResourcesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getPrivateLinkResources operation. */\nexport type DiskAccessesGetPrivateLinkResourcesResponse = PrivateLinkResourceListResult;\n\n/** Optional parameters. */\nexport interface DiskAccessesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type DiskAccessesListNextResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DiskAccessesListByResourceGroupNextResponse = DiskAccessList;\n\n/** Optional parameters. */\nexport interface DiskAccessesListPrivateEndpointConnectionsNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listPrivateEndpointConnectionsNext operation. */\nexport type DiskAccessesListPrivateEndpointConnectionsNextResponse =\n PrivateEndpointConnectionListResult;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type DiskEncryptionSetsListResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListByResourceGroupOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DiskEncryptionSetsListByResourceGroupResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DiskEncryptionSetsGetResponse = DiskEncryptionSet;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DiskEncryptionSetsCreateOrUpdateResponse = DiskEncryptionSet;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DiskEncryptionSetsUpdateResponse = DiskEncryptionSet;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListAssociatedResourcesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAssociatedResources operation. */\nexport type DiskEncryptionSetsListAssociatedResourcesResponse = ResourceUriList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type DiskEncryptionSetsListNextResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DiskEncryptionSetsListByResourceGroupNextResponse = DiskEncryptionSetList;\n\n/** Optional parameters. */\nexport interface DiskEncryptionSetsListAssociatedResourcesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAssociatedResourcesNext operation. */\nexport type DiskEncryptionSetsListAssociatedResourcesNextResponse = ResourceUriList;\n\n/** Optional parameters. */\nexport interface DisksListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type DisksListResponse = DiskList;\n\n/** Optional parameters. */\nexport interface DisksListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type DisksListByResourceGroupResponse = DiskList;\n\n/** Optional parameters. */\nexport interface DisksGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DisksGetResponse = Disk;\n\n/** Optional parameters. */\nexport interface DisksCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type DisksCreateOrUpdateResponse = Disk;\n\n/** Optional parameters. */\nexport interface DisksUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type DisksUpdateResponse = Disk;\n\n/** Optional parameters. */\nexport interface DisksDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DisksGrantAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the grantAccess operation. */\nexport type DisksGrantAccessResponse = AccessUri;\n\n/** Optional parameters. */\nexport interface DisksRevokeAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DisksListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type DisksListNextResponse = DiskList;\n\n/** Optional parameters. */\nexport interface DisksListByResourceGroupNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type DisksListByResourceGroupNextResponse = DiskList;\n\n/** Optional parameters. */\nexport interface SnapshotsListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type SnapshotsListResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface SnapshotsListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type SnapshotsListByResourceGroupResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface SnapshotsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SnapshotsGetResponse = Snapshot;\n\n/** Optional parameters. */\nexport interface SnapshotsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type SnapshotsCreateOrUpdateResponse = Snapshot;\n\n/** Optional parameters. */\nexport interface SnapshotsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type SnapshotsUpdateResponse = Snapshot;\n\n/** Optional parameters. */\nexport interface SnapshotsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface SnapshotsGrantAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the grantAccess operation. */\nexport type SnapshotsGrantAccessResponse = AccessUri;\n\n/** Optional parameters. */\nexport interface SnapshotsRevokeAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface SnapshotsListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SnapshotsListNextResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface SnapshotsListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type SnapshotsListByResourceGroupNextResponse = SnapshotList;\n\n/** Optional parameters. */\nexport interface DiskRestorePointListByRestorePointOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByRestorePoint operation. */\nexport type DiskRestorePointListByRestorePointResponse = DiskRestorePointList;\n\n/** Optional parameters. */\nexport interface DiskRestorePointGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type DiskRestorePointGetResponse = DiskRestorePoint;\n\n/** Optional parameters. */\nexport interface DiskRestorePointGrantAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the grantAccess operation. */\nexport type DiskRestorePointGrantAccessResponse = AccessUri;\n\n/** Optional parameters. */\nexport interface DiskRestorePointRevokeAccessOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface DiskRestorePointListByRestorePointNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByRestorePointNext operation. */\nexport type DiskRestorePointListByRestorePointNextResponse = DiskRestorePointList;\n\n/** Optional parameters. */\nexport interface ResourceSkusListOptionalParams extends coreClient.OperationOptions {\n /** The filter to apply on the operation. Only **location** filter is supported currently. */\n filter?: string;\n /** To Include Extended Locations information or not in the response. */\n includeExtendedLocations?: string;\n}\n\n/** Contains response data for the list operation. */\nexport type ResourceSkusListResponse = ResourceSkusResult;\n\n/** Optional parameters. */\nexport interface ResourceSkusListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type ResourceSkusListNextResponse = ResourceSkusResult;\n\n/** Optional parameters. */\nexport interface GalleriesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type GalleriesListResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface GalleriesListByResourceGroupOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroup operation. */\nexport type GalleriesListByResourceGroupResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface GalleriesGetOptionalParams extends coreClient.OperationOptions {\n /** The select expression to apply on the operation. */\n select?: SelectPermissions;\n /** The expand query option to apply on the operation. */\n expand?: GalleryExpandParams;\n}\n\n/** Contains response data for the get operation. */\nexport type GalleriesGetResponse = Gallery;\n\n/** Optional parameters. */\nexport interface GalleriesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleriesCreateOrUpdateResponse = Gallery;\n\n/** Optional parameters. */\nexport interface GalleriesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleriesUpdateResponse = GalleriesUpdateHeaders & Gallery;\n\n/** Optional parameters. */\nexport interface GalleriesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleriesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type GalleriesListNextResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface GalleriesListByResourceGroupNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByResourceGroupNext operation. */\nexport type GalleriesListByResourceGroupNextResponse = GalleryList;\n\n/** Optional parameters. */\nexport interface CommunityGalleriesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CommunityGalleriesGetResponse = CommunityGallery;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImagesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CommunityGalleryImagesListResponse = CommunityGalleryImageList;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CommunityGalleryImagesGetResponse = CommunityGalleryImage;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImagesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CommunityGalleryImagesListNextResponse = CommunityGalleryImageList;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImageVersionsListOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CommunityGalleryImageVersionsListResponse = CommunityGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImageVersionsGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CommunityGalleryImageVersionsGetResponse = CommunityGalleryImageVersion;\n\n/** Optional parameters. */\nexport interface CommunityGalleryImageVersionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CommunityGalleryImageVersionsListNextResponse = CommunityGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface SharedGalleriesListOptionalParams extends coreClient.OperationOptions {\n /** The query parameter to decide what shared galleries to fetch when doing listing operations. */\n sharedTo?: SharedToValues;\n}\n\n/** Contains response data for the list operation. */\nexport type SharedGalleriesListResponse = SharedGalleryList;\n\n/** Optional parameters. */\nexport interface SharedGalleriesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SharedGalleriesGetResponse = SharedGallery;\n\n/** Optional parameters. */\nexport interface SharedGalleriesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SharedGalleriesListNextResponse = SharedGalleryList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImagesListOptionalParams extends coreClient.OperationOptions {\n /** The query parameter to decide what shared galleries to fetch when doing listing operations. */\n sharedTo?: SharedToValues;\n}\n\n/** Contains response data for the list operation. */\nexport type SharedGalleryImagesListResponse = SharedGalleryImageList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SharedGalleryImagesGetResponse = SharedGalleryImage;\n\n/** Optional parameters. */\nexport interface SharedGalleryImagesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SharedGalleryImagesListNextResponse = SharedGalleryImageList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImageVersionsListOptionalParams extends coreClient.OperationOptions {\n /** The query parameter to decide what shared galleries to fetch when doing listing operations. */\n sharedTo?: SharedToValues;\n}\n\n/** Contains response data for the list operation. */\nexport type SharedGalleryImageVersionsListResponse = SharedGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface SharedGalleryImageVersionsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type SharedGalleryImageVersionsGetResponse = SharedGalleryImageVersion;\n\n/** Optional parameters. */\nexport interface SharedGalleryImageVersionsListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type SharedGalleryImageVersionsListNextResponse = SharedGalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsListByGalleryOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryApplicationsListByGalleryResponse = GalleryApplicationList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryApplicationsGetResponse = GalleryApplication;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryApplicationsCreateOrUpdateResponse = GalleryApplication;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryApplicationsUpdateResponse = GalleryApplicationsUpdateHeaders &\n GalleryApplication;\n\n/** Optional parameters. */\nexport interface GalleryApplicationsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryApplicationsListByGalleryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryApplicationsListByGalleryNextResponse = GalleryApplicationList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsListByGalleryApplicationOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryApplication operation. */\nexport type GalleryApplicationVersionsListByGalleryApplicationResponse =\n GalleryApplicationVersionList;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: ReplicationStatusTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type GalleryApplicationVersionsGetResponse = GalleryApplicationVersion;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryApplicationVersionsCreateOrUpdateResponse = GalleryApplicationVersion;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryApplicationVersionsUpdateResponse = GalleryApplicationVersionsUpdateHeaders &\n GalleryApplicationVersion;\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryApplicationVersionsListByGalleryApplicationNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryApplicationNext operation. */\nexport type GalleryApplicationVersionsListByGalleryApplicationNextResponse =\n GalleryApplicationVersionList;\n\n/** Optional parameters. */\nexport interface GalleryImagesListByGalleryOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryImagesListByGalleryResponse = GalleryImageList;\n\n/** Optional parameters. */\nexport interface GalleryImagesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryImagesGetResponse = GalleryImage;\n\n/** Optional parameters. */\nexport interface GalleryImagesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryImagesCreateOrUpdateResponse = GalleryImage;\n\n/** Optional parameters. */\nexport interface GalleryImagesUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryImagesUpdateResponse = GalleryImagesUpdateHeaders & GalleryImage;\n\n/** Optional parameters. */\nexport interface GalleryImagesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryImagesListByGalleryNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryImagesListByGalleryNextResponse = GalleryImageList;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsListByGalleryImageOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryImage operation. */\nexport type GalleryImageVersionsListByGalleryImageResponse = GalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply on the operation. */\n expand?: ReplicationStatusTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type GalleryImageVersionsGetResponse = GalleryImageVersion;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryImageVersionsCreateOrUpdateResponse = GalleryImageVersion;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryImageVersionsUpdateResponse = GalleryImageVersionsUpdateHeaders &\n GalleryImageVersion;\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface GalleryImageVersionsListByGalleryImageNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryImageNext operation. */\nexport type GalleryImageVersionsListByGalleryImageNextResponse = GalleryImageVersionList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesListByGalleryOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryInVMAccessControlProfilesListByGalleryResponse =\n GalleryInVMAccessControlProfileList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryInVMAccessControlProfilesGetResponse = GalleryInVMAccessControlProfile;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryInVMAccessControlProfilesCreateOrUpdateResponse =\n GalleryInVMAccessControlProfile;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryInVMAccessControlProfilesUpdateResponse =\n GalleryInVMAccessControlProfilesUpdateHeaders & GalleryInVMAccessControlProfile;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the delete operation. */\nexport type GalleryInVMAccessControlProfilesDeleteResponse =\n GalleryInVMAccessControlProfilesDeleteHeaders;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfilesListByGalleryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryInVMAccessControlProfilesListByGalleryNextResponse =\n GalleryInVMAccessControlProfileList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryInVMAccessControlProfile operation. */\nexport type GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileResponse =\n GalleryInVMAccessControlProfileVersionList;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsGetOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryInVMAccessControlProfileVersionsGetResponse =\n GalleryInVMAccessControlProfileVersion;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryInVMAccessControlProfileVersionsCreateOrUpdateResponse =\n GalleryInVMAccessControlProfileVersion;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryInVMAccessControlProfileVersionsUpdateResponse =\n GalleryInVMAccessControlProfileVersionsUpdateHeaders & GalleryInVMAccessControlProfileVersion;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsDeleteOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the delete operation. */\nexport type GalleryInVMAccessControlProfileVersionsDeleteResponse =\n GalleryInVMAccessControlProfileVersionsDeleteHeaders;\n\n/** Optional parameters. */\nexport interface GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryInVMAccessControlProfileNext operation. */\nexport type GalleryInVMAccessControlProfileVersionsListByGalleryInVMAccessControlProfileNextResponse =\n GalleryInVMAccessControlProfileVersionList;\n\n/** Optional parameters. */\nexport interface GalleryScriptsListByGalleryOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGallery operation. */\nexport type GalleryScriptsListByGalleryResponse = GalleryScriptList;\n\n/** Optional parameters. */\nexport interface GalleryScriptsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryScriptsGetResponse = GalleryScript;\n\n/** Optional parameters. */\nexport interface GalleryScriptsCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryScriptsCreateOrUpdateResponse = GalleryScript;\n\n/** Optional parameters. */\nexport interface GalleryScriptsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryScriptsUpdateResponse = GalleryScript;\n\n/** Optional parameters. */\nexport interface GalleryScriptsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the delete operation. */\nexport type GalleryScriptsDeleteResponse = GalleryScriptsDeleteHeaders;\n\n/** Optional parameters. */\nexport interface GalleryScriptsListByGalleryNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryNext operation. */\nexport type GalleryScriptsListByGalleryNextResponse = GalleryScriptList;\n\n/** Optional parameters. */\nexport interface GalleryScriptVersionsListByGalleryScriptOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryScript operation. */\nexport type GalleryScriptVersionsListByGalleryScriptResponse = GalleryScriptVersionList;\n\n/** Optional parameters. */\nexport interface GalleryScriptVersionsGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type GalleryScriptVersionsGetResponse = GalleryScriptVersion;\n\n/** Optional parameters. */\nexport interface GalleryScriptVersionsCreateOrUpdateOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type GalleryScriptVersionsCreateOrUpdateResponse = GalleryScriptVersion;\n\n/** Optional parameters. */\nexport interface GalleryScriptVersionsUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GalleryScriptVersionsUpdateResponse = GalleryScriptVersion;\n\n/** Optional parameters. */\nexport interface GalleryScriptVersionsDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the delete operation. */\nexport type GalleryScriptVersionsDeleteResponse = GalleryScriptVersionsDeleteHeaders;\n\n/** Optional parameters. */\nexport interface GalleryScriptVersionsListByGalleryScriptNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByGalleryScriptNext operation. */\nexport type GalleryScriptVersionsListByGalleryScriptNextResponse = GalleryScriptVersionList;\n\n/** Optional parameters. */\nexport interface GallerySharingProfileUpdateOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type GallerySharingProfileUpdateResponse = SharingUpdate;\n\n/** Optional parameters. */\nexport interface SoftDeletedResourceListByArtifactNameOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByArtifactName operation. */\nexport type SoftDeletedResourceListByArtifactNameResponse = GallerySoftDeletedResourceList;\n\n/** Optional parameters. */\nexport interface SoftDeletedResourceListByArtifactNameNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listByArtifactNameNext operation. */\nexport type SoftDeletedResourceListByArtifactNameNextResponse = GallerySoftDeletedResourceList;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesGetOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. 'UserData' is not supported for cloud services. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the get operation. */\nexport type CloudServiceRoleInstancesGetResponse = RoleInstance;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesGetInstanceViewOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type CloudServiceRoleInstancesGetInstanceViewResponse = RoleInstanceView;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesListOptionalParams extends coreClient.OperationOptions {\n /** The expand expression to apply to the operation. 'UserData' is not supported for cloud services. */\n expand?: InstanceViewTypes;\n}\n\n/** Contains response data for the list operation. */\nexport type CloudServiceRoleInstancesListResponse = RoleInstanceListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesRestartOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesReimageOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesRebuildOptionalParams\n extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesGetRemoteDesktopFileOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getRemoteDesktopFile operation. */\nexport type CloudServiceRoleInstancesGetRemoteDesktopFileResponse = {\n /**\n * BROWSER ONLY\n *\n * The response body as a browser Blob.\n * Always `undefined` in node.js.\n */\n blobBody?: Promise<Blob>;\n /**\n * NODEJS ONLY\n *\n * The response body as a node.js Readable stream.\n * Always `undefined` in the browser.\n */\n readableStreamBody?: NodeJS.ReadableStream;\n};\n\n/** Optional parameters. */\nexport interface CloudServiceRoleInstancesListNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CloudServiceRoleInstancesListNextResponse = RoleInstanceListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceRolesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CloudServiceRolesGetResponse = CloudServiceRole;\n\n/** Optional parameters. */\nexport interface CloudServiceRolesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CloudServiceRolesListResponse = CloudServiceRoleListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceRolesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CloudServiceRolesListNextResponse = CloudServiceRoleListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesCreateOrUpdateOptionalParams extends coreClient.OperationOptions {\n /** The cloud service object. */\n parameters?: CloudService;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the createOrUpdate operation. */\nexport type CloudServicesCreateOrUpdateResponse = CloudService;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateOptionalParams extends coreClient.OperationOptions {\n /** The cloud service object. */\n parameters?: CloudServiceUpdate;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Contains response data for the update operation. */\nexport type CloudServicesUpdateResponse = CloudService;\n\n/** Optional parameters. */\nexport interface CloudServicesDeleteOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesGetOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the get operation. */\nexport type CloudServicesGetResponse = CloudService;\n\n/** Optional parameters. */\nexport interface CloudServicesGetInstanceViewOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the getInstanceView operation. */\nexport type CloudServicesGetInstanceViewResponse = CloudServiceInstanceView;\n\n/** Optional parameters. */\nexport interface CloudServicesListAllOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAll operation. */\nexport type CloudServicesListAllResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesListOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the list operation. */\nexport type CloudServicesListResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesStartOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesPowerOffOptionalParams extends coreClient.OperationOptions {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesRestartOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesReimageOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesRebuildOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesDeleteInstancesOptionalParams extends coreClient.OperationOptions {\n /** List of cloud service role instance names. */\n parameters?: RoleInstances;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesListAllNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listAllNext operation. */\nexport type CloudServicesListAllNextResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesListNextOptionalParams extends coreClient.OperationOptions {}\n\n/** Contains response data for the listNext operation. */\nexport type CloudServicesListNextResponse = CloudServiceListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainWalkUpdateDomainOptionalParams\n extends coreClient.OperationOptions {\n /** The update domain object. */\n parameters?: UpdateDomain;\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /** A serialized poller which can be used to resume an existing paused Long-Running-Operation. */\n resumeFrom?: string;\n}\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainGetUpdateDomainOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getUpdateDomain operation. */\nexport type CloudServicesUpdateDomainGetUpdateDomainResponse = UpdateDomain;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainListUpdateDomainsOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listUpdateDomains operation. */\nexport type CloudServicesUpdateDomainListUpdateDomainsResponse = UpdateDomainListResult;\n\n/** Optional parameters. */\nexport interface CloudServicesUpdateDomainListUpdateDomainsNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listUpdateDomainsNext operation. */\nexport type CloudServicesUpdateDomainListUpdateDomainsNextResponse = UpdateDomainListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsGetOSVersionOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSVersion operation. */\nexport type CloudServiceOperatingSystemsGetOSVersionResponse = OSVersion;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSVersionsOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSVersions operation. */\nexport type CloudServiceOperatingSystemsListOSVersionsResponse = OSVersionListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsGetOSFamilyOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the getOSFamily operation. */\nexport type CloudServiceOperatingSystemsGetOSFamilyResponse = OSFamily;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSFamiliesOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSFamilies operation. */\nexport type CloudServiceOperatingSystemsListOSFamiliesResponse = OSFamilyListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSVersionsNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSVersionsNext operation. */\nexport type CloudServiceOperatingSystemsListOSVersionsNextResponse = OSVersionListResult;\n\n/** Optional parameters. */\nexport interface CloudServiceOperatingSystemsListOSFamiliesNextOptionalParams\n extends coreClient.OperationOptions {}\n\n/** Contains response data for the listOSFamiliesNext operation. */\nexport type CloudServiceOperatingSystemsListOSFamiliesNextResponse = OSFamilyListResult;\n\n/** Optional parameters. */\nexport interface ComputeManagementClientOptionalParams extends coreClient.ServiceClientOptions {\n /** server parameter */\n $host?: string;\n /** Overrides client endpoint. */\n endpoint?: string;\n}\n"]}
|