装饰(修改)一个Service
/htdocs/engine/Shopware/Bundle/StoreFrontBundle/Service/Core/ListProductService.php
可以在上面路径中找到ListProductService.php
文件 ==> 该 service 已存在。
定义该service的xml配置文件在/htdocs/engine/Shopware/Bundle/StoreFrontBundle/services.xml
。在这里面看到ListProductService.php被定义,如下:
我们自己定义的services.xml这样写:
属性id是新建的service的id,而decorate中是将要被修改的service的id。
这句代码的功能为:告诉服务器将用swag_example.list_product_service
代替 id 为shopware_storefront.list_product_service
的service。而旧的service通过
被重命名为swag_example.list_product_service.inner
,通过这种办法将旧的service注入到我们新建的service中。
注意:这里的
的id的命名基于新service的id,但有一定自由度,你也可以命名为比如
swag_example.list_product_service.wooz
```
更多关于service decorate的信息
这里相关的修改已经涉及到Symfony的知识点,跟多相关接下来对该service进行修改。
namespace SwagExample\Bundle\StoreFrontBundle;
// 引用需要用到的两个接口(这两个接口在原本的ListProductService.php中就有被引用,原文件中有许多许多被引用的文件,但这里只引用我们需要的)
use Shopware\Bundle\StoreFrontBundle\Service\ListProductServiceInterface;
use Shopware\Bundle\StoreFrontBundle\Struct\ProductContextInterface;
class ListProductService implements ListProductServiceInterface
{
private $service;
public function __construct(ListProductServiceInterface $service)
{
$this->service = $service;
}
public function getList(array $numbers, ProductContextInterface $context)
{
$products = $this->service->getList($numbers, $context);
//...
return $products;
}
public function get($number, ProductContextInterface $context)
{
return array_shift($this->getList([$number], $context));
}
}
到这里service decoration的内容告一段落 END
#### 实例
SwagSloganOfTheDay
├── Resources
│ └── services.xml xml为配置文件; 该文件中可新定义services; 或重写 / 修改核心service
├──SloganPrinter.php
├──RouteSubscriber.php
└──SwagSloganOfTheDay.php 主php文件,入口文件; 包含安装 / 卸载函数; 调用service.xml中的services
在shopware新的插件系统中,我们可以在services.xml中利用service的`tag`标签添加subscriber ==> 通过这种方式,Shopware能够自动加载所有事件监听器(event subscriber)而不用再手动声明。
> service的 `tag` 标签该service用于某个特定目的(specific purpose)
xsi:schemaLocation="http://symfony.com/schema/dic/services http://symfony.com/schema/dic/services/services-1.0.xsd">
注册带tpl的Controller
首先在插件的主php文件中注册controller:
'registerController',
];
}
// 注册控制器
public function registerController(\Enlight_Event_EventArgs $args)
{
// 获取模板文件路径
$this->container->get('template')->addTemplateDir(
$this->getPath() . '/Resources/views/'
);
return $this->getPath() . '/Controllers/Frontend/MyController.php';
}
}
编写的插件中,Controller需要放在固定路径下:SwagControllerExample/Controllers/(Backend|Frontend|Widgets|Api)/MyController.php
Controller的命名也需要遵守规则。在Controller的preDispatch()方法中,我们完成了模板template的注册。
class Shopware_Controllers_Frontend_MyController extends \Enlight_Controller_Action
{
public function preDispatch()
{
$pluginPath = $this->container->getParameter('swag_controller_example.plugin_dir');
// 添加模板路径
$this->get('template')->addTemplateDir($pluginPath . '/Resources/views/');
$this->get('snippets')->addConfigDir($pluginPath . '/Resources/snippets/');
}
}```