Prestashop - 我的模块的 REST 端点

Posted

技术标签:

【中文标题】Prestashop - 我的模块的 REST 端点【英文标题】:Prestashop - REST endpoints for my module 【发布时间】:2018-10-05 23:37:57 【问题描述】:

我正在开发 Prestashop 模块,它将导出客户数据和订单,它将包含用于客户同步、购物车和订单事件的挂钩 - 通常是与类似 CRM 服务的集成模块。

我的模块包含它自己的视图,在 vue.js 中制作 - 单页,异步。有注册、登录、设置等页面。与后端的通信是通过 baseUrl/mymodule/actionname 路由上的 GET/POST 请求和 vue 视图所依赖的简单 json 响应进行的。只需为我的模块创建 REST 端点,如下例所示。

Wordpress 自定义 RestApi:

class RestApi

    public function __construct()
    
        add_action('rest_api_init', array(get_class($this), 
        'register_endpoints'));
    

    public static function register_endpoints()
    
        register_rest_route('mymodule', '/login', array(
            'methods' => WP_REST_Server::CREATABLE,
            'callback' => array('RestApi', 'login' ),
        ));
    

SugarCRM 自定义 RestApi:

class ModuleRestApi extends SugarApi

    public function registerApiRest()
    
        return [
            'moduleLogin' => [
                'reqType' => 'POST',
                'noLoginRequired' => true,
                'path' => [
                    'mymodule', 'login'
                ],
                'method' => 'login'
            ],
        ];
    

我在 PrestaShop 中找不到类似的解决方案,presta 文档中没有关于自定义端点的消息,我尝试使用带有友好 url 的 FrontModuleControllers,但它似乎对我不起作用,它会抛出很多东西作为响应对我来说没用,当我尝试覆盖 init() 方法时,它也需要很多东西才能真正启动控制器。我需要简单的 REST 解决方案,我可以在其中放置用于从我的视图接收数据的逻辑,将其传递给我的 CRM 服务并将 json 响应返回到我的视图。我不需要更多的模板或视图渲染,只需要路由即可。

【问题讨论】:

【参考方案1】:

可以使用 Prestashop Web 服务,它允许从模块中添加资源。这种解决方案可以在标准和安全方面节省一些时间。

有关 Prestashop Webservice 中模块资源的文档在此链接中:

https://webkul.com/blog/creating-prestashop-module-webservice-api/

【讨论】:

【参考方案2】:

PrestaShop 不支持此功能。但是,您可以使用模块和前端控制器来做到这一点。

这是一个基本的例子。

1.注册友好 URL 的模块

class RestApiModule extends Module

    public function __construct() 
    
        $this->name = 'restapimodule';
        $this->tab = 'front_office_features';
        $this->version = '1.0';

        parent::__construct();
    

    public function install() 
    
        return parent::install() && $this->registerHook('moduleRoutes');
    

    public function hookModuleRoutes()
    
        return [
            'module-restapimodule-login' => [
                'rule' => 'restapimodule/login',
                'keywords' => [],
                'controller' => 'login',
                'params' => [
                    'fc' => 'module',
                    'module' => 'restapimodule'
                ] 
            ]              
        ];
    

2。创建一个抽象的 REST 控制器

创建一个抽象控制器,以便实际的端点可以从它扩展。在您的模块controllers 文件夹中创建它,然后将其命名为AbstractRestController.php

abstract class AbstractRestController extends ModuleFrontController

    public function init() 
    
        parent::init();
        switch ($_SERVER['REQUEST_METHOD']) 
            case 'GET':
                $this->processGetRequest();
                break;
            case 'POST':
                $this->processPostRequest();
                break;
            case 'PATCH': // you can also separate these into their own methods
            case 'PUT':
                $this->processPutRequest();
                break;
            case 'DELETE':
                $this->processDeleteRequest();
                break;
            default:
                // throw some error or whatever
        
    

    abstract protected function processGetRequest();
    abstract protected function processPostRequest();
    abstract protected function processPutRequest();
    abstract protected function processDeleteRequest();

3。创建一个实际的前端控制器

在您的模块controllers/front 文件夹中创建前端控制器并将其命名为login.php

require_once __DIR__ . '/../AbstractRestController.php';

class RestApiModuleLoginModuleFrontController extends AbstractRestController

    protected function processGetRequest()
    
        // do something then output the result
        $this->ajaxDie(json_encode([
            'success' => true,
            'operation' => 'get'
        ]));
    

    protected function processPostRequest()
    
        // do something then output the result
        $this->ajaxDie(json_encode([
            'success' => true,
            'operation' => 'post'
        ]));
    

    protected function processPutRequest()
    
        // do something then output the result
        $this->ajaxDie(json_encode([
            'success' => true,
            'operation' => 'put'
        ]));
    

    protected function processDeleteRequest()
    
        // do something then output the result
        $this->ajaxDie(json_encode([
            'success' => true,
            'operation' => 'delete'
        ]));
    

安装模块,现在你可以点击http://example.com/restapimodule/login,根据请求类型,它会做任何你想做的事情,你会得到 JSON 响应。

要添加更多端点,请在 hookModuleRoutes 数组中添加另一个 module-restapimodule-endpointname 条目以及从 AbstractRestController 扩展的前端控制器。

如果您还想要正确的响应代码等,您将不得不使用本机 php 函数设置标头,因为 PrestaShop afaik 没有任何实用程序可以为您执行此操作或使用某种库。

同样适用于您可能想要设置的任何其他标头,例如 content-type(默认为 text/html)。

【讨论】:

谢谢先生!这正是我想要的。 你好@maciey_b 你有这个工作吗?我尝试编写相同的示例,当我尝试点击 /restapimodule/login 时出现“找不到页面”谢谢

以上是关于Prestashop - 我的模块的 REST 端点的主要内容,如果未能解决你的问题,请参考以下文章

Prestashop 没有错误/空白页

Prestashop 1.7 模块目录数据未找到

模块 Prestashop 嫁接钩子模块是不同的服务器开发和预生产

未找到PrestaShop模块类(名称空间)

Prestashop PayPal 模块不会保存设置

使用 Prestashop 1.6 在模块中获取产品类别名称