|
6 | 6 |
|
7 | 7 | use Drupal\Component\Datetime\TimeInterface; |
8 | 8 | use Drupal\Core\Logger\LoggerChannelInterface; |
9 | | -use Drupal\os2forms_fordelingskomponent\Exception\SoapException; |
10 | 9 | use Drupal\os2forms_fordelingskomponent\Model\Fordelingskomponent\AnvenderKvittering; |
11 | 10 | use Drupal\os2forms_fordelingskomponent\Repository\AnvenderForsendelseRepository; |
12 | 11 | use Drupal\os2forms_fordelingskomponent\Repository\AnvenderKvitteringRepository; |
| 12 | +use ItkDev\Serviceplatformen\SF2900\EnumType\ForretningsValideringsKodeType; |
13 | 13 | use ItkDev\Serviceplatformen\SF2900\StructType\FordelingskvitteringModtagAnvenderRequestType; |
14 | 14 | use ItkDev\Serviceplatformen\SF2900\StructType\FordelingskvitteringModtagAnvenderResponseType; |
15 | 15 | use Symfony\Component\DependencyInjection\Attribute\Autowire; |
@@ -49,29 +49,27 @@ public function FordelingskvitteringModtag( |
49 | 49 | distributionTransaktionsId: $context->getDistributionTransktionsID(), |
50 | 50 | ); |
51 | 51 | if (NULL === $forsendelse) { |
52 | | - throw new SoapException(sprintf('Forsendelse %s not found.', $context->getAnvenderTransaktionsID())); |
| 52 | + $this->logger->warning(sprintf('Kvittering: Forsendelse %s not found.', $context->getAnvenderTransaktionsID())); |
53 | 53 | } |
54 | 54 |
|
55 | | - $forsendelse->deliveredAt = $this->time->getRequestTime(); |
56 | | - $this->forsendelseRepository->save($forsendelse); |
57 | | - |
58 | 55 | $response = new FordelingskvitteringModtagAnvenderResponseType(); |
59 | 56 |
|
60 | | - $kvittering = $this->kvitteringRepository->loadByAnvenderTransaktionsId( |
| 57 | + // We may receive multiple receipts. |
| 58 | + $kvittering = new AnvenderKvittering( |
| 59 | + id: NULL, |
61 | 60 | anvenderTransaktionsId: $context->getAnvenderTransaktionsID(), |
62 | 61 | distributionTransaktionsId: $context->getDistributionTransktionsID(), |
| 62 | + request: $request, |
| 63 | + response: $response, |
63 | 64 | ); |
64 | | - if (NULL === $kvittering) { |
65 | | - $kvittering = new AnvenderKvittering( |
66 | | - anvenderTransaktionsId: $context->getAnvenderTransaktionsID(), |
67 | | - distributionTransaktionsId: $context->getDistributionTransktionsID(), |
68 | | - request: $request, |
69 | | - response: $response, |
70 | | - ); |
71 | | - } |
72 | | - |
73 | 65 | $this->kvitteringRepository->save($kvittering); |
74 | 66 |
|
| 67 | + // @todo Should we set a status code (rather than deliveredAt) on the forsendelse? |
| 68 | + if (NULL !== $forsendelse && $request->getForretningskvittering()->getForretningsValideringsKode() === ForretningsValideringsKodeType::VALUE_ACCEPTERET) { |
| 69 | + $forsendelse->deliveredAt = $this->time->getRequestTime(); |
| 70 | + $this->forsendelseRepository->save($forsendelse); |
| 71 | + } |
| 72 | + |
75 | 73 | return $response; |
76 | 74 | } |
77 | 75 |
|
|
0 commit comments