Skip to content

Releases: opsmill/infrahub-sdk-python

Version 1.12.0

30 Apr 13:59
Compare
Choose a tag to compare

This release of the SDK introduces the capability to convert query responses to InfrahubNode objects in Transforms, as well as the branch parameter in the client.clone() method.

Added

  • Added the ability to convert the query response to InfrahubNode objects when using Python Transforms in the same way you can with Generators. (#281)
  • Added a "branch" parameter to the client.clone() method to allow properly cloning a client that targets another branch.

Version 1.11.1

28 Apr 14:50
9855534
Compare
Choose a tag to compare

This version of the SDK contains a minor change to fix how HFID functions for nodes with cardinality of many relationships.

Changed

  • Set the HFID on related nodes for cardinality many relationships, and add HFID support to the RelationshipManager add, extend and remove methods.

Version 1.11.0

17 Apr 17:18
06fff9d
Compare
Choose a tag to compare

This release focusing mainly on improving the user/developer experience with a new command to load data into Infrahub, some improvements around Python Typing as well as some fixes

Main changes

Manage data in yaml format using Object files

The new infrahubctl commands object load and object validate allows you to manage data to be loaded in Infrahub based on your own custom schema. It provides a declarative way to define and manage resources in your Infrahub instance.

Object files work well for models that don't change too often and/or that need to be tracked in Git. Examples include: Groups, tags, Users, etc.
Below is an example of an Object file that defines tags (BuiltinTag).

---
apiVersion: infrahub.app/v1
kind: Object
spec:
  kind: BuiltinTag
  data:
    - name: Blue
    - name: Yellow
    - name: Red

More information is available in the documentation

New user guide on how to use Python's type system effectively with the Infrahub SDK

A new guide is available in the documentation to explain how to leverage Python's type system better with the Python SDK by leveraging Python Protocols.

Changelog

Deprecated

  • The 'timeout' parameter while creating a node or fetching the schema has been deprecated. the default_timeout will be used instead.

Added

  • Add support for object Template when generating protocols (#329)
  • Add a Guide related to Python Typing
  • Add method client.schema.set_cache() to populate the cache manually (primarily for unit testing)
  • By default, schema.fetch will now populate the cache (this behavior can be changed with populate_cache)
  • Add menu validate command to validate the format of menu files.

Fixed

  • Raise a proper branch not found error when requesting a node or schema for a branch that doesn't exist. (#286)
  • Fix support for Sync when generating Python Protocols

Housekeeping

  • Add invoke lint-doc command to help run the docs linters locally
  • Add a fixture to always reset some environment variables before running tests
  • Update Pytest-httpx and set all responses as reusable

Version 1.10.2

11 Apr 09:38
dabb7c9
Compare
Choose a tag to compare

1.10.2 - 2025-04-11

Fixed

  • fix an issue where nodes attributes were not updated when setting the same value than the one used during node instantiation
  • fixes an issue where the default branch of the client store was not properly set in a generator

Version 1.10.1

04 Apr 16:20
d22626a
Compare
Choose a tag to compare

This version includes only one small change to help with the troubleshooting of a potential issue.

Changed

  • Improve error message when a schema received from the server is not JSON valid. The new exception will be of type infrahub_sdk.exceptions.JsonDecodeError instead of json.decoder.JSONDecodeError

Version 1.10.0

01 Apr 11:43
5bee453
Compare
Choose a tag to compare

This version of the Python SDK includes some improvement around Jinja2 templating with the addition of new Jinja2 filters (thanks to the netutils library) and some improvements of the object store, as well as some bug fixes.

Deprecated

  • The method get_by_hfid on the object Store has been deprecated, use get(key=[hfid]) instead
  • Using a Store without specifying a default branch is now deprecated and will be removed in a future version.

Added

  • All nodes generated by the SDK will now be assigned an internal_id (_internal_id). This ID has no significance outside of the SDK.
  • Jinja2 templating has been refactored to allow for filters within Infrahub. Builtin filters as well as those from Netutils are available.
  • The object store has been refactored to support more use cases in the future and it now properly support branches.

Fixed

  • Fix node processing, when using fragment with prefetch_relationships. (#331)

Version 1.9.2

26 Mar 17:52
eda8705
Compare
Choose a tag to compare

Changed

  • Remove hfid in upsert payload, to improve node upsert performances

Version 1.9.1

21 Mar 16:37
Compare
Choose a tag to compare

1.9.1 - 2025-03-21

Fixed

  • Fixed an issue where the process_nodes method in the generators used the old format of the schema hash, so node population didn't work

Version 1.9.0

21 Mar 13:53
a56a48e
Compare
Choose a tag to compare

1.9.0 - 2025-03-21

Added

  • Add 'schema_hash' parameter to client.schema.all to only optionally refresh the schema if the provided hash differs from what the client has already cached. (#152)

Changed

  • CoreStandardGroups created or updated by a generator in Infrahub are now stored as a member of the CoreGeneratorGroup. Previously they were being stored as children of the CoreGeneratorGroup.

Fixed

  • The SDK client query methods (get, filters, all) default behaviour has changed. The query methods will store the retrieved nodes in the internal store by default, where previously this behaviour had to be enabled explicitly using the populate_store argument. (#15)

Version 1.8.0

20 Mar 02:18
d040800
Compare
Choose a tag to compare

1.8.0 - 2025-03-19

Deprecated

  • Timestamp: Direct access to obj and add_delta have been deprecated and will be removed in a future version. (#255)

Added

  • Added support for Enum in GraphQL query and mutation. (#18)

Fixed

  • Refactored Timestamp to use whenever instead of pendulum and extend Timestamp with add(), subtract(), and to_datetime(). (#255)
  • Fixed support for Python 3.13 as it's no longer required to have Rust installed on the system.