واجهة برمجة التطبيقات:مراجعات_محذوفة
Appearance
هذه الصفحة جزء من توثيق واجهة برمجة تطبيقات ميدياويكي التي تحمل اسم Action. |
طلب GET الغرض منه الحصول على معلومات عن المراجعات المحذوفة.
إصدار ميدياويكي: | ≥ 1.25 |
توثيق واجهة برمجة التطبيقات
مثال
طلب GET
الحصول على قائمة بالمراجعات المحذوفة من أجل Talk:Main Page.
api.php? action=query& titles=Talk:Main%20Page& prop=deletedrevisions& drvprop=user|comment|content& drvslots=*& format=json [جربها في ApiSandbox]
النتيجة
"query": {
"pages": [
{
"ns": 1,
"title": "Talk:Main Page",
"missing": "",
"deletedrevisions": [
{
"user": "192.168.0.193",
"anon": "",
"comment": "I iz in yer wiki, blanking yer talk pages",
"contentformat": "text/x-wiki",
"contentmodel": "wikitext",
"content": ""
},
]
},
]
}
عينة من الكود البرمجي
Python
#!/usr/bin/python3
"""
deleted_revisions.py
MediaWiki API Demos
Demo of `Deletedrevisions` module: Get a list of deleted revisions for Talk:Main Page.
MIT License
"""
import requests
S = requests.Session()
URL = "https://test.wikipedia.org/w/api.php"
# Step 1: Retrieve a login token
PARAMS_1 = {
"action": "query",
"meta": "tokens",
"type": "login",
"format": "json"
}
R = S.get(url=URL, params=PARAMS_1)
DATA = R.json()
LOGIN_TOKEN = DATA['query']['tokens']['logintoken']
# Step 2: Send a POST request to log in. For this login
# method, obtain credentials by first visiting
# https://www.test.wikipedia.org/wiki/Manual:Bot_passwords
# See https://www.mediawiki.org/wiki/API:Login for more
# information on log in methods.
PARAMS_2 = {
"action": "login",
"lgname": "user_name",
"lgpassword": "password",
"format": "json",
"lgtoken": LOGIN_TOKEN
}
R = S.post(URL, data=PARAMS_2)
DATA = R.json()
# Step 3: While logged in, send a get reguest to get a list of deleted revisions for Talk:Main Page.
PARAMS = {
"action": "query",
"titles": "Talk:Main_Page",
"prop": "deletedrevisions",
"drvprop": "user|comment|content",
"drvslots": "*",
"format": "json"
}
R = S.get(url=URL, params=PARAMS)
DATA = R.json()
print(DATA)
PHP
<?php
/*
deleted_revisions.php
MediaWiki API Demos
Demo of `Deletedrevisions` module: Get a list of deleted revisions for Talk:Main Page.
MIT License
*/
$endPoint = "https://test.wikipedia.org/w/api.php";
$login_Token = getLoginToken(); // Step 1
loginRequest( $login_Token ); // Step 2
deletedRevisions(); // Step 3
// Step 1: GET request to fetch login token
function getLoginToken() {
global $endPoint;
$params1 = [
"action" => "query",
"meta" => "tokens",
"type" => "login",
"format" => "json"
];
$url = $endPoint . "?" . http_build_query( $params1 );
$ch = curl_init( $url );
curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true );
curl_setopt( $ch, CURLOPT_COOKIEJAR, "cookie.txt" );
curl_setopt( $ch, CURLOPT_COOKIEFILE, "cookie.txt" );
$output = curl_exec( $ch );
curl_close( $ch );
$result = json_decode( $output, true );
return $result["query"]["tokens"]["logintoken"];
}
// Step 2: Send a POST request to log in. For this login method,
// obtain credentials by first visiting https://www.test.wikipedia.org/wiki/Manual:Bot_passwords
// See https://www.mediawiki.org/wiki/API:Login for more information on log in methods.
function loginRequest( $logintoken ) {
global $endPoint;
$params2 = [
"action" => "login",
"lgname" => "bot_user_name",
"lgpassword" => "bot_password",
"lgtoken" => $logintoken,
"format" => "json"
];
$ch = curl_init();
curl_setopt( $ch, CURLOPT_URL, $endPoint );
curl_setopt( $ch, CURLOPT_POST, true );
curl_setopt( $ch, CURLOPT_POSTFIELDS, http_build_query( $params2 ) );
curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true );
curl_setopt( $ch, CURLOPT_COOKIEJAR, "cookie.txt" );
curl_setopt( $ch, CURLOPT_COOKIEFILE, "cookie.txt" );
$output = curl_exec( $ch );
curl_close( $ch );
}
// Step 3: Send a GET request to get a list of deleted revisions for Talk:Main Page.
function deletedRevisions() {
$params = [
"action" => "query",
"titles" => "Talk:Main_Page",
"prop" => "deletedrevisions",
"drvprop" => "user|comment|content",
"drvslots" => "*",
"format" => "json"
];
$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 );
var_dump( $result );
}
JavaScript
/*
deleted_revisions.js
MediaWiki API Demos
Demo of `Deletedrevisions` module: Get a list of deleted revisions for Talk:Main Page.
MIT License
*/
var request = require("request").defaults({jar: true}),
url = "https://en.wikipedia.org/w/api.php";
// Step 1: GET Request to fetch login token
function getLoginToken() {
var params_0 = {
action: "query",
meta: "tokens",
type: "login",
format: "json"
};
request.get({ url: url, qs: params_0 }, function (error, res, body) {
if (error) {
return;
}
var data = JSON.parse(body);
loginRequest(data.query.tokens.logintoken);
});
}
// Step 2: POST request to log in.
// Use of main account for login is not
// supported. Obtain credentials via Special:BotPasswords
// (https://www.mediawiki.org/wiki/Special:BotPasswords) for lgname & lgpassword
function loginRequest(login_token) {
var params_1 = {
action: "login",
lgname: "bot_username",
lgpassword: "bot_password",
lgtoken: login_token,
format: "json"
};
request.post({ url: url, form: params_1 }, function (error, res, body) {
if (error) {
return;
}
deletedRevisions();
});
}
// Step 3: Get a list of deleted revisions for Talk:Main Page.
function deletedRevisions() {
var params = {
action: "query",
titles: "Talk:Main_Page",
prop: "deletedrevisions",
drvprop: "user|comment|content",
drvslots: "*",
format: "json"
};
url = url + "?origin=*";
Object.keys(params).forEach(function(key){url += "&" + key + "=" + params[key];});
fetch(url)
.then(function(response){return response.json();})
.then(function(response) {console.log(response);})
.catch(function(error){console.log(error);});
}
MediaWiki JS
/*
deleted_revisions.js
MediaWiki API Demos
Demo of `Deletedrevisions` module: Get a list of deleted revisions for Talk:Main Page.
MIT License
*/
var params = {
action: 'query',
titles: 'Talk:Main_Page',
prop: 'deletedrevisions',
drvprop: 'user|comment|content',
drvslots: '*',
format: 'json'
},
api = new mw.Api();
api.get( params ).done( function ( data ) {
console.log( data );
} );
الأخطاء المحتملة
الكود | معلومات |
---|---|
drvdiffto | يجب تعيين drvdiffto على عدد غير سالب، prev, next أو cur. |
drvnosuchrevid | لا توجد مراجعة بالمعرف ID. |
drvnosuchsection | لا توجد فقرة section في ID المراجعة |
permissiondenied | ليس لديك صلاحية لعرض التعليقات المحذوفة. |
drvpermissiondenied | لا تتمتع بتصريح باستعراض معلومات عن المراجعات المحذوفة |
adrpermissiondenied | لا تتمتع بتصريح باستعراض محتوى المراجعات المحذوفة |
drvbadparams | لا يمكن استخدام user و excludeuser معا |
التحذيرات الممكنة
الكود | تحذير | معلومات |
---|---|---|
difftohidden | لا يمكنك إجراء مقارنة مع r#####: المحتوى مخفي. | تهمل لو كانت المراجعة جرى إخفائها (مثل استخدام RevisionDelete أو Oversight). |
Conversion to XML is supported for wikitext only, title uses content model content model | تهمل لو كانت الخاصية parsetree أو المعامل generatexml مستخدمين وكان نموذج المحتوى (حسب ما هو مبين في الخاصية content ) غير مضبوط على القيمة wikitext
| |
templateexpansion-notwikitext | توسيع القالب مدعوم لمحتوى نص الويكي فقط، يستخدم title نموذج المحتوى content model. | تهمل حينما يكون المعامل expandtemplates مستخدمًا وكان نموذج المحتوى (حسب ما هو في الخاصية content ) غير مضبوط على القيمة wikitext
|
apierror-badformat | التنسيق المطلوب contentFormat غير مدعوم لنموذج المحتوى model المستخدم بواسطة name. | تهمل حينما يكون محتوى المراجعة الحالية أو تلك التي يجري المقارنة معها غير مدعومة (بوجه عام، ليست نصًا). |
تاريخ المتغيرات
- v1.32: إضافة
slotsize
,slotsha1
,roles
,drvslots
- v1.32:
drvcontentformat
متقادم - v1.30:
parsetree
,drvexpandtemplates
,drvparse
,drvdiffto
,drvdifftotext
,drvdifftotextpst
متقادم - v1.27: إضافة
drvdifftotextpst
- v1.27:
drvdifftotextpst
متقادم - v1.26:
drvgeneratexml
متقادم
ملاحظات إضافية
- يمكن استخدام هذه الوحدة البرمجية بصفة مولّد .
- تدرج هذه الوحدة البرمجية قائمة بالمراجعات التي حذفت من صفحة ما، كما قد ترى ذلك في صفحة Special:Undelete. يجب ألا تخلط بين هذه وبين المراجعات التي أخفيت باستخدام سمة حذف مراجعة .
انظر أيضا
- Manual:RevisionDelete - لعرض مراجعات صفحات منفردة أو إخفائها.
- Help:RevisionDelete - لإخفاء قيود منفردة في تاريخ صفحة أو سجل.
- واجهة برمجة التطبيقات:مراجعات_محذوفة - متغيرات واجهة برمجة التطبيقات المستخدمة في سرد قائمة بالمراجعات المحذوفة.
- واجهة برمجة التطبيقات:حذف_مراجعة - لإلغاء المراجعات أو التراجع عن إلغائها.