Releases: opsmill/infrahub
Infrahub - v1.1.4
Release 1.1.4
This release is a bug-fix release to resolve issues found in Infrahub v1.1.3 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Removed
- Removed configuration option for experimental feature "pull request", since this feature was active in the configuration it has been renamed proposed change and is no longer experimental but always enabled. (#5409)
Added
- Artifacts can now be of type: YAML, XML, markdown, SVG and CSV. (#5452)
Changed
- Updated Infrahub SDK to version 1.6.1.
Fixed
- Fix issue when loading multiple schema files due to load order, schemas are now merged into a single one before importing (#4188)
- Accessibility improvements to homepage: Helper cards now scale based on user's defined font size.
- Task status indicators now poll for updates only when tab is focused.
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.4"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.1.3
Release 1.1.3
This release is a bug-fix release to resolve issues found in Infrahub v1.1.2 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Added
- Add a new link in the object details button to redirect to the tasks list with a filter for the current object
Changed
- Add ID and HFID copy buttons in a new action buttons for the object details (#4648)
- Remove the ID attribute from the list
- Get the description from the object if that's possible, if not then from the schema
- Disable action buttons depending on the on going tasks for the different workflows (merge, rebase, validate)
- Display multiple related nodes in the tasks list and details views
- Changed the default value for the s3.default_acl configuration setting to
private
Fixed
- Prevent access to REST API endpoints for anonymous user when anonymous access is not allowed (#5312)
- Fix pool exhaustion error for IP resource pools when some allocated nodes were deleted (#5315)
- Fix IP address being displayed in IP prefix pool after deleting the allocated prefix it was part of (#5316)
- Fixed text overflow when there is too many options when selecting a relationship with a hierarchical model (#5431)
- Allow to change any attributes and relationships when using a mutation on
CoreAccount
(#5455) - Validate updates to an attribute's
kind
when loading a new schema (#5460)
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.3"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.1.2
Release 1.1.2
This release is a bug-fix release to resolve issues found in Infrahub v1.1.1 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Null values in uniqueness constraints
Previous to v1.1.2, NULL values were incorrectly ignored in uniqueness constraints;
as of this release, NULL values will be treated properly by the uniqueness logic.
Because the previous logic could have resulted in unintended behavior, upgrading v1.1.2 will perform a database migration for data integrity purposes.
Added
- Added a configuration option for INFRAHUB_PUBLIC_URL, which could be required for SSO depending on how Infrahub is published and accessed within your organization. (#5306)
- Add
PermissionManager
that takes care of validating permissions when executing a GraphQL query or a requesting a REST endpoint by fetching permissions from backends only once per query. (#5350) - The query InfrahubTask in GraphQL, introduced a new
related_nodes
field to retrieve multiple related nodes per task.
Changed
- The fields
related_node
andrelated_node_kind
on the GraphQL queryInfrahubTask
have been deprecated, please userelated_nodes
instead.
Fixed
- Fix schema dropdown option removal in branches other than the default one (#5242)
- Fix an issue that would prevent creating a node on a branch with a computed attribute that referenced another node on that branch (#5385)
- Update how we calculate an incremental diff to skip potentially expensive operations if at all possible
- Update uniqueness checks/constraints logic to consider NULL values instead of ignoring.
This might cause data integrity issues if you have nodes with NULL values for attributes that are part of their
the uniqueness constraints of their schema. This change includes a database migration that validates data integrity
using the new uniqueness check/constraint logic and will fail if any uniqueness issues exist.
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.2"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.1.1
Release 1.1.1
This release is a bug-fix release to resolve issues found in Infrahub v1.1.0 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Fixed
- Raise a better error when trying to resolve an invalid HFID for a relationship (#5360)
- Fix an issue with session management that could lead to the crash of the GraphQL resolver
- Fix query response time when the number of historical value for a given attribute is large
- Fixed an issue that prevented using an IP Namespace on a branch
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.1"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.1.0
Release 1.1.0
This release contains both new features and bug-fixes to resolve issues found in Infrahub v1.0.10 and prior.
Main changes
Infrahub 1.1 brings computed attributes, a new (and highly-requested) feature, as well as many behind-the-scenes changes.
See the detailed changelog in the following sections for more information.
Computed attributes
The computed attributes feature enables the dynamic calculation of attribute values based on user-defined logic.
This functionality is valuable in a number of use cases, not least of which is programmatically generating interface or circuit names.
Several users have requested this capability and we are excited to make it available in Infrahub 1.1.
There are two main ways to configure computed attributes, they can be created using either Jinja2 or Python.
For basic use cases, Jinja2-based computed attributes are now available.
To use this style of computed attribute, the user writes a concise Jinja2 template directly into their Schema definition file.
Then, any changes to a field referenced in the template will update the resultant computed attribute automatically.
There are some limitations with Jinja2-based computed attributes however; for example, only direct relationships can be used (a relationship of a relationship is not accessible).
For more complex use cases, with the need for nested relationships or more detailed logic, Python-based computed attributes are also available.
Python-based computed attributes leverage the exiting Python-based transform feature.
Users can define a transformation within the schema to apply to their field, and the attribute is then generated asynchronously by an Infrahub worker.
When using Python-based computed attributes, note that there can be system performance impact with large or complex Python scripts.
See this table in the documentation for a concise comparison of the two types of computed attributes.
Caveats
- Only URL and Text attribute kinds are supported at the moment.
Documentation
For more information on either style of computed attribute, please see the below documentation.
- https://docs.infrahub.app/guides/computed-attributes
- https://docs.infrahub.app/topics/computed-attributes
- https://docs.infrahub.app/topics/transformation
Infrahub task enhancements
As part of Infrahub 1.0, we added a new tool into the system to assist with task management and control.
In Infrahub 1.1, we have now begun to migrate key backend system tasks over to this tool.
What this means in practice for the user is that now Infrahub tasks will have more robust error reporting and supervision.
Some example tasks run in the background by the updated task worker and framework are:
- Rendering a Jinja template.
- Rendering a transform function.
- Executing a check.
- All Git operations (pull/merge/diff).
All of these and more will benefit from migration to the new task framework, providing additional logging capabilities and overall supervision and control.
Finally, this updated task framework has allowed us to add an indicator at the top right of the Infrahub window to give users task status at a glance.
For example, a section of the indicator will change color when tasks are running.
This indicator also serves as quick access to view in-progress or completed tasks.
Remove shared storage requirements for Git
Previous to Infrahub 1.1, task workers needed access to shared storage such as NFS in order to function.
As of 1.1 this requirement is removed, and users are able to distribute task workers without needing shared storage for local Git repositories.
Each task worker now manages its own copy of any required Git repository.
This change not only simplifies deployment of Infrahub in some scenarios, but increases the overall reliability of the system.
Changelog
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Removed
- Remove at parameter from GraphQL mutate functions (#3587)
- Remove the "role" attribute of base schema account node. This attribute was no longer useful as roles are defined as dedicated nodes and are tightly related to permissions.
- Remove the /api/diff/data and /api/diff/schema endpoints that have been replaced by the DiffTree GraphQL query
Added
- Add support for computed attributes. The computed attributes allows you to define a schema attribute as read only and provide logic for how the attribute should be updated. The logic that updates a computed attribute can be a Jinja2 template or a Python Transform. Aside from the initial creation when using a Jinja2 template the updates will be done asynchronously in the background. (#3637)
- Add a "deprecation" property to attribute and relationship schema in order to allow users to identify deprecated fields for nodes and provide a user-friendly message about the deprecation reasons. (#4245)
- Enhanced relationship inputs for hierarchical models with a new way to navigate and select objects directly within the hierarchy. (#4636)
- Add ability to use node HFID to create a related node on a generic relationship (#4649)
Changed
- More efficient logic for retrieving cardinality-one relationships within a GraphQL query (#522)
- Change strings referring to file system paths to pathlib.Path objects (#3545)
- Improved response time of menu endpoint
Fixed
-
Fix search anywhere so it looks at Groups (#3173)
-
Display the IP Namespace for prefixes and IP addresses in the search anywhere (#3577)
-
Use the repository object ID as name for its git working copy directory (#4296)
-
Search anywhere now supports IPv6 extended format (#4613)
-
- Update action buttons UI in the branch details view
- Pre-fill the source branch select when creating a proposed change from the branch details view
(#4678)
-
Synchronise git repository clones and updates for task workers in order to remove the need for a shared storage (#4789)
-
FIX: Resolved edge cases in 'Search Anywhere' that were causing old results to be displayed. (#4863)
-
Remove Profile in registry for renamed schema nodes (#4909)
-
Forbid changing the "optional" property of an inherited attribute to not break GraphQL schema generation (#4936)
-
Send a request to the backend on logout to delete session cookies and prevent remaining information (#4962)
-
Fix query to correctly send the variables in the tasks details view (#5002, #5118)
-
Update alerts type on errors with proposed changes and branches (#5293)
-
- Verify the tasks related to the proposed changes view to show or hide the tasks accordion in the details view
- Disable the merge button if there is an ongoing merge
- Add poll-interval to the proposed changes query to be up to date on the state and disable the merge button if the proposed change is already merged
-
Add support for irresolvable conflicts to the diff logic and DiffTree GraphQL query
-
Fix a bug that prevented updating a relationship during a merge if ONLY the metadata was updated and not the peer.
-
Fix permission check when using multiple backends, if one grants a permission the next ones must not be queried.
-
Update logic to check if the changes on a branch include schema changes to use the new diff
-
Update the api/diff/artifacts endpoint to use a dedicated query
-
Verify if the requested branch exists. If it doesn't, it redirects to the homepage on the default branch.
This helps avoid query issues, such as empty results (for example, an empty menu) or incorrect queries being sent.
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.0"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied ...
Infrahub - v1.0.10
Release 1.0.10
This release is a bug-fix release to resolve issues found in Infrahub v1.0.9 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Added
- Make URL fields clickable in the details view (#5005)
Fixed
- Support directionality in the query to get all peer IDs for a given group of nodes (#3065)
- Fix errors when executing
infrahub db update-core-schema
command that were impacting migrations from prior versions (#5186, #5254)
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.0.10"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.0.9
Release 1.0.9
This release is a bug-fix release to resolve issues found in Infrahub v1.0.8 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Added
- Adding
invoke
tasks to assist with release process. (#4519) - Add pagination and backend search in new combobox for relationships.
- Added custom Towncrier template to remove extra space after new Changelog entries.
- In schema viewer, we now display
Hierarchical
value for generics.
Fixed
- Update delete constraints to correctly account for relationships on generics and relationships for which the peer kind is a generic. (#4332)
- Fix error when
pool
was used a relationship name. (#4807) - Ensure that deleted schema nodes are removed from all workers and that the schema is in sync without having to restart. (#4836)
- Consistently use "Save" on all object forms submit buttons. (#4850)
- Search shortcuts show
Cmd
on macOS andCtrl
on other systems. (#4861) - Update the parent relationship query to populate the dropdown options when editing an object, ensuring the current parent is correctly selected for the current node. (#5035)
- Correctly refresh menu after access token has expired. (#5099)
- On the object permission form, fix the name option selection when changing the namespace to get the latest options and to be able to choose a name option. (#5100)
- Prevent adding a new mandatory attribute or relationship to the schema if some nodes are already present in the database. (#5106)
- Refresh branch hash on local worker during branch create. (#5130)
- Fix uniqueness constraint check with enum based attributes. (#5132)
- Editing old
CHANGELOG.md
entries to use uniform formatting from new Towncrier template. - Store CoreProfile in database to ensure consistent initial schema hash. Prior to this the schema was reported as being out of sync when starting the application for the first time. This error wouldn't have hade any impact but was confusing. The workaround would be to load a schema or restart the application at least once after first time initialization.
- Use the branch uuid instead of the internal database id to track the hash of the schema in the cache.
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.0.9"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.1.0b2
Release 1.1.0 Beta 2
This is a preview release of Infrahub v1.1.0.
This release contains both new features and bug-fixes to resolve issues found in Infrahub v1.0.9 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Removed
- Remove at parameter from GraphQL mutate functions (#3587)
- Remove the "role" attribute of base schema account node. This attribute was no longer useful as roles are defined as dedicated nodes and are tightly related to permissions.
- Remove the /api/diff/data and /api/diff/schema endpoints that have been replaced by the DiffTree GraphQL query
Added
- Add a "deprecation" property to attribute and relationship schema in order to allow users to identify deprecated fields for nodes and provide a user-friendly message about the deprecation reasons. (#4245)
- Add ability to use node HFID to create a related node on a generic relationship (#4649)
Changed
- Change strings referring to file system paths to pathlib.Path objects (#3545)
Fixed
- Fix search anywhere so it looks at Groups (#3173)
- Use the repository object ID as name for its git working copy directory (#4296)
- Search anywhere now supports IPv6 extended format (#4613)
- Synchronize Git repository clones and updates for task workers in order to remove the need for a shared storage (#4789)
- FIX: Resolved edge cases in 'Search Anywhere' that were causing old results to be displayed. (#4863)
- Remove Profile in registry for renamed schema nodes (#4909)
- Forbid changing the "optional" property of an inherited attribute to not break GraphQL schema generation (#4936)
- Send a request to the backend on logout to delete session cookies and prevent remaining information (#4962)
- Add support for irresolvable conflicts to the diff logic and DiffTree GraphQL query
- Fix a bug that prevented updating a relationship during a merge if ONLY the metadata was updated and not the peer.
- Fix permission check when using multiple backends, if one grants a permission the next ones must not be queried.
- Update logic to check if the changes on a branch include schema changes to use the new diff
- Update the api/diff/artifacts endpoint to use a dedicated query
- Verify if the requested branch exists. If it doesn't, it redirects to the homepage on the default branch.
This helps avoid query issues, such as empty results (for example, an empty menu) or incorrect queries being sent.
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.0"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
Infrahub - v1.0.8
Release 1.0.8
This release is a bug-fix release to resolve issues found in Infrahub v1.0.7 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Added
- Add
sso_user_default_group
security setting to provide the name of a group to which SSO users will be assigned if the identity provider does not gives a list of groups to use (#4924) - Added a 'append_git_suffix' configuration setting for Git repositories that allows you to define domains for auto appending '.git' to repositories defined with an HTTP URL (#5077)
Fixed
-
Loosened up logic to determine when an artifact needs to be regenerated during a proposed change. This is to ensure that we always generate a new artifact if required. Until some other parts are refactored this will also need that we will generate artifacts in a few situations where it's not strictly required. This last part is a temporary solution. (#4198)
-
Migrates from headless UI combobox to
cmdk
to resolve focus behavior issues when there is no result in the search anywhere (#4715) -
Fix GraphQL mutations to make user permissions updates work correctly
- Update the alert message to better reflect the changes (between creation and update)
- Fix the objects delete modal on the global permission view
- Fix the global permission update mutation
-
Validate that a deleted schema node is not used in any relationship when loading a new schema (#4912)
-
Set content type of artifact when rendered to fix artifact content type if artifact definition has changed (#4969)
-
Raise error if pool allocation misses data to create node (#5006)
-
Process new schema before replacing branch in registry to avoid causing the GraphQL schema to be generated while the new schema is still loading (#5008)
-
Added a check on repository import and sync to wait until the schema has converged before importing additional objects when the repository contains an updated schema (#5051)
-
Fix artifact definition targets when changed in repository so that it's reflected in the database (#5060)
-
GraphQL query with filters on attribute of type List return the expected result (#5091)
-
Prevent adding a new mandatory attribute or relationship to the schema if some nodes are already present in the database (#5106)
-
Ensure that permission queries are run in non isolated mode so that updates from the default branch are automatically reflected in other branches (#5110)
-
Add retry for transient database errors during IP reconciliation tasks
-
Corrected configuration for prefect worker to never prompt for Git credentials on the console
-
Fix artifact object relationship by enforcing it to be an artifact target
-
Fix bug in IP reconciliation query around deleted nodes and relationships
-
Fix issue that could cause diff generation to crash if a schema was renamed
-
Fixes a bug that prevented running a generator from a read-only repository
-
Generator groups are correctly created after merging a proposed change
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.0.8"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.
Infrahub - v1.1.0b1
Release 1.1.0 Beta 1
This is a preview release of Infrahub v1.1.0.
This release contains both new features and bug-fixes to resolve issues found in Infrahub v1.0.7 and prior.
Main changes
The complete list of changes can always be found in the CHANGELOG.md
file in the Infrahub Git repository.
Removed
- Remove at parameter from GraphQL mutate functions (#3587)
- Remove the "role" attribute of base schema account node
- This attribute was no longer useful as roles are defined as dedicated nodes and are tightly related to permissions
- Remove the /api/diff/data and /api/diff/schema endpoints that have been replaced by the DiffTree GraphQL query
Added
- Add a "deprecation" property to attribute and relationship schema in order to allow users to identify deprecated fields for nodes and provide a user-friendly message about the deprecation reasons (#4245)
- Add ability to use node HFID to create a related node on a generic relationship (#4649)
Fixed
- Fix search anywhere so it looks at Groups (#3173)
- Loosened up logic to determine when an artifact needs to be regenerated during a proposed change. This is to ensure that we always generate a new artifact if required. Until some other sections are refactored this will also mean that Infrahub will generate artifacts in a few situations where it's not strictly required. This last part is a temporary solution. (#4198)
- Use the repository object ID as name for its git working copy directory (#4296)
- Search anywhere now supports IPv6 extended format (#4613)
- Synchronise git repository clones and updates for task workers in order to remove the need for a shared storage (#4789)
- Remove Profile in registry for renamed schema nodes (#4909)
- Forbid changing the "optional" property of an inherited attribute to not break GraphQL schema generation (#4936)
- Add support for irresolvable conflicts to the diff logic and DiffTree GraphQL query
- Fix a bug that prevented updating a relationship during a merge if ONLY the metadata was updated and not the peer
- Fix permission check when using multiple backends, if one grants a permission the next ones must not be queried
- Update the api/diff/artifacts endpoint to use a dedicated query
Migration guide
The process to migrate your instance of Infrahub to the latest version may vary depending on your deployment of Infrahub.
However, at a high-level, it will involve getting the latest version of the Infrahub code, and then performing any needed Database Migrations and Schema updates.
Please ensure you have a backup of your Infrahub environment prior to attempting any migration or upgrade activities.
Migration of an Infrahub instance
First, update the Infrahub version running in your environment.
Below are some example ways to get the latest version of Infrahub in your environment.
- For deployments via Docker Compose, update your container version by updating the
VERSION
environment variable and relaunch:export VERSION="1.1.0"; docker compose pull && docker compose up -d
- For deployments via Kubernetes, utilize the latest version of the Helm chart supplied with this release
Second, once you have gotten the desired version of Infrahub in your environment, please run the following commands.
Note: If you are running Infrahub in Docker/K8s, these commands need to run from a container where Infrahub is installed.
infrahub db migrate
infrahub db update-core-schema
Finally, restart all instances of Infrahub.
Migration of a dev or demo instance
If you are using the dev
or demo
environments, we have provided invoke
commands to aid in the migration to the latest version.
The below examples provide the demo
version of the commands, however similar commands can be used for dev
as well.
invoke demo.stop
invoke demo.build
invoke demo.migrate
invoke demo.start
If you don't want to keep your data, you can start a clean instance with the following command.
Warning: All data will be lost, please make sure to backup everything you need before running this command.
invoke demo.destroy demo.build demo.start demo.load-infra-schema demo.load-infra-data
The repository https://github.com/opsmill/infrahub-demo-edge has also been updated, it's recommended to pull the latest changes into your fork.