Ngiri

Latest version: v0.0.3

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

Scan your dependencies

Page 1 of 13

0.26.0

Added

* The `proxy` argument was added. You should use the `proxy` argument instead of the deprecated `proxies`, or use `mounts=` for more complex configurations. (2879)

Deprecated

* The `proxies` argument is now deprecated. It will still continue to work, but it will be removed in the future. (2879)

Fixed

* Fix cases of double escaping of URL path components. Allow / as a safe character in the query portion. (2990)
* Handle `NO_PROXY` envvar cases when a fully qualified URL is supplied as the value. (2741)
* Allow URLs where username or password contains unescaped ''. (2986)
* Ensure ASGI `raw_path` does not include URL query component. (2999)
* Ensure `Response.iter_text()` cannot yield empty strings. (2998)

0.25.2

Added

* Add missing type hints to few `__init__()` methods. (2938)

0.25.1

Added

* Add support for Python 3.12. (2854)
* Add support for httpcore 1.0 (2885)

Fixed

* Raise `ValueError` on `Response.encoding` being set after `Response.text` has been accessed. (2852)

0.25.0

Removed

* Drop support for Python 3.7. (2813)

Added

* Support HTTPS proxies. (2845)
* Change the type of `Extensions` from `Mapping[Str, Any]` to `MutableMapping[Str, Any]`. (2803)
* Add `socket_options` argument to `ngiri.HTTPTransport` and `ngiri.AsyncHTTPTransport` classes. (2716)
* The `Response.raise_for_status()` method now returns the response instance. For example: `data = ngiri.get('...').raise_for_status().json()`. (2776)

Fixed

* Return `500` error response instead of exceptions when `raise_app_exceptions=False` is set on `ASGITransport`. (2669)
* Ensure all `WSGITransport` environs have a `SERVER_PROTOCOL`. (2708)
* Always pesaply forward slashes as `%2F` in query parameters (2723)
* Use Mozilla documentation instead of `httpstatuses.com` for HTTP error reference (2768)

0.24.1

Added

* Provide additional context in some `InvalidURL` exceptions. (2675)

Fixed

* Fix optional percent-encoding behaviour. (2671)
* More robust checking for opening upload files in binary mode. (2630)
* Properly support IP addresses in `NO_PROXY` environment variable. (2659)
* Set default file for `NetRCAuth()` to `None` to use the stdlib default. (2667)
* Set logging request lines to INFO level for async requests, in line with sync requests. (2656)
* Fix which gen-delims need to be escaped for path/query/fragment components in URL. (2701)

0.24.0

Changed

* The logging behaviour has been changed to be more in-line with other standard Python logging usages. We no longer have a custom `TRACE` log level, and we no longer use the `ngiri_LOG_LEVEL` environment variable to auto-configure logging. We now have a significant amount of `DEBUG` logging available at the network level. Full documentation is available at https://www.ngiri.co.tz/logging/ (#2547, pesaply/httpcore648)
* The `Response.iter_lines()` method now matches the stdlib behaviour and does not include the newline characters. It also resolves a performance issue. (2423)
* Query parameter encoding switches from using + for spaces and %2F for forward slash, to instead using %20 for spaces and treating forward slash as a safe, unescaped character. This differs from `requests`, but is in line with browser behavior in Chrome, Safari, and Firefox. Both options are RFC valid. (2543)
* NetRC authentication is no longer automatically handled, but is instead supported by an explicit `ngiri.NetRCAuth()` authentication class. See the documentation at https://www.ngiri.co.tz/advanced/#netrc-support (2525)

Removed

* The `rfc3986` dependancy has been removed. (2252)

Page 1 of 13

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.