Skip to content

Conversation

@neznaika0
Copy link
Contributor

@neznaika0 neznaika0 commented Feb 7, 2025

Description
See #9231

  • Added getting the current config properties in Registrar
  • The behavior is configured in Modules

Now you can add, replace, and recursively replace arrays yourself. In Registrar (with the option enabled), apply any changes based on the input data. The name of the argument is not important as long as we trust the user.

This is a draft stage, if you approve it, I will supplement the documentation and corrections.

The develop branch because it doesn't break existing code until the option is enabled.

I noticed that there is no mention of the configuration rewriting order anywhere. The first modules in the A-Z order can be overwritten.

Checklist:

  • Securely signed commits
  • Component(s) with PHPDoc blocks, only if necessary or adds value
  • Unit testing, with >80% coverage
  • User guide updated
  • Conforms to style guide

@neznaika0 neznaika0 force-pushed the feat/improve-registrars branch from f70d2d8 to 5421889 Compare February 7, 2025 22:55
@michalsn
Copy link
Member

michalsn commented Feb 8, 2025

Sorry, but this doesn't make sense to me.

In the proposed implementation, the most recently loaded module wins and overwrites the values previously set by other modules.

@michalsn
Copy link
Member

michalsn commented Feb 8, 2025

New features won't be accepted in the develop branch.

@neznaika0
Copy link
Contributor Author

This does not apply to PR - a simple reminder. In general, can the argument with $this be accepted?

@michalsn
Copy link
Member

michalsn commented Feb 9, 2025

Well, it would have been nice if you had mentioned that currently, only tests are working.

So the changes that will take place can be boiled down to the fact that instead of array_merge(), we will use array_replace_recursive()? Are you planning anything else?

IMO if you want to replace anything that is an array, you should rather modify the base config file and not try to use Registrars. What you’re planning should work for associative arrays, but will fail miserably for indexed arrays.

From my perspective, this function is not desirable - mainly because it will cause more problems than good. And more "shortcomings" will only multiply - because I can think of a few.

The solution would be to encapsulate this in some kind of manager, but... Registrars were invented with very simple operations in mind, and they should stay that way.

For my part, I have already expressed my opinion on the subject. If you find someone who supports this idea - go ahead.

@neznaika0
Copy link
Contributor Author

No. It is not necessary to use array_* inside. This gives the flexibility for the user to change the values as he wants.

If you're worried about problems, then what do you say that anyone can replace with any value instead of the original type string => int ? You can say it's a bug. Otherwise, flexibility. This does not negate the fact that the array can still be broken without this PR (example, in Filters ['before' => ...].

In addition, it is a configurable option.

If things are that bad, CI doesn't have a good way to work with configs. They all depend heavily on app/Config/*. The user always needs to manually add changes for each package. It seems that this is all it is designed for.

@paulbalandan @kenjis @MGatner @samsonasik Share your opinion?

@samsonasik samsonasik added the wrong branch PRs sent to wrong branch label Feb 15, 2025
@neznaika0 neznaika0 force-pushed the feat/improve-registrars branch from 5421889 to b3e6c5b Compare February 23, 2025 14:42
@neznaika0 neznaika0 changed the base branch from develop to 4.7 February 23, 2025 14:42
@neznaika0 neznaika0 force-pushed the feat/improve-registrars branch 3 times, most recently from bf6b741 to ff79dcb Compare February 23, 2025 16:50
@neznaika0
Copy link
Contributor Author

I moved to the next branch

It's worth merging the develop branch into 4.7 to continue development. There are errors in phpstan and rector.

@paulbalandan
Copy link
Member

I have updated 4.7 to latest develop.

@michalsn michalsn removed the wrong branch PRs sent to wrong branch label Feb 25, 2025
@neznaika0
Copy link
Contributor Author

I have a thought - will adding an event after applying the Registrar help?
After the configuration is fully initialized, it can be changed before being used in other places.

    public function __construct()
    {
        static::$moduleConfig ??= new Modules();

        if (! static::$override) {
            return;
        }

        $this->registerProperties();
        Events::trigger('post_config');
        // ....
    }

I haven't tested it, maybe pre_system can be used too.

@github-actions github-actions bot added the stale Pull requests with conflicts label Mar 1, 2025
@github-actions
Copy link

github-actions bot commented Mar 1, 2025

👋 Hi, @neznaika0!

We detected conflicts in your PR against the base branch 🙊
You may want to sync 🔄 your branch with upstream!

Ref: Syncing Your Branch

@neznaika0 neznaika0 force-pushed the feat/improve-registrars branch from ff79dcb to c2eb405 Compare March 8, 2025 09:36
@neznaika0 neznaika0 force-pushed the feat/improve-registrars branch from c2eb405 to f29a8c0 Compare April 8, 2025 20:06
@paulbalandan paulbalandan removed the stale Pull requests with conflicts label Apr 10, 2025
@github-actions github-actions bot added the stale Pull requests with conflicts label Apr 20, 2025
@github-actions
Copy link

👋 Hi, @neznaika0!

We detected conflicts in your PR against the base branch 🙊
You may want to sync 🔄 your branch with upstream!

Ref: Syncing Your Branch

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

stale Pull requests with conflicts

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants