Php 如何从Shopware 6中的产品流ID获取产品?

Php 如何从Shopware 6中的产品流ID获取产品?,php,symfony4,shopware6,Php,Symfony4,Shopware6,我正在尝试创建一个自定义命令,在该命令中,我希望利用Shopware 6的动态产品组功能来获取与特定产品组(也称为产品流)中的过滤器匹配的产品 我这样做最初是为了获取流,但是我不知道如何应用过滤器来获取产品 $streamCriteria = new Criteria($productStreamIds); $streamCriteria->addAssociation('productCrossSellings');

我正在尝试创建一个自定义命令,在该命令中,我希望利用Shopware 6的动态产品组功能来获取与特定产品组(也称为产品流)中的过滤器匹配的产品

我这样做最初是为了获取流,但是我不知道如何应用过滤器来获取产品

            $streamCriteria = new Criteria($productStreamIds);
            $streamCriteria->addAssociation('productCrossSellings');
            $streamCriteria->addAssociation('productExports');
            $streamCriteria->addAssociation('filters');

            $streams = $this->streamRepository->search($streamCriteria, $context)->getEntities();
            /** @var ProductStreamEntity $stream */
            foreach ($streams as $stream) {
                foreach ($stream->getFilters() as $filter) {
                    $productCriteria->addAggregation($filter); // DOES NOT WORK
                    $productCriteria->addFilter($filter); // DOES NOT WORK EITHER
                }
            }
我试图获取
过滤器
,它提供了应用于产品流的过滤器数组,但由于预期的类型不同,它不能直接应用于
标准->addFilter()

这是我得到的过滤器阵列:

Shopware\Core\Content\ProductStream\Aggregate\ProductStreamFilter\ProductStreamFilterCollection^ {#10304
  #elements: array:5 [
    "2c6a8a44d9c544f2812024f6414d56f9" => Shopware\Core\Content\ProductStream\Aggregate\ProductStreamFilter\ProductStreamFilterEntity^ {#11014
      #type: "multi"
      #field: null
      #operator: "OR"
      #value: null
      #productStreamId: "160274948d684a73afad0bde6aee19e8"
      #parentId: null
      #productStream: null
      #queries: null
      #parent: null
      #position: 0
      #parameters: null
      #customFields: null
      #_uniqueIdentifier: "2c6a8a44d9c544f2812024f6414d56f9"
      #versionId: null
      #translated: []
      #createdAt: DateTimeImmutable @1600069477 {#3113
        date: 2020-09-14 07:44:37.521 UTC (+00:00)
      }
      #updatedAt: null
      #_entityName: "product_stream_filter"
      #extensions: array:1 [
        "foreignKeys" => Shopware\Core\Framework\Struct\ArrayStruct^ {#11007
          #data: []
          #apiAlias: null
          #extensions: []
        }
      ]
      #id: "2c6a8a44d9c544f2812024f6414d56f9"
    }
    "6dff7581e91a477ea2eca564a099eb90" => Shopware\Core\Content\ProductStream\Aggregate\ProductStreamFilter\ProductStreamFilterEntity^ {#10832
      #type: "range"
      #field: "width"
      #operator: null
      #value: null
      #productStreamId: "160274948d684a73afad0bde6aee19e8"
      #parentId: "2c6a8a44d9c544f2812024f6414d56f9"
      #productStream: null
      #queries: null
      #parent: null
      #position: 1
      #parameters: array:1 [
        "lte" => 749
      ]
      #customFields: null
      #_uniqueIdentifier: "6dff7581e91a477ea2eca564a099eb90"
      #versionId: null
      #translated: []
      #createdAt: DateTimeImmutable @1600069477 {#2958
        date: 2020-09-14 07:44:37.523 UTC (+00:00)
      }
      #updatedAt: null
      #_entityName: "product_stream_filter"
      #extensions: array:1 [
        "foreignKeys" => Shopware\Core\Framework\Struct\ArrayStruct^ {#10871
          #data: []
          #apiAlias: null
          #extensions: []
        }
      ]
      #id: "6dff7581e91a477ea2eca564a099eb90"
    }
    "754b78c4ec74492bb96dc724f3e7ba6a" => Shopware\Core\Content\ProductStream\Aggregate\ProductStreamFilter\ProductStreamFilterEntity^ {#10766
      #type: "range"
      #field: "weight"
      #operator: null
      #value: null
      #productStreamId: "160274948d684a73afad0bde6aee19e8"
      #parentId: "2c6a8a44d9c544f2812024f6414d56f9"
      #productStream: null
      #queries: null
      #parent: null
      #position: 2
      #parameters: array:1 [
        "gte" => 293
      ]
      #customFields: null
      #_uniqueIdentifier: "754b78c4ec74492bb96dc724f3e7ba6a"
      #versionId: null
      #translated: []
      #createdAt: DateTimeImmutable @1600069477 {#10274
        date: 2020-09-14 07:44:37.525 UTC (+00:00)
      }
      #updatedAt: null
      #_entityName: "product_stream_filter"
      #extensions: array:1 [
        "foreignKeys" => Shopware\Core\Framework\Struct\ArrayStruct^ {#10774
          #data: []
          #apiAlias: null
          #extensions: []
        }
      ]
      #id: "754b78c4ec74492bb96dc724f3e7ba6a"
    }
    "86d2c2bd8df14f8684c8f4c801e5a19a" => Shopware\Core\Content\ProductStream\Aggregate\ProductStreamFilter\ProductStreamFilterEntity^ {#10272
      #type: "range"
      #field: "height"
      #operator: null
      #value: null
      #productStreamId: "160274948d684a73afad0bde6aee19e8"
      #parentId: "2c6a8a44d9c544f2812024f6414d56f9"
      #productStream: null
      #queries: null
      #parent: null
      #position: 3
      #parameters: array:1 [
        "gte" => 746
      ]
      #customFields: null
      #_uniqueIdentifier: "86d2c2bd8df14f8684c8f4c801e5a19a"
      #versionId: null
      #translated: []
      #createdAt: DateTimeImmutable @1600069477 {#10313
        date: 2020-09-14 07:44:37.526 UTC (+00:00)
      }
      #updatedAt: null
      #_entityName: "product_stream_filter"
      #extensions: array:1 [
        "foreignKeys" => Shopware\Core\Framework\Struct\ArrayStruct^ {#11009
          #data: []
          #apiAlias: null
          #extensions: []
        }
      ]
      #id: "86d2c2bd8df14f8684c8f4c801e5a19a"
    }
    "9b763069551244179dbc1f285290b673" => Shopware\Core\Content\ProductStream\Aggregate\ProductStreamFilter\ProductStreamFilterEntity^ {#10283
      #type: "equalsAny"
      #field: "id"
      #operator: null
      #value: "c01c974a89eb4f17ab78c48251864eb7|5c0e5bc5f03d42a6980c11bf8ab67428"
      #productStreamId: "160274948d684a73afad0bde6aee19e8"
      #parentId: "2c6a8a44d9c544f2812024f6414d56f9"
      #productStream: null
      #queries: null
      #parent: null
      #position: 0
      #parameters: null
      #customFields: null
      #_uniqueIdentifier: "9b763069551244179dbc1f285290b673"
      #versionId: null
      #translated: []
      #createdAt: DateTimeImmutable @1600069477 {#12983
        date: 2020-09-14 07:44:37.522 UTC (+00:00)
      }
      #updatedAt: null
      #_entityName: "product_stream_filter"
      #extensions: array:1 [
        "foreignKeys" => Shopware\Core\Framework\Struct\ArrayStruct^ {#10356
          #data: []
          #apiAlias: null
          #extensions: []
        }
      ]
      #id: "9b763069551244179dbc1f285290b673"
    }
  ]
  #extensions: []
}

productCrossSellings
productExports
关联也都返回了
null
(虽然我不知道这些变量的用途,但我想可能是内部使用它来获取该组的关联产品)


所以我的问题是,我们如何获得与产品组中的过滤器匹配的产品?

您可以查看
\Shopware\Core\Content\ProductStream\Service\ProductStreamBuilder
以及它在
\Shopware\Core\Content\Product\salesschannel\crosssell\salesschannelcrosssellingcontroller::LoadProductsForcrosssell中的使用方式

我希望这会有帮助