Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Version-based migration service #344

Closed
gamerover98 opened this issue Aug 6, 2023 · 1 comment · Fixed by #346
Closed

Version-based migration service #344

gamerover98 opened this issue Aug 6, 2023 · 1 comment · Fixed by #346
Milestone

Comments

@gamerover98
Copy link
Contributor

gamerover98 commented Aug 6, 2023

Description

Currently, ConfigMe lacks versioning capabilities, making it challenging to update configurations without issues and data loss.

Scenario
Imagine that you are using ConfigMe to generate a YAML configuration file for an application. Currently, the library does not support version control for the generated configuration files.
Here's what happens:

  1. Initial Configuration:
    You create the initial configuration file with all properties for the first version of the application.
    This is the configuration of the first version:
potato:
  price: 10
  count: 100
tomato:
  price: 5
  count: 150
  1. Software Update:
    The team releases a new version of the application with a lot of changes:
shelf:
  - name: potato
    price: 10
    count: 100
  - name: tomato
    price: 5
    count: 150

As a result, the software update should have a way to convert from the first to the second configuration and so on.
At the current ConfigMe release (1.3.1), the SettingsHolder will overwrite the old file with the new settings so, this may incur data loss and issues.


To address this problem, the proposed feature aims to introduce version control support in ConfigMe. By incorporating a "config-version" parameter to manage the version compatibility, ConfigMe can enable users to smoothly transition between different configuration versions while avoiding data loss and strange behavior. I guess that what we'd need is a class or override method that allows us to do the things said above.


Looking forward to your feedback and collaboration on this enhancement.
Thank you 💯


Edit

Probably, I'm blind and I never seen the migration service.
The only thing to do now adds specific functionalities to a custom implementation of the MigrationService interface by adding a version control system.

My idea is now to create a YAML file with a property called "config-version" or "version" and according to this value, the "VersionMigrationService" should be able to migrate all things.

@ljacqu
Copy link
Member

ljacqu commented Aug 9, 2023

Breaking changes

  • PlainMigrationService#moveProperty has been moved to MigrationUtils#moveProperty

@ljacqu ljacqu changed the title Proposal for New Feature - Version Control Support Version-based migration service Aug 10, 2023
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Development

Successfully merging a pull request may close this issue.

2 participants