@azure-tools/typespec-python 0.32.1 → 0.34.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (150) hide show
  1. package/dist/scripts/copy-scripts.d.ts +2 -0
  2. package/dist/scripts/copy-scripts.d.ts.map +1 -0
  3. package/dist/scripts/copy-scripts.js +24 -0
  4. package/dist/scripts/copy-scripts.js.map +1 -0
  5. package/dist/scripts/eng/lint.js +1 -1
  6. package/dist/scripts/eng/lint.js.map +1 -1
  7. package/dist/src/emitter.d.ts +0 -2
  8. package/dist/src/emitter.d.ts.map +1 -1
  9. package/dist/src/emitter.js +2 -102
  10. package/dist/src/emitter.js.map +1 -1
  11. package/dist/src/index.d.ts +1 -1
  12. package/dist/src/index.d.ts.map +1 -1
  13. package/dist/src/index.js +1 -1
  14. package/dist/src/index.js.map +1 -1
  15. package/package.json +22 -19
  16. package/scripts/__pycache__/venvtools.cpython-310.pyc +0 -0
  17. package/scripts/copy-scripts.ts +26 -0
  18. package/scripts/eng/lint.ts +1 -1
  19. package/scripts/eng/pylintrc +2 -1
  20. package/dist/src/code-model.d.ts +0 -4
  21. package/dist/src/code-model.d.ts.map +0 -1
  22. package/dist/src/code-model.js +0 -190
  23. package/dist/src/code-model.js.map +0 -1
  24. package/dist/src/external-process.d.ts +0 -20
  25. package/dist/src/external-process.d.ts.map +0 -1
  26. package/dist/src/external-process.js +0 -44
  27. package/dist/src/external-process.js.map +0 -1
  28. package/dist/src/http.d.ts +0 -7
  29. package/dist/src/http.d.ts.map +0 -1
  30. package/dist/src/http.js +0 -266
  31. package/dist/src/http.js.map +0 -1
  32. package/dist/src/types.d.ts +0 -36
  33. package/dist/src/types.d.ts.map +0 -1
  34. package/dist/src/types.js +0 -488
  35. package/dist/src/types.js.map +0 -1
  36. package/dist/src/utils.d.ts +0 -26
  37. package/dist/src/utils.d.ts.map +0 -1
  38. package/dist/src/utils.js +0 -151
  39. package/dist/src/utils.js.map +0 -1
  40. package/generator/LICENSE +0 -21
  41. package/generator/README.md +0 -1
  42. package/generator/dev_requirements.txt +0 -5
  43. package/generator/pygen/__init__.py +0 -107
  44. package/generator/pygen/_version.py +0 -7
  45. package/generator/pygen/black.py +0 -69
  46. package/generator/pygen/codegen/__init__.py +0 -338
  47. package/generator/pygen/codegen/_utils.py +0 -16
  48. package/generator/pygen/codegen/models/__init__.py +0 -204
  49. package/generator/pygen/codegen/models/base.py +0 -186
  50. package/generator/pygen/codegen/models/base_builder.py +0 -119
  51. package/generator/pygen/codegen/models/client.py +0 -430
  52. package/generator/pygen/codegen/models/code_model.py +0 -237
  53. package/generator/pygen/codegen/models/combined_type.py +0 -149
  54. package/generator/pygen/codegen/models/constant_type.py +0 -129
  55. package/generator/pygen/codegen/models/credential_types.py +0 -214
  56. package/generator/pygen/codegen/models/dictionary_type.py +0 -127
  57. package/generator/pygen/codegen/models/enum_type.py +0 -238
  58. package/generator/pygen/codegen/models/imports.py +0 -291
  59. package/generator/pygen/codegen/models/list_type.py +0 -143
  60. package/generator/pygen/codegen/models/lro_operation.py +0 -142
  61. package/generator/pygen/codegen/models/lro_paging_operation.py +0 -32
  62. package/generator/pygen/codegen/models/model_type.py +0 -362
  63. package/generator/pygen/codegen/models/operation.py +0 -530
  64. package/generator/pygen/codegen/models/operation_group.py +0 -184
  65. package/generator/pygen/codegen/models/paging_operation.py +0 -155
  66. package/generator/pygen/codegen/models/parameter.py +0 -412
  67. package/generator/pygen/codegen/models/parameter_list.py +0 -387
  68. package/generator/pygen/codegen/models/primitive_types.py +0 -659
  69. package/generator/pygen/codegen/models/property.py +0 -171
  70. package/generator/pygen/codegen/models/request_builder.py +0 -189
  71. package/generator/pygen/codegen/models/request_builder_parameter.py +0 -115
  72. package/generator/pygen/codegen/models/response.py +0 -348
  73. package/generator/pygen/codegen/models/utils.py +0 -23
  74. package/generator/pygen/codegen/serializers/__init__.py +0 -574
  75. package/generator/pygen/codegen/serializers/base_serializer.py +0 -21
  76. package/generator/pygen/codegen/serializers/builder_serializer.py +0 -1513
  77. package/generator/pygen/codegen/serializers/client_serializer.py +0 -295
  78. package/generator/pygen/codegen/serializers/enum_serializer.py +0 -15
  79. package/generator/pygen/codegen/serializers/general_serializer.py +0 -213
  80. package/generator/pygen/codegen/serializers/import_serializer.py +0 -127
  81. package/generator/pygen/codegen/serializers/metadata_serializer.py +0 -198
  82. package/generator/pygen/codegen/serializers/model_init_serializer.py +0 -33
  83. package/generator/pygen/codegen/serializers/model_serializer.py +0 -300
  84. package/generator/pygen/codegen/serializers/operation_groups_serializer.py +0 -89
  85. package/generator/pygen/codegen/serializers/operations_init_serializer.py +0 -44
  86. package/generator/pygen/codegen/serializers/parameter_serializer.py +0 -221
  87. package/generator/pygen/codegen/serializers/patch_serializer.py +0 -19
  88. package/generator/pygen/codegen/serializers/request_builders_serializer.py +0 -52
  89. package/generator/pygen/codegen/serializers/sample_serializer.py +0 -168
  90. package/generator/pygen/codegen/serializers/test_serializer.py +0 -293
  91. package/generator/pygen/codegen/serializers/types_serializer.py +0 -31
  92. package/generator/pygen/codegen/serializers/utils.py +0 -68
  93. package/generator/pygen/codegen/templates/client.py.jinja2 +0 -37
  94. package/generator/pygen/codegen/templates/client_container.py.jinja2 +0 -12
  95. package/generator/pygen/codegen/templates/config.py.jinja2 +0 -73
  96. package/generator/pygen/codegen/templates/config_container.py.jinja2 +0 -16
  97. package/generator/pygen/codegen/templates/conftest.py.jinja2 +0 -28
  98. package/generator/pygen/codegen/templates/enum.py.jinja2 +0 -13
  99. package/generator/pygen/codegen/templates/enum_container.py.jinja2 +0 -10
  100. package/generator/pygen/codegen/templates/init.py.jinja2 +0 -24
  101. package/generator/pygen/codegen/templates/keywords.jinja2 +0 -19
  102. package/generator/pygen/codegen/templates/lro_operation.py.jinja2 +0 -16
  103. package/generator/pygen/codegen/templates/lro_paging_operation.py.jinja2 +0 -18
  104. package/generator/pygen/codegen/templates/macros.jinja2 +0 -12
  105. package/generator/pygen/codegen/templates/metadata.json.jinja2 +0 -167
  106. package/generator/pygen/codegen/templates/model_base.py.jinja2 +0 -1158
  107. package/generator/pygen/codegen/templates/model_container.py.jinja2 +0 -13
  108. package/generator/pygen/codegen/templates/model_dpg.py.jinja2 +0 -98
  109. package/generator/pygen/codegen/templates/model_init.py.jinja2 +0 -28
  110. package/generator/pygen/codegen/templates/model_msrest.py.jinja2 +0 -92
  111. package/generator/pygen/codegen/templates/operation.py.jinja2 +0 -21
  112. package/generator/pygen/codegen/templates/operation_group.py.jinja2 +0 -75
  113. package/generator/pygen/codegen/templates/operation_groups_container.py.jinja2 +0 -20
  114. package/generator/pygen/codegen/templates/operation_tools.jinja2 +0 -81
  115. package/generator/pygen/codegen/templates/operations_folder_init.py.jinja2 +0 -17
  116. package/generator/pygen/codegen/templates/packaging_templates/CHANGELOG.md.jinja2 +0 -6
  117. package/generator/pygen/codegen/templates/packaging_templates/LICENSE.jinja2 +0 -21
  118. package/generator/pygen/codegen/templates/packaging_templates/MANIFEST.in.jinja2 +0 -8
  119. package/generator/pygen/codegen/templates/packaging_templates/README.md.jinja2 +0 -107
  120. package/generator/pygen/codegen/templates/packaging_templates/dev_requirements.txt.jinja2 +0 -9
  121. package/generator/pygen/codegen/templates/packaging_templates/setup.py.jinja2 +0 -108
  122. package/generator/pygen/codegen/templates/paging_operation.py.jinja2 +0 -21
  123. package/generator/pygen/codegen/templates/patch.py.jinja2 +0 -19
  124. package/generator/pygen/codegen/templates/pkgutil_init.py.jinja2 +0 -1
  125. package/generator/pygen/codegen/templates/request_builder.py.jinja2 +0 -28
  126. package/generator/pygen/codegen/templates/request_builders.py.jinja2 +0 -10
  127. package/generator/pygen/codegen/templates/rest_init.py.jinja2 +0 -12
  128. package/generator/pygen/codegen/templates/sample.py.jinja2 +0 -44
  129. package/generator/pygen/codegen/templates/serialization.py.jinja2 +0 -2115
  130. package/generator/pygen/codegen/templates/test.py.jinja2 +0 -50
  131. package/generator/pygen/codegen/templates/testpreparer.py.jinja2 +0 -26
  132. package/generator/pygen/codegen/templates/types.py.jinja2 +0 -8
  133. package/generator/pygen/codegen/templates/validation.py.jinja2 +0 -38
  134. package/generator/pygen/codegen/templates/vendor.py.jinja2 +0 -96
  135. package/generator/pygen/codegen/templates/version.py.jinja2 +0 -4
  136. package/generator/pygen/m2r.py +0 -65
  137. package/generator/pygen/postprocess/__init__.py +0 -183
  138. package/generator/pygen/postprocess/get_all.py +0 -19
  139. package/generator/pygen/postprocess/venvtools.py +0 -75
  140. package/generator/pygen/preprocess/__init__.py +0 -509
  141. package/generator/pygen/preprocess/helpers.py +0 -27
  142. package/generator/pygen/preprocess/python_mappings.py +0 -224
  143. package/generator/pygen/utils.py +0 -160
  144. package/generator/pygen.egg-info/PKG-INFO +0 -25
  145. package/generator/pygen.egg-info/SOURCES.txt +0 -66
  146. package/generator/pygen.egg-info/dependency_links.txt +0 -1
  147. package/generator/pygen.egg-info/requires.txt +0 -4
  148. package/generator/pygen.egg-info/top_level.txt +0 -1
  149. package/generator/requirements.txt +0 -12
  150. package/generator/setup.py +0 -55
@@ -1,171 +0,0 @@
1
- # -------------------------------------------------------------------------
2
- # Copyright (c) Microsoft Corporation. All rights reserved.
3
- # Licensed under the MIT License. See License.txt in the project root for
4
- # license information.
5
- # --------------------------------------------------------------------------
6
- from typing import Any, Dict, Optional, TYPE_CHECKING, List, cast, Union
7
-
8
- from .base import BaseModel
9
- from .constant_type import ConstantType
10
- from .enum_type import EnumType
11
- from .base import BaseType
12
- from .imports import FileImport, ImportType
13
- from .utils import add_to_description, add_to_pylint_disable
14
-
15
- if TYPE_CHECKING:
16
- from .code_model import CodeModel
17
- from .model_type import ModelType
18
-
19
-
20
- class Property(BaseModel): # pylint: disable=too-many-instance-attributes
21
- def __init__(
22
- self,
23
- yaml_data: Dict[str, Any],
24
- code_model: "CodeModel",
25
- type: BaseType,
26
- ) -> None:
27
- super().__init__(yaml_data, code_model)
28
- self.wire_name: str = self.yaml_data["wireName"]
29
- self.client_name: str = self.yaml_data["clientName"]
30
- self.type = type
31
- self.optional: bool = self.yaml_data["optional"]
32
- self.readonly: bool = self.yaml_data.get("readonly", False)
33
- self.visibility: List[str] = self.yaml_data.get("visibility", [])
34
- self.is_polymorphic: bool = self.yaml_data.get("isPolymorphic", False)
35
- self.is_discriminator: bool = yaml_data.get("isDiscriminator", False)
36
- self.client_default_value = yaml_data.get("clientDefaultValue", None)
37
- if self.client_default_value is None:
38
- self.client_default_value = self.type.client_default_value
39
- self.flattened_names: List[str] = yaml_data.get("flattenedNames", [])
40
- self.is_multipart_file_input: bool = yaml_data.get("isMultipartFileInput", False)
41
- self.flatten = self.yaml_data.get("flatten", False) and not getattr(self.type, "flattened_property", False)
42
-
43
- @property
44
- def pylint_disable(self) -> str:
45
- retval: str = ""
46
- if self.yaml_data.get("pylintDisable"):
47
- retval = add_to_pylint_disable(retval, self.yaml_data["pylintDisable"])
48
- return retval
49
-
50
- def description(self, *, is_operation_file: bool) -> str:
51
- from .model_type import ModelType
52
-
53
- description = self.yaml_data.get("description", "")
54
- if not (self.optional or self.client_default_value):
55
- description = add_to_description(description, "Required.")
56
- # don't want model type documentation as part of property doc
57
- type_description = (
58
- "" if isinstance(self.type, ModelType) else self.type.description(is_operation_file=is_operation_file)
59
- )
60
- return add_to_description(description, type_description)
61
-
62
- @property
63
- def client_default_value_declaration(self) -> str:
64
- if self.client_default_value is not None:
65
- return self.get_declaration(self.client_default_value)
66
- if self.type.client_default_value is not None:
67
- return self.get_declaration(self.type.client_default_value)
68
- return "None"
69
-
70
- @property
71
- def constant(self) -> bool:
72
- # this bool doesn't consider you to be constant if you are a discriminator
73
- # you also have to be required to be considered a constant
74
- return isinstance(self.type, ConstantType) and not self.optional and not self.is_discriminator
75
-
76
- @property
77
- def is_input(self):
78
- return not (self.constant or self.readonly or self.is_discriminator)
79
-
80
- @property
81
- def serialization_type(self) -> str:
82
- return self.type.serialization_type
83
-
84
- @property
85
- def msrest_deserialization_key(self) -> str:
86
- return self.type.msrest_deserialization_key
87
-
88
- @property
89
- def is_enum_discriminator(self) -> bool:
90
- return self.is_discriminator and self.type.type == "enum"
91
-
92
- @property
93
- def is_base_discriminator(self) -> bool:
94
- """If this discriminator is on the base model for polymorphic inheritance"""
95
- if self.is_enum_discriminator:
96
- return self.is_polymorphic and self.client_default_value is None
97
- return self.is_discriminator and self.is_polymorphic and cast(ConstantType, self.type).value is None
98
-
99
- @property
100
- def xml_metadata(self) -> Optional[Dict[str, Union[str, bool]]]:
101
- return self.yaml_data.get("xmlMetadata")
102
-
103
- def type_annotation(self, *, is_operation_file: bool = False) -> str:
104
- if self.is_base_discriminator:
105
- return "str"
106
- types_type_annotation = self.type.type_annotation(is_operation_file=is_operation_file)
107
- if self.optional and self.client_default_value is None:
108
- return f"Optional[{types_type_annotation}]"
109
- return types_type_annotation
110
-
111
- def get_declaration(self, value: Any = None) -> Any:
112
- return self.type.get_declaration(value)
113
-
114
- def get_json_template_representation(
115
- self,
116
- *,
117
- client_default_value_declaration: Optional[str] = None,
118
- ) -> Any:
119
- if self.client_default_value:
120
- client_default_value_declaration = self.get_declaration(self.client_default_value)
121
- # make sure there is no \n otherwise the json template will be invalid
122
- return self.type.get_json_template_representation(
123
- client_default_value_declaration=client_default_value_declaration,
124
- )
125
-
126
- def get_polymorphic_subtypes(self, polymorphic_subtypes: List["ModelType"]) -> None:
127
- from .model_type import ModelType
128
-
129
- if isinstance(self.type, ModelType):
130
- self.type.get_polymorphic_subtypes(polymorphic_subtypes)
131
-
132
- @property
133
- def validation(self) -> Optional[Dict[str, Any]]:
134
- retval: Dict[str, Any] = {}
135
- if not self.optional:
136
- retval["required"] = True
137
- if self.readonly:
138
- retval["readonly"] = True
139
- if self.constant:
140
- retval["constant"] = True
141
- retval.update(self.type.validation or {})
142
- return retval or None
143
-
144
- def imports(self, **kwargs) -> FileImport:
145
- file_import = FileImport(self.code_model)
146
- if self.is_discriminator and isinstance(self.type, EnumType):
147
- return file_import
148
- file_import.merge(self.type.imports(**kwargs, relative_path="..", model_typing=True))
149
- if self.optional and self.client_default_value is None:
150
- file_import.add_submodule_import("typing", "Optional", ImportType.STDLIB)
151
- if self.code_model.options["models_mode"] == "dpg":
152
- file_import.add_submodule_import(
153
- ".._model_base",
154
- "rest_discriminator" if self.is_discriminator else "rest_field",
155
- ImportType.LOCAL,
156
- )
157
- return file_import
158
-
159
- @classmethod
160
- def from_yaml(
161
- cls,
162
- yaml_data: Dict[str, Any],
163
- code_model: "CodeModel",
164
- ) -> "Property":
165
- from . import build_type # pylint: disable=import-outside-toplevel
166
-
167
- return cls(
168
- yaml_data=yaml_data,
169
- code_model=code_model,
170
- type=build_type(yaml_data["type"], code_model),
171
- )
@@ -1,189 +0,0 @@
1
- # -------------------------------------------------------------------------
2
- # Copyright (c) Microsoft Corporation. All rights reserved.
3
- # Licensed under the MIT License. See License.txt in the project root for
4
- # license information.
5
- # --------------------------------------------------------------------------
6
- from typing import (
7
- Any,
8
- Callable,
9
- Dict,
10
- List,
11
- TypeVar,
12
- TYPE_CHECKING,
13
- Union,
14
- Optional,
15
- )
16
- from abc import abstractmethod
17
-
18
- from .base_builder import BaseBuilder
19
- from .utils import add_to_pylint_disable, NAME_LENGTH_LIMIT
20
- from .parameter_list import (
21
- RequestBuilderParameterList,
22
- OverloadedRequestBuilderParameterList,
23
- )
24
- from .imports import FileImport, ImportType, TypingSection, MsrestImportType
25
-
26
- if TYPE_CHECKING:
27
- from .code_model import CodeModel
28
- from .client import Client
29
-
30
- ParameterListType = TypeVar(
31
- "ParameterListType",
32
- bound=Union[RequestBuilderParameterList, OverloadedRequestBuilderParameterList],
33
- )
34
-
35
-
36
- class RequestBuilderBase(BaseBuilder[ParameterListType, List["RequestBuilder"]]):
37
- def __init__(
38
- self,
39
- yaml_data: Dict[str, Any],
40
- code_model: "CodeModel",
41
- client: "Client",
42
- name: str,
43
- parameters: ParameterListType,
44
- *,
45
- overloads: Optional[List["RequestBuilder"]] = None,
46
- ) -> None:
47
- super().__init__(
48
- code_model=code_model,
49
- client=client,
50
- yaml_data=yaml_data,
51
- name=name,
52
- parameters=parameters,
53
- overloads=overloads,
54
- )
55
- self.overloads: List["RequestBuilder"] = overloads or []
56
- self.url: str = yaml_data["url"]
57
- self.method: str = yaml_data["method"]
58
- self.want_tracing = False
59
-
60
- @property
61
- def has_form_data_body(self):
62
- return self.parameters.has_form_data_body
63
-
64
- @property
65
- def is_lro(self) -> bool:
66
- return self.yaml_data.get("discriminator") in ("lro", "lropaging")
67
-
68
- @property
69
- def pylint_disable(self) -> str:
70
- if len(self.name) > NAME_LENGTH_LIMIT:
71
- return add_to_pylint_disable("", "name-too-long")
72
- return ""
73
-
74
- def response_type_annotation(self, **kwargs) -> str:
75
- return "HttpRequest"
76
-
77
- def response_docstring_text(self, **kwargs) -> str:
78
- return (
79
- f"Returns an :class:`~{self.response_docstring_type()}` that you will pass to the client's "
80
- + "`send_request` method. See https://aka.ms/azsdk/dpcodegen/python/send_request for how to "
81
- + "incorporate this response into your code flow."
82
- )
83
-
84
- def response_docstring_type(self, **kwargs) -> str:
85
- return f"~{self.code_model.core_library}.rest.HttpRequest"
86
-
87
- def imports(self) -> FileImport:
88
- file_import = FileImport(self.code_model)
89
- relative_path = ".."
90
- if not self.code_model.options["builders_visibility"] == "embedded" and self.group_name:
91
- relative_path = "..." if self.group_name else ".."
92
- if self.abstract:
93
- return file_import
94
- for parameter in self.parameters.method:
95
- file_import.merge(parameter.imports(async_mode=False, relative_path=relative_path, operation=self))
96
-
97
- file_import.add_submodule_import(
98
- "rest",
99
- "HttpRequest",
100
- ImportType.SDKCORE,
101
- )
102
-
103
- if self.parameters.headers or self.parameters.query:
104
- file_import.add_submodule_import(
105
- "utils",
106
- "case_insensitive_dict",
107
- ImportType.SDKCORE,
108
- )
109
- file_import.add_submodule_import("typing", "Any", ImportType.STDLIB, typing_section=TypingSection.CONDITIONAL)
110
- file_import.add_msrest_import(
111
- relative_path=(
112
- "..."
113
- if (not self.code_model.options["builders_visibility"] == "embedded" and self.group_name)
114
- else ".."
115
- ),
116
- msrest_import_type=MsrestImportType.Serializer,
117
- typing_section=TypingSection.REGULAR,
118
- )
119
- if self.overloads and self.code_model.options["builders_visibility"] != "embedded":
120
- file_import.add_submodule_import("typing", "overload", ImportType.STDLIB)
121
- return file_import
122
-
123
- @staticmethod
124
- @abstractmethod
125
- def parameter_list_type() -> Callable[[Dict[str, Any], "CodeModel"], ParameterListType]: ...
126
-
127
- @classmethod
128
- def get_name(
129
- cls,
130
- name: str,
131
- yaml_data: Dict[str, Any],
132
- code_model: "CodeModel",
133
- client: "Client",
134
- ) -> str:
135
- additional_mark = ""
136
- if code_model.options["combine_operation_files"] and code_model.options["builders_visibility"] == "embedded":
137
- additional_mark = yaml_data["groupName"] or client.yaml_data["builderPadName"]
138
- names = [
139
- "build",
140
- additional_mark,
141
- name,
142
- "request",
143
- ]
144
- return "_".join([n for n in names if n])
145
-
146
- @classmethod
147
- def from_yaml(
148
- cls,
149
- yaml_data: Dict[str, Any],
150
- code_model: "CodeModel",
151
- client: "Client",
152
- ):
153
- # when combine embedded builders into one operation file, we need to avoid duplicated build function name.
154
- # So add operation group name is effective method
155
-
156
- overloads = [
157
- RequestBuilder.from_yaml(rb_yaml_data, code_model, client)
158
- for rb_yaml_data in yaml_data.get("overloads", [])
159
- ]
160
- parameter_list = cls.parameter_list_type()(yaml_data, code_model)
161
-
162
- return cls(
163
- yaml_data=yaml_data,
164
- code_model=code_model,
165
- client=client,
166
- name=cls.get_name(yaml_data["name"], yaml_data, code_model, client),
167
- parameters=parameter_list,
168
- overloads=overloads,
169
- )
170
-
171
-
172
- class RequestBuilder(RequestBuilderBase[RequestBuilderParameterList]):
173
- @staticmethod
174
- def parameter_list_type() -> Callable[[Dict[str, Any], "CodeModel"], RequestBuilderParameterList]:
175
- return RequestBuilderParameterList.from_yaml
176
-
177
-
178
- class OverloadedRequestBuilder(RequestBuilderBase[OverloadedRequestBuilderParameterList]):
179
- @staticmethod
180
- def parameter_list_type() -> Callable[[Dict[str, Any], "CodeModel"], OverloadedRequestBuilderParameterList]:
181
- return OverloadedRequestBuilderParameterList.from_yaml
182
-
183
-
184
- def get_request_builder(
185
- yaml_data: Dict[str, Any], code_model: "CodeModel", client: "Client"
186
- ) -> Union[RequestBuilder, OverloadedRequestBuilder]:
187
- if yaml_data.get("overloads"):
188
- return OverloadedRequestBuilder.from_yaml(yaml_data, code_model, client)
189
- return RequestBuilder.from_yaml(yaml_data, code_model, client)
@@ -1,115 +0,0 @@
1
- # -------------------------------------------------------------------------
2
- # Copyright (c) Microsoft Corporation. All rights reserved.
3
- # Licensed under the MIT License. See License.txt in the project root for
4
- # license information.
5
- # --------------------------------------------------------------------------
6
- from typing import TYPE_CHECKING, Any, Dict
7
- from .parameter import (
8
- ParameterLocation,
9
- ParameterMethodLocation,
10
- Parameter,
11
- BodyParameter,
12
- )
13
- from .base import BaseType
14
- from .primitive_types import BinaryType, StringType
15
- from .combined_type import CombinedType
16
-
17
- if TYPE_CHECKING:
18
- from .code_model import CodeModel
19
-
20
-
21
- class RequestBuilderBodyParameter(BodyParameter):
22
- """BOdy parmaeter for RequestBuilders"""
23
-
24
- def __init__(self, *args, **kwargs) -> None:
25
- super().__init__(*args, **kwargs)
26
- if (
27
- isinstance(self.type, (BinaryType, StringType))
28
- or any("xml" in ct for ct in self.content_types)
29
- or self.code_model.options["models_mode"] == "dpg"
30
- ):
31
- self.client_name = "content"
32
- else:
33
- self.client_name = "json"
34
-
35
- def type_annotation(self, **kwargs: Any) -> str:
36
- if self.type.is_xml:
37
- return "Any" # xml type technically not in type signature for HttpRequest content param
38
- return super().type_annotation(**kwargs)
39
-
40
- @property
41
- def in_method_signature(self) -> bool:
42
- return (
43
- super().in_method_signature and not self.is_partial_body and self.code_model.options["models_mode"] != "dpg"
44
- )
45
-
46
- @property
47
- def method_location(self) -> ParameterMethodLocation:
48
- return (
49
- ParameterMethodLocation.KWARG
50
- if (self.constant or isinstance(self.type, CombinedType))
51
- else ParameterMethodLocation.KEYWORD_ONLY
52
- )
53
-
54
- @classmethod
55
- def from_yaml(cls, yaml_data: Dict[str, Any], code_model: "CodeModel") -> "RequestBuilderBodyParameter":
56
- return super().from_yaml(yaml_data, code_model) # type: ignore
57
-
58
- @property
59
- def name_in_high_level_operation(self) -> str:
60
- if self.client_name == "json":
61
- return "_json"
62
- return "_content"
63
-
64
-
65
- class RequestBuilderParameter(Parameter):
66
- """Basic RequestBuilder Parameter."""
67
-
68
- def __init__(
69
- self,
70
- yaml_data: Dict[str, Any],
71
- code_model: "CodeModel",
72
- type: BaseType,
73
- ) -> None:
74
- super().__init__(yaml_data, code_model, type)
75
- # we don't want any default content type behavior in request builder
76
- if self.is_content_type:
77
- self.client_default_value = None
78
- if self.grouped_by and self.client_name[0] == "_":
79
- # we don't want hidden parameters for grouped by in request builders
80
- self.client_name = self.client_name[1:]
81
-
82
- @property
83
- def hide_in_operation_signature(self) -> bool:
84
- return False
85
-
86
- @property
87
- def in_method_signature(self) -> bool:
88
- if self.grouped_by and not self.in_flattened_body:
89
- return True
90
- return super().in_method_signature and not (
91
- self.location == ParameterLocation.ENDPOINT_PATH or self.in_flattened_body or self.grouper
92
- )
93
-
94
- @property
95
- def full_client_name(self) -> str:
96
- return self.client_name
97
-
98
- @property
99
- def method_location(self) -> ParameterMethodLocation:
100
- super_method_location = super().method_location
101
- if super_method_location == ParameterMethodLocation.KWARG:
102
- return super_method_location
103
- if self.in_overriden and super_method_location == ParameterMethodLocation.KEYWORD_ONLY:
104
- return ParameterMethodLocation.KWARG
105
- if self.location != ParameterLocation.PATH:
106
- return ParameterMethodLocation.KEYWORD_ONLY
107
- return super_method_location
108
-
109
- @property
110
- def name_in_high_level_operation(self) -> str:
111
- if self.grouped_by:
112
- return f"_{self.client_name}"
113
- if self.implementation == "Client":
114
- return f"self._config.{self.client_name}"
115
- return self.client_name