Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Support for Pre-Approved Datasets #116

Open
wants to merge 4 commits into
base: integration
Choose a base branch
from

Conversation

elmiomar
Copy link
Contributor

@elmiomar elmiomar commented Oct 30, 2024

Overview

This PR updates the record handling logic in our distribution service to differentiate between datasets that require SME approval and those that are pre-approved.

Changes

  • Updated the createRecord() method to first create records in Salesforce then handle all post-processing (caching, emailing) based on the dataset type, only after successful creation.
  • Added a new RECORD_PRE_APPROVED_STATUS, which is used for datasets that are pre-approved, allowing them to be cached and sent to the user without SME intervention.
  • Leveraged the RPA configuration to identify pre-approved datasets; each dataset ID is mapped to a set of approvers in the configuration file. If no approvers are specified for a given dataset ID, it is considered pre-approved. This is just temporary until we add the new metadata fields. Replaced the configuration-based logic with a metadata-based check: pre-approval is determined by parsing the NERDm metadata, looking for components with "@type" containing nrdp:RestrictedAccessPage and verifying that the pdr:accessProfile field has a "@type" value of rpa:rp0.
  • Added a new method in RecordResponseHandlerImpl to handle pre-approved datasets by sending both confirmation and download emails in a single step.

Updated workflow

  • User submits request to download dataset.
  • createRecord will be called with user info.
  • Blacklist Check: rejects user if email/country is blacklisted.
  • Dataset Type Check: sets RECORD_PRE_APPROVED_STATUS if pre-approved; otherwise, RECORD_PENDING_STATUS.
  • Salesforce Record Creation: sends request to create a record in Salesforce.
  • Post-Processing:
    • Rejected: ends process.
    • Pre-approved: caches dataset, sends confirmation and download emails.
    • SME-required: sends confirmation email to user and approval email request to SME.
  • SME Approval (when required):
    • Approve: caches dataset, sends download link to user.
    • Decline: updates status to declined, notifies user.

Testing

  • Tested end-to-end using oar-docker. I was able to download files, only individually.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants