منح شارة مخصصة عبر API

Custom badges that you have created on your forum can be granted through the API. This is a great way to award badges without having to use custom badge SQL.

To grant a badge through the API, you need to know the username of the user that you wish to grant the badge to, and the ID of the badge you wish to grant. You also need to make sure you have generated an All Users API Key from your site’s Admin/API section.

Finding your API Key

This screenshot is from my local development site. Generally, you need to be very careful about sharing your API keys:

Finding the Badge ID

You can get the Badge ID from the badge’s URL. Go to your Admin/Badges section and then click on the badge that you wish to grant. The URL will look something like this: https://forum.example.com/admin/badges/102. The last number in the URL is the badge ID.

Making the API call

To test an API call, you can try granting a badge using curl or Postman. Here is how I grant a badge from my computer’s terminal with curl.

First, to make things easier, set an api_key variable:

 api_key=yourallusersapikey

Then to grant a badge with the ID of 102 to the user bobby:

curl -X POST "https://forum.example.com/user_badges" \
-H "Content-Type: multipart/form-data;" \
-H "Api-Key: $api_key" \
-H "Api-Username: system" \
-F "username=bobby" \
-F "badge_id=102" \
-F "reason=https://forum.example.com/t/whats-the-best-photo-youve-ever-taken/160/2"

The reason parameter is optional. If you supply it, it must be set to the URL of a topic or a post on your site.

You should get a JSON response with details about the badge and when it was granted.

26 إعجابًا

Has anybody added a badge (or flair) via Zapier to Discourse API like outlined here?

Also, seems like a great candidate for an action via the official integration, @HAWK.

3 إعجابات

انظر أيضًا https://meta.discourse.org/t/how-to-create-a-custom-badge-with-an-image-through-the-api/210616، والذي يوضح كيفية التحميل، ويتضمن أيضًا مثالًا آخر لمنح الشارة (بلغة بايثون).

إعجاب واحد (1)

ما هو سبب عدم وصف هذه الطريقة في وثائق واجهة برمجة التطبيقات على https://docs.discourse.org/؟

لم أتمكن من العثور عليها هناك.

إعجابَين (2)

لأنه لا يبدو أن هناك وظيفة لأي شخص للحفاظ على هذه الوثائق كاملة أو محدثة، وقد نشر شخص طيب هذه التعليمات هنا. بشكل عام، وثائق واجهة برمجة التطبيقات هي الهندسة العكسية لواجهة برمجة تطبيقات Discourse والنظر في المصدر.

7 إعجابات

جميل، إذن لا توجد طريقة لأتمتة منح شارات كهذه عبر واجهة برمجة التطبيقات؟

على سبيل المثال، يُمنح شخص ما شارةً لحصوله على 5000 إعجاب على ردوده.

إعجاب واحد (1)

إذا كنت تستضيف بنفسك، أو على إصدار Enterprise، فأنت تريد تمكين شارة SQL.

إعجابَين (2)

إذا لم تتمكن من تمكين شارة SQL، فسيكون من الممكن تقنيًا أتمتة ذلك، ولكنه سيكون عملية من خطوتين. أولاً، قم بإجراء طلب API لتشغيل استعلام مستكشف البيانات الذي يُرجع أسماء المستخدمين للمستخدمين الذين يستوفون معاييرك والذين لم يتم منحهم الشارة بعد: تشغيل استعلامات مستكشف البيانات باستخدام Discourse API. ثم، استخدم أسماء المستخدمين التي تم إرجاعها بواسطة هذا الاستعلام لمنح الشارة عبر API.

هذا يبدو غير فعال إلى حد ما. على حد علمي، لا يوجد مسار يمكن استخدامه لمنح شارة لعدة مستخدمين بمكالمة API واحدة، لذلك اعتمادًا على عدد المستخدمين المؤهلين للشارة، قد ينتهي بك الأمر بإجراء الكثير من طلبات API.

في النهاية، يبدو هذا من نوع الأشياء التي يمكن التعامل معها بواسطة المكون الإضافي للأتمتة. يمكن أن يكون هناك مشغل متكرر يقوم بتشغيل استعلام مستكشف البيانات بمعرف استعلام معين. بناءً على الحقول التي تم إرجاعها بواسطة الاستعلام، يمكن استخدام النتائج لتشغيل نصوص برمجية مختلفة. على سبيل المثال، إذا تم إرجاع حقل username بواسطة الاستعلام، فيمكن استخدامه لتشغيل نصوص برمجية تمنح شارات، أو تضيف مستخدمين إلى مجموعات، وما إلى ذلك.

إعجابَين (2)

ألن يكون هذا له نفس المشاكل التي أدت إلى تعطيل استعلام الشارة في المقام الأول؟

إعجاب واحد (1)

لا أعتقد ذلك. يتم تشغيل استعلامات مستكشف البيانات في كتلة معاملة تنتهي مهلتها بعد 10 ثوانٍ. أعتقد أن الهدف من ذلك هو تجنب نوع المشكلة التي يمكن أن تؤدي إليها استعلامات الشارات. إذا لم يتم تكوين الأشياء بهذه الطريقة، يمكن لاستعلام مستكشف بيانات غير فعال أن يتسبب في تعطل الموقع.

بالتفكير في ذلك الآن، أتساءل عما إذا كان يمكن أن يكون لـ SQL المخصص للشارات نفس النوع من الضمانات.

4 إعجابات