From e277c39423da0f79334a45361748f3e157cb64a4 Mon Sep 17 00:00:00 2001 From: star-nox Date: Tue, 19 Mar 2024 13:08:14 -0500 Subject: [PATCH 1/3] fixed s3_path issues in cropwizard-1.5 --- ai_ta_backend/service/export_service.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ai_ta_backend/service/export_service.py b/ai_ta_backend/service/export_service.py index 3ceaabb7..ce60c23c 100644 --- a/ai_ta_backend/service/export_service.py +++ b/ai_ta_backend/service/export_service.py @@ -223,7 +223,7 @@ def export_data_in_bg(response, download_type, course_name, s3_path): # upload to S3 #s3_file = f"courses/{course_name}/exports/{os.path.basename(zip_file_path)}" - s3_file = f"courses/{course_name}/{os.path.basename(zip_file_path)}" + s3_file = f"courses/{course_name}/{os.path.basename(s3_path)}" s3.upload_file(zip_file_path, os.environ['S3_BUCKET_NAME'], s3_file) # remove local files @@ -234,6 +234,7 @@ def export_data_in_bg(response, download_type, course_name, s3_path): # generate presigned URL s3_url = s3.generatePresignedUrl('get_object', os.environ['S3_BUCKET_NAME'], s3_path, 3600) + #print("s3_url: ", s3_url) # get admin email IDs headers = { From 148e6da8386496f7eb6d0a224f582f365969a9f8 Mon Sep 17 00:00:00 2001 From: star-nox Date: Tue, 19 Mar 2024 16:43:17 -0500 Subject: [PATCH 2/3] changed json to jsonl --- ai_ta_backend/service/export_service.py | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/ai_ta_backend/service/export_service.py b/ai_ta_backend/service/export_service.py index ce60c23c..dde6b206 100644 --- a/ai_ta_backend/service/export_service.py +++ b/ai_ta_backend/service/export_service.py @@ -59,7 +59,7 @@ def export_documents_json(self, course_name: str, from_date='', to_date=''): print("last_id: ", last_id) curr_doc_count = 0 - filename = course_name + '_' + str(uuid.uuid4()) + '_documents.json' + filename = course_name + '_' + str(uuid.uuid4()) + '_documents.jsonl' file_path = os.path.join(os.getcwd(), filename) while curr_doc_count < total_doc_count: @@ -71,7 +71,7 @@ def export_documents_json(self, course_name: str, from_date='', to_date=''): # writing to file if not os.path.isfile(file_path): - df.to_json(file_path, orient='records') + df.to_json(file_path, orient='records', lines=True) else: df.to_json(file_path, orient='records', lines=True, mode='a') @@ -126,7 +126,7 @@ def export_convo_history_json(self, course_name: str, from_date='', to_date=''): last_id = response.data[-1]['id'] total_count = response.count - filename = course_name + '_' + str(uuid.uuid4()) + '_convo_history.json' + filename = course_name + '_' + str(uuid.uuid4()) + '_convo_history.jsonl' file_path = os.path.join(os.getcwd(), filename) curr_count = 0 # Fetch data in batches of 25 from first_id to last_id @@ -191,7 +191,7 @@ def export_data_in_bg(response, download_type, course_name, s3_path): print("pre-defined s3_path: ", s3_path) curr_doc_count = 0 - filename = s3_path.split('/')[-1].split('.')[0] + '.json' + filename = s3_path.split('/')[-1].split('.')[0] + '.jsonl' file_path = os.path.join(os.getcwd(), filename) # download data in batches of 100 @@ -203,7 +203,7 @@ def export_data_in_bg(response, download_type, course_name, s3_path): # writing to file if not os.path.isfile(file_path): - df.to_json(file_path, orient='records') + df.to_json(file_path, orient='records', lines=True) else: df.to_json(file_path, orient='records', lines=True, mode='a') @@ -267,8 +267,8 @@ def export_data_in_bg(response, download_type, course_name, s3_path): # send email to admins subject = "UIUC.chat Data Export Complete for " + course_name body_text = "The data export for " + course_name + " is complete.\n\nYou can download the file from the following link: \n\n" + s3_url + "\n\nThis link will expire in 48 hours." - email_status = send_email(subject, body_text, os.environ['EMAIL_SENDER'], admin_emails, bcc_emails) - print("email_status: ", email_status) + # email_status = send_email(subject, body_text, os.environ['EMAIL_SENDER'], admin_emails, bcc_emails) + # print("email_status: ", email_status) return "File uploaded to S3. Email sent to admins." From f57f65e0387cc43ef537802d6555f726bea1f1d3 Mon Sep 17 00:00:00 2001 From: star-nox Date: Tue, 19 Mar 2024 16:44:46 -0500 Subject: [PATCH 3/3] uncommented send_email() --- ai_ta_backend/service/export_service.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ai_ta_backend/service/export_service.py b/ai_ta_backend/service/export_service.py index dde6b206..3e4925af 100644 --- a/ai_ta_backend/service/export_service.py +++ b/ai_ta_backend/service/export_service.py @@ -267,8 +267,8 @@ def export_data_in_bg(response, download_type, course_name, s3_path): # send email to admins subject = "UIUC.chat Data Export Complete for " + course_name body_text = "The data export for " + course_name + " is complete.\n\nYou can download the file from the following link: \n\n" + s3_url + "\n\nThis link will expire in 48 hours." - # email_status = send_email(subject, body_text, os.environ['EMAIL_SENDER'], admin_emails, bcc_emails) - # print("email_status: ", email_status) + email_status = send_email(subject, body_text, os.environ['EMAIL_SENDER'], admin_emails, bcc_emails) + print("email_status: ", email_status) return "File uploaded to S3. Email sent to admins."