1

我使用这个技巧(感谢@Robban)通过 API 发布一个有内容的条目,而不触发 webhook。

但是,我无法弄清楚如何在不触发 webhook 的情况下通过 API 取消发布条目。

根据 Contentful 文档,要通过 API 取消发布条目,如下所示:

client.getSpace('<space_id>')
  .then((space) => space.getEntry('<entry_id>'))
  .then((entry) => entry.unpublish())

作为<entry_id>唯一的有效负载,我如何向 webhook 指示它不应该像往常一样进行,因为它是一个 API 调用?

4

1 回答 1

1

不幸的是,直接从 API 调用或从 Web 应用程序调用之间没有区别。Web 应用程序在后台执行此调用。

此外,在取消发布的情况下,您的 webhook 将收到的唯一内容是不包含任何字段的删除对象。这意味着上一个答案中显示的技巧不适用于此处。

我能想到的解决这个问题的唯一方法是再次调用某个数据存储(可能是内容存储)并将条目 ID 和一些时间戳放在那里。然后,您的 webhook 可以在收到取消发布事件后查询此数据存储并查看处理是否应该继续,或者是否取消发布似乎是通过网络应用程序进行的。

基本上是这样的:

client.getSpace('<space_id>')
.then((space) => space.getEntry('<entry_id>'))
.then((entry) => {

         otherService.SetUnpublishedThroughManualAPICall(entry.sys.id);
         entry.unpublish();

      })

然后在你的 webhook 中使用一些伪代码:

function HandleUnpublish(object entry) {

    if(OtherService.CheckIfManualUnpublish(entry.sys.id)){
         //Do some processing...
    }
}

您可以选择使用 Contentful 中的字段作为您的商店。在这种情况下,您将在取消发布之前设置此字段。像这样的东西:

client.getSpace('<space_id>')
.then((space) => space.getEntry('<entry_id>'))
.then((entry) => { 
     entry.fields['en-US'].unpublishedTroughApi = true;
     entry.update();
 })
.then((entry) => entry.unpublish())

然后在您的 webhook 中,您必须通过管理 API 再次获取条目并检查该字段。请记住,这会导致对 Contentful 进行大量额外的 API 调用。

于 2017-10-29T18:55:44.900 回答