FreewarWiki:Bot/Skripts/Waffenliste.php: Unterschied zwischen den Versionen

aus FreewarWiki, der Referenz für Freewar
Zur Navigation springen Zur Suche springen
(pre pre alpha version :D)
 
K (https)
 
(11 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 3: Zeile 3:
<pre>
<pre>
<?php
<?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 {
class mwBot {
Zeile 14: Zeile 26:
public function status($status, $code = 0) {
public function status($status, $code = 0) {
print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . "<br/>";
print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . "\n";
}
}
Zeile 22: Zeile 34:
private function getAPI($query) {
private function getAPI($query) {
$c = curl_init('http://' . $this->server . '/api.php?' . $query . '&format=json');  
$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);
Zeile 36: Zeile 48:
private function getContent($title) {
private function getContent($title) {
$this->status('Hole Artikel: ' . htmlentities($title));
$this->status('Hole Artikel: ' . $title);
$result = $this->getAPI('action=query&prop=info|revisions&titles=' . urlencode($title) . '&rvprop=timestamp|content&intoken=edit');
$result = $this->getAPI('action=query&prop=info|revisions&titles=' . urlencode($title) . '&rvprop=timestamp|content&intoken=edit');
$pages = $result['pages'];
$pages = $result['pages'];
Zeile 48: Zeile 60:
#################################*/
#################################*/
/* Angriffswaffen des FWWiki*/
/* Main-Funktion - sucht die Artikel einer Waffenkategorie und baut die Wiki-Seite auf */
public function start($cat) {
public function getAWaffe() {
$pages = $this->getAPI('action=query&list=categorymembers&cmtitle=Category:' . urlencode($cat) . '&cmlimit=500');
$pages = $this->getAPI('action=query&list=categorymembers&cmtitle=Category:' . urlencode('Angriffswaffen') . '&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);
$out = htmlentities("Diese Tabelle wird von Zeit zu Zeit automatisch aus den Daten aus den einzelnen Angriffswaffen-Artikeln erstellt (zuletzt am '''" . date("d.m.Y H:i:s") . "'''). Die Daten hier sollten nicht direkt geändert werden, weil solche Änderungen bei einer Neuerstellung verloren gehen. Stattdessen bitte die Daten auf den Seiten der jeweiligen Angriffswaffe korrigieren!");
// 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 .= "\n\n";
$out .= htmlentities("Die Buttons neben den Überschriften können zum Sortieren angeklickt werden. Da die Liste sehr lang ist, kann dies allerdings einige Sekunden dauern.");
$out .= "Anzahl Waffen: " . $count . "\n\n</noinclude><!--\n\n-->{{#vardefine:" . $cat . "Anzahl|" . $count . "}}<!--\n";
$out .= "\n\n";
$out .= "{| class=\"sortable prettytable\" style=\"text-align:right;\"\n";
$out .= "! align=\"center\" | Angriffswaffe\n";
$out .= "! align=\"center\" | Stärke\n";
$out .= "|-\n";
foreach($pages['categorymembers'] as $page) {
// TODO {{Item/Layout|Typ=awaffe als Regex einbauen um nur Waffen-Artikel zu filtern
$content = $this->getContent($page['title']);
// Durchlaufen des Waffen-Arrays und Hinzufuegen zur Liste
preg_match('#Stärke=\W*([0-9]+)#si', $content, $staerke);
foreach($waffenArray as $currentWaffe) {
$out .= "| [[" . ($page['title']) . "]]" .
$out .= "\n-->{{{{{Vorlage}}}|Name=" . $currentWaffe->name . "}}<!--" ;  
"\n|{{SortKey|{{nts|" . $staerke[1] . "}}|" . $staerke[1] . "}}\n" . 
"|-\n";
}
}
return substr($out, 0, -2) . "}\n [[Kategorie:Angriffswaffen|!]]";
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]);
}
}
Zeile 80: Zeile 114:
}
}


//Benutzername wird für den User-Agent benötigt
class Waffe {
$bot = new mwBot('Beispieluser', 'www.fwwiki.de');
public $name;
//HINWEIS: Skript schreibt Output in die Textdatei output.txt, evtl muss diese bestehen und die nötigen Rechte gegeben sein!
public $staerke;
if (false === $bot->print2file($bot->getAWaffe())) {
 
  echo 'Daten konnten nicht geschrieben werden, Datei "output.txt" vorhanden und beschreibbar?';
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;
}
}
}
</pre>
</pre>

Aktuelle Version vom 24. Dezember 2020, 14:25 Uhr

Dieses Script ist hier lediglich archiviert und nicht direkt lauffähig. Wenn Du es benutzen möchtest, musst Du es lokal abspeichern und mit einem geeigneten Interpreter ausführen lassen. Zum Übernehmen solltest Du nicht den unten angezeigten Text verwenden, sondern den Quelltext des Wiki-Artikels: Dazu wählst Du Bearbeiten und kopierst den (meist zwischen PRE-Tags eingefassten) Scripttext.

Sofern Du die Scripte dauerhaft lokal abgespeichert hältst, solltest Du sie vor der nächsten Ausführung darauf prüfen, ob sie noch aktuell sind.

Letzter Bearbeiter: Draco Ellmano — Zuletzt bearbeitet: 24.12.2020
<?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;
	}
}