Skip to content

Commit

Permalink
[SchemaRegistry] renaming from archboard feedback (#20766)
Browse files Browse the repository at this point in the history
addressing part of #20703
  • Loading branch information
swathipil authored and iscai-msft committed Sep 29, 2021
1 parent 0a8aabf commit 128227a
Show file tree
Hide file tree
Showing 20 changed files with 195 additions and 214 deletions.
5 changes: 3 additions & 2 deletions sdk/schemaregistry/azure-schemaregistry/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,9 @@
- `register_schema` and `get_schema_properties` methods on sync and async `SchemaRegistryClient` now take in the following parameters in the given order:
- `group_name`, which has been renamed from `schema_group`
- `name`, which has been renamed from `schema_name`
- `content`, which has been renamed from `schema_content`
- `serialization_type`
- `schema_definition`, which has been renamed from `schema_content`
- `format`, which has been renamed from `serialization_type`
- `endpoint` parameter in `SchemaRegistryClient` constructor has been renamed `fully_qualified_namespace`

### Bugs Fixed

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,12 @@
__version__ = VERSION

from ._schema_registry_client import SchemaRegistryClient
from ._common._constants import SerializationType
from ._common._constants import SchemaFormat
from ._common._schema import Schema, SchemaProperties

__all__ = [
"SchemaRegistryClient",
"SerializationType",
"SchemaFormat",
"Schema",
"SchemaProperties"
]
Original file line number Diff line number Diff line change
Expand Up @@ -26,5 +26,5 @@
from enum import Enum


class SerializationType(str, Enum):
class SchemaFormat(str, Enum):
AVRO = "avro"
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,8 @@

def _parse_schema_properties_dict(response):
return {
'location': response.headers.get('location'),
'id': response.headers.get('schema-id'),
'serialization_type': response.headers.get('serialization-type'),
'format': response.headers.get('serialization-type'),
'version': int(response.headers.get('schema-version'))
}

Expand All @@ -45,6 +44,6 @@ def _parse_response_schema_properties(response):

def _parse_response_schema(response):
return Schema(
content=response.text(),
schema_definition=response.text(),
properties=SchemaProperties(**_parse_schema_properties_dict(response))
)
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,8 @@ class SchemaProperties(object):
:ivar id: References specific schema in registry namespace.
:type id: str
:ivar location: URL location of schema, identified by schema group, schema name, and version.
:type location: str
:ivar serialization_type: Serialization type for the schema being stored.
:type serialization_type: str
:ivar format: Format for the schema being stored.
:type format: str
:ivar version: Version of the returned schema.
:type version: int
Expand All @@ -57,17 +55,16 @@ def __init__(
):
# type: (Optional[str], Any) -> None
self.id = id
self.location = kwargs.get('location')
self.serialization_type = kwargs.get('serialization_type')
self.format = kwargs.get('format')
self.version = kwargs.get('version')


class Schema(object):
"""
The schema content of a schema, along with id and meta properties.
:ivar content: The content of the schema.
:type content: str
:ivar schema_definition: The content of the schema.
:type schema_definition: str
:ivar properties: The properties of the schema.
:type properties: SchemaProperties
Expand All @@ -84,9 +81,9 @@ class Schema(object):

def __init__(
self,
content,
schema_definition,
properties,
):
# type: (str, SchemaProperties) -> None
self.content = content
self.schema_definition = schema_definition
self.properties = properties
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
# --------------------------------------------------------------------------
from typing import Any, TYPE_CHECKING, Union

from ._common._constants import SerializationType
from ._common._constants import SchemaFormat
from ._common._schema import Schema, SchemaProperties
from ._common._response_handlers import (
_parse_response_schema,
Expand All @@ -44,7 +44,8 @@ class SchemaRegistryClient(object):
SchemaRegistryClient is as a central schema repository for enterprise-level data infrastructure,
complete with support for versioning and management.
:param str endpoint: The Schema Registry service endpoint, for example my-namespace.servicebus.windows.net.
:param str fully_qualified_namespace: The Schema Registry service fully qualified host name,
for example my-namespace.servicebus.windows.net.
:param credential: To authenticate to manage the entities of the SchemaRegistry namespace.
:type credential: TokenCredential
Expand All @@ -59,10 +60,10 @@ class SchemaRegistryClient(object):
"""

def __init__(self, endpoint, credential, **kwargs):
def __init__(self, fully_qualified_namespace, credential, **kwargs):
# type: (str, TokenCredential, Any) -> None
self._generated_client = AzureSchemaRegistry(
credential=credential, endpoint=endpoint, **kwargs
credential=credential, endpoint=fully_qualified_namespace, **kwargs
)

def __enter__(self):
Expand All @@ -82,22 +83,20 @@ def close(self):
self._generated_client.close()

def register_schema(
self, group_name, name, content, serialization_type, **kwargs
self, group_name, name, schema_definition, format, **kwargs # pylint:disable=redefined-builtin
):
# type: (str, str, str, Union[str, SerializationType], Any) -> SchemaProperties
# type: (str, str, str, Union[str, SchemaFormat], Any) -> SchemaProperties
"""
Register new schema. If schema of specified name does not exist in specified group,
schema is created at version 1. If schema of specified name exists already in specified group,
schema is created at latest version + 1.
:param str group_name: Schema group under which schema should be registered.
:param str name: Name of schema being registered.
:param str content: String representation of the schema being registered.
:param serialization_type: Serialization type for the schema being registered.
For now Avro is the only supported serialization type by the service.
:type serialization_type: Union[str, SerializationType]
:keyword content_type: The content type of the request. Default value is 'application/json'.
:paramtype content_type: str
:param str schema_definition: String representation of the schema being registered.
:param format: Format for the schema being registered.
For now Avro is the only supported schema format by the service.
:type format: Union[str, SchemaFormat]
:rtype: SchemaProperties
.. admonition:: Example:
Expand All @@ -111,15 +110,15 @@ def register_schema(
"""
try:
serialization_type = serialization_type.value
format = format.value
except AttributeError:
pass

request = schema_rest.build_register_request(
group_name=group_name,
schema_name=name,
content=content,
serialization_type=serialization_type,
content=schema_definition,
serialization_type=format,
content_type=kwargs.pop("content_type", "application/json"),
**kwargs
)
Expand Down Expand Up @@ -153,20 +152,18 @@ def get_schema(self, id, **kwargs): # pylint:disable=redefined-builtin
return _parse_response_schema(response)

def get_schema_properties(
self, group_name, name, content, serialization_type, **kwargs
self, group_name, name, schema_definition, format, **kwargs # pylint:disable=redefined-builtin
):
# type: (str, str, str, Union[str, SerializationType], Any) -> SchemaProperties
# type: (str, str, str, Union[str, SchemaFormat], Any) -> SchemaProperties
"""
Gets the ID referencing an existing schema within the specified schema group,
as matched by schema content comparison.
as matched by schema definition comparison.
:param str group_name: Schema group under which schema should be registered.
:param str name: Name of schema being registered.
:param str content: String representation of the schema being registered.
:param serialization_type: Serialization type for the schema being registered.
:type serialization_type: Union[str, SerializationType]
:keyword content_type: The content type of the request. Default value is 'application/json'.
:paramtype content_type: str
:param str schema_definition: String representation of the schema being registered.
:param format: Format for the schema being registered.
:type format: Union[str, SchemaFormat]
:rtype: SchemaProperties
.. admonition:: Example:
Expand All @@ -180,15 +177,15 @@ def get_schema_properties(
"""
try:
serialization_type = serialization_type.value
format = format.value
except AttributeError:
pass

request = schema_rest.build_query_id_by_content_request(
group_name=group_name,
schema_name=name,
content=content,
serialization_type=serialization_type,
content=schema_definition,
serialization_type=format,
content_type=kwargs.pop("content_type", "application/json"),
**kwargs
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
# --------------------------------------------------------------------------
from typing import Any, TYPE_CHECKING, Union

from .._common._constants import SerializationType
from .._common._constants import SchemaFormat
from .._common._schema import Schema, SchemaProperties
from .._common._response_handlers import (
_parse_response_schema,
Expand All @@ -44,7 +44,8 @@ class SchemaRegistryClient(object):
SchemaRegistryClient is as a central schema repository for enterprise-level data infrastructure,
complete with support for versioning and management.
:param str endpoint: The Schema Registry service endpoint, for example my-namespace.servicebus.windows.net.
:param str fully_qualified_namespace: The Schema Registry service fully qualified host name,
for example my-namespace.servicebus.windows.net.
:param credential: To authenticate to manage the entities of the SchemaRegistry namespace.
:type credential: AsyncTokenCredential
Expand All @@ -60,11 +61,11 @@ class SchemaRegistryClient(object):
"""
def __init__(
self,
endpoint: str,
fully_qualified_namespace: str,
credential: "AsyncTokenCredential",
**kwargs: Any
) -> None:
self._generated_client = AzureSchemaRegistry(credential, endpoint, **kwargs)
self._generated_client = AzureSchemaRegistry(credential, fully_qualified_namespace, **kwargs)

async def __aenter__(self):
await self._generated_client.__aenter__()
Expand All @@ -83,8 +84,8 @@ async def register_schema(
self,
group_name: str,
name: str,
content: str,
serialization_type: Union[str, SerializationType],
schema_definition: str,
format: Union[str, SchemaFormat], # pylint:disable=redefined-builtin
**kwargs: Any
) -> SchemaProperties:
"""
Expand All @@ -94,10 +95,10 @@ async def register_schema(
:param str group_name: Schema group under which schema should be registered.
:param str name: Name of schema being registered.
:param str content: String representation of the schema being registered.
:param serialization_type: Serialization type for the schema being registered.
For now Avro is the only supported serialization type by the service.
:type serialization_type: Union[str, SerializationType]
:param str schema_definition: String representation of the schema being registered.
:param format: Format for the schema being registered.
For now Avro is the only supported schema format by the service.
:type format: Union[str, SchemaFormat]
:rtype: SchemaProperties
.. admonition:: Example:
Expand All @@ -111,15 +112,15 @@ async def register_schema(
"""
try:
serialization_type = serialization_type.value
format = format.value
except AttributeError:
pass

request = schema_rest.build_register_request(
group_name=group_name,
schema_name=name,
content=content,
serialization_type=serialization_type,
content=schema_definition,
serialization_type=format,
content_type=kwargs.pop("content_type", "application/json"),
**kwargs
)
Expand Down Expand Up @@ -159,19 +160,19 @@ async def get_schema_properties(
self,
group_name: str,
name: str,
content: str,
serialization_type: Union[str, SerializationType],
schema_definition: str,
format: Union[str, SchemaFormat], # pylint:disable=redefined-builtin
**kwargs: Any
) -> SchemaProperties:
"""
Gets the ID referencing an existing schema within the specified schema group,
as matched by schema content comparison.
as matched by schema defintion comparison.
:param str group_name: Schema group under which schema should be registered.
:param str name: Name of schema being registered.
:param str content: String representation of the schema being registered.
:param serialization_type: Serialization type for the schema being registered.
:type serialization_type: Union[str, SerializationType]
:param str schema_definition: String representation of the schema being registered.
:param format: Format for the schema being registered.
:type format: Union[str, SchemaFormat]
:rtype: SchemaProperties
.. admonition:: Example:
Expand All @@ -185,15 +186,15 @@ async def get_schema_properties(
"""
try:
serialization_type = serialization_type.value
format = format.value
except AttributeError:
pass

request = schema_rest.build_query_id_by_content_request(
group_name=group_name,
schema_name=name,
content=content,
serialization_type=serialization_type,
content=schema_definition,
serialization_type=format,
content_type=kwargs.pop("content_type", "application/json"),
**kwargs
)
Expand Down
Loading

0 comments on commit 128227a

Please sign in to comment.