Skip to content

Commit

Permalink
[purview scanning] new release by new LLC version (Azure#20823)
Browse files Browse the repository at this point in the history
  • Loading branch information
msyyc authored Sep 29, 2021
1 parent ae69e4b commit b0acdfb
Show file tree
Hide file tree
Showing 58 changed files with 8,794 additions and 6,759 deletions.
12 changes: 12 additions & 0 deletions sdk/purview/azure-purview-scanning/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,17 @@
# Release History

## 1.0.0b2 (2021-09-29)

**Features**

- Add convenience operations to client

**Breaking changes**

- Remove rest layer and request builders(detailed description is in `README.md`)
- The HttpRequest parameter to send_request has changed from `http_request` to `request`
- Ordering of endpoint and credential params have changed

## 1.0.0b1 (2021-05-11)

- This is the initial release of the Azure Purview Scanning library.
17 changes: 4 additions & 13 deletions sdk/purview/azure-purview-scanning/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -73,23 +73,14 @@ The following section shows you how to initialize and authenticate your client,
```python
from azure.purview.scanning import PurviewScanningClient
from azure.identity import DefaultAzureCredential
from azure.purview.scanning.rest import data_sources
from azure.core.exceptions import HttpResponseError

credential = DefaultAzureCredential()
client = PurviewScanningClient(endpoint="https://<my-account-name>.scan.purview.azure.com", credential=credential)

request = data_sources.build_list_all_request()

response = client.send_request(request)
try:
response.raise_for_status()
json_response = response.json()

assert len(json_response['value']) == json_response['count']
for value in json_response['value']:
print(value)

response = client.data_sources.list_all()
result = [item for item in response]
print(result)
except HttpResponseError as e:
print(e)
```
Expand Down Expand Up @@ -135,7 +126,7 @@ Similarly, `logging_enable` can enable detailed logging for a single `send_reque
even when it isn't enabled for the client:

```python
result = client.send_request(request, logging_enable=True)
result = client.data_sources.list_all(logging_enable=True)
```

## Next steps
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
# --------------------------------------------------------------------------

from ._azure_purview_scanning_client import PurviewScanningClient
from ._purview_scanning_client import PurviewScanningClient
from ._version import VERSION

__version__ = VERSION
Expand Down

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -26,27 +26,27 @@ class PurviewScanningClientConfiguration(Configuration):
Note that all parameters used to create this instance are saved as instance
attributes.
:param credential: Credential needed for the client to connect to Azure.
:type credential: ~azure.core.credentials.TokenCredential
:param endpoint: The scanning endpoint of your purview account. Example: https://{accountName}.scan.purview.azure.com.
:type endpoint: str
:param credential: Credential needed for the client to connect to Azure.
:type credential: ~azure.core.credentials.TokenCredential
"""

def __init__(
self,
credential, # type: "TokenCredential"
endpoint, # type: str
credential, # type: "TokenCredential"
**kwargs # type: Any
):
# type: (...) -> None
if credential is None:
raise ValueError("Parameter 'credential' must not be None.")
if endpoint is None:
raise ValueError("Parameter 'endpoint' must not be None.")
if credential is None:
raise ValueError("Parameter 'credential' must not be None.")
super(PurviewScanningClientConfiguration, self).__init__(**kwargs)

self.credential = credential
self.endpoint = endpoint
self.credential = credential
self.api_version = "2018-12-01-preview"
self.credential_scopes = kwargs.pop('credential_scopes', ['https://purview.azure.net/.default'])
kwargs.setdefault('sdk_moniker', 'purview-scanning/{}'.format(VERSION))
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
# coding=utf-8
# --------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See License.txt in the project root for license information.
# Code generated by Microsoft (R) AutoRest Code Generator.
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
# --------------------------------------------------------------------------

from copy import deepcopy
from typing import TYPE_CHECKING

from azure.core import PipelineClient
from msrest import Deserializer, Serializer

from ._configuration import PurviewScanningClientConfiguration
from .operations import ClassificationRulesOperations, DataSourcesOperations, FiltersOperations, KeyVaultConnectionsOperations, ScanResultOperations, ScanRulesetsOperations, ScansOperations, SystemScanRulesetsOperations, TriggersOperations

if TYPE_CHECKING:
# pylint: disable=unused-import,ungrouped-imports
from typing import Any, Dict, Optional

from azure.core.credentials import TokenCredential
from azure.core.rest import HttpRequest, HttpResponse

class PurviewScanningClient(object):
"""Creates a Microsoft.Scanning management client.
:ivar key_vault_connections: KeyVaultConnectionsOperations operations
:vartype key_vault_connections: azure.purview.scanning.operations.KeyVaultConnectionsOperations
:ivar classification_rules: ClassificationRulesOperations operations
:vartype classification_rules: azure.purview.scanning.operations.ClassificationRulesOperations
:ivar data_sources: DataSourcesOperations operations
:vartype data_sources: azure.purview.scanning.operations.DataSourcesOperations
:ivar filters: FiltersOperations operations
:vartype filters: azure.purview.scanning.operations.FiltersOperations
:ivar scans: ScansOperations operations
:vartype scans: azure.purview.scanning.operations.ScansOperations
:ivar scan_result: ScanResultOperations operations
:vartype scan_result: azure.purview.scanning.operations.ScanResultOperations
:ivar scan_rulesets: ScanRulesetsOperations operations
:vartype scan_rulesets: azure.purview.scanning.operations.ScanRulesetsOperations
:ivar system_scan_rulesets: SystemScanRulesetsOperations operations
:vartype system_scan_rulesets: azure.purview.scanning.operations.SystemScanRulesetsOperations
:ivar triggers: TriggersOperations operations
:vartype triggers: azure.purview.scanning.operations.TriggersOperations
:param endpoint: The scanning endpoint of your purview account. Example:
https://{accountName}.scan.purview.azure.com.
:type endpoint: str
:param credential: Credential needed for the client to connect to Azure.
:type credential: ~azure.core.credentials.TokenCredential
"""

def __init__(
self,
endpoint, # type: str
credential, # type: "TokenCredential"
**kwargs # type: Any
):
# type: (...) -> None
_endpoint = '{Endpoint}'
self._config = PurviewScanningClientConfiguration(endpoint, credential, **kwargs)
self._client = PipelineClient(base_url=_endpoint, config=self._config, **kwargs)

self._serialize = Serializer()
self._deserialize = Deserializer()
self._serialize.client_side_validation = False
self.key_vault_connections = KeyVaultConnectionsOperations(self._client, self._config, self._serialize, self._deserialize)
self.classification_rules = ClassificationRulesOperations(self._client, self._config, self._serialize, self._deserialize)
self.data_sources = DataSourcesOperations(self._client, self._config, self._serialize, self._deserialize)
self.filters = FiltersOperations(self._client, self._config, self._serialize, self._deserialize)
self.scans = ScansOperations(self._client, self._config, self._serialize, self._deserialize)
self.scan_result = ScanResultOperations(self._client, self._config, self._serialize, self._deserialize)
self.scan_rulesets = ScanRulesetsOperations(self._client, self._config, self._serialize, self._deserialize)
self.system_scan_rulesets = SystemScanRulesetsOperations(self._client, self._config, self._serialize, self._deserialize)
self.triggers = TriggersOperations(self._client, self._config, self._serialize, self._deserialize)


def send_request(
self,
request, # type: HttpRequest
**kwargs # type: Any
):
# type: (...) -> HttpResponse
"""Runs the network request through the client's chained policies.
>>> from azure.core.rest import HttpRequest
>>> request = HttpRequest("GET", "https://www.example.org/")
<HttpRequest [GET], url: 'https://www.example.org/'>
>>> response = client.send_request(request)
<HttpResponse: 200 OK>
For more information on this code flow, see https://aka.ms/azsdk/python/protocol/quickstart
:param request: The network request you want to make. Required.
:type request: ~azure.core.rest.HttpRequest
:keyword bool stream: Whether the response payload will be streamed. Defaults to False.
:return: The response of your network call. Does not do error handling on your response.
:rtype: ~azure.core.rest.HttpResponse
"""

request_copy = deepcopy(request)
path_format_arguments = {
"Endpoint": self._serialize.url("self._config.endpoint", self._config.endpoint, 'str', skip_quote=True),
}

request_copy.url = self._client.format_url(request_copy.url, **path_format_arguments)
return self._client.send_request(request_copy, **kwargs)

def close(self):
# type: () -> None
self._client.close()

def __enter__(self):
# type: () -> PurviewScanningClient
self._client.__enter__()
return self

def __exit__(self, *exc_details):
# type: (Any) -> None
self._client.__exit__(*exc_details)
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# --------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See License.txt in the project root for license information.
# Code generated by Microsoft (R) AutoRest Code Generator.
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
# --------------------------------------------------------------------------

from azure.core.pipeline.transport import HttpRequest

def _convert_request(request, files=None):
data = request.content if not files else None
request = HttpRequest(method=request.method, url=request.url, headers=request.headers, data=data)
if files:
request.set_formdata_body(files)
return request

def _format_url_section(template, **kwargs):
components = template.split("/")
while components:
try:
return template.format(**kwargs)
except KeyError as key:
formatted_components = template.split("/")
components = [
c for c in formatted_components if "{}".format(key.args[0]) not in c
]
template = "/".join(components)
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,4 @@
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
# --------------------------------------------------------------------------

VERSION = "1.0.0b1"
VERSION = "1.0.0b2"
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,5 @@
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
# --------------------------------------------------------------------------

from ._azure_purview_scanning_client import PurviewScanningClient
from ._purview_scanning_client import PurviewScanningClient
__all__ = ['PurviewScanningClient']
Loading

0 comments on commit b0acdfb

Please sign in to comment.