Skip to content
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

Service Directory python snippets #3456

Merged
merged 42 commits into from
Jul 24, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
1490a11
python snippets for service directory
Apr 16, 2020
390ee2d
update requirements.txt to correct version
Apr 16, 2020
29d9d19
fix location constant
Apr 21, 2020
aaa8360
limit scope of import of os, fix create namespace to not create endpo…
Apr 21, 2020
9995dc5
add request metadata for grpc routing
Apr 21, 2020
80df034
Merge pull request #1 from rebeccawshaw/sd-python-doc-samples
rebeccawshaw Apr 21, 2020
83b878d
Merge branch 'master' into master
rebeccawshaw Apr 21, 2020
506c1db
fix: use 0.3.0 and remove extra metadata
busunkim96 Jun 11, 2020
2fc3917
Merge branch 'master' into master
busunkim96 Jun 11, 2020
33440b6
chore(deps): update dependency google-auth-oauthlib to v0.4.1 (#2797)
renovate-bot Apr 18, 2020
a954aa7
undo accidental changes to translate dir
busunkim96 Jun 11, 2020
a429af0
chore: remove extra files
busunkim96 Jun 11, 2020
300370a
remove extra files
busunkim96 Jun 11, 2020
420e8ec
take 2
busunkim96 Jun 11, 2020
89a40fb
remove accidentally committed translate test
busunkim96 Jun 11, 2020
657b38d
fix: use GOOGLE_CLOUD_PROJECT
busunkim96 Jun 11, 2020
cd5febe
Merge branch 'master' of https://github.com/rebeccawshaw/python-docs-…
Jun 16, 2020
322e70b
add quickstart files,generate README.rst, remove metadata from snippe…
Jun 17, 2020
fb971a6
remove README.rst file
Jun 17, 2020
6dedabb
Merge branch 'master' into master
rebeccawshaw Jun 17, 2020
ad957b8
use api for creating resource paths instead of string format
Jun 17, 2020
b3a9282
Merge branch 'master' of https://github.com/rebeccawshaw/python-docs-…
Jun 17, 2020
c3a32fe
change the region tags to be set to 'us-east1', change the namespace …
Jun 24, 2020
36b2da6
change test to fixture
Jun 24, 2020
1210541
Merge branch 'master' into master
busunkim96 Jul 6, 2020
8a991f5
change strings to f-strings, make namespace, service, and endpoint id…
Jul 16, 2020
cd2ef68
Merge branch 'master' of https://github.com/rebeccawshaw/python-docs-…
Jul 16, 2020
a64af6d
missed an f-string, added it to delete namespace
Jul 16, 2020
63e36f3
move list_namespace fixture into namespace fixture, remove unnecessar…
Jul 17, 2020
29d6707
Merge branch 'master' into master
rebeccawshaw Jul 20, 2020
f37d48d
Merge branch 'master' of https://github.com/GoogleCloudPlatform/pytho…
Jul 22, 2020
542910a
add generated README.rst file
Jul 22, 2020
e393114
add requirements to readme and regenerate the file
Jul 23, 2020
ca3d5b3
Merge branch 'master' into master
rebeccawshaw Jul 23, 2020
40334b2
Merge branch 'master' into master
leahecole Jul 23, 2020
c9d52f5
fix linter errors
Jul 24, 2020
4b54713
Merge branch 'master' of https://github.com/rebeccawshaw/python-docs-…
Jul 24, 2020
807730c
Merge branch 'master' into master
rebeccawshaw Jul 24, 2020
3f42d08
Merge branch 'master' into master
rebeccawshaw Jul 24, 2020
6680dc8
only delete the namespace created upon teardown
Jul 24, 2020
083801a
Merge branch 'master' of https://github.com/rebeccawshaw/python-docs-…
Jul 24, 2020
7f0f27b
Merge branch 'master' into master
rebeccawshaw Jul 24, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
89 changes: 89 additions & 0 deletions servicedirectory/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
.. This file is automatically generated. Do not edit this file directly.

Google Cloud Service Directory Python Samples
===============================================================================

.. image:: https://gstatic.com/cloudssh/images/open-btn.png
:target: https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/GoogleCloudPlatform/python-docs-samples&page=editor&open_in_editor=servicedirectory/README.rst


This directory contains samples for Google Cloud Service Directory. `Google Cloud Service Directory`_ is a platform for discovering, publishing, and connecting services. It offers customers a single place to register and discover their services in a consistent and reliable way, regardless of their environment. These sample Java applications demonstrate how to access the Service Directory API using the Google Java API Client Libraries.




.. _Google Cloud Service Directory: https://cloud.google.com/service-directory/docs/

To run the sample, you need to enable the API at: https://console.developers.google.com/apis/api/servicedirectory.googleapis.com/overview

To run the sample, you need to have `Service Directory Admin` role.




Setup
-------------------------------------------------------------------------------


Authentication
++++++++++++++

This sample requires you to have authentication setup. Refer to the
`Authentication Getting Started Guide`_ for instructions on setting up
credentials for applications.

.. _Authentication Getting Started Guide:
https://cloud.google.com/docs/authentication/getting-started

Install Dependencies
++++++++++++++++++++

#. Clone python-docs-samples and change directory to the sample directory you want to use.

.. code-block:: bash

$ git clone https://github.com/GoogleCloudPlatform/python-docs-samples.git

#. Install `pip`_ and `virtualenv`_ if you do not already have them. You may want to refer to the `Python Development Environment Setup Guide`_ for Google Cloud Platform for instructions.

.. _Python Development Environment Setup Guide:
https://cloud.google.com/python/setup

#. Create a virtualenv. Samples are compatible with Python 2.7 and 3.4+.

.. code-block:: bash

$ virtualenv env
$ source env/bin/activate

#. Install the dependencies needed to run the samples.

.. code-block:: bash

$ pip install -r requirements.txt

.. _pip: https://pip.pypa.io/
.. _virtualenv: https://virtualenv.pypa.io/

Samples
-------------------------------------------------------------------------------

Snippets
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

.. image:: https://gstatic.com/cloudssh/images/open-btn.png
:target: https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/GoogleCloudPlatform/python-docs-samples&page=editor&open_in_editor=servicedirectory/snippets.py,servicedirectory/README.rst




To run this sample:

.. code-block:: bash

$ python snippets.py




.. _Google Cloud SDK: https://cloud.google.com/sdk/
28 changes: 28 additions & 0 deletions servicedirectory/README.rst.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# This file is used to generate README.rst

product:
name: Google Cloud Service Directory
short_name: Service Directory
url: https://cloud.google.com/service-directory/docs/
description: >
`Google Cloud Service Directory`_ is a platform
for discovering, publishing, and connecting services. It offers customers a
single place to register and discover their services in a consistent and
reliable way, regardless of their environment. These sample Java applications
demonstrate how to access the Service Directory API using the Google Java API
Client Libraries.


rebeccawshaw marked this conversation as resolved.
Show resolved Hide resolved
required_api_url: https://console.developers.google.com/apis/api/servicedirectory.googleapis.com/overview
required_role: Service Directory Admin

setup:
- auth
- install_deps

samples:
- name: Snippets
file: snippets.py


folder: servicedirectory
32 changes: 32 additions & 0 deletions servicedirectory/quickstart.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
#!/usr/bin/env python

# Copyright 2020 Google Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from google.cloud import servicedirectory_v1beta1


def list_namespaces(project_id, location_id):
"""Lists all namespaces in the given location."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

response = client.list_namespaces(
parent=f'projects/{project_id}/locations/{location_id}')

print(f'Listed namespaces in {location_id}.')
for namespace in response:
print(f'Namespace: {namespace.name}')

return response
54 changes: 54 additions & 0 deletions servicedirectory/quickstart_test.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
#!/usr/bin/env python

# Copyright 2020 Google Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from os import environ
import uuid

from google.cloud import servicedirectory_v1beta1

import pytest

import quickstart

PROJECT_ID = environ['GOOGLE_CLOUD_PROJECT']
LOCATION_ID = 'us-east1'
NAMESPACE_ID = f'test-namespace-{uuid.uuid4().hex}'


@pytest.fixture(scope='module')
def client():
return servicedirectory_v1beta1.RegistrationServiceClient()


@pytest.fixture(scope='module')
def namespace(client):
namespace = servicedirectory_v1beta1.Namespace(
name=client.namespace_path(PROJECT_ID, LOCATION_ID, NAMESPACE_ID))

client.create_namespace(
parent=f'projects/{PROJECT_ID}/locations/{LOCATION_ID}',
namespace=namespace,
namespace_id=NAMESPACE_ID,
)

yield namespace

client.delete_namespace(name=namespace.name)
rebeccawshaw marked this conversation as resolved.
Show resolved Hide resolved


def test_list_namespace(namespace):
assert namespace in quickstart.list_namespaces(PROJECT_ID,
LOCATION_ID).namespaces
1 change: 1 addition & 0 deletions servicedirectory/requirements-test.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
pytest==5.4.3
1 change: 1 addition & 0 deletions servicedirectory/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
google-cloud-service-directory==0.3.0
137 changes: 137 additions & 0 deletions servicedirectory/snippets.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
#!/usr/bin/env python

# Copyright 2020 Google Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from google.cloud import servicedirectory_v1beta1


def create_namespace(project_id, location_id, namespace_id):
"""Creates a namespace in the given location."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

namespace = servicedirectory_v1beta1.Namespace(
name=client.namespace_path(project_id, location_id, namespace_id))

response = client.create_namespace(
parent=f'projects/{project_id}/locations/{location_id}',
namespace=namespace,
namespace_id=namespace_id,
)

print(f'Created namespace {response.name}.')

return response


def delete_namespace(project_id, location_id, namespace_id):
"""Deletes a namespace in the given location."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

namespace_name = client.namespace_path(project_id, location_id, namespace_id)

client.delete_namespace(name=namespace_name)

print(f'Deleted namespace {namespace_name}.')


def create_service(project_id, location_id, namespace_id, service_id):
"""Creates a service in the given namespace."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

service = servicedirectory_v1beta1.Service(
name=client.service_path(project_id, location_id, namespace_id,
service_id))

response = client.create_service(
parent=client.namespace_path(project_id, location_id, namespace_id),
service=service,
service_id=service_id,
)

print(f'Created service {response.name}.')

return response


def delete_service(project_id, location_id, namespace_id, service_id):
"""Deletes a service in the given namespace."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

service_name = client.service_path(project_id, location_id, namespace_id,
service_id)

client.delete_service(name=service_name)

print(f'Deleted service {service_name}.')


def resolve_service(project_id, location_id, namespace_id, service_id):
"""Resolves a service in the given namespace."""

client = servicedirectory_v1beta1.LookupServiceClient()

request = servicedirectory_v1beta1.ResolveServiceRequest(
name=servicedirectory_v1beta1.RegistrationServiceClient().service_path(
project_id, location_id, namespace_id, service_id))

response = client.resolve_service(request=request)

print('Endpoints found:')
for endpoint in response.service.endpoints:
print(f'{endpoint.name} -- {endpoint.address}:{endpoint.port}')

return response


def create_endpoint(project_id, location_id, namespace_id, service_id,
endpoint_id, address, port):
"""Creates a endpoint in the given service."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

endpoint = servicedirectory_v1beta1.Endpoint(
name=client.endpoint_path(project_id, location_id, namespace_id,
service_id, endpoint_id),
address=address,
port=port)

response = client.create_endpoint(
parent=client.service_path(project_id, location_id, namespace_id,
service_id),
endpoint=endpoint,
endpoint_id=endpoint_id,
)

print(f'Created endpoint {response.name}.')

return response


def delete_endpoint(project_id, location_id, namespace_id, service_id,
endpoint_id):
"""Deletes a endpoin in the given service."""

client = servicedirectory_v1beta1.RegistrationServiceClient()

endpoint_name = client.endpoint_path(project_id, location_id, namespace_id,
service_id, endpoint_id)

client.delete_endpoint(name=endpoint_name)

print(f'Deleted endpoint {endpoint_name}.')
Loading