Convert payload field values
The payload of an event often includes field values that are not easily interpretable for third-party implementations. For example, a value might be stored in the Commerce database as an integer, but the external system stores the same information as a string. Alternatively, instead of transforming data types, you might want to change a Commerce-supplied string to a string defined in the external system. To address this issue, you can implement a converter, enabling custom values for any field in the payload.
Converter definition
Your converter class must implement FieldConverterInterface. This interface contains the convert method, which accepts mixed and Event arguments. The method returns a mixed data type. You must create individual converter classes for each field when converting multiple fields within a payload. You can reuse a class to replace a specific field across multiple events.
Copied to your clipboardinterface FieldConverterInterface{/*** Converts a field value** @param mixed $value* @param Event $event* @return mixed*/public function convert(mixed $value, Event $event);}
As an example, the observer.catalog_product_save_after event contains a top-level visibility field, which must contain an integer value. Convert these values to strings that match values on the external system. The following table describes these values.
| Commerce value | Converted value | Description | 
|---|---|---|
| 1 | NOT_VISIBLE_INDIVIDUALLY | This product should not be displayed if it is part of a configurable product. | 
| 2 | CATALOG_ONLY | This product appears in catalog listings, but not in searches. | 
| 3 | SEARCH_ONLY | This product appears in searches, but not catalog listings. | 
| 4 | CATALOG_AND_SEARCH | This product appears in catalog listings and searches. For most products, this is the default. | 
In the following example, the TestConverterVisibility converter class updates the value of the visibility field to a string.
Copied to your clipboard<?php/*** Copyright [first year code created] Adobe* All rights reserved.*/declare(strict_types=1);namespace Magento\AdobeCommerceEventsClient\Event;use Magento\AdobeCommerceEventsClient\Event\Filter\FieldConverterInterface;class TestConverterVisibility implements FieldConverterInterface{/*** Method used to convert field value** @param mixed $value* @return mixed*/public function convert(mixed $value, Event $event): mixed{return match ($value) {'1' => 'NOT_VISIBLE_INDIVIDUALLY','2' => 'CATALOG_ONLY','3' => 'SEARCH_ONLY','4' => 'CATALOG_AND_SEARCH'};}}
The default payload for this event includes the following:
Copied to your clipboard{"event":{"data":{"value":{"visibility":"4",}}}}
The converter changes the payload to:
Copied to your clipboard{"event":{"data":{"value":{"visibility":"CATALOG_AND_SEARCH",}}}}
Register the converter
You must configure a module's io_events.xml or root app/etc/io_events.xml file to update the required fields. You can also declare them in the system env.php or config.php files or add them when using the CLI to subscribe to an event.
Command line
The bin/magento events:subscribe --fields command defines the fields and converters to include in the payload of a subscribed event. The example command adds the visibility field and provides the path to the converter class. You can specify multiple fields in the same request.
Copied to your clipboardbin/magento events:subscribe observer.catalog_product_save_after --fields="store_id" --fields='{"name":"visibility", "converter": "Magento\AdobeCommerceEventsClient\Event\TestConverterVisibility"}'`
config.php file
The following example config.php is the equivalent of the example bin/magento events:subscribe command in the Command line example above.
Copied to your clipboard'io_events' => ['observer.catalog_product_save_after' => ['fields' => ['store_id',['name' => 'visibility','converter' => 'Magento\\AdobeCommerceEventsClient\\Event\\TestConverterVisibility']],'enabled' => 1]]
Configure an io_events.xml file
The converter attribute of the field element defines the converter class that updates the event data field value for the specified event. Only one converter class can be defined per field.
The following example updates the value of the field visibility present in the observer.catalog_product_save_after event payload using the TestConverterVisibility converter class.
Copied to your clipboard<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module-commerce-events-client/etc/io_events.xsd"><event name="observer.catalog_product_save_after" ><fields><field name="visibility" converter="Magento\AdobeCommerceEventsClient\Event\TestConverterVisibility"/></fields></event></config>