* chore: Add romeo runner * fix: Linter * dedupe fixes * wip * wip dump * allbirds * chore: Update romeo parser * chore: Anthropic model fix * allbirds runner * format * wip * mypy updates * update * remove r * update tests * format * wip * wip * wip * chore: Strategically update the message * chore: Add romeo runner * fix: Linter * wip * wip dump * chore: Update romeo parser * chore: Anthropic model fix * wip * allbirds * allbirds runner * format * wip * wip * mypy updates * update * remove r * update tests * format * wip * chore: Strategically update the message * rebase and fix import issues * Update package imports for graphiti_core in examples and utils * nits * chore: Update OpenAI GPT-4o model to gpt-4o-2024-08-06 * implement groq * improvments & linting * cleanup and nits * Refactor package imports for graphiti_core in examples and utils * Refactor package imports for graphiti_core in examples and utils * chore: Nuke unused examples * chore: Nuke unused examples * chore: Only run type check on graphiti_core * fix unit tests * reformat * unit test * fix: Unit tests * test: Add coverage for extract_date_strings_from_edge * lint * remove commented code --------- Co-authored-by: prestonrasmussen <prasmuss15@gmail.com> Co-authored-by: Daniel Chalef <131175+danielchalef@users.noreply.github.com>
93 lines
2.9 KiB
Python
93 lines
2.9 KiB
Python
"""
|
|
Copyright 2024, Zep Software, Inc.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
"""
|
|
|
|
import asyncio
|
|
import logging
|
|
import os
|
|
import sys
|
|
from datetime import datetime, timedelta
|
|
|
|
from dotenv import load_dotenv
|
|
|
|
from examples.wizard_of_oz.parser import get_wizard_of_oz_messages
|
|
from graphiti_core import Graphiti
|
|
from graphiti_core.llm_client.anthropic_client import AnthropicClient
|
|
from graphiti_core.llm_client.config import LLMConfig
|
|
from graphiti_core.utils.maintenance.graph_data_operations import clear_data
|
|
|
|
load_dotenv()
|
|
|
|
neo4j_uri = os.environ.get('NEO4J_URI') or 'bolt://localhost:7687'
|
|
neo4j_user = os.environ.get('NEO4J_USER') or 'neo4j'
|
|
neo4j_password = os.environ.get('NEO4J_PASSWORD') or 'password'
|
|
|
|
|
|
def setup_logging():
|
|
# Create a logger
|
|
logger = logging.getLogger()
|
|
logger.setLevel(logging.INFO) # Set the logging level to INFO
|
|
|
|
# Create console handler and set level to INFO
|
|
console_handler = logging.StreamHandler(sys.stdout)
|
|
console_handler.setLevel(logging.INFO)
|
|
|
|
# Create formatter
|
|
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
|
|
|
|
# Add formatter to console handler
|
|
console_handler.setFormatter(formatter)
|
|
|
|
# Add console handler to logger
|
|
logger.addHandler(console_handler)
|
|
|
|
return logger
|
|
|
|
|
|
async def main():
|
|
setup_logging()
|
|
llm_client = AnthropicClient(LLMConfig(api_key=os.environ.get('ANTHROPIC_API_KEY')))
|
|
client = Graphiti(neo4j_uri, neo4j_user, neo4j_password, llm_client)
|
|
messages = get_wizard_of_oz_messages()
|
|
print(messages)
|
|
print(len(messages))
|
|
now = datetime.now()
|
|
# episodes: list[BulkEpisode] = [
|
|
# BulkEpisode(
|
|
# name=f'Chapter {i + 1}',
|
|
# content=chapter['content'],
|
|
# source_description='Wizard of Oz Transcript',
|
|
# episode_type='string',
|
|
# reference_time=now + timedelta(seconds=i * 10),
|
|
# )
|
|
# for i, chapter in enumerate(messages[0:50])
|
|
# ]
|
|
|
|
# await clear_data(client.driver)
|
|
# await client.build_indices_and_constraints()
|
|
# await client.add_episode_bulk(episodes)
|
|
|
|
await clear_data(client.driver)
|
|
await client.build_indices_and_constraints()
|
|
for i, chapter in enumerate(messages):
|
|
await client.add_episode(
|
|
name=f'Chapter {i + 1}',
|
|
episode_body=chapter['content'],
|
|
source_description='Wizard of Oz Transcript',
|
|
reference_time=now + timedelta(seconds=i * 10),
|
|
)
|
|
|
|
|
|
asyncio.run(main())
|