205 lines
7.0 KiB
Python
205 lines
7.0 KiB
Python
#
|
|
# MIT License
|
|
#
|
|
# Copyright (c) 2020 Airbyte
|
|
#
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
#
|
|
# The above copyright notice and this permission notice shall be included in all
|
|
# copies or substantial portions of the Software.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
# SOFTWARE.
|
|
#
|
|
|
|
# generated by datamodel-codegen:
|
|
# filename: airbyte_protocol.yaml
|
|
|
|
from __future__ import annotations
|
|
|
|
from enum import Enum
|
|
from typing import Any, Dict, List, Optional
|
|
|
|
from pydantic import AnyUrl, BaseModel, Extra, Field
|
|
|
|
|
|
class Type(Enum):
|
|
RECORD = "RECORD"
|
|
STATE = "STATE"
|
|
LOG = "LOG"
|
|
SPEC = "SPEC"
|
|
CONNECTION_STATUS = "CONNECTION_STATUS"
|
|
CATALOG = "CATALOG"
|
|
|
|
|
|
class AirbyteRecordMessage(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
stream: str = Field(..., description="the name of this record's stream")
|
|
data: Dict[str, Any] = Field(..., description="the record data")
|
|
emitted_at: int = Field(
|
|
...,
|
|
description="when the data was emitted from the source. epoch in millisecond.",
|
|
)
|
|
namespace: Optional[str] = Field(None, description="the namespace of this record's stream")
|
|
|
|
|
|
class AirbyteStateMessage(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
data: Dict[str, Any] = Field(..., description="the state data")
|
|
|
|
|
|
class Level(Enum):
|
|
FATAL = "FATAL"
|
|
ERROR = "ERROR"
|
|
WARN = "WARN"
|
|
INFO = "INFO"
|
|
DEBUG = "DEBUG"
|
|
TRACE = "TRACE"
|
|
|
|
|
|
class AirbyteLogMessage(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
level: Level = Field(..., description="the type of logging")
|
|
message: str = Field(..., description="the log message")
|
|
|
|
|
|
class Status(Enum):
|
|
SUCCEEDED = "SUCCEEDED"
|
|
FAILED = "FAILED"
|
|
|
|
|
|
class AirbyteConnectionStatus(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
status: Status
|
|
message: Optional[str] = None
|
|
|
|
|
|
class SyncMode(Enum):
|
|
full_refresh = "full_refresh"
|
|
incremental = "incremental"
|
|
|
|
|
|
class DestinationSyncMode(Enum):
|
|
append = "append"
|
|
overwrite = "overwrite"
|
|
append_dedup = "append_dedup"
|
|
|
|
|
|
class ConnectorSpecification(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
documentationUrl: Optional[AnyUrl] = None
|
|
changelogUrl: Optional[AnyUrl] = None
|
|
connectionSpecification: Dict[str, Any] = Field(
|
|
...,
|
|
description="ConnectorDefinition specific blob. Must be a valid JSON string.",
|
|
)
|
|
supportsIncremental: Optional[bool] = Field(None, description="If the connector supports incremental mode or not.")
|
|
supportsNormalization: Optional[bool] = Field(False, description="If the connector supports normalization or not.")
|
|
supportsDBT: Optional[bool] = Field(False, description="If the connector supports DBT or not.")
|
|
supported_destination_sync_modes: Optional[List[DestinationSyncMode]] = Field(
|
|
None, description="List of destination sync modes supported by the connector"
|
|
)
|
|
|
|
|
|
class AirbyteStream(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
name: str = Field(..., description="Stream's name.")
|
|
json_schema: Dict[str, Any] = Field(..., description="Stream schema using Json Schema specs.")
|
|
supported_sync_modes: Optional[List[SyncMode]] = None
|
|
source_defined_cursor: Optional[bool] = Field(
|
|
None,
|
|
description="If the source defines the cursor field, then any other cursor field inputs will be ignored. If it does not, either the user_provided one is used, or the default one is used as a backup.",
|
|
)
|
|
default_cursor_field: Optional[List[str]] = Field(
|
|
None,
|
|
description="Path to the field that will be used to determine if a record is new or modified since the last sync. If not provided by the source, the end user will have to specify the comparable themselves.",
|
|
)
|
|
source_defined_primary_key: Optional[List[List[str]]] = Field(
|
|
None,
|
|
description="If the source defines the primary key, paths to the fields that will be used as a primary key. If not provided by the source, the end user will have to specify the primary key themselves.",
|
|
)
|
|
namespace: Optional[str] = Field(
|
|
None,
|
|
description="Optional Source-defined namespace. Currently only used by JDBC destinations to determine what schema to write to. Airbyte streams from the same sources should have the same namespace.",
|
|
)
|
|
|
|
|
|
class ConfiguredAirbyteStream(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
stream: AirbyteStream
|
|
sync_mode: SyncMode
|
|
cursor_field: Optional[List[str]] = Field(
|
|
None,
|
|
description="Path to the field that will be used to determine if a record is new or modified since the last sync. This field is REQUIRED if `sync_mode` is `incremental`. Otherwise it is ignored.",
|
|
)
|
|
destination_sync_mode: DestinationSyncMode
|
|
primary_key: Optional[List[List[str]]] = Field(
|
|
None,
|
|
description="Paths to the fields that will be used as primary key. This field is REQUIRED if `destination_sync_mode` is `*_dedup`. Otherwise it is ignored.",
|
|
)
|
|
|
|
|
|
class AirbyteCatalog(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
streams: List[AirbyteStream]
|
|
|
|
|
|
class ConfiguredAirbyteCatalog(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
streams: List[ConfiguredAirbyteStream]
|
|
|
|
|
|
class AirbyteMessage(BaseModel):
|
|
class Config:
|
|
extra = Extra.allow
|
|
|
|
type: Type = Field(..., description="Message type")
|
|
log: Optional[AirbyteLogMessage] = Field(
|
|
None,
|
|
description="log message: any kind of logging you want the platform to know about.",
|
|
)
|
|
spec: Optional[ConnectorSpecification] = None
|
|
connectionStatus: Optional[AirbyteConnectionStatus] = None
|
|
catalog: Optional[AirbyteCatalog] = Field(
|
|
None,
|
|
description="log message: any kind of logging you want the platform to know about.",
|
|
)
|
|
record: Optional[AirbyteRecordMessage] = Field(None, description="record message: the record")
|
|
state: Optional[AirbyteStateMessage] = Field(
|
|
None,
|
|
description="schema message: the state. Must be the last message produced. The platform uses this information",
|
|
)
|
|
|
|
|
|
class AirbyteProtocol(BaseModel):
|
|
airbyte_message: Optional[AirbyteMessage] = None
|
|
configured_airbyte_catalog: Optional[ConfiguredAirbyteCatalog] = None
|