Skip to content

Conversation

@KminekMatej
Copy link
Contributor

@KminekMatej KminekMatej commented Jan 4, 2024

Extending $cache->clean(); with possibility to search for tags to drop using AND logic

  • new feature?
  • BC break? no
  • doc PR: nette/docs (not yet, but planned)

Usage:
Dropping entities having tags animal and dog and (brown or white). Will not match entity, tagged animal and dog and black.

$cache = new Cache($this->cacheStorage, "animals");
$cache->clean([
    Cache::Tags => (new CacheSelector())->where("animal")->where("dog")->where(["brown", "white"])
]);
//

Standard behaviour stays unchanged.

@KminekMatej
Copy link
Contributor Author

Documentation planned to create after expected discussion

@JanTvrdik
Copy link
Contributor

Have you considered using adminal-dog as tag instead of having tags animal and dog?

@KminekMatej
Copy link
Contributor Author

@JanTvrdik I did and it works. However this is usable for some simple scenarios like you wrote, but when the logic grows bigger, using this approach makes it way clearer.

In some points, I need to drop all animals, regardless on any other tags they have. In that case, I need to add to newly created dog these tags:

  1. Animal
  2. Animal-Dog
  3. Animal-Dog-Brown

You can imagine that when your orm complexity grows large, this gets a big messy. Way easier solution is then tagging with:

  1. Animal
  2. Dog
  3. Brown

and in different points of application perform drops right the way you want

@dg dg force-pushed the master branch 2 times, most recently from 40be743 to a116cb9 Compare March 10, 2024 22:09
@dg dg force-pushed the master branch 2 times, most recently from ea335de to ccec70b Compare June 18, 2024 22:13
@dg dg force-pushed the master branch 3 times, most recently from 3ce492d to fb5c89d Compare August 13, 2024 20:20
@dg dg force-pushed the master branch 3 times, most recently from d31ad07 to a71faf1 Compare June 5, 2025 23:25
@dg dg force-pushed the master branch 2 times, most recently from 2d5f7a5 to 91c8061 Compare June 19, 2025 16:58
@dg dg force-pushed the master branch 3 times, most recently from b91fc47 to 05451a0 Compare August 6, 2025 23:06
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants