airbyte-agent-slack 0.1.1__py3-none-any.whl → 0.1.2__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.
@@ -18,8 +18,8 @@ from .models import (
18
18
  ChannelsListResponse,
19
19
  ChannelResponse,
20
20
  Reaction,
21
- File,
22
21
  Attachment,
22
+ File,
23
23
  Message,
24
24
  Thread,
25
25
  EditedInfo,
@@ -60,8 +60,8 @@ __all__ = [
60
60
  "ChannelsListResponse",
61
61
  "ChannelResponse",
62
62
  "Reaction",
63
- "File",
64
63
  "Attachment",
64
+ "File",
65
65
  "Message",
66
66
  "Thread",
67
67
  "EditedInfo",
@@ -519,13 +519,14 @@ def _parse_oauth2_config(scheme: Any) -> dict[str, str]:
519
519
  config["refresh_url"] = refresh_url
520
520
 
521
521
  # Extract custom refresh configuration from x-airbyte-token-refresh extension
522
+ # Note: x_token_refresh is a Dict[str, Any], not a Pydantic model, so use .get()
522
523
  x_token_refresh = getattr(scheme, "x_token_refresh", None)
523
524
  if x_token_refresh:
524
- auth_style = getattr(x_token_refresh, "auth_style", None)
525
+ auth_style = x_token_refresh.get("auth_style")
525
526
  if auth_style:
526
527
  config["auth_style"] = auth_style
527
528
 
528
- body_format = getattr(x_token_refresh, "body_format", None)
529
+ body_format = x_token_refresh.get("body_format")
529
530
  if body_format:
530
531
  config["body_format"] = body_format
531
532
 
@@ -152,6 +152,7 @@ class Server(BaseModel):
152
152
  url: str
153
153
  description: str | None = None
154
154
  variables: Dict[str, ServerVariable] = Field(default_factory=dict)
155
+ x_airbyte_replication_user_config_mapping: Dict[str, str] | None = Field(default=None, alias="x-airbyte-replication-user-config-mapping")
155
156
 
156
157
  @field_validator("url")
157
158
  @classmethod
@@ -109,6 +109,30 @@ class RetryConfig(BaseModel):
109
109
  retry_after_format: Literal["seconds", "milliseconds", "unix_timestamp"] = "seconds"
110
110
 
111
111
 
112
+ class CacheFieldProperty(BaseModel):
113
+ """
114
+ Nested property definition for object-type cache fields.
115
+
116
+ Supports recursive nesting to represent complex nested schemas in cache field definitions.
117
+ Used when a cache field has type 'object' and needs to define its internal structure.
118
+
119
+ Example YAML usage:
120
+ - name: collaboration
121
+ type: ['null', 'object']
122
+ description: "Collaboration data"
123
+ properties:
124
+ brief:
125
+ type: ['null', 'string']
126
+ comments:
127
+ type: ['null', 'array']
128
+ """
129
+
130
+ model_config = ConfigDict(populate_by_name=True, extra="forbid")
131
+
132
+ type: str | list[str]
133
+ properties: dict[str, "CacheFieldProperty"] | None = None
134
+
135
+
112
136
  class CacheFieldConfig(BaseModel):
113
137
  """
114
138
  Field configuration for cache mapping.
@@ -116,6 +140,9 @@ class CacheFieldConfig(BaseModel):
116
140
  Defines a single field in a cache entity, with optional name aliasing
117
141
  to map between user-facing field names and cache storage names.
118
142
 
143
+ For object-type fields, supports nested properties to define the internal structure
144
+ of complex nested schemas.
145
+
119
146
  Used in x-airbyte-cache extension for api_search operations.
120
147
  """
121
148
 
@@ -125,6 +152,7 @@ class CacheFieldConfig(BaseModel):
125
152
  x_airbyte_name: str | None = Field(default=None, alias="x-airbyte-name")
126
153
  type: str | list[str]
127
154
  description: str
155
+ properties: dict[str, CacheFieldProperty] | None = None
128
156
 
129
157
  @property
130
158
  def cache_name(self) -> str:
@@ -184,6 +184,27 @@ class Reaction(BaseModel):
184
184
  users: Union[list[str] | None, Any] = Field(default=None)
185
185
  count: Union[int | None, Any] = Field(default=None)
186
186
 
187
+ class Attachment(BaseModel):
188
+ """Message attachment"""
189
+ model_config = ConfigDict(extra="allow", populate_by_name=True)
190
+
191
+ id: Union[int | None, Any] = Field(default=None)
192
+ fallback: Union[str | None, Any] = Field(default=None)
193
+ color: Union[str | None, Any] = Field(default=None)
194
+ pretext: Union[str | None, Any] = Field(default=None)
195
+ author_name: Union[str | None, Any] = Field(default=None)
196
+ author_link: Union[str | None, Any] = Field(default=None)
197
+ author_icon: Union[str | None, Any] = Field(default=None)
198
+ title: Union[str | None, Any] = Field(default=None)
199
+ title_link: Union[str | None, Any] = Field(default=None)
200
+ text: Union[str | None, Any] = Field(default=None)
201
+ fields: Union[list[dict[str, Any]] | None, Any] = Field(default=None)
202
+ image_url: Union[str | None, Any] = Field(default=None)
203
+ thumb_url: Union[str | None, Any] = Field(default=None)
204
+ footer: Union[str | None, Any] = Field(default=None)
205
+ footer_icon: Union[str | None, Any] = Field(default=None)
206
+ ts: Union[Any, Any] = Field(default=None)
207
+
187
208
  class File(BaseModel):
188
209
  """File object"""
189
210
  model_config = ConfigDict(extra="allow", populate_by_name=True)
@@ -208,27 +229,6 @@ class File(BaseModel):
208
229
  created: Union[int | None, Any] = Field(default=None)
209
230
  timestamp: Union[int | None, Any] = Field(default=None)
210
231
 
211
- class Attachment(BaseModel):
212
- """Message attachment"""
213
- model_config = ConfigDict(extra="allow", populate_by_name=True)
214
-
215
- id: Union[int | None, Any] = Field(default=None)
216
- fallback: Union[str | None, Any] = Field(default=None)
217
- color: Union[str | None, Any] = Field(default=None)
218
- pretext: Union[str | None, Any] = Field(default=None)
219
- author_name: Union[str | None, Any] = Field(default=None)
220
- author_link: Union[str | None, Any] = Field(default=None)
221
- author_icon: Union[str | None, Any] = Field(default=None)
222
- title: Union[str | None, Any] = Field(default=None)
223
- title_link: Union[str | None, Any] = Field(default=None)
224
- text: Union[str | None, Any] = Field(default=None)
225
- fields: Union[list[dict[str, Any]] | None, Any] = Field(default=None)
226
- image_url: Union[str | None, Any] = Field(default=None)
227
- thumb_url: Union[str | None, Any] = Field(default=None)
228
- footer: Union[str | None, Any] = Field(default=None)
229
- footer_icon: Union[str | None, Any] = Field(default=None)
230
- ts: Union[Any, Any] = Field(default=None)
231
-
232
232
  class Message(BaseModel):
233
233
  """Slack message object"""
234
234
  model_config = ConfigDict(extra="allow", populate_by_name=True)
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: airbyte-agent-slack
3
- Version: 0.1.1
3
+ Version: 0.1.2
4
4
  Summary: Airbyte Slack 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/
@@ -123,6 +123,6 @@ For the service's official API docs, see the [Slack API reference](https://api.s
123
123
 
124
124
  ## Version information
125
125
 
126
- - **Package version:** 0.1.1
126
+ - **Package version:** 0.1.2
127
127
  - **Connector version:** 0.1.1
128
- - **Generated with Connector SDK commit SHA:** 3521119342fc2a44fcae909505ffb1e7b75557eb
128
+ - **Generated with Connector SDK commit SHA:** 61a2e8229a38f13564ef2f85e276dff02f707573
@@ -1,13 +1,13 @@
1
- airbyte_agent_slack/__init__.py,sha256=8GPXkTAiah-N_W7LUw8lX7pP6CntIgjwVizrL4VfqiE,1827
1
+ airbyte_agent_slack/__init__.py,sha256=tODFTz4328M40qrpjD8py7VUMPAgvyCS99SERNkZ2c4,1827
2
2
  airbyte_agent_slack/connector.py,sha256=5U0F8qNoT7UDS6MZ0_BidNt7p1wI73YKNqUxMlZZ-Po,20012
3
3
  airbyte_agent_slack/connector_model.py,sha256=4s3vSwHde2emQI_kkIhL8JMkQoJlFqUbFKDU6dGUqD8,126566
4
- airbyte_agent_slack/models.py,sha256=Fx1Apb4TVuba_lo_CjpgnVikq3efWrWbGBfZmak9Esk,17688
4
+ airbyte_agent_slack/models.py,sha256=vyc_sR8j4nVYAZlLXmA-9s1vd4yFWB_i-uAJUNQRBzw,17688
5
5
  airbyte_agent_slack/types.py,sha256=0B5u0udAnf6wxK8nUpzgk1opmO8dkIaOupJBltqXsVs,1550
6
6
  airbyte_agent_slack/_vendored/__init__.py,sha256=ILl7AHXMui__swyrjxrh9yRa4dLiwBvV6axPWFWty80,38
7
7
  airbyte_agent_slack/_vendored/connector_sdk/__init__.py,sha256=T5o7roU6NSpH-lCAGZ338sE5dlh4ZU6i6IkeG1zpems,1949
8
8
  airbyte_agent_slack/_vendored/connector_sdk/auth_strategies.py,sha256=BdjAzFRTwXCmLFqYWqZ4Dx9RsqtI7pAkw-8NynSK4sQ,39914
9
9
  airbyte_agent_slack/_vendored/connector_sdk/auth_template.py,sha256=nju4jqlFC_KI82ILNumNIyiUtRJcy7J94INIZ0QraI4,4454
10
- airbyte_agent_slack/_vendored/connector_sdk/connector_model_loader.py,sha256=Cx9wPhKwWfzkc8i63IevL0EsN3iWUl_OA-_jA9EKNcE,34877
10
+ airbyte_agent_slack/_vendored/connector_sdk/connector_model_loader.py,sha256=b88aoMynHxtG2dhzclkWrLiJbefTiKMzReyj3lOiwJI,34940
11
11
  airbyte_agent_slack/_vendored/connector_sdk/constants.py,sha256=AtzOvhDMWbRJgpsQNWl5tkogHD6mWgEY668PgRmgtOY,2737
12
12
  airbyte_agent_slack/_vendored/connector_sdk/exceptions.py,sha256=ss5MGv9eVPmsbLcLWetuu3sDmvturwfo6Pw3M37Oq5k,481
13
13
  airbyte_agent_slack/_vendored/connector_sdk/extensions.py,sha256=XWRRoJOOrwUHSKbuQt5DU7CCu8ePzhd_HuP7c_uD77w,21376
@@ -42,16 +42,16 @@ airbyte_agent_slack/_vendored/connector_sdk/performance/__init__.py,sha256=Sp5fS
42
42
  airbyte_agent_slack/_vendored/connector_sdk/performance/instrumentation.py,sha256=_dXvNiqdndIBwDjeDKNViWzn_M5FkSUsMmJtFldrmsM,1504
43
43
  airbyte_agent_slack/_vendored/connector_sdk/performance/metrics.py,sha256=FRff7dKt4iwt_A7pxV5n9kAGBR756PC7q8-weWygPSM,2817
44
44
  airbyte_agent_slack/_vendored/connector_sdk/schema/__init__.py,sha256=Uymu-QuzGJuMxexBagIvUxpVAigIuIhz3KeBl_Vu4Ko,1638
45
- airbyte_agent_slack/_vendored/connector_sdk/schema/base.py,sha256=RcsVLrO0L57g4kWfpDWjfc9gelvecplmoy43Zi-7GEY,4944
45
+ airbyte_agent_slack/_vendored/connector_sdk/schema/base.py,sha256=4RYTkCWgyS5Z75z9TKj9vXySfO00HJ03QDtbdVYeHYM,5086
46
46
  airbyte_agent_slack/_vendored/connector_sdk/schema/components.py,sha256=x3YCM1p2n_xHi50fMeOX0mXUiPqjGlLHs3Go8jXokb0,7895
47
47
  airbyte_agent_slack/_vendored/connector_sdk/schema/connector.py,sha256=mSZk1wr2YSdRj9tTRsPAuIlCzd_xZLw-Bzl1sMwE0rE,3731
48
- airbyte_agent_slack/_vendored/connector_sdk/schema/extensions.py,sha256=U2sOTEXVi3DV6bIvbZPA0WUl5_vLuS_IzaDXQAJ4O14,6220
48
+ airbyte_agent_slack/_vendored/connector_sdk/schema/extensions.py,sha256=f7VhHrcIYxaPOJHMc4g0lpy04pZTbx5nlroNzAu5B9Q,7135
49
49
  airbyte_agent_slack/_vendored/connector_sdk/schema/operations.py,sha256=RpzGtAI4yvAtMHAfMUMcUwgHv_qJojnKlNb75_agUF8,5729
50
50
  airbyte_agent_slack/_vendored/connector_sdk/schema/security.py,sha256=zQ9RRuF3LBgLQi_4cItmjXbG_5WKlmCNM3nCil30H90,8470
51
51
  airbyte_agent_slack/_vendored/connector_sdk/telemetry/__init__.py,sha256=RaLgkBU4dfxn1LC5Y0Q9rr2PJbrwjxvPgBLmq8_WafE,211
52
52
  airbyte_agent_slack/_vendored/connector_sdk/telemetry/config.py,sha256=tLmQwAFD0kP1WyBGWBS3ysaudN9H3e-3EopKZi6cGKg,885
53
53
  airbyte_agent_slack/_vendored/connector_sdk/telemetry/events.py,sha256=8Y1NbXiwISX-V_wRofY7PqcwEXD0dLMnntKkY6XFU2s,1328
54
54
  airbyte_agent_slack/_vendored/connector_sdk/telemetry/tracker.py,sha256=Ftrk0_ddfM7dZG8hF9xBuPwhbc9D6JZ7Q9qs5o3LEyA,5579
55
- airbyte_agent_slack-0.1.1.dist-info/METADATA,sha256=cZs7WDnRry6SS5DB_xwtCQNRw5sSGYbzr16GA8OnLJ4,4158
56
- airbyte_agent_slack-0.1.1.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
57
- airbyte_agent_slack-0.1.1.dist-info/RECORD,,
55
+ airbyte_agent_slack-0.1.2.dist-info/METADATA,sha256=LjAbm4ayysRReA8Y0n1bzFgK5Ubm_3BpvguKgNIBJD8,4158
56
+ airbyte_agent_slack-0.1.2.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
57
+ airbyte_agent_slack-0.1.2.dist-info/RECORD,,