From bb6a1d67304d6f05aacfe63897ad6170133f9d83 Mon Sep 17 00:00:00 2001 From: Max Ustinov Date: Fri, 15 Sep 2023 16:54:48 -0700 Subject: [PATCH 1/2] Update README, bumped to version 1.1.1, and bumped `keeper-secrets-manager-core` to 16.6.2 and `keeper-secrets-manager-storage` to 1.0.2 --- integration/keeper_secrets_manager_cli/README.md | 4 ++++ integration/keeper_secrets_manager_cli/requirements.txt | 4 ++-- integration/keeper_secrets_manager_cli/setup.py | 2 +- 3 files changed, 7 insertions(+), 3 deletions(-) diff --git a/integration/keeper_secrets_manager_cli/README.md b/integration/keeper_secrets_manager_cli/README.md index 4e140122..f6f5d98a 100644 --- a/integration/keeper_secrets_manager_cli/README.md +++ b/integration/keeper_secrets_manager_cli/README.md @@ -6,6 +6,10 @@ For more information see our official documentation page https://docs.keeper.io/ # Change History +## 1.1.1 + +* KSM-429 - Add `--profile-name` to `ksm profile import` command + ## 1.1.0 * KSM-395 - New feature to load configurations from AWS Secrets Manager diff --git a/integration/keeper_secrets_manager_cli/requirements.txt b/integration/keeper_secrets_manager_cli/requirements.txt index 3ce53efe..448d3553 100644 --- a/integration/keeper_secrets_manager_cli/requirements.txt +++ b/integration/keeper_secrets_manager_cli/requirements.txt @@ -1,6 +1,6 @@ -keeper-secrets-manager-core>=16.5.4 +keeper-secrets-manager-core>=16.6.2 keeper-secrets-manager-helper -keeper-secrets-manager-storage>=1.0.1 +keeper-secrets-manager-storage>=1.0.2 prompt-toolkit~=2.0 jsonpath-rw-ext colorama diff --git a/integration/keeper_secrets_manager_cli/setup.py b/integration/keeper_secrets_manager_cli/setup.py index 6e5e074e..f10c308b 100644 --- a/integration/keeper_secrets_manager_cli/setup.py +++ b/integration/keeper_secrets_manager_cli/setup.py @@ -27,7 +27,7 @@ # Version set in the keeper_secrets_manager_cli.version file. setup( name="keeper-secrets-manager-cli", - version="1.1.0", + version="1.1.1", description="Command line tool for Keeper Secrets Manager", long_description=long_description, long_description_content_type="text/markdown", From e95a1ee8c9e03e624d648e0817385a58a1985193 Mon Sep 17 00:00:00 2001 From: idimov-keeper <78815270+idimov-keeper@users.noreply.github.com> Date: Fri, 15 Sep 2023 18:55:32 -0500 Subject: [PATCH 2/2] Added --profile-name option to `ksm profile import` command (#478) --- .../keeper_secrets_manager_cli/__main__.py | 6 ++++-- .../keeper_secrets_manager_cli/profile.py | 15 ++++++++++++--- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/__main__.py b/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/__main__.py index a28c1bed..80fa6c92 100644 --- a/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/__main__.py +++ b/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/__main__.py @@ -489,14 +489,16 @@ def profile_export_command(ctx, plain, file_format, profile_name): cls=HelpColorsCommand, help_options_color='blue' ) +@click.option('--profile-name', '-p', type=str, required=False, help='Config profile to import into.') @click.option('--output-file', '-f', type=str, required=False, help='Create the config in a specific file location.') @click.argument('config-base64', type=str, required=True, nargs=1) @click.pass_context -def profile_import_command(ctx, output_file, config_base64): +def profile_import_command(ctx, profile_name, output_file, config_base64): """Import an encrypted config file""" Profile(cli=ctx.obj["cli"], config=global_config).import_config( - file=output_file, config_base64=config_base64, + file=output_file, + profile_name=profile_name, launched_from_app=global_config.launched_from_app ) diff --git a/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/profile.py b/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/profile.py index b557e269..d4d3bbf2 100644 --- a/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/profile.py +++ b/integration/keeper_secrets_manager_cli/keeper_secrets_manager_cli/profile.py @@ -372,9 +372,7 @@ def import_config(config_base64, file=None, profile_name=None, launched_from_app """ Take base64 config file and write it back to disk. - This file could be a JSON or a Keeper ini file. - """ config_data = base64.urlsafe_b64decode(config_base64.encode()) @@ -392,15 +390,26 @@ def import_config(config_base64, file=None, profile_name=None, launched_from_app # If a JSON file was import, convert the JSON to a INI. if is_json is True: + if profile_name is None: + profile_name = os.environ.get("KSM_CLI_PROFILE", Profile.default_profile) config = Config(ini_file=file) + + try: + # If the file exists attempt to load as INI to merge new config + config.load() + except: + pass # doesn't exists, inaccessible, or not INI: create new + config.set_profile_using_base64( - profile_name=Profile.default_profile, + profile_name=profile_name, base64_config=config_base64 ) config.save() # Else just save the INI. It's in the right format, just save it. No processing needed. else: + if profile_name: + print("Ignored option --profile-name as incompaible with INI file format that can handle multiple profiles.") with open(file, "w") as fh: fh.write(config_data.decode()) fh.close()