Expose Category and Group IDs to admins

Hi, I think it would make it easier for admins to edit data explorer queries if it was easier to find Category and Group IDs. If this information was made visible to accounts with admin status it wouldn’t bother most people while making it simple to find for those who need access.

Alternatively, in the meantime, if there are already easy ways to find Category and Group IDs, I’m eager to learn how to find this information.

1 curtida

I’ll admit it’s not super easy to find if you don’t know where to look, but here’s a couple ways:

  • Data Explorer query:

    SELECT name, id FROM categories ORDER BY name
    
  • via categories.json

    curl https://meta.discourse.org/categories.json | jq '.category_list.categories[] | [.name,.id]'`
    …info for all categories…
    
    curl https://meta.discourse.org/categories.json | jq '.category_list.categories[] | select(.name == "feature").id'
    2
    
  • via the JS console in the browser, e.g.:

    > Discourse.Category.findBySlug('feature').id
    2
13 curtidas

For Data Explorer queries, you can use a pattern similar to the WHERE statement in this query to avoid having to lookup category or group ids:

--[params]
-- string :category_name

SELECT
id AS topic_id
FROM topics t
WHERE t.category_id = (SELECT id FROM categories WHERE name = :category_name)
7 curtidas

Reabrindo este tópico porque tive a mesma pergunta. Para categorias, é relativamente fácil olhar para o URL:

https://meta.discourse.org/c/announcements/67
                                           ^^

Mas não consigo encontrar nada parecido para grupos. Um local ideal para isso seria na página de perfil do grupo (/g/[group_name]/manage/profile), em algum lugar. Não é um grande problema, claro (o Explorador de Dados é meu cobertor de segurança), mas é um incômodo ao trabalhar com a API.

Para qualquer coisa interna, você pode simplesmente adicionar .json após um URL. Também funciona para aqueles identificadores de postagem irritantes.

2 curtidas

Meu voto para o explorador de dados seria por mais parâmetros no estilo user_id como este Feature request para grupos:

5 curtidas