Split structure_sync.data.yml to reduce risk of conflicts

Created on 7 November 2018, about 6 years ago
Updated 3 May 2024, 8 months ago

One thing we have encountered while using this module is that it is very easy to accidentally wipe out another developer's structure sync data.
While it could be argued that this is a workflow issue - I think that refactoring the config schema for structure sync to use separate files instead of putting every piece of content into the same file, would help reduce the risk of this occurring.

For example, each Menu, Taxonomy Vocab, and Block could have its own config file.
Or at the very least, split structure_sync.data.yml into three separate files - one for taxonomy, one for menus, and one for blocks.

📌 Task
Status

Active

Version

2.0

Component

Code

Created by

🇺🇸United States nplowman

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇫🇷France louis-cuny

    How to handle this issue without creating BC breaks/new major version?

    Maybe something like:
    On any export, export to the new splitted configuration(s) and delete the corresponding part from legacy config
    On import, for each entity type, if we find data on splitted config, use this one, if not, try the legacy config file

    We need to make sure to handle entity types separatly.
    Users may use structure_sync for all entity type but export only one time for some reason and wouldn't expect entities disapearing

    We should then deprecate the usage of the old structure_sync.data config and plane to delete it in a next major version

    ~~~

    Other possibility would be to work on a new major version where we simply ask to users to re-export everything after major version update

  • 🇫🇮Finland heikkiy Oulu

    +1 for this feature. We have encountered the issue several times now. It even doesn't necessarily involve several developers but a single developer might have hard time figuring out what the conflict with the structure data YAML file is.

    We have used Fixed block content module in another project and it splits for example each block config into a separate file and we haven't had the same issue there.

    I think it would make sense here also because each block, taxonomy and menu is a separate configuration in core also so you would have a linked structure file for it.

Production build 0.71.5 2024