تحديث منشور عبر طلب PUT في واجهة برمجة التطبيقات: طلب

فقط للتأكد من الفهم، تشير وثائق API الخاصة بـ Discourse إلى هذا النوع من… الهيكل…

{
"post[raw]": "string",
"post[raw_old]": "string",
"post[edit_reason]": "string",
"post[cooked]": "string"
}

قبل أن أحاول ذلك، هل يعني هذا، أو حسنًا… ماذا يعني بالضبط؟

هل يعني: {post: {raw: ..., raw_old: ... }}

أم ببساطة {raw: "", raw_old: ""...}؟

وكذلك، ما هو raw_old؟ تذكر الوثائق فقط أن كل عنصر هو “سلسلة” (string) مما يجب أن أضعه في جسم JSON.

أحاول ببساطة إضافة سطر في أعلى المنشور (الذي تم إنشاؤه في البداية بواسطة بوت) حيث نحتاج إلى إضافة رابط إلى موقع آخر. لاحظ أيضًا أننا نسعى إلى عرض تلك الفقرة الأولى تحت عنوان الفئة، أو في عنصر cooked

الذي سيظهر (مُعرَّف مباشرةً تحت عنوان الفئة).

آمل أن يكون هذا منطقيًا. إذا لم يكن كذلك، اطلب مني التوضيح.

I’m not actually sure what raw_old is for at the moment, but you just need to use the raw field and it will replace the entire post. So, in your code you would fetch the post you want to edit, add your line to the top, then update the post using the raw field.

It might be helpful to see how Discourse does it by editing a post live on your site and inspecting the browser calls:

This is also how the discourse_api gem does it:

3 إعجابات

Just a question on this, are you referring to different documentation then what is defined at Discourse API Docs ? That would be interesting… however I am only going by the API docs.

My simple goal is to simply add a comment + link below the category name, which I think Discourse takes from the first Post of the "About … " topic? Like I’m just looking for what it will insert into the

… element or what I need to do to make my post appear there. Does my explanation make sense?

From the above, and from attempting, you can not update a post using “cooked” as the API documentation states, it is however possible with “raw”, all attempts I made using “cooked” kept giving me back an error that my post was invalid as it was under 20 characters, or not a clear sentence …

However there are additional issues with “raw” that I will make into another post as this isn’t directly related.

Thanks for all your help.

There is a slight discrepancy in API Docs:

Documentation says: PUT /posts/{id}.json with payload

Content type: application/json

{
  "post[raw]": "string",
  "post[raw_old]": "string",
  "post[edit_reason]": "string",
  "post[cooked]": "string"
}

but this only works with PUT /posts/{id} and Content-Type: application/x-www-form-urlencoded.

The correct payload for PUT /posts/{id}.json should be:

Content type: application/json

{
  "post": {
      "raw": "string",
      "raw_old": "string",
      "edit_reason": "string",
      "cooked": "string"
    }
}

The raw parameter is sufficient for replacing the entire post.

5 إعجابات

Yes, thanks, I realized this after attempting a few Postman requests and playing around with it… also in my attempts, the “cooked” seemed to do nothing… and I’m still not sure what “raw_old” is.

تم تصعيد هذا اليوم وتم تعييني له. ربما يمكن إلغاء تعييني :slight_smile:
على أي حال، الوثائق صحيحة الآن: https://docs.discourse.org/#tag/Posts/operation/updatePost.

3 إعجابات