WP Discourse effectue beaucoup de requêtes vers site.json

Je travaille sur une intégration pour un client et j’ai eu une surveillance des journaux Discourse pendant que je travaillais sur son forum Wordpress.

Et voici ce que j’ai vu passer (désolé pour le format étrange du journal). L’adresse IP est l’adresse IP du serveur Wordpress. Il exécute WP Discourse 2.5.5.

Je parcouru le code et je n’arrive pas à comprendre pourquoi cela se produit.

2024-10-23T06:39:30+00:00|67.225.163.100|5857|0.023|200|GET /site.json HTTP/1.1
2024-10-23T06:39:30+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:30+00:00|67.225.163.100|5857|0.020|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.023|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.024|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.020|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.019|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:32+00:00|67.225.163.100|5857|0.018|200|GET /site.json HTTP/1.1
2024-10-23T06:39:32+00:00|67.225.163.100|5857|0.018|200|GET /site.json HTTP/1.1
2024-10-23T06:39:32+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.024|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.020|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.024|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|5857|0.023|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|662|0.012|429|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|662|0.014|429|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|662|0.011|429|GET /site.json HTTP/1.1
2 « J'aime »

J’imagine que cela provient de cet appel : wp-discourse/lib/plugin-utilities.php at main · discourse/wp-discourse · GitHub

Qui est apparemment utilisé dans 3 cas :

  • Remplir le sélecteur de catégorie dans certains formulaires
  • Boîte méta
  • discourse-sidebar

Oui.
La chose étrange est qu’il est censé être mis en cache, et je n’ai aucune raison de croire que ce n’est pas le cas.

$categories = get_transient( 'wpdc_discourse_categories' );
if ( ! empty( $options['publish-category-update'] ) || ! $categories ) {
  $body = $this->discourse_request( '/site.json' );
  if ( is_wp_error( $body ) ) {
    return $body;
  }

  if ( $body->categories ) {

    // supprimé pour plus de brièveté

    // Notez que la définition du cache à 0 désactivera l'expiration du transient.
    $category_cache_period = apply_filters( 'wpdc_category_cache_minutes', 10 );
    set_transient( 'wpdc_discourse_categories', $discourse_categories, intval( $category_cache_period ) * MINUTE_IN_SECONDS );

    return $discourse_categories;
  } else {
    return new \WP_Error( 'key_not_found', 'La clé des catégories n\'a pas été trouvée dans la réponse de Discourse.' );
  }
}

EDIT Lorsque je liste les transients, j’ai bien une clé timeout_wpdc_discourse_categories avec une valeur d’horodatage dans 5 minutes, mais je n’ai pas de wpdc_discourse_categories :thinking:

EDIT 2 set_transient( 'wpdc_discourse_categories', $discourse_categories, intval( $category_cache_period ) * MINUTE_IN_SECONDS ); retourne false. $discourse_categories est correctement rempli. D’autres transients fonctionnent.

Mise à jour : Le transitoire ne s’enregistre tout simplement pas. Il s’enregistre lorsque je l’encode en json_encode().

De plus, je ne parviens pas à reproduire ce problème sur une autre instance Wordpress, je déplace donc ce sujet vers le support car je pense qu’il s’agit d’un problème Wordpress. Je soupçonne qu’un plugin de sécurité pourrait interférer.

1 « J'aime »