import json from pathlib import Path from typing import List, Union from langchain_core.documents import Document from langchain_core.utils import stringify_dict from langchain_community.document_loaders.base import BaseLoader class AirbyteJSONLoader(BaseLoader): """Load local `Airbyte` json files.""" def __init__(self, file_path: Union[str, Path]): """Initialize with a file path. This should start with '/tmp/airbyte_local/'.""" self.file_path = file_path """Path to the directory containing the json files.""" def load(self) -> List[Document]: text = "" for line in open(self.file_path, "r"): data = json.loads(line)["_airbyte_data"] text += stringify_dict(data) metadata = {"source": str(self.file_path)} return [Document(page_content=text, metadata=metadata)]