private function migrateReplies(){ global $wpdb; // đŸ”č dernier topic WP traitĂ© pour les replies $last_topic_wp = (int) $this->getLast_Topic(); // STEP 1 : batch topics WP $topic_rows = $wpdb->get_results($wpdb->prepare(" SELECT p.ID AS wp_topic_id, pm.meta_value AS xoops_topic_id FROM {$wpdb->posts} p JOIN {$wpdb->postmeta} pm ON pm.post_id = p.ID AND pm.meta_key = 'bbex_topic_id' WHERE p.post_type = 'topic' AND p.ID > %d ORDER BY p.ID ASC LIMIT 2000 ", $last_topic_wp)); if(!$topic_rows){ $this->log('🏁 REPLIES DONE → plus aucun topic WP Ă  traiter'); update_option('bbex_replies_done', 1, false); return; } // BUILD MAP $topic_map = []; $xoops_topic_ids = []; foreach($topic_rows as $t){ $topic_map[(int)$t->xoops_topic_id] = (int)$t->wp_topic_id; $xoops_topic_ids[] = (int)$t->xoops_topic_id; } $ids_sql = implode(',', $xoops_topic_ids); $this->log("🔄 REPLIES BATCH START"); $this->log("WP topics batch: " . count($topic_rows)); $this->log("XOOPS topics batch: " . count($xoops_topic_ids)); $this->log("XOOPS range: " . (min($xoops_topic_ids) ?? 0) . " → " . (max($xoops_topic_ids) ?? 0)); // STEP 2 : GET POSTS (LIVE XOOPSEOL) $posts = $wpdb->get_results(" SELECT p.post_id, p.topic_id AS xoops_topic_id, p.uid, p.pid, p.post_time, pt.post_text FROM {$this->getTable('posts')} p JOIN {$this->getTable('posts_text')} pt ON pt.post_id = p.post_id WHERE p.topic_id IN ($ids_sql) ORDER BY p.post_id ASC "); if(!$posts){ $max_wp_topic = max(array_column($topic_rows, 'wp_topic_id')); $this->setLast_Topic($max_wp_topic); $this->log("⚠ Aucun post trouvĂ©"); $this->log("âžĄïž Skip batch → last_topic_wp=$max_wp_topic"); return; } $inserted = 0; $skipped = 0; $updated = 0; $total = count($posts); $i = 0; foreach($posts as $p){ $i++; if($i % 200 === 0 || $i === $total){ $pct = round(($i / $total) * 100, 2); $this->log("⏳ Progress replies: $i/$total ($pct%) | inserted=$inserted skipped=$skipped updated=$updated"); } // user check if(empty($this->user_map[$p->uid])){ $skipped++; continue; } $wp_tid = $topic_map[(int)$p->xoops_topic_id] ?? 0; if(!$wp_tid){ $skipped++; continue; } // MAIN TOPIC POST → CONTENT if($p->pid == 0){ $wpdb->query($wpdb->prepare(" UPDATE {$wpdb->posts} SET post_content = IF(post_content = '', %s, post_content) WHERE ID = %d ", $p->post_text, $wp_tid)); $updated++; continue; } // ANTI DOUBLON $exists = $wpdb->get_var($wpdb->prepare(" SELECT 1 FROM bbex_post_lookup WHERE xoops_post_id = %d AND type = 'reply' LIMIT 1 ", $p->post_id)); if($exists){ $skipped++; continue; } // INSERT REPLY $wpdb->insert($wpdb->posts, [ 'post_author' => $this->user_map[$p->uid], 'post_date' => date('Y-m-d H:i:s', $p->post_time), 'post_content' => $p->post_text, 'post_status' => 'publish', 'post_type' => 'reply', 'post_parent' => $wp_tid ]); $rid = (int) $wpdb->insert_id; if(!$rid){ $skipped++; continue; } $inserted++; // meta topic $wpdb->insert($wpdb->postmeta,[ 'post_id' => $rid, 'meta_key' => '_bbp_topic_id', 'meta_value' => $wp_tid ]); // forum $forum_id = $wpdb->get_var($wpdb->prepare(" SELECT post_parent FROM {$wpdb->posts} WHERE ID = %d ", $wp_tid)); if($forum_id){ $wpdb->insert($wpdb->postmeta,[ 'post_id' => $rid, 'meta_key' => '_bbp_forum_id', 'meta_value' => $forum_id ]); } // lookup $wpdb->query($wpdb->prepare(" INSERT INTO bbex_post_lookup (xoops_post_id, wp_post_id, type) VALUES (%d, %d, 'reply') ON DUPLICATE KEY UPDATE wp_post_id = wp_post_id ", $p->post_id, $rid)); } $max_wp_topic = max(array_column($topic_rows, 'wp_topic_id')); $this->setLast_Topic($max_wp_topic); $this->log("===================================="); $this->log("🏁 REPLIES BATCH FINISHED"); $this->log("📊 total=$total | inserted=$inserted | updated=$updated | skipped=$skipped"); $this->log("âžĄïž last_topic_wp=$max_wp_topic"); $this->log("===================================="); } if(isset($_GET['source'])){ $migration->setSource($_GET['source']); } COUP DE COEUR Yohann - Oasis des Artistes. Le plus beau site de poĂ©sie

Oasis des Artistes. Le plus beau site de poésie

Oasis des artistes: PoĂ©sie en ligne, Concours de poĂšmes en ligne – membres !

COUP DE COEUR Yohann

  • Ce sujet contient 3 réponses, 4 participants et a Ă©tĂ© mis Ă  jour pour la derniĂšre fois par Avatar photoyoledelatole4, le 31-08-2024 19:24.
  • Créateur
    Sujet
  • #2714276
    Plume de diamant
    ★★★★★★
    Avatar photocyrael
    Membre Oasis
      • Sujet: 14564
      • RĂ©ponses: 136022

      coup de coeur si celui ci

      n’a pas encore Ă©tĂ© nominĂ©

      je le propose

      https://www.oasisdesartistes.org/modules/newbbex/viewtopic.php?viewmode=flat&topic_id=323748&forum=2

      *

      Mais il me manque l’essentiel…..
      Quelques nuages dans un ciel bleu azur
      Un tableau de Léo Ferré qui ne vieillit pas avec le temps
      Un poisson combattant en pierre blanche sur une table basse
      La biographie de Bruce Springsteen sur le canapé
      Mais il manque l’essentiel

      Quelques heures évanouies qui font déjà partie du passé
      Un petit vent du Nord qui soulÚve les vagues nacrées
      Un vendeur de glaces parfums soleil qui se couche
      Un couple encore assis main dans la main sur la plage et un foulard qui s’envole
      Mais il manque l’essentiel

      Une bougie sur le sable qui fait de la résistance à la nuit
      Une petite Ă©toile qui meurt avant d’avoir pu illuminer le monde
      Un autre qui naĂźt pour redonner de l’espoir Ă  la terre
      Bob Dylan qui chante Make you feel my love
      Et tu arrives mon amour
      Et l’essentiel pour moi est lĂ 

      Y.

      yoledelatole4

      JE VAIS ILLUSTRER mais je vais essayer de refaire

      [url=https://zupimages.net/viewer.php?id=24/34/kohf.jpg][/url]

      l'Amour rayonne quand l'Ame s'?l?ve, citation maryjo
    Vous lisez 2 fils de discussion
    • Auteur
      Réponses
      • #3529417
        Mascotte d'Oasis
        Avatar phototerry
        Membre Oasis
          • Sujet: 2010
          • RĂ©ponses: 13996

          magnifique poĂšme
          cyrael
          j ‘ adhĂšre
          Terry

        • #3529446
          Administratrice
          Avatar photoSybilla
          Maßtre des clés
            • Sujet: 17798
            • RĂ©ponses: 198089

            Bonsoir ma ChĂšre Amie Maryjo,

            Yohann refuse d’ĂȘtre nominĂ©.
            Marie et moi voulions le faire depuis un moment…

            Mais je vais mettre un message sur la rubrique de la modération pour signaler que tu as proposé si gentiment une de ses poésies.

            Si Yohann change d’avis, je donne bien entendu mon accord !

            Belle soirée ChÚre Amie poétesse Maryjo ainsi que ma ChÚre Amie Terry pour ton acceptation !
            Toutes mes amitiés à vous deux
            Gros bisous affectueux
            Sybilla

            Le r?ve est le poumon de ma vie (Citation de Sybilla)
          • #3531186
            Modérateur
            Avatar photoyoledelatole4
            Modérateur
              • Sujet: 4281
              • RĂ©ponses: 56546

              Bonsoir Mary Jo , je ne souhaite plus effectivement ĂȘtre nominĂ©
              Je te remercie pour l’attention
              Mes amitiés
              Yohann

              la nostalgie est un bouquet de fleurs enfoui au fond de votre coeur , qui vous embaume quand remontent les souvenirs du bonheur , yohann
          Vous lisez 2 fils de discussion
          • Vous devez être connecté pour répondre à ce sujet.