aboutsummaryrefslogtreecommitdiffstats
path: root/alphabetlearning/resources
diff options
context:
space:
mode:
Diffstat (limited to 'alphabetlearning/resources')
-rw-r--r--alphabetlearning/resources/views.py77
1 files changed, 50 insertions, 27 deletions
diff --git a/alphabetlearning/resources/views.py b/alphabetlearning/resources/views.py
index 773b1c2..8b0f8c5 100644
--- a/alphabetlearning/resources/views.py
+++ b/alphabetlearning/resources/views.py
@@ -63,61 +63,84 @@ def create_featured(request):
def _extract_metadata_from_resource(resource_obj) -> ResourceInfo | None:
"""
This function extracts the resource information from the model object and returns it as a
- ResourceInfo object
- :param resource_obj:
- :return:
+ ResourceInfo object.
+
+ :param resource_obj: An instance of the resource model from which metadata is extracted.
+ :return: ResourceInfo object containing the extracted metadata, or None if an error occurs.
"""
+
+ # Fetch and create a list of filenames for all PDF resources linked to the given resource object.
pdf_resource_filenames = [
x.file_name for x in PDFResource.objects.filter(resource=resource_obj).all()
]
+
+ # Retrieve all PDFResource objects associated with the resource_obj.
pdf_resources = PDFResource.objects.filter(resource=resource_obj).all()
+
+ # Initialize a dictionary to hold mappings of PDF filenames to their associated page snapshot filenames.
snapshot_dict = {}
+
+ # Iterate through each PDF resource to build the snapshot_dict mapping.
for p in pdf_resources:
+ # For each PDF resource, populate the dictionary with its filename as the key
+ # and a list of its associated snapshot filenames as the value.
snapshot_dict[p.file_name] = [
x.file_name for x in PDFPageSnapshot.objects.filter(pdf_file=p).all()
]
+
+ # Initialize a dictionary to hold the URLs for the snapshots.
snapshot_url_dict = {}
- # Iterate through the snapshot dict and generate the URLs
+
+ # Generate the URLs for each snapshot based on the snapshot_dict.
for k, v in snapshot_dict.items():
snapshot_url_dict[k] = [
get_presigned_obj_url(
- settings.AWS_STORAGE_BUCKET_NAME,
- f"snapshotted_pages/{f}",
+ settings.AWS_STORAGE_BUCKET_NAME, # Specify the bucket name for S3 storage.
+ f"snapshotted_pages/{f}", # Build the path to the snapshot image in S3.
)
- for f in v
+ for f in v # Iterate through the filenames in the snapshot list.
]
+
+ # Generate pre-signed URLs for the PDF files collected.
pdf_urls = [
get_presigned_obj_url(settings.AWS_STORAGE_BUCKET_NAME, f"pdfuploads/{f}")
- for f in pdf_resource_filenames
+ for f in pdf_resource_filenames # Iterate through the PDF filenames.
]
+
+ # Generate pre-signed URLs for the thumbnail images associated with the resource.
thumbnail_urls = [
get_presigned_obj_url(settings.AWS_STORAGE_BUCKET_NAME, f"thumbnails/{f}")
- for f in resource_obj.thumbnail_filenames
+ for f in resource_obj.thumbnail_filenames # Iterate through the thumbnail filenames.
]
+
try:
+ # Safely retrieve the subcategory name from resource_obj; handle the case where subcategories might be None.
arc_name = resource_obj.subcategories.name if resource_obj.subcategories else None
+
+ # Create and return a ResourceInfo object, populating it with various properties from resource_obj.
return ResourceInfo(
- id=resource_obj.id,
- name=resource_obj.name,
- description=resource_obj.description,
- card_description=resource_obj.card_description,
- main_resource_category_name=resource_obj.main_resource_category.name,
- main_resource_category_colour_css_class=resource_obj.main_resource_category.colour_css_class,
- main_resource_badge_foreground_colour=resource_obj.main_resource_category.badge_foreground_colour,
- subcategories=arc_name,
- age_range=resource_obj.age_range,
- pdf_filenames=pdf_resource_filenames,
- pdf_urls=pdf_urls,
- snapshot_urls=snapshot_url_dict,
- thumbnail_filenames=resource_obj.thumbnail_filenames,
- thumbnail_urls=thumbnail_urls,
- feature_slot=resource_obj.feature_slot,
- created=resource_obj.created_at,
- updated=resource_obj.updated_at,
+ id=resource_obj.id, # Resource ID
+ name=resource_obj.name, # Resource name
+ description=resource_obj.description, # Resource description
+ card_description=resource_obj.card_description, # Description for card visuals
+ main_resource_category_name=resource_obj.main_resource_category.name, # Main category name
+ main_resource_category_colour_css_class=resource_obj.main_resource_category.colour_css_class, # CSS class for category color
+ main_resource_badge_foreground_colour=resource_obj.main_resource_category.badge_foreground_colour, # Badge color for category
+ subcategories=arc_name, # Subcategory if it exists
+ age_range=resource_obj.age_range, # Target age range for the resource
+ pdf_filenames=pdf_resource_filenames, # List of PDF filenames
+ pdf_urls=pdf_urls, # List of URLs for PDFs
+ snapshot_urls=snapshot_url_dict, # Dictionary of snapshot filenames mapped to their URLs
+ thumbnail_filenames=resource_obj.thumbnail_filenames, # List of thumbnail filenames
+ thumbnail_urls=thumbnail_urls, # List of URLs for thumbnails
+ feature_slot=resource_obj.feature_slot, # Feature slot information
+ created=resource_obj.created_at, # Creation timestamp
+ updated=resource_obj.updated_at, # Last updated timestamp
)
except Exception:
+ # Log an exception if there was an error during the extraction process.
logging.exception("Error extracting resource information: ")
- return None
+ return None # Return None in case of an error.
@login_required