Erreur lors de la mise à jour vers la dernière version de Discourse -- résolue

Corrigé.

Cela a nécessité une manipulation de la base de données. J’ai utilisé l’image Docker de PostgreSQL pour monter la base de données :

docker run --name postgres_container_2 -e POSTGRES_PASSWORD=mysecretpassword -d -p 5432:5432 -v /var/discourse/shared/standalone/postgres_data:/var/lib/postgresql/data postgres:15

Ensuite, j’ai localisé la ligne de table fautive :

SELECT
          tc.topic_id,
          tc.answer_post_id,
          tc.topic_timer_id,
          tc.accepter_user_id,
          tc.created_at,
          tc.updated_at
        FROM (
          SELECT
            tc.topic_id,
            CAST(tc.value AS INTEGER) AS answer_post_id,
            CAST(tc2.value AS INTEGER) AS topic_timer_id,
            COALESCE(ua.acting_user_id, -1) AS accepter_user_id,
            tc.created_at,
            tc.updated_at,
            ROW_NUMBER() OVER (PARTITION BY tc.topic_id ORDER BY tc.created_at ASC) AS rn_topic,
            ROW_NUMBER() OVER (PARTITION BY CAST(tc.value AS INTEGER) ORDER BY tc.created_at ASC) AS rn_answer
          FROM topic_custom_fields tc
          LEFT JOIN topic_custom_fields tc2 ON tc2.topic_id = tc.topic_id AND tc2.name = 'solved_auto_close_topic_timer_id'
          LEFT JOIN user_actions ua ON ua.target_topic_id = tc.topic_id AND ua.action_type = 15
          WHERE tc.name = 'accepted_answer_post_id'
            AND tc.id > 0
            AND tc.id <= 0 + 10000
            AND tc.value IS NULL
        ) tc

Une fois que j’ai eu la certitude que cela ne sélectionnait que la ligne de l’erreur, j’ai remplacé le SELECT par un DELETE, j’ai croisé les doigts et lancé ./launcher rebuild app.

Après avoir attendu longtemps la construction de l’image, j’ai maintenant une communauté heureuse et un site reconstruit, avec les correctifs de sécurité inclus.

Je ne sais pas ce qui a rendu la ligne mentionnée ci-dessus invalide, mais une fois qu’elle a été supprimée, tout va bien.

4 « J'aime »