Strapi Beta (3.0) 的自定义控制器代码

IT技术 javascript node.js reactjs ecmascript-6 strapi
2021-05-08 04:03:12

我有一些来自先前版本的 Strapi 的代码可以工作,而控制器的 beta 版本则大不相同。添加了 multipart / santization 样板,并且发生了一些变化。不明白如何整合我的订单对象和条纹收费。

这是添加的样板:

  module.exports = {
       async create(ctx) {


 // New Boilerplate added with Strapi Beta - how to integrate this with custom stuff below? 
 let entity;
   if (ctx.is('multipart')) {
     const { data, files } = parseMultipartData(ctx);
     entity = await service.create(data, { files });
   } else {
     entity = await service.create(ctx.request.body);
   }
return sanitizeEntity(entity, { model });
 }
  }

这是我的自定义代码(控制器名称是 Order.js)

 const { address, amount, products, postalCode, token, city } = ctx.request.body;

 // Send charge to Stripe
 const charge = await stripe.charges.create({
   amount: amount * 100,
   currency: 'usd',
   description: `Order ${new Date(Date.now())} - User ${ctx.state.user.id}`,
   source: token
 });

 // Create order in database
 const order = await strapi.services.order.add({
   user: ctx.state.user.id,
   address,
   amount,
   products,
   postalCode,
   city
 });

看起来我会将我的代码添加到 if 语句的第二部分,因为它不是多部分,但如果“实体”是真正的变量名 Strapi 需要或占位符变量,我将其重命名为“订单”代码在 Alpha 中工作正常,但阅读 Strapi 文档并没有解释如何将这个结构与“实体”、{模型} 和“数据”变量一起使用。

1个回答

在以前的 Strapi 版本中,要将文件上传到新条目,您必须首先创建条目,然后上传图像并指定要链接此图像的条目。现在使用 multipart,您可以在发送输入属性的同时发送图像。

现在关于您的用例,service.必须替换为strapi.api.order.service.order您的案例。我同意文档不清楚!我会立即更新。

const { parseMultipartData, sanitizeEntity } = require('strapi-utils');

module.exports = {
  async create(ctx) {
    // New Boilerplate added with Strapi Beta - how to integrate this with custom stuff below?
    let entity;
    if (ctx.is('multipart')) {
      const { data, files } = parseMultipartData(ctx);
      entity = await strapi.api.order.services.order.create(data, { files });
    } else {
      const { address, amount, products, postalCode, token, city } = ctx.request.body;

      // Send charge to Stripe
      const charge = await stripe.charges.create({
        amount: amount * 100,
        currency: 'usd',
        description: `Order ${new Date(Date.now())} - User ${ctx.state.user.id}`,
        source: token
      });

      entity = await strapi.api.order.services.order.create({
        user: ctx.state.user,
        address,
        amount,
        products,
        postalCode,
        city
      });
    }
    return sanitizeEntity(entity, { model: strapi.query('order').model });
  }
}