API:Logbuch-Aktionen
Diese Seite ist Teil der Dokumentation der MediaWiki action API. |
MediaWiki Version: | ≥ 1.9 |
GET-Abfrage um eine Liste aller geloggten Aktionen zu erhalten, wie sie auf Special:Log zu sehen ist.
API-Dokumentation
Beispiel
GET-Anfrage
Erhalte die drei letzten geloggten Aktionen.
Antwort
{
"batchcomplete": "",
"continue": {
"continue": "-||",
"lecontinue": "20190606150600|99729503"
},
"query": {
"logevents": [
{
"action": "create",
"comment": "added to WikiProject (via [[WP:JWB]])",
"logid": 99729506,
"logpage": 60974819,
"ns": 15,
"pageid": 60974819,
"params": {},
"timestamp": "2019-06-06T15:06:07Z",
"title": "Category talk:Electronic albums by Senegalese artists",
"type": "create",
"user": "Jevansen"
}
...
]
}
}
Beispielcode
Python
#!/usr/bin/python3
"""
get_logevents.py
MediaWiki API Demos
Demo of `Logevents` module: Get the three most recent logevents.
MIT License
"""
import requests
S = requests.Session()
URL = "https://en.wikipedia.org/w/api.php"
PARAMS = {
"action": "query",
"format": "json",
"list": "logevents",
"lelimit": "3"
}
R = S.get(url=URL, params=PARAMS)
DATA = R.json()
LOGS = DATA["query"]["logevents"]
for l in LOGS:
print("There is " + l["type"] + " log for page " + l["title"])
PHP
<?php
/*
get_logevents.php
MediaWiki API Demos
Demo of `Logevents` module: Get the three most recent logevents.
MIT License
*/
$endPoint = "https://en.wikipedia.org/w/api.php";
$params = [
"action" => "query",
"format" => "json",
"list" => "logevents",
"lelimit" => "3"
];
$url = $endPoint . "?" . http_build_query( $params );
$ch = curl_init( $url );
curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true );
$output = curl_exec( $ch );
curl_close( $ch );
$result = json_decode( $output, true );
foreach( $result["query"]["logevents"] as $k => $v ) {
echo( "There is " . $v["type"] . " log for page " . $v["title"] . "\n" );
}
JavaScript
/*
get_logevents.js
MediaWiki API Demos
Demo of `Logevents` module: Get the three most recent logevents.
MIT License
*/
var url = "https://en.wikipedia.org/w/api.php";
var params = {
action: "query",
format: "json",
list: "logevents",
lelimit: "3"
};
url = url + "?origin=*";
Object.keys(params).forEach(function(key){url += "&" + key + "=" + params[key];});
fetch(url)
.then(function(response){return response.json();})
.then(function(response) {
var logs = response.query.logevents;
for (var l in logs) {
console.log("There is " + logs[l].type + " log for page " + logs[l].title);
}
})
.catch(function(error){console.log(error);});
MediaWiki JS
/*
get_logevents.js
MediaWiki API Demos
Demo of `Logevents` module: Get the three most recent logevents.
MIT License
*/
var params = {
action: 'query',
format: 'json',
list: 'logevents',
lelimit: '3'
},
api = new mw.Api();
api.get( params ).done( function ( data ) {
var logs = data.query.logevents,
l;
for ( l in logs ) {
console.log( 'There is ' + logs[ l ].type + ' log for page ' + logs[ l ].title );
}
} );
Mögliche Fehler
Code | Information |
---|---|
leparam_user | Benutzername Benutzername nicht gefunden. |
leparam_title | Ungültiger Titel „title“. Dies passiert, wenn du letitle auf einen ungültigen Titel setzt.
|
apierror-unrecognizedvalue | Unrecognized value for parameter leaction: value. |
apierror-prefixsearchdisabled | Prefix search is disabled in Miser Mode. |
Parametergeschichte
- v1.17: Eingeführt
leaction
Zusätzliche Anmerkungen
- Dieses Modul kann nicht als Generator benutzt werden.
- Für Einträge zu Autoblock-Entsperrungen wird der ausgegebene
title
als "User:$blockid" angezeigt. Dies ist keine Benutzerseite, sondern einfach die Art, auf die es gespeichert wird. Siehe task T19781. - Wenn die
userid
für die Erstellung eines Benutzerkontos spezifiziert wird, wird dieuserid
des erstellenden Benutzers ausgegeben. Wenn es fehlt, wird dieuserid
des erstellten Kontos ausgegeben. Siehe task T73020. - Siehe Manual:Log_actions für Log-Typen und Log-Aktionen, sowie ihre Log-Parameter und Einträge und Beschreibungen der Log-Suche .
- Jede geloggte Aktion wird in der Handbuch:logging-Tabelle geloggt. Benutzer können diese Bearbeitungen auf Special:Log sehen, mit Ausnahme von ein paar beschränkten Logbüchern wie Special:Log/suppress.
Siehe auch
- API:Recentchanges - Erhält eine Liste aller letzten Änderungen.
- API:Datenbankfeld und API-Eigenschaftszuordnung .