Pyppms

Latest version: v3.3.0

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

Scan your dependencies

Page 2 of 2

2.2.0

Added

- `pyppms.ppms.PpmsConnection.flush_cache()` to flush the on-disk cache with an
optional argument `keep_users` (defaulting to `False`) that allows for
flushing the entire cache **except** for the user **details**. This provides
the opportunity of refreshing the cache on everything but *existing* users.
Note that this will **not** affect **new** users, they will still be
recognized and fetched from PUMAPI (and stored in the cache).

Changed

- `pyppms.ppms.PpmsConnection.get_systems_matching()` now raises a `TypeError`
in case the parameter `name_contains` is accidentially as `str` instead of a
list.
- `pyppms.ppms.PpmsConnection.get_running_sheet()` now has an optional parameter
`ignore_uncached_users` (defaulting to `False`) that allows to process the
running sheet even if it contains users that are not in the `fullname_mapping`
attribute.
- If the `cache_path` attribute is set for an `pyppms.ppms.PpmsConnection`
instance but creating the actual subdir for an intercepted response fails
(e.g. due to permission problems) the response-cache will not be updated.
Before, the exception raised by the underlying code (e.g. a `PermissionError`)
was passed on.
- Methods of `pyppms.ppms.PpmsConnection` are now sorted in alphabetical order,
making it easier to locate them e.g. in the API documentation.

Removed

- The following previously deprecated (or not even implemented) methods of
`pyppms.ppms.PpmsConnection` have been removed in favor of
`pyppms.ppms.PpmsConnection.get_systems_matching()`:
- `_get_system_with_name()`
- `_get_machine_catalogue_from_system()`
- `get_bookable_ids()`
- Removed the stub `pyppms.ppms.PpmsConnection.get_system()` that was only
raising a `NotImplementedError`.

2.1.0

Changed

- [API] `pyppms.ppms.PpmsConnection.get_user()` and
`pyppms.ppms.PpmsConnection.get_user_dict()` now both accept an optional
parameter `skip_cache` that is passed on to the
`pyppms.ppms.PpmsConnection.request()` call
- [FIX] `pyppms.ppms.PpmsConnection.update_users()` now explicitly asks for the
cache to be skipped

2.0.0

Changed

- [API] 🧨 the signature for `pyppms.user.PpmsUser` has been changed and now
expects a single argument (the PUMAPI response text)
- [API] 🧨 the constructor signature for `pyppms.system.PpmsSystem()` has been
changed and now expects a single argument (a dict as generated by
`pyppms.common.parse_multiline_response()`)
- [API] 🧨 the constructor signature for `pyppms.booking.PpmsBooking()` has been
changed and now expects the PUMAPI response text, the booking type (if the
booking is currently running or upcoming) and the system ID
- [API] 🧨 the following methods have been removed as their behavior is now
achieved by the corresponding default constructor of the respective class:
- `pyppms.user.PpmsUser.from_response()`
- `pyppms.system.PpmsSystem.from_parsed_response()`
- `pyppms.booking.PpmsBooking.from_booking_request()`

Page 2 of 2

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.