-
Notifications
You must be signed in to change notification settings - Fork 521
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Remove host container migration #4324
base: develop
Are you sure you want to change the base?
Remove host container migration #4324
Conversation
Updated the `commit_transaction` function to enable committing metadata from pending transactions. In commit transaction we will first commit metadata and then pending keys to correctly perform the check to identify if key exists or not. The strength handling among pending and committed transaction is as: If pending metadata is strong and committed metadata is weak, commit the pending setting. If pending metadata is weak, committed metadata is strong and the setting is already available, do not downgrade from strong to weak. Otherwise add the strength file with value as weak. If pending and committed metadata are the same, no action is performed. Additionally, made minor changes to metadata functions for improved access and flexibility: Introduced a `committed` field to dynamically access metadata in pending transactions. Replaced the hardcoded use of live committed metadata with this committed variable ans pass Committed::Live from previous usages. Refer commit: bottlerocket-os/bottlerocket-core-kit@20a435e Refer PR: bottlerocket-os/bottlerocket-core-kit#294
…o table Update the source from string like: schnauzer-v2 render --requires 'aws@v1(helpers=[ecr-prefix])' --template '{{ ecr-prefix settings.aws.region }}/bottlerocket-admin:v0.11.14' To setting generator as object, that contains: - command - strength - skip-if-populated
…r to table Update the source from string like: public.ecr.aws/bottlerocket/bottlerocket-admin:v0.11.14 To setting generator as object, that contains: - command - strength - skip-if-populated
We need to add these to match changes in Bottlerocket-core-kit Refer commit: bottlerocket-os/bottlerocket-core-kit@a72f6bd PR: bottlerocket-os/bottlerocket-core-kit#294
… struct - RemoveWeakSettingsMigration: When we downgrade multiple version to a version where migrator is not aware of deleting the setting-generator as struct or the strength file. This migration will help us to delete the strength and setting generator metadata. - MetadataStringToStructMigration: migration to change host-containers source metadata to struct from string. - ReplaceSettingWithSettingGeneratorMigration: Migration to replace a setting with setting generator. This migration will be used to convert a strong setting to a weak setting.
…bject This migration will change the public control host-container source to setting-generator metadata(that will generate source using sundog) on forward migration. In backward migration, it will reset the value of the source as string.
This migration will change the aws admin host-container source setting-generator from string to object setting-generator metadata (that will generate source using sundog) on forward migration. We will also add a strength file with value "weak". In backward migration, it will reset the value of the source setting generator as string and delete the strength metadata.
…bject This migration will change the public control host-container source to setting-generator metadata(that will generate source using sundog) on forward migration. In backward migration, it will reset the value of the source as string.
We need this migration that will delete all the weak settings and setting-generators.
This migration will change the public admin host-container source to setting-generator metadata(that will generate source using sundog) on forward migration. In backward migration, it will reset the value of the source as string.
f3531f7
to
b77efc3
Compare
☝️ Changed the Version in Twoliter.toml |
command = "schnauzer-v2 render --requires 'aws@v1(helpers=[ecr-prefix])' --template '{{ ecr-prefix settings.aws.region }}/bottlerocket-control:v0.7.18'" | ||
strength = "weak" | ||
skip-if-populated = true | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[metadata.settings.host-containers.admin.source.setting-generator] | ||
command = "schnauzer-v2 render --requires 'aws@v1(helpers=[ecr-prefix])' --template '{{ ecr-prefix settings.aws.region }}/bottlerocket-admin:v0.11.14'" | ||
strength = "weak" | ||
skip-if-populated = true |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't skip-if-populated
default to true? Can we omit this?
#[snafu(display("Unable to de-serialize data: {}", source))] | ||
DeSerialize { source: serde_json::Error }, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
#[snafu(display("Unable to de-serialize data: {}", source))] | |
DeSerialize { source: serde_json::Error }, | |
#[snafu(display("Unable to deserialize data: {}", source))] | |
Deserialize { source: serde_json::Error }, |
setting: "settings.host-containers.control.source", | ||
old_val: OLD_CONTROL_CTR, | ||
new_val: NEW_CONTROL_CTR, | ||
setting_gen_command: "emitter public.ecr.aws/bottlerocket/bottlerocket-control:v0.7.17", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't understand where emitter
comes from.
migrate(ReplaceSettingWithSettingGeneratorMigration { | ||
setting: "settings.host-containers.control.source", | ||
old_val: OLD_CONTROL_CTR, | ||
new_val: NEW_CONTROL_CTR, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's confusing to me to mix settings changes with metadata changes.
I would model this with a pair of migration types:
RemoveSchnauzerMigration
- likeReplaceSchnauzerMigration
, but removes the setting on upgrade if it matches. No-op on downgrade, likeRemoveMetadataMigration
.- Maybe
ResetMetadataMigration
where the upgrade and downgrade action is the same, and we delete the metadata both ways, so thatstorewolf
fixes it up? In effect this would combine the behaviors ofAddMetadataMigration
andRemoveMetadataMigration
.
Edit: having seen the RemoveWeakSettingsMigration
- I think you want a similar ResetMetadataMigration
that clears out all metadata for all settings. Otherwise it'll be easy to lose track of which settings might have metadata that persists on downgrade.
Ok(input) | ||
} | ||
|
||
/// No work to do on backward migrations, copy the same datastore |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Comment seems incorrect?
inner_map.remove("strength"); | ||
input.metadata.insert(key.clone(), inner_map); | ||
} | ||
input.data.remove(&key); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: add a comment that we're also removing the setting, not just the "strength" metadata
// Remove all the setting generators with weak strength | ||
for (key, inner_map) in input.metadata.clone() { | ||
if let Some(Value::Object(_)) = inner_map.get("setting-generator") { | ||
// We need to remove the setting-generators that are an object | ||
// because the API in destination version is not aware about the | ||
// object setting generator. | ||
let mut inner_map = inner_map.clone(); | ||
inner_map.remove("setting-generator"); | ||
input.metadata.insert(key.clone(), inner_map); | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think we should touch settings generators here
// Remove all the setting generators with weak strength | |
for (key, inner_map) in input.metadata.clone() { | |
if let Some(Value::Object(_)) = inner_map.get("setting-generator") { | |
// We need to remove the setting-generators that are an object | |
// because the API in destination version is not aware about the | |
// object setting generator. | |
let mut inner_map = inner_map.clone(); | |
inner_map.remove("setting-generator"); | |
input.metadata.insert(key.clone(), inner_map); | |
} | |
} |
Issue number:
Closes #
Description of changes:
Testing done:
Refer to testing in bottlerocket-os/bottlerocket-core-kit#294
Terms of contribution:
By submitting this pull request, I agree that this contribution is dual-licensed under the terms of both the Apache License, version 2.0, and the MIT license.