Kategorien
FreewarWiki:Bot/Skripts/Waffenliste.php: Unterschied zwischen den Versionen
< FreewarWiki:Bot | Skripts
Bwoebi (Diskussion | Beiträge) (oder so. mit explizitem |) |
K (https) |
||
Zeile 34: | Zeile 34: | ||
private function getAPI($query) { | private function getAPI($query) { | ||
$c = curl_init(' | $c = curl_init('https://' . $this->server . '/api.php?' . $query . '&format=json'); | ||
curl_setopt($c, CURLOPT_USERAGENT, 'BotFrameWorkApi -- Benutzer:' . $this->nick); | curl_setopt($c, CURLOPT_USERAGENT, 'BotFrameWorkApi -- Benutzer:' . $this->nick); | ||
curl_setopt($c, CURLOPT_RETURNTRANSFER, true); | curl_setopt($c, CURLOPT_RETURNTRANSFER, true); |
Aktuelle Version vom 24. Dezember 2020, 14:25 Uhr
<?php $cats = array("Verteidigungswaffen", "Angriffswaffen"); if (!isset($argv[1]) && !in_array($argv[1], $cats)) { die("Nutzung: php Waffenliste.php arg\narg ist dabei einer der folgenden Werte: " . implode(", ", $cats) . "\n"); } //Benutzername wird für den User-Agent benötigt $bot = new mwBot('Beispieluser', 'www.fwwiki.de'); //HINWEIS: Skript schreibt Output in die Textdatei output.txt, evtl muss diese bestehen und die nötigen Rechte gegeben sein! if (false === $bot->print2file($bot->start($argv[1]))) { echo 'Daten konnten nicht geschrieben werden, Datei "output.txt" vorhanden und beschreibbar?'; } class mwBot { private $server; private $nick; public function __construct($name, $server) { $this->nick = $name; $this->server = $server; } public function status($status, $code = 0) { print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . "\n"; } /*################################# # APIVERBINDUNG ## #################################*/ private function getAPI($query) { $c = curl_init('https://' . $this->server . '/api.php?' . $query . '&format=json'); curl_setopt($c, CURLOPT_USERAGENT, 'BotFrameWorkApi -- Benutzer:' . $this->nick); curl_setopt($c, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($c); curl_close($c); $decoded = json_decode($result, true); return $decoded['query']; } /*################################# # HILFSFUNKTIONEN ## #################################*/ private function getContent($title) { $this->status('Hole Artikel: ' . $title); $result = $this->getAPI('action=query&prop=info|revisions&titles=' . urlencode($title) . '&rvprop=timestamp|content&intoken=edit'); $pages = $result['pages']; foreach($pages as $page) { return $page['revisions'][0]['*']; } } /*################################# # SPEZIELLE FUNKTIONEN ## #################################*/ /* Main-Funktion - sucht die Artikel einer Waffenkategorie und baut die Wiki-Seite auf */ public function start($cat) { $pages = $this->getAPI('action=query&list=categorymembers&cmtitle=Category:' . urlencode($cat) . '&cmlimit=500'); foreach ($pages['categorymembers'] as $page) { $content = $this->getContent($page['title']); if ($this->isWaffe($content)) { $waffenArray[] = $this->createWaffe($content, $page['title']); } else { echo "\tArtikel beschreibt keine Waffe!\n"; } } // Sortierung des Arrays nach der Stärke der Waffen-Objekte usort($waffenArray, array("Waffe", "cmpWaffe")); // Zählen der Waffen $count = count($waffenArray); // Aufbau der Liste $out = "<noinclude>\nDiese Liste wird von Zeit zu Zeit automatisch aus den Daten aus den einzelnen $cat-Artikeln erstellt (zuletzt am '''" . date("d.m.Y H:i:s") . "'''). Das Script um die Liste zu akualisieren findet ihr hier [[FreewarWiki:Bot/Skripts/Waffenliste.php]]."; $out .= "\n\n"; $out .= "Anzahl Waffen: " . $count . "\n\n</noinclude><!--\n\n-->{{#vardefine:" . $cat . "Anzahl|" . $count . "}}<!--\n"; // Durchlaufen des Waffen-Arrays und Hinzufuegen zur Liste foreach($waffenArray as $currentWaffe) { $out .= "\n-->{{{{{Vorlage}}}|Name=" . $currentWaffe->name . "}}<!--" ; } return $out . "\n\n--><noinclude>{{Dokumentation}}</noinclude>"; } /* Überprüfung ob der Artikel eine Waffe ist */ private function isWaffe($content) { // Überprüfung ob der Artikel dem Layout für eine Angriffswaffe entspricht if (preg_match('~Item/Layout|Typ=awaffe~', $content)) { // Überprüfung ob der Artikel eine saisonale Waffe beschreibt if (!preg_match('/Saisonale Items/', $content)) { return true; } } return false; } /* Erstellen eines neuen Waffen-Objektes */ private function createWaffe($content, $name) { preg_match('#\|Stärke=\W*([0-9]+)#si', $content, $staerke); return new Waffe($name, $staerke[1]); } public function print2file($str, $file = 'output.txt') { return file_put_contents($file, $str); } } class Waffe { public $name; public $staerke; function __construct($name, $staerke){ $this->name = $name; $this->staerke = $staerke; } // Vergleichsfunktion fuer Waffen-Objekte static function cmpWaffe($waffe1, $waffe2){ $staerke1 = $waffe1->staerke; $staerke2 = $waffe2->staerke; if ($staerke1 == $staerke2) { return strcasecmp($waffe1->name, $waffe2->name); } return $staerke1 - $staerke2; } }