=================
packageurl-python
=================
Python library to parse and build "purl" aka. Package URLs.
See https://github.com/package-url/purl-spec for details.
Join the discussion at https://gitter.im/package-url/Lobby or enter a ticket for support.
License: MIT
Tests and build status
======================
+----------------------+
| **Tests and build** |
+======================+
| |ci-tests| |
+----------------------+
Install
=======
::
pip install packageurl-python
Usage
=====
::
>>> from packageurl import PackageURL
>>> purl = PackageURL.from_string("pkg:maven/org.apache.commons/io@1.3.4")
>>> print(purl.to_dict())
{'type': 'maven', 'namespace': 'org.apache.commons', 'name': 'io', 'version': '1.3.4', 'qualifiers': None, 'subpath': None}
>>> print(purl.to_string())
pkg:maven/org.apache.commons/io@1.3.4
>>> print(str(purl))
pkg:maven/org.apache.commons/io@1.3.4
>>> print(repr(purl))
PackageURL(type='maven', namespace='org.apache.commons', name='io', version='1.3.4', qualifiers={}, subpath=None)
Utilities
=========
Django models
^^^^^^^^^^^^^
`packageurl.contrib.django.models.PackageURLMixin` is a Django abstract model mixin to
use Package URLs in Django.
SQLAlchemy mixin
^^^^^^^^^^^^^^^^
`packageurl.contrib.sqlalchemy.mixin.PackageURLMixin` is a SQLAlchemy declarative mixin
to use Package URLs in SQLAlchemy models.
URL to PURL
^^^^^^^^^^^
`packageurl.contrib.url2purl.get_purl(url)` returns a Package URL inferred from an URL.
::
>>> from packageurl.contrib import url2purl
>>> url2purl.get_purl("https://github.com/package-url/packageurl-python")
PackageURL(type='github', namespace='package-url', name='packageurl-python', version=None, qualifiers={}, subpath=None)
PURL to URL
^^^^^^^^^^^
- `packageurl.contrib.purl2url.get_repo_url(purl)` returns a repository URL inferred
from a Package URL.
- `packageurl.contrib.purl2url.get_download_url(purl)` returns a download URL inferred
from a Package URL.
- `packageurl.contrib.purl2url.get_inferred_urls(purl)` return all inferred URLs
(repository, download) from a Package URL.
::
>>> from packageurl.contrib import purl2url
>>> purl2url.get_repo_url("pkg:gem/bundler@2.3.23")
"https://rubygems.org/gems/bundler/versions/2.3.23"
>>> purl2url.get_download_url("pkg:gem/bundler@2.3.23")
"https://rubygems.org/downloads/bundler-2.3.23.gem"
>>> purl2url.get_inferred_urls("pkg:gem/bundler@2.3.23")
["https://rubygems.org/gems/bundler/versions/2.3.23", "https://rubygems.org/downloads/bundler-2.3.23.gem"]
Run tests
=========
Install test dependencies::
python3 thirdparty/virtualenv.pyz --never-download --no-periodic-update .
bin/pip install -e ."[test]"
Run tests::
bin/pytest tests
Make a new release
==================
- Start a new release branch
- Update the CHANGELOG.rst, AUTHORS.rst, and README.rst if needed
- Bump version in setup.cfg
- Run all tests
- Install restview and validate that all .rst docs are correct
- Commit and push this branch
- Make a PR and merge once approved
- Tag and push that tag. This triggers the pypi-release.yml workflow that takes care of
building the dist release files and upload those to pypi::
VERSION=v0.x.x
git tag -a $VERSION -m "Tag $VERSION"
git push origin $VERSION
- Review the GitHub release created by the workflow at
https://github.com/package-url/packageurl-python/releases
.. |ci-tests| image:: https://github.com/package-url/packageurl-python/actions/workflows/ci.yml/badge.svg?branch=main
:target: https://github.com/package-url/packageurl-python/actions/workflows/ci.yml
:alt: CI Tests and build status
Raw data
{
"_id": null,
"home_page": "https://github.com/package-url/packageurl-python",
"name": "packageurl-python",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "package, url, package manager, package url",
"author": "the purl authors",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/37/0f/66c682b6d6844247a5ba04e1be51ee782d1a921ebffc8fa0b3f4d520d885/packageurl_python-0.17.3.tar.gz",
"platform": null,
"description": "=================\npackageurl-python\n=================\n\nPython library to parse and build \"purl\" aka. Package URLs.\nSee https://github.com/package-url/purl-spec for details.\n\nJoin the discussion at https://gitter.im/package-url/Lobby or enter a ticket for support.\n\nLicense: MIT\n\nTests and build status\n======================\n\n+----------------------+\n| **Tests and build** |\n+======================+\n| |ci-tests| |\n+----------------------+\n\nInstall\n=======\n::\n\n pip install packageurl-python\n\nUsage\n=====\n::\n\n >>> from packageurl import PackageURL\n\n >>> purl = PackageURL.from_string(\"pkg:maven/org.apache.commons/io@1.3.4\")\n >>> print(purl.to_dict())\n {'type': 'maven', 'namespace': 'org.apache.commons', 'name': 'io', 'version': '1.3.4', 'qualifiers': None, 'subpath': None}\n\n >>> print(purl.to_string())\n pkg:maven/org.apache.commons/io@1.3.4\n\n >>> print(str(purl))\n pkg:maven/org.apache.commons/io@1.3.4\n\n >>> print(repr(purl))\n PackageURL(type='maven', namespace='org.apache.commons', name='io', version='1.3.4', qualifiers={}, subpath=None)\n\nUtilities\n=========\n\nDjango models\n^^^^^^^^^^^^^\n\n`packageurl.contrib.django.models.PackageURLMixin` is a Django abstract model mixin to\nuse Package URLs in Django.\n\nSQLAlchemy mixin\n^^^^^^^^^^^^^^^^\n\n`packageurl.contrib.sqlalchemy.mixin.PackageURLMixin` is a SQLAlchemy declarative mixin\nto use Package URLs in SQLAlchemy models.\n\nURL to PURL\n^^^^^^^^^^^\n\n`packageurl.contrib.url2purl.get_purl(url)` returns a Package URL inferred from an URL.\n\n::\n\n >>> from packageurl.contrib import url2purl\n >>> url2purl.get_purl(\"https://github.com/package-url/packageurl-python\")\n PackageURL(type='github', namespace='package-url', name='packageurl-python', version=None, qualifiers={}, subpath=None)\n\nPURL to URL\n^^^^^^^^^^^\n\n- `packageurl.contrib.purl2url.get_repo_url(purl)` returns a repository URL inferred\n from a Package URL.\n- `packageurl.contrib.purl2url.get_download_url(purl)` returns a download URL inferred\n from a Package URL.\n- `packageurl.contrib.purl2url.get_inferred_urls(purl)` return all inferred URLs\n (repository, download) from a Package URL.\n\n::\n\n >>> from packageurl.contrib import purl2url\n\n >>> purl2url.get_repo_url(\"pkg:gem/bundler@2.3.23\")\n \"https://rubygems.org/gems/bundler/versions/2.3.23\"\n\n >>> purl2url.get_download_url(\"pkg:gem/bundler@2.3.23\")\n \"https://rubygems.org/downloads/bundler-2.3.23.gem\"\n\n >>> purl2url.get_inferred_urls(\"pkg:gem/bundler@2.3.23\")\n [\"https://rubygems.org/gems/bundler/versions/2.3.23\", \"https://rubygems.org/downloads/bundler-2.3.23.gem\"]\n\nRun tests\n=========\n\nInstall test dependencies::\n\n python3 thirdparty/virtualenv.pyz --never-download --no-periodic-update .\n bin/pip install -e .\"[test]\"\n\nRun tests::\n\n bin/pytest tests\n\nMake a new release\n==================\n\n- Start a new release branch\n- Update the CHANGELOG.rst, AUTHORS.rst, and README.rst if needed\n- Bump version in setup.cfg\n- Run all tests\n- Install restview and validate that all .rst docs are correct\n- Commit and push this branch\n- Make a PR and merge once approved\n- Tag and push that tag. This triggers the pypi-release.yml workflow that takes care of\n building the dist release files and upload those to pypi::\n\n VERSION=v0.x.x\n git tag -a $VERSION -m \"Tag $VERSION\"\n git push origin $VERSION\n\n- Review the GitHub release created by the workflow at\n https://github.com/package-url/packageurl-python/releases\n\n.. |ci-tests| image:: https://github.com/package-url/packageurl-python/actions/workflows/ci.yml/badge.svg?branch=main\n :target: https://github.com/package-url/packageurl-python/actions/workflows/ci.yml\n :alt: CI Tests and build status\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A purl aka. Package URL parser and builder",
"version": "0.17.3",
"project_urls": {
"Homepage": "https://github.com/package-url/packageurl-python"
},
"split_keywords": [
"package",
" url",
" package manager",
" package url"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "da3971ca0df9154070661a967edc2a518d612e94782cfe502ab09f180efc224c",
"md5": "f3cc1ad294dfa315f95b8136f4d19a77",
"sha256": "f51b5aab570159f07258c8e998e9972ff3bf060da16b7334a42bd9f9737777d9"
},
"downloads": -1,
"filename": "packageurl_python-0.17.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "f3cc1ad294dfa315f95b8136f4d19a77",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 29942,
"upload_time": "2025-08-01T03:24:33",
"upload_time_iso_8601": "2025-08-01T03:24:33.131386Z",
"url": "https://files.pythonhosted.org/packages/da/39/71ca0df9154070661a967edc2a518d612e94782cfe502ab09f180efc224c/packageurl_python-0.17.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "370f66c682b6d6844247a5ba04e1be51ee782d1a921ebffc8fa0b3f4d520d885",
"md5": "feffccc2f7d3ba0a5f26ad3b7afef24d",
"sha256": "719995f0c7f706890277ba57ec95afcaa9696c836a7675770a1279b01a41f7be"
},
"downloads": -1,
"filename": "packageurl_python-0.17.3.tar.gz",
"has_sig": false,
"md5_digest": "feffccc2f7d3ba0a5f26ad3b7afef24d",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 43004,
"upload_time": "2025-08-01T03:24:35",
"upload_time_iso_8601": "2025-08-01T03:24:35.307952Z",
"url": "https://files.pythonhosted.org/packages/37/0f/66c682b6d6844247a5ba04e1be51ee782d1a921ebffc8fa0b3f4d520d885/packageurl_python-0.17.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-08-01 03:24:35",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "package-url",
"github_project": "packageurl-python",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "packageurl-python"
}