Puxar lista de RSVP do Evento através do Data Explorer

Estamos tentando aumentar a participação em nosso evento, encontrando usuários que interagiram com conteúdo semelhante existente. Com a ajuda do bot de IA, conseguimos elaborar a seguinte consulta.

-- [params]
-- text :keyword
-- int :min_engagements
-- null string :tag_name

WITH keyword_posts AS (
    SELECT
        p.id AS post_id
    FROM
        posts p
    JOIN
        topics t ON t.id = p.topic_id
    LEFT JOIN
        topic_tags tt ON tt.topic_id = t.id
    LEFT JOIN
        tags tg ON tg.id = tt.tag_id
    WHERE
        p.raw ILIKE '%' || :keyword || '%'
        AND (:tag_name is null OR tg.name = :tag_name)
),
user_engagement AS (
    SELECT
        ua.user_id,
        COUNT(DISTINCT ua.target_post_id) AS engaged_posts_count
    FROM
        user_actions ua
    JOIN
        keyword_posts kp ON kp.post_id = ua.target_post_id
    WHERE
        ua.action_type IN (1, 4, 5, 6)
    AND ua.user_id NOT IN (
        SELECT gu.user_id
        FROM group_users gu
        JOIN groups g ON g.id = gu.group_id
        WHERE g.name = 'developer_relations'
    )
    GROUP BY
        ua.user_id
)
SELECT
    ue.user_id,
    ue.engaged_posts_count
FROM
    user_engagement ue
WHERE
    ue.engaged_posts_count >= :min_engagements
ORDER BY
    ue.engaged_posts_count DESC

Estamos dando tempo aos usuários para descobrir e confirmar presença em nossos eventos organicamente, mas à medida que o evento se aproxima, queremos enviar convites mais direcionados. Para fazer isso, precisamos cruzar a lista de confirmações de presença existente e excluí-los da lista de usuários direcionados. Existe alguma maneira de acessar essa lista de confirmações de presença por meio do data-explorer?

A única maneira que encontrei de acessar isso manualmente é usando a opção Exportar em um objeto de Evento:

O problema é que isso gera um arquivo compactado que é enviado por mensagem privada para mim, o que presumo que não seja visível para o Data Explorer.

Eu acho que você vai querer usar as tabelas discourse_post_event_events e discourse_post_event_invitees para isso.

Consegui trabalhar no seguinte com o bot, mas ele está retornando 0 resultados (mesmo que eu possa ver que mais de 30 pessoas responderam. A consulta funciona se eu remover a instrução WHERE.

-- [params]
-- text :event_url = 'https://developer.sailpoint.com/discuss/t/deploying-the-beyondtrust-password-safe-connector-for-identityiq-with-michel-bluteau/68228'

SELECT 
    users.username AS "Username",
    invitees.status AS "RSVP Status",
    invitees.updated_at AS "Last Updated"
FROM 
    discourse_post_event_events AS events
JOIN 
    discourse_post_event_invitees AS invitees
ON 
    events.id = invitees.post_id
JOIN 
    users
ON 
    invitees.user_id = users.id
WHERE 
    events.url = :event_url

Que tal algo assim:

-- [params]
-- text :keyword
-- int :min_engagements
-- null string :tag_name
-- post_id :event_post

WITH keyword_posts AS (
    
    SELECT 
        p.id AS post_id
    FROM posts p
      JOIN topics t ON t.id = p.topic_id
      LEFT JOIN topic_tags tt ON tt.topic_id = t.id
      LEFT JOIN tags tg ON tg.id = tt.tag_id
    WHERE p.raw ILIKE '%' || :keyword || '%'
      AND (:tag_name is null OR tg.name = :tag_name)
),

user_engagement AS (

    SELECT
        ua.user_id,
        COUNT(DISTINCT ua.target_post_id) AS engaged_posts_count
    FROM user_actions ua
    JOIN keyword_posts kp ON kp.post_id = ua.target_post_id
    WHERE ua.action_type IN (1, 4, 5, 6)
    AND ua.user_id NOT IN (SELECT user_id FROM group_users WHERE group_id = 41)
    GROUP BY ua.user_id
)

SELECT
    ue.user_id,
    ue.engaged_posts_count
FROM user_engagement ue
WHERE ue.engaged_posts_count >= :min_engagements
  AND ue.user_id NOT IN (SELECT user_id FROM discourse_post_event_invitees WHERE post_id = :event_post AND status = 0)
ORDER BY ue.engaged_posts_count DESC

Para o parâmetro event_url, ele aceita a URL do tópico, mas com o número da postagem no final, então https://developer.sailpoint.com/discuss/t/deploying-the-beyondtrust-password-safe-connector-for-identityiq-with-michel-bluteau/68228/1 (em vez da versão do tópico que não tem o /1 no final)

1 curtida