Pypi-simple

Latest version: v1.6.1

Safety actively analyzes 723929 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 2 of 4

1.2.0

-------------------
- Update pydantic to v2.0

1.1.0

-------------------
- Support PEP 700
- `versions` field added to `ProjectPage`
- `size` and `upload_time` fields added to `DistributionPackage`
- `SUPPORTED_REPOSITORY_VERSION` increased to `"1.1"`

1.0.0

-------------------
- Removed deprecated functionality:
- `DistributionPackage.get_digests()`
- `PyPISimple.get_projects()`
- `PyPISimple.get_project_files()`
- `parse_simple_index()`
- `parse_project_page()`
- `parse_links()`
- Drop support for Python 3.6
- Support Python 3.11
- `IndexPage`, `ProjectPage`, `DistributionPackage`, and `Link` have been
changed from NamedTuples to dataclasses
- Replaced `DistributionPackage.yanked` with separate `is_yanked` and
`yanked_reason` attributes
- `parse_filename()` now raises an `UnparsableFilenameError` on unparsable
filenames instead of returning a triple of `None`s
- `PyPISimple.get_project_page()` now raises a `NoSuchProjectError` on 404
responses instead of returning `None`
- The functions for parsing data into `IndexPage` and `ProjectPage` instances
have been replaced with classmethods:
- `parse_repo_index_page()` → `IndexPage.from_html()`
- `parse_repo_index_json()` → `IndexPage.from_json_data()`
- `parse_repo_index_response()` → `IndexPage.from_response()`
- `parse_repo_links()` → `RepositoryPage.from_html()`
- `parse_repo_project_page()` → `ProjectPage.from_html()`
- `parse_repo_project_json()` → `ProjectPage.from_json_data()`
- `parse_repo_project_response()` → `ProjectPage.from_response()`
- Add a `RepositoryPage` class for representing the return value of
`parse_repo_links()` (now called `RepositoryPage.from_html()`)
- Renamed `DistributionPackage.from_pep691_details()` to `from_json_data()`
- `PyPISimple.stream_project_names()` now accepts JSON responses
- Use pydantic internally to parse JSON responses
- Added constants for passing to `PyPISimple` and its methods in order to
specify the `Accept` header to send

0.10.0

--------------------
- Support Python 3.10
- Support PEP 691
- Send "Accept" headers in requests (except for `stream_project_names()`)
listing both the new JSON format and the old HTML format
- `parse_repo_project_response()` and `parse_repo_index_response()` now
support both the JSON and HTML formats
- Add `parse_repo_index_json()` and `parse_repo_project_json()` functions
- Gave `DistributionPackage` a `from_pep691_details()` classmethod
- `DistributionPackage.has_metadata` will now be `None` if not specified by
a JSON response
- `DistributionPackage.metadata_url` is now always non-`None`
- Gave `DistributionPackage` a `digests` attribute
- The `get_digests()` method of `DistributionPackage` is now deprecated;
use `digests` instead
- Digest fragments are now removed from `DistributionPackage.url` when
parsing HTML responses
- Warn on encountering a repository version with a greater minor version than
expected
- Gave `PyPISimple` a `download_package()` method

0.9.0

-------------------
- Support PEP 658 by adding `has_metadata`, `metadata_url`, and
`metadata_digests` attributes to `DistributionPackage`

0.8.0

-------------------
- Support Python 3.9
- `PyPISimple` is now usable as a context manager that will close the session
on exit

Page 2 of 4

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.