From 22c3cbf58128c1bb4fd1621f6afca4d457f8f337 Mon Sep 17 00:00:00 2001 From: Eric Rosas Date: Mon, 11 Dec 2023 15:01:57 -0700 Subject: [PATCH] Added email address validation EPO-8832 Added email address validation --- pyproject.toml | 2 +- src/rubin/citsci/pipeline.py | 27 +++++++++++++++++++++------ 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index ccbb128..d96d858 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta" [project] name = "rubin.citsci" -version = "0.2.2" +version = "0.2.3" readme = "README.md" dependencies = [ "panoptes_client", diff --git a/src/rubin/citsci/pipeline.py b/src/rubin/citsci/pipeline.py index af09029..3eda725 100644 --- a/src/rubin/citsci/pipeline.py +++ b/src/rubin/citsci/pipeline.py @@ -1,4 +1,4 @@ -import csv, uuid, os, shutil, json, logging, urllib.request, base64 +import csv, uuid, os, shutil, json, logging, urllib.request, base64, re from datetime import datetime, timezone, timedelta from IPython.display import display import google.cloud.storage as storage @@ -61,15 +61,30 @@ def login_to_zooniverse(self, slug_name, email): platform. If not, please go to the Zooniverse website and create an account: https://www.zooniverse.org/ + + Email address validation occurs before the login prompt is called. """ - self.client = panoptes_client.Panoptes.connect(login="interactive") - self.project = Project.find(slug=slug_name) - self.project_id = self.project.id - self.email = email - print("You now are logged in to the Zooniverse platform.") + valid_email = self.__validate_email_address(email) + + if(valid_email): + self.email = email + self.client = panoptes_client.Panoptes.connect(login="interactive") + self.project = Project.find(slug=slug_name) + self.project_id = self.project.id + + print("You now are logged in to the Zooniverse platform.") + else: + print("Invalid email address! Please check the email address you provided and ensure it is correct.") return + def __validate_email_address(email): + regex = r'\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,7}\b' + if re.fullmatch(regex, email): + return True + else: + return False + def create_project(self, name, description, make_active_project=False): """ Assuming you have a Zooniverse account and have used the login_to_zooniverse()