Skip to content

Commit d9ba8e7

Browse files
author
markus-moser
committed
[DuplicatesIndex] ignore duplicate check when merging customer - fixes #8
1 parent 7f6b301 commit d9ba8e7

File tree

3 files changed

+26
-1
lines changed

3 files changed

+26
-1
lines changed

composer.json

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
},
88
"require": {
99
"drewm/mailchimp-api": "*",
10-
"pimcore/object-merger": "^1.0",
10+
"pimcore/object-merger": "^1.0.1",
1111
"guzzlehttp/guzzle": ">=4.1.4 <7.0",
1212
"hwi/oauth-bundle": "^0.5.3",
1313
"mtdowling/cron-expression": "^1.1.0",

src/Event/CustomerMergerEventListener.php

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -15,8 +15,29 @@
1515

1616
namespace CustomerManagementFrameworkBundle\Event;
1717

18+
use CustomerManagementFrameworkBundle\CustomerSaveManager\CustomerSaveManagerInterface;
19+
1820
class CustomerMergerEventListener
1921
{
22+
/**
23+
* @var CustomerSaveManagerInterface
24+
*/
25+
private $customerSaveManager;
26+
27+
public function __construct(CustomerSaveManagerInterface $customerSaveManager)
28+
{
29+
$this->customerSaveManager = $customerSaveManager;
30+
}
31+
32+
public function onPreMerge(\Symfony\Component\EventDispatcher\GenericEvent $e)
33+
{
34+
$this->customerSaveManager
35+
->getSaveOptions()
36+
->disableOnSaveSegmentBuilders()
37+
->disableValidator();
38+
39+
}
40+
2041
public function onPostMerge(\Symfony\Component\EventDispatcher\GenericEvent $e)
2142
{
2243
$sourceCustomer = \Pimcore::getContainer()->get('cmf.customer_provider')->getById($e->getArgument('sourceId'));
@@ -25,5 +46,8 @@ public function onPostMerge(\Symfony\Component\EventDispatcher\GenericEvent $e)
2546
if ($sourceCustomer && $targetCustomer) {
2647
\Pimcore::getContainer()->get('cmf.customer_merger')->mergeCustomers($sourceCustomer, $targetCustomer, false);
2748
}
49+
$this->customerSaveManager->setSaveOptions(
50+
$this->customerSaveManager->getDefaultSaveOptions()
51+
);
2852
}
2953
}

src/Resources/config/services_events.yml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@ services:
2424
class: CustomerManagementFrameworkBundle\Event\CustomerMergerEventListener
2525
tags:
2626
- { name: kernel.event_listener, event: plugin.ObjectMerger.postMerge, method: onPostMerge }
27+
- { name: kernel.event_listener, event: plugin.ObjectMerger.preMerge, method: onPreMerge }
2728

2829
cmf.event_listener.maintenance:
2930
class: CustomerManagementFrameworkBundle\Event\MaintenanceEventListener

0 commit comments

Comments
 (0)