Skip to content

Commit

Permalink
Updating regex and improved debug
Browse files Browse the repository at this point in the history
  • Loading branch information
NotChristianGarcia committed Nov 27, 2024
1 parent e69feb6 commit 8ada027
Showing 1 changed file with 9 additions and 7 deletions.
16 changes: 9 additions & 7 deletions service/models_pods.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ def check_url(cls, v):
# Regex match to ensure url is safe with only [A-z0-9.-] chars.
res = re.fullmatch(r'[a-z][a-z0-9.-]+', v)
if not res:
raise ValueError(f"networking.url can only contain lowercase alphanumeric characters, periods, and hyphens.")
raise ValueError(f"networking.url can only contain lowercase alphanumeric characters, periods, and hyphens. Got {v}")
# pod_id char limit = 64
if len(v) > 128:
raise ValueError(f"networking.*.url length must be below 128 characters. Inputted length: {len(v)}")
Expand All @@ -131,12 +131,14 @@ def check_tapis_auth_forward_cookies(cls, v):
@validator('tapis_auth_return_path')
def check_tapis_auth_return_path(cls, v):
if v:
if not v.startswith('/'):
raise ValueError(f"networking.tapis_auth_return_path should start with '/'. Got {v}")
# Regex match to ensure url is safe with only [A-z0-9.-/] chars.
res = re.fullmatch(r'[a-z][a-z0-9.-/]+', v)
res = re.fullmatch(r'^\/[A-Za-z][a-z0-9.\-_\/]+', v)
if not res:
raise ValueError(f"networking.tapis_auth_return_path can only contain lowercase alphanumeric characters, periods, forward-slash, and hyphens.")
raise ValueError(f"networking.tapis_auth_return_path should start with '/' and can contain alphanumeric characters, periods, forward-slash, underscores, and hyphens. Got {v}")
if len(v) > 180:
raise ValueError(f"networking.tapis_auth_return_path length must be below 180 characters. Inputted length: {len(v)}")
raise ValueError(f"networking.tapis_auth_return_path length must be below 180 characters. Got length: {len(v)}")
return v

@validator('tapis_auth_allowed_users')
Expand All @@ -155,7 +157,7 @@ def check_tapis_ui_uri(cls, v):
# Regex match to ensure url is safe with only [A-z0-9.-/] chars.
res = re.fullmatch(r'[a-z][a-z0-9.-/]+', v)
if not res:
raise ValueError(f"networking.tapis_ui_uri can only contain lowercase alphanumeric characters, periods, forward-slash, and hyphens.")
raise ValueError(f"networking.tapis_ui_uri can only contain lowercase alphanumeric characters, periods, forward-slash, and hyphens. Got {v}")
# pod_id char limit = 64
if len(v) > 128:
raise ValueError(f"networking.tapis_ui_uri length must be below 128 characters. Inputted length: {len(v)}")
Expand All @@ -165,7 +167,7 @@ def check_tapis_ui_uri(cls, v):
def check_tapis_ui_uri_description(cls, v):
# ensure tapis_ui_uri_description is all ascii
if not v.isascii():
raise ValueError(f"networking.tapis_ui_uri_description field may only contain ASCII characters.")
raise ValueError(f"networking.tapis_ui_uri_description field may only contain ASCII characters. Got {v}")
# make sure tapis_ui_uri_description < 255 characters
if len(v) > 255:
raise ValueError(f"networking.tapis_ui_uri_description field must be less than 255 characters. Inputted length: {len(v)}")
Expand All @@ -177,7 +179,7 @@ def check_tapis_auth_fields(cls, values):
tapis_auth = values.get('tapis_auth')

if tapis_auth and protocol != "http":
raise ValueError(f"networking.tapis_auth can only be used with protocol 'http'.")
raise ValueError(f"networking.tapis_auth can only be used with protocol 'http'. Got protocol {protocol}.")

return values

Expand Down

0 comments on commit 8ada027

Please sign in to comment.