diff --git a/assistant/data.py b/assistant/data.py index 205015af..1e20c8e5 100644 --- a/assistant/data.py +++ b/assistant/data.py @@ -5,12 +5,12 @@ from django.db.models import Prefetch from openai import OpenAI -from battles.models import Player, Battle +from battles.models import Player, Battle, BattleGroup client = OpenAI(api_key=settings.OPENAI_API_KEY) -def upload_data_to_openai(user): +def upload_user_battles_to_openai(user): player_query = Player.objects.select_related( "title_adjective__string", "title_subject__string", @@ -59,3 +59,68 @@ def upload_data_to_openai(user): purpose='assistants' ) return openai_file + + +def upload_battle_to_openai(battle: Battle): + battle_array = [json.dumps(battle.to_gpt_dict()) + '\n'] + temp_file = StringIO("") + temp_file.writelines(battle_array) + temp_file.seek(0) + temp_file = BytesIO(temp_file.read().encode('utf-8')) + temp_file.seek(0) + openai_file = client.files.create( + file=temp_file, + purpose='assistants' + ) + return openai_file + + +def upload_battle_group_to_openai(battle_group: BattleGroup): + player_query = Player.objects.select_related( + "title_adjective__string", + "title_subject__string", + "nameplate_background", + "nameplate_badge_1__description", + "nameplate_badge_2__description", + "nameplate_badge_3__description", + "weapon__name", + "weapon__sub__name", + "weapon__special__name", + "head_gear__gear__name", + "head_gear__primary_ability__name", + "head_gear__secondary_ability_1__name", + "head_gear__secondary_ability_2__name", + "head_gear__secondary_ability_3__name", + "clothing_gear__gear__name", + "clothing_gear__primary_ability__name", + "clothing_gear__secondary_ability_1__name", + "clothing_gear__secondary_ability_2__name", + "clothing_gear__secondary_ability_3__name", + "shoes_gear__gear__name", + "shoes_gear__primary_ability__name", + "shoes_gear__secondary_ability_1__name", + "shoes_gear__secondary_ability_2__name", + "shoes_gear__secondary_ability_3__name", + ) + player_prefetch = Prefetch( + 'teams__players', + queryset=player_query, + ) + battles = battle_group.battles.select_related("vs_stage__name").prefetch_related("awards__name", + player_prefetch).order_by( + '-played_time') + battle_array = [] + battle: Battle + for battle in battles: + battle_data = battle.to_gpt_dict() + battle_array.append(json.dumps(battle_data) + '\n') + temp_file = StringIO("") + temp_file.writelines(battle_array) + temp_file.seek(0) + temp_file = BytesIO(temp_file.read().encode('utf-8')) + temp_file.seek(0) + openai_file = client.files.create( + file=temp_file, + purpose='assistants' + ) + return openai_file diff --git a/assistant/migrations/0005_thread_content_type_thread_object_id_and_more.py b/assistant/migrations/0005_thread_content_type_thread_object_id_and_more.py new file mode 100644 index 00000000..798c4b62 --- /dev/null +++ b/assistant/migrations/0005_thread_content_type_thread_object_id_and_more.py @@ -0,0 +1,29 @@ +# Generated by Django 4.2.7 on 2023-11-30 01:47 + +import django.db.models.deletion +from django.db import migrations, models + + +class Migration(migrations.Migration): + dependencies = [ + ('contenttypes', '0002_remove_content_type_name'), + ('assistant', '0004_thread_runner_machine_id'), + ] + + operations = [ + migrations.AddField( + model_name='thread', + name='content_type', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, + to='contenttypes.contenttype'), + ), + migrations.AddField( + model_name='thread', + name='object_id', + field=models.PositiveIntegerField(blank=True, null=True), + ), + migrations.AddIndex( + model_name='thread', + index=models.Index(fields=['content_type', 'object_id'], name='assistant_t_content_9f2484_idx'), + ), + ] diff --git a/assistant/models.py b/assistant/models.py index b2c33ed5..64743242 100644 --- a/assistant/models.py +++ b/assistant/models.py @@ -1,3 +1,5 @@ +from django.contrib.contenttypes.fields import GenericForeignKey +from django.contrib.contenttypes.models import ContentType from django.db import models @@ -15,3 +17,11 @@ class Status(models.TextChoices): initial_message = models.TextField(default='') status = models.CharField(blank=True, choices=Status.choices, max_length=25) runner_machine_id = models.CharField(blank=True, max_length=20) + content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE, blank=True, null=True) + object_id = models.PositiveIntegerField(blank=True, null=True) + content_object = GenericForeignKey("content_type", "object_id") + + class Meta: + indexes = [ + models.Index(fields=["content_type", "object_id"]), + ] diff --git a/assistant/runner.py b/assistant/runner.py index 3d629c7e..29913a38 100644 --- a/assistant/runner.py +++ b/assistant/runner.py @@ -11,7 +11,8 @@ os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'splashcat.settings') django.setup() -from assistant.data import upload_data_to_openai +from battles.models import Battle, BattleGroup +from assistant.data import upload_user_battles_to_openai, upload_battle_to_openai, upload_battle_group_to_openai from assistant.models import Thread client = OpenAI(api_key=settings.OPENAI_API_KEY) @@ -26,7 +27,12 @@ initial_prompt = thread.initial_message -openai_file = upload_data_to_openai(thread.creator) +if thread.content_type.model_class() == Battle: + openai_file = upload_battle_to_openai(thread.content_object) +elif thread.content_type.model_class() == BattleGroup: + openai_file = upload_battle_group_to_openai(thread.content_object) +else: + openai_file = upload_user_battles_to_openai(thread.creator) thread.openai_file_id = openai_file.id thread.status = thread.Status.CREATED diff --git a/assistant/templates/assistant/create_thread.html b/assistant/templates/assistant/create_thread.html index 2fba8bcc..1bac4008 100644 --- a/assistant/templates/assistant/create_thread.html +++ b/assistant/templates/assistant/create_thread.html @@ -5,7 +5,7 @@