From 73885e4b2a4ed35cde7dc6b971a72efa577917ba Mon Sep 17 00:00:00 2001 From: Yoshi Automation Bot Date: Wed, 23 Dec 2020 08:10:05 -0800 Subject: [PATCH] feat: add `from_service_account_info` (#31) --- .../services/os_config_service/async_client.py | 1 + .../services/os_config_service/client.py | 16 ++++++++++++++++ packages/google-cloud-os-config/synth.metadata | 2 +- .../gapic/osconfig_v1/test_os_config_service.py | 13 +++++++++++++ 4 files changed, 31 insertions(+), 1 deletion(-) diff --git a/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/async_client.py b/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/async_client.py index 0c4c1e65082e..0042cef6656a 100644 --- a/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/async_client.py +++ b/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/async_client.py @@ -89,6 +89,7 @@ class OsConfigServiceAsyncClient: OsConfigServiceClient.parse_common_location_path ) + from_service_account_info = OsConfigServiceClient.from_service_account_info from_service_account_file = OsConfigServiceClient.from_service_account_file from_service_account_json = from_service_account_file diff --git a/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/client.py b/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/client.py index d74daa20f189..f1101be73098 100644 --- a/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/client.py +++ b/packages/google-cloud-os-config/google/cloud/osconfig_v1/services/os_config_service/client.py @@ -117,6 +117,22 @@ def _get_default_mtls_endpoint(api_endpoint): DEFAULT_ENDPOINT ) + @classmethod + def from_service_account_info(cls, info: dict, *args, **kwargs): + """Creates an instance of this client using the provided credentials info. + + Args: + info (dict): The service account private key info. + args: Additional arguments to pass to the constructor. + kwargs: Additional arguments to pass to the constructor. + + Returns: + {@api.name}: The constructed client. + """ + credentials = service_account.Credentials.from_service_account_info(info) + kwargs["credentials"] = credentials + return cls(*args, **kwargs) + @classmethod def from_service_account_file(cls, filename: str, *args, **kwargs): """Creates an instance of this client using the provided credentials diff --git a/packages/google-cloud-os-config/synth.metadata b/packages/google-cloud-os-config/synth.metadata index 89d139406ba7..787bb07f2f2d 100644 --- a/packages/google-cloud-os-config/synth.metadata +++ b/packages/google-cloud-os-config/synth.metadata @@ -4,7 +4,7 @@ "git": { "name": ".", "remote": "https://github.com/googleapis/python-os-config.git", - "sha": "b84dce022c84d79e8193c6881338fb3f79345740" + "sha": "628ada4004b1add04f5c2d95b9b1cad48616cf2c" } }, { diff --git a/packages/google-cloud-os-config/tests/unit/gapic/osconfig_v1/test_os_config_service.py b/packages/google-cloud-os-config/tests/unit/gapic/osconfig_v1/test_os_config_service.py index 188b5d341ece..2affe127f6cd 100644 --- a/packages/google-cloud-os-config/tests/unit/gapic/osconfig_v1/test_os_config_service.py +++ b/packages/google-cloud-os-config/tests/unit/gapic/osconfig_v1/test_os_config_service.py @@ -93,6 +93,19 @@ def test__get_default_mtls_endpoint(): ) +def test_os_config_service_client_from_service_account_info(): + creds = credentials.AnonymousCredentials() + with mock.patch.object( + service_account.Credentials, "from_service_account_info" + ) as factory: + factory.return_value = creds + info = {"valid": True} + client = OsConfigServiceClient.from_service_account_info(info) + assert client.transport._credentials == creds + + assert client.transport._host == "osconfig.googleapis.com:443" + + @pytest.mark.parametrize( "client_class", [OsConfigServiceClient, OsConfigServiceAsyncClient] )