@azure-tools/typespec-python 0.33.0 → 0.35.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 (146) hide show
  1. package/dist/scripts/eng/lint.d.ts.map +1 -1
  2. package/dist/scripts/eng/lint.js +18 -1
  3. package/dist/scripts/eng/lint.js.map +1 -1
  4. package/dist/src/emitter.d.ts +0 -2
  5. package/dist/src/emitter.d.ts.map +1 -1
  6. package/dist/src/emitter.js +2 -102
  7. package/dist/src/emitter.js.map +1 -1
  8. package/dist/src/index.d.ts +1 -1
  9. package/dist/src/index.d.ts.map +1 -1
  10. package/dist/src/index.js +1 -1
  11. package/dist/src/index.js.map +1 -1
  12. package/generator/dev_requirements.txt +10 -3
  13. package/package.json +14 -11
  14. package/scripts/__pycache__/venvtools.cpython-310.pyc +0 -0
  15. package/scripts/eng/lint.ts +17 -1
  16. package/scripts/eng/pylintrc +2 -1
  17. package/scripts/install.py +0 -1
  18. package/dist/src/code-model.d.ts +0 -4
  19. package/dist/src/code-model.d.ts.map +0 -1
  20. package/dist/src/code-model.js +0 -190
  21. package/dist/src/code-model.js.map +0 -1
  22. package/dist/src/external-process.d.ts +0 -20
  23. package/dist/src/external-process.d.ts.map +0 -1
  24. package/dist/src/external-process.js +0 -44
  25. package/dist/src/external-process.js.map +0 -1
  26. package/dist/src/http.d.ts +0 -7
  27. package/dist/src/http.d.ts.map +0 -1
  28. package/dist/src/http.js +0 -266
  29. package/dist/src/http.js.map +0 -1
  30. package/dist/src/types.d.ts +0 -36
  31. package/dist/src/types.d.ts.map +0 -1
  32. package/dist/src/types.js +0 -489
  33. package/dist/src/types.js.map +0 -1
  34. package/dist/src/utils.d.ts +0 -26
  35. package/dist/src/utils.d.ts.map +0 -1
  36. package/dist/src/utils.js +0 -151
  37. package/dist/src/utils.js.map +0 -1
  38. package/generator/LICENSE +0 -21
  39. package/generator/README.md +0 -1
  40. package/generator/pygen/__init__.py +0 -107
  41. package/generator/pygen/_version.py +0 -7
  42. package/generator/pygen/black.py +0 -69
  43. package/generator/pygen/codegen/__init__.py +0 -338
  44. package/generator/pygen/codegen/_utils.py +0 -16
  45. package/generator/pygen/codegen/models/__init__.py +0 -204
  46. package/generator/pygen/codegen/models/base.py +0 -186
  47. package/generator/pygen/codegen/models/base_builder.py +0 -119
  48. package/generator/pygen/codegen/models/client.py +0 -430
  49. package/generator/pygen/codegen/models/code_model.py +0 -237
  50. package/generator/pygen/codegen/models/combined_type.py +0 -149
  51. package/generator/pygen/codegen/models/constant_type.py +0 -129
  52. package/generator/pygen/codegen/models/credential_types.py +0 -214
  53. package/generator/pygen/codegen/models/dictionary_type.py +0 -127
  54. package/generator/pygen/codegen/models/enum_type.py +0 -238
  55. package/generator/pygen/codegen/models/imports.py +0 -291
  56. package/generator/pygen/codegen/models/list_type.py +0 -143
  57. package/generator/pygen/codegen/models/lro_operation.py +0 -142
  58. package/generator/pygen/codegen/models/lro_paging_operation.py +0 -32
  59. package/generator/pygen/codegen/models/model_type.py +0 -362
  60. package/generator/pygen/codegen/models/operation.py +0 -530
  61. package/generator/pygen/codegen/models/operation_group.py +0 -184
  62. package/generator/pygen/codegen/models/paging_operation.py +0 -155
  63. package/generator/pygen/codegen/models/parameter.py +0 -412
  64. package/generator/pygen/codegen/models/parameter_list.py +0 -387
  65. package/generator/pygen/codegen/models/primitive_types.py +0 -659
  66. package/generator/pygen/codegen/models/property.py +0 -171
  67. package/generator/pygen/codegen/models/request_builder.py +0 -189
  68. package/generator/pygen/codegen/models/request_builder_parameter.py +0 -115
  69. package/generator/pygen/codegen/models/response.py +0 -348
  70. package/generator/pygen/codegen/models/utils.py +0 -23
  71. package/generator/pygen/codegen/serializers/__init__.py +0 -574
  72. package/generator/pygen/codegen/serializers/base_serializer.py +0 -21
  73. package/generator/pygen/codegen/serializers/builder_serializer.py +0 -1513
  74. package/generator/pygen/codegen/serializers/client_serializer.py +0 -295
  75. package/generator/pygen/codegen/serializers/enum_serializer.py +0 -15
  76. package/generator/pygen/codegen/serializers/general_serializer.py +0 -213
  77. package/generator/pygen/codegen/serializers/import_serializer.py +0 -127
  78. package/generator/pygen/codegen/serializers/metadata_serializer.py +0 -198
  79. package/generator/pygen/codegen/serializers/model_init_serializer.py +0 -33
  80. package/generator/pygen/codegen/serializers/model_serializer.py +0 -300
  81. package/generator/pygen/codegen/serializers/operation_groups_serializer.py +0 -89
  82. package/generator/pygen/codegen/serializers/operations_init_serializer.py +0 -44
  83. package/generator/pygen/codegen/serializers/parameter_serializer.py +0 -221
  84. package/generator/pygen/codegen/serializers/patch_serializer.py +0 -19
  85. package/generator/pygen/codegen/serializers/request_builders_serializer.py +0 -52
  86. package/generator/pygen/codegen/serializers/sample_serializer.py +0 -168
  87. package/generator/pygen/codegen/serializers/test_serializer.py +0 -293
  88. package/generator/pygen/codegen/serializers/types_serializer.py +0 -31
  89. package/generator/pygen/codegen/serializers/utils.py +0 -68
  90. package/generator/pygen/codegen/templates/client.py.jinja2 +0 -37
  91. package/generator/pygen/codegen/templates/client_container.py.jinja2 +0 -12
  92. package/generator/pygen/codegen/templates/config.py.jinja2 +0 -73
  93. package/generator/pygen/codegen/templates/config_container.py.jinja2 +0 -16
  94. package/generator/pygen/codegen/templates/conftest.py.jinja2 +0 -28
  95. package/generator/pygen/codegen/templates/enum.py.jinja2 +0 -13
  96. package/generator/pygen/codegen/templates/enum_container.py.jinja2 +0 -10
  97. package/generator/pygen/codegen/templates/init.py.jinja2 +0 -24
  98. package/generator/pygen/codegen/templates/keywords.jinja2 +0 -19
  99. package/generator/pygen/codegen/templates/lro_operation.py.jinja2 +0 -16
  100. package/generator/pygen/codegen/templates/lro_paging_operation.py.jinja2 +0 -18
  101. package/generator/pygen/codegen/templates/macros.jinja2 +0 -12
  102. package/generator/pygen/codegen/templates/metadata.json.jinja2 +0 -167
  103. package/generator/pygen/codegen/templates/model_base.py.jinja2 +0 -1158
  104. package/generator/pygen/codegen/templates/model_container.py.jinja2 +0 -13
  105. package/generator/pygen/codegen/templates/model_dpg.py.jinja2 +0 -98
  106. package/generator/pygen/codegen/templates/model_init.py.jinja2 +0 -28
  107. package/generator/pygen/codegen/templates/model_msrest.py.jinja2 +0 -92
  108. package/generator/pygen/codegen/templates/operation.py.jinja2 +0 -21
  109. package/generator/pygen/codegen/templates/operation_group.py.jinja2 +0 -75
  110. package/generator/pygen/codegen/templates/operation_groups_container.py.jinja2 +0 -20
  111. package/generator/pygen/codegen/templates/operation_tools.jinja2 +0 -81
  112. package/generator/pygen/codegen/templates/operations_folder_init.py.jinja2 +0 -17
  113. package/generator/pygen/codegen/templates/packaging_templates/CHANGELOG.md.jinja2 +0 -6
  114. package/generator/pygen/codegen/templates/packaging_templates/LICENSE.jinja2 +0 -21
  115. package/generator/pygen/codegen/templates/packaging_templates/MANIFEST.in.jinja2 +0 -8
  116. package/generator/pygen/codegen/templates/packaging_templates/README.md.jinja2 +0 -107
  117. package/generator/pygen/codegen/templates/packaging_templates/dev_requirements.txt.jinja2 +0 -9
  118. package/generator/pygen/codegen/templates/packaging_templates/setup.py.jinja2 +0 -108
  119. package/generator/pygen/codegen/templates/paging_operation.py.jinja2 +0 -21
  120. package/generator/pygen/codegen/templates/patch.py.jinja2 +0 -19
  121. package/generator/pygen/codegen/templates/pkgutil_init.py.jinja2 +0 -1
  122. package/generator/pygen/codegen/templates/request_builder.py.jinja2 +0 -28
  123. package/generator/pygen/codegen/templates/request_builders.py.jinja2 +0 -10
  124. package/generator/pygen/codegen/templates/rest_init.py.jinja2 +0 -12
  125. package/generator/pygen/codegen/templates/sample.py.jinja2 +0 -44
  126. package/generator/pygen/codegen/templates/serialization.py.jinja2 +0 -2115
  127. package/generator/pygen/codegen/templates/test.py.jinja2 +0 -50
  128. package/generator/pygen/codegen/templates/testpreparer.py.jinja2 +0 -26
  129. package/generator/pygen/codegen/templates/types.py.jinja2 +0 -8
  130. package/generator/pygen/codegen/templates/validation.py.jinja2 +0 -38
  131. package/generator/pygen/codegen/templates/vendor.py.jinja2 +0 -96
  132. package/generator/pygen/codegen/templates/version.py.jinja2 +0 -4
  133. package/generator/pygen/m2r.py +0 -65
  134. package/generator/pygen/postprocess/__init__.py +0 -183
  135. package/generator/pygen/postprocess/get_all.py +0 -19
  136. package/generator/pygen/postprocess/venvtools.py +0 -75
  137. package/generator/pygen/preprocess/__init__.py +0 -509
  138. package/generator/pygen/preprocess/helpers.py +0 -27
  139. package/generator/pygen/preprocess/python_mappings.py +0 -224
  140. package/generator/pygen/utils.py +0 -160
  141. package/generator/pygen.egg-info/PKG-INFO +0 -25
  142. package/generator/pygen.egg-info/SOURCES.txt +0 -66
  143. package/generator/pygen.egg-info/dependency_links.txt +0 -1
  144. package/generator/pygen.egg-info/requires.txt +0 -4
  145. package/generator/pygen.egg-info/top_level.txt +0 -1
  146. 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