-
Notifications
You must be signed in to change notification settings - Fork 2.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[purview scanning] new release by new LLC version (#20823)
- Loading branch information
Showing
58 changed files
with
8,794 additions
and
6,759 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
104 changes: 0 additions & 104 deletions
104
sdk/purview/azure-purview-scanning/azure/purview/scanning/_azure_purview_scanning_client.py
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
120 changes: 120 additions & 0 deletions
120
sdk/purview/azure-purview-scanning/azure/purview/scanning/_purview_scanning_client.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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) |
27 changes: 27 additions & 0 deletions
27
sdk/purview/azure-purview-scanning/azure/purview/scanning/_vendor.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.