Skip to content

Commit

Permalink
Apply suggestions from code review
Browse files Browse the repository at this point in the history
Co-authored-by: Samuel Gaist <[email protected]>
  • Loading branch information
stevejpurves and sgaist authored Feb 20, 2024
1 parent e85495c commit 9e0bd86
Showing 1 changed file with 5 additions and 9 deletions.
14 changes: 5 additions & 9 deletions repo2docker/contentproviders/meca.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
from urllib.parse import urlparse, urlunparse

def get_hashed_slug(url, changes_with_content):
"""Return a unique slug that is invariant to query parameters in the url"""
"""Returns a unique slug that is invariant to query parameters in the url"""
parsed_url = urlparse(url)
stripped_url = urlunparse(
(parsed_url.scheme, parsed_url.netloc, parsed_url.path, "", "", "")
Expand All @@ -30,13 +30,9 @@ def fetch_zipfile(session, url, dst_dir):
return dst_filename


def handle_items(_, item):
print(item)


def extract_validate_and_identify_bundle(zip_filename, dst_dir):
if not os.path.exists(zip_filename):
raise RuntimeError("Download MECA bundle not found")
raise RuntimeError("Downloaded MECA bundle not found")

if not is_zipfile(zip_filename):
raise RuntimeError("MECA bundle is not a zip file")
Expand Down Expand Up @@ -80,7 +76,7 @@ def __init__(self):
def detect(self, spec, ref=None, extra_args=None):
"""`spec` contains a faux protocol of meca+http[s] for detection purposes
and we assume `spec` trusted as a reachable MECA bundle from an allowed origin
(binderhub RepoProvider class already checking for this).
(binderhub RepoProvider class is already checking for this).
An other HEAD check in made here in order to get the content-length header
"""
Expand All @@ -90,8 +86,8 @@ def detect(self, spec, ref=None, extra_args=None):
parsed = parsed._replace(scheme=parsed.scheme[:-5])
url = urlunparse(parsed)

r = self.session.head(url)
changes_with_content = r.headers.get("ETag") or r.headers.get("Content-Length")
headers = self.session.head(url).headers
changes_with_content = headers.get("ETag") or headers.get("Content-Length")

self.hashed_slug = get_hashed_slug(url, changes_with_content)

Expand Down

0 comments on commit 9e0bd86

Please sign in to comment.