All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Support for longer-form CVE identifies.
- Dependency updates.
- Updated
certifi
dependency to latest version.
runzero.types.ImportAsset
now supports associating services with an asset by adding arunzero.types.Service
type to be set on theImportAsset.services
field.- Updated
certifi
dependency to latest version.
- Fixed IDE autocompletion naming for the Software and Vulnerability classes by modifying the underlying class names which previously did not match the exported class name.
- Patched
urllib3
dependency to latest version to resolveCVE-2023-45803
.
- A number of type conversions have been added for user convenience.
- The
hostnames
field ofrunzero.types.ImportAsset
now accepts valid strings in addition to therunzero.types.Hostname
type in the list of inputs. - The
tags
field ofrunzero.types.ImportAsset
now accepts valid strings in addition to therunzero.types.Tag
type in the list of inputs. - The
ipv4_addresses
field ofrunzero.types.NetworkInterface
now accepts valid strings in addition to theIPv4Address
type in the list of inputs. - The
ipv6_addresses
field ofrunzero.types.NetworkInterface
now accepts valid strings in addition to theIPv6Address
type in the list of inputs. - The
service_address
field ofrunzero.types.Software
now accepts valid strings in addition to theIPv4Address
/IPv6Address
types. - The
service_address
field ofrunzero.types.Vulnerability
now accepts valid strings in addition to theIPv4Address
/IPv6Address
types.
- The
runzero.types.ImportAsset
now supports associating vulnerabilities with an asset by adding arunzero.types.Vulnerability
type to be set on theImportAsset.vulnerabilities
field.runzero.types.ImportAsset
now supports associating software with an asset by adding arunzero.types.Software
type to be set on theImportAsset.software
field.runzero.types.ImportAsset.custom_attributes
no longer requires using theCustomAttribute
type to wrap your string values. You can now use aDict[str, str]
directly.runzero.types.CustomAttribute
has been deprecated and will be removed in thev1.0
release of the SDK.- Updated license requirement verbiage to reflect the new Platform license requirement.
- Added official support for Python 3.12.
- The SDK now supports the
exclude_unknown
option in theImportTask
object which will ignore any asset that does not merge into an existing asset in your inventory. - Updated the
create_upload_custom_integration
example file to highlight theexclude_unknown
functionality.
- Improved the validation on the
ImportAsset
class to now catch and surface issues with thecustom_attributes
field which would have caused an import task to fail during processing. - Added new
runzero.ValidationError
andrunzero.types.AddressValueError
exceptions as part of the SDK package exports. - Updated dependencies to require the latest version of both
requests
andcertifi
as both contained security updates.
- Improved project documentation and tests.
- Moved to PyPI's new and more secure Trusted Publisher workflow for package maintainers.
- Removed spurious run_zero_id from NewAssetImport requests - a change made alongside updated OpenAPI spec.
- Added ability to hide and halt or unschedule scans/tasks.
- Added autogenerated HTML project documentation which publishes to https://github.com/runZeroInc/runzero-sdk-py in cadence with releases.
- Added task, scan, and template management capabilities to SDK.
- Added explorer management capabilities to SDK.
- Added hosted zone enumeration to SDK.
- Added source_id field to Task objects.
- Updated example code to demonstrate forcing data to be merged onto a known runZero asset ID, allowing for arbitrary asset matching, programmatically defined.
- Increase supported custom integration icon size from 32x32 to 256x256
- Loosen restrictions on MAC address input validation, permitting all types that the runZero platform can accept.
- Remove ability to specify last seen timestamp on asset imports. Though the server retained the timestamp as a custom property, it is not a merge-able property. This is likely to cause confusion. API users are advised to use any invented custom property to hold this value.
- Added new 'RateLimitError' exception to inform the user when they reach their daily usage limit.
- Rename all occurrences in API docs, models, types, routes of 'sources' or 'custom sources' with 'custom integrations'
- Require the latest version of transitive dependency 'certifi'.
- Simplified and restructured the imports for the runzero sdk so that all type definitions come from the
runzero.types
module, all API managers come from therunzero.api
module, and only named exceptions and the client come from the rootrunzero
module. - Improved the ergonomics of the
Tag
,Hostname
, andCustomAttributes
types. - Removed the
asset_from_json
andasset_from_csv
functions. In place of those functions, we are now providing an example of how to transform your data into anImportAsset
for uploading. This enables users to handle converting their own data much more accurately than an abstracted function ever could.
Initial beta release
- Authentication and connection
- Crud operations on sites, tasks, organizations, custom asset data integrations
- Custom asset data transformation
- Uploadable custom assets