From 854720d795dd39ca46cb27677a2103153e8af095 Mon Sep 17 00:00:00 2001 From: Blaize M Kaye Date: Tue, 5 Sep 2023 08:27:14 +1200 Subject: [PATCH 1/4] First pass at adding event dispatching for sites not found --- composer.json | 1 + composer.lock | 43 ++++++++++++++----------------- src/Events/AliasNotFoundEvent.php | 37 ++++++++++++++++++++++++++ src/SiteAliasManager.php | 21 ++++++++++++++- tests/SiteAliasManagerTest.php | 23 +++++++++++++++++ 5 files changed, 100 insertions(+), 25 deletions(-) create mode 100644 src/Events/AliasNotFoundEvent.php diff --git a/composer.json b/composer.json index f6cc9b9..5d927da 100644 --- a/composer.json +++ b/composer.json @@ -25,6 +25,7 @@ "require": { "php": ">=7.4", "consolidation/config": "^1.2.1 || ^2", + "symfony/event-dispatcher": "^6", "symfony/filesystem": "^5.4 || ^6", "symfony/finder": "^5 || ^6" }, diff --git a/composer.lock b/composer.lock index a1be500..890a60a 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "9b7a7566012d952bbf17cfcb02fed52d", + "content-hash": "2d180b0e825c7b41a76212ee62ce4dd0", "packages": [ { "name": "consolidation/config", @@ -361,44 +361,39 @@ }, { "name": "symfony/event-dispatcher", - "version": "v5.4.9", + "version": "v6.3.2", "source": { "type": "git", "url": "https://github.com/symfony/event-dispatcher.git", - "reference": "8e6ce1cc0279e3ff3c8ff0f43813bc88d21ca1bc" + "reference": "adb01fe097a4ee930db9258a3cc906b5beb5cf2e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/8e6ce1cc0279e3ff3c8ff0f43813bc88d21ca1bc", - "reference": "8e6ce1cc0279e3ff3c8ff0f43813bc88d21ca1bc", + "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/adb01fe097a4ee930db9258a3cc906b5beb5cf2e", + "reference": "adb01fe097a4ee930db9258a3cc906b5beb5cf2e", "shasum": "" }, "require": { - "php": ">=7.2.5", - "symfony/deprecation-contracts": "^2.1|^3", - "symfony/event-dispatcher-contracts": "^2|^3", - "symfony/polyfill-php80": "^1.16" + "php": ">=8.1", + "symfony/event-dispatcher-contracts": "^2.5|^3" }, "conflict": { - "symfony/dependency-injection": "<4.4" + "symfony/dependency-injection": "<5.4", + "symfony/service-contracts": "<2.5" }, "provide": { "psr/event-dispatcher-implementation": "1.0", - "symfony/event-dispatcher-implementation": "2.0" + "symfony/event-dispatcher-implementation": "2.0|3.0" }, "require-dev": { "psr/log": "^1|^2|^3", - "symfony/config": "^4.4|^5.0|^6.0", - "symfony/dependency-injection": "^4.4|^5.0|^6.0", - "symfony/error-handler": "^4.4|^5.0|^6.0", - "symfony/expression-language": "^4.4|^5.0|^6.0", - "symfony/http-foundation": "^4.4|^5.0|^6.0", - "symfony/service-contracts": "^1.1|^2|^3", - "symfony/stopwatch": "^4.4|^5.0|^6.0" - }, - "suggest": { - "symfony/dependency-injection": "", - "symfony/http-kernel": "" + "symfony/config": "^5.4|^6.0", + "symfony/dependency-injection": "^5.4|^6.0", + "symfony/error-handler": "^5.4|^6.0", + "symfony/expression-language": "^5.4|^6.0", + "symfony/http-foundation": "^5.4|^6.0", + "symfony/service-contracts": "^2.5|^3", + "symfony/stopwatch": "^5.4|^6.0" }, "type": "library", "autoload": { @@ -426,7 +421,7 @@ "description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/event-dispatcher/tree/v5.4.9" + "source": "https://github.com/symfony/event-dispatcher/tree/v6.3.2" }, "funding": [ { @@ -442,7 +437,7 @@ "type": "tidelift" } ], - "time": "2022-05-05T16:45:39+00:00" + "time": "2023-07-06T06:56:43+00:00" }, { "name": "symfony/event-dispatcher-contracts", diff --git a/src/Events/AliasNotFoundEvent.php b/src/Events/AliasNotFoundEvent.php new file mode 100644 index 0000000..e245cb9 --- /dev/null +++ b/src/Events/AliasNotFoundEvent.php @@ -0,0 +1,37 @@ +aliasName = $aliasName; + } + + public function setAlias(SiteAlias $alias) + { + $this->alias = $alias; + } + + public function hasAlias() + { + return $this->alias !== false; + } + + public function getAlias() + { + return $this->alias; + } + +} diff --git a/src/SiteAliasManager.php b/src/SiteAliasManager.php index 4105a2b..fe7e906 100644 --- a/src/SiteAliasManager.php +++ b/src/SiteAliasManager.php @@ -1,6 +1,9 @@ aliasLoader = $aliasLoader ?: new SiteAliasFileLoader(); $this->specParser = new SiteSpecParser(); $this->selfSiteAlias = new SiteAlias(); + $this->dispatcher = new EventDispatcher(); $this->setRoot($root); } @@ -97,7 +102,16 @@ public function searchLocations() public function get($name) { if (SiteAliasName::isAliasName($name)) { - return $this->getAlias($name); + $alias = $this->getAlias($name); + if (!$alias) { + //TODO, call all registered listeners here - if none of them return an alias, we return false + $event = new AliasNotFoundEvent($name); + $this->dispatcher->dispatch($event, AliasNotFoundEvent::NAME); + if ($event->hasAlias()) { + return $event->getAlias(); + } + return false; + } } if ($this->specParser->validSiteSpec($name)) { @@ -212,4 +226,9 @@ public function listAllFilePaths($location = '') { return $this->aliasLoader->listAll($location); } + + public function addListener($hook, callable $callback) + { + $this->dispatcher->addListener($hook, $callback); + } } diff --git a/tests/SiteAliasManagerTest.php b/tests/SiteAliasManagerTest.php index d80df01..915c856 100644 --- a/tests/SiteAliasManagerTest.php +++ b/tests/SiteAliasManagerTest.php @@ -1,9 +1,12 @@ assertEquals('@other.single.dev,@other.single.other', implode(',', $allNames)); } + /** + * This tests registering a custom site alias resolver when sites are not found using the standard resolution methods + * + */ + public function testEventListener() + { + /* @var SiteAlias $alias */ + $alias = $this->manager->get('@nonexistent.me'); + $this->assertFalse($alias, false); + $this->manager->addListener( + AliasNotFoundEvent::NAME, + function (AliasNotFoundEvent $event) { + $event->setAlias(new SiteAlias(['test' => 'isset'])); + } + ); + + $alias = $this->manager->get('@nonexistent.site'); + $this->assertEquals('isset', $alias->get('test')); + } + /** * @covers \Consolidation\SiteAlias\SiteAlias::root() */ From 65fe9b5813ef839c0a1f94c673ca10689135e3df Mon Sep 17 00:00:00 2001 From: Blaize M Kaye Date: Tue, 5 Sep 2023 08:39:43 +1200 Subject: [PATCH 2/4] Fixing up deps --- composer.json | 2 +- composer.lock | 57 ++++++++++++++++++++++++++++----------------------- 2 files changed, 32 insertions(+), 27 deletions(-) diff --git a/composer.json b/composer.json index 5d927da..3ec5766 100644 --- a/composer.json +++ b/composer.json @@ -25,7 +25,7 @@ "require": { "php": ">=7.4", "consolidation/config": "^1.2.1 || ^2", - "symfony/event-dispatcher": "^6", + "symfony/event-dispatcher":"^5|| ^6", "symfony/filesystem": "^5.4 || ^6", "symfony/finder": "^5 || ^6" }, diff --git a/composer.lock b/composer.lock index 890a60a..1d688da 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "2d180b0e825c7b41a76212ee62ce4dd0", + "content-hash": "7504c986f47d2aa268d067df3d16e26a", "packages": [ { "name": "consolidation/config", @@ -361,39 +361,44 @@ }, { "name": "symfony/event-dispatcher", - "version": "v6.3.2", + "version": "v5.4.26", "source": { "type": "git", "url": "https://github.com/symfony/event-dispatcher.git", - "reference": "adb01fe097a4ee930db9258a3cc906b5beb5cf2e" + "reference": "5dcc00e03413f05c1e7900090927bb7247cb0aac" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/adb01fe097a4ee930db9258a3cc906b5beb5cf2e", - "reference": "adb01fe097a4ee930db9258a3cc906b5beb5cf2e", + "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/5dcc00e03413f05c1e7900090927bb7247cb0aac", + "reference": "5dcc00e03413f05c1e7900090927bb7247cb0aac", "shasum": "" }, "require": { - "php": ">=8.1", - "symfony/event-dispatcher-contracts": "^2.5|^3" + "php": ">=7.2.5", + "symfony/deprecation-contracts": "^2.1|^3", + "symfony/event-dispatcher-contracts": "^2|^3", + "symfony/polyfill-php80": "^1.16" }, "conflict": { - "symfony/dependency-injection": "<5.4", - "symfony/service-contracts": "<2.5" + "symfony/dependency-injection": "<4.4" }, "provide": { "psr/event-dispatcher-implementation": "1.0", - "symfony/event-dispatcher-implementation": "2.0|3.0" + "symfony/event-dispatcher-implementation": "2.0" }, "require-dev": { "psr/log": "^1|^2|^3", - "symfony/config": "^5.4|^6.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/error-handler": "^5.4|^6.0", - "symfony/expression-language": "^5.4|^6.0", - "symfony/http-foundation": "^5.4|^6.0", - "symfony/service-contracts": "^2.5|^3", - "symfony/stopwatch": "^5.4|^6.0" + "symfony/config": "^4.4|^5.0|^6.0", + "symfony/dependency-injection": "^4.4|^5.0|^6.0", + "symfony/error-handler": "^4.4|^5.0|^6.0", + "symfony/expression-language": "^4.4|^5.0|^6.0", + "symfony/http-foundation": "^4.4|^5.0|^6.0", + "symfony/service-contracts": "^1.1|^2|^3", + "symfony/stopwatch": "^4.4|^5.0|^6.0" + }, + "suggest": { + "symfony/dependency-injection": "", + "symfony/http-kernel": "" }, "type": "library", "autoload": { @@ -421,7 +426,7 @@ "description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/event-dispatcher/tree/v6.3.2" + "source": "https://github.com/symfony/event-dispatcher/tree/v5.4.26" }, "funding": [ { @@ -437,7 +442,7 @@ "type": "tidelift" } ], - "time": "2023-07-06T06:56:43+00:00" + "time": "2023-07-06T06:34:20+00:00" }, { "name": "symfony/event-dispatcher-contracts", @@ -812,16 +817,16 @@ }, { "name": "symfony/polyfill-php80", - "version": "v1.26.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-php80.git", - "reference": "cfa0ae98841b9e461207c13ab093d76b0fa7bace" + "reference": "6caa57379c4aec19c0a12a38b59b26487dcfe4b5" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/cfa0ae98841b9e461207c13ab093d76b0fa7bace", - "reference": "cfa0ae98841b9e461207c13ab093d76b0fa7bace", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/6caa57379c4aec19c0a12a38b59b26487dcfe4b5", + "reference": "6caa57379c4aec19c0a12a38b59b26487dcfe4b5", "shasum": "" }, "require": { @@ -830,7 +835,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.26-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -875,7 +880,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-php80/tree/v1.26.0" + "source": "https://github.com/symfony/polyfill-php80/tree/v1.28.0" }, "funding": [ { @@ -891,7 +896,7 @@ "type": "tidelift" } ], - "time": "2022-05-10T07:21:04+00:00" + "time": "2023-01-26T09:26:14+00:00" } ], "packages-dev": [ From 7ce346ab096537bdf4cd668aa9cb1c9de90be5d5 Mon Sep 17 00:00:00 2001 From: Blaize M Kaye Date: Tue, 5 Sep 2023 08:45:42 +1200 Subject: [PATCH 3/4] Fixes linting issue --- src/Events/AliasNotFoundEvent.php | 1 - 1 file changed, 1 deletion(-) diff --git a/src/Events/AliasNotFoundEvent.php b/src/Events/AliasNotFoundEvent.php index e245cb9..190d44b 100644 --- a/src/Events/AliasNotFoundEvent.php +++ b/src/Events/AliasNotFoundEvent.php @@ -33,5 +33,4 @@ public function getAlias() { return $this->alias; } - } From f8f8b30a2cb8c2ac0263259bef273578a8f06aa8 Mon Sep 17 00:00:00 2001 From: Blaize M Kaye Date: Wed, 6 Sep 2023 06:03:23 +1200 Subject: [PATCH 4/4] Fixes dispatch return logic --- src/SiteAliasManager.php | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/SiteAliasManager.php b/src/SiteAliasManager.php index fe7e906..665ed43 100644 --- a/src/SiteAliasManager.php +++ b/src/SiteAliasManager.php @@ -104,14 +104,13 @@ public function get($name) if (SiteAliasName::isAliasName($name)) { $alias = $this->getAlias($name); if (!$alias) { - //TODO, call all registered listeners here - if none of them return an alias, we return false $event = new AliasNotFoundEvent($name); $this->dispatcher->dispatch($event, AliasNotFoundEvent::NAME); if ($event->hasAlias()) { return $event->getAlias(); } - return false; } + return $alias; } if ($this->specParser->validSiteSpec($name)) {