dub 0.26.6__py3-none-any.whl → 0.26.8__py3-none-any.whl

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.
dub/_version.py CHANGED
@@ -3,10 +3,10 @@
3
3
  import importlib.metadata
4
4
 
5
5
  __title__: str = "dub"
6
- __version__: str = "0.26.6"
6
+ __version__: str = "0.26.8"
7
7
  __openapi_doc_version__: str = "0.0.1"
8
- __gen_version__: str = "2.623.0"
9
- __user_agent__: str = "speakeasy-sdk/python 0.26.6 2.623.0 0.0.1 dub"
8
+ __gen_version__: str = "2.630.6"
9
+ __user_agent__: str = "speakeasy-sdk/python 0.26.8 2.630.6 0.0.1 dub"
10
10
 
11
11
  try:
12
12
  if __package__ is not None:
@@ -235,6 +235,7 @@ if TYPE_CHECKING:
235
235
  ListDomainsResponseTypedDict,
236
236
  )
237
237
  from .listevents import (
238
+ ListEventsQueryParamSortBy,
238
239
  ListEventsQueryParamTagIds,
239
240
  ListEventsQueryParamTagIdsTypedDict,
240
241
  ListEventsRequest,
@@ -244,7 +245,6 @@ if TYPE_CHECKING:
244
245
  Order,
245
246
  QueryParamEvent,
246
247
  QueryParamInterval,
247
- QueryParamSortBy,
248
248
  QueryParamSortOrder,
249
249
  QueryParamTrigger,
250
250
  )
@@ -259,6 +259,7 @@ if TYPE_CHECKING:
259
259
  Event,
260
260
  Interval,
261
261
  QueryParamGroupBy,
262
+ QueryParamSortBy,
262
263
  RetrieveAnalyticsQueryParamTagIds,
263
264
  RetrieveAnalyticsQueryParamTagIdsTypedDict,
264
265
  RetrieveAnalyticsRequest,
@@ -568,6 +569,7 @@ __all__ = [
568
569
  "ListDomainsRequestTypedDict",
569
570
  "ListDomainsResponse",
570
571
  "ListDomainsResponseTypedDict",
572
+ "ListEventsQueryParamSortBy",
571
573
  "ListEventsQueryParamTagIds",
572
574
  "ListEventsQueryParamTagIdsTypedDict",
573
575
  "ListEventsRequest",
@@ -904,6 +906,7 @@ _dynamic_imports: dict[str, str] = {
904
906
  "ListDomainsRequestTypedDict": ".listdomains",
905
907
  "ListDomainsResponse": ".listdomains",
906
908
  "ListDomainsResponseTypedDict": ".listdomains",
909
+ "ListEventsQueryParamSortBy": ".listevents",
907
910
  "ListEventsQueryParamTagIds": ".listevents",
908
911
  "ListEventsQueryParamTagIdsTypedDict": ".listevents",
909
912
  "ListEventsRequest": ".listevents",
@@ -913,7 +916,6 @@ _dynamic_imports: dict[str, str] = {
913
916
  "Order": ".listevents",
914
917
  "QueryParamEvent": ".listevents",
915
918
  "QueryParamInterval": ".listevents",
916
- "QueryParamSortBy": ".listevents",
917
919
  "QueryParamSortOrder": ".listevents",
918
920
  "QueryParamTrigger": ".listevents",
919
921
  "ListFoldersRequest": ".listfolders",
@@ -925,6 +927,7 @@ _dynamic_imports: dict[str, str] = {
925
927
  "Event": ".retrieveanalytics",
926
928
  "Interval": ".retrieveanalytics",
927
929
  "QueryParamGroupBy": ".retrieveanalytics",
930
+ "QueryParamSortBy": ".retrieveanalytics",
928
931
  "RetrieveAnalyticsQueryParamTagIds": ".retrieveanalytics",
929
932
  "RetrieveAnalyticsQueryParamTagIdsTypedDict": ".retrieveanalytics",
930
933
  "RetrieveAnalyticsRequest": ".retrieveanalytics",
@@ -14,6 +14,7 @@ class Type(str, Enum):
14
14
  CLICK = "click"
15
15
  LEAD = "lead"
16
16
  SALE = "sale"
17
+ CUSTOM = "custom"
17
18
 
18
19
 
19
20
  class QueryParamStatus(str, Enum):
@@ -174,6 +175,7 @@ class ListCommissionsType(str, Enum):
174
175
  CLICK = "click"
175
176
  LEAD = "lead"
176
177
  SALE = "sale"
178
+ CUSTOM = "custom"
177
179
 
178
180
 
179
181
  class ListCommissionsStatus(str, Enum):
@@ -71,7 +71,7 @@ class QueryParamSortOrder(str, Enum):
71
71
  DESC = "desc"
72
72
 
73
73
 
74
- class QueryParamSortBy(str, Enum):
74
+ class ListEventsQueryParamSortBy(str, Enum):
75
75
  r"""The field to sort the events by. The default is `timestamp`."""
76
76
 
77
77
  TIMESTAMP = "timestamp"
@@ -160,7 +160,7 @@ class ListEventsRequestTypedDict(TypedDict):
160
160
  limit: NotRequired[float]
161
161
  sort_order: NotRequired[QueryParamSortOrder]
162
162
  r"""The sort order. The default is `desc`."""
163
- sort_by: NotRequired[QueryParamSortBy]
163
+ sort_by: NotRequired[ListEventsQueryParamSortBy]
164
164
  r"""The field to sort the events by. The default is `timestamp`."""
165
165
  order: NotRequired[Order]
166
166
  r"""DEPRECATED. Use `sortOrder` instead."""
@@ -399,10 +399,10 @@ class ListEventsRequest(BaseModel):
399
399
  r"""The sort order. The default is `desc`."""
400
400
 
401
401
  sort_by: Annotated[
402
- Optional[QueryParamSortBy],
402
+ Optional[ListEventsQueryParamSortBy],
403
403
  pydantic.Field(alias="sortBy"),
404
404
  FieldMetadata(query=QueryParamMetadata(style="form", explode=True)),
405
- ] = QueryParamSortBy.TIMESTAMP
405
+ ] = ListEventsQueryParamSortBy.TIMESTAMP
406
406
  r"""The field to sort the events by. The default is `timestamp`."""
407
407
 
408
408
  order: Annotated[
@@ -96,6 +96,12 @@ RetrieveAnalyticsQueryParamTagIds = TypeAliasType(
96
96
  r"""The tag IDs to retrieve analytics for."""
97
97
 
98
98
 
99
+ class QueryParamSortBy(str, Enum):
100
+ CLICKS = "clicks"
101
+ LEADS = "leads"
102
+ SALES = "sales"
103
+
104
+
99
105
  class RetrieveAnalyticsRequestTypedDict(TypedDict):
100
106
  event: NotRequired[Event]
101
107
  r"""The type of event to retrieve analytics for. Defaults to `clicks`."""
@@ -157,6 +163,7 @@ class RetrieveAnalyticsRequestTypedDict(TypedDict):
157
163
  r"""Deprecated. Use the `trigger` field instead. Filter for QR code scans. If true, filter for QR codes only. If false, filter for links only. If undefined, return both."""
158
164
  root: NotRequired[bool]
159
165
  r"""Filter for root domains. If true, filter for domains only. If false, filter for links only. If undefined, return both."""
166
+ sort_by: NotRequired[QueryParamSortBy]
160
167
  utm_source: NotRequired[Nullable[str]]
161
168
  r"""The UTM source of the short link."""
162
169
  utm_medium: NotRequired[Nullable[str]]
@@ -361,6 +368,12 @@ class RetrieveAnalyticsRequest(BaseModel):
361
368
  ] = None
362
369
  r"""Filter for root domains. If true, filter for domains only. If false, filter for links only. If undefined, return both."""
363
370
 
371
+ sort_by: Annotated[
372
+ Optional[QueryParamSortBy],
373
+ pydantic.Field(alias="sortBy"),
374
+ FieldMetadata(query=QueryParamMetadata(style="form", explode=True)),
375
+ ] = None
376
+
364
377
  utm_source: Annotated[
365
378
  OptionalNullable[str],
366
379
  FieldMetadata(query=QueryParamMetadata(style="form", explode=True)),
@@ -424,6 +437,7 @@ class RetrieveAnalyticsRequest(BaseModel):
424
437
  "folderId",
425
438
  "qr",
426
439
  "root",
440
+ "sortBy",
427
441
  "utm_source",
428
442
  "utm_medium",
429
443
  "utm_campaign",
@@ -68,6 +68,7 @@ class UpdateCommissionType(str, Enum):
68
68
  CLICK = "click"
69
69
  LEAD = "lead"
70
70
  SALE = "sale"
71
+ CUSTOM = "custom"
71
72
 
72
73
 
73
74
  class UpdateCommissionStatus(str, Enum):
dub/utils/forms.py CHANGED
@@ -86,11 +86,39 @@ def _populate_form(
86
86
  return form
87
87
 
88
88
 
89
+ def _extract_file_properties(file_obj: Any) -> Tuple[str, Any, Any]:
90
+ """Extract file name, content, and content type from a file object."""
91
+ file_fields: Dict[str, FieldInfo] = file_obj.__class__.model_fields
92
+
93
+ file_name = ""
94
+ content = None
95
+ content_type = None
96
+
97
+ for file_field_name in file_fields:
98
+ file_field = file_fields[file_field_name]
99
+
100
+ file_metadata = find_field_metadata(file_field, MultipartFormMetadata)
101
+ if file_metadata is None:
102
+ continue
103
+
104
+ if file_metadata.content:
105
+ content = getattr(file_obj, file_field_name, None)
106
+ elif file_field_name == "content_type":
107
+ content_type = getattr(file_obj, file_field_name, None)
108
+ else:
109
+ file_name = getattr(file_obj, file_field_name)
110
+
111
+ if file_name == "" or content is None:
112
+ raise ValueError("invalid multipart/form-data file")
113
+
114
+ return file_name, content, content_type
115
+
116
+
89
117
  def serialize_multipart_form(
90
118
  media_type: str, request: Any
91
- ) -> Tuple[str, Dict[str, Any], Dict[str, Any]]:
119
+ ) -> Tuple[str, Dict[str, Any], List[Tuple[str, Any]]]:
92
120
  form: Dict[str, Any] = {}
93
- files: Dict[str, Any] = {}
121
+ files: List[Tuple[str, Any]] = []
94
122
 
95
123
  if not isinstance(request, BaseModel):
96
124
  raise TypeError("invalid request body type")
@@ -112,39 +140,32 @@ def serialize_multipart_form(
112
140
  f_name = field.alias if field.alias else name
113
141
 
114
142
  if field_metadata.file:
115
- file_fields: Dict[str, FieldInfo] = val.__class__.model_fields
116
-
117
- file_name = ""
118
- content = None
119
- content_type = None
120
-
121
- for file_field_name in file_fields:
122
- file_field = file_fields[file_field_name]
143
+ if isinstance(val, List):
144
+ # Handle array of files
145
+ for file_obj in val:
146
+ if not _is_set(file_obj):
147
+ continue
148
+
149
+ file_name, content, content_type = _extract_file_properties(file_obj)
123
150
 
124
- file_metadata = find_field_metadata(file_field, MultipartFormMetadata)
125
- if file_metadata is None:
126
- continue
151
+ if content_type is not None:
152
+ files.append((f_name + "[]", (file_name, content, content_type)))
153
+ else:
154
+ files.append((f_name + "[]", (file_name, content)))
155
+ else:
156
+ # Handle single file
157
+ file_name, content, content_type = _extract_file_properties(val)
127
158
 
128
- if file_metadata.content:
129
- content = getattr(val, file_field_name, None)
130
- elif file_field_name == "content_type":
131
- content_type = getattr(val, file_field_name, None)
159
+ if content_type is not None:
160
+ files.append((f_name, (file_name, content, content_type)))
132
161
  else:
133
- file_name = getattr(val, file_field_name)
134
-
135
- if file_name == "" or content is None:
136
- raise ValueError("invalid multipart/form-data file")
137
-
138
- if content_type is not None:
139
- files[f_name] = (file_name, content, content_type)
140
- else:
141
- files[f_name] = (file_name, content)
162
+ files.append((f_name, (file_name, content)))
142
163
  elif field_metadata.json:
143
- files[f_name] = (
164
+ files.append((f_name, (
144
165
  None,
145
166
  marshal_json(val, request_field_types[name]),
146
167
  "application/json",
147
- )
168
+ )))
148
169
  else:
149
170
  if isinstance(val, List):
150
171
  values = []
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: dub
3
- Version: 0.26.6
3
+ Version: 0.26.8
4
4
  Summary: Python Client SDK Generated by Speakeasy
5
5
  Author: Speakeasy
6
6
  Requires-Python: >=3.9.2
@@ -3,7 +3,7 @@ dub/_hooks/__init__.py,sha256=9_7W5jAYw8rcO8Kfc-Ty-lB82BHfksAJJpVFb_UeU1c,146
3
3
  dub/_hooks/registration.py,sha256=tT-1Cjp5ax1DL-84HBNWPy4wAwgP-0aI4-asLfnkIlw,625
4
4
  dub/_hooks/sdkhooks.py,sha256=2rLEjSz1xFGWabNs1voFn0lXSCqkS38bdKVFdnBJufE,2553
5
5
  dub/_hooks/types.py,sha256=5vcNbFBNpCxqI7ZebiBtut7T_Gz2i36L5MjTqGvxV7Y,3035
6
- dub/_version.py,sha256=0JMPZI3Qq3DbHnG_Sm_a98G4NBIRHcyvGvuXPy07pvQ,450
6
+ dub/_version.py,sha256=juzPjHDfwC-l2lfWrk3VSzNjbCtbs_5ASh4Lmx_Afmk,450
7
7
  dub/analytics.py,sha256=acVdNv1hS7JDmBS1ena0kG-RNNq64lRZwOV6_2FZn60,13032
8
8
  dub/basesdk.py,sha256=nY5yee9uE5SQHkG_9Di9MUoQR0KcPr-WrtTCDHUdRnY,11779
9
9
  dub/commissions.py,sha256=H56AkD5M03FuXaIdsd5jY6rWZ7qa8c0gssXQhLkF634,25796
@@ -63,7 +63,7 @@ dub/models/errors/ratelimitexceeded.py,sha256=0S2eQlQMdVQ8BZYXX59AQZkf5HtexijmQn
63
63
  dub/models/errors/sdkerror.py,sha256=kd75e3JYF2TXNgRZopcV-oGdBWoBZqRcvrwqn2fsFYs,528
64
64
  dub/models/errors/unauthorized.py,sha256=ranMcawvM0oJxxVkShfZsc7V5YYjbz9luhHywE_ObIg,1525
65
65
  dub/models/errors/unprocessableentity.py,sha256=TxgP43hrqcBW-UDMo8yJ7B0_o_skIH_dXw3DfEWG_cY,1515
66
- dub/models/operations/__init__.py,sha256=qQXnwHCbeVw_tQxL3vIkJrD5QPLwPwdLhX94nFQxjYc,39411
66
+ dub/models/operations/__init__.py,sha256=Ya0H4YzB64rwnD5r7si2Itp7yWX3E3sA0IiZx5l7Hn8,39537
67
67
  dub/models/operations/bulkcreatelinks.py,sha256=RSPHaN565k4ds9IHceoYkxtysezKiSBIE2N6jn7cop4,17416
68
68
  dub/models/operations/bulkdeletelinks.py,sha256=u_hEFC9TZ1UnGGgLhQ-Mf3HNDO98Ur49MtdBnNVIRsE,1151
69
69
  dub/models/operations/bulkupdatelinks.py,sha256=qo5t0RnwzxpdQnz5IivH9plgjMaJAX0i7gXJHmCck_M,15972
@@ -89,17 +89,17 @@ dub/models/operations/getlinkscount.py,sha256=KvD0gh-Imn1WmiiRAIYUXHBoNNGEnmfBQX
89
89
  dub/models/operations/getqrcode.py,sha256=ynCPJc8vy_QEt5FP8OU2s-u6UIt1BhmFSNZC-XPmO4I,3848
90
90
  dub/models/operations/gettags.py,sha256=c9p_JrHFnTDJURyR5iiKFKpXFHlzJDt3R5X1U-anyYg,2664
91
91
  dub/models/operations/getworkspace.py,sha256=V4-NfsEg3M1BTeoE13sDyazefb2_kI4yFxnzgvHPv4s,625
92
- dub/models/operations/listcommissions.py,sha256=6bP8Hc5kwoMi--nCSIaMgDipwUnin47qRV11vEkpQks,7995
92
+ dub/models/operations/listcommissions.py,sha256=LNb0OGeSGt4fFIfDBZLmLqtMmMDbT2fq-Bd_hbMqONg,8039
93
93
  dub/models/operations/listdomains.py,sha256=gbQrJyBIvTGKSeqJo0Jb08iE44Xu39NS9zbfetx4p-s,1936
94
- dub/models/operations/listevents.py,sha256=AwnXpTWOhhZ_er9FZukptf1U2dD52j-xQtvop9k-J7g,17943
94
+ dub/models/operations/listevents.py,sha256=D4dNL0KmL5XbJqPVPLOZZuMDuZ5E47qZJsTTxGMMBeY,17983
95
95
  dub/models/operations/listfolders.py,sha256=5FGf62ZTjquVXjq5axlzQgYGfEnrEwDn8QLlgGH_7jQ,1209
96
96
  dub/models/operations/registerdomain.py,sha256=fjozn1tFU-cNarHdAqN_flQoGAE498ob-f4A2bIAiOc,2058
97
- dub/models/operations/retrieveanalytics.py,sha256=ITNmlEK_ifUwK-opXAIrdjnpZQBW8DK_OgpzNHkfcY8,19211
97
+ dub/models/operations/retrieveanalytics.py,sha256=Qol10DdnH79YTiR_OW1uz962xR0QIeuB7Qu1Va4yTIU,19566
98
98
  dub/models/operations/retrievelinks.py,sha256=1bLrT_Q2y60eU_gdOHTu99VW8c09gX3nkidb0R5qLuk,2988
99
99
  dub/models/operations/retrievepartneranalytics.py,sha256=MmBDRCB5lQ1lKkfHpeMnZcQXkKIjSCVGEUVcvJgZ_Io,5275
100
100
  dub/models/operations/tracklead.py,sha256=FxdbxL9r3PF0eqo4aOcGXCS7EERq11x07NEdPDkqeps,6855
101
101
  dub/models/operations/tracksale.py,sha256=q_IL4dHay_dDTmRYH80zI6JphCyk46yHoLHBFEJEILg,8189
102
- dub/models/operations/updatecommission.py,sha256=wXdqGWEKobCJEJpgeAYhnjPfE7641jJFarIAtwaEKBU,5452
102
+ dub/models/operations/updatecommission.py,sha256=q5Ifb9Zms429lr2MgORkdPG6FEfHz2jmByG_kAGy8Dg,5474
103
103
  dub/models/operations/updatecustomer.py,sha256=xlW-W99WgdlAsKD4fNhIEw3f1Sipnb4ahPnZFOcisSY,13517
104
104
  dub/models/operations/updatedomain.py,sha256=rexCga7uNxgBZLPiCMcaudc2cQGB0E_qX2HI0DgG_3M,4519
105
105
  dub/models/operations/updatefolder.py,sha256=dNvSPY67g58SWynB8ic5rcgT-h7THRmyxuzuFdO42GQ,2581
@@ -122,7 +122,7 @@ dub/utils/annotations.py,sha256=aR7mZG34FzgRdew7WZPYEu9QGBerpuKxCF4sek5Z_5Y,1699
122
122
  dub/utils/datetimes.py,sha256=oppAA5e3V35pQov1-FNLKxAaNF1_XWi-bQtyjjql3H8,855
123
123
  dub/utils/enums.py,sha256=REU6ydF8gsVL3xaeGX4sMNyiL3q5P9h29-f6Sa6luAE,2633
124
124
  dub/utils/eventstreaming.py,sha256=LtcrfJYw4nP2Oe4Wl0-cEURLzRGYReRGWNFY5wYECIE,6186
125
- dub/utils/forms.py,sha256=YSSijXrsM2nfrRHlPQejh1uRRKfoILomHL3d9xpJiy8,6058
125
+ dub/utils/forms.py,sha256=EJdnrfIkuwpDtekyHutla0HjI_FypTYcmYNyPKEu_W0,6874
126
126
  dub/utils/headers.py,sha256=cPxWSmUILrefTGDzTH1Hdj7_Hlsj-EY6K5Tyc4iH4dk,3663
127
127
  dub/utils/logger.py,sha256=9nUtlKHo3RFsIVyMw5jq3wEKZMVwHnZMSc6xLp-otC0,520
128
128
  dub/utils/metadata.py,sha256=Per2KFXXOqOtoUWXrlIfjrSrBg199KrRW0nKQDgHIBU,3136
@@ -134,7 +134,7 @@ dub/utils/serializers.py,sha256=hiHBXM1AY8_N2Z_rvFfNSYwvLBkSQlPGFp8poasdU4s,5986
134
134
  dub/utils/url.py,sha256=BgGPgcTA6MRK4bF8fjP2dUopN3NzEzxWMXPBVg8NQUA,5254
135
135
  dub/utils/values.py,sha256=CcaCXEa3xHhkUDROyXZocN8f0bdITftv9Y0P9lTf0YM,3517
136
136
  dub/workspaces.py,sha256=_4KOZwwL0KADDqSrHZWfO7LpEwLi59uvaKm-X7JzAv0,25823
137
- dub-0.26.6.dist-info/LICENSE,sha256=kc_aZ6YHHcdSsRy-mGsT0Ehji0ZgR_zevXiUt05V2KY,1079
138
- dub-0.26.6.dist-info/METADATA,sha256=15YlQmTzUIKT4Y97z7pr664t44NSZ3VxsSwNUyjgMd0,28075
139
- dub-0.26.6.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
140
- dub-0.26.6.dist-info/RECORD,,
137
+ dub-0.26.8.dist-info/LICENSE,sha256=kc_aZ6YHHcdSsRy-mGsT0Ehji0ZgR_zevXiUt05V2KY,1079
138
+ dub-0.26.8.dist-info/METADATA,sha256=JiiBi3zPu6OFmQ52a3rDJhIzfsPZmyUgtfB0KIqDMAE,28075
139
+ dub-0.26.8.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
140
+ dub-0.26.8.dist-info/RECORD,,
File without changes
File without changes