diff --git a/Tasks/AzurePowerShellV4/_buildConfigs/Node16/FilesOverriddenForConfigGoHereREADME.txt b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/FilesOverriddenForConfigGoHereREADME.txt new file mode 100644 index 000000000000..b338e624afcd --- /dev/null +++ b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/FilesOverriddenForConfigGoHereREADME.txt @@ -0,0 +1 @@ +Place files overridden for this config in this directory \ No newline at end of file diff --git a/Tasks/AzurePowerShellV4/_buildConfigs/Node16/make.json b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/make.json new file mode 100644 index 000000000000..b23bd532015c --- /dev/null +++ b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/make.json @@ -0,0 +1,52 @@ +{ + "rm": [ + { + "items": [ + "node_modules/https-proxy-agent/node_modules/agent-base", + "node_modules/azure-pipelines-tasks-azure-arm-rest/node_modules/azure-pipelines-task-lib", + "node_modules/azure-pipelines-tasks-utility-common/node_modules/azure-pipelines-task-lib", + "node_modules/azure-pipelines-tool-lib/node_modules/azure-pipelines-task-lib" + ], + "options": "-Rf" + } + ], + "common": [ + { + "module": "../Common/VstsAzureHelpers_", + "type": "ps" + }, + { + "module": "../Common/TlsHelper_", + "type": "ps" + } + ], + "externals": { + "nugetv2": [ + { + "name": "VstsTaskSdk", + "version": "0.11.0", + "repository": "https://www.powershellgallery.com/api/v2/", + "cp": [ + { + "source": [ + "*.dll", + "*.ps1", + "*.psd1", + "*.psm1", + "lib.json", + "Strings" + ], + "dest": "ps_modules/VstsTaskSdk/", + "options": "-R" + } + ] + } + ], + "archivePackages": [ + { + "url": "https://vstsagenttools.blob.core.windows.net/tools/7zip/1/7zip.zip", + "dest": "./" + } + ] + } +} diff --git a/Tasks/AzurePowerShellV4/_buildConfigs/Node16/package-lock.json b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/package-lock.json new file mode 100644 index 000000000000..4df893519494 --- /dev/null +++ b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/package-lock.json @@ -0,0 +1,859 @@ +{ + "name": "azure-powershell-v4", + "requires": true, + "lockfileVersion": 1, + "dependencies": { + "@azure/msal-common": { + "version": "9.1.1", + "resolved": "https://registry.npmjs.org/@azure/msal-common/-/msal-common-9.1.1.tgz", + "integrity": "sha512-we9xR8lvu47fF0h+J8KyXoRy9+G/fPzm3QEa2TrdR3jaVS3LKAyE2qyMuUkNdbVkvzl8Zr9f7l+IUSP22HeqXw==" + }, + "@azure/msal-node": { + "version": "1.14.5", + "resolved": "https://registry.npmjs.org/@azure/msal-node/-/msal-node-1.14.5.tgz", + "integrity": "sha512-NcVdMfn8Z3ogN+9RjOSF7uwf2Gki5DEJl0BdDSL83KUAgVAobtkZi5W8EqxbJLrTO/ET0jv5DregrcR5qg2pEA==", + "requires": { + "@azure/msal-common": "^9.0.1", + "jsonwebtoken": "^8.5.1", + "uuid": "^8.3.0" + }, + "dependencies": { + "uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" + } + } + }, + "@types/concat-stream": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/@types/concat-stream/-/concat-stream-1.6.1.tgz", + "integrity": "sha512-eHE4cQPoj6ngxBZMvVf6Hw7Mh4jMW4U9lpGmS5GBPB9RYxlFg+CHaVN7ErNY4W9XfLIEn20b4VDYaIrbq0q4uA==", + "requires": { + "@types/node": "*" + } + }, + "@types/form-data": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/@types/form-data/-/form-data-0.0.33.tgz", + "integrity": "sha512-8BSvG1kGm83cyJITQMZSulnl6QV8jqAGreJsc5tPu1Jq0vTSOiY/k24Wx82JRpWwZSqrala6sd5rWi6aNXvqcw==", + "requires": { + "@types/node": "*" + } + }, + "@types/jsonwebtoken": { + "version": "8.5.9", + "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.9.tgz", + "integrity": "sha512-272FMnFGzAVMGtu9tkr29hRL6bZj4Zs1KZNeHLnKqAvp06tAIcarTMwOh8/8bz4FmKRcMxZhZNeUAQsNLoiPhg==", + "requires": { + "@types/node": "*" + } + }, + "@types/mocha": { + "version": "5.2.7", + "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-5.2.7.tgz", + "integrity": "sha512-NYrtPht0wGzhwe9+/idPaBB+TqkY9AhTvOLMkThm0IoEfLaiVQZwBwyJ5puCkO3AUCWrmcoePjp2mbFocKy4SQ==" + }, + "@types/node": { + "version": "16.18.39", + "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.39.tgz", + "integrity": "sha512-8q9ZexmdYYyc5/cfujaXb4YOucpQxAV4RMG0himLyDUOEr8Mr79VrqsFI+cQ2M2h89YIuy95lbxuYjxT4Hk4kQ==" + }, + "@types/q": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.0.7.tgz", + "integrity": "sha512-0WS7XU7sXzQ7J1nbnMKKYdjrrFoO3YtZYgUzeV8JFXffPnHfvSJQleR70I8BOAsOm14i4dyaAZ3YzqIl1YhkXQ==" + }, + "@types/qs": { + "version": "6.9.7", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", + "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" + }, + "@types/semver": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-5.5.0.tgz", + "integrity": "sha512-41qEJgBH/TWgo5NFSvBCJ1qkoi3Q6ONSF2avrHq1LVEZfYpdHmj0y9SuTK+u9ZhG1sYQKBL1AWXKyLWP4RaUoQ==" + }, + "@types/uuid": { + "version": "3.4.10", + "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-3.4.10.tgz", + "integrity": "sha512-BgeaZuElf7DEYZhWYDTc/XcLZXdVgFkVSTa13BqKvbnmUrxr3TJFKofUxCtDO9UQOdhnV+HPOESdHiHKZOJV1A==" + }, + "agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "requires": { + "debug": "4" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "asap": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", + "integrity": "sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA==" + }, + "async-mutex": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/async-mutex/-/async-mutex-0.4.0.tgz", + "integrity": "sha512-eJFZ1YhRR8UN8eBLoNzcDPcy/jqjsg6I1AP+KvWQX80BqOSW1oJPJXDylPUEeMr2ZQvHgnQ//Lp6f3RQ1zI7HA==", + "requires": { + "tslib": "^2.4.0" + } + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + }, + "azure-devops-node-api": { + "version": "12.1.0", + "resolved": "https://registry.npmjs.org/azure-devops-node-api/-/azure-devops-node-api-12.1.0.tgz", + "integrity": "sha512-VY+G45eNKVJfMIO0uyZfbi4PzUR8JHEfsHQjEUAXUGRkYhhBbhGHjy8cpiyYFxLXc3a4PL5cqgqqV/YD1SaCXg==", + "requires": { + "tunnel": "0.0.6", + "typed-rest-client": "^1.8.4" + } + }, + "azure-pipelines-task-lib": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-4.4.0.tgz", + "integrity": "sha512-JgtxfjxjRA+KWY0Q5UC1fo48nkbVxFHgKEuasKdJMSNxHydOyNlB5MNw4UTiTXp9b0nnqKeOQOBn5RN3go3aPg==", + "requires": { + "minimatch": "3.0.5", + "mockery": "^2.1.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.5", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + }, + "azure-pipelines-tasks-azure-arm-rest": { + "version": "3.225.1", + "resolved": "https://registry.npmjs.org/azure-pipelines-tasks-azure-arm-rest/-/azure-pipelines-tasks-azure-arm-rest-3.225.1.tgz", + "integrity": "sha512-fbRcoYKEbFj2jslocX4wV0hbnN/9ZGepdzcLI+5vdOkGcKNIdOctUNvggrN1KFg9nH+NoxK1pE4+kl316VVpMA==", + "requires": { + "@azure/msal-node": "1.14.5", + "@types/jsonwebtoken": "^8.5.8", + "@types/mocha": "^5.2.7", + "@types/node": "^10.17.0", + "@types/q": "1.5.4", + "async-mutex": "^0.4.0", + "azure-devops-node-api": "^12.0.0", + "azure-pipelines-task-lib": "^3.4.0", + "https-proxy-agent": "^4.0.0", + "jsonwebtoken": "^8.5.1", + "node-fetch": "^2.6.7", + "q": "1.5.1", + "typed-rest-client": "1.8.4", + "xml2js": "0.4.13" + }, + "dependencies": { + "@types/node": { + "version": "10.17.60", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.60.tgz", + "integrity": "sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==" + }, + "@types/q": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.4.tgz", + "integrity": "sha512-1HcDas8SEj4z1Wc696tH56G8OlRaH/sqZOynNNB+HF0WOeXPaxTtbYzJY2oEfiUxjSKjhCKr+MvR7dCHcEelug==" + }, + "azure-pipelines-task-lib": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-3.4.0.tgz", + "integrity": "sha512-3eC4OTFw+7xD7A2aUhxR/j+jRlTI+vVfS0CGxt1pCLs4c/KmY0tQWgbqjD3157kmiucWxELBvgZHaD2gCBe9fg==", + "requires": { + "minimatch": "3.0.5", + "mockery": "^2.1.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.5", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + } + } + }, + "azure-pipelines-tasks-utility-common": { + "version": "3.225.0", + "resolved": "https://registry.npmjs.org/azure-pipelines-tasks-utility-common/-/azure-pipelines-tasks-utility-common-3.225.0.tgz", + "integrity": "sha512-Na7g1+zcsQpYogyex457QT6o9EB2+WQYwLUXPiszhTdf83hKJUmDMqvl2qm/mHqYuP1zg5KkRfJaPy4/09M8pA==", + "requires": { + "@types/node": "^16.11.39", + "azure-pipelines-task-lib": "^4.4.0", + "azure-pipelines-tool-lib": "^2.0.0-preview", + "js-yaml": "3.13.1", + "semver": "^5.4.1" + } + }, + "azure-pipelines-tool-lib": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/azure-pipelines-tool-lib/-/azure-pipelines-tool-lib-2.0.4.tgz", + "integrity": "sha512-LgAelZKJe3k/t3NsKSKzjeRviphns0w0p5tgwz8uHN70I9m2TToiOKl+fogrdXcM6+jiLBk5KTqrcRBqPpv/XA==", + "requires": { + "@types/semver": "^5.3.0", + "@types/uuid": "^3.4.5", + "azure-pipelines-task-lib": "^4.1.0", + "semver": "^5.7.0", + "semver-compare": "^1.0.0", + "typed-rest-client": "^1.8.6", + "uuid": "^3.3.2" + }, + "dependencies": { + "typed-rest-client": { + "version": "1.8.11", + "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.8.11.tgz", + "integrity": "sha512-5UvfMpd1oelmUPRbbaVnq+rHP7ng2cE4qoQkQeAqxRL6PklkxsM0g32/HL0yfvruK6ojQ5x8EE+HF4YV6DtuCA==", + "requires": { + "qs": "^6.9.1", + "tunnel": "0.0.6", + "underscore": "^1.12.1" + } + } + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "buffer-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" + }, + "buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" + }, + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==" + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "core-util-is": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" + }, + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "requires": { + "ms": "2.1.2" + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" + }, + "ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" + }, + "form-data": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.5.1.tgz", + "integrity": "sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA==", + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "get-intrinsic": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", + "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3" + } + }, + "get-port": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/get-port/-/get-port-3.2.0.tgz", + "integrity": "sha512-x5UJKlgeUiNT8nyo/AcnwLnZuZNcSjSw0kogRB+Whd1fjjFq4B1hySFxSFWWSn4mIBzg3sRNUDFYc4g5gjPoLg==" + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "dependencies": { + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "requires": { + "brace-expansion": "^1.1.7" + } + } + } + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==" + }, + "has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" + }, + "http-basic": { + "version": "8.1.3", + "resolved": "https://registry.npmjs.org/http-basic/-/http-basic-8.1.3.tgz", + "integrity": "sha512-/EcDMwJZh3mABI2NhGfHOGOeOZITqfkEO4p/xK+l3NpyncIHUQBoMvCSF/b5GqvKtySC2srL/GGG3+EtlqlmCw==", + "requires": { + "caseless": "^0.12.0", + "concat-stream": "^1.6.2", + "http-response-object": "^3.0.1", + "parse-cache-control": "^1.0.1" + } + }, + "http-response-object": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/http-response-object/-/http-response-object-3.0.2.tgz", + "integrity": "sha512-bqX0XTF6fnXSQcEJ2Iuyr75yVakyjIDCqroJQ/aHfSdlM743Cwqoi2nDYMzLGWUcuTWGWy8AAvOKXTfiv6q9RA==", + "requires": { + "@types/node": "^10.0.3" + }, + "dependencies": { + "@types/node": { + "version": "10.17.60", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.60.tgz", + "integrity": "sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==" + } + } + }, + "https-proxy-agent": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-4.0.0.tgz", + "integrity": "sha512-zoDhWrkR3of1l9QAL8/scJZyLu8j/gBkcwcaQOZh7Gyh/+uJQzGVETdgT30akuwkpL8HTRfssqI3BZuV18teDg==", + "requires": { + "agent-base": "5", + "debug": "4" + }, + "dependencies": { + "agent-base": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-5.1.1.tgz", + "integrity": "sha512-TMeqbNl2fMW0nMjTEPOwe3J/PRFP4vqeoNuQMG0HlMrtm5QxKqdvAkZ1pRBQ/ulIyDD5Yq0nJ7YbdD8ey0TO3g==" + } + } + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "interpret": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.4.0.tgz", + "integrity": "sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA==" + }, + "is-core-module": { + "version": "2.12.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", + "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", + "requires": { + "has": "^1.0.3" + } + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsonwebtoken": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", + "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", + "requires": { + "jws": "^3.2.2", + "lodash.includes": "^4.3.0", + "lodash.isboolean": "^3.0.3", + "lodash.isinteger": "^4.0.4", + "lodash.isnumber": "^3.0.3", + "lodash.isplainobject": "^4.0.6", + "lodash.isstring": "^4.0.1", + "lodash.once": "^4.0.0", + "ms": "^2.1.1", + "semver": "^5.6.0" + } + }, + "jwa": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", + "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", + "requires": { + "buffer-equal-constant-time": "1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "jws": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", + "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", + "requires": { + "jwa": "^1.4.1", + "safe-buffer": "^5.0.1" + } + }, + "lodash.includes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", + "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" + }, + "lodash.isboolean": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", + "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" + }, + "lodash.isinteger": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", + "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" + }, + "lodash.isnumber": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", + "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" + }, + "lodash.isplainobject": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", + "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" + }, + "lodash.isstring": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", + "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" + }, + "lodash.once": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", + "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" + }, + "mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" + }, + "mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "requires": { + "mime-db": "1.52.0" + } + }, + "minimatch": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.5.tgz", + "integrity": "sha512-tUpxzX0VAzJHjLu0xUfFv1gwVp9ba3IOuRAVH2EGuRW8a5emA2FlACLqiT/lDVtS1W+TGNwqz3sWaNyLgDJWuw==", + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "mockery": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mockery/-/mockery-2.1.0.tgz", + "integrity": "sha512-9VkOmxKlWXoDO/h1jDZaS4lH33aWfRiJiNT/tKj+8OGzrcFDLo8d0syGdbsc3Bc4GvRXPb+NMMvojotmuGJTvA==" + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + }, + "node-fetch": { + "version": "2.6.12", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.12.tgz", + "integrity": "sha512-C/fGU2E8ToujUivIO0H+tpQ6HWo4eEmchoPIoXtxCrVghxdKq+QOHqEZW7tuP3KlV3bC8FRMO5nMCC7Zm1VP6g==", + "requires": { + "whatwg-url": "^5.0.0" + } + }, + "object-inspect": { + "version": "1.12.3", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", + "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "requires": { + "wrappy": "1" + } + }, + "parse-cache-control": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parse-cache-control/-/parse-cache-control-1.0.1.tgz", + "integrity": "sha512-60zvsJReQPX5/QP0Kzfd/VrpjScIQ7SHBW6bFCYfEP+fp0Eppr1SHhIO5nd1PjZtvclzSzES9D/p5nFJurwfWg==" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + }, + "promise": { + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/promise/-/promise-8.3.0.tgz", + "integrity": "sha512-rZPNPKTOYVNEEKFaq1HqTgOwZD+4/YHS5ukLzQCypkj+OkYx7iv0mA91lJlpPPZ8vMau3IIGj5Qlwrx+8iiSmg==", + "requires": { + "asap": "~2.0.6" + } + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==" + }, + "qs": { + "version": "6.11.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.2.tgz", + "integrity": "sha512-tDNIz22aBzCDxLtVH++VnTfzxlfeK5CbqohpSqpJgj1Wg/cQbStNAz3NuqCs5vV+pjBsK4x4pN9HlVh7rcYRiA==", + "requires": { + "side-channel": "^1.0.4" + } + }, + "readable-stream": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", + "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rechoir": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", + "integrity": "sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw==", + "requires": { + "resolve": "^1.1.6" + } + }, + "resolve": { + "version": "1.22.2", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", + "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", + "requires": { + "is-core-module": "^2.11.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "sax": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", + "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" + }, + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==" + }, + "semver-compare": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", + "integrity": "sha512-YM3/ITh2MJ5MtzaM429anh+x2jiLVjqILF4m4oyQB18W7Ggea7BfqdH/wGMK7dDiMghv/6WG7znWMwUDzJiXow==" + }, + "shelljs": { + "version": "0.8.5", + "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.8.5.tgz", + "integrity": "sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==", + "requires": { + "glob": "^7.0.0", + "interpret": "^1.0.0", + "rechoir": "^0.6.2" + } + }, + "side-channel": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", + "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", + "requires": { + "call-bind": "^1.0.0", + "get-intrinsic": "^1.0.2", + "object-inspect": "^1.9.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" + }, + "sync-request": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/sync-request/-/sync-request-6.1.0.tgz", + "integrity": "sha512-8fjNkrNlNCrVc/av+Jn+xxqfCjYaBoHqCsDz6mt030UMxJGr+GSfCV1dQt2gRtlL63+VPidwDVLr7V2OcTSdRw==", + "requires": { + "http-response-object": "^3.0.1", + "sync-rpc": "^1.2.1", + "then-request": "^6.0.0" + } + }, + "sync-rpc": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/sync-rpc/-/sync-rpc-1.3.6.tgz", + "integrity": "sha512-J8jTXuZzRlvU7HemDgHi3pGnh/rkoqR/OZSjhTyyZrEkkYQbk7Z33AXp37mkPfPpfdOuj7Ex3H/TJM1z48uPQw==", + "requires": { + "get-port": "^3.1.0" + } + }, + "then-request": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/then-request/-/then-request-6.0.2.tgz", + "integrity": "sha512-3ZBiG7JvP3wbDzA9iNY5zJQcHL4jn/0BWtXIkagfz7QgOL/LqjCEOBQuJNZfu0XYnv5JhKh+cDxCPM4ILrqruA==", + "requires": { + "@types/concat-stream": "^1.6.0", + "@types/form-data": "0.0.33", + "@types/node": "^8.0.0", + "@types/qs": "^6.2.31", + "caseless": "~0.12.0", + "concat-stream": "^1.6.0", + "form-data": "^2.2.0", + "http-basic": "^8.1.1", + "http-response-object": "^3.0.1", + "promise": "^8.0.0", + "qs": "^6.4.0" + }, + "dependencies": { + "@types/node": { + "version": "8.10.66", + "resolved": "https://registry.npmjs.org/@types/node/-/node-8.10.66.tgz", + "integrity": "sha512-tktOkFUA4kXx2hhhrB8bIFb5TbwzS4uOhKEmwiD+NoiL0qtP2OQ9mFldbgD4dV1djrlBYP6eBuQZiWjuHUpqFw==" + } + } + }, + "tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" + }, + "tslib": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.1.tgz", + "integrity": "sha512-t0hLfiEKfMUoqhG+U1oid7Pva4bbDPHYfJNiB7BiIjRkj1pyC++4N3huJfqY6aRH6VTB0rvtzQwjM4K6qpfOig==" + }, + "tunnel": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", + "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==" + }, + "typed-rest-client": { + "version": "1.8.4", + "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.8.4.tgz", + "integrity": "sha512-MyfKKYzk3I6/QQp6e1T50py4qg+c+9BzOEl2rBmQIpStwNUoqQ73An+Tkfy9YuV7O+o2mpVVJpe+fH//POZkbg==", + "requires": { + "qs": "^6.9.1", + "tunnel": "0.0.6", + "underscore": "^1.12.1" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==" + }, + "typescript": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.2.tgz", + "integrity": "sha512-e4ERvRV2wb+rRZ/IQeb3jm2VxBsirQLpQhdxplZ2MEzGvDkkMmPglecnNDfSUBivMjP93vRbngYYDQqQ/78bcQ==", + "dev": true + }, + "underscore": { + "version": "1.13.6", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz", + "integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==" + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" + }, + "uuid": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", + "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" + }, + "webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" + }, + "whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "requires": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" + }, + "xml2js": { + "version": "0.4.13", + "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.13.tgz", + "integrity": "sha512-BoxD65qWA2p4znzbaati/Td19uFEc0X6ydj0bFphJO62RrNaGqOyW6ljLWPo3GKDbvW/6dnxAoRX01BsgEWsMA==", + "requires": { + "sax": ">=0.6.0", + "xmlbuilder": ">=2.4.6" + } + }, + "xmlbuilder": { + "version": "15.1.1", + "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-15.1.1.tgz", + "integrity": "sha512-yMqGBqtXyeN1e3TGYvgNgDVZ3j84W4cwkOXQswghol6APgZWaff9lnbvN7MHYJOiXsvGPXtjTYJEiC9J2wv9Eg==" + } + } +} diff --git a/Tasks/AzurePowerShellV4/_buildConfigs/Node16/package.json b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/package.json new file mode 100644 index 000000000000..2a3abb98351f --- /dev/null +++ b/Tasks/AzurePowerShellV4/_buildConfigs/Node16/package.json @@ -0,0 +1,18 @@ +{ + "name": "azure-powershell-v4", + "author": { + "name": "Microsoft Corporation" + }, + "dependencies": { + "@types/mocha": "^5.2.7", + "@types/node": "^16.11.39", + "@types/q": "1.0.7", + "agent-base": "6.0.2", + "azure-pipelines-task-lib": "^4.4.0", + "azure-pipelines-tasks-azure-arm-rest": "^3.225.1", + "azure-pipelines-tasks-utility-common": "^3.225.0" + }, + "devDependencies": { + "typescript": "4.0.2" + } +} diff --git a/Tasks/AzurePowerShellV4/task.json b/Tasks/AzurePowerShellV4/task.json index b90175341ad3..033120a4108a 100644 --- a/Tasks/AzurePowerShellV4/task.json +++ b/Tasks/AzurePowerShellV4/task.json @@ -1,209 +1,209 @@ { - "id": "72A1931B-EFFB-4D2E-8FD8-F8472A07CB62", - "name": "AzurePowerShell", - "friendlyName": "Azure PowerShell", - "description": "Run a PowerShell script within an Azure environment", - "helpMarkDown": "[Learn more about this task](https://go.microsoft.com/fwlink/?LinkID=613749)", - "helpUrl": "https://aka.ms/azurepowershelltroubleshooting", - "category": "Deploy", - "visibility": [ - "Build", - "Release" - ], - "runsOn": [ - "Agent", - "DeploymentGroup" - ], - "author": "Microsoft Corporation", - "version": { - "Major": 4, - "Minor": 225, - "Patch": 2 + "id": "72A1931B-EFFB-4D2E-8FD8-F8472A07CB62", + "name": "AzurePowerShell", + "friendlyName": "Azure PowerShell", + "description": "Run a PowerShell script within an Azure environment", + "helpMarkDown": "[Learn more about this task](https://go.microsoft.com/fwlink/?LinkID=613749)", + "helpUrl": "https://aka.ms/azurepowershelltroubleshooting", + "category": "Deploy", + "visibility": [ + "Build", + "Release" + ], + "runsOn": [ + "Agent", + "DeploymentGroup" + ], + "author": "Microsoft Corporation", + "version": { + "Major": 4, + "Minor": 226, + "Patch": 1 + }, + "releaseNotes": "Added support for Az Module and cross platform agents.", + "groups": [ + { + "name": "AzurePowerShellVersionOptions", + "displayName": "Azure PowerShell version options", + "isExpanded": true }, - "releaseNotes": "Added support for Az Module and cross platform agents.", - "groups": [ - { - "name": "AzurePowerShellVersionOptions", - "displayName": "Azure PowerShell version options", - "isExpanded": true - }, - { - "name": "advanced", - "displayName": "Advanced", - "isExpanded": false - } - ], - "minimumAgentVersion": "2.115.0", - "inputs": [ - { - "name": "ConnectedServiceNameARM", - "aliases": [ - "azureSubscription" - ], - "type": "connectedService:AzureRM", - "label": "Azure Subscription", - "defaultValue": "", - "required": true, - "helpMarkDown": "Azure Resource Manager subscription to configure before running PowerShell", - "properties": { - "EndpointFilterRule": "ScopeLevel != AzureMLWorkspace" - } - }, - { - "name": "ScriptType", - "type": "radio", - "label": "Script Type", - "required": false, - "helpMarkDown": "Type of the script: File Path or Inline Script", - "defaultValue": "FilePath", - "options": { - "FilePath": "Script File Path", - "InlineScript": "Inline Script" - } - }, - { - "name": "ScriptPath", - "type": "filePath", - "label": "Script Path", - "defaultValue": "", - "required": false, - "helpMarkDown": "Path of the script. Should be fully qualified path or relative to the default working directory.", - "visibleRule": "ScriptType = FilePath" - }, - { - "name": "Inline", - "type": "multiLine", - "label": "Inline Script", - "required": false, - "defaultValue": "# You can write your azure powershell scripts inline here. \n# You can also pass predefined and custom variables to this script using arguments", - "helpMarkDown": "Enter the script to execute.", - "visibleRule": "ScriptType = InlineScript", - "properties": { - "resizable": "true", - "rows": "10", - "maxLength": "5000" - } - }, - { - "name": "ScriptArguments", - "type": "string", - "label": "Script Arguments", - "defaultValue": "", - "visibleRule": "ScriptType = FilePath", - "required": false, - "properties": { - "editorExtension": "ms.vss-services-azure.parameters-grid" - }, - "helpMarkDown": "Additional parameters to pass to PowerShell. Can be either ordinal or named parameters." - }, - { - "name": "errorActionPreference", - "type": "pickList", - "label": "ErrorActionPreference", - "required": false, - "defaultValue": "stop", - "options": { - "stop": "Stop", - "continue": "Continue", - "silentlyContinue": "SilentlyContinue" - }, - "helpMarkDown": "Select the value of the ErrorActionPreference variable for executing the script." - }, - { - "name": "FailOnStandardError", - "type": "boolean", - "label": "Fail on Standard Error", - "required": false, - "defaultValue": "false", - "helpMarkDown": "If this is true, this task will fail if any errors are written to the error pipeline, or if any data is written to the Standard Error stream." - }, - { - "name": "RestrictContextToCurrentTask", - "type": "boolean", - "label": "Restrict scope of context to current task", - "required": false, - "defaultValue": "false", - "helpMarkDown": "If this is true, this task will restrict the scope of context to current task only and the context will not be available to other tasks in the pipeline when using private agent." - }, - { - "name": "TargetAzurePs", - "aliases": [ - "azurePowerShellVersion" - ], - "type": "radio", - "label": "Azure PowerShell Version", - "defaultValue": "OtherVersion", - "required": false, - "options": { - "LatestVersion": "Latest installed version", - "OtherVersion": "Specify other version" - }, - "groupName": "AzurePowerShellVersionOptions", - "helpMarkDown": "In case of hosted agents, the supported Azure PowerShell Version is: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nTo pick the latest version available on the agent, select \"Latest installed version\".\n\nFor private agents you can specify preferred version of Azure PowerShell using \"Specify version\"" - }, - { - "name": "CustomTargetAzurePs", - "aliases": [ - "preferredAzurePowerShellVersion" - ], - "type": "string", - "label": "Preferred Azure PowerShell Version", - "defaultValue": "", - "required": true, - "visibleRule": "TargetAzurePs = OtherVersion", - "groupName": "AzurePowerShellVersionOptions", - "helpMarkDown": "Preferred Azure PowerShell Version needs to be a proper semantic version eg. 1.2.3. Regex like 2.\\*,2.3.\\* is not supported. The Hosted VS2017 Pool currently supports Az module version: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0" - }, - { - "name": "pwsh", - "type": "boolean", - "label": "Use PowerShell Core", - "required": false, - "defaultValue": "false", - "helpMarkDown": "If this is true, then on Windows the task will use pwsh.exe from your PATH instead of powershell.exe.", - "groupName": "advanced" - }, - { - "name": "validateScriptSignature", - "type": "boolean", - "label": "Validate script signature", - "required": false, - "defaultValue": "false", - "helpMarkDown": "If this is true, then the task will first check to make sure specified script is signed and valid before executing it.", - "groupName": "advanced", - "visibleRule": "ScriptType = FilePath" - }, - { - "name": "workingDirectory", - "type": "filePath", - "label": "Working Directory", - "required": false, - "defaultValue": "", - "helpMarkDown": "Working directory where the script is run.", - "groupName": "advanced" - } - ], - "instanceNameFormat": "Azure PowerShell script: $(ScriptType)", - "execution": { - "PowerShell3": { - "target": "azurepowershell.ps1", - "platforms": [ - "windows" - ] - }, - "Node10": { - "target": "azurepowershell.js", - "argumentFormat": "" - } + { + "name": "advanced", + "displayName": "Advanced", + "isExpanded": false + } + ], + "minimumAgentVersion": "2.115.0", + "inputs": [ + { + "name": "ConnectedServiceNameARM", + "aliases": [ + "azureSubscription" + ], + "type": "connectedService:AzureRM", + "label": "Azure Subscription", + "defaultValue": "", + "required": true, + "helpMarkDown": "Azure Resource Manager subscription to configure before running PowerShell", + "properties": { + "EndpointFilterRule": "ScopeLevel != AzureMLWorkspace" + } + }, + { + "name": "ScriptType", + "type": "radio", + "label": "Script Type", + "required": false, + "helpMarkDown": "Type of the script: File Path or Inline Script", + "defaultValue": "FilePath", + "options": { + "FilePath": "Script File Path", + "InlineScript": "Inline Script" + } + }, + { + "name": "ScriptPath", + "type": "filePath", + "label": "Script Path", + "defaultValue": "", + "required": false, + "helpMarkDown": "Path of the script. Should be fully qualified path or relative to the default working directory.", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "Inline", + "type": "multiLine", + "label": "Inline Script", + "required": false, + "defaultValue": "# You can write your azure powershell scripts inline here. \n# You can also pass predefined and custom variables to this script using arguments", + "helpMarkDown": "Enter the script to execute.", + "visibleRule": "ScriptType = InlineScript", + "properties": { + "resizable": "true", + "rows": "10", + "maxLength": "5000" + } + }, + { + "name": "ScriptArguments", + "type": "string", + "label": "Script Arguments", + "defaultValue": "", + "visibleRule": "ScriptType = FilePath", + "required": false, + "properties": { + "editorExtension": "ms.vss-services-azure.parameters-grid" + }, + "helpMarkDown": "Additional parameters to pass to PowerShell. Can be either ordinal or named parameters." + }, + { + "name": "errorActionPreference", + "type": "pickList", + "label": "ErrorActionPreference", + "required": false, + "defaultValue": "stop", + "options": { + "stop": "Stop", + "continue": "Continue", + "silentlyContinue": "SilentlyContinue" + }, + "helpMarkDown": "Select the value of the ErrorActionPreference variable for executing the script." + }, + { + "name": "FailOnStandardError", + "type": "boolean", + "label": "Fail on Standard Error", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, this task will fail if any errors are written to the error pipeline, or if any data is written to the Standard Error stream." + }, + { + "name": "RestrictContextToCurrentTask", + "type": "boolean", + "label": "Restrict scope of context to current task", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, this task will restrict the scope of context to current task only and the context will not be available to other tasks in the pipeline when using private agent." + }, + { + "name": "TargetAzurePs", + "aliases": [ + "azurePowerShellVersion" + ], + "type": "radio", + "label": "Azure PowerShell Version", + "defaultValue": "OtherVersion", + "required": false, + "options": { + "LatestVersion": "Latest installed version", + "OtherVersion": "Specify other version" + }, + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "In case of hosted agents, the supported Azure PowerShell Version is: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nTo pick the latest version available on the agent, select \"Latest installed version\".\n\nFor private agents you can specify preferred version of Azure PowerShell using \"Specify version\"" + }, + { + "name": "CustomTargetAzurePs", + "aliases": [ + "preferredAzurePowerShellVersion" + ], + "type": "string", + "label": "Preferred Azure PowerShell Version", + "defaultValue": "", + "required": true, + "visibleRule": "TargetAzurePs = OtherVersion", + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "Preferred Azure PowerShell Version needs to be a proper semantic version eg. 1.2.3. Regex like 2.\\*,2.3.\\* is not supported. The Hosted VS2017 Pool currently supports Az module version: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0" + }, + { + "name": "pwsh", + "type": "boolean", + "label": "Use PowerShell Core", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, then on Windows the task will use pwsh.exe from your PATH instead of powershell.exe.", + "groupName": "advanced" + }, + { + "name": "validateScriptSignature", + "type": "boolean", + "label": "Validate script signature", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, then the task will first check to make sure specified script is signed and valid before executing it.", + "groupName": "advanced", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "workingDirectory", + "type": "filePath", + "label": "Working Directory", + "required": false, + "defaultValue": "", + "helpMarkDown": "Working directory where the script is run.", + "groupName": "advanced" + } + ], + "instanceNameFormat": "Azure PowerShell script: $(ScriptType)", + "execution": { + "PowerShell3": { + "target": "azurepowershell.ps1", + "platforms": [ + "windows" + ] }, - "messages": { - "GeneratingScript": "Generating script.", - "JS_FormattedCommand": "Formatted command: %s", - "InvalidScriptArguments0": "Invalid script arguments '{0}'. Line breaks are not allowed.", - "InvalidScriptPath0": "Invalid script path '{0}'. Invalid path characters specified.", - "InvalidAzurePsVersion": "The Azure PowerShell version '{0}' specified is not in the correct format. Please check the format. An example of correct format is 1.0.1", - "JS_ExitCode": "PowerShell exited with code '%s'.", - "JS_Stderr": "PowerShell wrote one or more lines to the standard error stream.", - "ExpiredServicePrincipal": "Could not fetch access token for Azure. Verify if the Service Principal used is valid and not expired." + "Node10": { + "target": "azurepowershell.js", + "argumentFormat": "" } + }, + "messages": { + "GeneratingScript": "Generating script.", + "JS_FormattedCommand": "Formatted command: %s", + "InvalidScriptArguments0": "Invalid script arguments '{0}'. Line breaks are not allowed.", + "InvalidScriptPath0": "Invalid script path '{0}'. Invalid path characters specified.", + "InvalidAzurePsVersion": "The Azure PowerShell version '{0}' specified is not in the correct format. Please check the format. An example of correct format is 1.0.1", + "JS_ExitCode": "PowerShell exited with code '%s'.", + "JS_Stderr": "PowerShell wrote one or more lines to the standard error stream.", + "ExpiredServicePrincipal": "Could not fetch access token for Azure. Verify if the Service Principal used is valid and not expired." + } } \ No newline at end of file diff --git a/Tasks/AzurePowerShellV4/task.loc.json b/Tasks/AzurePowerShellV4/task.loc.json index bebd56efdd88..e63edbf22e31 100644 --- a/Tasks/AzurePowerShellV4/task.loc.json +++ b/Tasks/AzurePowerShellV4/task.loc.json @@ -17,8 +17,8 @@ "author": "Microsoft Corporation", "version": { "Major": 4, - "Minor": 225, - "Patch": 2 + "Minor": 226, + "Patch": 1 }, "releaseNotes": "ms-resource:loc.releaseNotes", "groups": [ diff --git a/_generated/AzurePowerShellV4.versionmap.txt b/_generated/AzurePowerShellV4.versionmap.txt new file mode 100644 index 000000000000..f225e3229fa0 --- /dev/null +++ b/_generated/AzurePowerShellV4.versionmap.txt @@ -0,0 +1,2 @@ +Default|4.226.1 +Node16-225|4.226.0 diff --git a/_generated/AzurePowerShellV4/AzurePowerShell.ps1 b/_generated/AzurePowerShellV4/AzurePowerShell.ps1 new file mode 100644 index 000000000000..1212b0efaa6e --- /dev/null +++ b/_generated/AzurePowerShellV4/AzurePowerShell.ps1 @@ -0,0 +1,298 @@ +Trace-VstsEnteringInvocation $MyInvocation +Import-VstsLocStrings "$PSScriptRoot\Task.json" + +# Get inputs. +$scriptType = Get-VstsInput -Name ScriptType -Require +$scriptPath = Get-VstsInput -Name ScriptPath +$scriptInline = Get-VstsInput -Name Inline +$scriptArguments = Get-VstsInput -Name ScriptArguments +$__vsts_input_errorActionPreference = Get-VstsInput -Name errorActionPreference +$__vsts_input_failOnStandardError = Get-VstsInput -Name FailOnStandardError -AsBool +$targetAzurePs = Get-VstsInput -Name TargetAzurePs +$customTargetAzurePs = Get-VstsInput -Name CustomTargetAzurePs +$input_pwsh = Get-VstsInput -Name pwsh -AsBool +$input_workingDirectory = Get-VstsInput -Name workingDirectory -Require +$restrictContext = Get-VstsInput -Name RestrictContextToCurrentTask -AsBool +$validateScriptSignature = Get-VstsInput -Name validateScriptSignature -AsBool + +Write-Host "## Validating Inputs" +# Validate the script path and args do not contains new-lines. Otherwise, it will +# break invoking the script via Invoke-Expression. +if ($scriptType -eq "FilePath") { + if ($scriptPath -match '[\r\n]' -or [string]::IsNullOrWhitespace($scriptPath)) { + throw (Get-VstsLocString -Key InvalidScriptPath0 -ArgumentList $scriptPath) + } +} + +if ($scriptArguments -match '[\r\n]') { + throw (Get-VstsLocString -Key InvalidScriptArguments0 -ArgumentList $scriptArguments) +} + +# string constants +$otherVersion = "OtherVersion" +$latestVersion = "LatestVersion" + +if ($targetAzurePs -eq $otherVersion) { + if ($customTargetAzurePs -eq $null) { + throw (Get-VstsLocString -Key InvalidAzurePsVersion $customTargetAzurePs) + } else { + $targetAzurePs = $customTargetAzurePs.Trim() + } +} + +$pattern = "^[0-9]+\.[0-9]+\.[0-9]+$" +$regex = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $pattern + +if ($targetAzurePs -eq $latestVersion) { + $targetAzurePs = "" +} elseif (-not($regex.IsMatch($targetAzurePs))) { + throw (Get-VstsLocString -Key InvalidAzurePsVersion -ArgumentList $targetAzurePs) +} +Write-Host "## Validating Inputs Complete" + +. $PSScriptRoot\TryMakingModuleAvailable.ps1 -targetVersion "$targetAzurePs" -platform Windows + +if ($validateScriptSignature) { + try { + if ($scriptType -ne "InlineScript") { + Write-Host "## Validating Script Signature" + + # Validate script is signed + $scriptSignature = Get-AuthenticodeSignature $scriptPath + if ($scriptSignature.Status -eq "NotSigned") { + throw "Object does not have a digital signature. Please ensure your script is signed and try again." + } + elseif ($scriptSignature.Status -ne "Valid") { + throw "Digital signature of the object did not verify. Please ensure your script is properly signed and try again." + } + + Write-Host "## Validating Script Signature Complete" + } + } + catch + { + $errorMsg = $_.Exception.Message + throw "Unable to validate script signature: $errorMsg" + } +} + +Write-Host "## Initializing Az module" +. "$PSScriptRoot\Utility.ps1" + +$serviceName = Get-VstsInput -Name ConnectedServiceNameARM -Require +$endpoint = Get-VstsEndpoint -Name $serviceName -Require +CleanUp-PSModulePathForHostedAgent +Update-PSModulePathForHostedAgent -targetAzurePs $targetAzurePs +$vstsEndpoint = Get-VstsEndpoint -Name SystemVssConnection -Require +$vstsAccessToken = $vstsEndpoint.auth.parameters.AccessToken + +# troubleshoot link +$troubleshoot = "https://aka.ms/azurepowershelltroubleshooting" +try +{ + # Initialize Azure. + Import-Module $PSScriptRoot\ps_modules\VstsAzureHelpers_ + $encryptedToken = ConvertTo-SecureString $vstsAccessToken -AsPlainText -Force + Initialize-AzModule -Endpoint $endpoint -connectedServiceNameARM $serviceName ` + -azVersion $targetAzurePs -encryptedToken $encryptedToken -isPSCore $input_pwsh + Write-Host "## Az module initialization Complete" + $success = $true +} +finally { + if (!$success) { + Write-VstsTaskError "Initializing Az module failed: For troubleshooting, refer: $troubleshoot" + } +} + +Write-Host "## Beginning Script Execution" +try { + if ($input_pwsh) + { + # Generate the script contents. + Write-Host (Get-VstsLocString -Key 'GeneratingScript') + $UpdatePSModulePathArgument = $null; + if ($targetAzurePs) + { + $UpdatePSModulePathArgument = "-targetAzurePs $targetAzurePs" + } + + $contents = @() + $contents += "`$ErrorActionPreference = '$__vsts_input_errorActionPreference'" + if ($env:system_debug -eq "true") { + $contents += "`$VerbosePreference = 'continue'" + } + + $contents += ". '$PSScriptRoot\UpdatePSModulePath.ps1' $UpdatePSModulePathArgument" + if ($scriptType -eq "InlineScript") { + $contents += "$scriptInline".Replace("`r`n", "`n").Replace("`n", "`r`n") + } else { + $contents += ". '$("$scriptPath".Replace("'", "''"))' $scriptArguments".Trim() + } + + # Write the script to disk. + $__vstsAzPSScriptPath = [System.IO.Path]::Combine($env:Agent_TempDirectory, ([guid]::NewGuid().ToString() + ".ps1")); + $joinedContents = [System.String]::Join( + ([System.Environment]::NewLine), + $contents) + $null = [System.IO.File]::WriteAllText( + $__vstsAzPSScriptPath, + $joinedContents, + ([System.Text.Encoding]::UTF8)) + + # Prepare the external command values. + # + # Note, use "-Command" instead of "-File". On PowerShell v4 and V3 when using "-File", terminating + # errors do not cause a non-zero exit code. + if ($input_pwsh) { + $powershellPath = Get-Command -Name pwsh.exe -CommandType Application | Select-Object -First 1 -ExpandProperty Path + } else { + $powershellPath = Get-Command -Name powershell.exe -CommandType Application | Select-Object -First 1 -ExpandProperty Path + } + Assert-VstsPath -LiteralPath $powershellPath -PathType 'Leaf' + $arguments = "-NoLogo -NoProfile -NonInteractive -ExecutionPolicy Unrestricted -Command `". '$($__vstsAzPSScriptPath.Replace("'", "''"))'`"" + $splat = @{ + 'FileName' = $powershellPath + 'Arguments' = $arguments + 'WorkingDirectory' = $input_workingDirectory + } + + # Switch to "Continue". + $global:ErrorActionPreference = 'Continue' + $failed = $false + + # Run the script. + Write-Host '========================== Starting Command Output ===========================' + if (!$__vsts_input_failOnStandardError) { + Invoke-VstsTool @splat + } + else { + $inError = $false + $errorLines = New-Object System.Text.StringBuilder + Invoke-VstsTool @splat 2>&1 | + ForEach-Object { + if ($_ -is [System.Management.Automation.ErrorRecord]) { + # Buffer the error lines. + $failed = $true + $inError = $true + $null = $errorLines.AppendLine("$($_.Exception.Message)") + + # Write to verbose to mitigate if the process hangs. + Write-Verbose "STDERR: $($_.Exception.Message)" + } else { + # Flush the error buffer. + if ($inError) { + $inError = $false + $message = $errorLines.ToString().Trim() + $null = $errorLines.Clear() + if ($message) { + Write-VstsTaskError -Message $message + } + } + + Write-Host "$_" + } + } + + # Flush the error buffer one last time. + if ($inError) { + $inError = $false + $message = $errorLines.ToString().Trim() + $null = $errorLines.Clear() + if ($message) { + Write-VstsTaskError -Message $message + } + } + } + + # Fail if any errors. + if ($failed) { + Write-VstsSetResult -Result 'Failed' -Message "Error detected" -DoNotThrow + } + } + else + { + # Trace the expression as it will be invoked. + $__vstsAzPSInlineScriptPath = $null + If ($scriptType -eq "InlineScript") { + $scriptArguments = $null + $__vstsAzPSInlineScriptPath = [System.IO.Path]::Combine($env:Agent_TempDirectory, ([guid]::NewGuid().ToString() + ".ps1")); + ($scriptInline | Out-File $__vstsAzPSInlineScriptPath) + $scriptPath = $__vstsAzPSInlineScriptPath + } + + $scriptCommand = "& '$($scriptPath.Replace("'", "''"))' $scriptArguments" + Remove-Variable -Name scriptType + Remove-Variable -Name scriptPath + Remove-Variable -Name scriptInline + Remove-Variable -Name scriptArguments + + # Remove all commands imported from VstsTaskSdk, other than Out-Default. + # Remove all commands imported from VstsAzureHelpers_. + Get-ChildItem -LiteralPath function: | + Where-Object { + ($_.ModuleName -eq 'VstsTaskSdk' -and $_.Name -ne 'Out-Default') -or + ($_.Name -eq 'Invoke-VstsTaskScript') -or + ($_.ModuleName -eq 'VstsAzureHelpers_' ) + } | + Remove-Item + + # For compatibility with the legacy handler implementation, set the error action + # preference to continue. An implication of changing the preference to Continue, + # is that Invoke-VstsTaskScript will no longer handle setting the result to failed. + $global:ErrorActionPreference = 'Continue' + + # Undocumented VstsTaskSdk variable so Verbose/Debug isn't converted to ##vso[task.debug]. + # Otherwise any content the ad-hoc script writes to the verbose pipeline gets dropped by + # the agent when System.Debug is not set. + $global:__vstsNoOverrideVerbose = $true + + # Run the user's script. Redirect the error pipeline to the output pipeline to enable + # a couple goals due to compatibility with the legacy handler implementation: + # 1) STDERR from external commands needs to be converted into error records. Piping + # the redirected error output to an intermediate command before it is piped to + # Out-Default will implicitly perform the conversion. + # 2) The task result needs to be set to failed if an error record is encountered. + # As mentioned above, the requirement to handle this is an implication of changing + # the error action preference. + ([scriptblock]::Create($scriptCommand)) | + ForEach-Object { + Remove-Variable -Name scriptCommand + Write-Host "##[command]$_" + . $_ 2>&1 + } | + ForEach-Object { + if($_ -is [System.Management.Automation.ErrorRecord]) { + if($_.FullyQualifiedErrorId -eq "NativeCommandError" -or $_.FullyQualifiedErrorId -eq "NativeCommandErrorMessage") { + ,$_ + if($__vsts_input_failOnStandardError -eq $true) { + "##vso[task.complete result=Failed]" + } + } + else { + if($__vsts_input_errorActionPreference -eq "continue") { + ,$_ + if($__vsts_input_failOnStandardError -eq $true) { + "##vso[task.complete result=Failed]" + } + } + elseif($__vsts_input_errorActionPreference -eq "stop") { + throw $_ + } + } + } else { + ,$_ + } + } + } + +} +finally { + if ($__vstsAzPSInlineScriptPath -and (Test-Path -LiteralPath $__vstsAzPSInlineScriptPath) ) { + Remove-Item -LiteralPath $__vstsAzPSInlineScriptPath -ErrorAction 'SilentlyContinue' + } + + Import-Module $PSScriptRoot\ps_modules\VstsAzureHelpers_ + Remove-EndpointSecrets + Disconnect-AzureAndClearContext -restrictContext $restrictContext -ErrorAction SilentlyContinue +} +Write-Host "## Script Execution Complete" \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/InitializeAz.ps1 b/_generated/AzurePowerShellV4/InitializeAz.ps1 new file mode 100644 index 000000000000..076d87fe029c --- /dev/null +++ b/_generated/AzurePowerShellV4/InitializeAz.ps1 @@ -0,0 +1,107 @@ +[CmdletBinding()] +param +( + [String] [Parameter(Mandatory = $true)] + $endpoint, + + [String] [Parameter(Mandatory = $false)] + $targetAzurePs +) + +$endpointObject = ConvertFrom-Json $endpoint +$moduleName = "Az.Accounts" +$environmentName = $endpointObject.environment + +. "$PSScriptRoot/Utility.ps1" +Update-PSModulePathForHostedAgentLinux -targetAzurePs $targetAzurePs + +if($targetAzurePs -eq ""){ + $module = Get-Module -Name $moduleName -ListAvailable | Sort-Object Version -Descending | Select-Object -First 1 +} +else{ + $modules = Get-Module -Name $moduleName -ListAvailable + foreach ($moduleVal in $modules) { + # $moduleVal.Path will have value like /usr/local/share/powershell/Modules/Az.Accounts/1.2.1/Az.Accounts.psd1 + $azModulePath = Split-Path (Split-Path (Split-Path $moduleVal.Path -Parent) -Parent) -Parent + $azModulePath = $azModulePath + "/Az/*" + $azModuleVersion = split-path -path $azModulePath -Leaf -Resolve + if($azModuleVersion -eq $targetAzurePs) { + $module = $moduleVal + break + } + } +} + +if (!$module) { + # Will handle localization later + Write-Verbose "No module found with name: $moduleName" + throw ("Could not find the module Az.Accounts with given version. If the module was recently installed, retry after restarting the Azure Pipelines task agent.") +} + +# Import the module. +Write-Host "##[command]Import-Module -Name $($module.Path) -Global" +$module = Import-Module -Name $module.Path -Global -PassThru -Force + +# Clear context +Write-Host "##[command]Clear-AzContext -Scope CurrentUser -Force -ErrorAction SilentlyContinue" +$null = Clear-AzContext -Scope CurrentUser -Force -ErrorAction SilentlyContinue +Write-Host "##[command]Clear-AzContext -Scope Process" +$null = Clear-AzContext -Scope Process + +$scopeLevel = "Subscription" +if($endpointObject.scopeLevel) { + $scopeLevel = $endpointObject.scopeLevel +} +$processScope = @{ Scope = "Process" } + +function Format-Splat { + [CmdletBinding()] + param([Parameter(Mandatory = $true)][hashtable]$Hashtable) + + # Collect the parameters (names and values) in an array. + $parameters = foreach ($key in $Hashtable.Keys) { + $value = $Hashtable[$key] + # If the value is a bool, format the parameter as a switch (ending with ':'). + if ($value -is [bool]) { "-$($key):" } else { "-$key" } + $value + } + + "$parameters" # String join the array. +} + +if ($endpointObject.scheme -eq 'ServicePrincipal') { + try { + if ($endpointObject.authenticationType -ieq 'SPNKey') { + $psCredential = New-Object System.Management.Automation.PSCredential( + $endpointObject.servicePrincipalClientID, + (ConvertTo-SecureString $endpointObject.servicePrincipalKey -AsPlainText -Force)) + Write-Host "##[command]Connect-AzAccount -ServicePrincipal -Tenant $($endpointObject.tenantId) -Credential $psCredential -Environment $environmentName @processScope" + $null = Connect-AzAccount -ServicePrincipal -Tenant $endpointObject.tenantId ` + -Credential $psCredential ` + -Environment $environmentName @processScope -WarningAction SilentlyContinue + } + else { + # Provide an additional, custom, credentials-related error message. Will handle localization later + throw ("Only SPN credential auth scheme is supported for non windows agent.") + } + } + catch { + # Provide an additional, custom, credentials-related error message. Will handle localization later + Write-Host "Exception is : $($_.Exception.Message)" + throw (New-Object System.Exception("There was an error with the service principal used for the deployment.", $_.Exception)) + } + + if($scopeLevel -eq "Subscription") + { + $SubscriptionId = $endpointObject.subscriptionId + $TenantId = $endpointObject.tenantId + $additional = @{ TenantId = $TenantId } + + Write-Host "##[command] Set-AzContext -SubscriptionId $SubscriptionId $(Format-Splat $additional)" + $null = Set-AzContext -SubscriptionId $SubscriptionId @additional + } +} +else { + # Provide an additional, custom, credentials-related error message. Will handle localization later + throw ("Only SPN credential auth scheme is supported for non windows agent.") +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/de-DE/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/de-DE/resources.resjson new file mode 100644 index 000000000000..44d372e42cb4 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/de-DE/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Weitere Informationen zu dieser Aufgabe](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "PowerShell-Skript innerhalb einer Azure-Umgebung ausführen", + "loc.instanceNameFormat": "Azure PowerShell-Skript: $(ScriptType)", + "loc.releaseNotes": "Unterstützung für Az-Modul und plattformübergreifende Agents hinzugefügt.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell-Versionsoptionen", + "loc.group.displayName.advanced": "Erweitert", + "loc.input.label.ConnectedServiceNameARM": "Azure-Abonnement", + "loc.input.help.ConnectedServiceNameARM": "Azure Resource Manager-Abonnement, das vor dem Ausführen von PowerShell konfiguriert wird.", + "loc.input.label.ScriptType": "Skripttyp", + "loc.input.help.ScriptType": "Der Typ des Skripts: Dateipfad oder Inlineskript.", + "loc.input.label.ScriptPath": "Skriptpfad", + "loc.input.help.ScriptPath": "Der Pfad des Skripts. Es muss sich um den vollqualifizierten Pfad oder einen Pfad relativ zum Standardarbeitsverzeichnis handeln.", + "loc.input.label.Inline": "Inlineskript", + "loc.input.help.Inline": "Geben Sie das Skript ein, das ausgeführt werden soll.", + "loc.input.label.ScriptArguments": "Skriptargumente", + "loc.input.help.ScriptArguments": "Zusätzliche Argumente, die an PowerShell übergeben werden sollen. Entweder Ordnungszahl- oder benannte Parameter.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Wählen Sie den Wert der Variablen \"ErrorActionPreference\" für die Skriptausführung.", + "loc.input.label.FailOnStandardError": "Fehler bei Standardfehler.", + "loc.input.help.FailOnStandardError": "Wenn dieser Wert TRUE ist, tritt ein Aufgabenfehler auf, wenn Fehler in die Fehlerpipeline oder Daten in den Standard-Fehlerdatenstrom geschrieben werden.", + "loc.input.label.RestrictContextToCurrentTask": "Kontextbereich auf aktuelle Aufgabe beschränken", + "loc.input.help.RestrictContextToCurrentTask": "Wenn diese Option auf TRUE festgelegt ist, beschränkt diese Aufgabe den Kontextbereich nur auf die aktuelle Aufgabe, und der Kontext steht bei Verwendung des privaten Agents für andere Aufgaben in der Pipeline nicht zur Verfügung.", + "loc.input.label.TargetAzurePs": "Azure PowerShell-Version", + "loc.input.help.TargetAzurePs": "Im Falle gehosteter Agents werden die folgenden Azure PowerShell-Versionen unterstützt: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (gehostete VS2017-Warteschlange).\nWenn Sie die neueste für den Agent verfügbare Version auswählen möchten, wählen Sie \"Neueste installierte Version\" aus.\n\nFür private Agents können Sie mithilfe von \"Version angeben\" die bevorzugte Version von Azure PowerShell festlegen.", + "loc.input.label.CustomTargetAzurePs": "Bevorzugte Azure PowerShell-Version", + "loc.input.help.CustomTargetAzurePs": "Die bevorzugte Azure PowerShell-Version muss einem ordnungsgemäßen semantischen Versionsmuster folgen, z. B. \"1.2.3\". Reguläre Ausdrücke wie 2.\\*,2.3.\\* werden nicht unterstützt. Der gehostete VS2017-Pool unterstützt aktuell die folgenden Az-Modulversionen: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "PowerShell Core verwenden", + "loc.input.help.pwsh": "Sofern TRUE, verwendet die Aufgabe unter Windows anstelle von \"powershell.exe\" die in PATH festgelegte \"pwsh.exe\".", + "loc.input.label.validateScriptSignature": "Skriptsignatur überprüfen", + "loc.input.help.validateScriptSignature": "Wenn dies der Fall ist, überprüft die Aufgabe zunächst, ob das angegebene Skript signiert und gültig ist, bevor es ausgeführt wird.", + "loc.input.label.workingDirectory": "Arbeitsverzeichnis", + "loc.input.help.workingDirectory": "Arbeitsverzeichnis zum Ausführen des Skripts.", + "loc.messages.GeneratingScript": "Skript wird erstellt.", + "loc.messages.JS_FormattedCommand": "Formatierter Befehl: %s", + "loc.messages.InvalidScriptArguments0": "Ungültige Skriptargumente \"{0}\". Zeilenumbrüche sind unzulässig.", + "loc.messages.InvalidScriptPath0": "Ungültiger Skriptpfad \"{0}\". Es wurden ungültige Pfadzeichen angegeben.", + "loc.messages.InvalidAzurePsVersion": "Die angegebene Azure PowerShell-Version \"{0}\" weist nicht das richtige Format auf. Überprüfen Sie das Format. Ein Beispiel für das richtige Format ist etwa 1.0.1.", + "loc.messages.JS_ExitCode": "PowerShell wurde beendet mit dem Code \"%s\".", + "loc.messages.JS_Stderr": "PowerShell hat mindestens eine Zeile in den Standardfehlerstream geschrieben.", + "loc.messages.ExpiredServicePrincipal": "Das Zugriffstoken für Azure konnte nicht abgerufen werden. Stellen Sie sicher, dass der verwendete Dienstprinzipal gültig und nicht abgelaufen ist." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/en-US/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/en-US/resources.resjson new file mode 100644 index 000000000000..5357601c22f5 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/en-US/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Learn more about this task](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Run a PowerShell script within an Azure environment", + "loc.instanceNameFormat": "Azure PowerShell script: $(ScriptType)", + "loc.releaseNotes": "Added support for Az Module and cross platform agents.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell version options", + "loc.group.displayName.advanced": "Advanced", + "loc.input.label.ConnectedServiceNameARM": "Azure Subscription", + "loc.input.help.ConnectedServiceNameARM": "Azure Resource Manager subscription to configure before running PowerShell", + "loc.input.label.ScriptType": "Script Type", + "loc.input.help.ScriptType": "Type of the script: File Path or Inline Script", + "loc.input.label.ScriptPath": "Script Path", + "loc.input.help.ScriptPath": "Path of the script. Should be fully qualified path or relative to the default working directory.", + "loc.input.label.Inline": "Inline Script", + "loc.input.help.Inline": "Enter the script to execute.", + "loc.input.label.ScriptArguments": "Script Arguments", + "loc.input.help.ScriptArguments": "Additional parameters to pass to PowerShell. Can be either ordinal or named parameters.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Select the value of the ErrorActionPreference variable for executing the script.", + "loc.input.label.FailOnStandardError": "Fail on Standard Error", + "loc.input.help.FailOnStandardError": "If this is true, this task will fail if any errors are written to the error pipeline, or if any data is written to the Standard Error stream.", + "loc.input.label.RestrictContextToCurrentTask": "Restrict scope of context to current task", + "loc.input.help.RestrictContextToCurrentTask": "If this is true, this task will restrict the scope of context to current task only and the context will not be available to other tasks in the pipeline when using private agent.", + "loc.input.label.TargetAzurePs": "Azure PowerShell Version", + "loc.input.help.TargetAzurePs": "In case of hosted agents, the supported Azure PowerShell Version is: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nTo pick the latest version available on the agent, select \"Latest installed version\".\n\nFor private agents you can specify preferred version of Azure PowerShell using \"Specify version\"", + "loc.input.label.CustomTargetAzurePs": "Preferred Azure PowerShell Version", + "loc.input.help.CustomTargetAzurePs": "Preferred Azure PowerShell Version needs to be a proper semantic version eg. 1.2.3. Regex like 2.\\*,2.3.\\* is not supported. The Hosted VS2017 Pool currently supports Az module version: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Use PowerShell Core", + "loc.input.help.pwsh": "If this is true, then on Windows the task will use pwsh.exe from your PATH instead of powershell.exe.", + "loc.input.label.validateScriptSignature": "Validate script signature", + "loc.input.help.validateScriptSignature": "If this is true, then the task will first check to make sure specified script is signed and valid before executing it.", + "loc.input.label.workingDirectory": "Working Directory", + "loc.input.help.workingDirectory": "Working directory where the script is run.", + "loc.messages.GeneratingScript": "Generating script.", + "loc.messages.JS_FormattedCommand": "Formatted command: %s", + "loc.messages.InvalidScriptArguments0": "Invalid script arguments '{0}'. Line breaks are not allowed.", + "loc.messages.InvalidScriptPath0": "Invalid script path '{0}'. Invalid path characters specified.", + "loc.messages.InvalidAzurePsVersion": "The Azure PowerShell version '{0}' specified is not in the correct format. Please check the format. An example of correct format is 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell exited with code '%s'.", + "loc.messages.JS_Stderr": "PowerShell wrote one or more lines to the standard error stream.", + "loc.messages.ExpiredServicePrincipal": "Could not fetch access token for Azure. Verify if the Service Principal used is valid and not expired." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/es-ES/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/es-ES/resources.resjson new file mode 100644 index 000000000000..9f596d3fdf27 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/es-ES/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Obtener más información acerca de esta tarea](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Ejecutar un script de PowerShell en un entorno de Azure", + "loc.instanceNameFormat": "Script de Azure PowerShell: $(ScriptType)", + "loc.releaseNotes": "Se ha agregado compatibilidad con el módulo Az y los agentes multiplataforma.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Opciones de versión de Azure PowerShell", + "loc.group.displayName.advanced": "Avanzado", + "loc.input.label.ConnectedServiceNameARM": "Suscripción a Azure", + "loc.input.help.ConnectedServiceNameARM": "Suscripción de Azure Resource Manager para configurar antes de ejecutar PowerShell", + "loc.input.label.ScriptType": "Tipo de script", + "loc.input.help.ScriptType": "Tipo del script: ruta de acceso del archivo o script en línea", + "loc.input.label.ScriptPath": "Ruta de acceso del script", + "loc.input.help.ScriptPath": "Ruta de acceso del script. Debe ser una ruta de acceso completa o relativa al directorio de trabajo predeterminado.", + "loc.input.label.Inline": "Script alineado", + "loc.input.help.Inline": "Escriba el script que se va a ejecutar.", + "loc.input.label.ScriptArguments": "Argumentos de script", + "loc.input.help.ScriptArguments": "Parámetros adicionales que pasar a PowerShell. Pueden ser parámetros ordinales o con nombre.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Seleccione el valor de la variable ErrorActionPreference para ejecutar el script.", + "loc.input.label.FailOnStandardError": "Error si se produce un error estándar", + "loc.input.help.FailOnStandardError": "Si es true, se producirá un error en la tarea si se escriben errores en la canalización de errores o si se escriben datos en el flujo de error estándar.", + "loc.input.label.RestrictContextToCurrentTask": "Restringir el ámbito de contexto a la tarea actual", + "loc.input.help.RestrictContextToCurrentTask": "Si es true, esta tarea restringirá el ámbito de contexto solo a la tarea actual y el contexto no estará disponible para otras tareas de la canalización cuando se use el agente privado.", + "loc.input.label.TargetAzurePs": "Versión de Azure PowerShell", + "loc.input.help.TargetAzurePs": "En el caso de los agentes hospedados, las versiones de Azure PowerShell admitidas son 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nPara seleccionar la última versión disponible en el agente, seleccione \"Latest installed version\".\n\nPara los agentes privados, puede especificar la versión de Azure PowerShell que prefiera con la opción \"Specify version\"", + "loc.input.label.CustomTargetAzurePs": "Versión de Azure PowerShell preferida", + "loc.input.help.CustomTargetAzurePs": "La versión preferida de Azure PowerShell debe ser una versión de semántica adecuada, por ejemplo, 1.2.3. No se admite una notación regex como 2.\\*,2.3.\\*. El grupo Hosted VS2017 Pool es compatible con las versiones del módulo Az 1.0.0, 1.6.0, 2.3.2, 2.6.0 y 3.1.0", + "loc.input.label.pwsh": "Usar PowerShell Core", + "loc.input.help.pwsh": "Si es true, la tarea usará pwsh.exe desde PATH en lugar de powershell.exe en Windows.", + "loc.input.label.validateScriptSignature": "Validación de la firma del script", + "loc.input.help.validateScriptSignature": "Si es true, la tarea comprobará primero para asegurarse de que el script especificado está firmado y es válido antes de ejecutarlo.", + "loc.input.label.workingDirectory": "Directorio de trabajo", + "loc.input.help.workingDirectory": "Directorio de trabajo donde se ejecuta el script.", + "loc.messages.GeneratingScript": "Generando script.", + "loc.messages.JS_FormattedCommand": "Comando con formato: %s", + "loc.messages.InvalidScriptArguments0": "Argumentos de script '{0}' no válidos. No se permiten los saltos de línea.", + "loc.messages.InvalidScriptPath0": "Ruta del script '{0}' no válida. Los caracteres de ruta de acceso especificados no son válidos.", + "loc.messages.InvalidAzurePsVersion": "La versión de Azure PowerShell \"{0}\" especificada no tiene el formato correcto. Compruebe el formato. Ejemplo de formato correcto: 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell se cerró con el código \"%s\".", + "loc.messages.JS_Stderr": "PowerShell escribió una o varias líneas en la secuencia de error estándar.", + "loc.messages.ExpiredServicePrincipal": "No se pudo capturar el token de acceso de Azure. Compruebe que la entidad de servicio usada es válida y no ha expirado." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/fr-FR/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/fr-FR/resources.resjson new file mode 100644 index 000000000000..85ffdca03de8 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/fr-FR/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[En savoir plus sur cette tâche](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Exécuter un script PowerShell dans un environnement Azure", + "loc.instanceNameFormat": "Script Azure PowerShell : $(ScriptType)", + "loc.releaseNotes": "Ajout de la prise en charge du module Azure et des agents multiplateformes.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Options de version Azure PowerShell", + "loc.group.displayName.advanced": "Avancé", + "loc.input.label.ConnectedServiceNameARM": "Abonnement Azure", + "loc.input.help.ConnectedServiceNameARM": "Abonnement Azure Resource Manager à configurer avant d'exécuter PowerShell", + "loc.input.label.ScriptType": "Type de script", + "loc.input.help.ScriptType": "Type du script : chemin de fichier ou script inline", + "loc.input.label.ScriptPath": "Chemin d'accès du script", + "loc.input.help.ScriptPath": "Chemin d'accès du script. Doit être un chemin d'accès complet ou relatif au répertoire de travail par défaut.", + "loc.input.label.Inline": "Script inline", + "loc.input.help.Inline": "Entrez le script à exécuter.", + "loc.input.label.ScriptArguments": "Arguments de script", + "loc.input.help.ScriptArguments": "Paramètres supplémentaires à passer à PowerShell. Peuvent être des paramètres ordinaux ou nommés.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Sélectionnez la valeur de la variable ErrorActionPreference pour l'exécution du script.", + "loc.input.label.FailOnStandardError": "Échec sur une erreur standard", + "loc.input.help.FailOnStandardError": "Si la valeur est true, et si des erreurs sont écrites dans le pipeline d'erreurs ou si des données sont écrites dans le flux d'erreurs standard, cette tâche se solde par un échec.", + "loc.input.label.RestrictContextToCurrentTask": "Limiter l'étendue du contexte à la tâche active", + "loc.input.help.RestrictContextToCurrentTask": "Si cette condition est vérifiée, la tâche limite l'étendue du contexte à la tâche active uniquement. Le contexte n'est pas accessible aux autres tâches du pipeline quand l'agent privé est utilisé.", + "loc.input.label.TargetAzurePs": "Version d'Azure PowerShell", + "loc.input.help.TargetAzurePs": "Dans le cas d'agents hébergés, les versions d'Azure PowerShell prises en charge sont les suivantes : 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (file d'attente VS2017 hébergée).\nPour choisir la dernière version disponible sur l'agent, sélectionnez \"Dernière version installée\".\n\nPour les agents privés, vous pouvez spécifier la version par défaut d'Azure PowerShell via \"Spécifier la version\"", + "loc.input.label.CustomTargetAzurePs": "Version préférée d'Azure PowerShell", + "loc.input.help.CustomTargetAzurePs": "La version par défaut d'Azure PowerShell doit être une version sémantique appropriée, par exemple 1.2.3. La notation regex telle que 2.\\*,2.3.\\* n'est pas prise en charge. Le pool VS2017 hébergé prend en charge les versions de module Az suivantes : 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Utilisez PowerShell Core", + "loc.input.help.pwsh": "Si la valeur est true, dans Windows, la tâche utilise pwsh.exe à partir de votre variable PATH au lieu de powershell.exe.", + "loc.input.label.validateScriptSignature": "Valider la signature du script", + "loc.input.help.validateScriptSignature": "Si la valeur est true, la tâche vérifie d’abord que le script spécifié est signé et valide avant de l’exécuter.", + "loc.input.label.workingDirectory": "Répertoire de travail", + "loc.input.help.workingDirectory": "Répertoire de travail où le script est exécuté.", + "loc.messages.GeneratingScript": "Génération du script.", + "loc.messages.JS_FormattedCommand": "Commande mise en forme : %s", + "loc.messages.InvalidScriptArguments0": "Arguments de script '{0}' non valides. Les sauts de ligne ne sont pas autorisés.", + "loc.messages.InvalidScriptPath0": "Chemin de script '{0}' non valide. Caractères non valides spécifiés dans le chemin.", + "loc.messages.InvalidAzurePsVersion": "La version '{0}' spécifiée pour Azure PowerShell n'est pas au format approprié. Vérifiez le format. Exemple de format correct : 1.0.1", + "loc.messages.JS_ExitCode": "Arrêt de PowerShell. Code de sortie : '%s'.", + "loc.messages.JS_Stderr": "PowerShell a écrit une ou plusieurs lignes dans le flux d'erreurs standard.", + "loc.messages.ExpiredServicePrincipal": "Impossible de récupérer (fetch) le jeton d'accès pour Azure. Vérifiez si le principal de service utilisé est valide et s'il n'a pas expiré." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/it-IT/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/it-IT/resources.resjson new file mode 100644 index 000000000000..de03075839b5 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/it-IT/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Altre informazioni su questa attività](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Consente di eseguire uno script PowerShell in un ambiente Azure", + "loc.instanceNameFormat": "Script Azure PowerShell: $(ScriptType)", + "loc.releaseNotes": "È stato aggiunto il supporto per il modulo AZ e gli agenti multipiattaforma.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Opzioni della versione di Azure PowerShell", + "loc.group.displayName.advanced": "Avanzate", + "loc.input.label.ConnectedServiceNameARM": "Sottoscrizione di Azure", + "loc.input.help.ConnectedServiceNameARM": "Sottoscrizione di Azure Resource Manager da configurare prima di eseguire PowerShell", + "loc.input.label.ScriptType": "Tipo di script", + "loc.input.help.ScriptType": "Tipo dello script: Percorso file o Script inline", + "loc.input.label.ScriptPath": "Percorso script", + "loc.input.help.ScriptPath": "Percorso dello script. Deve essere un percorso completo o relativo rispetto alla directory di lavoro predefinita.", + "loc.input.label.Inline": "Script inline", + "loc.input.help.Inline": "Consente di immettere lo script da eseguire.", + "loc.input.label.ScriptArguments": "Argomenti script", + "loc.input.help.ScriptArguments": "Parametri aggiuntivi da passare a PowerShell. Possono essere ordinali o denominati.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Consente di selezionare il valore della variabile ErrorActionPreference per l'esecuzione dello script.", + "loc.input.label.FailOnStandardError": "Interrompi in caso di errore standard", + "loc.input.help.FailOnStandardError": "Se il valore è true, questa attività non riuscirà nel caso in cui vengano scritti errori nella pipeline degli errori oppure se vengono scritti dati nel flusso STDERR.", + "loc.input.label.RestrictContextToCurrentTask": "Limita l'ambito del contesto all'attività corrente", + "loc.input.help.RestrictContextToCurrentTask": "Se è true, questa attività limiterà l'ambito del contesto solo all'attività corrente e il contesto non sarà disponibile per altre attività nella pipeline quando si usa l'agente privato.", + "loc.input.label.TargetAzurePs": "Versione di Azure PowerShell", + "loc.input.help.TargetAzurePs": "In caso di agenti ospitati la versione supportata di Azure PowerShell è: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nPer selezionare l'ultima versione disponibile per l'agente ospitato, selezionare \"Ultima versione installata\".\n\nPer gli agenti privati è possibile selezionare \"Specifica versione\" per specificare la versione preferita di Azure PowerShell", + "loc.input.label.CustomTargetAzurePs": "Versione preferita di Azure PowerShell", + "loc.input.help.CustomTargetAzurePs": "La versione preferita di Azure PowerShell deve essere una versione semantica valida, ad esempio 1.2.3. Espressioni regolari come 2.\\*,2.3.\\* non sono supportate. La versione Hosted VS2017 Pool supporta attualmente le versioni seguenti del modulo Az: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Usa PowerShell Core", + "loc.input.help.pwsh": "Se è impostata su true, in Windows l'attività userà pwsh.exe da PATH invece di powershell.exe.", + "loc.input.label.validateScriptSignature": "Convalida firma script", + "loc.input.help.validateScriptSignature": "Se è True, l'attività verificherà innanzitutto che lo script specificato sia firmato e valido prima di eseguirlo.", + "loc.input.label.workingDirectory": "Directory di lavoro", + "loc.input.help.workingDirectory": "Directory di lavoro in cui viene eseguito lo script.", + "loc.messages.GeneratingScript": "Generazione dello script.", + "loc.messages.JS_FormattedCommand": "Comando formattato: %s", + "loc.messages.InvalidScriptArguments0": "Gli argomenti '{0}' dello script non sono validi. Le interruzioni di riga non sono consentite.", + "loc.messages.InvalidScriptPath0": "Il percorso '{0}' dello script non è valido. Sono stati specificati caratteri non validi.", + "loc.messages.InvalidAzurePsVersion": "Il formato della versione di Azure PowerShell '{0}' specificata non è corretto. Controllare il formato. Un esempio di formato corretto è 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell terminato con codice '%s'.", + "loc.messages.JS_Stderr": "PowerShell ha scritto una o più righe nel flusso di errore standard.", + "loc.messages.ExpiredServicePrincipal": "Non è stato possibile recuperare il token di accesso per Azure. Verificare che l'entità servizio usata sia valida e non sia scaduta." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/ja-JP/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/ja-JP/resources.resjson new file mode 100644 index 000000000000..5f60ce4b7a81 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/ja-JP/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[このタスクの詳細を表示](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Azure 環境内で PowerShell スクリプトを実行します", + "loc.instanceNameFormat": "Azure PowerShell スクリプト: $(ScriptType)", + "loc.releaseNotes": "Az モジュールとクロス プラットフォームのエージェントのサポートが追加されました。", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell バージョンのオプション", + "loc.group.displayName.advanced": "詳細設定", + "loc.input.label.ConnectedServiceNameARM": "Azure サブスクリプション", + "loc.input.help.ConnectedServiceNameARM": "PowerShell を実行する前に構成する Azure Resource Manager サブスクリプション", + "loc.input.label.ScriptType": "スクリプトの種類", + "loc.input.help.ScriptType": "スクリプトの種類: ファイル パスまたはインライン スクリプト", + "loc.input.label.ScriptPath": "スクリプト パス", + "loc.input.help.ScriptPath": "スクリプトのパス。完全修飾パスか、既定の作業ディレクトリを基準とした相対パスのいずれかです。", + "loc.input.label.Inline": "インライン スクリプト", + "loc.input.help.Inline": "実行するスクリプトを入力します。", + "loc.input.label.ScriptArguments": "スクリプトの引数", + "loc.input.help.ScriptArguments": "PowerShell に渡す追加のパラメーター。順序によるパラメーターまたは名前指定されたパラメーターのいずれかです。", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "スクリプトを実行するための ErrorActionPreference 変数の値を選択します。", + "loc.input.label.FailOnStandardError": "標準エラーで失敗", + "loc.input.help.FailOnStandardError": "これが true の場合、何らかのエラーがエラー パイプラインに書き込まれるか、何らかのデータが標準エラー ストリームに書き込まれる場合、このタスクは失敗します。", + "loc.input.label.RestrictContextToCurrentTask": "コンテキストのスコープを現在のタスクに制限する", + "loc.input.help.RestrictContextToCurrentTask": "これが true の場合、このタスクによってコンテキストのスコープが現在のタスクのみに制限されます。また、プライベート エージェントを使用している場合、このコンテキストをパイプライン内の他のタスクで使用することはできなくなります。", + "loc.input.label.TargetAzurePs": "Azure PowerShell バージョン", + "loc.input.help.TargetAzurePs": "ホステッド エージェントの場合、サポートされている Azure PowerShell のバージョンは、1.0.0、1.6.0、2.3.2、2.6.0、3.1.0 (ホステッド VS2017 キュー) です。\nエージェントで利用可能な最新バージョンを選ぶには、[Latest installed version](インストールされている最新バージョン) を選択します。\n\nプライベート エージェントの場合は、[Specify version](バージョンを指定する) を使用して優先されるバージョンの Azure PowerShell を指定できます。", + "loc.input.label.CustomTargetAzurePs": "優先される Azure PowerShell バージョン", + "loc.input.help.CustomTargetAzurePs": "優先される Azure PowerShell バージョンは、1.2.3 などの適切なセマンティック バージョンである必要があります。2.\\*、2.3.\\* などの正規表現はサポートされていません。ホステッド VS2017 プールは、現在次の Az モジュール バージョンをサポートしています: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0", + "loc.input.label.pwsh": "PowerShell Core を使用する", + "loc.input.help.pwsh": "これが true の場合、Windows 上のタスクは powershell.exe ではなく PATH からの pwsh.exe を使用します。", + "loc.input.label.validateScriptSignature": "スクリプトの署名を検証する", + "loc.input.help.validateScriptSignature": "これが true の場合、タスクはまず、指定されたスクリプトが署名され、有効であることを確認してからこれを実行します。", + "loc.input.label.workingDirectory": "作業ディレクトリ", + "loc.input.help.workingDirectory": "スクリプトが実行される作業ディレクトリ。", + "loc.messages.GeneratingScript": "スクリプトを生成しています。", + "loc.messages.JS_FormattedCommand": "フォーマット後のコマンド: %s", + "loc.messages.InvalidScriptArguments0": "スクリプトの引数 '{0}' が無効です。改行は使用できません。", + "loc.messages.InvalidScriptPath0": "スクリプト パス '{0}' が無効です。無効なパス文字が指定されました。", + "loc.messages.InvalidAzurePsVersion": "指定した Azure PowerShell バージョン '{0}' は、形式が正しくありません。形式をご確認ください。正しい形式の例は、1.0.1 です", + "loc.messages.JS_ExitCode": "PowerShell がコード '%s' で終了しました。", + "loc.messages.JS_Stderr": "PowerShell が標準エラー ストリームに 1 行以上を書き込みました。", + "loc.messages.ExpiredServicePrincipal": "Azure のアクセス トークンをフェッチできませんでした。使用されているサービス プリンシパルが有効であり、有効期限が切れていないことを確認してください。" +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/ko-KR/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/ko-KR/resources.resjson new file mode 100644 index 000000000000..b00a1a1619c4 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/ko-KR/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[이 작업에 대한 자세한 정보](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Azure 환경에서 PowerShell 스크립트 실행", + "loc.instanceNameFormat": "Azure PowerShell 스크립트: $(ScriptType)", + "loc.releaseNotes": "Az 모듈 및 플랫폼 간 에이전트에 대한 지원이 추가되었습니다.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell 버전 옵션", + "loc.group.displayName.advanced": "고급", + "loc.input.label.ConnectedServiceNameARM": "Azure 구독", + "loc.input.help.ConnectedServiceNameARM": "PowerShell을 실행하기 전에 구성할 Azure Resource Manager 구독", + "loc.input.label.ScriptType": "스크립트 유형", + "loc.input.help.ScriptType": "스크립트 유형: 파일 경로 또는 인라인 스크립트", + "loc.input.label.ScriptPath": "스크립트 경로", + "loc.input.help.ScriptPath": "스크립트의 경로입니다. 정규화된 경로이거나 기본 작업 디렉터리에 대한 상대 경로여야 합니다.", + "loc.input.label.Inline": "인라인 스크립트", + "loc.input.help.Inline": "실행할 스크립트를 입력합니다.", + "loc.input.label.ScriptArguments": "스크립트 인수", + "loc.input.help.ScriptArguments": "PowerShell에 전달할 추가 인수입니다. 서수 매개 변수나 명명된 매개 변수 중 하나일 수 있습니다.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "스크립트 실행에 대한 ErrorActionPreference 변수의 값을 선택합니다.", + "loc.input.label.FailOnStandardError": "표준 오류 시 실패", + "loc.input.help.FailOnStandardError": "이 값이 true이면 오류 파이프라인에 오류가 작성되거나 표준 오류 스트림에 데이터가 작성될 경우 이 작업은 실패하게 됩니다.", + "loc.input.label.RestrictContextToCurrentTask": "컨텍스트 범위를 현재 작업으로 제한", + "loc.input.help.RestrictContextToCurrentTask": "true이면 이 작업이 컨텍스트 범위를 현재 작업으로만 제한하고 프라이빗 에이전트를 사용할 때 파이프라인의 다른 작업에 대해 컨텍스트를 사용할 수 없게 됩니다.", + "loc.input.label.TargetAzurePs": "Azure PowerShell 버전", + "loc.input.help.TargetAzurePs": "호스트된 에이전트의 경우 지원되는 Azure PowerShell 버전은 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0(Hosted VS2017 Queue)입니다.\n에이전트에서 사용 가능한 최신 버전을 선택하려면 \"설치된 최신 버전\"을 선택합니다.\n\n사용자 에이전트의 경우 \"버전 지정\"을 사용하여 기본 Azure PowerShell 버전을 지정할 수 있습니다.", + "loc.input.label.CustomTargetAzurePs": "기본 Azure PowerShell 버전", + "loc.input.help.CustomTargetAzurePs": "기본 Azure PowerShell 버전은 올바른 의미 체계 버전(예: 1.2.3)이어야 합니다. 2.\\*,2.3.\\*와 같은 Regex는 지원되지 않습니다. Hosted VS2017 풀은 현재 Az 모듈 버전 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0을 지원합니다.", + "loc.input.label.pwsh": "PowerShell Core 사용", + "loc.input.help.pwsh": "true이면, Windows에서 작업이 powershell.exe 대신 PATH의 pwsh.exe를 사용합니다.", + "loc.input.label.validateScriptSignature": "스크립트 서명 유효성 검사", + "loc.input.help.validateScriptSignature": "true이면 작업을 실행하기 전에 먼저 지정한 스크립트가 서명되어 있고 유효한지 확인합니다.", + "loc.input.label.workingDirectory": "작업 디렉터리", + "loc.input.help.workingDirectory": "스크립트가 실행되는 작업 디렉터리입니다.", + "loc.messages.GeneratingScript": "스크립트를 생성 중입니다.", + "loc.messages.JS_FormattedCommand": "형식이 지정된 명령: %s", + "loc.messages.InvalidScriptArguments0": "스크립트 인수 '{0}'이(가) 잘못되었습니다. 줄 바꿈은 허용되지 않습니다.", + "loc.messages.InvalidScriptPath0": "스크립트 경로 '{0}'이(가) 잘못되었습니다. 잘못된 경로 문자를 지정했습니다.", + "loc.messages.InvalidAzurePsVersion": "지정한 Azure PowerShell 버전 '{0}'의 형식이 잘못되었습니다. 형식을 확인하세요. 올바른 형식의 예는 1.0.1입니다.", + "loc.messages.JS_ExitCode": "PowerShell이 코드 '%s'(으)로 종료되었습니다.", + "loc.messages.JS_Stderr": "PowerShell이 표준 오류 스트림에 하나 이상의 줄을 썼습니다.", + "loc.messages.ExpiredServicePrincipal": "Azure의 액세스 토큰을 페치할 수 없습니다. 사용한 서비스 주체가 유효하고 만료되지 않았는지 확인하세요." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/ru-RU/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/ru-RU/resources.resjson new file mode 100644 index 000000000000..c20a9b0fce5f --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/ru-RU/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[См. дополнительные сведения об этой задаче](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Выполнение скрипта PowerShell в среде Azure", + "loc.instanceNameFormat": "Сценарий Azure PowerShell: $(ScriptType)", + "loc.releaseNotes": "Добавлена поддержка модуля Az и кроссплатформенных агентов.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Параметры версии Azure PowerShell", + "loc.group.displayName.advanced": "Дополнительно", + "loc.input.label.ConnectedServiceNameARM": "Подписка Azure", + "loc.input.help.ConnectedServiceNameARM": "Подписка на Azure Resource Manager для настройки перед запуском PowerShell", + "loc.input.label.ScriptType": "Тип сценария", + "loc.input.help.ScriptType": "Тип сценария: путь к файлу или встроенный сценарий", + "loc.input.label.ScriptPath": "Путь к скрипту", + "loc.input.help.ScriptPath": "Путь к сценарию. Это должен быть полный путь или путь относительно рабочего каталога по умолчанию.", + "loc.input.label.Inline": "Встроенный сценарий", + "loc.input.help.Inline": "Введите сценарий для выполнения.", + "loc.input.label.ScriptArguments": "Аргументы скрипта", + "loc.input.help.ScriptArguments": "Дополнительные параметры для передачи в PowerShell. Могут быть как порядковыми, так и именованными.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Выберите значение переменной ErrorActionPreference для выполнения скрипта.", + "loc.input.label.FailOnStandardError": "Сбой со стандартной ошибкой", + "loc.input.help.FailOnStandardError": "Если задано значение True, задача будет завершаться сбоем при записи любых ошибок в конвейер ошибок или записи любых данных в стандартный поток ошибок.", + "loc.input.label.RestrictContextToCurrentTask": "Ограничить область контекста текущей задачей", + "loc.input.help.RestrictContextToCurrentTask": "Если задано значение true, задача ограничивает область контекста только текущей задачей и при использовании частного агента контекст будет недоступен для других задач в конвейере.", + "loc.input.label.TargetAzurePs": "Версия Azure PowerShell", + "loc.input.help.TargetAzurePs": "Для размещенных агентов поддерживаются следующие версии Azure PowerShell: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (размещенная очередь Visual Studio 2017).\nЧтобы выбрать последнюю версию, доступную в агенте, выберите пункт \"Последняя установленная версия\".\n\nДля частных агентов можно указать предпочтительную версию Azure PowerShell с помощью элемента \"Указать версию\"", + "loc.input.label.CustomTargetAzurePs": "Предпочтительная версия Azure PowerShell", + "loc.input.help.CustomTargetAzurePs": "Предпочтительная версия Azure PowerShell должна быть надлежащей семантической версией, например 1.2.3. Регулярные выражения, например 2.\\*,2.3.\\*, не поддерживаются. Размещенный пул Visual Studio 2017 сейчас поддерживает следующие версии модуля Az: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Использовать PowerShell Core", + "loc.input.help.pwsh": "Если задано значение True, в Windows задача будет использовать программу pwsh.exe, указанную в переменной PATH, вместо powershell.exe.", + "loc.input.label.validateScriptSignature": "Проверка подписи сценария", + "loc.input.help.validateScriptSignature": "Если задано значение true, задача сначала проверит, что указанный сценарий подписан и действителен, прежде чем выполнить его.", + "loc.input.label.workingDirectory": "Рабочий каталог", + "loc.input.help.workingDirectory": "Рабочий каталог, в котором выполняется скрипт.", + "loc.messages.GeneratingScript": "Формируется скрипт.", + "loc.messages.JS_FormattedCommand": "Отформатирована команда: %s", + "loc.messages.InvalidScriptArguments0": "Недопустимые аргументы скрипта \"{0}\". Разрывы строк запрещены.", + "loc.messages.InvalidScriptPath0": "Недопустимый путь к скрипту \"{0}\". Указаны символы, недопустимые в пути.", + "loc.messages.InvalidAzurePsVersion": "Указанная версия Azure PowerShell \"{0}\" имеет неправильный формат. Проверьте формат. Пример правильного формата: 1.0.1", + "loc.messages.JS_ExitCode": "Завершение работы PowerShell с кодом \"%s\".", + "loc.messages.JS_Stderr": "Оболочка PowerShell записала одну или несколько строк в стандартный поток ошибок.", + "loc.messages.ExpiredServicePrincipal": "Не удалось получить маркер доступа для Azure. Убедитесь, что используемый субъект-служба является допустимым, а срок его действия не истек." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/zh-CN/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/zh-CN/resources.resjson new file mode 100644 index 000000000000..fe4a5eb3b960 --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/zh-CN/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[详细了解此任务](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "在 Azure 环境中运行 PowerShell 脚本", + "loc.instanceNameFormat": "Azure PowerShell 脚本: $(ScriptType)", + "loc.releaseNotes": "添加了对 Azure 模块和跨平台代理的支持。", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell 版本选项", + "loc.group.displayName.advanced": "高级", + "loc.input.label.ConnectedServiceNameARM": "Azure 订阅", + "loc.input.help.ConnectedServiceNameARM": "在运行 PowerShell 之前配置的 Azure 资源管理器订阅", + "loc.input.label.ScriptType": "脚本类型", + "loc.input.help.ScriptType": "脚本类型: 文件路径或内联脚本", + "loc.input.label.ScriptPath": "脚本路径", + "loc.input.help.ScriptPath": "脚本的路径。应是完全限定的路径或相对于默认工作目录。", + "loc.input.label.Inline": "内联脚本", + "loc.input.help.Inline": "输入要执行的脚本。", + "loc.input.label.ScriptArguments": "脚本参数", + "loc.input.help.ScriptArguments": "要传递给 PowerShell 的其他参数。可以是序号或命名参数。", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "选择执行脚本的 ErrorActionPreference 变量的值。", + "loc.input.label.FailOnStandardError": "因标准错误失败", + "loc.input.help.FailOnStandardError": "如果为 true,当有错误被写入错误管道或有数据被写入标准错误流时,此任务将失败。", + "loc.input.label.RestrictContextToCurrentTask": "将上下文的范围限于当前任务", + "loc.input.help.RestrictContextToCurrentTask": "如果为 true,此任务会将上下文的范围仅限于当前任务,并且在使用专用代理时,管道中的其他任务将无法使用该上下文。", + "loc.input.label.TargetAzurePs": "Azure PowerShell 版本", + "loc.input.help.TargetAzurePs": "对于托管代理,受支持的 Azure PowerShell 版本为: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0 (托管的 VS2017 队列)。\n若要选择代理上的最新可用版本,请选择“已安装的最新版本”。\n\n对于专用代理,可以使用“指定版本”指定 Azure PowerShell 的首选版本", + "loc.input.label.CustomTargetAzurePs": "首选 Azure PowerShell 版本", + "loc.input.help.CustomTargetAzurePs": "首选 Azure PowerShell 版本需为正确的语义版本,例如 1.2.3。不支持 2.\\*、2.3.\\* 等正则表达式。托管 VS2017 池当前支持 Azure 模块版本: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0", + "loc.input.label.pwsh": "使用 PowerShell Core", + "loc.input.help.pwsh": "如果为 true,则在 Windows 上,任务将使用来自 PATH 的 pwsh.exe,而不是 powershell.exe。", + "loc.input.label.validateScriptSignature": "验证脚本签名", + "loc.input.help.validateScriptSignature": "如果为 true,则任务将首先检查以确保指定的脚本已签名并且在执行前有效。", + "loc.input.label.workingDirectory": "工作目录", + "loc.input.help.workingDirectory": "在其中运行脚本的工作目录。", + "loc.messages.GeneratingScript": "正在生成脚本。", + "loc.messages.JS_FormattedCommand": "已设置格式的命令: %s", + "loc.messages.InvalidScriptArguments0": "脚本参数“{0}”无效。不允许换行。", + "loc.messages.InvalidScriptPath0": "脚本路径“{0}”无效。指定的路径字符无效。", + "loc.messages.InvalidAzurePsVersion": "指定的 Azure PowerShell 版本“{0}”格式不正确。请检查格式。正确格式的示例为 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell 已退出,代码为“%s”。", + "loc.messages.JS_Stderr": "PowerShell 向标准错误流写入一个或多个行。", + "loc.messages.ExpiredServicePrincipal": "无法提取 Azure 的访问令牌。请确保使用的服务主体有效且未过期。" +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Strings/resources.resjson/zh-TW/resources.resjson b/_generated/AzurePowerShellV4/Strings/resources.resjson/zh-TW/resources.resjson new file mode 100644 index 000000000000..5b87db2dbbac --- /dev/null +++ b/_generated/AzurePowerShellV4/Strings/resources.resjson/zh-TW/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[深入了解此工作](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "在 Azure 環境中執行 PowerShell 指令碼", + "loc.instanceNameFormat": "Azure PowerShell 指令碼: $(ScriptType)", + "loc.releaseNotes": "新增了 Az 模組和跨平台代理程式的支援。", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell 版本選項", + "loc.group.displayName.advanced": "進階", + "loc.input.label.ConnectedServiceNameARM": "Azure 訂用帳戶", + "loc.input.help.ConnectedServiceNameARM": "執行 PowerShell 之前要設定的 Azure Resource Manager 訂用帳戶", + "loc.input.label.ScriptType": "指令碼類型", + "loc.input.help.ScriptType": "指令碼類型: 檔案路徑或內嵌指令碼", + "loc.input.label.ScriptPath": "指令碼路徑", + "loc.input.help.ScriptPath": "指令碼的路徑。必須是完整路徑名稱或預設工作目錄的相對路徑。", + "loc.input.label.Inline": "內嵌指令碼", + "loc.input.help.Inline": "請輸入要執行的指令碼。", + "loc.input.label.ScriptArguments": "指令碼引數", + "loc.input.help.ScriptArguments": "傳遞至 PowerShell 的額外引數。可以是序數或具名參數。", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "請選取用於執行指令碼的 ErrorActionPreference 變數值。", + "loc.input.label.FailOnStandardError": "發生標準錯誤的失敗", + "loc.input.help.FailOnStandardError": "若此項為 true,如果在錯誤管線中寫入任何錯誤,或在標準錯誤資料流中寫入任何資料,此工作就會失敗。", + "loc.input.label.RestrictContextToCurrentTask": "將內容範圍限制在目前的工作", + "loc.input.help.RestrictContextToCurrentTask": "若為 true,則此工作只會將內容範圍限制在目前的工作,而在使用私人代理程式時,管線中的其他工作將無法使用內容。", + "loc.input.label.TargetAzurePs": "Azure PowerShell 版本", + "loc.input.help.TargetAzurePs": "若為裝載的代理程式,則支援的 Azure PowerShell 版本為: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0 (裝載的 VS2017 佇列)。\n若要挑選代理程式上可用的最新版本,請選取 [最新安裝的版本]。\n\n若為私人代理程式,您可以使用 [指定版本] 指定慣用的 Azure PowerShell 版本", + "loc.input.label.CustomTargetAzurePs": "慣用的 Azure PowerShell 版本", + "loc.input.help.CustomTargetAzurePs": "慣用的 Azure PowerShell 版本必須是正確的語意版本,例如 1.2.3。不支援像 2.\\*,2.3.\\* 這樣的 Regex。裝載的 VS2017 集區目前支援 Az 模組版本: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0", + "loc.input.label.pwsh": "使用 PowerShell Core", + "loc.input.help.pwsh": "若此為 true,那麼在 Windows 上,工作就會使用 PATH 中的 pwsh.exe 而非 powershell.exe。", + "loc.input.label.validateScriptSignature": "驗證指令碼簽章", + "loc.input.help.validateScriptSignature": "如果此為 true,則工作會先進行檢查,確定指定的指令碼已簽署且有效,然後再執行。", + "loc.input.label.workingDirectory": "工作目錄", + "loc.input.help.workingDirectory": "指令碼執行所在的工作目錄。", + "loc.messages.GeneratingScript": "正在產生指令碼。", + "loc.messages.JS_FormattedCommand": "經過格式化的命令: %s", + "loc.messages.InvalidScriptArguments0": "指令碼引數 '{0}' 無效。不允許分行符號。", + "loc.messages.InvalidScriptPath0": "指令碼路徑 '{0}' 無效。指定的路徑字元無效。", + "loc.messages.InvalidAzurePsVersion": "指定的 Azure PowerShell 版本 '{0}' 格式不正確。請檢查格式。正確格式的範例為 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell 已結束,代碼為 '%s'。", + "loc.messages.JS_Stderr": "PowerShell 已將一或多行寫入標準錯誤資料流。", + "loc.messages.ExpiredServicePrincipal": "無法擷取 Azure 的存取權杖。請驗證使用的服務主體是否有效且未過期。" +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/ChecksForPowerShell.ps1 b/_generated/AzurePowerShellV4/Tests/ChecksForPowerShell.ps1 new file mode 100644 index 000000000000..c88aa1ffb54d --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/ChecksForPowerShell.ps1 @@ -0,0 +1,30 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Get-VstsInput { $false } -- -Name pwsh -AsBool +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +Assert-WasCalled Invoke-VstsTool -Times 1 +Assert-WasCalled Invoke-VstsTool -ArgumentsEvaluator {($args | ConvertTo-Json) -like '*powershell.exe*'} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/ChecksForPowerShellCore.ps1 b/_generated/AzurePowerShellV4/Tests/ChecksForPowerShellCore.ps1 new file mode 100644 index 000000000000..60caed9e28fe --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/ChecksForPowerShellCore.ps1 @@ -0,0 +1,31 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Get-VstsInput { $true } -- -Name pwsh -AsBool +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module +Register-Mock ConvertTo-SecureString + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +Assert-WasCalled Invoke-VstsTool -Times 1 +Assert-WasCalled Invoke-VstsTool -ArgumentsEvaluator {($args | ConvertTo-Json) -like '*pwsh.exe*'} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/ChecksForWorkingDirectory.ps1 b/_generated/AzurePowerShellV4/Tests/ChecksForWorkingDirectory.ps1 new file mode 100644 index 000000000000..4f824ae5b8c2 --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/ChecksForWorkingDirectory.ps1 @@ -0,0 +1,33 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +$input_workingDirectory = "C:\Users" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Get-VstsInput { $true } -- -Name pwsh -AsBool +Register-Mock Get-VstsInput { $input_workingDirectory } -- -Name workingDirectory -Require +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module +Register-Mock ConvertTo-SecureString + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +Assert-WasCalled Invoke-VstsTool -Times 1 +Assert-WasCalled Invoke-VstsTool -ArgumentsEvaluator {($args | ConvertTo-Json) -like '*C:\\Users*'} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/L0.ts b/_generated/AzurePowerShellV4/Tests/L0.ts new file mode 100644 index 000000000000..23000ff892d3 --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/L0.ts @@ -0,0 +1,58 @@ +/// +/// +/// + +import Q = require('q'); +import assert = require('assert'); +import path = require('path'); +var psm = require('../../../Tests/lib/psRunner'); +var psr = null; + +describe('AzurePowerShell Suite', function () { + this.timeout(parseInt(process.env.TASK_TEST_TIMEOUT) || 20000); + + before((done) => { + if (psm.testSupported()) { + psr = new psm.PSRunner(); + psr.start(); + } + + done(); + }); + + after(function () { + if (psr) { + psr.kill(); + } + }); + + if (psm.testSupported()) { + it('checks for powershell core', (done) => { + psr.run(path.join(__dirname, 'ChecksForPowerShellCore.ps1'), done); + }) + /*it('checks for powershell', (done) => { + psr.run(path.join(__dirname, 'ChecksForPowerShell.ps1'), done); + })*/ + it('checks for working directory', (done) => { + psr.run(path.join(__dirname, 'ChecksForWorkingDirectory.ps1'), done); + }) + it('performs basic flow', (done) => { + psr.run(path.join(__dirname, 'PerformsBasicFlow.ps1'), done); + }) + it('throws when otherversion is specified in a wrong format', (done) => { + psr.run(path.join(__dirname, 'ThrowsForInvalidVersion.ps1'), done); + }) + it('throws when invalid script arguments', (done) => { + psr.run(path.join(__dirname, 'ThrowsWhenInvalidScriptArguments.ps1'), done); + }) + it('throws when invalid script path', (done) => { + psr.run(path.join(__dirname, 'ThrowsWhenInvalidScriptPath.ps1'), done); + }) + it('Get-LatestModule returns the latest available module', (done) => { + psr.run(path.join(__dirname, 'Utility.Get-LatestModule.ps1'), done); + }) + it('Update-PSModulePathForHostedAgent updated psmodulepath correctly', (done) => { + psr.run(path.join(__dirname, 'Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1'), done); + }) + } +}); \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/PerformsBasicFlow.ps1 b/_generated/AzurePowerShellV4/Tests/PerformsBasicFlow.ps1 new file mode 100644 index 000000000000..6a2b2e74708d --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/PerformsBasicFlow.ps1 @@ -0,0 +1,35 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module +Register-Mock ConvertTo-SecureString + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +# Assert the error action preference was set to Continue. +Assert-AreEqual "Continue" $global:ErrorActionPreference +$global:ErrorActionPreference = 'Stop' # Reset to stop. + +# Assert the Azure helpers module was imported and invoked. +Assert-WasCalled Import-Module -- ([System.IO.Path]::GetFullPath("$PSScriptRoot\..\ps_modules\VstsAzureHelpers_")) +Assert-WasCalled Initialize-AzModule diff --git a/_generated/AzurePowerShellV4/Tests/PerformsBasicFlow_TargetScript.ps1 b/_generated/AzurePowerShellV4/Tests/PerformsBasicFlow_TargetScript.ps1 new file mode 100644 index 000000000000..53aafdebcdd8 --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/PerformsBasicFlow_TargetScript.ps1 @@ -0,0 +1,4 @@ +# Return key information. +New-Object psobject -Property @{ + Args = $args +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/ThrowsForInvalidVersion.ps1 b/_generated/AzurePowerShellV4/Tests/ThrowsForInvalidVersion.ps1 new file mode 100644 index 000000000000..5afc27858f1e --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/ThrowsForInvalidVersion.ps1 @@ -0,0 +1,15 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 + +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "foobar.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { "OtherVersion" } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { "x.y.z" } -- -Name CustomTargetAzurePs + +# Act/Assert. +Assert-Throws { + & $PSScriptRoot\..\AzurePowerShell.ps1 +} -MessagePattern "InvalidAzurePsVersion*x.y.z" diff --git a/_generated/AzurePowerShellV4/Tests/ThrowsWhenInvalidScriptArguments.ps1 b/_generated/AzurePowerShellV4/Tests/ThrowsWhenInvalidScriptArguments.ps1 new file mode 100644 index 000000000000..af93358163bc --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/ThrowsWhenInvalidScriptArguments.ps1 @@ -0,0 +1,14 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +foreach ($arguments in @( "script`rarguments", "script`narguments" )) { + Unregister-Mock Get-VstsInput + Register-Mock Get-VstsInput { $arguments } -- -Name ScriptArguments + + # Act/Assert. + Assert-Throws { + & $PSScriptRoot\..\AzurePowerShell.ps1 + } -MessagePattern "InvalidScriptArguments0*$arguments" +} diff --git a/_generated/AzurePowerShellV4/Tests/ThrowsWhenInvalidScriptPath.ps1 b/_generated/AzurePowerShellV4/Tests/ThrowsWhenInvalidScriptPath.ps1 new file mode 100644 index 000000000000..a1334790ccba --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/ThrowsWhenInvalidScriptPath.ps1 @@ -0,0 +1,16 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +foreach ($path in @( "script`rpath", "script`npath" )) { + Unregister-Mock Get-VstsInput + Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require + Register-Mock Get-VstsInput { $path } -- -Name ScriptPath + Register-Mock Get-VstsInput { "4.1.0" } -- -Name TargetAzurePs + + # Act/Assert. + Assert-Throws { + & $PSScriptRoot\..\AzurePowerShell.ps1 + } -MessagePattern "InvalidScriptPath0*$path" +} diff --git a/_generated/AzurePowerShellV4/Tests/Utility.Get-LatestModule.ps1 b/_generated/AzurePowerShellV4/Tests/Utility.Get-LatestModule.ps1 new file mode 100644 index 000000000000..71609db6ede0 --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/Utility.Get-LatestModule.ps1 @@ -0,0 +1,30 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +. $PSScriptRoot\..\Utility.ps1 + +$azModulePath = "c:\modules\az_4.1.0" + +$azModulePattern = "^az_[0-9]+\.[0-9]+\.[0-9]+$" +$versionPattern = "[0-9]+\.[0-9]+\.[0-9]+$" + +$mockDirectoryStructure = @( + @{ + Name = "az_4.1.0" + FullName = "C:\Modules\az_4.1.0" + } + @{ + Name = "az_3.6.0" + FullName = "C:\Modules\az_3.6.0" + } +) + +Register-Mock Get-ChildItem { $mockDirectoryStructure } -- -Directory -Path "C:\Modules" +Register-Mock Test-Path { $true } + +# Act +$result = Get-LatestModule -patternToMatch $azModulePattern -patternToExtract $versionPattern +# Assert +Assert-AreEqual $result.toLower() $azModulePath \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Tests/Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1 b/_generated/AzurePowerShellV4/Tests/Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1 new file mode 100644 index 000000000000..53c9c7875e54 --- /dev/null +++ b/_generated/AzurePowerShellV4/Tests/Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1 @@ -0,0 +1,47 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +. $PSScriptRoot\..\Utility.ps1 + +$azModulePath = "c:\modules\az_3.6.0" + +$azModulePattern = "^az_[0-9]+\.[0-9]+\.[0-9]+$" +$versionPattern = "[0-9]+\.[0-9]+\.[0-9]+$" + +$variableSets = @( + @{ + targetAzurePsVersion = "3.6.0" + azModuleExist = $true + } + @{ + targetAzurePsVersion = "" + azModulePath = $true + } +) + +$temp = $env:PSModulePath + +foreach ($variableSet in $variableSets) { + $env:PSModulePath = $temp + # Arrange + Unregister-Mock Get-LatestModule + if($variableSet.azModuleExist) { + Register-Mock Get-LatestModule { $azModulePath } -- -patternToMatch $azModulePattern -patternToExtract $versionPattern -Classic:$false + } else { + Register-Mock Get-LatestModule { "" } -- -patternToMatch $azModulePattern -patternToExtract $versionPattern -Classic:$false + } + + # Act + Update-PSModulePathForHostedAgent -targetAzurePs $variableSet.targetAzurePsVersion + + # Assert + if($variableSet.azModuleExist) { + Assert-IsGreaterThan -1 $env:PSModulePath.toLower().IndexOf($azModulePath) + } else { + Assert-AreEqual -1 $env:PSModulePath.toLower().IndexOf($azModulePath) + } + + Assert-IsGreaterThan 0 $env:PSModulePath.toLower().IndexOf(";") +} diff --git a/_generated/AzurePowerShellV4/ThirdPartyNotices.txt b/_generated/AzurePowerShellV4/ThirdPartyNotices.txt new file mode 100644 index 000000000000..abc33cfd772f --- /dev/null +++ b/_generated/AzurePowerShellV4/ThirdPartyNotices.txt @@ -0,0 +1,136 @@ + +THIRD-PARTY SOFTWARE NOTICES AND INFORMATION +Do Not Translate or Localize + +Azure PowerShell incorporates third party material from the projects listed below. The original copyright notice and the license under which Microsoft received such third party material are set forth below. Microsoft reserves all other rights not expressly granted, whether by implication, estoppel or otherwise. + +1. OpenSSL (http://www.openssl.org) + +%% OpenSSL NOTICES, INFORMATION, AND LICENSE BEGIN HERE +========================================= + LICENSE ISSUES + ============== + + The OpenSSL toolkit stays under a dual license, i.e. both the conditions of + the OpenSSL License and the original SSLeay license apply to the toolkit. + See below for the actual license texts. Actually both licenses are BSD-style + Open Source licenses. In case of any license issues related to OpenSSL + please contact openssl-core@openssl.org. + + OpenSSL License + --------------- + +/* ==================================================================== + * Copyright (c) 1998-2011 The OpenSSL Project. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * + * 3. All advertising materials mentioning features or use of this + * software must display the following acknowledgment: + * This product includes software developed by the OpenSSL Project + * for use in the OpenSSL Toolkit. (http://www.openssl.org/) + * + * 4. The names OpenSSL Toolkit and OpenSSL Project must not be used to + * endorse or promote products derived from this software without + * prior written permission. For written permission, please contact + * openssl-core@openssl.org. + * + * 5. Products derived from this software may not be called OpenSSL + * nor may OpenSSL appear in their names without prior written + * permission of the OpenSSL Project. + * + * 6. Redistributions of any form whatsoever must retain the following + * acknowledgment: + * This product includes software developed by the OpenSSL Project + * for use in the OpenSSL Toolkit (http://www.openssl.org/) + * + * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY + * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR + * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + * ==================================================================== + * + * This product includes cryptographic software written by Eric Young + * (eay@cryptsoft.com). This product includes software written by Tim + * Hudson (tjh@cryptsoft.com). + * + */ + + Original SSLeay License + ----------------------- + +/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) + * All rights reserved. + * + * This package is an SSL implementation written + * by Eric Young (eay@cryptsoft.com). + * The implementation was written so as to conform with Netscapes SSL. + * + * This library is free for commercial and non-commercial use as long as + * the following conditions are aheared to. The following conditions + * apply to all code found in this distribution, be it the RC4, RSA, + * lhash, DES, etc., code; not just the SSL code. The SSL documentation + * included with this distribution is covered by the same copyright terms + * except that the holder is Tim Hudson (tjh@cryptsoft.com). + * + * Copyright remains Eric Young's, and as such any Copyright notices in + * the code are not to be removed. + * If this package is used in a product, Eric Young should be given attribution + * as the author of the parts of the library used. + * This can be in the form of a textual message at program startup or + * in documentation (online or textual) provided with the package. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes cryptographic software written by + * Eric Young (eay@cryptsoft.com) + * The word 'cryptographic' can be left out if the rouines from the library + * being used are not cryptographic related :-). + * 4. If you include any Windows specific code (or a derivative thereof) from + * the apps directory (application code) you must include an acknowledgement: + * This product includes software written by Tim Hudson (tjh@cryptsoft.com) + * + * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * The licence and distribution terms for any publically available version or + * derivative of this code cannot be changed. i.e. this code cannot simply be + * copied and put under another distribution licence + * [including the GNU Public Licence.] +========================================= +END OF OpenSSL NOTICES, INFORMATION, AND LICENSE diff --git a/_generated/AzurePowerShellV4/TryMakingModuleAvailable.ps1 b/_generated/AzurePowerShellV4/TryMakingModuleAvailable.ps1 new file mode 100644 index 000000000000..71d91e944af9 --- /dev/null +++ b/_generated/AzurePowerShellV4/TryMakingModuleAvailable.ps1 @@ -0,0 +1,85 @@ +[CmdletBinding()] +param ( + [string] + $targetVersion, + + [string] [Parameter(Mandatory = $true)] [ValidateSet("Windows", "Linux", "Mac")] + $platform +) + +try { + $isWin = $platform -eq "Windows" + + . (Join-Path $PSScriptRoot "Utility.ps1") + $isHostedAgent = Test-IsHostedAgentPathPresent -isWin $isWin + + if (!$isHostedAgent) { + Write-Verbose "Module path not present as expected in hosted agent, skipping step to make module available." + $moduleSource = "privateAgent" + return + } + + if (!$targetVersion) { + Write-Verbose "Latest selected, will make use of the latest available in agent as folder." + $moduleSource = "hostedAgentFolder" + return + } + + $modulePath = Get-SavedModulePath -azurePowerShellVersion $targetVersion -isWin $isWin + if (Test-Path $modulePath) { + Write-Verbose "Az $targetVersion present at $modulePath as folder." + $moduleSource = "hostedAgentFolder" + return + } + + $moduleContainerPath = Get-SavedModuleContainerPath -isWin $isWin + $moduleZipPath = $modulePath + ".zip"; + if (Test-Path $moduleZipPath) { + Write-Verbose "Az $targetVersion present at $moduleZipPath as zip, expanding it." + Expand-ModuleZip -zipPath $moduleZipPath -destination $moduleContainerPath -isWin $isWin + Write-Verbose "Zip expanded" + $moduleSource = "hostedAgentZip" + return + } + + Write-Host "Az version $targetVersion not avaiable locally on the agent. Downloading dynamically." + + try { + Write-Verbose "Getting versions manifest from GHRelease." + $versionsManifest = Invoke-RestMethod -Method Get ` + -Headers @{ "Accept" = "application/vnd.github.VERSION.raw" } ` + -Uri "https://api.github.com/repos/Azure/az-ps-module-versions/contents/versions-manifest.json" + Write-Verbose "Versions manifest downloaded." + $downloadUrlEntity = $versionsManifest | Where-Object version -eq $targetVersion + if ($downloadUrlEntity) { + $downloadUrl = $downloadUrlEntity.files[0].download_url + Write-Verbose "Downloading Az $targetVersion from GHRelease" + (New-Object System.Net.WebClient).DownloadFile($downloadUrl, $moduleZipPath) + Write-Verbose "Download succeeded" + if (Test-Path $moduleZipPath) { + Write-Verbose "Expanding Az $targetVersion downloaded at $moduleZipPath as zip." + Expand-ModuleZip -zipPath $moduleZipPath -destination $moduleContainerPath -isWin $isWin + Write-Verbose "Zip expanded" + $moduleSource = "hostedAgentGHRelease" + return + } + } else { + Write-Verbose "Az $targetVersion not present in versions manifest from GHRelease" + } + } catch { + Write-Verbose "Failed to download from GHRelease" + Write-Verbose $_ + } + + Write-Verbose "Downloading Az $targetVersion from PSGallery." + Save-Module -Path $modulePath -Name Az -RequiredVersion $targetVersion -Force -ErrorAction Stop + $moduleSource = "hostedAgentPSGallery" +} finally { + # Telemetry + # moduleSource value will be privateAgent(in case of self hosted private agents), hostedAgentFolder(when a version is present as folder or + # when latest is selected we will use the one latest available as folder), hostedAgentZip(when the module is available as a zip locally), + # hostedAgentGHRelease(when the module zip is downloaded from our GitHub releases management), hostedAgentPSGallery(when we download from PSGallery + # using the Save-Module cmdlet). + $telemetryJsonContent = @{ targetAzurePs = $targetVersion; moduleSource = $moduleSource } | ConvertTo-Json -Compress + Write-Host "##vso[telemetry.publish area=TaskHub;feature=AzurePowerShellV4]$telemetryJsonContent" +} diff --git a/_generated/AzurePowerShellV4/UpdatePSModulePath.ps1 b/_generated/AzurePowerShellV4/UpdatePSModulePath.ps1 new file mode 100644 index 000000000000..e36160743c59 --- /dev/null +++ b/_generated/AzurePowerShellV4/UpdatePSModulePath.ps1 @@ -0,0 +1,11 @@ +[CmdletBinding()] +param +( + [String] [Parameter(Mandatory = $false)] + $targetAzurePs +) + +# Update PSModulePath for hosted agent +. "$PSScriptRoot\Utility.ps1" +CleanUp-PSModulePathForHostedAgent +Update-PSModulePathForHostedAgent -targetAzurePs $targetAzurePs \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/Utility.ps1 b/_generated/AzurePowerShellV4/Utility.ps1 new file mode 100644 index 000000000000..8e6804ffe66e --- /dev/null +++ b/_generated/AzurePowerShellV4/Utility.ps1 @@ -0,0 +1,203 @@ +function Get-SavedModuleContainerPath { + [CmdletBinding()] + param ( + [Parameter(Mandatory = $true)] + [bool] + $isWin + ) + + if ($isWin) { + return $env:SystemDrive + "\Modules"; + } else { + return "/usr/share"; + } +} + +function Test-IsHostedAgentPathPresent { + [CmdletBinding()] + param ( + [Parameter(Mandatory = $true)] + [bool] + $isWin + ) + + $containerPath = Get-SavedModuleContainerPath -isWin $isWin + return Test-Path (Join-Path $containerPath "az_*") +} + +function Get-SavedModulePath { + [CmdletBinding()] + param ( + [Parameter(Mandatory = $true)] + [string] + $azurePowerShellVersion, + + [Parameter(Mandatory = $true)] + [bool] + $isWin + ) + + $savedModulePath = Join-Path (Get-SavedModuleContainerPath -isWin $isWin) "az_$azurePowerShellVersion" + Write-Verbose "The value of the module path is: $savedModulePath" + return $savedModulePath +} + +function Expand-ModuleZip { + param ( + [string] [Parameter(Mandatory = $true)] + $zipPath, + + [string] [Parameter(Mandatory = $true)] + $destination, + + [bool] [Parameter(Mandatory=$true)] + $isWin + ) + + if ($isWin) { + $parameter = @("x", "-o$destination", "$zipPath") + $command = "$PSScriptRoot\7zip\7z.exe" + &$command @parameter + } else { + $prevProgressPref = $ProgressPreference + $ProgressPreference = 'SilentlyContinue' + Expand-Archive -Path $zipPath -DestinationPath $destination + $ProgressPreference = $prevProgressPref + } +} + +function Update-PSModulePathForHostedAgent { + [CmdletBinding()] + param([string] $targetAzurePs) + try { + if ($targetAzurePs) { + $hostedAgentAzModulePath = Get-SavedModulePath -azurePowerShellVersion $targetAzurePs -isWin $true + } + else { + $hostedAgentAzModulePath = Get-LatestModule -patternToMatch "^az_[0-9]+\.[0-9]+\.[0-9]+$" -patternToExtract "[0-9]+\.[0-9]+\.[0-9]+$" + } + $env:PSModulePath = $hostedAgentAzModulePath + ";" + $env:PSModulePath + $env:PSModulePath = $env:PSModulePath.TrimStart(';') + } finally { + Write-Verbose "The updated value of the PSModulePath is: $($env:PSModulePath)" + } +} + +function Update-PSModulePathForHostedAgentLinux { + [CmdletBinding()] + param([string] $targetAzurePs) + try { + if ($targetAzurePs) { + $hostedAgentAzModulePath = Get-SavedModulePath -azurePowerShellVersion $targetAzurePs -isWin $false + if(!(Test-Path $hostedAgentAzModulePath)) { + Write-Verbose "No module path found with this name" + throw ("Could not find the module path with given version.") + } + } + else { + $hostedAgentAzModulePath = Get-LatestModuleLinux -patternToMatch "^az_[0-9]+\.[0-9]+\.[0-9]+$" -patternToExtract "[0-9]+\.[0-9]+\.[0-9]+$" + } + $env:PSModulePath = $hostedAgentAzModulePath + ":" + $env:PSModulePath + $env:PSModulePath = $env:PSModulePath.TrimStart(':') + } finally { + Write-Verbose "The updated value of the PSModulePath is: $($env:PSModulePath)" + } +} + +function Get-LatestModule { + [CmdletBinding()] + param([string] $patternToMatch, + [string] $patternToExtract) + + $resultFolder = "" + $regexToMatch = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToMatch + $regexToExtract = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToExtract + $maxVersion = [version] "0.0.0" + $modulePath = $env:SystemDrive + "\Modules"; + + try { + if (-not (Test-Path -Path $modulePath)) { + return $resultFolder + } + + $moduleFolders = Get-ChildItem -Directory -Path $modulePath | Where-Object { $regexToMatch.IsMatch($_.Name) } + foreach ($moduleFolder in $moduleFolders) { + $moduleVersion = [version] $($regexToExtract.Match($moduleFolder.Name).Groups[0].Value) + if($moduleVersion -gt $maxVersion) { + $modulePath = [System.IO.Path]::Combine($moduleFolder.FullName,"Az\$moduleVersion\Az.psm1") + + if(Test-Path -LiteralPath $modulePath -PathType Leaf) { + $maxVersion = $moduleVersion + $resultFolder = $moduleFolder.FullName + } else { + Write-Verbose "A folder matching the module folder pattern was found at $($moduleFolder.FullName) but didn't contain a valid module file" + } + } + } + } + catch { + Write-Verbose "Attempting to find the Latest Module Folder failed with the error: $($_.Exception.Message)" + $resultFolder = "" + } + Write-Verbose "Latest module folder detected: $resultFolder" + return $resultFolder +} + +function Get-LatestModuleLinux { + [CmdletBinding()] + param([string] $patternToMatch, + [string] $patternToExtract) + + $resultFolder = "" + $regexToMatch = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToMatch + $regexToExtract = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToExtract + $maxVersion = [version] "0.0.0" + + try { + $moduleFolders = Get-ChildItem -Directory -Path $("/usr/share") | Where-Object { $regexToMatch.IsMatch($_.Name) } + foreach ($moduleFolder in $moduleFolders) { + $moduleVersion = [version] $($regexToExtract.Match($moduleFolder.Name).Groups[0].Value) + if($moduleVersion -gt $maxVersion) { + $modulePath = [System.IO.Path]::Combine($moduleFolder.FullName,"Az/$moduleVersion/Az.psm1") + + if(Test-Path -LiteralPath $modulePath -PathType Leaf) { + $maxVersion = $moduleVersion + $resultFolder = $moduleFolder.FullName + } else { + Write-Verbose "A folder matching the module folder pattern was found at $($moduleFolder.FullName) but didn't contain a valid module file" + } + } + } + } + catch { + Write-Verbose "Attempting to find the Latest Module Folder failed with the error: $($_.Exception.Message)" + $resultFolder = "" + } + Write-Verbose "Latest module folder detected: $resultFolder" + return $resultFolder +} + +function CleanUp-PSModulePathForHostedAgent { + # Clean up PSModulePath for hosted agent + $azureRMModulePath = "C:\Modules\azurerm_2.1.0" + $azureModulePath = "C:\Modules\azure_2.1.0" + $azPSModulePath = $env:PSModulePath + + if ($azPSModulePath.split(";") -contains $azureRMModulePath) { + $azPSModulePath = (($azPSModulePath).Split(";") | ? { $_ -ne $azureRMModulePath }) -join ";" + write-verbose "$azureRMModulePath removed. Restart the prompt for the changes to take effect." + } + else { + write-verbose "$azureRMModulePath is not present in $azPSModulePath" + } + + if ($azPSModulePath.split(";") -contains $azureModulePath) { + $azPSModulePath = (($azPSModulePath).Split(";") | ? { $_ -ne $azureModulePath }) -join ";" + write-verbose "$azureModulePath removed. Restart the prompt for the changes to take effect." + } + else { + write-verbose "$azureModulePath is not present in $azPSModulePath" + } + + $env:PSModulePath = $azPSModulePath +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/azurepowershell.ts b/_generated/AzurePowerShellV4/azurepowershell.ts new file mode 100644 index 000000000000..055826a0965a --- /dev/null +++ b/_generated/AzurePowerShellV4/azurepowershell.ts @@ -0,0 +1,169 @@ +import fs = require('fs'); +import path = require('path'); +import os = require('os'); +import tl = require('azure-pipelines-task-lib/task'); +import tr = require('azure-pipelines-task-lib/toolrunner'); +import * as telemetry from 'azure-pipelines-tasks-utility-common/telemetry'; + +import { AzureRMEndpoint } from 'azure-pipelines-tasks-azure-arm-rest/azure-arm-endpoint'; +var uuidV4 = require('uuid/v4'); + +function convertToNullIfUndefined(arg: T): T|null { + return arg ? arg : null; +} + +async function run() { + try { + tl.setResourcePath(path.join(__dirname, 'task.json')); + + // Get inputs. + console.log("## Validating Inputs"); + let _vsts_input_errorActionPreference: string = tl.getInput('errorActionPreference', false) || 'Stop'; + switch (_vsts_input_errorActionPreference.toUpperCase()) { + case 'STOP': + case 'CONTINUE': + case 'SILENTLYCONTINUE': + break; + default: + throw new Error(tl.loc('JS_InvalidErrorActionPreference', _vsts_input_errorActionPreference)); + } + let scriptType: string = tl.getInput('ScriptType', /*required*/true); + let scriptPath = convertToNullIfUndefined(tl.getPathInput('ScriptPath', false)); + let scriptInline: string = convertToNullIfUndefined(tl.getInput('Inline', false)); + let scriptArguments: string = convertToNullIfUndefined(tl.getInput('ScriptArguments', false)); + let _vsts_input_failOnStandardError = convertToNullIfUndefined(tl.getBoolInput('FailOnStandardError', false)); + let targetAzurePs: string = convertToNullIfUndefined(tl.getInput('TargetAzurePs', false)); + let customTargetAzurePs: string = convertToNullIfUndefined(tl.getInput('CustomTargetAzurePs', false)); + let serviceName = tl.getInput('ConnectedServiceNameARM',/*required*/true); + let endpointObject= await new AzureRMEndpoint(serviceName).getEndpoint(); + let input_workingDirectory = tl.getPathInput('workingDirectory', /*required*/ true, /*check*/ true); + let isDebugEnabled = (process.env['SYSTEM_DEBUG'] || "").toLowerCase() === "true"; + + // string constants + let otherVersion = "OtherVersion" + + if (targetAzurePs == otherVersion) { + if (customTargetAzurePs != "") { + targetAzurePs = customTargetAzurePs; + } + else { + console.log(tl.loc('InvalidAzurePsVersion',customTargetAzurePs)); + } + } + else { + targetAzurePs = "" + } + + var endpoint = JSON.stringify(endpointObject); + + if (scriptType.toUpperCase() == 'FILEPATH') { + if (!tl.stats(scriptPath).isFile() || !scriptPath.toUpperCase().match(/\.PS1$/)) { + throw new Error(tl.loc('JS_InvalidFilePath', scriptPath)); + } + } + console.log("## Validating Inputs Complete"); + + // Generate the script contents. + console.log("## Initializing Az module"); + console.log(tl.loc('GeneratingScript')); + let contents: string[] = []; + + if (isDebugEnabled) { + contents.push("$VerbosePreference = 'continue'"); + } + + const makeModuleAvailableScriptPath = path.join(path.resolve(__dirname), 'TryMakingModuleAvailable.ps1'); + contents.push(`${makeModuleAvailableScriptPath} -targetVersion '${targetAzurePs}' -platform Linux`); + + let azFilePath = path.join(path.resolve(__dirname), 'InitializeAz.ps1'); + contents.push(`$ErrorActionPreference = '${_vsts_input_errorActionPreference}'`); + if(targetAzurePs == "") { + contents.push(`${azFilePath} -endpoint '${endpoint}'`); + } + else { + contents.push(`${azFilePath} -endpoint '${endpoint}' -targetAzurePs ${targetAzurePs}`); + } + + if(scriptArguments == null) + { + scriptArguments = ""; + } + + if (scriptType.toUpperCase() == 'FILEPATH') { + contents.push(`. '${scriptPath.replace(/'/g, "''")}' ${scriptArguments}`.trim()); + console.log(tl.loc('JS_FormattedCommand', contents[contents.length - 1])); + } + else { + contents.push(scriptInline); + } + + // Write the script to disk. + tl.assertAgent('2.115.0'); + let tempDirectory = tl.getVariable('agent.tempDirectory'); + tl.checkPath(tempDirectory, `${tempDirectory} (agent.tempDirectory)`); + let filePath = path.join(tempDirectory, uuidV4() + '.ps1'); + await fs.writeFile( + filePath, + '\ufeff' + contents.join(os.EOL), // Prepend the Unicode BOM character. + { encoding: 'utf8' }, // Since UTF8 encoding is specified, node will + function (err) { // encode the BOM into its UTF8 binary sequence. + if (err) throw err; + console.log('Saved!'); + }); + console.log("## Az module initialization Complete"); + console.log("## Beginning Script Execution"); + // Run the script. + // + // Note, prefer "pwsh" over "powershell". At some point we can remove support for "powershell". + // + // Note, use "-Command" instead of "-File" to match the Windows implementation. Refer to + // comment on Windows implementation for an explanation why "-Command" is preferred. + let powershell = tl.tool(tl.which('pwsh') || tl.which('powershell') || tl.which('pwsh', true)) + .arg('-NoLogo') + .arg('-NoProfile') + .arg('-NonInteractive') + .arg('-ExecutionPolicy') + .arg('Unrestricted') + .arg('-Command') + .arg(`. '${filePath.replace(/'/g, "''")}'`); + + let options = { + cwd: input_workingDirectory, + failOnStdErr: false, + errStream: process.stdout, // Direct all output to STDOUT, otherwise the output may appear out + outStream: process.stdout, // of order since Node buffers it's own STDOUT but not STDERR. + ignoreReturnCode: true + }; + + // Listen for stderr. + let stderrFailure = false; + if (_vsts_input_failOnStandardError) { + powershell.on('stderr', (data) => { + stderrFailure = true; + }); + } + + // Run bash. + let exitCode: number = await powershell.exec(options); + + // Fail on exit code. + if (exitCode !== 0) { + tl.setResult(tl.TaskResult.Failed, tl.loc('JS_ExitCode', exitCode)); + } + + // Fail on stderr. + if (stderrFailure) { + tl.setResult(tl.TaskResult.Failed, tl.loc('JS_Stderr')); + } + console.log("## Script Execution Complete"); + } + catch (err) { + // troubleshoot link + const troubleshoot = "https://aka.ms/azurepowershelltroubleshooting"; + console.log(`##[error] run failed: For troubleshooting, refer: ${troubleshoot}`); + tl.setResult(tl.TaskResult.Failed, err.message || 'run() failed'); + } +} + + +run(); diff --git a/_generated/AzurePowerShellV4/icon.png b/_generated/AzurePowerShellV4/icon.png new file mode 100644 index 000000000000..039b77995289 Binary files /dev/null and b/_generated/AzurePowerShellV4/icon.png differ diff --git a/_generated/AzurePowerShellV4/icon.svg b/_generated/AzurePowerShellV4/icon.svg new file mode 100644 index 000000000000..9d97d76e24ec --- /dev/null +++ b/_generated/AzurePowerShellV4/icon.svg @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + + + diff --git a/_generated/AzurePowerShellV4/make.json b/_generated/AzurePowerShellV4/make.json new file mode 100644 index 000000000000..c413ae080f32 --- /dev/null +++ b/_generated/AzurePowerShellV4/make.json @@ -0,0 +1,51 @@ +{ + "rm": [ + { + "items": [ + "node_modules/azure-pipelines-tasks-azure-arm-rest/node_modules/azure-pipelines-task-lib", + "node_modules/azure-pipelines-tasks-utility-common/node_modules/azure-pipelines-task-lib", + "node_modules/azure-pipelines-tool-lib/node_modules/azure-pipelines-task-lib" + ], + "options": "-Rf" + } + ], + "common": [ + { + "module": "../Common/VstsAzureHelpers_", + "type": "ps" + }, + { + "module": "../Common/TlsHelper_", + "type": "ps" + } + ], + "externals": { + "nugetv2": [ + { + "name": "VstsTaskSdk", + "version": "0.11.0", + "repository": "https://www.powershellgallery.com/api/v2/", + "cp": [ + { + "source": [ + "*.dll", + "*.ps1", + "*.psd1", + "*.psm1", + "lib.json", + "Strings" + ], + "dest": "ps_modules/VstsTaskSdk/", + "options": "-R" + } + ] + } + ], + "archivePackages": [ + { + "url": "https://vstsagenttools.blob.core.windows.net/tools/7zip/1/7zip.zip", + "dest": "./" + } + ] + } +} diff --git a/_generated/AzurePowerShellV4/package-lock.json b/_generated/AzurePowerShellV4/package-lock.json new file mode 100644 index 000000000000..bcf1873f0987 --- /dev/null +++ b/_generated/AzurePowerShellV4/package-lock.json @@ -0,0 +1,786 @@ +{ + "name": "azure-powershell-v4", + "requires": true, + "lockfileVersion": 1, + "dependencies": { + "@azure/msal-common": { + "version": "9.1.1", + "resolved": "https://registry.npmjs.org/@azure/msal-common/-/msal-common-9.1.1.tgz", + "integrity": "sha512-we9xR8lvu47fF0h+J8KyXoRy9+G/fPzm3QEa2TrdR3jaVS3LKAyE2qyMuUkNdbVkvzl8Zr9f7l+IUSP22HeqXw==" + }, + "@azure/msal-node": { + "version": "1.14.5", + "resolved": "https://registry.npmjs.org/@azure/msal-node/-/msal-node-1.14.5.tgz", + "integrity": "sha512-NcVdMfn8Z3ogN+9RjOSF7uwf2Gki5DEJl0BdDSL83KUAgVAobtkZi5W8EqxbJLrTO/ET0jv5DregrcR5qg2pEA==", + "requires": { + "@azure/msal-common": "^9.0.1", + "jsonwebtoken": "^8.5.1", + "uuid": "^8.3.0" + }, + "dependencies": { + "uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" + } + } + }, + "@types/concat-stream": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/@types/concat-stream/-/concat-stream-1.6.0.tgz", + "integrity": "sha1-OU2+C7X+5Gs42JZzXoto7yOQ0A0=", + "requires": { + "@types/node": "*" + } + }, + "@types/form-data": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/@types/form-data/-/form-data-0.0.33.tgz", + "integrity": "sha1-yayFsqX9GENbjIXZ7LUObWyJP/g=", + "requires": { + "@types/node": "*" + } + }, + "@types/jsonwebtoken": { + "version": "8.5.9", + "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.9.tgz", + "integrity": "sha512-272FMnFGzAVMGtu9tkr29hRL6bZj4Zs1KZNeHLnKqAvp06tAIcarTMwOh8/8bz4FmKRcMxZhZNeUAQsNLoiPhg==", + "requires": { + "@types/node": "*" + } + }, + "@types/mocha": { + "version": "5.2.7", + "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-5.2.7.tgz", + "integrity": "sha512-NYrtPht0wGzhwe9+/idPaBB+TqkY9AhTvOLMkThm0IoEfLaiVQZwBwyJ5puCkO3AUCWrmcoePjp2mbFocKy4SQ==" + }, + "@types/node": { + "version": "10.17.50", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.50.tgz", + "integrity": "sha512-vwX+/ija9xKc/z9VqMCdbf4WYcMTGsI0I/L/6shIF3qXURxZOhPQlPRHtjTpiNhAwn0paMJzlOQqw6mAGEQnTA==" + }, + "@types/q": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.0.7.tgz", + "integrity": "sha512-0WS7XU7sXzQ7J1nbnMKKYdjrrFoO3YtZYgUzeV8JFXffPnHfvSJQleR70I8BOAsOm14i4dyaAZ3YzqIl1YhkXQ==" + }, + "@types/qs": { + "version": "6.9.5", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.5.tgz", + "integrity": "sha512-/JHkVHtx/REVG0VVToGRGH2+23hsYLHdyG+GrvoUGlGAd0ErauXDyvHtRI/7H7mzLm+tBCKA7pfcpkQ1lf58iQ==" + }, + "@types/semver": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-5.5.0.tgz", + "integrity": "sha512-41qEJgBH/TWgo5NFSvBCJ1qkoi3Q6ONSF2avrHq1LVEZfYpdHmj0y9SuTK+u9ZhG1sYQKBL1AWXKyLWP4RaUoQ==" + }, + "@types/uuid": { + "version": "3.4.10", + "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-3.4.10.tgz", + "integrity": "sha512-BgeaZuElf7DEYZhWYDTc/XcLZXdVgFkVSTa13BqKvbnmUrxr3TJFKofUxCtDO9UQOdhnV+HPOESdHiHKZOJV1A==" + }, + "agent-base": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-5.1.1.tgz", + "integrity": "sha512-TMeqbNl2fMW0nMjTEPOwe3J/PRFP4vqeoNuQMG0HlMrtm5QxKqdvAkZ1pRBQ/ulIyDD5Yq0nJ7YbdD8ey0TO3g==" + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "asap": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", + "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" + }, + "async-mutex": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/async-mutex/-/async-mutex-0.4.0.tgz", + "integrity": "sha512-eJFZ1YhRR8UN8eBLoNzcDPcy/jqjsg6I1AP+KvWQX80BqOSW1oJPJXDylPUEeMr2ZQvHgnQ//Lp6f3RQ1zI7HA==", + "requires": { + "tslib": "^2.4.0" + } + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" + }, + "azure-pipelines-task-lib": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-3.1.10.tgz", + "integrity": "sha512-S5iH1mD9G7boOV0kjVsFkqlz/6FOZjQAajshj3ajzQK9Wr3XRq9JK9+grJP4ityG6of28X2XWpieFdJLhnWLoA==", + "requires": { + "minimatch": "3.0.4", + "mockery": "^1.7.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.4", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + }, + "azure-pipelines-tasks-azure-arm-rest": { + "version": "3.217.1", + "resolved": "https://registry.npmjs.org/azure-pipelines-tasks-azure-arm-rest/-/azure-pipelines-tasks-azure-arm-rest-3.217.1.tgz", + "integrity": "sha512-OjO/G+/bQhtW769xQ/U0c+4DeEBPEa6ya+wyTS+ntge/EaMgha7IN+7TR7aMdlgs741Bn1AB/n5DmOqIJXXxSw==", + "requires": { + "@azure/msal-node": "1.14.5", + "@types/jsonwebtoken": "^8.5.8", + "@types/mocha": "^5.2.7", + "@types/node": "^10.17.0", + "@types/q": "1.5.4", + "async-mutex": "^0.4.0", + "azure-pipelines-task-lib": "^3.1.0", + "https-proxy-agent": "^4.0.0", + "jsonwebtoken": "^8.5.1", + "node-fetch": "^2.6.7", + "q": "1.5.1", + "typed-rest-client": "1.8.4" + }, + "dependencies": { + "@types/q": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.4.tgz", + "integrity": "sha512-1HcDas8SEj4z1Wc696tH56G8OlRaH/sqZOynNNB+HF0WOeXPaxTtbYzJY2oEfiUxjSKjhCKr+MvR7dCHcEelug==" + } + } + }, + "azure-pipelines-tasks-utility-common": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/azure-pipelines-tasks-utility-common/-/azure-pipelines-tasks-utility-common-3.0.3.tgz", + "integrity": "sha512-kG2RWtfYf3t+y0I+yJACRLOB1rJYjUf2dLlxwXqgOrAU1g2amVNTLbEcL/VSqqrFQq2UwvBoVVppDbwPyfhm9Q==", + "requires": { + "@types/node": "^10.17.0", + "azure-pipelines-task-lib": "^3.1.0", + "azure-pipelines-tool-lib": "^1.0.2", + "js-yaml": "3.13.1", + "semver": "^5.4.1" + }, + "dependencies": { + "azure-pipelines-task-lib": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-3.1.10.tgz", + "integrity": "sha512-S5iH1mD9G7boOV0kjVsFkqlz/6FOZjQAajshj3ajzQK9Wr3XRq9JK9+grJP4ityG6of28X2XWpieFdJLhnWLoA==", + "requires": { + "minimatch": "3.0.4", + "mockery": "^1.7.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.4", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + } + } + }, + "azure-pipelines-tool-lib": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/azure-pipelines-tool-lib/-/azure-pipelines-tool-lib-1.0.2.tgz", + "integrity": "sha512-0wWAqIY1n9UvcHP3AKLWIVd5fTPKaUOZJ50bNwW3NMpFlfpxZDAi8Ck9wvVm9oBdwHVYZsQy3WfK71DiBWQiHg==", + "requires": { + "@types/semver": "^5.3.0", + "@types/uuid": "^3.4.5", + "azure-pipelines-task-lib": "^3.1.0", + "semver": "^5.7.0", + "semver-compare": "^1.0.0", + "typed-rest-client": "^1.8.4", + "uuid": "^3.3.2" + }, + "dependencies": { + "azure-pipelines-task-lib": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-3.1.10.tgz", + "integrity": "sha512-S5iH1mD9G7boOV0kjVsFkqlz/6FOZjQAajshj3ajzQK9Wr3XRq9JK9+grJP4ityG6of28X2XWpieFdJLhnWLoA==", + "requires": { + "minimatch": "3.0.4", + "mockery": "^1.7.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.4", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + } + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "buffer-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + }, + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "requires": { + "ms": "2.1.2" + }, + "dependencies": { + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + } + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" + }, + "ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" + }, + "form-data": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.5.1.tgz", + "integrity": "sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA==", + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "get-port": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/get-port/-/get-port-3.2.0.tgz", + "integrity": "sha1-3Xzn3hh8Bsi/NTeWrHHgmfCYDrw=" + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "dependencies": { + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "requires": { + "brace-expansion": "^1.1.7" + } + } + } + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "requires": { + "function-bind": "^1.1.1" + } + }, + "http-basic": { + "version": "8.1.3", + "resolved": "https://registry.npmjs.org/http-basic/-/http-basic-8.1.3.tgz", + "integrity": "sha512-/EcDMwJZh3mABI2NhGfHOGOeOZITqfkEO4p/xK+l3NpyncIHUQBoMvCSF/b5GqvKtySC2srL/GGG3+EtlqlmCw==", + "requires": { + "caseless": "^0.12.0", + "concat-stream": "^1.6.2", + "http-response-object": "^3.0.1", + "parse-cache-control": "^1.0.1" + } + }, + "http-response-object": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/http-response-object/-/http-response-object-3.0.2.tgz", + "integrity": "sha512-bqX0XTF6fnXSQcEJ2Iuyr75yVakyjIDCqroJQ/aHfSdlM743Cwqoi2nDYMzLGWUcuTWGWy8AAvOKXTfiv6q9RA==", + "requires": { + "@types/node": "^10.0.3" + } + }, + "https-proxy-agent": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-4.0.0.tgz", + "integrity": "sha512-zoDhWrkR3of1l9QAL8/scJZyLu8j/gBkcwcaQOZh7Gyh/+uJQzGVETdgT30akuwkpL8HTRfssqI3BZuV18teDg==", + "requires": { + "agent-base": "5", + "debug": "4" + } + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "interpret": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.4.0.tgz", + "integrity": "sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA==" + }, + "is-core-module": { + "version": "2.10.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.10.0.tgz", + "integrity": "sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg==", + "requires": { + "has": "^1.0.3" + } + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsonwebtoken": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", + "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", + "requires": { + "jws": "^3.2.2", + "lodash.includes": "^4.3.0", + "lodash.isboolean": "^3.0.3", + "lodash.isinteger": "^4.0.4", + "lodash.isnumber": "^3.0.3", + "lodash.isplainobject": "^4.0.6", + "lodash.isstring": "^4.0.1", + "lodash.once": "^4.0.0", + "ms": "^2.1.1", + "semver": "^5.6.0" + } + }, + "jwa": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", + "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", + "requires": { + "buffer-equal-constant-time": "1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "jws": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", + "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", + "requires": { + "jwa": "^1.4.1", + "safe-buffer": "^5.0.1" + } + }, + "lodash.includes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", + "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" + }, + "lodash.isboolean": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", + "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" + }, + "lodash.isinteger": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", + "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" + }, + "lodash.isnumber": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", + "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" + }, + "lodash.isplainobject": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", + "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" + }, + "lodash.isstring": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", + "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" + }, + "lodash.once": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", + "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" + }, + "mime-db": { + "version": "1.45.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.45.0.tgz", + "integrity": "sha512-CkqLUxUk15hofLoLyljJSrukZi8mAtgd+yE5uO4tqRZsdsAJKv0O+rFMhVDRJgozy+yG6md5KwuXhD4ocIoP+w==" + }, + "mime-types": { + "version": "2.1.28", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.28.tgz", + "integrity": "sha512-0TO2yJ5YHYr7M2zzT7gDU1tbwHxEUWBCLt0lscSNpcdAfFyJOVEpRYNS7EXVcTLNj/25QO8gulHC5JtTzSE2UQ==", + "requires": { + "mime-db": "1.45.0" + } + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "mockery": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/mockery/-/mockery-1.7.0.tgz", + "integrity": "sha1-9O3g2HUMHJcnwnLqLGBiniyaHE8=" + }, + "ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" + }, + "node-fetch": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.8.tgz", + "integrity": "sha512-RZ6dBYuj8dRSfxpUSu+NsdF1dpPpluJxwOp+6IoDp/sH2QNDSvurYsAa+F1WxY2RjA1iP93xhcsUoYbF2XBqVg==", + "requires": { + "whatwg-url": "^5.0.0" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "requires": { + "wrappy": "1" + } + }, + "parse-cache-control": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parse-cache-control/-/parse-cache-control-1.0.1.tgz", + "integrity": "sha1-juqz5U+laSD+Fro493+iGqzC104=" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + }, + "promise": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/promise/-/promise-8.1.0.tgz", + "integrity": "sha512-W04AqnILOL/sPRXziNicCjSNRruLAuIHEOVBazepu0545DDNGYHz7ar9ZgZ1fMU8/MA4mVxp5rkBWRi6OXIy3Q==", + "requires": { + "asap": "~2.0.6" + } + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=" + }, + "qs": { + "version": "6.9.4", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.4.tgz", + "integrity": "sha512-A1kFqHekCTM7cz0udomYUoYNWjBebHm/5wzU/XqrBRBNWectVH0QIiN+NEcZ0Dte5hvzHwbr8+XQmguPhJ6WdQ==" + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + } + } + }, + "rechoir": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", + "integrity": "sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw==", + "requires": { + "resolve": "^1.1.6" + } + }, + "resolve": { + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", + "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", + "requires": { + "is-core-module": "^2.9.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + }, + "semver-compare": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", + "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=" + }, + "shelljs": { + "version": "0.8.5", + "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.8.5.tgz", + "integrity": "sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==", + "requires": { + "glob": "^7.0.0", + "interpret": "^1.0.0", + "rechoir": "^0.6.2" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + } + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" + }, + "sync-request": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/sync-request/-/sync-request-6.1.0.tgz", + "integrity": "sha512-8fjNkrNlNCrVc/av+Jn+xxqfCjYaBoHqCsDz6mt030UMxJGr+GSfCV1dQt2gRtlL63+VPidwDVLr7V2OcTSdRw==", + "requires": { + "http-response-object": "^3.0.1", + "sync-rpc": "^1.2.1", + "then-request": "^6.0.0" + } + }, + "sync-rpc": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/sync-rpc/-/sync-rpc-1.3.6.tgz", + "integrity": "sha512-J8jTXuZzRlvU7HemDgHi3pGnh/rkoqR/OZSjhTyyZrEkkYQbk7Z33AXp37mkPfPpfdOuj7Ex3H/TJM1z48uPQw==", + "requires": { + "get-port": "^3.1.0" + } + }, + "then-request": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/then-request/-/then-request-6.0.2.tgz", + "integrity": "sha512-3ZBiG7JvP3wbDzA9iNY5zJQcHL4jn/0BWtXIkagfz7QgOL/LqjCEOBQuJNZfu0XYnv5JhKh+cDxCPM4ILrqruA==", + "requires": { + "@types/concat-stream": "^1.6.0", + "@types/form-data": "0.0.33", + "@types/node": "^8.0.0", + "@types/qs": "^6.2.31", + "caseless": "~0.12.0", + "concat-stream": "^1.6.0", + "form-data": "^2.2.0", + "http-basic": "^8.1.1", + "http-response-object": "^3.0.1", + "promise": "^8.0.0", + "qs": "^6.4.0" + }, + "dependencies": { + "@types/node": { + "version": "8.10.66", + "resolved": "https://registry.npmjs.org/@types/node/-/node-8.10.66.tgz", + "integrity": "sha512-tktOkFUA4kXx2hhhrB8bIFb5TbwzS4uOhKEmwiD+NoiL0qtP2OQ9mFldbgD4dV1djrlBYP6eBuQZiWjuHUpqFw==" + } + } + }, + "tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" + }, + "tslib": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", + "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==" + }, + "tunnel": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", + "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==" + }, + "typed-rest-client": { + "version": "1.8.4", + "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.8.4.tgz", + "integrity": "sha512-MyfKKYzk3I6/QQp6e1T50py4qg+c+9BzOEl2rBmQIpStwNUoqQ73An+Tkfy9YuV7O+o2mpVVJpe+fH//POZkbg==", + "requires": { + "qs": "^6.9.1", + "tunnel": "0.0.6", + "underscore": "^1.12.1" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" + }, + "typescript": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.2.tgz", + "integrity": "sha512-e4ERvRV2wb+rRZ/IQeb3jm2VxBsirQLpQhdxplZ2MEzGvDkkMmPglecnNDfSUBivMjP93vRbngYYDQqQ/78bcQ==", + "dev": true + }, + "underscore": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.1.tgz", + "integrity": "sha512-hzSoAVtJF+3ZtiFX0VgfFPHEDRm7Y/QPjGyNo4TVdnDTdft3tr8hEkD25a1jC+TjTuE7tkHGKkhwCgs9dgBB2g==" + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + }, + "uuid": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", + "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" + }, + "webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" + }, + "whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "requires": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" + } + } +} diff --git a/_generated/AzurePowerShellV4/package.json b/_generated/AzurePowerShellV4/package.json new file mode 100644 index 000000000000..2df4109aa445 --- /dev/null +++ b/_generated/AzurePowerShellV4/package.json @@ -0,0 +1,17 @@ +{ + "name": "azure-powershell-v4", + "author": { + "name": "Microsoft Corporation" + }, + "dependencies": { + "@types/mocha": "^5.2.7", + "@types/node": "^10.17.0", + "@types/q": "1.0.7", + "azure-pipelines-task-lib": "3.1.10", + "azure-pipelines-tasks-azure-arm-rest": "3.217.1", + "azure-pipelines-tasks-utility-common": "^3.0.3" + }, + "devDependencies": { + "typescript": "4.0.2" + } +} diff --git a/_generated/AzurePowerShellV4/task.json b/_generated/AzurePowerShellV4/task.json new file mode 100644 index 000000000000..75459a52b1f0 --- /dev/null +++ b/_generated/AzurePowerShellV4/task.json @@ -0,0 +1,213 @@ +{ + "id": "72A1931B-EFFB-4D2E-8FD8-F8472A07CB62", + "name": "AzurePowerShell", + "friendlyName": "Azure PowerShell", + "description": "Run a PowerShell script within an Azure environment", + "helpMarkDown": "[Learn more about this task](https://go.microsoft.com/fwlink/?LinkID=613749)", + "helpUrl": "https://aka.ms/azurepowershelltroubleshooting", + "category": "Deploy", + "visibility": [ + "Build", + "Release" + ], + "runsOn": [ + "Agent", + "DeploymentGroup" + ], + "author": "Microsoft Corporation", + "version": { + "Major": 4, + "Minor": 226, + "Patch": 1 + }, + "releaseNotes": "Added support for Az Module and cross platform agents.", + "groups": [ + { + "name": "AzurePowerShellVersionOptions", + "displayName": "Azure PowerShell version options", + "isExpanded": true + }, + { + "name": "advanced", + "displayName": "Advanced", + "isExpanded": false + } + ], + "minimumAgentVersion": "2.115.0", + "inputs": [ + { + "name": "ConnectedServiceNameARM", + "aliases": [ + "azureSubscription" + ], + "type": "connectedService:AzureRM", + "label": "Azure Subscription", + "defaultValue": "", + "required": true, + "helpMarkDown": "Azure Resource Manager subscription to configure before running PowerShell", + "properties": { + "EndpointFilterRule": "ScopeLevel != AzureMLWorkspace" + } + }, + { + "name": "ScriptType", + "type": "radio", + "label": "Script Type", + "required": false, + "helpMarkDown": "Type of the script: File Path or Inline Script", + "defaultValue": "FilePath", + "options": { + "FilePath": "Script File Path", + "InlineScript": "Inline Script" + } + }, + { + "name": "ScriptPath", + "type": "filePath", + "label": "Script Path", + "defaultValue": "", + "required": false, + "helpMarkDown": "Path of the script. Should be fully qualified path or relative to the default working directory.", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "Inline", + "type": "multiLine", + "label": "Inline Script", + "required": false, + "defaultValue": "# You can write your azure powershell scripts inline here. \n# You can also pass predefined and custom variables to this script using arguments", + "helpMarkDown": "Enter the script to execute.", + "visibleRule": "ScriptType = InlineScript", + "properties": { + "resizable": "true", + "rows": "10", + "maxLength": "5000" + } + }, + { + "name": "ScriptArguments", + "type": "string", + "label": "Script Arguments", + "defaultValue": "", + "visibleRule": "ScriptType = FilePath", + "required": false, + "properties": { + "editorExtension": "ms.vss-services-azure.parameters-grid" + }, + "helpMarkDown": "Additional parameters to pass to PowerShell. Can be either ordinal or named parameters." + }, + { + "name": "errorActionPreference", + "type": "pickList", + "label": "ErrorActionPreference", + "required": false, + "defaultValue": "stop", + "options": { + "stop": "Stop", + "continue": "Continue", + "silentlyContinue": "SilentlyContinue" + }, + "helpMarkDown": "Select the value of the ErrorActionPreference variable for executing the script." + }, + { + "name": "FailOnStandardError", + "type": "boolean", + "label": "Fail on Standard Error", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, this task will fail if any errors are written to the error pipeline, or if any data is written to the Standard Error stream." + }, + { + "name": "RestrictContextToCurrentTask", + "type": "boolean", + "label": "Restrict scope of context to current task", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, this task will restrict the scope of context to current task only and the context will not be available to other tasks in the pipeline when using private agent." + }, + { + "name": "TargetAzurePs", + "aliases": [ + "azurePowerShellVersion" + ], + "type": "radio", + "label": "Azure PowerShell Version", + "defaultValue": "OtherVersion", + "required": false, + "options": { + "LatestVersion": "Latest installed version", + "OtherVersion": "Specify other version" + }, + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "In case of hosted agents, the supported Azure PowerShell Version is: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nTo pick the latest version available on the agent, select \"Latest installed version\".\n\nFor private agents you can specify preferred version of Azure PowerShell using \"Specify version\"" + }, + { + "name": "CustomTargetAzurePs", + "aliases": [ + "preferredAzurePowerShellVersion" + ], + "type": "string", + "label": "Preferred Azure PowerShell Version", + "defaultValue": "", + "required": true, + "visibleRule": "TargetAzurePs = OtherVersion", + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "Preferred Azure PowerShell Version needs to be a proper semantic version eg. 1.2.3. Regex like 2.\\*,2.3.\\* is not supported. The Hosted VS2017 Pool currently supports Az module version: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0" + }, + { + "name": "pwsh", + "type": "boolean", + "label": "Use PowerShell Core", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, then on Windows the task will use pwsh.exe from your PATH instead of powershell.exe.", + "groupName": "advanced" + }, + { + "name": "validateScriptSignature", + "type": "boolean", + "label": "Validate script signature", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, then the task will first check to make sure specified script is signed and valid before executing it.", + "groupName": "advanced", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "workingDirectory", + "type": "filePath", + "label": "Working Directory", + "required": false, + "defaultValue": "", + "helpMarkDown": "Working directory where the script is run.", + "groupName": "advanced" + } + ], + "instanceNameFormat": "Azure PowerShell script: $(ScriptType)", + "execution": { + "PowerShell3": { + "target": "azurepowershell.ps1", + "platforms": [ + "windows" + ] + }, + "Node10": { + "target": "azurepowershell.js", + "argumentFormat": "" + } + }, + "messages": { + "GeneratingScript": "Generating script.", + "JS_FormattedCommand": "Formatted command: %s", + "InvalidScriptArguments0": "Invalid script arguments '{0}'. Line breaks are not allowed.", + "InvalidScriptPath0": "Invalid script path '{0}'. Invalid path characters specified.", + "InvalidAzurePsVersion": "The Azure PowerShell version '{0}' specified is not in the correct format. Please check the format. An example of correct format is 1.0.1", + "JS_ExitCode": "PowerShell exited with code '%s'.", + "JS_Stderr": "PowerShell wrote one or more lines to the standard error stream.", + "ExpiredServicePrincipal": "Could not fetch access token for Azure. Verify if the Service Principal used is valid and not expired." + }, + "_buildConfigMapping": { + "Default": "4.226.1", + "Node16-225": "4.226.0" + } +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/task.loc.json b/_generated/AzurePowerShellV4/task.loc.json new file mode 100644 index 000000000000..0eea91fba629 --- /dev/null +++ b/_generated/AzurePowerShellV4/task.loc.json @@ -0,0 +1,213 @@ +{ + "id": "72A1931B-EFFB-4D2E-8FD8-F8472A07CB62", + "name": "AzurePowerShell", + "friendlyName": "ms-resource:loc.friendlyName", + "description": "ms-resource:loc.description", + "helpMarkDown": "ms-resource:loc.helpMarkDown", + "helpUrl": "https://aka.ms/azurepowershelltroubleshooting", + "category": "Deploy", + "visibility": [ + "Build", + "Release" + ], + "runsOn": [ + "Agent", + "DeploymentGroup" + ], + "author": "Microsoft Corporation", + "version": { + "Major": 4, + "Minor": 226, + "Patch": 1 + }, + "releaseNotes": "ms-resource:loc.releaseNotes", + "groups": [ + { + "name": "AzurePowerShellVersionOptions", + "displayName": "ms-resource:loc.group.displayName.AzurePowerShellVersionOptions", + "isExpanded": true + }, + { + "name": "advanced", + "displayName": "ms-resource:loc.group.displayName.advanced", + "isExpanded": false + } + ], + "minimumAgentVersion": "2.115.0", + "inputs": [ + { + "name": "ConnectedServiceNameARM", + "aliases": [ + "azureSubscription" + ], + "type": "connectedService:AzureRM", + "label": "ms-resource:loc.input.label.ConnectedServiceNameARM", + "defaultValue": "", + "required": true, + "helpMarkDown": "ms-resource:loc.input.help.ConnectedServiceNameARM", + "properties": { + "EndpointFilterRule": "ScopeLevel != AzureMLWorkspace" + } + }, + { + "name": "ScriptType", + "type": "radio", + "label": "ms-resource:loc.input.label.ScriptType", + "required": false, + "helpMarkDown": "ms-resource:loc.input.help.ScriptType", + "defaultValue": "FilePath", + "options": { + "FilePath": "Script File Path", + "InlineScript": "Inline Script" + } + }, + { + "name": "ScriptPath", + "type": "filePath", + "label": "ms-resource:loc.input.label.ScriptPath", + "defaultValue": "", + "required": false, + "helpMarkDown": "ms-resource:loc.input.help.ScriptPath", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "Inline", + "type": "multiLine", + "label": "ms-resource:loc.input.label.Inline", + "required": false, + "defaultValue": "# You can write your azure powershell scripts inline here. \n# You can also pass predefined and custom variables to this script using arguments", + "helpMarkDown": "ms-resource:loc.input.help.Inline", + "visibleRule": "ScriptType = InlineScript", + "properties": { + "resizable": "true", + "rows": "10", + "maxLength": "5000" + } + }, + { + "name": "ScriptArguments", + "type": "string", + "label": "ms-resource:loc.input.label.ScriptArguments", + "defaultValue": "", + "visibleRule": "ScriptType = FilePath", + "required": false, + "properties": { + "editorExtension": "ms.vss-services-azure.parameters-grid" + }, + "helpMarkDown": "ms-resource:loc.input.help.ScriptArguments" + }, + { + "name": "errorActionPreference", + "type": "pickList", + "label": "ms-resource:loc.input.label.errorActionPreference", + "required": false, + "defaultValue": "stop", + "options": { + "stop": "Stop", + "continue": "Continue", + "silentlyContinue": "SilentlyContinue" + }, + "helpMarkDown": "ms-resource:loc.input.help.errorActionPreference" + }, + { + "name": "FailOnStandardError", + "type": "boolean", + "label": "ms-resource:loc.input.label.FailOnStandardError", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.FailOnStandardError" + }, + { + "name": "RestrictContextToCurrentTask", + "type": "boolean", + "label": "ms-resource:loc.input.label.RestrictContextToCurrentTask", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.RestrictContextToCurrentTask" + }, + { + "name": "TargetAzurePs", + "aliases": [ + "azurePowerShellVersion" + ], + "type": "radio", + "label": "ms-resource:loc.input.label.TargetAzurePs", + "defaultValue": "OtherVersion", + "required": false, + "options": { + "LatestVersion": "Latest installed version", + "OtherVersion": "Specify other version" + }, + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "ms-resource:loc.input.help.TargetAzurePs" + }, + { + "name": "CustomTargetAzurePs", + "aliases": [ + "preferredAzurePowerShellVersion" + ], + "type": "string", + "label": "ms-resource:loc.input.label.CustomTargetAzurePs", + "defaultValue": "", + "required": true, + "visibleRule": "TargetAzurePs = OtherVersion", + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "ms-resource:loc.input.help.CustomTargetAzurePs" + }, + { + "name": "pwsh", + "type": "boolean", + "label": "ms-resource:loc.input.label.pwsh", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.pwsh", + "groupName": "advanced" + }, + { + "name": "validateScriptSignature", + "type": "boolean", + "label": "ms-resource:loc.input.label.validateScriptSignature", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.validateScriptSignature", + "groupName": "advanced", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "workingDirectory", + "type": "filePath", + "label": "ms-resource:loc.input.label.workingDirectory", + "required": false, + "defaultValue": "", + "helpMarkDown": "ms-resource:loc.input.help.workingDirectory", + "groupName": "advanced" + } + ], + "instanceNameFormat": "ms-resource:loc.instanceNameFormat", + "execution": { + "PowerShell3": { + "target": "azurepowershell.ps1", + "platforms": [ + "windows" + ] + }, + "Node10": { + "target": "azurepowershell.js", + "argumentFormat": "" + } + }, + "messages": { + "GeneratingScript": "ms-resource:loc.messages.GeneratingScript", + "JS_FormattedCommand": "ms-resource:loc.messages.JS_FormattedCommand", + "InvalidScriptArguments0": "ms-resource:loc.messages.InvalidScriptArguments0", + "InvalidScriptPath0": "ms-resource:loc.messages.InvalidScriptPath0", + "InvalidAzurePsVersion": "ms-resource:loc.messages.InvalidAzurePsVersion", + "JS_ExitCode": "ms-resource:loc.messages.JS_ExitCode", + "JS_Stderr": "ms-resource:loc.messages.JS_Stderr", + "ExpiredServicePrincipal": "ms-resource:loc.messages.ExpiredServicePrincipal" + }, + "_buildConfigMapping": { + "Default": "4.226.1", + "Node16-225": "4.226.0" + } +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4/tsconfig.json b/_generated/AzurePowerShellV4/tsconfig.json new file mode 100644 index 000000000000..6a07b24acf54 --- /dev/null +++ b/_generated/AzurePowerShellV4/tsconfig.json @@ -0,0 +1,7 @@ +{ + "compilerOptions": { + "target": "ES6", + "module": "commonjs", + "skipLibCheck": true + } +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/AzurePowerShell.ps1 b/_generated/AzurePowerShellV4_Node16/AzurePowerShell.ps1 new file mode 100644 index 000000000000..1212b0efaa6e --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/AzurePowerShell.ps1 @@ -0,0 +1,298 @@ +Trace-VstsEnteringInvocation $MyInvocation +Import-VstsLocStrings "$PSScriptRoot\Task.json" + +# Get inputs. +$scriptType = Get-VstsInput -Name ScriptType -Require +$scriptPath = Get-VstsInput -Name ScriptPath +$scriptInline = Get-VstsInput -Name Inline +$scriptArguments = Get-VstsInput -Name ScriptArguments +$__vsts_input_errorActionPreference = Get-VstsInput -Name errorActionPreference +$__vsts_input_failOnStandardError = Get-VstsInput -Name FailOnStandardError -AsBool +$targetAzurePs = Get-VstsInput -Name TargetAzurePs +$customTargetAzurePs = Get-VstsInput -Name CustomTargetAzurePs +$input_pwsh = Get-VstsInput -Name pwsh -AsBool +$input_workingDirectory = Get-VstsInput -Name workingDirectory -Require +$restrictContext = Get-VstsInput -Name RestrictContextToCurrentTask -AsBool +$validateScriptSignature = Get-VstsInput -Name validateScriptSignature -AsBool + +Write-Host "## Validating Inputs" +# Validate the script path and args do not contains new-lines. Otherwise, it will +# break invoking the script via Invoke-Expression. +if ($scriptType -eq "FilePath") { + if ($scriptPath -match '[\r\n]' -or [string]::IsNullOrWhitespace($scriptPath)) { + throw (Get-VstsLocString -Key InvalidScriptPath0 -ArgumentList $scriptPath) + } +} + +if ($scriptArguments -match '[\r\n]') { + throw (Get-VstsLocString -Key InvalidScriptArguments0 -ArgumentList $scriptArguments) +} + +# string constants +$otherVersion = "OtherVersion" +$latestVersion = "LatestVersion" + +if ($targetAzurePs -eq $otherVersion) { + if ($customTargetAzurePs -eq $null) { + throw (Get-VstsLocString -Key InvalidAzurePsVersion $customTargetAzurePs) + } else { + $targetAzurePs = $customTargetAzurePs.Trim() + } +} + +$pattern = "^[0-9]+\.[0-9]+\.[0-9]+$" +$regex = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $pattern + +if ($targetAzurePs -eq $latestVersion) { + $targetAzurePs = "" +} elseif (-not($regex.IsMatch($targetAzurePs))) { + throw (Get-VstsLocString -Key InvalidAzurePsVersion -ArgumentList $targetAzurePs) +} +Write-Host "## Validating Inputs Complete" + +. $PSScriptRoot\TryMakingModuleAvailable.ps1 -targetVersion "$targetAzurePs" -platform Windows + +if ($validateScriptSignature) { + try { + if ($scriptType -ne "InlineScript") { + Write-Host "## Validating Script Signature" + + # Validate script is signed + $scriptSignature = Get-AuthenticodeSignature $scriptPath + if ($scriptSignature.Status -eq "NotSigned") { + throw "Object does not have a digital signature. Please ensure your script is signed and try again." + } + elseif ($scriptSignature.Status -ne "Valid") { + throw "Digital signature of the object did not verify. Please ensure your script is properly signed and try again." + } + + Write-Host "## Validating Script Signature Complete" + } + } + catch + { + $errorMsg = $_.Exception.Message + throw "Unable to validate script signature: $errorMsg" + } +} + +Write-Host "## Initializing Az module" +. "$PSScriptRoot\Utility.ps1" + +$serviceName = Get-VstsInput -Name ConnectedServiceNameARM -Require +$endpoint = Get-VstsEndpoint -Name $serviceName -Require +CleanUp-PSModulePathForHostedAgent +Update-PSModulePathForHostedAgent -targetAzurePs $targetAzurePs +$vstsEndpoint = Get-VstsEndpoint -Name SystemVssConnection -Require +$vstsAccessToken = $vstsEndpoint.auth.parameters.AccessToken + +# troubleshoot link +$troubleshoot = "https://aka.ms/azurepowershelltroubleshooting" +try +{ + # Initialize Azure. + Import-Module $PSScriptRoot\ps_modules\VstsAzureHelpers_ + $encryptedToken = ConvertTo-SecureString $vstsAccessToken -AsPlainText -Force + Initialize-AzModule -Endpoint $endpoint -connectedServiceNameARM $serviceName ` + -azVersion $targetAzurePs -encryptedToken $encryptedToken -isPSCore $input_pwsh + Write-Host "## Az module initialization Complete" + $success = $true +} +finally { + if (!$success) { + Write-VstsTaskError "Initializing Az module failed: For troubleshooting, refer: $troubleshoot" + } +} + +Write-Host "## Beginning Script Execution" +try { + if ($input_pwsh) + { + # Generate the script contents. + Write-Host (Get-VstsLocString -Key 'GeneratingScript') + $UpdatePSModulePathArgument = $null; + if ($targetAzurePs) + { + $UpdatePSModulePathArgument = "-targetAzurePs $targetAzurePs" + } + + $contents = @() + $contents += "`$ErrorActionPreference = '$__vsts_input_errorActionPreference'" + if ($env:system_debug -eq "true") { + $contents += "`$VerbosePreference = 'continue'" + } + + $contents += ". '$PSScriptRoot\UpdatePSModulePath.ps1' $UpdatePSModulePathArgument" + if ($scriptType -eq "InlineScript") { + $contents += "$scriptInline".Replace("`r`n", "`n").Replace("`n", "`r`n") + } else { + $contents += ". '$("$scriptPath".Replace("'", "''"))' $scriptArguments".Trim() + } + + # Write the script to disk. + $__vstsAzPSScriptPath = [System.IO.Path]::Combine($env:Agent_TempDirectory, ([guid]::NewGuid().ToString() + ".ps1")); + $joinedContents = [System.String]::Join( + ([System.Environment]::NewLine), + $contents) + $null = [System.IO.File]::WriteAllText( + $__vstsAzPSScriptPath, + $joinedContents, + ([System.Text.Encoding]::UTF8)) + + # Prepare the external command values. + # + # Note, use "-Command" instead of "-File". On PowerShell v4 and V3 when using "-File", terminating + # errors do not cause a non-zero exit code. + if ($input_pwsh) { + $powershellPath = Get-Command -Name pwsh.exe -CommandType Application | Select-Object -First 1 -ExpandProperty Path + } else { + $powershellPath = Get-Command -Name powershell.exe -CommandType Application | Select-Object -First 1 -ExpandProperty Path + } + Assert-VstsPath -LiteralPath $powershellPath -PathType 'Leaf' + $arguments = "-NoLogo -NoProfile -NonInteractive -ExecutionPolicy Unrestricted -Command `". '$($__vstsAzPSScriptPath.Replace("'", "''"))'`"" + $splat = @{ + 'FileName' = $powershellPath + 'Arguments' = $arguments + 'WorkingDirectory' = $input_workingDirectory + } + + # Switch to "Continue". + $global:ErrorActionPreference = 'Continue' + $failed = $false + + # Run the script. + Write-Host '========================== Starting Command Output ===========================' + if (!$__vsts_input_failOnStandardError) { + Invoke-VstsTool @splat + } + else { + $inError = $false + $errorLines = New-Object System.Text.StringBuilder + Invoke-VstsTool @splat 2>&1 | + ForEach-Object { + if ($_ -is [System.Management.Automation.ErrorRecord]) { + # Buffer the error lines. + $failed = $true + $inError = $true + $null = $errorLines.AppendLine("$($_.Exception.Message)") + + # Write to verbose to mitigate if the process hangs. + Write-Verbose "STDERR: $($_.Exception.Message)" + } else { + # Flush the error buffer. + if ($inError) { + $inError = $false + $message = $errorLines.ToString().Trim() + $null = $errorLines.Clear() + if ($message) { + Write-VstsTaskError -Message $message + } + } + + Write-Host "$_" + } + } + + # Flush the error buffer one last time. + if ($inError) { + $inError = $false + $message = $errorLines.ToString().Trim() + $null = $errorLines.Clear() + if ($message) { + Write-VstsTaskError -Message $message + } + } + } + + # Fail if any errors. + if ($failed) { + Write-VstsSetResult -Result 'Failed' -Message "Error detected" -DoNotThrow + } + } + else + { + # Trace the expression as it will be invoked. + $__vstsAzPSInlineScriptPath = $null + If ($scriptType -eq "InlineScript") { + $scriptArguments = $null + $__vstsAzPSInlineScriptPath = [System.IO.Path]::Combine($env:Agent_TempDirectory, ([guid]::NewGuid().ToString() + ".ps1")); + ($scriptInline | Out-File $__vstsAzPSInlineScriptPath) + $scriptPath = $__vstsAzPSInlineScriptPath + } + + $scriptCommand = "& '$($scriptPath.Replace("'", "''"))' $scriptArguments" + Remove-Variable -Name scriptType + Remove-Variable -Name scriptPath + Remove-Variable -Name scriptInline + Remove-Variable -Name scriptArguments + + # Remove all commands imported from VstsTaskSdk, other than Out-Default. + # Remove all commands imported from VstsAzureHelpers_. + Get-ChildItem -LiteralPath function: | + Where-Object { + ($_.ModuleName -eq 'VstsTaskSdk' -and $_.Name -ne 'Out-Default') -or + ($_.Name -eq 'Invoke-VstsTaskScript') -or + ($_.ModuleName -eq 'VstsAzureHelpers_' ) + } | + Remove-Item + + # For compatibility with the legacy handler implementation, set the error action + # preference to continue. An implication of changing the preference to Continue, + # is that Invoke-VstsTaskScript will no longer handle setting the result to failed. + $global:ErrorActionPreference = 'Continue' + + # Undocumented VstsTaskSdk variable so Verbose/Debug isn't converted to ##vso[task.debug]. + # Otherwise any content the ad-hoc script writes to the verbose pipeline gets dropped by + # the agent when System.Debug is not set. + $global:__vstsNoOverrideVerbose = $true + + # Run the user's script. Redirect the error pipeline to the output pipeline to enable + # a couple goals due to compatibility with the legacy handler implementation: + # 1) STDERR from external commands needs to be converted into error records. Piping + # the redirected error output to an intermediate command before it is piped to + # Out-Default will implicitly perform the conversion. + # 2) The task result needs to be set to failed if an error record is encountered. + # As mentioned above, the requirement to handle this is an implication of changing + # the error action preference. + ([scriptblock]::Create($scriptCommand)) | + ForEach-Object { + Remove-Variable -Name scriptCommand + Write-Host "##[command]$_" + . $_ 2>&1 + } | + ForEach-Object { + if($_ -is [System.Management.Automation.ErrorRecord]) { + if($_.FullyQualifiedErrorId -eq "NativeCommandError" -or $_.FullyQualifiedErrorId -eq "NativeCommandErrorMessage") { + ,$_ + if($__vsts_input_failOnStandardError -eq $true) { + "##vso[task.complete result=Failed]" + } + } + else { + if($__vsts_input_errorActionPreference -eq "continue") { + ,$_ + if($__vsts_input_failOnStandardError -eq $true) { + "##vso[task.complete result=Failed]" + } + } + elseif($__vsts_input_errorActionPreference -eq "stop") { + throw $_ + } + } + } else { + ,$_ + } + } + } + +} +finally { + if ($__vstsAzPSInlineScriptPath -and (Test-Path -LiteralPath $__vstsAzPSInlineScriptPath) ) { + Remove-Item -LiteralPath $__vstsAzPSInlineScriptPath -ErrorAction 'SilentlyContinue' + } + + Import-Module $PSScriptRoot\ps_modules\VstsAzureHelpers_ + Remove-EndpointSecrets + Disconnect-AzureAndClearContext -restrictContext $restrictContext -ErrorAction SilentlyContinue +} +Write-Host "## Script Execution Complete" \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/InitializeAz.ps1 b/_generated/AzurePowerShellV4_Node16/InitializeAz.ps1 new file mode 100644 index 000000000000..076d87fe029c --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/InitializeAz.ps1 @@ -0,0 +1,107 @@ +[CmdletBinding()] +param +( + [String] [Parameter(Mandatory = $true)] + $endpoint, + + [String] [Parameter(Mandatory = $false)] + $targetAzurePs +) + +$endpointObject = ConvertFrom-Json $endpoint +$moduleName = "Az.Accounts" +$environmentName = $endpointObject.environment + +. "$PSScriptRoot/Utility.ps1" +Update-PSModulePathForHostedAgentLinux -targetAzurePs $targetAzurePs + +if($targetAzurePs -eq ""){ + $module = Get-Module -Name $moduleName -ListAvailable | Sort-Object Version -Descending | Select-Object -First 1 +} +else{ + $modules = Get-Module -Name $moduleName -ListAvailable + foreach ($moduleVal in $modules) { + # $moduleVal.Path will have value like /usr/local/share/powershell/Modules/Az.Accounts/1.2.1/Az.Accounts.psd1 + $azModulePath = Split-Path (Split-Path (Split-Path $moduleVal.Path -Parent) -Parent) -Parent + $azModulePath = $azModulePath + "/Az/*" + $azModuleVersion = split-path -path $azModulePath -Leaf -Resolve + if($azModuleVersion -eq $targetAzurePs) { + $module = $moduleVal + break + } + } +} + +if (!$module) { + # Will handle localization later + Write-Verbose "No module found with name: $moduleName" + throw ("Could not find the module Az.Accounts with given version. If the module was recently installed, retry after restarting the Azure Pipelines task agent.") +} + +# Import the module. +Write-Host "##[command]Import-Module -Name $($module.Path) -Global" +$module = Import-Module -Name $module.Path -Global -PassThru -Force + +# Clear context +Write-Host "##[command]Clear-AzContext -Scope CurrentUser -Force -ErrorAction SilentlyContinue" +$null = Clear-AzContext -Scope CurrentUser -Force -ErrorAction SilentlyContinue +Write-Host "##[command]Clear-AzContext -Scope Process" +$null = Clear-AzContext -Scope Process + +$scopeLevel = "Subscription" +if($endpointObject.scopeLevel) { + $scopeLevel = $endpointObject.scopeLevel +} +$processScope = @{ Scope = "Process" } + +function Format-Splat { + [CmdletBinding()] + param([Parameter(Mandatory = $true)][hashtable]$Hashtable) + + # Collect the parameters (names and values) in an array. + $parameters = foreach ($key in $Hashtable.Keys) { + $value = $Hashtable[$key] + # If the value is a bool, format the parameter as a switch (ending with ':'). + if ($value -is [bool]) { "-$($key):" } else { "-$key" } + $value + } + + "$parameters" # String join the array. +} + +if ($endpointObject.scheme -eq 'ServicePrincipal') { + try { + if ($endpointObject.authenticationType -ieq 'SPNKey') { + $psCredential = New-Object System.Management.Automation.PSCredential( + $endpointObject.servicePrincipalClientID, + (ConvertTo-SecureString $endpointObject.servicePrincipalKey -AsPlainText -Force)) + Write-Host "##[command]Connect-AzAccount -ServicePrincipal -Tenant $($endpointObject.tenantId) -Credential $psCredential -Environment $environmentName @processScope" + $null = Connect-AzAccount -ServicePrincipal -Tenant $endpointObject.tenantId ` + -Credential $psCredential ` + -Environment $environmentName @processScope -WarningAction SilentlyContinue + } + else { + # Provide an additional, custom, credentials-related error message. Will handle localization later + throw ("Only SPN credential auth scheme is supported for non windows agent.") + } + } + catch { + # Provide an additional, custom, credentials-related error message. Will handle localization later + Write-Host "Exception is : $($_.Exception.Message)" + throw (New-Object System.Exception("There was an error with the service principal used for the deployment.", $_.Exception)) + } + + if($scopeLevel -eq "Subscription") + { + $SubscriptionId = $endpointObject.subscriptionId + $TenantId = $endpointObject.tenantId + $additional = @{ TenantId = $TenantId } + + Write-Host "##[command] Set-AzContext -SubscriptionId $SubscriptionId $(Format-Splat $additional)" + $null = Set-AzContext -SubscriptionId $SubscriptionId @additional + } +} +else { + # Provide an additional, custom, credentials-related error message. Will handle localization later + throw ("Only SPN credential auth scheme is supported for non windows agent.") +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/de-DE/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/de-DE/resources.resjson new file mode 100644 index 000000000000..44d372e42cb4 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/de-DE/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Weitere Informationen zu dieser Aufgabe](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "PowerShell-Skript innerhalb einer Azure-Umgebung ausführen", + "loc.instanceNameFormat": "Azure PowerShell-Skript: $(ScriptType)", + "loc.releaseNotes": "Unterstützung für Az-Modul und plattformübergreifende Agents hinzugefügt.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell-Versionsoptionen", + "loc.group.displayName.advanced": "Erweitert", + "loc.input.label.ConnectedServiceNameARM": "Azure-Abonnement", + "loc.input.help.ConnectedServiceNameARM": "Azure Resource Manager-Abonnement, das vor dem Ausführen von PowerShell konfiguriert wird.", + "loc.input.label.ScriptType": "Skripttyp", + "loc.input.help.ScriptType": "Der Typ des Skripts: Dateipfad oder Inlineskript.", + "loc.input.label.ScriptPath": "Skriptpfad", + "loc.input.help.ScriptPath": "Der Pfad des Skripts. Es muss sich um den vollqualifizierten Pfad oder einen Pfad relativ zum Standardarbeitsverzeichnis handeln.", + "loc.input.label.Inline": "Inlineskript", + "loc.input.help.Inline": "Geben Sie das Skript ein, das ausgeführt werden soll.", + "loc.input.label.ScriptArguments": "Skriptargumente", + "loc.input.help.ScriptArguments": "Zusätzliche Argumente, die an PowerShell übergeben werden sollen. Entweder Ordnungszahl- oder benannte Parameter.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Wählen Sie den Wert der Variablen \"ErrorActionPreference\" für die Skriptausführung.", + "loc.input.label.FailOnStandardError": "Fehler bei Standardfehler.", + "loc.input.help.FailOnStandardError": "Wenn dieser Wert TRUE ist, tritt ein Aufgabenfehler auf, wenn Fehler in die Fehlerpipeline oder Daten in den Standard-Fehlerdatenstrom geschrieben werden.", + "loc.input.label.RestrictContextToCurrentTask": "Kontextbereich auf aktuelle Aufgabe beschränken", + "loc.input.help.RestrictContextToCurrentTask": "Wenn diese Option auf TRUE festgelegt ist, beschränkt diese Aufgabe den Kontextbereich nur auf die aktuelle Aufgabe, und der Kontext steht bei Verwendung des privaten Agents für andere Aufgaben in der Pipeline nicht zur Verfügung.", + "loc.input.label.TargetAzurePs": "Azure PowerShell-Version", + "loc.input.help.TargetAzurePs": "Im Falle gehosteter Agents werden die folgenden Azure PowerShell-Versionen unterstützt: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (gehostete VS2017-Warteschlange).\nWenn Sie die neueste für den Agent verfügbare Version auswählen möchten, wählen Sie \"Neueste installierte Version\" aus.\n\nFür private Agents können Sie mithilfe von \"Version angeben\" die bevorzugte Version von Azure PowerShell festlegen.", + "loc.input.label.CustomTargetAzurePs": "Bevorzugte Azure PowerShell-Version", + "loc.input.help.CustomTargetAzurePs": "Die bevorzugte Azure PowerShell-Version muss einem ordnungsgemäßen semantischen Versionsmuster folgen, z. B. \"1.2.3\". Reguläre Ausdrücke wie 2.\\*,2.3.\\* werden nicht unterstützt. Der gehostete VS2017-Pool unterstützt aktuell die folgenden Az-Modulversionen: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "PowerShell Core verwenden", + "loc.input.help.pwsh": "Sofern TRUE, verwendet die Aufgabe unter Windows anstelle von \"powershell.exe\" die in PATH festgelegte \"pwsh.exe\".", + "loc.input.label.validateScriptSignature": "Skriptsignatur überprüfen", + "loc.input.help.validateScriptSignature": "Wenn dies der Fall ist, überprüft die Aufgabe zunächst, ob das angegebene Skript signiert und gültig ist, bevor es ausgeführt wird.", + "loc.input.label.workingDirectory": "Arbeitsverzeichnis", + "loc.input.help.workingDirectory": "Arbeitsverzeichnis zum Ausführen des Skripts.", + "loc.messages.GeneratingScript": "Skript wird erstellt.", + "loc.messages.JS_FormattedCommand": "Formatierter Befehl: %s", + "loc.messages.InvalidScriptArguments0": "Ungültige Skriptargumente \"{0}\". Zeilenumbrüche sind unzulässig.", + "loc.messages.InvalidScriptPath0": "Ungültiger Skriptpfad \"{0}\". Es wurden ungültige Pfadzeichen angegeben.", + "loc.messages.InvalidAzurePsVersion": "Die angegebene Azure PowerShell-Version \"{0}\" weist nicht das richtige Format auf. Überprüfen Sie das Format. Ein Beispiel für das richtige Format ist etwa 1.0.1.", + "loc.messages.JS_ExitCode": "PowerShell wurde beendet mit dem Code \"%s\".", + "loc.messages.JS_Stderr": "PowerShell hat mindestens eine Zeile in den Standardfehlerstream geschrieben.", + "loc.messages.ExpiredServicePrincipal": "Das Zugriffstoken für Azure konnte nicht abgerufen werden. Stellen Sie sicher, dass der verwendete Dienstprinzipal gültig und nicht abgelaufen ist." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/en-US/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/en-US/resources.resjson new file mode 100644 index 000000000000..5357601c22f5 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/en-US/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Learn more about this task](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Run a PowerShell script within an Azure environment", + "loc.instanceNameFormat": "Azure PowerShell script: $(ScriptType)", + "loc.releaseNotes": "Added support for Az Module and cross platform agents.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell version options", + "loc.group.displayName.advanced": "Advanced", + "loc.input.label.ConnectedServiceNameARM": "Azure Subscription", + "loc.input.help.ConnectedServiceNameARM": "Azure Resource Manager subscription to configure before running PowerShell", + "loc.input.label.ScriptType": "Script Type", + "loc.input.help.ScriptType": "Type of the script: File Path or Inline Script", + "loc.input.label.ScriptPath": "Script Path", + "loc.input.help.ScriptPath": "Path of the script. Should be fully qualified path or relative to the default working directory.", + "loc.input.label.Inline": "Inline Script", + "loc.input.help.Inline": "Enter the script to execute.", + "loc.input.label.ScriptArguments": "Script Arguments", + "loc.input.help.ScriptArguments": "Additional parameters to pass to PowerShell. Can be either ordinal or named parameters.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Select the value of the ErrorActionPreference variable for executing the script.", + "loc.input.label.FailOnStandardError": "Fail on Standard Error", + "loc.input.help.FailOnStandardError": "If this is true, this task will fail if any errors are written to the error pipeline, or if any data is written to the Standard Error stream.", + "loc.input.label.RestrictContextToCurrentTask": "Restrict scope of context to current task", + "loc.input.help.RestrictContextToCurrentTask": "If this is true, this task will restrict the scope of context to current task only and the context will not be available to other tasks in the pipeline when using private agent.", + "loc.input.label.TargetAzurePs": "Azure PowerShell Version", + "loc.input.help.TargetAzurePs": "In case of hosted agents, the supported Azure PowerShell Version is: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nTo pick the latest version available on the agent, select \"Latest installed version\".\n\nFor private agents you can specify preferred version of Azure PowerShell using \"Specify version\"", + "loc.input.label.CustomTargetAzurePs": "Preferred Azure PowerShell Version", + "loc.input.help.CustomTargetAzurePs": "Preferred Azure PowerShell Version needs to be a proper semantic version eg. 1.2.3. Regex like 2.\\*,2.3.\\* is not supported. The Hosted VS2017 Pool currently supports Az module version: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Use PowerShell Core", + "loc.input.help.pwsh": "If this is true, then on Windows the task will use pwsh.exe from your PATH instead of powershell.exe.", + "loc.input.label.validateScriptSignature": "Validate script signature", + "loc.input.help.validateScriptSignature": "If this is true, then the task will first check to make sure specified script is signed and valid before executing it.", + "loc.input.label.workingDirectory": "Working Directory", + "loc.input.help.workingDirectory": "Working directory where the script is run.", + "loc.messages.GeneratingScript": "Generating script.", + "loc.messages.JS_FormattedCommand": "Formatted command: %s", + "loc.messages.InvalidScriptArguments0": "Invalid script arguments '{0}'. Line breaks are not allowed.", + "loc.messages.InvalidScriptPath0": "Invalid script path '{0}'. Invalid path characters specified.", + "loc.messages.InvalidAzurePsVersion": "The Azure PowerShell version '{0}' specified is not in the correct format. Please check the format. An example of correct format is 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell exited with code '%s'.", + "loc.messages.JS_Stderr": "PowerShell wrote one or more lines to the standard error stream.", + "loc.messages.ExpiredServicePrincipal": "Could not fetch access token for Azure. Verify if the Service Principal used is valid and not expired." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/es-ES/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/es-ES/resources.resjson new file mode 100644 index 000000000000..9f596d3fdf27 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/es-ES/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Obtener más información acerca de esta tarea](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Ejecutar un script de PowerShell en un entorno de Azure", + "loc.instanceNameFormat": "Script de Azure PowerShell: $(ScriptType)", + "loc.releaseNotes": "Se ha agregado compatibilidad con el módulo Az y los agentes multiplataforma.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Opciones de versión de Azure PowerShell", + "loc.group.displayName.advanced": "Avanzado", + "loc.input.label.ConnectedServiceNameARM": "Suscripción a Azure", + "loc.input.help.ConnectedServiceNameARM": "Suscripción de Azure Resource Manager para configurar antes de ejecutar PowerShell", + "loc.input.label.ScriptType": "Tipo de script", + "loc.input.help.ScriptType": "Tipo del script: ruta de acceso del archivo o script en línea", + "loc.input.label.ScriptPath": "Ruta de acceso del script", + "loc.input.help.ScriptPath": "Ruta de acceso del script. Debe ser una ruta de acceso completa o relativa al directorio de trabajo predeterminado.", + "loc.input.label.Inline": "Script alineado", + "loc.input.help.Inline": "Escriba el script que se va a ejecutar.", + "loc.input.label.ScriptArguments": "Argumentos de script", + "loc.input.help.ScriptArguments": "Parámetros adicionales que pasar a PowerShell. Pueden ser parámetros ordinales o con nombre.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Seleccione el valor de la variable ErrorActionPreference para ejecutar el script.", + "loc.input.label.FailOnStandardError": "Error si se produce un error estándar", + "loc.input.help.FailOnStandardError": "Si es true, se producirá un error en la tarea si se escriben errores en la canalización de errores o si se escriben datos en el flujo de error estándar.", + "loc.input.label.RestrictContextToCurrentTask": "Restringir el ámbito de contexto a la tarea actual", + "loc.input.help.RestrictContextToCurrentTask": "Si es true, esta tarea restringirá el ámbito de contexto solo a la tarea actual y el contexto no estará disponible para otras tareas de la canalización cuando se use el agente privado.", + "loc.input.label.TargetAzurePs": "Versión de Azure PowerShell", + "loc.input.help.TargetAzurePs": "En el caso de los agentes hospedados, las versiones de Azure PowerShell admitidas son 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nPara seleccionar la última versión disponible en el agente, seleccione \"Latest installed version\".\n\nPara los agentes privados, puede especificar la versión de Azure PowerShell que prefiera con la opción \"Specify version\"", + "loc.input.label.CustomTargetAzurePs": "Versión de Azure PowerShell preferida", + "loc.input.help.CustomTargetAzurePs": "La versión preferida de Azure PowerShell debe ser una versión de semántica adecuada, por ejemplo, 1.2.3. No se admite una notación regex como 2.\\*,2.3.\\*. El grupo Hosted VS2017 Pool es compatible con las versiones del módulo Az 1.0.0, 1.6.0, 2.3.2, 2.6.0 y 3.1.0", + "loc.input.label.pwsh": "Usar PowerShell Core", + "loc.input.help.pwsh": "Si es true, la tarea usará pwsh.exe desde PATH en lugar de powershell.exe en Windows.", + "loc.input.label.validateScriptSignature": "Validación de la firma del script", + "loc.input.help.validateScriptSignature": "Si es true, la tarea comprobará primero para asegurarse de que el script especificado está firmado y es válido antes de ejecutarlo.", + "loc.input.label.workingDirectory": "Directorio de trabajo", + "loc.input.help.workingDirectory": "Directorio de trabajo donde se ejecuta el script.", + "loc.messages.GeneratingScript": "Generando script.", + "loc.messages.JS_FormattedCommand": "Comando con formato: %s", + "loc.messages.InvalidScriptArguments0": "Argumentos de script '{0}' no válidos. No se permiten los saltos de línea.", + "loc.messages.InvalidScriptPath0": "Ruta del script '{0}' no válida. Los caracteres de ruta de acceso especificados no son válidos.", + "loc.messages.InvalidAzurePsVersion": "La versión de Azure PowerShell \"{0}\" especificada no tiene el formato correcto. Compruebe el formato. Ejemplo de formato correcto: 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell se cerró con el código \"%s\".", + "loc.messages.JS_Stderr": "PowerShell escribió una o varias líneas en la secuencia de error estándar.", + "loc.messages.ExpiredServicePrincipal": "No se pudo capturar el token de acceso de Azure. Compruebe que la entidad de servicio usada es válida y no ha expirado." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/fr-FR/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/fr-FR/resources.resjson new file mode 100644 index 000000000000..85ffdca03de8 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/fr-FR/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[En savoir plus sur cette tâche](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Exécuter un script PowerShell dans un environnement Azure", + "loc.instanceNameFormat": "Script Azure PowerShell : $(ScriptType)", + "loc.releaseNotes": "Ajout de la prise en charge du module Azure et des agents multiplateformes.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Options de version Azure PowerShell", + "loc.group.displayName.advanced": "Avancé", + "loc.input.label.ConnectedServiceNameARM": "Abonnement Azure", + "loc.input.help.ConnectedServiceNameARM": "Abonnement Azure Resource Manager à configurer avant d'exécuter PowerShell", + "loc.input.label.ScriptType": "Type de script", + "loc.input.help.ScriptType": "Type du script : chemin de fichier ou script inline", + "loc.input.label.ScriptPath": "Chemin d'accès du script", + "loc.input.help.ScriptPath": "Chemin d'accès du script. Doit être un chemin d'accès complet ou relatif au répertoire de travail par défaut.", + "loc.input.label.Inline": "Script inline", + "loc.input.help.Inline": "Entrez le script à exécuter.", + "loc.input.label.ScriptArguments": "Arguments de script", + "loc.input.help.ScriptArguments": "Paramètres supplémentaires à passer à PowerShell. Peuvent être des paramètres ordinaux ou nommés.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Sélectionnez la valeur de la variable ErrorActionPreference pour l'exécution du script.", + "loc.input.label.FailOnStandardError": "Échec sur une erreur standard", + "loc.input.help.FailOnStandardError": "Si la valeur est true, et si des erreurs sont écrites dans le pipeline d'erreurs ou si des données sont écrites dans le flux d'erreurs standard, cette tâche se solde par un échec.", + "loc.input.label.RestrictContextToCurrentTask": "Limiter l'étendue du contexte à la tâche active", + "loc.input.help.RestrictContextToCurrentTask": "Si cette condition est vérifiée, la tâche limite l'étendue du contexte à la tâche active uniquement. Le contexte n'est pas accessible aux autres tâches du pipeline quand l'agent privé est utilisé.", + "loc.input.label.TargetAzurePs": "Version d'Azure PowerShell", + "loc.input.help.TargetAzurePs": "Dans le cas d'agents hébergés, les versions d'Azure PowerShell prises en charge sont les suivantes : 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (file d'attente VS2017 hébergée).\nPour choisir la dernière version disponible sur l'agent, sélectionnez \"Dernière version installée\".\n\nPour les agents privés, vous pouvez spécifier la version par défaut d'Azure PowerShell via \"Spécifier la version\"", + "loc.input.label.CustomTargetAzurePs": "Version préférée d'Azure PowerShell", + "loc.input.help.CustomTargetAzurePs": "La version par défaut d'Azure PowerShell doit être une version sémantique appropriée, par exemple 1.2.3. La notation regex telle que 2.\\*,2.3.\\* n'est pas prise en charge. Le pool VS2017 hébergé prend en charge les versions de module Az suivantes : 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Utilisez PowerShell Core", + "loc.input.help.pwsh": "Si la valeur est true, dans Windows, la tâche utilise pwsh.exe à partir de votre variable PATH au lieu de powershell.exe.", + "loc.input.label.validateScriptSignature": "Valider la signature du script", + "loc.input.help.validateScriptSignature": "Si la valeur est true, la tâche vérifie d’abord que le script spécifié est signé et valide avant de l’exécuter.", + "loc.input.label.workingDirectory": "Répertoire de travail", + "loc.input.help.workingDirectory": "Répertoire de travail où le script est exécuté.", + "loc.messages.GeneratingScript": "Génération du script.", + "loc.messages.JS_FormattedCommand": "Commande mise en forme : %s", + "loc.messages.InvalidScriptArguments0": "Arguments de script '{0}' non valides. Les sauts de ligne ne sont pas autorisés.", + "loc.messages.InvalidScriptPath0": "Chemin de script '{0}' non valide. Caractères non valides spécifiés dans le chemin.", + "loc.messages.InvalidAzurePsVersion": "La version '{0}' spécifiée pour Azure PowerShell n'est pas au format approprié. Vérifiez le format. Exemple de format correct : 1.0.1", + "loc.messages.JS_ExitCode": "Arrêt de PowerShell. Code de sortie : '%s'.", + "loc.messages.JS_Stderr": "PowerShell a écrit une ou plusieurs lignes dans le flux d'erreurs standard.", + "loc.messages.ExpiredServicePrincipal": "Impossible de récupérer (fetch) le jeton d'accès pour Azure. Vérifiez si le principal de service utilisé est valide et s'il n'a pas expiré." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/it-IT/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/it-IT/resources.resjson new file mode 100644 index 000000000000..de03075839b5 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/it-IT/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[Altre informazioni su questa attività](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Consente di eseguire uno script PowerShell in un ambiente Azure", + "loc.instanceNameFormat": "Script Azure PowerShell: $(ScriptType)", + "loc.releaseNotes": "È stato aggiunto il supporto per il modulo AZ e gli agenti multipiattaforma.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Opzioni della versione di Azure PowerShell", + "loc.group.displayName.advanced": "Avanzate", + "loc.input.label.ConnectedServiceNameARM": "Sottoscrizione di Azure", + "loc.input.help.ConnectedServiceNameARM": "Sottoscrizione di Azure Resource Manager da configurare prima di eseguire PowerShell", + "loc.input.label.ScriptType": "Tipo di script", + "loc.input.help.ScriptType": "Tipo dello script: Percorso file o Script inline", + "loc.input.label.ScriptPath": "Percorso script", + "loc.input.help.ScriptPath": "Percorso dello script. Deve essere un percorso completo o relativo rispetto alla directory di lavoro predefinita.", + "loc.input.label.Inline": "Script inline", + "loc.input.help.Inline": "Consente di immettere lo script da eseguire.", + "loc.input.label.ScriptArguments": "Argomenti script", + "loc.input.help.ScriptArguments": "Parametri aggiuntivi da passare a PowerShell. Possono essere ordinali o denominati.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Consente di selezionare il valore della variabile ErrorActionPreference per l'esecuzione dello script.", + "loc.input.label.FailOnStandardError": "Interrompi in caso di errore standard", + "loc.input.help.FailOnStandardError": "Se il valore è true, questa attività non riuscirà nel caso in cui vengano scritti errori nella pipeline degli errori oppure se vengono scritti dati nel flusso STDERR.", + "loc.input.label.RestrictContextToCurrentTask": "Limita l'ambito del contesto all'attività corrente", + "loc.input.help.RestrictContextToCurrentTask": "Se è true, questa attività limiterà l'ambito del contesto solo all'attività corrente e il contesto non sarà disponibile per altre attività nella pipeline quando si usa l'agente privato.", + "loc.input.label.TargetAzurePs": "Versione di Azure PowerShell", + "loc.input.help.TargetAzurePs": "In caso di agenti ospitati la versione supportata di Azure PowerShell è: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nPer selezionare l'ultima versione disponibile per l'agente ospitato, selezionare \"Ultima versione installata\".\n\nPer gli agenti privati è possibile selezionare \"Specifica versione\" per specificare la versione preferita di Azure PowerShell", + "loc.input.label.CustomTargetAzurePs": "Versione preferita di Azure PowerShell", + "loc.input.help.CustomTargetAzurePs": "La versione preferita di Azure PowerShell deve essere una versione semantica valida, ad esempio 1.2.3. Espressioni regolari come 2.\\*,2.3.\\* non sono supportate. La versione Hosted VS2017 Pool supporta attualmente le versioni seguenti del modulo Az: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Usa PowerShell Core", + "loc.input.help.pwsh": "Se è impostata su true, in Windows l'attività userà pwsh.exe da PATH invece di powershell.exe.", + "loc.input.label.validateScriptSignature": "Convalida firma script", + "loc.input.help.validateScriptSignature": "Se è True, l'attività verificherà innanzitutto che lo script specificato sia firmato e valido prima di eseguirlo.", + "loc.input.label.workingDirectory": "Directory di lavoro", + "loc.input.help.workingDirectory": "Directory di lavoro in cui viene eseguito lo script.", + "loc.messages.GeneratingScript": "Generazione dello script.", + "loc.messages.JS_FormattedCommand": "Comando formattato: %s", + "loc.messages.InvalidScriptArguments0": "Gli argomenti '{0}' dello script non sono validi. Le interruzioni di riga non sono consentite.", + "loc.messages.InvalidScriptPath0": "Il percorso '{0}' dello script non è valido. Sono stati specificati caratteri non validi.", + "loc.messages.InvalidAzurePsVersion": "Il formato della versione di Azure PowerShell '{0}' specificata non è corretto. Controllare il formato. Un esempio di formato corretto è 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell terminato con codice '%s'.", + "loc.messages.JS_Stderr": "PowerShell ha scritto una o più righe nel flusso di errore standard.", + "loc.messages.ExpiredServicePrincipal": "Non è stato possibile recuperare il token di accesso per Azure. Verificare che l'entità servizio usata sia valida e non sia scaduta." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ja-JP/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ja-JP/resources.resjson new file mode 100644 index 000000000000..5f60ce4b7a81 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ja-JP/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[このタスクの詳細を表示](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Azure 環境内で PowerShell スクリプトを実行します", + "loc.instanceNameFormat": "Azure PowerShell スクリプト: $(ScriptType)", + "loc.releaseNotes": "Az モジュールとクロス プラットフォームのエージェントのサポートが追加されました。", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell バージョンのオプション", + "loc.group.displayName.advanced": "詳細設定", + "loc.input.label.ConnectedServiceNameARM": "Azure サブスクリプション", + "loc.input.help.ConnectedServiceNameARM": "PowerShell を実行する前に構成する Azure Resource Manager サブスクリプション", + "loc.input.label.ScriptType": "スクリプトの種類", + "loc.input.help.ScriptType": "スクリプトの種類: ファイル パスまたはインライン スクリプト", + "loc.input.label.ScriptPath": "スクリプト パス", + "loc.input.help.ScriptPath": "スクリプトのパス。完全修飾パスか、既定の作業ディレクトリを基準とした相対パスのいずれかです。", + "loc.input.label.Inline": "インライン スクリプト", + "loc.input.help.Inline": "実行するスクリプトを入力します。", + "loc.input.label.ScriptArguments": "スクリプトの引数", + "loc.input.help.ScriptArguments": "PowerShell に渡す追加のパラメーター。順序によるパラメーターまたは名前指定されたパラメーターのいずれかです。", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "スクリプトを実行するための ErrorActionPreference 変数の値を選択します。", + "loc.input.label.FailOnStandardError": "標準エラーで失敗", + "loc.input.help.FailOnStandardError": "これが true の場合、何らかのエラーがエラー パイプラインに書き込まれるか、何らかのデータが標準エラー ストリームに書き込まれる場合、このタスクは失敗します。", + "loc.input.label.RestrictContextToCurrentTask": "コンテキストのスコープを現在のタスクに制限する", + "loc.input.help.RestrictContextToCurrentTask": "これが true の場合、このタスクによってコンテキストのスコープが現在のタスクのみに制限されます。また、プライベート エージェントを使用している場合、このコンテキストをパイプライン内の他のタスクで使用することはできなくなります。", + "loc.input.label.TargetAzurePs": "Azure PowerShell バージョン", + "loc.input.help.TargetAzurePs": "ホステッド エージェントの場合、サポートされている Azure PowerShell のバージョンは、1.0.0、1.6.0、2.3.2、2.6.0、3.1.0 (ホステッド VS2017 キュー) です。\nエージェントで利用可能な最新バージョンを選ぶには、[Latest installed version](インストールされている最新バージョン) を選択します。\n\nプライベート エージェントの場合は、[Specify version](バージョンを指定する) を使用して優先されるバージョンの Azure PowerShell を指定できます。", + "loc.input.label.CustomTargetAzurePs": "優先される Azure PowerShell バージョン", + "loc.input.help.CustomTargetAzurePs": "優先される Azure PowerShell バージョンは、1.2.3 などの適切なセマンティック バージョンである必要があります。2.\\*、2.3.\\* などの正規表現はサポートされていません。ホステッド VS2017 プールは、現在次の Az モジュール バージョンをサポートしています: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0", + "loc.input.label.pwsh": "PowerShell Core を使用する", + "loc.input.help.pwsh": "これが true の場合、Windows 上のタスクは powershell.exe ではなく PATH からの pwsh.exe を使用します。", + "loc.input.label.validateScriptSignature": "スクリプトの署名を検証する", + "loc.input.help.validateScriptSignature": "これが true の場合、タスクはまず、指定されたスクリプトが署名され、有効であることを確認してからこれを実行します。", + "loc.input.label.workingDirectory": "作業ディレクトリ", + "loc.input.help.workingDirectory": "スクリプトが実行される作業ディレクトリ。", + "loc.messages.GeneratingScript": "スクリプトを生成しています。", + "loc.messages.JS_FormattedCommand": "フォーマット後のコマンド: %s", + "loc.messages.InvalidScriptArguments0": "スクリプトの引数 '{0}' が無効です。改行は使用できません。", + "loc.messages.InvalidScriptPath0": "スクリプト パス '{0}' が無効です。無効なパス文字が指定されました。", + "loc.messages.InvalidAzurePsVersion": "指定した Azure PowerShell バージョン '{0}' は、形式が正しくありません。形式をご確認ください。正しい形式の例は、1.0.1 です", + "loc.messages.JS_ExitCode": "PowerShell がコード '%s' で終了しました。", + "loc.messages.JS_Stderr": "PowerShell が標準エラー ストリームに 1 行以上を書き込みました。", + "loc.messages.ExpiredServicePrincipal": "Azure のアクセス トークンをフェッチできませんでした。使用されているサービス プリンシパルが有効であり、有効期限が切れていないことを確認してください。" +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ko-KR/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ko-KR/resources.resjson new file mode 100644 index 000000000000..b00a1a1619c4 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ko-KR/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[이 작업에 대한 자세한 정보](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Azure 환경에서 PowerShell 스크립트 실행", + "loc.instanceNameFormat": "Azure PowerShell 스크립트: $(ScriptType)", + "loc.releaseNotes": "Az 모듈 및 플랫폼 간 에이전트에 대한 지원이 추가되었습니다.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell 버전 옵션", + "loc.group.displayName.advanced": "고급", + "loc.input.label.ConnectedServiceNameARM": "Azure 구독", + "loc.input.help.ConnectedServiceNameARM": "PowerShell을 실행하기 전에 구성할 Azure Resource Manager 구독", + "loc.input.label.ScriptType": "스크립트 유형", + "loc.input.help.ScriptType": "스크립트 유형: 파일 경로 또는 인라인 스크립트", + "loc.input.label.ScriptPath": "스크립트 경로", + "loc.input.help.ScriptPath": "스크립트의 경로입니다. 정규화된 경로이거나 기본 작업 디렉터리에 대한 상대 경로여야 합니다.", + "loc.input.label.Inline": "인라인 스크립트", + "loc.input.help.Inline": "실행할 스크립트를 입력합니다.", + "loc.input.label.ScriptArguments": "스크립트 인수", + "loc.input.help.ScriptArguments": "PowerShell에 전달할 추가 인수입니다. 서수 매개 변수나 명명된 매개 변수 중 하나일 수 있습니다.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "스크립트 실행에 대한 ErrorActionPreference 변수의 값을 선택합니다.", + "loc.input.label.FailOnStandardError": "표준 오류 시 실패", + "loc.input.help.FailOnStandardError": "이 값이 true이면 오류 파이프라인에 오류가 작성되거나 표준 오류 스트림에 데이터가 작성될 경우 이 작업은 실패하게 됩니다.", + "loc.input.label.RestrictContextToCurrentTask": "컨텍스트 범위를 현재 작업으로 제한", + "loc.input.help.RestrictContextToCurrentTask": "true이면 이 작업이 컨텍스트 범위를 현재 작업으로만 제한하고 프라이빗 에이전트를 사용할 때 파이프라인의 다른 작업에 대해 컨텍스트를 사용할 수 없게 됩니다.", + "loc.input.label.TargetAzurePs": "Azure PowerShell 버전", + "loc.input.help.TargetAzurePs": "호스트된 에이전트의 경우 지원되는 Azure PowerShell 버전은 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0(Hosted VS2017 Queue)입니다.\n에이전트에서 사용 가능한 최신 버전을 선택하려면 \"설치된 최신 버전\"을 선택합니다.\n\n사용자 에이전트의 경우 \"버전 지정\"을 사용하여 기본 Azure PowerShell 버전을 지정할 수 있습니다.", + "loc.input.label.CustomTargetAzurePs": "기본 Azure PowerShell 버전", + "loc.input.help.CustomTargetAzurePs": "기본 Azure PowerShell 버전은 올바른 의미 체계 버전(예: 1.2.3)이어야 합니다. 2.\\*,2.3.\\*와 같은 Regex는 지원되지 않습니다. Hosted VS2017 풀은 현재 Az 모듈 버전 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0을 지원합니다.", + "loc.input.label.pwsh": "PowerShell Core 사용", + "loc.input.help.pwsh": "true이면, Windows에서 작업이 powershell.exe 대신 PATH의 pwsh.exe를 사용합니다.", + "loc.input.label.validateScriptSignature": "스크립트 서명 유효성 검사", + "loc.input.help.validateScriptSignature": "true이면 작업을 실행하기 전에 먼저 지정한 스크립트가 서명되어 있고 유효한지 확인합니다.", + "loc.input.label.workingDirectory": "작업 디렉터리", + "loc.input.help.workingDirectory": "스크립트가 실행되는 작업 디렉터리입니다.", + "loc.messages.GeneratingScript": "스크립트를 생성 중입니다.", + "loc.messages.JS_FormattedCommand": "형식이 지정된 명령: %s", + "loc.messages.InvalidScriptArguments0": "스크립트 인수 '{0}'이(가) 잘못되었습니다. 줄 바꿈은 허용되지 않습니다.", + "loc.messages.InvalidScriptPath0": "스크립트 경로 '{0}'이(가) 잘못되었습니다. 잘못된 경로 문자를 지정했습니다.", + "loc.messages.InvalidAzurePsVersion": "지정한 Azure PowerShell 버전 '{0}'의 형식이 잘못되었습니다. 형식을 확인하세요. 올바른 형식의 예는 1.0.1입니다.", + "loc.messages.JS_ExitCode": "PowerShell이 코드 '%s'(으)로 종료되었습니다.", + "loc.messages.JS_Stderr": "PowerShell이 표준 오류 스트림에 하나 이상의 줄을 썼습니다.", + "loc.messages.ExpiredServicePrincipal": "Azure의 액세스 토큰을 페치할 수 없습니다. 사용한 서비스 주체가 유효하고 만료되지 않았는지 확인하세요." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ru-RU/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ru-RU/resources.resjson new file mode 100644 index 000000000000..c20a9b0fce5f --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/ru-RU/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[См. дополнительные сведения об этой задаче](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "Выполнение скрипта PowerShell в среде Azure", + "loc.instanceNameFormat": "Сценарий Azure PowerShell: $(ScriptType)", + "loc.releaseNotes": "Добавлена поддержка модуля Az и кроссплатформенных агентов.", + "loc.group.displayName.AzurePowerShellVersionOptions": "Параметры версии Azure PowerShell", + "loc.group.displayName.advanced": "Дополнительно", + "loc.input.label.ConnectedServiceNameARM": "Подписка Azure", + "loc.input.help.ConnectedServiceNameARM": "Подписка на Azure Resource Manager для настройки перед запуском PowerShell", + "loc.input.label.ScriptType": "Тип сценария", + "loc.input.help.ScriptType": "Тип сценария: путь к файлу или встроенный сценарий", + "loc.input.label.ScriptPath": "Путь к скрипту", + "loc.input.help.ScriptPath": "Путь к сценарию. Это должен быть полный путь или путь относительно рабочего каталога по умолчанию.", + "loc.input.label.Inline": "Встроенный сценарий", + "loc.input.help.Inline": "Введите сценарий для выполнения.", + "loc.input.label.ScriptArguments": "Аргументы скрипта", + "loc.input.help.ScriptArguments": "Дополнительные параметры для передачи в PowerShell. Могут быть как порядковыми, так и именованными.", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "Выберите значение переменной ErrorActionPreference для выполнения скрипта.", + "loc.input.label.FailOnStandardError": "Сбой со стандартной ошибкой", + "loc.input.help.FailOnStandardError": "Если задано значение True, задача будет завершаться сбоем при записи любых ошибок в конвейер ошибок или записи любых данных в стандартный поток ошибок.", + "loc.input.label.RestrictContextToCurrentTask": "Ограничить область контекста текущей задачей", + "loc.input.help.RestrictContextToCurrentTask": "Если задано значение true, задача ограничивает область контекста только текущей задачей и при использовании частного агента контекст будет недоступен для других задач в конвейере.", + "loc.input.label.TargetAzurePs": "Версия Azure PowerShell", + "loc.input.help.TargetAzurePs": "Для размещенных агентов поддерживаются следующие версии Azure PowerShell: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (размещенная очередь Visual Studio 2017).\nЧтобы выбрать последнюю версию, доступную в агенте, выберите пункт \"Последняя установленная версия\".\n\nДля частных агентов можно указать предпочтительную версию Azure PowerShell с помощью элемента \"Указать версию\"", + "loc.input.label.CustomTargetAzurePs": "Предпочтительная версия Azure PowerShell", + "loc.input.help.CustomTargetAzurePs": "Предпочтительная версия Azure PowerShell должна быть надлежащей семантической версией, например 1.2.3. Регулярные выражения, например 2.\\*,2.3.\\*, не поддерживаются. Размещенный пул Visual Studio 2017 сейчас поддерживает следующие версии модуля Az: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0", + "loc.input.label.pwsh": "Использовать PowerShell Core", + "loc.input.help.pwsh": "Если задано значение True, в Windows задача будет использовать программу pwsh.exe, указанную в переменной PATH, вместо powershell.exe.", + "loc.input.label.validateScriptSignature": "Проверка подписи сценария", + "loc.input.help.validateScriptSignature": "Если задано значение true, задача сначала проверит, что указанный сценарий подписан и действителен, прежде чем выполнить его.", + "loc.input.label.workingDirectory": "Рабочий каталог", + "loc.input.help.workingDirectory": "Рабочий каталог, в котором выполняется скрипт.", + "loc.messages.GeneratingScript": "Формируется скрипт.", + "loc.messages.JS_FormattedCommand": "Отформатирована команда: %s", + "loc.messages.InvalidScriptArguments0": "Недопустимые аргументы скрипта \"{0}\". Разрывы строк запрещены.", + "loc.messages.InvalidScriptPath0": "Недопустимый путь к скрипту \"{0}\". Указаны символы, недопустимые в пути.", + "loc.messages.InvalidAzurePsVersion": "Указанная версия Azure PowerShell \"{0}\" имеет неправильный формат. Проверьте формат. Пример правильного формата: 1.0.1", + "loc.messages.JS_ExitCode": "Завершение работы PowerShell с кодом \"%s\".", + "loc.messages.JS_Stderr": "Оболочка PowerShell записала одну или несколько строк в стандартный поток ошибок.", + "loc.messages.ExpiredServicePrincipal": "Не удалось получить маркер доступа для Azure. Убедитесь, что используемый субъект-служба является допустимым, а срок его действия не истек." +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/zh-CN/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/zh-CN/resources.resjson new file mode 100644 index 000000000000..fe4a5eb3b960 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/zh-CN/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[详细了解此任务](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "在 Azure 环境中运行 PowerShell 脚本", + "loc.instanceNameFormat": "Azure PowerShell 脚本: $(ScriptType)", + "loc.releaseNotes": "添加了对 Azure 模块和跨平台代理的支持。", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell 版本选项", + "loc.group.displayName.advanced": "高级", + "loc.input.label.ConnectedServiceNameARM": "Azure 订阅", + "loc.input.help.ConnectedServiceNameARM": "在运行 PowerShell 之前配置的 Azure 资源管理器订阅", + "loc.input.label.ScriptType": "脚本类型", + "loc.input.help.ScriptType": "脚本类型: 文件路径或内联脚本", + "loc.input.label.ScriptPath": "脚本路径", + "loc.input.help.ScriptPath": "脚本的路径。应是完全限定的路径或相对于默认工作目录。", + "loc.input.label.Inline": "内联脚本", + "loc.input.help.Inline": "输入要执行的脚本。", + "loc.input.label.ScriptArguments": "脚本参数", + "loc.input.help.ScriptArguments": "要传递给 PowerShell 的其他参数。可以是序号或命名参数。", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "选择执行脚本的 ErrorActionPreference 变量的值。", + "loc.input.label.FailOnStandardError": "因标准错误失败", + "loc.input.help.FailOnStandardError": "如果为 true,当有错误被写入错误管道或有数据被写入标准错误流时,此任务将失败。", + "loc.input.label.RestrictContextToCurrentTask": "将上下文的范围限于当前任务", + "loc.input.help.RestrictContextToCurrentTask": "如果为 true,此任务会将上下文的范围仅限于当前任务,并且在使用专用代理时,管道中的其他任务将无法使用该上下文。", + "loc.input.label.TargetAzurePs": "Azure PowerShell 版本", + "loc.input.help.TargetAzurePs": "对于托管代理,受支持的 Azure PowerShell 版本为: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0 (托管的 VS2017 队列)。\n若要选择代理上的最新可用版本,请选择“已安装的最新版本”。\n\n对于专用代理,可以使用“指定版本”指定 Azure PowerShell 的首选版本", + "loc.input.label.CustomTargetAzurePs": "首选 Azure PowerShell 版本", + "loc.input.help.CustomTargetAzurePs": "首选 Azure PowerShell 版本需为正确的语义版本,例如 1.2.3。不支持 2.\\*、2.3.\\* 等正则表达式。托管 VS2017 池当前支持 Azure 模块版本: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0", + "loc.input.label.pwsh": "使用 PowerShell Core", + "loc.input.help.pwsh": "如果为 true,则在 Windows 上,任务将使用来自 PATH 的 pwsh.exe,而不是 powershell.exe。", + "loc.input.label.validateScriptSignature": "验证脚本签名", + "loc.input.help.validateScriptSignature": "如果为 true,则任务将首先检查以确保指定的脚本已签名并且在执行前有效。", + "loc.input.label.workingDirectory": "工作目录", + "loc.input.help.workingDirectory": "在其中运行脚本的工作目录。", + "loc.messages.GeneratingScript": "正在生成脚本。", + "loc.messages.JS_FormattedCommand": "已设置格式的命令: %s", + "loc.messages.InvalidScriptArguments0": "脚本参数“{0}”无效。不允许换行。", + "loc.messages.InvalidScriptPath0": "脚本路径“{0}”无效。指定的路径字符无效。", + "loc.messages.InvalidAzurePsVersion": "指定的 Azure PowerShell 版本“{0}”格式不正确。请检查格式。正确格式的示例为 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell 已退出,代码为“%s”。", + "loc.messages.JS_Stderr": "PowerShell 向标准错误流写入一个或多个行。", + "loc.messages.ExpiredServicePrincipal": "无法提取 Azure 的访问令牌。请确保使用的服务主体有效且未过期。" +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/zh-TW/resources.resjson b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/zh-TW/resources.resjson new file mode 100644 index 000000000000..5b87db2dbbac --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Strings/resources.resjson/zh-TW/resources.resjson @@ -0,0 +1,43 @@ +{ + "loc.friendlyName": "Azure PowerShell", + "loc.helpMarkDown": "[深入了解此工作](https://go.microsoft.com/fwlink/?LinkID=613749)", + "loc.description": "在 Azure 環境中執行 PowerShell 指令碼", + "loc.instanceNameFormat": "Azure PowerShell 指令碼: $(ScriptType)", + "loc.releaseNotes": "新增了 Az 模組和跨平台代理程式的支援。", + "loc.group.displayName.AzurePowerShellVersionOptions": "Azure PowerShell 版本選項", + "loc.group.displayName.advanced": "進階", + "loc.input.label.ConnectedServiceNameARM": "Azure 訂用帳戶", + "loc.input.help.ConnectedServiceNameARM": "執行 PowerShell 之前要設定的 Azure Resource Manager 訂用帳戶", + "loc.input.label.ScriptType": "指令碼類型", + "loc.input.help.ScriptType": "指令碼類型: 檔案路徑或內嵌指令碼", + "loc.input.label.ScriptPath": "指令碼路徑", + "loc.input.help.ScriptPath": "指令碼的路徑。必須是完整路徑名稱或預設工作目錄的相對路徑。", + "loc.input.label.Inline": "內嵌指令碼", + "loc.input.help.Inline": "請輸入要執行的指令碼。", + "loc.input.label.ScriptArguments": "指令碼引數", + "loc.input.help.ScriptArguments": "傳遞至 PowerShell 的額外引數。可以是序數或具名參數。", + "loc.input.label.errorActionPreference": "ErrorActionPreference", + "loc.input.help.errorActionPreference": "請選取用於執行指令碼的 ErrorActionPreference 變數值。", + "loc.input.label.FailOnStandardError": "發生標準錯誤的失敗", + "loc.input.help.FailOnStandardError": "若此項為 true,如果在錯誤管線中寫入任何錯誤,或在標準錯誤資料流中寫入任何資料,此工作就會失敗。", + "loc.input.label.RestrictContextToCurrentTask": "將內容範圍限制在目前的工作", + "loc.input.help.RestrictContextToCurrentTask": "若為 true,則此工作只會將內容範圍限制在目前的工作,而在使用私人代理程式時,管線中的其他工作將無法使用內容。", + "loc.input.label.TargetAzurePs": "Azure PowerShell 版本", + "loc.input.help.TargetAzurePs": "若為裝載的代理程式,則支援的 Azure PowerShell 版本為: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0 (裝載的 VS2017 佇列)。\n若要挑選代理程式上可用的最新版本,請選取 [最新安裝的版本]。\n\n若為私人代理程式,您可以使用 [指定版本] 指定慣用的 Azure PowerShell 版本", + "loc.input.label.CustomTargetAzurePs": "慣用的 Azure PowerShell 版本", + "loc.input.help.CustomTargetAzurePs": "慣用的 Azure PowerShell 版本必須是正確的語意版本,例如 1.2.3。不支援像 2.\\*,2.3.\\* 這樣的 Regex。裝載的 VS2017 集區目前支援 Az 模組版本: 1.0.0、1.6.0、2.3.2、2.6.0、3.1.0", + "loc.input.label.pwsh": "使用 PowerShell Core", + "loc.input.help.pwsh": "若此為 true,那麼在 Windows 上,工作就會使用 PATH 中的 pwsh.exe 而非 powershell.exe。", + "loc.input.label.validateScriptSignature": "驗證指令碼簽章", + "loc.input.help.validateScriptSignature": "如果此為 true,則工作會先進行檢查,確定指定的指令碼已簽署且有效,然後再執行。", + "loc.input.label.workingDirectory": "工作目錄", + "loc.input.help.workingDirectory": "指令碼執行所在的工作目錄。", + "loc.messages.GeneratingScript": "正在產生指令碼。", + "loc.messages.JS_FormattedCommand": "經過格式化的命令: %s", + "loc.messages.InvalidScriptArguments0": "指令碼引數 '{0}' 無效。不允許分行符號。", + "loc.messages.InvalidScriptPath0": "指令碼路徑 '{0}' 無效。指定的路徑字元無效。", + "loc.messages.InvalidAzurePsVersion": "指定的 Azure PowerShell 版本 '{0}' 格式不正確。請檢查格式。正確格式的範例為 1.0.1", + "loc.messages.JS_ExitCode": "PowerShell 已結束,代碼為 '%s'。", + "loc.messages.JS_Stderr": "PowerShell 已將一或多行寫入標準錯誤資料流。", + "loc.messages.ExpiredServicePrincipal": "無法擷取 Azure 的存取權杖。請驗證使用的服務主體是否有效且未過期。" +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/ChecksForPowerShell.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/ChecksForPowerShell.ps1 new file mode 100644 index 000000000000..c88aa1ffb54d --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/ChecksForPowerShell.ps1 @@ -0,0 +1,30 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Get-VstsInput { $false } -- -Name pwsh -AsBool +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +Assert-WasCalled Invoke-VstsTool -Times 1 +Assert-WasCalled Invoke-VstsTool -ArgumentsEvaluator {($args | ConvertTo-Json) -like '*powershell.exe*'} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/ChecksForPowerShellCore.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/ChecksForPowerShellCore.ps1 new file mode 100644 index 000000000000..60caed9e28fe --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/ChecksForPowerShellCore.ps1 @@ -0,0 +1,31 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Get-VstsInput { $true } -- -Name pwsh -AsBool +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module +Register-Mock ConvertTo-SecureString + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +Assert-WasCalled Invoke-VstsTool -Times 1 +Assert-WasCalled Invoke-VstsTool -ArgumentsEvaluator {($args | ConvertTo-Json) -like '*pwsh.exe*'} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/ChecksForWorkingDirectory.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/ChecksForWorkingDirectory.ps1 new file mode 100644 index 000000000000..4f824ae5b8c2 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/ChecksForWorkingDirectory.ps1 @@ -0,0 +1,33 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +$input_workingDirectory = "C:\Users" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Get-VstsInput { $true } -- -Name pwsh -AsBool +Register-Mock Get-VstsInput { $input_workingDirectory } -- -Name workingDirectory -Require +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module +Register-Mock ConvertTo-SecureString + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +Assert-WasCalled Invoke-VstsTool -Times 1 +Assert-WasCalled Invoke-VstsTool -ArgumentsEvaluator {($args | ConvertTo-Json) -like '*C:\\Users*'} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/L0.ts b/_generated/AzurePowerShellV4_Node16/Tests/L0.ts new file mode 100644 index 000000000000..23000ff892d3 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/L0.ts @@ -0,0 +1,58 @@ +/// +/// +/// + +import Q = require('q'); +import assert = require('assert'); +import path = require('path'); +var psm = require('../../../Tests/lib/psRunner'); +var psr = null; + +describe('AzurePowerShell Suite', function () { + this.timeout(parseInt(process.env.TASK_TEST_TIMEOUT) || 20000); + + before((done) => { + if (psm.testSupported()) { + psr = new psm.PSRunner(); + psr.start(); + } + + done(); + }); + + after(function () { + if (psr) { + psr.kill(); + } + }); + + if (psm.testSupported()) { + it('checks for powershell core', (done) => { + psr.run(path.join(__dirname, 'ChecksForPowerShellCore.ps1'), done); + }) + /*it('checks for powershell', (done) => { + psr.run(path.join(__dirname, 'ChecksForPowerShell.ps1'), done); + })*/ + it('checks for working directory', (done) => { + psr.run(path.join(__dirname, 'ChecksForWorkingDirectory.ps1'), done); + }) + it('performs basic flow', (done) => { + psr.run(path.join(__dirname, 'PerformsBasicFlow.ps1'), done); + }) + it('throws when otherversion is specified in a wrong format', (done) => { + psr.run(path.join(__dirname, 'ThrowsForInvalidVersion.ps1'), done); + }) + it('throws when invalid script arguments', (done) => { + psr.run(path.join(__dirname, 'ThrowsWhenInvalidScriptArguments.ps1'), done); + }) + it('throws when invalid script path', (done) => { + psr.run(path.join(__dirname, 'ThrowsWhenInvalidScriptPath.ps1'), done); + }) + it('Get-LatestModule returns the latest available module', (done) => { + psr.run(path.join(__dirname, 'Utility.Get-LatestModule.ps1'), done); + }) + it('Update-PSModulePathForHostedAgent updated psmodulepath correctly', (done) => { + psr.run(path.join(__dirname, 'Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1'), done); + }) + } +}); \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/PerformsBasicFlow.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/PerformsBasicFlow.ps1 new file mode 100644 index 000000000000..6a2b2e74708d --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/PerformsBasicFlow.ps1 @@ -0,0 +1,35 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +$targetAzurePs = "4.1.0" +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "$PSScriptRoot/PerformsBasicFlow_TargetScript.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { $targetAzurePs } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { 'arg1 arg2' } -- -Name ScriptArguments +Register-Mock Get-VstsInput { "continue" } -- -Name errorActionPreference +Register-Mock Get-VstsInput { $true } -- -Name FailOnStandardError +Register-Mock Update-PSModulePathForHostedAgent +Register-Mock Get-Module +Register-Mock Initialize-AzModule +Register-Mock Get-VstsEndpoint { @{auth = @{ scheme = "ServicePrincipal" }} } +Register-Mock Remove-EndpointSecrets +Register-Mock Disconnect-AzureAndClearContext +Register-Mock Assert-VstsPath +Register-Mock Invoke-VstsTool { } +Register-Mock Expand-ModuleZip +Register-Mock Invoke-RestMethod +Register-Mock Save-Module +Register-Mock ConvertTo-SecureString + +# Act. +$actual = & $PSScriptRoot\..\AzurePowerShell.ps1 + +# Assert the error action preference was set to Continue. +Assert-AreEqual "Continue" $global:ErrorActionPreference +$global:ErrorActionPreference = 'Stop' # Reset to stop. + +# Assert the Azure helpers module was imported and invoked. +Assert-WasCalled Import-Module -- ([System.IO.Path]::GetFullPath("$PSScriptRoot\..\ps_modules\VstsAzureHelpers_")) +Assert-WasCalled Initialize-AzModule diff --git a/_generated/AzurePowerShellV4_Node16/Tests/PerformsBasicFlow_TargetScript.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/PerformsBasicFlow_TargetScript.ps1 new file mode 100644 index 000000000000..53aafdebcdd8 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/PerformsBasicFlow_TargetScript.ps1 @@ -0,0 +1,4 @@ +# Return key information. +New-Object psobject -Property @{ + Args = $args +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/ThrowsForInvalidVersion.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/ThrowsForInvalidVersion.ps1 new file mode 100644 index 000000000000..5afc27858f1e --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/ThrowsForInvalidVersion.ps1 @@ -0,0 +1,15 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 + +Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require +Register-Mock Get-VstsInput { "foobar.ps1" } -- -Name ScriptPath +Register-Mock Get-VstsInput { "OtherVersion" } -- -Name TargetAzurePs +Register-Mock Get-VstsInput { "x.y.z" } -- -Name CustomTargetAzurePs + +# Act/Assert. +Assert-Throws { + & $PSScriptRoot\..\AzurePowerShell.ps1 +} -MessagePattern "InvalidAzurePsVersion*x.y.z" diff --git a/_generated/AzurePowerShellV4_Node16/Tests/ThrowsWhenInvalidScriptArguments.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/ThrowsWhenInvalidScriptArguments.ps1 new file mode 100644 index 000000000000..af93358163bc --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/ThrowsWhenInvalidScriptArguments.ps1 @@ -0,0 +1,14 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +foreach ($arguments in @( "script`rarguments", "script`narguments" )) { + Unregister-Mock Get-VstsInput + Register-Mock Get-VstsInput { $arguments } -- -Name ScriptArguments + + # Act/Assert. + Assert-Throws { + & $PSScriptRoot\..\AzurePowerShell.ps1 + } -MessagePattern "InvalidScriptArguments0*$arguments" +} diff --git a/_generated/AzurePowerShellV4_Node16/Tests/ThrowsWhenInvalidScriptPath.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/ThrowsWhenInvalidScriptPath.ps1 new file mode 100644 index 000000000000..a1334790ccba --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/ThrowsWhenInvalidScriptPath.ps1 @@ -0,0 +1,16 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +foreach ($path in @( "script`rpath", "script`npath" )) { + Unregister-Mock Get-VstsInput + Register-Mock Get-VstsInput { "FilePath" } -- -Name ScriptType -Require + Register-Mock Get-VstsInput { $path } -- -Name ScriptPath + Register-Mock Get-VstsInput { "4.1.0" } -- -Name TargetAzurePs + + # Act/Assert. + Assert-Throws { + & $PSScriptRoot\..\AzurePowerShell.ps1 + } -MessagePattern "InvalidScriptPath0*$path" +} diff --git a/_generated/AzurePowerShellV4_Node16/Tests/Utility.Get-LatestModule.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/Utility.Get-LatestModule.ps1 new file mode 100644 index 000000000000..71609db6ede0 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/Utility.Get-LatestModule.ps1 @@ -0,0 +1,30 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +. $PSScriptRoot\..\Utility.ps1 + +$azModulePath = "c:\modules\az_4.1.0" + +$azModulePattern = "^az_[0-9]+\.[0-9]+\.[0-9]+$" +$versionPattern = "[0-9]+\.[0-9]+\.[0-9]+$" + +$mockDirectoryStructure = @( + @{ + Name = "az_4.1.0" + FullName = "C:\Modules\az_4.1.0" + } + @{ + Name = "az_3.6.0" + FullName = "C:\Modules\az_3.6.0" + } +) + +Register-Mock Get-ChildItem { $mockDirectoryStructure } -- -Directory -Path "C:\Modules" +Register-Mock Test-Path { $true } + +# Act +$result = Get-LatestModule -patternToMatch $azModulePattern -patternToExtract $versionPattern +# Assert +Assert-AreEqual $result.toLower() $azModulePath \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Tests/Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1 b/_generated/AzurePowerShellV4_Node16/Tests/Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1 new file mode 100644 index 000000000000..53c9c7875e54 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Tests/Utility.UpdatePSModulePathForHostedAgentWorksCorrectly.ps1 @@ -0,0 +1,47 @@ +[CmdletBinding()] +param() + +# Arrange. +. $PSScriptRoot\..\..\..\Tests\lib\Initialize-Test.ps1 +. $PSScriptRoot\..\Utility.ps1 + +$azModulePath = "c:\modules\az_3.6.0" + +$azModulePattern = "^az_[0-9]+\.[0-9]+\.[0-9]+$" +$versionPattern = "[0-9]+\.[0-9]+\.[0-9]+$" + +$variableSets = @( + @{ + targetAzurePsVersion = "3.6.0" + azModuleExist = $true + } + @{ + targetAzurePsVersion = "" + azModulePath = $true + } +) + +$temp = $env:PSModulePath + +foreach ($variableSet in $variableSets) { + $env:PSModulePath = $temp + # Arrange + Unregister-Mock Get-LatestModule + if($variableSet.azModuleExist) { + Register-Mock Get-LatestModule { $azModulePath } -- -patternToMatch $azModulePattern -patternToExtract $versionPattern -Classic:$false + } else { + Register-Mock Get-LatestModule { "" } -- -patternToMatch $azModulePattern -patternToExtract $versionPattern -Classic:$false + } + + # Act + Update-PSModulePathForHostedAgent -targetAzurePs $variableSet.targetAzurePsVersion + + # Assert + if($variableSet.azModuleExist) { + Assert-IsGreaterThan -1 $env:PSModulePath.toLower().IndexOf($azModulePath) + } else { + Assert-AreEqual -1 $env:PSModulePath.toLower().IndexOf($azModulePath) + } + + Assert-IsGreaterThan 0 $env:PSModulePath.toLower().IndexOf(";") +} diff --git a/_generated/AzurePowerShellV4_Node16/ThirdPartyNotices.txt b/_generated/AzurePowerShellV4_Node16/ThirdPartyNotices.txt new file mode 100644 index 000000000000..abc33cfd772f --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/ThirdPartyNotices.txt @@ -0,0 +1,136 @@ + +THIRD-PARTY SOFTWARE NOTICES AND INFORMATION +Do Not Translate or Localize + +Azure PowerShell incorporates third party material from the projects listed below. The original copyright notice and the license under which Microsoft received such third party material are set forth below. Microsoft reserves all other rights not expressly granted, whether by implication, estoppel or otherwise. + +1. OpenSSL (http://www.openssl.org) + +%% OpenSSL NOTICES, INFORMATION, AND LICENSE BEGIN HERE +========================================= + LICENSE ISSUES + ============== + + The OpenSSL toolkit stays under a dual license, i.e. both the conditions of + the OpenSSL License and the original SSLeay license apply to the toolkit. + See below for the actual license texts. Actually both licenses are BSD-style + Open Source licenses. In case of any license issues related to OpenSSL + please contact openssl-core@openssl.org. + + OpenSSL License + --------------- + +/* ==================================================================== + * Copyright (c) 1998-2011 The OpenSSL Project. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * + * 3. All advertising materials mentioning features or use of this + * software must display the following acknowledgment: + * This product includes software developed by the OpenSSL Project + * for use in the OpenSSL Toolkit. (http://www.openssl.org/) + * + * 4. The names OpenSSL Toolkit and OpenSSL Project must not be used to + * endorse or promote products derived from this software without + * prior written permission. For written permission, please contact + * openssl-core@openssl.org. + * + * 5. Products derived from this software may not be called OpenSSL + * nor may OpenSSL appear in their names without prior written + * permission of the OpenSSL Project. + * + * 6. Redistributions of any form whatsoever must retain the following + * acknowledgment: + * This product includes software developed by the OpenSSL Project + * for use in the OpenSSL Toolkit (http://www.openssl.org/) + * + * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY + * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR + * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + * ==================================================================== + * + * This product includes cryptographic software written by Eric Young + * (eay@cryptsoft.com). This product includes software written by Tim + * Hudson (tjh@cryptsoft.com). + * + */ + + Original SSLeay License + ----------------------- + +/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) + * All rights reserved. + * + * This package is an SSL implementation written + * by Eric Young (eay@cryptsoft.com). + * The implementation was written so as to conform with Netscapes SSL. + * + * This library is free for commercial and non-commercial use as long as + * the following conditions are aheared to. The following conditions + * apply to all code found in this distribution, be it the RC4, RSA, + * lhash, DES, etc., code; not just the SSL code. The SSL documentation + * included with this distribution is covered by the same copyright terms + * except that the holder is Tim Hudson (tjh@cryptsoft.com). + * + * Copyright remains Eric Young's, and as such any Copyright notices in + * the code are not to be removed. + * If this package is used in a product, Eric Young should be given attribution + * as the author of the parts of the library used. + * This can be in the form of a textual message at program startup or + * in documentation (online or textual) provided with the package. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes cryptographic software written by + * Eric Young (eay@cryptsoft.com) + * The word 'cryptographic' can be left out if the rouines from the library + * being used are not cryptographic related :-). + * 4. If you include any Windows specific code (or a derivative thereof) from + * the apps directory (application code) you must include an acknowledgement: + * This product includes software written by Tim Hudson (tjh@cryptsoft.com) + * + * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * The licence and distribution terms for any publically available version or + * derivative of this code cannot be changed. i.e. this code cannot simply be + * copied and put under another distribution licence + * [including the GNU Public Licence.] +========================================= +END OF OpenSSL NOTICES, INFORMATION, AND LICENSE diff --git a/_generated/AzurePowerShellV4_Node16/TryMakingModuleAvailable.ps1 b/_generated/AzurePowerShellV4_Node16/TryMakingModuleAvailable.ps1 new file mode 100644 index 000000000000..71d91e944af9 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/TryMakingModuleAvailable.ps1 @@ -0,0 +1,85 @@ +[CmdletBinding()] +param ( + [string] + $targetVersion, + + [string] [Parameter(Mandatory = $true)] [ValidateSet("Windows", "Linux", "Mac")] + $platform +) + +try { + $isWin = $platform -eq "Windows" + + . (Join-Path $PSScriptRoot "Utility.ps1") + $isHostedAgent = Test-IsHostedAgentPathPresent -isWin $isWin + + if (!$isHostedAgent) { + Write-Verbose "Module path not present as expected in hosted agent, skipping step to make module available." + $moduleSource = "privateAgent" + return + } + + if (!$targetVersion) { + Write-Verbose "Latest selected, will make use of the latest available in agent as folder." + $moduleSource = "hostedAgentFolder" + return + } + + $modulePath = Get-SavedModulePath -azurePowerShellVersion $targetVersion -isWin $isWin + if (Test-Path $modulePath) { + Write-Verbose "Az $targetVersion present at $modulePath as folder." + $moduleSource = "hostedAgentFolder" + return + } + + $moduleContainerPath = Get-SavedModuleContainerPath -isWin $isWin + $moduleZipPath = $modulePath + ".zip"; + if (Test-Path $moduleZipPath) { + Write-Verbose "Az $targetVersion present at $moduleZipPath as zip, expanding it." + Expand-ModuleZip -zipPath $moduleZipPath -destination $moduleContainerPath -isWin $isWin + Write-Verbose "Zip expanded" + $moduleSource = "hostedAgentZip" + return + } + + Write-Host "Az version $targetVersion not avaiable locally on the agent. Downloading dynamically." + + try { + Write-Verbose "Getting versions manifest from GHRelease." + $versionsManifest = Invoke-RestMethod -Method Get ` + -Headers @{ "Accept" = "application/vnd.github.VERSION.raw" } ` + -Uri "https://api.github.com/repos/Azure/az-ps-module-versions/contents/versions-manifest.json" + Write-Verbose "Versions manifest downloaded." + $downloadUrlEntity = $versionsManifest | Where-Object version -eq $targetVersion + if ($downloadUrlEntity) { + $downloadUrl = $downloadUrlEntity.files[0].download_url + Write-Verbose "Downloading Az $targetVersion from GHRelease" + (New-Object System.Net.WebClient).DownloadFile($downloadUrl, $moduleZipPath) + Write-Verbose "Download succeeded" + if (Test-Path $moduleZipPath) { + Write-Verbose "Expanding Az $targetVersion downloaded at $moduleZipPath as zip." + Expand-ModuleZip -zipPath $moduleZipPath -destination $moduleContainerPath -isWin $isWin + Write-Verbose "Zip expanded" + $moduleSource = "hostedAgentGHRelease" + return + } + } else { + Write-Verbose "Az $targetVersion not present in versions manifest from GHRelease" + } + } catch { + Write-Verbose "Failed to download from GHRelease" + Write-Verbose $_ + } + + Write-Verbose "Downloading Az $targetVersion from PSGallery." + Save-Module -Path $modulePath -Name Az -RequiredVersion $targetVersion -Force -ErrorAction Stop + $moduleSource = "hostedAgentPSGallery" +} finally { + # Telemetry + # moduleSource value will be privateAgent(in case of self hosted private agents), hostedAgentFolder(when a version is present as folder or + # when latest is selected we will use the one latest available as folder), hostedAgentZip(when the module is available as a zip locally), + # hostedAgentGHRelease(when the module zip is downloaded from our GitHub releases management), hostedAgentPSGallery(when we download from PSGallery + # using the Save-Module cmdlet). + $telemetryJsonContent = @{ targetAzurePs = $targetVersion; moduleSource = $moduleSource } | ConvertTo-Json -Compress + Write-Host "##vso[telemetry.publish area=TaskHub;feature=AzurePowerShellV4]$telemetryJsonContent" +} diff --git a/_generated/AzurePowerShellV4_Node16/UpdatePSModulePath.ps1 b/_generated/AzurePowerShellV4_Node16/UpdatePSModulePath.ps1 new file mode 100644 index 000000000000..e36160743c59 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/UpdatePSModulePath.ps1 @@ -0,0 +1,11 @@ +[CmdletBinding()] +param +( + [String] [Parameter(Mandatory = $false)] + $targetAzurePs +) + +# Update PSModulePath for hosted agent +. "$PSScriptRoot\Utility.ps1" +CleanUp-PSModulePathForHostedAgent +Update-PSModulePathForHostedAgent -targetAzurePs $targetAzurePs \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/Utility.ps1 b/_generated/AzurePowerShellV4_Node16/Utility.ps1 new file mode 100644 index 000000000000..8e6804ffe66e --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/Utility.ps1 @@ -0,0 +1,203 @@ +function Get-SavedModuleContainerPath { + [CmdletBinding()] + param ( + [Parameter(Mandatory = $true)] + [bool] + $isWin + ) + + if ($isWin) { + return $env:SystemDrive + "\Modules"; + } else { + return "/usr/share"; + } +} + +function Test-IsHostedAgentPathPresent { + [CmdletBinding()] + param ( + [Parameter(Mandatory = $true)] + [bool] + $isWin + ) + + $containerPath = Get-SavedModuleContainerPath -isWin $isWin + return Test-Path (Join-Path $containerPath "az_*") +} + +function Get-SavedModulePath { + [CmdletBinding()] + param ( + [Parameter(Mandatory = $true)] + [string] + $azurePowerShellVersion, + + [Parameter(Mandatory = $true)] + [bool] + $isWin + ) + + $savedModulePath = Join-Path (Get-SavedModuleContainerPath -isWin $isWin) "az_$azurePowerShellVersion" + Write-Verbose "The value of the module path is: $savedModulePath" + return $savedModulePath +} + +function Expand-ModuleZip { + param ( + [string] [Parameter(Mandatory = $true)] + $zipPath, + + [string] [Parameter(Mandatory = $true)] + $destination, + + [bool] [Parameter(Mandatory=$true)] + $isWin + ) + + if ($isWin) { + $parameter = @("x", "-o$destination", "$zipPath") + $command = "$PSScriptRoot\7zip\7z.exe" + &$command @parameter + } else { + $prevProgressPref = $ProgressPreference + $ProgressPreference = 'SilentlyContinue' + Expand-Archive -Path $zipPath -DestinationPath $destination + $ProgressPreference = $prevProgressPref + } +} + +function Update-PSModulePathForHostedAgent { + [CmdletBinding()] + param([string] $targetAzurePs) + try { + if ($targetAzurePs) { + $hostedAgentAzModulePath = Get-SavedModulePath -azurePowerShellVersion $targetAzurePs -isWin $true + } + else { + $hostedAgentAzModulePath = Get-LatestModule -patternToMatch "^az_[0-9]+\.[0-9]+\.[0-9]+$" -patternToExtract "[0-9]+\.[0-9]+\.[0-9]+$" + } + $env:PSModulePath = $hostedAgentAzModulePath + ";" + $env:PSModulePath + $env:PSModulePath = $env:PSModulePath.TrimStart(';') + } finally { + Write-Verbose "The updated value of the PSModulePath is: $($env:PSModulePath)" + } +} + +function Update-PSModulePathForHostedAgentLinux { + [CmdletBinding()] + param([string] $targetAzurePs) + try { + if ($targetAzurePs) { + $hostedAgentAzModulePath = Get-SavedModulePath -azurePowerShellVersion $targetAzurePs -isWin $false + if(!(Test-Path $hostedAgentAzModulePath)) { + Write-Verbose "No module path found with this name" + throw ("Could not find the module path with given version.") + } + } + else { + $hostedAgentAzModulePath = Get-LatestModuleLinux -patternToMatch "^az_[0-9]+\.[0-9]+\.[0-9]+$" -patternToExtract "[0-9]+\.[0-9]+\.[0-9]+$" + } + $env:PSModulePath = $hostedAgentAzModulePath + ":" + $env:PSModulePath + $env:PSModulePath = $env:PSModulePath.TrimStart(':') + } finally { + Write-Verbose "The updated value of the PSModulePath is: $($env:PSModulePath)" + } +} + +function Get-LatestModule { + [CmdletBinding()] + param([string] $patternToMatch, + [string] $patternToExtract) + + $resultFolder = "" + $regexToMatch = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToMatch + $regexToExtract = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToExtract + $maxVersion = [version] "0.0.0" + $modulePath = $env:SystemDrive + "\Modules"; + + try { + if (-not (Test-Path -Path $modulePath)) { + return $resultFolder + } + + $moduleFolders = Get-ChildItem -Directory -Path $modulePath | Where-Object { $regexToMatch.IsMatch($_.Name) } + foreach ($moduleFolder in $moduleFolders) { + $moduleVersion = [version] $($regexToExtract.Match($moduleFolder.Name).Groups[0].Value) + if($moduleVersion -gt $maxVersion) { + $modulePath = [System.IO.Path]::Combine($moduleFolder.FullName,"Az\$moduleVersion\Az.psm1") + + if(Test-Path -LiteralPath $modulePath -PathType Leaf) { + $maxVersion = $moduleVersion + $resultFolder = $moduleFolder.FullName + } else { + Write-Verbose "A folder matching the module folder pattern was found at $($moduleFolder.FullName) but didn't contain a valid module file" + } + } + } + } + catch { + Write-Verbose "Attempting to find the Latest Module Folder failed with the error: $($_.Exception.Message)" + $resultFolder = "" + } + Write-Verbose "Latest module folder detected: $resultFolder" + return $resultFolder +} + +function Get-LatestModuleLinux { + [CmdletBinding()] + param([string] $patternToMatch, + [string] $patternToExtract) + + $resultFolder = "" + $regexToMatch = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToMatch + $regexToExtract = New-Object -TypeName System.Text.RegularExpressions.Regex -ArgumentList $patternToExtract + $maxVersion = [version] "0.0.0" + + try { + $moduleFolders = Get-ChildItem -Directory -Path $("/usr/share") | Where-Object { $regexToMatch.IsMatch($_.Name) } + foreach ($moduleFolder in $moduleFolders) { + $moduleVersion = [version] $($regexToExtract.Match($moduleFolder.Name).Groups[0].Value) + if($moduleVersion -gt $maxVersion) { + $modulePath = [System.IO.Path]::Combine($moduleFolder.FullName,"Az/$moduleVersion/Az.psm1") + + if(Test-Path -LiteralPath $modulePath -PathType Leaf) { + $maxVersion = $moduleVersion + $resultFolder = $moduleFolder.FullName + } else { + Write-Verbose "A folder matching the module folder pattern was found at $($moduleFolder.FullName) but didn't contain a valid module file" + } + } + } + } + catch { + Write-Verbose "Attempting to find the Latest Module Folder failed with the error: $($_.Exception.Message)" + $resultFolder = "" + } + Write-Verbose "Latest module folder detected: $resultFolder" + return $resultFolder +} + +function CleanUp-PSModulePathForHostedAgent { + # Clean up PSModulePath for hosted agent + $azureRMModulePath = "C:\Modules\azurerm_2.1.0" + $azureModulePath = "C:\Modules\azure_2.1.0" + $azPSModulePath = $env:PSModulePath + + if ($azPSModulePath.split(";") -contains $azureRMModulePath) { + $azPSModulePath = (($azPSModulePath).Split(";") | ? { $_ -ne $azureRMModulePath }) -join ";" + write-verbose "$azureRMModulePath removed. Restart the prompt for the changes to take effect." + } + else { + write-verbose "$azureRMModulePath is not present in $azPSModulePath" + } + + if ($azPSModulePath.split(";") -contains $azureModulePath) { + $azPSModulePath = (($azPSModulePath).Split(";") | ? { $_ -ne $azureModulePath }) -join ";" + write-verbose "$azureModulePath removed. Restart the prompt for the changes to take effect." + } + else { + write-verbose "$azureModulePath is not present in $azPSModulePath" + } + + $env:PSModulePath = $azPSModulePath +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/azurepowershell.ts b/_generated/AzurePowerShellV4_Node16/azurepowershell.ts new file mode 100644 index 000000000000..055826a0965a --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/azurepowershell.ts @@ -0,0 +1,169 @@ +import fs = require('fs'); +import path = require('path'); +import os = require('os'); +import tl = require('azure-pipelines-task-lib/task'); +import tr = require('azure-pipelines-task-lib/toolrunner'); +import * as telemetry from 'azure-pipelines-tasks-utility-common/telemetry'; + +import { AzureRMEndpoint } from 'azure-pipelines-tasks-azure-arm-rest/azure-arm-endpoint'; +var uuidV4 = require('uuid/v4'); + +function convertToNullIfUndefined(arg: T): T|null { + return arg ? arg : null; +} + +async function run() { + try { + tl.setResourcePath(path.join(__dirname, 'task.json')); + + // Get inputs. + console.log("## Validating Inputs"); + let _vsts_input_errorActionPreference: string = tl.getInput('errorActionPreference', false) || 'Stop'; + switch (_vsts_input_errorActionPreference.toUpperCase()) { + case 'STOP': + case 'CONTINUE': + case 'SILENTLYCONTINUE': + break; + default: + throw new Error(tl.loc('JS_InvalidErrorActionPreference', _vsts_input_errorActionPreference)); + } + let scriptType: string = tl.getInput('ScriptType', /*required*/true); + let scriptPath = convertToNullIfUndefined(tl.getPathInput('ScriptPath', false)); + let scriptInline: string = convertToNullIfUndefined(tl.getInput('Inline', false)); + let scriptArguments: string = convertToNullIfUndefined(tl.getInput('ScriptArguments', false)); + let _vsts_input_failOnStandardError = convertToNullIfUndefined(tl.getBoolInput('FailOnStandardError', false)); + let targetAzurePs: string = convertToNullIfUndefined(tl.getInput('TargetAzurePs', false)); + let customTargetAzurePs: string = convertToNullIfUndefined(tl.getInput('CustomTargetAzurePs', false)); + let serviceName = tl.getInput('ConnectedServiceNameARM',/*required*/true); + let endpointObject= await new AzureRMEndpoint(serviceName).getEndpoint(); + let input_workingDirectory = tl.getPathInput('workingDirectory', /*required*/ true, /*check*/ true); + let isDebugEnabled = (process.env['SYSTEM_DEBUG'] || "").toLowerCase() === "true"; + + // string constants + let otherVersion = "OtherVersion" + + if (targetAzurePs == otherVersion) { + if (customTargetAzurePs != "") { + targetAzurePs = customTargetAzurePs; + } + else { + console.log(tl.loc('InvalidAzurePsVersion',customTargetAzurePs)); + } + } + else { + targetAzurePs = "" + } + + var endpoint = JSON.stringify(endpointObject); + + if (scriptType.toUpperCase() == 'FILEPATH') { + if (!tl.stats(scriptPath).isFile() || !scriptPath.toUpperCase().match(/\.PS1$/)) { + throw new Error(tl.loc('JS_InvalidFilePath', scriptPath)); + } + } + console.log("## Validating Inputs Complete"); + + // Generate the script contents. + console.log("## Initializing Az module"); + console.log(tl.loc('GeneratingScript')); + let contents: string[] = []; + + if (isDebugEnabled) { + contents.push("$VerbosePreference = 'continue'"); + } + + const makeModuleAvailableScriptPath = path.join(path.resolve(__dirname), 'TryMakingModuleAvailable.ps1'); + contents.push(`${makeModuleAvailableScriptPath} -targetVersion '${targetAzurePs}' -platform Linux`); + + let azFilePath = path.join(path.resolve(__dirname), 'InitializeAz.ps1'); + contents.push(`$ErrorActionPreference = '${_vsts_input_errorActionPreference}'`); + if(targetAzurePs == "") { + contents.push(`${azFilePath} -endpoint '${endpoint}'`); + } + else { + contents.push(`${azFilePath} -endpoint '${endpoint}' -targetAzurePs ${targetAzurePs}`); + } + + if(scriptArguments == null) + { + scriptArguments = ""; + } + + if (scriptType.toUpperCase() == 'FILEPATH') { + contents.push(`. '${scriptPath.replace(/'/g, "''")}' ${scriptArguments}`.trim()); + console.log(tl.loc('JS_FormattedCommand', contents[contents.length - 1])); + } + else { + contents.push(scriptInline); + } + + // Write the script to disk. + tl.assertAgent('2.115.0'); + let tempDirectory = tl.getVariable('agent.tempDirectory'); + tl.checkPath(tempDirectory, `${tempDirectory} (agent.tempDirectory)`); + let filePath = path.join(tempDirectory, uuidV4() + '.ps1'); + await fs.writeFile( + filePath, + '\ufeff' + contents.join(os.EOL), // Prepend the Unicode BOM character. + { encoding: 'utf8' }, // Since UTF8 encoding is specified, node will + function (err) { // encode the BOM into its UTF8 binary sequence. + if (err) throw err; + console.log('Saved!'); + }); + console.log("## Az module initialization Complete"); + console.log("## Beginning Script Execution"); + // Run the script. + // + // Note, prefer "pwsh" over "powershell". At some point we can remove support for "powershell". + // + // Note, use "-Command" instead of "-File" to match the Windows implementation. Refer to + // comment on Windows implementation for an explanation why "-Command" is preferred. + let powershell = tl.tool(tl.which('pwsh') || tl.which('powershell') || tl.which('pwsh', true)) + .arg('-NoLogo') + .arg('-NoProfile') + .arg('-NonInteractive') + .arg('-ExecutionPolicy') + .arg('Unrestricted') + .arg('-Command') + .arg(`. '${filePath.replace(/'/g, "''")}'`); + + let options = { + cwd: input_workingDirectory, + failOnStdErr: false, + errStream: process.stdout, // Direct all output to STDOUT, otherwise the output may appear out + outStream: process.stdout, // of order since Node buffers it's own STDOUT but not STDERR. + ignoreReturnCode: true + }; + + // Listen for stderr. + let stderrFailure = false; + if (_vsts_input_failOnStandardError) { + powershell.on('stderr', (data) => { + stderrFailure = true; + }); + } + + // Run bash. + let exitCode: number = await powershell.exec(options); + + // Fail on exit code. + if (exitCode !== 0) { + tl.setResult(tl.TaskResult.Failed, tl.loc('JS_ExitCode', exitCode)); + } + + // Fail on stderr. + if (stderrFailure) { + tl.setResult(tl.TaskResult.Failed, tl.loc('JS_Stderr')); + } + console.log("## Script Execution Complete"); + } + catch (err) { + // troubleshoot link + const troubleshoot = "https://aka.ms/azurepowershelltroubleshooting"; + console.log(`##[error] run failed: For troubleshooting, refer: ${troubleshoot}`); + tl.setResult(tl.TaskResult.Failed, err.message || 'run() failed'); + } +} + + +run(); diff --git a/_generated/AzurePowerShellV4_Node16/icon.png b/_generated/AzurePowerShellV4_Node16/icon.png new file mode 100644 index 000000000000..039b77995289 Binary files /dev/null and b/_generated/AzurePowerShellV4_Node16/icon.png differ diff --git a/_generated/AzurePowerShellV4_Node16/icon.svg b/_generated/AzurePowerShellV4_Node16/icon.svg new file mode 100644 index 000000000000..9d97d76e24ec --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/icon.svg @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + + + diff --git a/_generated/AzurePowerShellV4_Node16/make.json b/_generated/AzurePowerShellV4_Node16/make.json new file mode 100644 index 000000000000..b23bd532015c --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/make.json @@ -0,0 +1,52 @@ +{ + "rm": [ + { + "items": [ + "node_modules/https-proxy-agent/node_modules/agent-base", + "node_modules/azure-pipelines-tasks-azure-arm-rest/node_modules/azure-pipelines-task-lib", + "node_modules/azure-pipelines-tasks-utility-common/node_modules/azure-pipelines-task-lib", + "node_modules/azure-pipelines-tool-lib/node_modules/azure-pipelines-task-lib" + ], + "options": "-Rf" + } + ], + "common": [ + { + "module": "../Common/VstsAzureHelpers_", + "type": "ps" + }, + { + "module": "../Common/TlsHelper_", + "type": "ps" + } + ], + "externals": { + "nugetv2": [ + { + "name": "VstsTaskSdk", + "version": "0.11.0", + "repository": "https://www.powershellgallery.com/api/v2/", + "cp": [ + { + "source": [ + "*.dll", + "*.ps1", + "*.psd1", + "*.psm1", + "lib.json", + "Strings" + ], + "dest": "ps_modules/VstsTaskSdk/", + "options": "-R" + } + ] + } + ], + "archivePackages": [ + { + "url": "https://vstsagenttools.blob.core.windows.net/tools/7zip/1/7zip.zip", + "dest": "./" + } + ] + } +} diff --git a/_generated/AzurePowerShellV4_Node16/package-lock.json b/_generated/AzurePowerShellV4_Node16/package-lock.json new file mode 100644 index 000000000000..4df893519494 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/package-lock.json @@ -0,0 +1,859 @@ +{ + "name": "azure-powershell-v4", + "requires": true, + "lockfileVersion": 1, + "dependencies": { + "@azure/msal-common": { + "version": "9.1.1", + "resolved": "https://registry.npmjs.org/@azure/msal-common/-/msal-common-9.1.1.tgz", + "integrity": "sha512-we9xR8lvu47fF0h+J8KyXoRy9+G/fPzm3QEa2TrdR3jaVS3LKAyE2qyMuUkNdbVkvzl8Zr9f7l+IUSP22HeqXw==" + }, + "@azure/msal-node": { + "version": "1.14.5", + "resolved": "https://registry.npmjs.org/@azure/msal-node/-/msal-node-1.14.5.tgz", + "integrity": "sha512-NcVdMfn8Z3ogN+9RjOSF7uwf2Gki5DEJl0BdDSL83KUAgVAobtkZi5W8EqxbJLrTO/ET0jv5DregrcR5qg2pEA==", + "requires": { + "@azure/msal-common": "^9.0.1", + "jsonwebtoken": "^8.5.1", + "uuid": "^8.3.0" + }, + "dependencies": { + "uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" + } + } + }, + "@types/concat-stream": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/@types/concat-stream/-/concat-stream-1.6.1.tgz", + "integrity": "sha512-eHE4cQPoj6ngxBZMvVf6Hw7Mh4jMW4U9lpGmS5GBPB9RYxlFg+CHaVN7ErNY4W9XfLIEn20b4VDYaIrbq0q4uA==", + "requires": { + "@types/node": "*" + } + }, + "@types/form-data": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/@types/form-data/-/form-data-0.0.33.tgz", + "integrity": "sha512-8BSvG1kGm83cyJITQMZSulnl6QV8jqAGreJsc5tPu1Jq0vTSOiY/k24Wx82JRpWwZSqrala6sd5rWi6aNXvqcw==", + "requires": { + "@types/node": "*" + } + }, + "@types/jsonwebtoken": { + "version": "8.5.9", + "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.9.tgz", + "integrity": "sha512-272FMnFGzAVMGtu9tkr29hRL6bZj4Zs1KZNeHLnKqAvp06tAIcarTMwOh8/8bz4FmKRcMxZhZNeUAQsNLoiPhg==", + "requires": { + "@types/node": "*" + } + }, + "@types/mocha": { + "version": "5.2.7", + "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-5.2.7.tgz", + "integrity": "sha512-NYrtPht0wGzhwe9+/idPaBB+TqkY9AhTvOLMkThm0IoEfLaiVQZwBwyJ5puCkO3AUCWrmcoePjp2mbFocKy4SQ==" + }, + "@types/node": { + "version": "16.18.39", + "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.39.tgz", + "integrity": "sha512-8q9ZexmdYYyc5/cfujaXb4YOucpQxAV4RMG0himLyDUOEr8Mr79VrqsFI+cQ2M2h89YIuy95lbxuYjxT4Hk4kQ==" + }, + "@types/q": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.0.7.tgz", + "integrity": "sha512-0WS7XU7sXzQ7J1nbnMKKYdjrrFoO3YtZYgUzeV8JFXffPnHfvSJQleR70I8BOAsOm14i4dyaAZ3YzqIl1YhkXQ==" + }, + "@types/qs": { + "version": "6.9.7", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", + "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" + }, + "@types/semver": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-5.5.0.tgz", + "integrity": "sha512-41qEJgBH/TWgo5NFSvBCJ1qkoi3Q6ONSF2avrHq1LVEZfYpdHmj0y9SuTK+u9ZhG1sYQKBL1AWXKyLWP4RaUoQ==" + }, + "@types/uuid": { + "version": "3.4.10", + "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-3.4.10.tgz", + "integrity": "sha512-BgeaZuElf7DEYZhWYDTc/XcLZXdVgFkVSTa13BqKvbnmUrxr3TJFKofUxCtDO9UQOdhnV+HPOESdHiHKZOJV1A==" + }, + "agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "requires": { + "debug": "4" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "asap": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", + "integrity": "sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA==" + }, + "async-mutex": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/async-mutex/-/async-mutex-0.4.0.tgz", + "integrity": "sha512-eJFZ1YhRR8UN8eBLoNzcDPcy/jqjsg6I1AP+KvWQX80BqOSW1oJPJXDylPUEeMr2ZQvHgnQ//Lp6f3RQ1zI7HA==", + "requires": { + "tslib": "^2.4.0" + } + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + }, + "azure-devops-node-api": { + "version": "12.1.0", + "resolved": "https://registry.npmjs.org/azure-devops-node-api/-/azure-devops-node-api-12.1.0.tgz", + "integrity": "sha512-VY+G45eNKVJfMIO0uyZfbi4PzUR8JHEfsHQjEUAXUGRkYhhBbhGHjy8cpiyYFxLXc3a4PL5cqgqqV/YD1SaCXg==", + "requires": { + "tunnel": "0.0.6", + "typed-rest-client": "^1.8.4" + } + }, + "azure-pipelines-task-lib": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-4.4.0.tgz", + "integrity": "sha512-JgtxfjxjRA+KWY0Q5UC1fo48nkbVxFHgKEuasKdJMSNxHydOyNlB5MNw4UTiTXp9b0nnqKeOQOBn5RN3go3aPg==", + "requires": { + "minimatch": "3.0.5", + "mockery": "^2.1.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.5", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + }, + "azure-pipelines-tasks-azure-arm-rest": { + "version": "3.225.1", + "resolved": "https://registry.npmjs.org/azure-pipelines-tasks-azure-arm-rest/-/azure-pipelines-tasks-azure-arm-rest-3.225.1.tgz", + "integrity": "sha512-fbRcoYKEbFj2jslocX4wV0hbnN/9ZGepdzcLI+5vdOkGcKNIdOctUNvggrN1KFg9nH+NoxK1pE4+kl316VVpMA==", + "requires": { + "@azure/msal-node": "1.14.5", + "@types/jsonwebtoken": "^8.5.8", + "@types/mocha": "^5.2.7", + "@types/node": "^10.17.0", + "@types/q": "1.5.4", + "async-mutex": "^0.4.0", + "azure-devops-node-api": "^12.0.0", + "azure-pipelines-task-lib": "^3.4.0", + "https-proxy-agent": "^4.0.0", + "jsonwebtoken": "^8.5.1", + "node-fetch": "^2.6.7", + "q": "1.5.1", + "typed-rest-client": "1.8.4", + "xml2js": "0.4.13" + }, + "dependencies": { + "@types/node": { + "version": "10.17.60", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.60.tgz", + "integrity": "sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==" + }, + "@types/q": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.4.tgz", + "integrity": "sha512-1HcDas8SEj4z1Wc696tH56G8OlRaH/sqZOynNNB+HF0WOeXPaxTtbYzJY2oEfiUxjSKjhCKr+MvR7dCHcEelug==" + }, + "azure-pipelines-task-lib": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/azure-pipelines-task-lib/-/azure-pipelines-task-lib-3.4.0.tgz", + "integrity": "sha512-3eC4OTFw+7xD7A2aUhxR/j+jRlTI+vVfS0CGxt1pCLs4c/KmY0tQWgbqjD3157kmiucWxELBvgZHaD2gCBe9fg==", + "requires": { + "minimatch": "3.0.5", + "mockery": "^2.1.0", + "q": "^1.5.1", + "semver": "^5.1.0", + "shelljs": "^0.8.5", + "sync-request": "6.1.0", + "uuid": "^3.0.1" + } + } + } + }, + "azure-pipelines-tasks-utility-common": { + "version": "3.225.0", + "resolved": "https://registry.npmjs.org/azure-pipelines-tasks-utility-common/-/azure-pipelines-tasks-utility-common-3.225.0.tgz", + "integrity": "sha512-Na7g1+zcsQpYogyex457QT6o9EB2+WQYwLUXPiszhTdf83hKJUmDMqvl2qm/mHqYuP1zg5KkRfJaPy4/09M8pA==", + "requires": { + "@types/node": "^16.11.39", + "azure-pipelines-task-lib": "^4.4.0", + "azure-pipelines-tool-lib": "^2.0.0-preview", + "js-yaml": "3.13.1", + "semver": "^5.4.1" + } + }, + "azure-pipelines-tool-lib": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/azure-pipelines-tool-lib/-/azure-pipelines-tool-lib-2.0.4.tgz", + "integrity": "sha512-LgAelZKJe3k/t3NsKSKzjeRviphns0w0p5tgwz8uHN70I9m2TToiOKl+fogrdXcM6+jiLBk5KTqrcRBqPpv/XA==", + "requires": { + "@types/semver": "^5.3.0", + "@types/uuid": "^3.4.5", + "azure-pipelines-task-lib": "^4.1.0", + "semver": "^5.7.0", + "semver-compare": "^1.0.0", + "typed-rest-client": "^1.8.6", + "uuid": "^3.3.2" + }, + "dependencies": { + "typed-rest-client": { + "version": "1.8.11", + "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.8.11.tgz", + "integrity": "sha512-5UvfMpd1oelmUPRbbaVnq+rHP7ng2cE4qoQkQeAqxRL6PklkxsM0g32/HL0yfvruK6ojQ5x8EE+HF4YV6DtuCA==", + "requires": { + "qs": "^6.9.1", + "tunnel": "0.0.6", + "underscore": "^1.12.1" + } + } + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "buffer-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" + }, + "buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" + }, + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==" + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "core-util-is": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" + }, + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "requires": { + "ms": "2.1.2" + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" + }, + "ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" + }, + "form-data": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.5.1.tgz", + "integrity": "sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA==", + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "get-intrinsic": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", + "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3" + } + }, + "get-port": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/get-port/-/get-port-3.2.0.tgz", + "integrity": "sha512-x5UJKlgeUiNT8nyo/AcnwLnZuZNcSjSw0kogRB+Whd1fjjFq4B1hySFxSFWWSn4mIBzg3sRNUDFYc4g5gjPoLg==" + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "dependencies": { + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "requires": { + "brace-expansion": "^1.1.7" + } + } + } + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==" + }, + "has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" + }, + "http-basic": { + "version": "8.1.3", + "resolved": "https://registry.npmjs.org/http-basic/-/http-basic-8.1.3.tgz", + "integrity": "sha512-/EcDMwJZh3mABI2NhGfHOGOeOZITqfkEO4p/xK+l3NpyncIHUQBoMvCSF/b5GqvKtySC2srL/GGG3+EtlqlmCw==", + "requires": { + "caseless": "^0.12.0", + "concat-stream": "^1.6.2", + "http-response-object": "^3.0.1", + "parse-cache-control": "^1.0.1" + } + }, + "http-response-object": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/http-response-object/-/http-response-object-3.0.2.tgz", + "integrity": "sha512-bqX0XTF6fnXSQcEJ2Iuyr75yVakyjIDCqroJQ/aHfSdlM743Cwqoi2nDYMzLGWUcuTWGWy8AAvOKXTfiv6q9RA==", + "requires": { + "@types/node": "^10.0.3" + }, + "dependencies": { + "@types/node": { + "version": "10.17.60", + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.60.tgz", + "integrity": "sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==" + } + } + }, + "https-proxy-agent": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-4.0.0.tgz", + "integrity": "sha512-zoDhWrkR3of1l9QAL8/scJZyLu8j/gBkcwcaQOZh7Gyh/+uJQzGVETdgT30akuwkpL8HTRfssqI3BZuV18teDg==", + "requires": { + "agent-base": "5", + "debug": "4" + }, + "dependencies": { + "agent-base": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-5.1.1.tgz", + "integrity": "sha512-TMeqbNl2fMW0nMjTEPOwe3J/PRFP4vqeoNuQMG0HlMrtm5QxKqdvAkZ1pRBQ/ulIyDD5Yq0nJ7YbdD8ey0TO3g==" + } + } + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "interpret": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.4.0.tgz", + "integrity": "sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA==" + }, + "is-core-module": { + "version": "2.12.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", + "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", + "requires": { + "has": "^1.0.3" + } + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsonwebtoken": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", + "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", + "requires": { + "jws": "^3.2.2", + "lodash.includes": "^4.3.0", + "lodash.isboolean": "^3.0.3", + "lodash.isinteger": "^4.0.4", + "lodash.isnumber": "^3.0.3", + "lodash.isplainobject": "^4.0.6", + "lodash.isstring": "^4.0.1", + "lodash.once": "^4.0.0", + "ms": "^2.1.1", + "semver": "^5.6.0" + } + }, + "jwa": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", + "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", + "requires": { + "buffer-equal-constant-time": "1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "jws": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", + "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", + "requires": { + "jwa": "^1.4.1", + "safe-buffer": "^5.0.1" + } + }, + "lodash.includes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", + "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" + }, + "lodash.isboolean": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", + "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" + }, + "lodash.isinteger": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", + "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" + }, + "lodash.isnumber": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", + "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" + }, + "lodash.isplainobject": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", + "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" + }, + "lodash.isstring": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", + "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" + }, + "lodash.once": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", + "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" + }, + "mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" + }, + "mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "requires": { + "mime-db": "1.52.0" + } + }, + "minimatch": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.5.tgz", + "integrity": "sha512-tUpxzX0VAzJHjLu0xUfFv1gwVp9ba3IOuRAVH2EGuRW8a5emA2FlACLqiT/lDVtS1W+TGNwqz3sWaNyLgDJWuw==", + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "mockery": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mockery/-/mockery-2.1.0.tgz", + "integrity": "sha512-9VkOmxKlWXoDO/h1jDZaS4lH33aWfRiJiNT/tKj+8OGzrcFDLo8d0syGdbsc3Bc4GvRXPb+NMMvojotmuGJTvA==" + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + }, + "node-fetch": { + "version": "2.6.12", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.12.tgz", + "integrity": "sha512-C/fGU2E8ToujUivIO0H+tpQ6HWo4eEmchoPIoXtxCrVghxdKq+QOHqEZW7tuP3KlV3bC8FRMO5nMCC7Zm1VP6g==", + "requires": { + "whatwg-url": "^5.0.0" + } + }, + "object-inspect": { + "version": "1.12.3", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", + "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "requires": { + "wrappy": "1" + } + }, + "parse-cache-control": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parse-cache-control/-/parse-cache-control-1.0.1.tgz", + "integrity": "sha512-60zvsJReQPX5/QP0Kzfd/VrpjScIQ7SHBW6bFCYfEP+fp0Eppr1SHhIO5nd1PjZtvclzSzES9D/p5nFJurwfWg==" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + }, + "promise": { + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/promise/-/promise-8.3.0.tgz", + "integrity": "sha512-rZPNPKTOYVNEEKFaq1HqTgOwZD+4/YHS5ukLzQCypkj+OkYx7iv0mA91lJlpPPZ8vMau3IIGj5Qlwrx+8iiSmg==", + "requires": { + "asap": "~2.0.6" + } + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==" + }, + "qs": { + "version": "6.11.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.2.tgz", + "integrity": "sha512-tDNIz22aBzCDxLtVH++VnTfzxlfeK5CbqohpSqpJgj1Wg/cQbStNAz3NuqCs5vV+pjBsK4x4pN9HlVh7rcYRiA==", + "requires": { + "side-channel": "^1.0.4" + } + }, + "readable-stream": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", + "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rechoir": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", + "integrity": "sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw==", + "requires": { + "resolve": "^1.1.6" + } + }, + "resolve": { + "version": "1.22.2", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", + "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", + "requires": { + "is-core-module": "^2.11.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "sax": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", + "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" + }, + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==" + }, + "semver-compare": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", + "integrity": "sha512-YM3/ITh2MJ5MtzaM429anh+x2jiLVjqILF4m4oyQB18W7Ggea7BfqdH/wGMK7dDiMghv/6WG7znWMwUDzJiXow==" + }, + "shelljs": { + "version": "0.8.5", + "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.8.5.tgz", + "integrity": "sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==", + "requires": { + "glob": "^7.0.0", + "interpret": "^1.0.0", + "rechoir": "^0.6.2" + } + }, + "side-channel": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", + "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", + "requires": { + "call-bind": "^1.0.0", + "get-intrinsic": "^1.0.2", + "object-inspect": "^1.9.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" + }, + "sync-request": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/sync-request/-/sync-request-6.1.0.tgz", + "integrity": "sha512-8fjNkrNlNCrVc/av+Jn+xxqfCjYaBoHqCsDz6mt030UMxJGr+GSfCV1dQt2gRtlL63+VPidwDVLr7V2OcTSdRw==", + "requires": { + "http-response-object": "^3.0.1", + "sync-rpc": "^1.2.1", + "then-request": "^6.0.0" + } + }, + "sync-rpc": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/sync-rpc/-/sync-rpc-1.3.6.tgz", + "integrity": "sha512-J8jTXuZzRlvU7HemDgHi3pGnh/rkoqR/OZSjhTyyZrEkkYQbk7Z33AXp37mkPfPpfdOuj7Ex3H/TJM1z48uPQw==", + "requires": { + "get-port": "^3.1.0" + } + }, + "then-request": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/then-request/-/then-request-6.0.2.tgz", + "integrity": "sha512-3ZBiG7JvP3wbDzA9iNY5zJQcHL4jn/0BWtXIkagfz7QgOL/LqjCEOBQuJNZfu0XYnv5JhKh+cDxCPM4ILrqruA==", + "requires": { + "@types/concat-stream": "^1.6.0", + "@types/form-data": "0.0.33", + "@types/node": "^8.0.0", + "@types/qs": "^6.2.31", + "caseless": "~0.12.0", + "concat-stream": "^1.6.0", + "form-data": "^2.2.0", + "http-basic": "^8.1.1", + "http-response-object": "^3.0.1", + "promise": "^8.0.0", + "qs": "^6.4.0" + }, + "dependencies": { + "@types/node": { + "version": "8.10.66", + "resolved": "https://registry.npmjs.org/@types/node/-/node-8.10.66.tgz", + "integrity": "sha512-tktOkFUA4kXx2hhhrB8bIFb5TbwzS4uOhKEmwiD+NoiL0qtP2OQ9mFldbgD4dV1djrlBYP6eBuQZiWjuHUpqFw==" + } + } + }, + "tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" + }, + "tslib": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.1.tgz", + "integrity": "sha512-t0hLfiEKfMUoqhG+U1oid7Pva4bbDPHYfJNiB7BiIjRkj1pyC++4N3huJfqY6aRH6VTB0rvtzQwjM4K6qpfOig==" + }, + "tunnel": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", + "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==" + }, + "typed-rest-client": { + "version": "1.8.4", + "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.8.4.tgz", + "integrity": "sha512-MyfKKYzk3I6/QQp6e1T50py4qg+c+9BzOEl2rBmQIpStwNUoqQ73An+Tkfy9YuV7O+o2mpVVJpe+fH//POZkbg==", + "requires": { + "qs": "^6.9.1", + "tunnel": "0.0.6", + "underscore": "^1.12.1" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==" + }, + "typescript": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.2.tgz", + "integrity": "sha512-e4ERvRV2wb+rRZ/IQeb3jm2VxBsirQLpQhdxplZ2MEzGvDkkMmPglecnNDfSUBivMjP93vRbngYYDQqQ/78bcQ==", + "dev": true + }, + "underscore": { + "version": "1.13.6", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz", + "integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==" + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" + }, + "uuid": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", + "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" + }, + "webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" + }, + "whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "requires": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" + }, + "xml2js": { + "version": "0.4.13", + "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.13.tgz", + "integrity": "sha512-BoxD65qWA2p4znzbaati/Td19uFEc0X6ydj0bFphJO62RrNaGqOyW6ljLWPo3GKDbvW/6dnxAoRX01BsgEWsMA==", + "requires": { + "sax": ">=0.6.0", + "xmlbuilder": ">=2.4.6" + } + }, + "xmlbuilder": { + "version": "15.1.1", + "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-15.1.1.tgz", + "integrity": "sha512-yMqGBqtXyeN1e3TGYvgNgDVZ3j84W4cwkOXQswghol6APgZWaff9lnbvN7MHYJOiXsvGPXtjTYJEiC9J2wv9Eg==" + } + } +} diff --git a/_generated/AzurePowerShellV4_Node16/package.json b/_generated/AzurePowerShellV4_Node16/package.json new file mode 100644 index 000000000000..9d310c0b992f --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/package.json @@ -0,0 +1,18 @@ +{ + "name": "azure-powershell-v4", + "author": { + "name": "Microsoft Corporation" + }, + "dependencies": { + "@types/mocha": "^5.2.7", + "@types/node": "^16.11.39", + "@types/q": "1.0.7", + "agent-base": "6.0.2", + "azure-pipelines-task-lib": "^4.4.0", + "azure-pipelines-tasks-azure-arm-rest": "^3.225.1", + "azure-pipelines-tasks-utility-common": "^3.225.0" + }, + "devDependencies": { + "typescript": "4.0.2" + } +} diff --git a/_generated/AzurePowerShellV4_Node16/task.json b/_generated/AzurePowerShellV4_Node16/task.json new file mode 100644 index 000000000000..0fa74857ce3b --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/task.json @@ -0,0 +1,217 @@ +{ + "id": "72A1931B-EFFB-4D2E-8FD8-F8472A07CB62", + "name": "AzurePowerShell", + "friendlyName": "Azure PowerShell", + "description": "Run a PowerShell script within an Azure environment", + "helpMarkDown": "[Learn more about this task](https://go.microsoft.com/fwlink/?LinkID=613749)", + "helpUrl": "https://aka.ms/azurepowershelltroubleshooting", + "category": "Deploy", + "visibility": [ + "Build", + "Release" + ], + "runsOn": [ + "Agent", + "DeploymentGroup" + ], + "author": "Microsoft Corporation", + "version": { + "Major": 4, + "Minor": 226, + "Patch": 0 + }, + "releaseNotes": "Added support for Az Module and cross platform agents.", + "groups": [ + { + "name": "AzurePowerShellVersionOptions", + "displayName": "Azure PowerShell version options", + "isExpanded": true + }, + { + "name": "advanced", + "displayName": "Advanced", + "isExpanded": false + } + ], + "minimumAgentVersion": "2.115.0", + "inputs": [ + { + "name": "ConnectedServiceNameARM", + "aliases": [ + "azureSubscription" + ], + "type": "connectedService:AzureRM", + "label": "Azure Subscription", + "defaultValue": "", + "required": true, + "helpMarkDown": "Azure Resource Manager subscription to configure before running PowerShell", + "properties": { + "EndpointFilterRule": "ScopeLevel != AzureMLWorkspace" + } + }, + { + "name": "ScriptType", + "type": "radio", + "label": "Script Type", + "required": false, + "helpMarkDown": "Type of the script: File Path or Inline Script", + "defaultValue": "FilePath", + "options": { + "FilePath": "Script File Path", + "InlineScript": "Inline Script" + } + }, + { + "name": "ScriptPath", + "type": "filePath", + "label": "Script Path", + "defaultValue": "", + "required": false, + "helpMarkDown": "Path of the script. Should be fully qualified path or relative to the default working directory.", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "Inline", + "type": "multiLine", + "label": "Inline Script", + "required": false, + "defaultValue": "# You can write your azure powershell scripts inline here. \n# You can also pass predefined and custom variables to this script using arguments", + "helpMarkDown": "Enter the script to execute.", + "visibleRule": "ScriptType = InlineScript", + "properties": { + "resizable": "true", + "rows": "10", + "maxLength": "5000" + } + }, + { + "name": "ScriptArguments", + "type": "string", + "label": "Script Arguments", + "defaultValue": "", + "visibleRule": "ScriptType = FilePath", + "required": false, + "properties": { + "editorExtension": "ms.vss-services-azure.parameters-grid" + }, + "helpMarkDown": "Additional parameters to pass to PowerShell. Can be either ordinal or named parameters." + }, + { + "name": "errorActionPreference", + "type": "pickList", + "label": "ErrorActionPreference", + "required": false, + "defaultValue": "stop", + "options": { + "stop": "Stop", + "continue": "Continue", + "silentlyContinue": "SilentlyContinue" + }, + "helpMarkDown": "Select the value of the ErrorActionPreference variable for executing the script." + }, + { + "name": "FailOnStandardError", + "type": "boolean", + "label": "Fail on Standard Error", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, this task will fail if any errors are written to the error pipeline, or if any data is written to the Standard Error stream." + }, + { + "name": "RestrictContextToCurrentTask", + "type": "boolean", + "label": "Restrict scope of context to current task", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, this task will restrict the scope of context to current task only and the context will not be available to other tasks in the pipeline when using private agent." + }, + { + "name": "TargetAzurePs", + "aliases": [ + "azurePowerShellVersion" + ], + "type": "radio", + "label": "Azure PowerShell Version", + "defaultValue": "OtherVersion", + "required": false, + "options": { + "LatestVersion": "Latest installed version", + "OtherVersion": "Specify other version" + }, + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "In case of hosted agents, the supported Azure PowerShell Version is: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0 (Hosted VS2017 Queue).\nTo pick the latest version available on the agent, select \"Latest installed version\".\n\nFor private agents you can specify preferred version of Azure PowerShell using \"Specify version\"" + }, + { + "name": "CustomTargetAzurePs", + "aliases": [ + "preferredAzurePowerShellVersion" + ], + "type": "string", + "label": "Preferred Azure PowerShell Version", + "defaultValue": "", + "required": true, + "visibleRule": "TargetAzurePs = OtherVersion", + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "Preferred Azure PowerShell Version needs to be a proper semantic version eg. 1.2.3. Regex like 2.\\*,2.3.\\* is not supported. The Hosted VS2017 Pool currently supports Az module version: 1.0.0, 1.6.0, 2.3.2, 2.6.0, 3.1.0" + }, + { + "name": "pwsh", + "type": "boolean", + "label": "Use PowerShell Core", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, then on Windows the task will use pwsh.exe from your PATH instead of powershell.exe.", + "groupName": "advanced" + }, + { + "name": "validateScriptSignature", + "type": "boolean", + "label": "Validate script signature", + "required": false, + "defaultValue": "false", + "helpMarkDown": "If this is true, then the task will first check to make sure specified script is signed and valid before executing it.", + "groupName": "advanced", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "workingDirectory", + "type": "filePath", + "label": "Working Directory", + "required": false, + "defaultValue": "", + "helpMarkDown": "Working directory where the script is run.", + "groupName": "advanced" + } + ], + "instanceNameFormat": "Azure PowerShell script: $(ScriptType)", + "execution": { + "PowerShell3": { + "target": "azurepowershell.ps1", + "platforms": [ + "windows" + ] + }, + "Node10": { + "target": "azurepowershell.js", + "argumentFormat": "" + }, + "Node16": { + "target": "azurepowershell.js", + "argumentFormat": "" + } + }, + "messages": { + "GeneratingScript": "Generating script.", + "JS_FormattedCommand": "Formatted command: %s", + "InvalidScriptArguments0": "Invalid script arguments '{0}'. Line breaks are not allowed.", + "InvalidScriptPath0": "Invalid script path '{0}'. Invalid path characters specified.", + "InvalidAzurePsVersion": "The Azure PowerShell version '{0}' specified is not in the correct format. Please check the format. An example of correct format is 1.0.1", + "JS_ExitCode": "PowerShell exited with code '%s'.", + "JS_Stderr": "PowerShell wrote one or more lines to the standard error stream.", + "ExpiredServicePrincipal": "Could not fetch access token for Azure. Verify if the Service Principal used is valid and not expired." + }, + "_buildConfigMapping": { + "Default": "4.226.1", + "Node16-225": "4.226.0" + } +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/task.loc.json b/_generated/AzurePowerShellV4_Node16/task.loc.json new file mode 100644 index 000000000000..66f7556f5e9f --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/task.loc.json @@ -0,0 +1,217 @@ +{ + "id": "72A1931B-EFFB-4D2E-8FD8-F8472A07CB62", + "name": "AzurePowerShell", + "friendlyName": "ms-resource:loc.friendlyName", + "description": "ms-resource:loc.description", + "helpMarkDown": "ms-resource:loc.helpMarkDown", + "helpUrl": "https://aka.ms/azurepowershelltroubleshooting", + "category": "Deploy", + "visibility": [ + "Build", + "Release" + ], + "runsOn": [ + "Agent", + "DeploymentGroup" + ], + "author": "Microsoft Corporation", + "version": { + "Major": 4, + "Minor": 226, + "Patch": 0 + }, + "releaseNotes": "ms-resource:loc.releaseNotes", + "groups": [ + { + "name": "AzurePowerShellVersionOptions", + "displayName": "ms-resource:loc.group.displayName.AzurePowerShellVersionOptions", + "isExpanded": true + }, + { + "name": "advanced", + "displayName": "ms-resource:loc.group.displayName.advanced", + "isExpanded": false + } + ], + "minimumAgentVersion": "2.115.0", + "inputs": [ + { + "name": "ConnectedServiceNameARM", + "aliases": [ + "azureSubscription" + ], + "type": "connectedService:AzureRM", + "label": "ms-resource:loc.input.label.ConnectedServiceNameARM", + "defaultValue": "", + "required": true, + "helpMarkDown": "ms-resource:loc.input.help.ConnectedServiceNameARM", + "properties": { + "EndpointFilterRule": "ScopeLevel != AzureMLWorkspace" + } + }, + { + "name": "ScriptType", + "type": "radio", + "label": "ms-resource:loc.input.label.ScriptType", + "required": false, + "helpMarkDown": "ms-resource:loc.input.help.ScriptType", + "defaultValue": "FilePath", + "options": { + "FilePath": "Script File Path", + "InlineScript": "Inline Script" + } + }, + { + "name": "ScriptPath", + "type": "filePath", + "label": "ms-resource:loc.input.label.ScriptPath", + "defaultValue": "", + "required": false, + "helpMarkDown": "ms-resource:loc.input.help.ScriptPath", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "Inline", + "type": "multiLine", + "label": "ms-resource:loc.input.label.Inline", + "required": false, + "defaultValue": "# You can write your azure powershell scripts inline here. \n# You can also pass predefined and custom variables to this script using arguments", + "helpMarkDown": "ms-resource:loc.input.help.Inline", + "visibleRule": "ScriptType = InlineScript", + "properties": { + "resizable": "true", + "rows": "10", + "maxLength": "5000" + } + }, + { + "name": "ScriptArguments", + "type": "string", + "label": "ms-resource:loc.input.label.ScriptArguments", + "defaultValue": "", + "visibleRule": "ScriptType = FilePath", + "required": false, + "properties": { + "editorExtension": "ms.vss-services-azure.parameters-grid" + }, + "helpMarkDown": "ms-resource:loc.input.help.ScriptArguments" + }, + { + "name": "errorActionPreference", + "type": "pickList", + "label": "ms-resource:loc.input.label.errorActionPreference", + "required": false, + "defaultValue": "stop", + "options": { + "stop": "Stop", + "continue": "Continue", + "silentlyContinue": "SilentlyContinue" + }, + "helpMarkDown": "ms-resource:loc.input.help.errorActionPreference" + }, + { + "name": "FailOnStandardError", + "type": "boolean", + "label": "ms-resource:loc.input.label.FailOnStandardError", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.FailOnStandardError" + }, + { + "name": "RestrictContextToCurrentTask", + "type": "boolean", + "label": "ms-resource:loc.input.label.RestrictContextToCurrentTask", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.RestrictContextToCurrentTask" + }, + { + "name": "TargetAzurePs", + "aliases": [ + "azurePowerShellVersion" + ], + "type": "radio", + "label": "ms-resource:loc.input.label.TargetAzurePs", + "defaultValue": "OtherVersion", + "required": false, + "options": { + "LatestVersion": "Latest installed version", + "OtherVersion": "Specify other version" + }, + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "ms-resource:loc.input.help.TargetAzurePs" + }, + { + "name": "CustomTargetAzurePs", + "aliases": [ + "preferredAzurePowerShellVersion" + ], + "type": "string", + "label": "ms-resource:loc.input.label.CustomTargetAzurePs", + "defaultValue": "", + "required": true, + "visibleRule": "TargetAzurePs = OtherVersion", + "groupName": "AzurePowerShellVersionOptions", + "helpMarkDown": "ms-resource:loc.input.help.CustomTargetAzurePs" + }, + { + "name": "pwsh", + "type": "boolean", + "label": "ms-resource:loc.input.label.pwsh", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.pwsh", + "groupName": "advanced" + }, + { + "name": "validateScriptSignature", + "type": "boolean", + "label": "ms-resource:loc.input.label.validateScriptSignature", + "required": false, + "defaultValue": "false", + "helpMarkDown": "ms-resource:loc.input.help.validateScriptSignature", + "groupName": "advanced", + "visibleRule": "ScriptType = FilePath" + }, + { + "name": "workingDirectory", + "type": "filePath", + "label": "ms-resource:loc.input.label.workingDirectory", + "required": false, + "defaultValue": "", + "helpMarkDown": "ms-resource:loc.input.help.workingDirectory", + "groupName": "advanced" + } + ], + "instanceNameFormat": "ms-resource:loc.instanceNameFormat", + "execution": { + "PowerShell3": { + "target": "azurepowershell.ps1", + "platforms": [ + "windows" + ] + }, + "Node10": { + "target": "azurepowershell.js", + "argumentFormat": "" + }, + "Node16": { + "target": "azurepowershell.js", + "argumentFormat": "" + } + }, + "messages": { + "GeneratingScript": "ms-resource:loc.messages.GeneratingScript", + "JS_FormattedCommand": "ms-resource:loc.messages.JS_FormattedCommand", + "InvalidScriptArguments0": "ms-resource:loc.messages.InvalidScriptArguments0", + "InvalidScriptPath0": "ms-resource:loc.messages.InvalidScriptPath0", + "InvalidAzurePsVersion": "ms-resource:loc.messages.InvalidAzurePsVersion", + "JS_ExitCode": "ms-resource:loc.messages.JS_ExitCode", + "JS_Stderr": "ms-resource:loc.messages.JS_Stderr", + "ExpiredServicePrincipal": "ms-resource:loc.messages.ExpiredServicePrincipal" + }, + "_buildConfigMapping": { + "Default": "4.226.1", + "Node16-225": "4.226.0" + } +} \ No newline at end of file diff --git a/_generated/AzurePowerShellV4_Node16/tsconfig.json b/_generated/AzurePowerShellV4_Node16/tsconfig.json new file mode 100644 index 000000000000..6a07b24acf54 --- /dev/null +++ b/_generated/AzurePowerShellV4_Node16/tsconfig.json @@ -0,0 +1,7 @@ +{ + "compilerOptions": { + "target": "ES6", + "module": "commonjs", + "skipLibCheck": true + } +} \ No newline at end of file diff --git a/make-options.json b/make-options.json index 5bd3a9aabec4..5f19ff94075b 100644 --- a/make-options.json +++ b/make-options.json @@ -244,6 +244,7 @@ "PublishSymbolsV2", "AzureAppServiceManageV0", "AzureKeyVaultV1", - "AzureKeyVaultV2" + "AzureKeyVaultV2", + "AzurePowerShellV4" ] } \ No newline at end of file