From 7578b55af5522d6c07494e4ff1f8b7025b4850a2 Mon Sep 17 00:00:00 2001 From: antonio Date: Tue, 13 Aug 2024 14:25:00 +0200 Subject: [PATCH 1/3] Fixed datestamps --- app/oaipmh/oai.py | 36 ++++++++++++++++++++---------------- 1 file changed, 20 insertions(+), 16 deletions(-) diff --git a/app/oaipmh/oai.py b/app/oaipmh/oai.py index 69493b3a9..d66df6733 100644 --- a/app/oaipmh/oai.py +++ b/app/oaipmh/oai.py @@ -111,9 +111,10 @@ def getRecord(self, root, metadata_dict, verb, identifier, metadata_prefix): identifier_element = etree.SubElement(header, 'identifier') identifier_element.text = identifier datestamp_element = etree.SubElement(header, 'datestamp') - datestamp_element.text = self.earliest_datestamp - if record_data.get('creation_date'): - datestamp_element.text = record_data.get('creation_date').strftime("%Y-%m-%d") + if 'creation_date' in record_data: + datestamp_element.text = record_data['creation_date'].strftime("%Y-%m-%d") + else: # if creation_date is not present in the metadata + datestamp_element.text = self.earliest_datestamp metadata_element = etree.SubElement(record, 'metadata') @@ -203,9 +204,11 @@ def listIdentifiers(self, root, metadata_dict, verb, metadata_prefix, from_date= identifier_element = etree.Element('identifier') identifier_element.text = f'{self.repository_indentifier_base_url}{record_identifier}' datestamp_element = etree.Element('datestamp') - datestamp_element.text = self.earliest_datestamp - if metadata_dict[record_identifier].get('creation_date'): - datestamp_element.text = metadata_dict[record_identifier].get('creation_date').strftime("%Y-%m-%d") + record_metadata = metadata_dict[record_identifier] + if 'creation_date' in record_metadata: + datestamp_element.text = record_metadata['creation_date'].strftime("%Y-%m-%d") + else: # if creation_date is not present in the metadata + datestamp_element.text = f'{self.earliest_datestamp}' header_element.append(identifier_element) header_element.append(datestamp_element) @@ -278,16 +281,17 @@ def listRecords(self, root, metadata_dict, verb, metadata_prefix, from_date=None root.append(error_element) return etree.tostring(root, pretty_print=True, encoding='unicode') else: - for record_name in filtered_identifiers: + for record_name, record_metadata in filtered_identifiers: record_element = etree.Element('record') header_element = etree.Element('header') identifier_element = etree.Element('identifier') identifier_element.text = f'{self.repository_indentifier_base_url}{record_name}' datestamp_element = etree.Element('datestamp') - datestamp_element.text = 'datestamp' - if metadata_dict[record_name].get('creation_date'): - datestamp_element.text = metadata_dict[record_name].get('creation_date').strftime("%Y-%m-%d") + if 'creation_date' in record_metadata: + datestamp_element.text = record_metadata['creation_date'].strftime("%Y-%m-%d") + else: # if creation_date is not present in the metadata + datestamp_element.text = f'{self.earliest_datestamp}' metadata_element = etree.Element('metadata') @@ -427,7 +431,7 @@ def mapOAIRE(self, metadata_dict): etree.register_namespace('oai_dc', nsmap['oai_dc']) for key, value in metadata_dict.items(): - if key == 'display_name': + if key == 'template_name': title_element = etree.Element('{http://datacite.org/schema/kernel-4}title') title_element.text = value root.append(title_element) @@ -465,7 +469,7 @@ def mapOAIRE(self, metadata_dict): version_element = etree.Element('{http://purl.org/dc/elements/1.1/}version') version_element.text = value root.append(version_element) - if key == 'subject': + if key == 'display_name': # tag subject_element = etree.Element('{http://namespace.openaire.eu/schema/oaire/}subject') subject_element.text = value root.append(subject_element) @@ -501,7 +505,7 @@ def mapDC(self, metadata_dict): etree.register_namespace('oai_dc', nsmap['oai_dc']) for key, value in metadata_dict.items(): - if key == 'display_name': + if key == 'template_name': title_element = etree.Element('{http://purl.org/dc/elements/1.1/}title') title_element.text = value root.append(title_element) @@ -533,14 +537,14 @@ def mapDC(self, metadata_dict): related_identifier_element = etree.Element('{http://purl.org/dc/elements/1.1/}version') related_identifier_element.text = value root.append(related_identifier_element) - if key == 'tag': + if key == 'display_name': # tag subject_element = etree.Element('{http://purl.org/dc/elements/1.1/}subject') subject_element.text = value root.append(subject_element) if key == 'childs': related_identifier_element = etree.Element('{http://purl.org/dc/elements/1.1/}relation') - # childs = value["childs"] - # related_identifier_element.text = ', '.join(childs) + childs = value + related_identifier_element.text = ', '.join(childs) root.append(related_identifier_element) if key == 'format': format_element = etree.Element('{http://purl.org/dc/elements/1.1/}format') From e6783492c69f0d0b869e40b13a91352cb865e6e3 Mon Sep 17 00:00:00 2001 From: Sanch3z_Sama Date: Wed, 14 Aug 2024 10:45:56 +0200 Subject: [PATCH 2/3] Fixed identify response --- app/oaipmh/oai.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/app/oaipmh/oai.py b/app/oaipmh/oai.py index d66df6733..5ad255d8f 100644 --- a/app/oaipmh/oai.py +++ b/app/oaipmh/oai.py @@ -343,6 +343,9 @@ def addIdentifyElements(self, identify_element): protocol_version_element = etree.SubElement(identify_element, 'protocolVersion') protocol_version_element.text = self.repository_protocol_version + admin_email_element = etree.SubElement(identify_element, 'adminEmail') + admin_email_element.text = self.repository_admin_email + earliest_datestamp_element = etree.SubElement(identify_element, 'earliestDatestamp') earliest_datestamp_element.text = self.earliest_datestamp @@ -352,9 +355,6 @@ def addIdentifyElements(self, identify_element): granularity_element = etree.SubElement(identify_element, 'granularity') granularity_element.text = self.datestamp_granularity - admin_email_element = etree.SubElement(identify_element, 'adminEmail') - admin_email_element.text = self.repository_admin_email - def addRequestElement(self, root, verb=None, metadata_prefix=None, identifier=None, from_date=None, until_date=None, set_spec=None, resumption_token=None): if verb: From 2f1a528b715435ba231c1ab4db9cd7278b7a5b0a Mon Sep 17 00:00:00 2001 From: Miguel Caballer Fernandez Date: Mon, 2 Sep 2024 09:28:54 +0200 Subject: [PATCH 3/3] Fix style --- app/oaipmh/oai.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/app/oaipmh/oai.py b/app/oaipmh/oai.py index 5ad255d8f..5224234b6 100644 --- a/app/oaipmh/oai.py +++ b/app/oaipmh/oai.py @@ -207,7 +207,7 @@ def listIdentifiers(self, root, metadata_dict, verb, metadata_prefix, from_date= record_metadata = metadata_dict[record_identifier] if 'creation_date' in record_metadata: datestamp_element.text = record_metadata['creation_date'].strftime("%Y-%m-%d") - else: # if creation_date is not present in the metadata + else: # if creation_date is not present in the metadata datestamp_element.text = f'{self.earliest_datestamp}' header_element.append(identifier_element) @@ -290,7 +290,7 @@ def listRecords(self, root, metadata_dict, verb, metadata_prefix, from_date=None datestamp_element = etree.Element('datestamp') if 'creation_date' in record_metadata: datestamp_element.text = record_metadata['creation_date'].strftime("%Y-%m-%d") - else: # if creation_date is not present in the metadata + else: # if creation_date is not present in the metadata datestamp_element.text = f'{self.earliest_datestamp}' metadata_element = etree.Element('metadata') @@ -537,7 +537,7 @@ def mapDC(self, metadata_dict): related_identifier_element = etree.Element('{http://purl.org/dc/elements/1.1/}version') related_identifier_element.text = value root.append(related_identifier_element) - if key == 'display_name': # tag + if key == 'display_name': # tag subject_element = etree.Element('{http://purl.org/dc/elements/1.1/}subject') subject_element.text = value root.append(subject_element)