-
-
Notifications
You must be signed in to change notification settings - Fork 23
Expand file tree
/
Copy pathpypi.py
More file actions
58 lines (43 loc) · 1.83 KB
/
pypi.py
File metadata and controls
58 lines (43 loc) · 1.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# fetchcode is a free software tool from nexB Inc. and others.
# Visit https://github.com/aboutcode-org/fetchcode for support and download.
#
# Copyright (c) nexB Inc. and others. All rights reserved.
# http://nexb.com and http://aboutcode.org
#
# This software is licensed under the Apache License version 2.0.
#
# You may not use this software except in compliance with the License.
# You may obtain a copy of the License at:
# http://apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing, software distributed
# under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
# CONDITIONS OF ANY KIND, either express or implied. See the License for the
# specific language governing permissions and limitations under the License.
from urllib.parse import urljoin
from packageurl import PackageURL
from fetchcode import fetch_json_response
class Pypi:
"""
This class handles Pypi PURLs.
"""
purl_pattern = "pkg:pypi/.*"
base_url = "https://pypi.org/pypi/"
@classmethod
def get_download_url(cls, purl):
"""
Return the download URL for a Pypi PURL.
"""
purl = PackageURL.from_string(purl)
name = purl.name
version = purl.version
if not name or not version:
raise ValueError("Pypi PURL must specify a name and version")
url = urljoin(cls.base_url, f"{name}/{version}/json")
data = fetch_json_response(url)
download_urls = data.get("urls", [{}])
if not download_urls:
raise ValueError(f"No download URLs found for {name} version {version}")
download_url = next((url["url"] for url in download_urls if url.get("url")), None)
if not download_url:
raise ValueError(f"No download URL found for {name} version {version}")
return download_url