airbyte-agent-shopify 0.1.16__py3-none-any.whl → 0.1.18__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.
@@ -14,9 +14,9 @@ from .models import (
14
14
  MarketingConsent,
15
15
  OrderAddress,
16
16
  LineItem,
17
- Fulfillment,
18
17
  Transaction,
19
18
  Refund,
19
+ Fulfillment,
20
20
  Order,
21
21
  OrderList,
22
22
  ProductVariant,
@@ -187,9 +187,9 @@ __all__ = [
187
187
  "MarketingConsent",
188
188
  "OrderAddress",
189
189
  "LineItem",
190
- "Fulfillment",
191
190
  "Transaction",
192
191
  "Refund",
192
+ "Fulfillment",
193
193
  "Order",
194
194
  "OrderList",
195
195
  "ProductVariant",
@@ -380,7 +380,11 @@ def describe_entities(model: ConnectorModelProtocol) -> list[dict[str, Any]]:
380
380
  return entities
381
381
 
382
382
 
383
- def generate_tool_description(model: ConnectorModelProtocol) -> str:
383
+ def generate_tool_description(
384
+ model: ConnectorModelProtocol,
385
+ *,
386
+ enable_hosted_mode_features: bool = True,
387
+ ) -> str:
384
388
  """Generate AI tool description from connector metadata.
385
389
 
386
390
  Produces a detailed description that includes:
@@ -393,6 +397,7 @@ def generate_tool_description(model: ConnectorModelProtocol) -> str:
393
397
 
394
398
  Args:
395
399
  model: Object conforming to ConnectorModelProtocol (e.g., ConnectorModel)
400
+ enable_hosted_mode_features: When False, omit hosted-mode search guidance from the docstring.
396
401
 
397
402
  Returns:
398
403
  Formatted description string suitable for AI tool documentation
@@ -402,8 +407,9 @@ def generate_tool_description(model: ConnectorModelProtocol) -> str:
402
407
  # at the first empty line and only keeps the initial section.
403
408
 
404
409
  # Entity/action parameter details (including pagination params like limit, starting_after)
405
- search_field_paths = _collect_search_field_paths(model)
406
- lines.append("ENTITIES AND PARAMETERS:")
410
+ search_field_paths = _collect_search_field_paths(model) if enable_hosted_mode_features else {}
411
+ # Avoid a "PARAMETERS:" header because some docstring parsers treat it as a params section marker.
412
+ lines.append("ENTITIES (ACTIONS + PARAMS):")
407
413
  for entity in model.entities:
408
414
  lines.append(f" {entity.name}:")
409
415
  actions = getattr(entity, "actions", []) or []
@@ -427,8 +433,9 @@ def generate_tool_description(model: ConnectorModelProtocol) -> str:
427
433
  lines.append(" To paginate: pass starting_after=<last_id> while has_more is true")
428
434
 
429
435
  lines.append("GUIDELINES:")
430
- lines.append(' - Prefer cached search over direct API calls when using execute(): action="search" whenever possible.')
431
- lines.append(" - Direct API actions (list/get/download) are slower and should be used only if search cannot answer the query.")
436
+ if enable_hosted_mode_features:
437
+ lines.append(' - Prefer cached search over direct API calls when using execute(): action="search" whenever possible.')
438
+ lines.append(" - Direct API actions (list/get/download) are slower and should be used only if search cannot answer the query.")
432
439
  lines.append(" - Keep results small: use params.fields, params.query.filter, small params.limit, and cursor pagination.")
433
440
  lines.append(" - If output is too large, refine the query with tighter filters/fields/limit.")
434
441
 
@@ -908,6 +908,7 @@ class ShopifyConnector:
908
908
  func: _F | None = None,
909
909
  *,
910
910
  update_docstring: bool = True,
911
+ enable_hosted_mode_features: bool = True,
911
912
  max_output_chars: int | None = DEFAULT_MAX_OUTPUT_CHARS,
912
913
  ) -> _F | Callable[[_F], _F]:
913
914
  """
@@ -926,12 +927,16 @@ class ShopifyConnector:
926
927
 
927
928
  Args:
928
929
  update_docstring: When True, append connector capabilities to __doc__.
930
+ enable_hosted_mode_features: When False, omit hosted-mode search sections from docstrings.
929
931
  max_output_chars: Max serialized output size before raising. Use None to disable.
930
932
  """
931
933
 
932
934
  def decorate(inner: _F) -> _F:
933
935
  if update_docstring:
934
- description = generate_tool_description(ShopifyConnectorModel)
936
+ description = generate_tool_description(
937
+ ShopifyConnectorModel,
938
+ enable_hosted_mode_features=enable_hosted_mode_features,
939
+ )
935
940
  original_doc = inner.__doc__ or ""
936
941
  if original_doc.strip():
937
942
  full_doc = f"{original_doc.strip()}\n{description}"
@@ -153,29 +153,6 @@ class LineItem(BaseModel):
153
153
  duties: Union[list[dict[str, Any]] | None, Any] = Field(default=None)
154
154
  discount_allocations: Union[list[dict[str, Any]] | None, Any] = Field(default=None)
155
155
 
156
- class Fulfillment(BaseModel):
157
- """A fulfillment"""
158
- model_config = ConfigDict(extra="allow", populate_by_name=True)
159
-
160
- id: Union[int, Any] = Field(default=None)
161
- order_id: Union[int | None, Any] = Field(default=None)
162
- status: Union[str | None, Any] = Field(default=None)
163
- created_at: Union[str | None, Any] = Field(default=None)
164
- service: Union[str | None, Any] = Field(default=None)
165
- updated_at: Union[str | None, Any] = Field(default=None)
166
- tracking_company: Union[str | None, Any] = Field(default=None)
167
- shipment_status: Union[str | None, Any] = Field(default=None)
168
- location_id: Union[int | None, Any] = Field(default=None)
169
- origin_address: Union[dict[str, Any] | None, Any] = Field(default=None)
170
- line_items: Union[list[LineItem] | None, Any] = Field(default=None)
171
- tracking_number: Union[str | None, Any] = Field(default=None)
172
- tracking_numbers: Union[list[str] | None, Any] = Field(default=None)
173
- tracking_url: Union[str | None, Any] = Field(default=None)
174
- tracking_urls: Union[list[str] | None, Any] = Field(default=None)
175
- receipt: Union[dict[str, Any] | None, Any] = Field(default=None)
176
- name: Union[str | None, Any] = Field(default=None)
177
- admin_graphql_api_id: Union[str | None, Any] = Field(default=None)
178
-
179
156
  class Transaction(BaseModel):
180
157
  """An order transaction"""
181
158
  model_config = ConfigDict(extra="allow", populate_by_name=True)
@@ -225,6 +202,29 @@ class Refund(BaseModel):
225
202
  admin_graphql_api_id: Union[str | None, Any] = Field(default=None)
226
203
  refund_shipping_lines: Union[list[dict[str, Any]] | None, Any] = Field(default=None)
227
204
 
205
+ class Fulfillment(BaseModel):
206
+ """A fulfillment"""
207
+ model_config = ConfigDict(extra="allow", populate_by_name=True)
208
+
209
+ id: Union[int, Any] = Field(default=None)
210
+ order_id: Union[int | None, Any] = Field(default=None)
211
+ status: Union[str | None, Any] = Field(default=None)
212
+ created_at: Union[str | None, Any] = Field(default=None)
213
+ service: Union[str | None, Any] = Field(default=None)
214
+ updated_at: Union[str | None, Any] = Field(default=None)
215
+ tracking_company: Union[str | None, Any] = Field(default=None)
216
+ shipment_status: Union[str | None, Any] = Field(default=None)
217
+ location_id: Union[int | None, Any] = Field(default=None)
218
+ origin_address: Union[dict[str, Any] | None, Any] = Field(default=None)
219
+ line_items: Union[list[LineItem] | None, Any] = Field(default=None)
220
+ tracking_number: Union[str | None, Any] = Field(default=None)
221
+ tracking_numbers: Union[list[str] | None, Any] = Field(default=None)
222
+ tracking_url: Union[str | None, Any] = Field(default=None)
223
+ tracking_urls: Union[list[str] | None, Any] = Field(default=None)
224
+ receipt: Union[dict[str, Any] | None, Any] = Field(default=None)
225
+ name: Union[str | None, Any] = Field(default=None)
226
+ admin_graphql_api_id: Union[str | None, Any] = Field(default=None)
227
+
228
228
  class Order(BaseModel):
229
229
  """A Shopify order"""
230
230
  model_config = ConfigDict(extra="allow", populate_by_name=True)
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: airbyte-agent-shopify
3
- Version: 0.1.16
3
+ Version: 0.1.18
4
4
  Summary: Airbyte Shopify Connector for AI platforms
5
5
  Project-URL: Homepage, https://github.com/airbytehq/airbyte-agent-connectors
6
6
  Project-URL: Documentation, https://docs.airbyte.com/ai-agents/
@@ -119,10 +119,11 @@ async def shopify_execute(entity: str, action: str, params: dict | None = None):
119
119
  return await connector.execute(entity, action, params or {})
120
120
  ```
121
121
 
122
-
123
122
  ## Full documentation
124
123
 
125
- This connector supports the following entities and actions.
124
+ ### Entities and actions
125
+
126
+ This connector supports the following entities and actions. For more details, see this connector's [full reference documentation](REFERENCE.md).
126
127
 
127
128
  | Entity | Actions |
128
129
  |--------|---------|
@@ -160,14 +161,16 @@ This connector supports the following entities and actions.
160
161
  | Fulfillment Orders | [List](./REFERENCE.md#fulfillment-orders-list), [Get](./REFERENCE.md#fulfillment-orders-get) |
161
162
 
162
163
 
163
- For all authentication options, see the connector's [authentication documentation](AUTH.md).
164
+ ### Authentication and configuration
165
+
166
+ For all authentication and configuration options, see the connector's [authentication documentation](AUTH.md).
164
167
 
165
- For detailed documentation on available actions and parameters, see this connector's [full reference documentation](./REFERENCE.md).
168
+ ### Shopify API docs
166
169
 
167
- For the service's official API docs, see the [Shopify API reference](https://shopify.dev/docs/api/admin-rest).
170
+ See the official [Shopify API reference](https://shopify.dev/docs/api/admin-rest).
168
171
 
169
172
  ## Version information
170
173
 
171
- - **Package version:** 0.1.16
174
+ - **Package version:** 0.1.18
172
175
  - **Connector version:** 0.1.2
173
- - **Generated with Connector SDK commit SHA:** 71f48c102ce98c9298e5102761e740f0d97eb71b
176
+ - **Generated with Connector SDK commit SHA:** 97007bbdad3a6ac982ee2c0cdd667acdb5c12d3c
@@ -1,7 +1,7 @@
1
- airbyte_agent_shopify/__init__.py,sha256=uFn4x1bUldfWTPBITTIGYrjD5bRufgEVvKVviDOUd_0,9661
2
- airbyte_agent_shopify/connector.py,sha256=uDA7DNbgXNQQ94sp2Kinq2Rgu2FgBZEWzbgKTLEteZM,93793
1
+ airbyte_agent_shopify/__init__.py,sha256=SorpgqhXmkY-bs1JXRCnWPmshvaKFpjvzY8KEeiZpNo,9661
2
+ airbyte_agent_shopify/connector.py,sha256=fnlv35f3Vg0ktwdeegm7OKldNrI7yJPPg7DC1Y0qkFU,94062
3
3
  airbyte_agent_shopify/connector_model.py,sha256=AVa7n--wns14y5tdsiKymVUMS7HboqVD8sdzvKPlBRM,691010
4
- airbyte_agent_shopify/models.py,sha256=hBMmLBLBlmqU8TdcJGpm3fQyyDVP3BEpDJ5C2cInBso,60917
4
+ airbyte_agent_shopify/models.py,sha256=3lpgsHJsVc8Oo63qb5sloQrikb9fJ9vkxswB8mUCbPc,60917
5
5
  airbyte_agent_shopify/types.py,sha256=AwQ4PR2wZmHNuryriCFdRxf9q48J1mnPwspUB1b-L_o,10221
6
6
  airbyte_agent_shopify/_vendored/__init__.py,sha256=ILl7AHXMui__swyrjxrh9yRa4dLiwBvV6axPWFWty80,38
7
7
  airbyte_agent_shopify/_vendored/connector_sdk/__init__.py,sha256=T5o7roU6NSpH-lCAGZ338sE5dlh4ZU6i6IkeG1zpems,1949
@@ -12,7 +12,7 @@ airbyte_agent_shopify/_vendored/connector_sdk/constants.py,sha256=AtzOvhDMWbRJgp
12
12
  airbyte_agent_shopify/_vendored/connector_sdk/exceptions.py,sha256=ss5MGv9eVPmsbLcLWetuu3sDmvturwfo6Pw3M37Oq5k,481
13
13
  airbyte_agent_shopify/_vendored/connector_sdk/extensions.py,sha256=XWRRoJOOrwUHSKbuQt5DU7CCu8ePzhd_HuP7c_uD77w,21376
14
14
  airbyte_agent_shopify/_vendored/connector_sdk/http_client.py,sha256=09Fclbq4wrg38EM2Yh2kHiykQVXqdAGby024elcEz8E,28027
15
- airbyte_agent_shopify/_vendored/connector_sdk/introspection.py,sha256=kRVI4TDQDLdcCnTBUML8ycAtdqAQufVh-027sMkb4i8,19165
15
+ airbyte_agent_shopify/_vendored/connector_sdk/introspection.py,sha256=e9uWn2ofpeehoBbzNgts_bjlKLn8ayA1Y3OpDC3b7ZA,19517
16
16
  airbyte_agent_shopify/_vendored/connector_sdk/secrets.py,sha256=J9ezMu4xNnLW11xY5RCre6DHP7YMKZCqwGJfk7ufHAM,6855
17
17
  airbyte_agent_shopify/_vendored/connector_sdk/types.py,sha256=in8gHsn5nsScujOfHZmkOgNmqmJKiPyNNjg59m5fGWc,8807
18
18
  airbyte_agent_shopify/_vendored/connector_sdk/utils.py,sha256=G4LUXOC2HzPoND2v4tQW68R9uuPX9NQyCjaGxb7Kpl0,1958
@@ -52,6 +52,6 @@ airbyte_agent_shopify/_vendored/connector_sdk/telemetry/__init__.py,sha256=RaLgk
52
52
  airbyte_agent_shopify/_vendored/connector_sdk/telemetry/config.py,sha256=tLmQwAFD0kP1WyBGWBS3ysaudN9H3e-3EopKZi6cGKg,885
53
53
  airbyte_agent_shopify/_vendored/connector_sdk/telemetry/events.py,sha256=8Y1NbXiwISX-V_wRofY7PqcwEXD0dLMnntKkY6XFU2s,1328
54
54
  airbyte_agent_shopify/_vendored/connector_sdk/telemetry/tracker.py,sha256=Ftrk0_ddfM7dZG8hF9xBuPwhbc9D6JZ7Q9qs5o3LEyA,5579
55
- airbyte_agent_shopify-0.1.16.dist-info/METADATA,sha256=vzGjdAedaMX_-w0h9_jQ-v5AUi21PZgAwyFf1OIAvYI,7842
56
- airbyte_agent_shopify-0.1.16.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
57
- airbyte_agent_shopify-0.1.16.dist-info/RECORD,,
55
+ airbyte_agent_shopify-0.1.18.dist-info/METADATA,sha256=CKnvFGf-Jtlh3lDD2bJ-j21-Z9k4PGPxsGm7o3709aY,7868
56
+ airbyte_agent_shopify-0.1.18.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
57
+ airbyte_agent_shopify-0.1.18.dist-info/RECORD,,