Expiração automática de crachá

Gostaria de oferecer benefícios aos usuários do meu Discourse que permanecem engajados periodicamente. Por exemplo, quero conceder benefícios apenas para usuários que convidem pelo menos 1 novo usuário por mês.

Eu poderia configurar isso dizendo que todos os usuários que possuem a medalha “Promotor” receberiam tais benefícios. No entanto, a medalha “Promotor” exige que o usuário convide apenas um visitante e, em seguida, ele mantém essa medalha para sempre.

Existe uma maneira de configurar uma expiração automática de medalha para que, após um mês, a medalha “Promotor” (ou qualquer outra) seja removida do usuário, exigindo que ele a conquiste novamente?

Ou existe uma abordagem melhor para o que estou tentando fazer (exigir engajamento mensal dos usuários)?

Obrigado antecipadamente.

Definitely an interesting idea.

@codinghorror, I understand then that there is no such feature yet? :slight_smile:
Is there any workaround that can be used to implement this, even if manually? The main problem I see now is that I can’t see even information about when a badge was granted to a user. Is this available somewhere, even if it via API?

I guess you could use Discourse Data Explorer Plugin to replicate SQL queries and add time constraints to create new “expiring” badges. I did not check in the #plugin:data-explorer category or (Superseded) What cool data explorer queries have you come up with? collection if there are such queries already. It would definitely be appreciated to share what you come up with in this topic!

Under the 3 lines next to your Avatar, click Badges. Each badge has a number… for how many users have it. Click on the number it shows. Then, each user with the badge will be listed with the date they earned the badge.

But why would anyone want expiring badges? Users will get ticked, IMO.

This is actually a common ask within the community space. Badges that are tied to more recent/current actions of the users vs. the historical granting of badges you get to keep forever regardless of whether or not you are still active in the community. Especially for communities that have been up for years. Facebook does this with the “Top Fan” badge which is not static and can go away if you fade away from participating on the page.

If I simply manually delete a badge from an user, will he/she gain that badge again if he perform the needed actions?

Para isso, acho que o conselho ainda seria criar novos distintivos que tivessem um elemento de tempo incorporado à consulta SQL subjacente.

Se alguém quiser ajuda com uma consulta, pode iniciar um tópico em Data & reporting. :+1: