ACSD-50368:通过异步REST API或异步批量REST API创建客户时,将忽略客户group_id
ACSD-50368修补程序修复了在通过异步REST API或异步批量REST API创建客户时忽略客户group_id的问题。 安装Quality Patches Tool (QPT) 1.1.33时,此修补程序可用。 修补程序ID为ACSD-50368。 请注意,该问题计划在Adobe Commerce 2.4.7中修复。
受影响的产品和版本
为Adobe Commerce版本创建了修补程序:
- Adobe Commerce(所有部署方法) 2.4.4
与Adobe Commerce版本兼容:
- Adobe Commerce(所有部署方法) 2.4.3 - 2.4.4-p4
NOTE
该修补程序可能适用于具有新Quality Patches Tool发行版本的其他版本。 要检查修补程序是否与您的Adobe Commerce版本兼容,请将
magento/quality-patches
包更新到最新版本,并在Quality Patches Tool:搜索修补程序页面上检查兼容性。 使用修补程序ID作为搜索关键字来查找修补程序。问题
通过异步REST API或异步批量REST API创建客户时,会忽略客户group_id。
先决条件:
配置RabbitMQ以处理队列:
bin/magento setup:config:set --amqp-host=services --amqp-port=5672 --amqp-user=guest --amqp-password=guest
bin/magento setup:upgrade --keep-generated
重现步骤
-
使用异步Rest API请求创建客户:
code language-none curl --location 'https://site.test/rest/default/async/V1/customers' \ --header 'Authorization: Bearer eyJraWQiOiIxIiwiYWxnIjoiSFMyNTYifQ.eyJ1aWQiOjEsInV0eXBpZCI6MiwiaWF0IjoxNjc5NDMzNzcxLCJleHAiOjE2Nzk0MzczNzF9.xau6KyILrkdCY_8K8aMlH4TmqcCXdH4Zcst_CLhdxYY' \ --header 'Content-Type: application/json' \ --header 'Cookie: PHPSESSID=844fltmqq1g15qe4ju3l00tiai' \ --data-raw '{ "customer": { "email": "foo@bar.test", "firstname": "Test", "lastname": "User", "group_id": 2 } }
-
将返回类似的响应:
code language-none { "bulk_uuid": "b101ddcb-b7fd-4208-a2a6-2e84c9e61bcd", "request_items": [ { "id": 0, "data_hash": "6e718a93b02a30a98cb994d1c4e8cf1eeedcb962f384e4a463c" , "status": "accepted" } ], "errors": false }
-
检查此异步请求的状态:
code language-none curl --location 'https://site.test/rest/default/V1/bulk/b101ddcb-b7fd-4208-a2a6-2e84c9e61bcd/detailed-status' \ --header 'Authorization: Bearer eyJraWQiOiIxIiwiYWxnIjoiSFMyNTYifQ.eyJ1aWQiOjEsInV0eXBpZCI6MiwiaWF0IjoxNjc5NDMzNzcxLCJleHAiOjE2Nzk0MzczNzF9.xau6KyILrkdCY_8K8aMlH4TmqcCXdH4Zcst_CLhdxYY' \ --header 'Cookie: PHPSESSID=844fltmqq1g15qe4ju3l00tiai
预期的结果:
对于新客户,group_id正确设置为2。
实际结果:
对于新客户,group_id设置为默认值1。
{
"operations_list": [
{
"id": 0,
"bulk_uuid": "b101ddcb-b7fd-4208-a2a6-2e84c9e61bcd",
"topic_name": "async.magento.customer.api.accountmanagementinterface.createaccount.post",
"serialized_data": null,
"result_serialized_data": "{\"id\":4,\"group_id\":1,\"created_at\":\"2023-03-21 22:01:09\",\"updated_at\":\"2023-03-21 22:01:09\",\"created_in\":\"Default Store View\",\"email\":\"foo@bar.test\",\"firstname\":\"Test\",\"lastname\":\"User\",\"store_id\":1,\"website_id\":1,\"addresses\":[],\"disable_auto_group_change\":0,\"extension_attributes\":{\"is_subscribed\":false}}",
"status": 1,
"result_message": "Service execution success Magento\\Customer\\Model\\AccountManagement\\Interceptor::createAccount",
"error_code": null
}
],
"user_type": 2,
"bulk_id": "b101ddcb-b7fd-4208-a2a6-2e84c9e61bcd",
"description": "Topic async.magento.customer.api.accountmanagementinterface.createaccount.post",
"start_time": "2023-03-21 22:01:09",
"user_id": 1,
"operation_count": 1
}
应用修补程序
要应用单独的修补程序,请根据您的部署方法使用以下链接:
- Adobe Commerce或Magento Open Source内部部署: Quality Patches Tool指南中的Quality Patches Tool >使用情况。
- 云基础架构上的Adobe Commerce:云基础架构上的Commerce指南中的升级和修补程序>应用修补程序。
相关阅读
要了解有关Quality Patches Tool的更多信息,请参阅:
- Quality Patches Tool 已发布:支持知识库中用于自助提供高质量修补程序的新工具。
- 使用Quality Patches Tool指南中的 Quality Patches Tool检查修补程序是否可用于您的Adobe Commerce问题。
有关QPT中其他可用修补程序的信息,请参阅Quality Patches Tool指南中的Quality Patches Tool:搜索修补程序。
recommendation-more-help
c2d96e17-5179-455c-ad3a-e1697bb4e8c3