-
Notifications
You must be signed in to change notification settings - Fork 3.3k
[vm] Enable password and ssh key authentication during linux VM creation #7863
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
src/command_modules/azure-cli-vm/azure/cli/command_modules/vm/_template_builder.py
Show resolved
Hide resolved
Fix conflict by checking out ephemeral os disk recording from dev branch.
9b6a18e to
0f3e2cf
Compare
|
@yugangw-msft, please let me know if this looks good to you. |
yugangw-msft
left a comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, please clean up a few minor things and merge.
|
|
||
| if not namespace.admin_password: | ||
| _prompt_for_password(namespace) | ||
| _validate_admin_password(namespace.admin_password, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NIT: make 2 parameters in the same line
|
|
||
| validate_ssh_key(namespace) | ||
| if not namespace.ssh_dest_key_path: | ||
| namespace.ssh_dest_key_path = \ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unless it is 120 characters plus, make it same line.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree. I copied and pasted code from the other blocks without updating. Will make the changes.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the catch, @yugangw-msft
| self.assertEqual(ns.authentication_type, 'all') | ||
| self.assertEqual(ns.ssh_dest_key_path, '/home/{}/.ssh/authorized_keys'.format(ns.admin_username)) | ||
|
|
||
| def test_linux_with_password_and_ssh_explicit(self): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is a dupe test :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hello Yugang, I will rename the test. The only difference is that the second test sets authentication_type to none
…ion (Azure#7863) * authentication-type can be set to all to permit both ssh key and password authentication * Added tests and updated authentication type validation error. * Added history entry, bumped version. Checked out file recording from dev branch. * Addressed PEP8 issues. * Updated test_vm_defaults auth tests. * Updated other profile's unittests. * Now infers authentication_type, other updates. Do not need to explicitly pass all. * Updated help text. Fix conflict by checking out ephemeral os disk recording from dev branch. * Style changes.
* fix live tests for sas token urls to use datetime (#7866) * Convert test back to scenario test. (#7862) * Remove unused scripts. (#7860) * fix get curren user id azure-graphrbac Breaking change fixes #7839 (#7864) * Use knack 0.5.1. (#7780) * test: make webjob tests record only as create command is unavailable (#7870) * Deprecate expand param. (#7868) * Updated help.py - generate-sas example (#7873) Added MacOS example for generating SAS token with expiration time. The call to the date function `date -d` works on Linux, but not on MacOS. I provided MacOS sample. * Low priority vmss test and help update. (#7882) Updated help text and test location for low priority vmss * Added --force to az vm restart. Added simple test. (#7885) * Fix requests version > 2.20 (#7858) * Bump CLI versions * [vm] Enable password and ssh key authentication during linux VM creation (#7863) * authentication-type can be set to all to permit both ssh key and password authentication * Added tests and updated authentication type validation error. * Added history entry, bumped version. Checked out file recording from dev branch. * Addressed PEP8 issues. * Updated test_vm_defaults auth tests. * Updated other profile's unittests. * Now infers authentication_type, other updates. Do not need to explicitly pass all. * Updated help text. Fix conflict by checking out ephemeral os disk recording from dev branch. * Style changes. * Properly handle parsing of ids from -o tsv on windows. (#7898) * Properly handle parsing of ids from -o tsv on windows. * Removed unused import. * [Storage] bump mgmt sdk version to 3.1.0 and set new api-version to use. (#7869) * changed api-version in recordings and set to new ver of sdk * version bump and history * fix immutability test * re-record all * fixed recordings fix recording * bumped version after release * test: live test fixes in appservice, vm, resource (#7899) * ci: fix build break (#7900) * Updated adls version (#7859) * core: support cross tenant resource provisioning for multi-tenant service principal (#7916) * core: fix the error on matching SP creds (#7923) * resource: fix live test failure of policyset (#7922) * [CI] reenable extension checking in CI (#7933) * reenable extension checking in CI minor edit to get travis to run edit * minor edit * BotService: Bugfixing, code refactoring, reorganization and UX revamping (#7924) * Close #7528. (#7920) * Minor updates to core/generate_ssh_keys and batchai/_generate_ssh_keys (#7895) * [image] create. Add --os-disk-caching parameter. (#7919) * graph: support custom key identifier (#7913) * support key-id description * linter error fixes * consolidate * use official sdk * update history * BotService: fix tests, improve test robustness and update recordings (#7941) * BotService: fix tests, mprove test robustness and update recordings * BotService; fixing tests * BotService: Update recordings * webapp: Adding support for az webapp up (#7930) * core: fix a breaking in kv when run under service principal (#7946) * Disable version check from CI. (#7958) * test: add test coverage for regression from auth (#7949) * core: fix a breaking in kv when run under service principal * test: add test coverage for regression from auth * [AKS] Remove "(PREVIEW)" from AAD arguments (#7960) * [AKS] Remove "(PREVIEW)" from AAD arguments * Bump module version and update HISTORY.rst * Bug fixes for azure-cli-botservice (#7956) * Az bot: fix bug when publishing Node.js bots, fix minor bugs * Az bot: rerecord BotTests * Az bot: fix static check error * [core] Updated location help text (#7951) * Updated location help text. * Update parameters.py * EventHubs help fixes (#7961) * EventHubs help fixes #Fixes 7937. Fixes #7938. * Update _help.py * Fixes for VPN Client Generate (#7962) * Remove mock dependency. * Fix linter issues. * Condense the table format for task list and change all column headers to NAME
Fixes #6230
--authentication-typenow accepts all, which enables both password and ssh key authentication for linux vm's. Providing both password and ssh key value enables both forms of authentication without explicitly setting--authentication-type.This checklist is used to make sure that common guidelines for a pull request are followed.
The PR has modified HISTORY.rst describing any customer-facing, functional changes. Note that this does not include changes only to help content. (see Modifying change log).
I adhere to the Command Guidelines.