diff --git a/Classes/Service/DestinationDataImportService.php b/Classes/Service/DestinationDataImportService.php index 89d1868..af04c2c 100644 --- a/Classes/Service/DestinationDataImportService.php +++ b/Classes/Service/DestinationDataImportService.php @@ -355,6 +355,7 @@ final class DestinationDataImportService private function setTexts(array $texts): void { + $shouldSetPrice = true; foreach ($texts as $text) { if (isset($text['value']) === false) { continue; @@ -366,7 +367,11 @@ final class DestinationDataImportService if ($text['rel'] == 'teaser' && $text['type'] == 'text/plain') { $this->tmpCurrentEvent->setTeaser(str_replace("\n\n", "\n", (string)$text['value'])); } - if ($text['rel'] == 'PRICE_INFO' && $text['type'] == 'text/plain') { + if ($shouldSetPrice && $text['rel'] == 'PRICE_INFO_EXTRA' && $text['type'] == 'text/plain') { + $shouldSetPrice = false; + $this->tmpCurrentEvent->setPriceInfo(str_replace("\n\n", "\n", (string)$text['value'])); + } + if ($shouldSetPrice && $text['rel'] == 'PRICE_INFO' && $text['type'] == 'text/plain') { $this->tmpCurrentEvent->setPriceInfo(str_replace("\n\n", "\n", (string)$text['value'])); } } diff --git a/Documentation/Changelog/3.7.0.rst b/Documentation/Changelog/3.7.0.rst new file mode 100644 index 0000000..ac2ef8d --- /dev/null +++ b/Documentation/Changelog/3.7.0.rst @@ -0,0 +1,27 @@ +3.7.0 +===== + +Breaking +-------- + +Nothing + +Features +-------- + +* Support new ``PRICE_INFO_EXTRA`` field as price info. The existing field ``PRICE_INFO`` is kept as fallback. + +Fixes +----- + +Nothing + +Tasks +----- + +Nothing + +Deprecation +----------- + +Nothing diff --git a/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNewPriceInfo.json b/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNewPriceInfo.json new file mode 100644 index 0000000..f79ebd7 --- /dev/null +++ b/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNewPriceInfo.json @@ -0,0 +1,178 @@ +{ + "status": "OK", + "count": 3, + "overallcount": 50, + "channels": [], + "facetGroups": [], + "items": [ + { + "global_id": "e_100350503", + "id": "100350503", + "title": "Adventliche Orgelmusik (Orgel: KMD Frank Bettenhausen)", + "type": "Event", + "categories": [ + "Konzerte, Festivals, Show & Tanz", + "Weihnachten" + ], + "texts": [ + { + "rel": "details", + "type": "text/html", + "value": "Immer mittwochs in der Adventszeit spielt Frank Bettenhausen solo und zusammen mit anderen Musikern auf der Steinmeyerorgel aus dem Jahr 1906.  Bekannte Adventslieder, barocke und romantische Kompositionen stehen neben besinnlichen Texten von Pfarrer Johannes-Martin Weiss.

Es gilt die 2G-PLUS-Regel.
" + }, + { + "rel": "details", + "type": "text/plain", + "value": "Immer mittwochs in der Adventszeit spielt Frank Bettenhausen solo und zusammen mit anderen Musikern auf der Steinmeyerorgel aus dem Jahr 1906. Bekannte Adventslieder, barocke und romantische Kompositionen stehen neben besinnlichen Texten von Pfarrer Johannes-Martin Weiss.\n\nEs gilt die 2G-PLUS-Regel." + }, + { + "rel": "PRICE_INFO", + "type": "text/plain", + "value": "Preis Info" + } + ], + "country": "Deutschland", + "areas": [ + "Rudolstadt und Umgebung" + ], + "city": "Rudolstadt", + "zip": "07407", + "street": "Caspar-Schulte-Straße", + "phone": "03672 - 48 96 13", + "author": "support@hubermedia.de", + "geo": { + "main": { + "latitude": 50.718688721182531, + "longitude": 11.327333450317383 + }, + "entry": [], + "attributes": [] + }, + "ratings": [ + { + "type": "eT4", + "value": 40.0 + }, + { + "type": "order", + "value": 99.0001 + } + ], + "cuisine_types": [], + "payment": [], + "media_objects": [ + ], + "keywords": [], + "timeIntervals": [ + { + "weekdays": [], + "start": "2022-12-01T19:00:00+01:00", + "end": "2022-12-01T20:00:00+01:00", + "tz": "Europe/Berlin", + "interval": 1 + }, + { + "weekdays": [ + "Saturday", + "Sunday" + ], + "start": "2022-11-02T11:00:00+01:00", + "end": "2022-11-02T13:00:00+01:00", + "repeatUntil": "2022-11-25T13:00:00+01:00", + "tz": "Europe/Berlin", + "freq": "Weekly", + "interval": 1 + }, + { + "weekdays": [], + "start": "2022-12-22T19:00:00+01:00", + "end": "2022-12-22T20:00:00+01:00", + "tz": "Europe/Berlin", + "interval": 1 + } + ], + "kitchenTimeIntervals": [], + "deliveryTimeIntervals": [], + "numbers": [], + "name": "Lutherkirche", + "attributes": [ + { + "key": "VO_Id", + "value": "100118350" + }, + { + "key": "VO_CategoryName", + "value": "POI" + }, + { + "key": "VA_Id", + "value": "100118350" + }, + { + "key": "VA_CategoryName", + "value": "POI" + }, + { + "key": "interval_first_match_start", + "value": "2022-12-15T19:00:00+01" + }, + { + "key": "interval_first_match_end", + "value": "2022-12-15T20:00:00+01" + }, + { + "key": "interval_match_count", + "value": "2" + }, + { + "key": "interval_last_match_start", + "value": "2022-12-22T19:00:00+01" + }, + { + "key": "interval_last_match_end", + "value": "2022-12-22T20:00:00+01" + } + ], + "features": [], + "addresses": [ + { + "name": "Städtetourismus in Thüringen e.V.", + "city": "Weimar", + "zip": "99423", + "street": "UNESCO-Platz 1", + "phone": "+49 (3643) 745 314", + "web": "http://www.thueringer-staedte.de", + "email": "verein@thueringer-staedte.de", + "rel": "author" + }, + { + "name": "Städtetourismus in Thüringen\" e.V.", + "web": "http://www.thueringer-staedte.de", + "email": "verein@thueringer-staedte.de", + "rel": "organisation" + }, + { + "name": "Lutherkirche", + "city": "Rudolstadt", + "zip": "07407", + "street": "Caspar-Schulte-Straße", + "phone": "03672 - 48 96 13", + "rel": "organizer" + } + ], + "created": "2022-11-08T22:15:00+00:00", + "changed": "2022-12-14T08:38:00+00:00", + "source": { + "url": "http://destination.one/", + "value": "destination.one" + }, + "company": "", + "district": "", + "postoffice": "", + "phone2": "", + "seasons": [], + "subitems": [], + "hyperObjects": [] + } + ] +} diff --git a/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNewPriceInfoExtra.json b/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNewPriceInfoExtra.json new file mode 100644 index 0000000..d96677a --- /dev/null +++ b/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNewPriceInfoExtra.json @@ -0,0 +1,183 @@ +{ + "status": "OK", + "count": 3, + "overallcount": 50, + "channels": [], + "facetGroups": [], + "items": [ + { + "global_id": "e_100350503", + "id": "100350503", + "title": "Adventliche Orgelmusik (Orgel: KMD Frank Bettenhausen)", + "type": "Event", + "categories": [ + "Konzerte, Festivals, Show & Tanz", + "Weihnachten" + ], + "texts": [ + { + "rel": "details", + "type": "text/html", + "value": "Immer mittwochs in der Adventszeit spielt Frank Bettenhausen solo und zusammen mit anderen Musikern auf der Steinmeyerorgel aus dem Jahr 1906.  Bekannte Adventslieder, barocke und romantische Kompositionen stehen neben besinnlichen Texten von Pfarrer Johannes-Martin Weiss.

Es gilt die 2G-PLUS-Regel.
" + }, + { + "rel": "details", + "type": "text/plain", + "value": "Immer mittwochs in der Adventszeit spielt Frank Bettenhausen solo und zusammen mit anderen Musikern auf der Steinmeyerorgel aus dem Jahr 1906. Bekannte Adventslieder, barocke und romantische Kompositionen stehen neben besinnlichen Texten von Pfarrer Johannes-Martin Weiss.\n\nEs gilt die 2G-PLUS-Regel." + }, + { + "rel": "PRICE_INFO_EXTRA", + "type": "text/plain", + "value": "Preis Info Extra" + }, + { + "rel": "PRICE_INFO", + "type": "text/plain", + "value": "Preis Info" + } + ], + "country": "Deutschland", + "areas": [ + "Rudolstadt und Umgebung" + ], + "city": "Rudolstadt", + "zip": "07407", + "street": "Caspar-Schulte-Straße", + "phone": "03672 - 48 96 13", + "author": "support@hubermedia.de", + "geo": { + "main": { + "latitude": 50.718688721182531, + "longitude": 11.327333450317383 + }, + "entry": [], + "attributes": [] + }, + "ratings": [ + { + "type": "eT4", + "value": 40.0 + }, + { + "type": "order", + "value": 99.0001 + } + ], + "cuisine_types": [], + "payment": [], + "media_objects": [ + ], + "keywords": [], + "timeIntervals": [ + { + "weekdays": [], + "start": "2022-12-01T19:00:00+01:00", + "end": "2022-12-01T20:00:00+01:00", + "tz": "Europe/Berlin", + "interval": 1 + }, + { + "weekdays": [ + "Saturday", + "Sunday" + ], + "start": "2022-11-02T11:00:00+01:00", + "end": "2022-11-02T13:00:00+01:00", + "repeatUntil": "2022-11-25T13:00:00+01:00", + "tz": "Europe/Berlin", + "freq": "Weekly", + "interval": 1 + }, + { + "weekdays": [], + "start": "2022-12-22T19:00:00+01:00", + "end": "2022-12-22T20:00:00+01:00", + "tz": "Europe/Berlin", + "interval": 1 + } + ], + "kitchenTimeIntervals": [], + "deliveryTimeIntervals": [], + "numbers": [], + "name": "Lutherkirche", + "attributes": [ + { + "key": "VO_Id", + "value": "100118350" + }, + { + "key": "VO_CategoryName", + "value": "POI" + }, + { + "key": "VA_Id", + "value": "100118350" + }, + { + "key": "VA_CategoryName", + "value": "POI" + }, + { + "key": "interval_first_match_start", + "value": "2022-12-15T19:00:00+01" + }, + { + "key": "interval_first_match_end", + "value": "2022-12-15T20:00:00+01" + }, + { + "key": "interval_match_count", + "value": "2" + }, + { + "key": "interval_last_match_start", + "value": "2022-12-22T19:00:00+01" + }, + { + "key": "interval_last_match_end", + "value": "2022-12-22T20:00:00+01" + } + ], + "features": [], + "addresses": [ + { + "name": "Städtetourismus in Thüringen e.V.", + "city": "Weimar", + "zip": "99423", + "street": "UNESCO-Platz 1", + "phone": "+49 (3643) 745 314", + "web": "http://www.thueringer-staedte.de", + "email": "verein@thueringer-staedte.de", + "rel": "author" + }, + { + "name": "Städtetourismus in Thüringen\" e.V.", + "web": "http://www.thueringer-staedte.de", + "email": "verein@thueringer-staedte.de", + "rel": "organisation" + }, + { + "name": "Lutherkirche", + "city": "Rudolstadt", + "zip": "07407", + "street": "Caspar-Schulte-Straße", + "phone": "03672 - 48 96 13", + "rel": "organizer" + } + ], + "created": "2022-11-08T22:15:00+00:00", + "changed": "2022-12-14T08:38:00+00:00", + "source": { + "url": "http://destination.one/", + "value": "destination.one" + }, + "company": "", + "district": "", + "postoffice": "", + "phone2": "", + "seasons": [], + "subitems": [], + "hyperObjects": [] + } + ] +} diff --git a/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNoPriceInfo.json b/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNoPriceInfo.json new file mode 100644 index 0000000..c970f49 --- /dev/null +++ b/Tests/Functional/Import/DestinationDataTest/Fixtures/ResponseWithNoPriceInfo.json @@ -0,0 +1,173 @@ +{ + "status": "OK", + "count": 3, + "overallcount": 50, + "channels": [], + "facetGroups": [], + "items": [ + { + "global_id": "e_100350503", + "id": "100350503", + "title": "Adventliche Orgelmusik (Orgel: KMD Frank Bettenhausen)", + "type": "Event", + "categories": [ + "Konzerte, Festivals, Show & Tanz", + "Weihnachten" + ], + "texts": [ + { + "rel": "details", + "type": "text/html", + "value": "Immer mittwochs in der Adventszeit spielt Frank Bettenhausen solo und zusammen mit anderen Musikern auf der Steinmeyerorgel aus dem Jahr 1906.  Bekannte Adventslieder, barocke und romantische Kompositionen stehen neben besinnlichen Texten von Pfarrer Johannes-Martin Weiss.

Es gilt die 2G-PLUS-Regel.
" + }, + { + "rel": "details", + "type": "text/plain", + "value": "Immer mittwochs in der Adventszeit spielt Frank Bettenhausen solo und zusammen mit anderen Musikern auf der Steinmeyerorgel aus dem Jahr 1906. Bekannte Adventslieder, barocke und romantische Kompositionen stehen neben besinnlichen Texten von Pfarrer Johannes-Martin Weiss.\n\nEs gilt die 2G-PLUS-Regel." + } + ], + "country": "Deutschland", + "areas": [ + "Rudolstadt und Umgebung" + ], + "city": "Rudolstadt", + "zip": "07407", + "street": "Caspar-Schulte-Straße", + "phone": "03672 - 48 96 13", + "author": "support@hubermedia.de", + "geo": { + "main": { + "latitude": 50.718688721182531, + "longitude": 11.327333450317383 + }, + "entry": [], + "attributes": [] + }, + "ratings": [ + { + "type": "eT4", + "value": 40.0 + }, + { + "type": "order", + "value": 99.0001 + } + ], + "cuisine_types": [], + "payment": [], + "media_objects": [ + ], + "keywords": [], + "timeIntervals": [ + { + "weekdays": [], + "start": "2022-12-01T19:00:00+01:00", + "end": "2022-12-01T20:00:00+01:00", + "tz": "Europe/Berlin", + "interval": 1 + }, + { + "weekdays": [ + "Saturday", + "Sunday" + ], + "start": "2022-11-02T11:00:00+01:00", + "end": "2022-11-02T13:00:00+01:00", + "repeatUntil": "2022-11-25T13:00:00+01:00", + "tz": "Europe/Berlin", + "freq": "Weekly", + "interval": 1 + }, + { + "weekdays": [], + "start": "2022-12-22T19:00:00+01:00", + "end": "2022-12-22T20:00:00+01:00", + "tz": "Europe/Berlin", + "interval": 1 + } + ], + "kitchenTimeIntervals": [], + "deliveryTimeIntervals": [], + "numbers": [], + "name": "Lutherkirche", + "attributes": [ + { + "key": "VO_Id", + "value": "100118350" + }, + { + "key": "VO_CategoryName", + "value": "POI" + }, + { + "key": "VA_Id", + "value": "100118350" + }, + { + "key": "VA_CategoryName", + "value": "POI" + }, + { + "key": "interval_first_match_start", + "value": "2022-12-15T19:00:00+01" + }, + { + "key": "interval_first_match_end", + "value": "2022-12-15T20:00:00+01" + }, + { + "key": "interval_match_count", + "value": "2" + }, + { + "key": "interval_last_match_start", + "value": "2022-12-22T19:00:00+01" + }, + { + "key": "interval_last_match_end", + "value": "2022-12-22T20:00:00+01" + } + ], + "features": [], + "addresses": [ + { + "name": "Städtetourismus in Thüringen e.V.", + "city": "Weimar", + "zip": "99423", + "street": "UNESCO-Platz 1", + "phone": "+49 (3643) 745 314", + "web": "http://www.thueringer-staedte.de", + "email": "verein@thueringer-staedte.de", + "rel": "author" + }, + { + "name": "Städtetourismus in Thüringen\" e.V.", + "web": "http://www.thueringer-staedte.de", + "email": "verein@thueringer-staedte.de", + "rel": "organisation" + }, + { + "name": "Lutherkirche", + "city": "Rudolstadt", + "zip": "07407", + "street": "Caspar-Schulte-Straße", + "phone": "03672 - 48 96 13", + "rel": "organizer" + } + ], + "created": "2022-11-08T22:15:00+00:00", + "changed": "2022-12-14T08:38:00+00:00", + "source": { + "url": "http://destination.one/", + "value": "destination.one" + }, + "company": "", + "district": "", + "postoffice": "", + "phone2": "", + "seasons": [], + "subitems": [], + "hyperObjects": [] + } + ] +} diff --git a/Tests/Functional/Import/DestinationDataTest/ImportHandlesPricesTest.php b/Tests/Functional/Import/DestinationDataTest/ImportHandlesPricesTest.php new file mode 100644 index 0000000..046edc6 --- /dev/null +++ b/Tests/Functional/Import/DestinationDataTest/ImportHandlesPricesTest.php @@ -0,0 +1,135 @@ +importPHPDataSet(__DIR__ . '/Fixtures/Database/DefaultImportConfiguration.php'); + $this->setUpConfiguration([ + 'restUrl = https://example.com/some-path/', + 'license = example-license', + 'restType = Event', + 'restLimit = 3', + 'restMode = next_months,12', + 'restTemplate = ET2014A.json', + ]); + } + + #[Test] + public function addsNewPriceFromPriceInfo(): void + { + $this->setUpResponses([ + new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithNewPriceInfo.json') ?: ''), + ]); + + $this->executeCommand(); + + self::assertSame( + 'Preis Info', + $this->getAllRecords('tx_events_domain_model_event')[0]['price_info'] ?? '' + ); + + $this->assertEmptyLog(); + } + + #[Test] + public function addsNewPriceFromPriceInfoExtra(): void + { + $this->setUpResponses([ + new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithNewPriceInfoExtra.json') ?: ''), + ]); + + $this->executeCommand(); + + self::assertSame( + 'Preis Info Extra', + $this->getAllRecords('tx_events_domain_model_event')[0]['price_info'] ?? '' + ); + + $this->assertEmptyLog(); + } + + #[Test] + public function keepsNoLongerExistingPrice(): void + { + (new PhpDataSet())->import(['tx_events_domain_model_event' => [0 => [ + 'uid' => 1, + 'pid' => 2, + 'global_id' => 'e_100350503', + 'price_info' => 'Existing price info', + ]]]); + + $this->setUpResponses([ + new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithNoPriceInfo.json') ?: ''), + ]); + + $this->executeCommand(); + + self::assertSame( + 'Existing price info', + $this->getAllRecords('tx_events_domain_model_event')[0]['price_info'] ?? '' + ); + + $this->assertEmptyLog(); + } + + #[Test] + public function updatesExistingPriceFromPriceInfo(): void + { + (new PhpDataSet())->import(['tx_events_domain_model_event' => [0 => [ + 'uid' => 1, + 'pid' => 2, + 'global_id' => 'e_100350503', + 'price_info' => 'Existing price info', + ]]]); + + $this->setUpResponses([ + new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithNewPriceInfo.json') ?: ''), + ]); + + $this->executeCommand(); + + self::assertSame( + 'Preis Info', + $this->getAllRecords('tx_events_domain_model_event')[0]['price_info'] ?? '' + ); + + $this->assertEmptyLog(); + } + + #[Test] + public function updatesExistingPriceFromPriceInfoExtra(): void + { + (new PhpDataSet())->import(['tx_events_domain_model_event' => [0 => [ + 'uid' => 1, + 'pid' => 2, + 'global_id' => 'e_100350503', + 'price_info' => 'Existing price info', + ]]]); + + $this->setUpResponses([ + new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithNewPriceInfoExtra.json') ?: ''), + ]); + + $this->executeCommand(); + + self::assertSame( + 'Preis Info Extra', + $this->getAllRecords('tx_events_domain_model_event')[0]['price_info'] ?? '' + ); + + $this->assertEmptyLog(); + } +}