API:Uživatel e-mailu
Akce API MediaWiki |
---|
Základní informace |
Přihlášení |
Uživatelské účty a uživatelé |
Operace spojené se stránkou |
|
Vyhledávání |
Nástroje pro vývojáře |
Návody |
v · d · u |
Emailuser | |
---|---|
Email a user. Tento modul nelze použít jako zdroj. | |
Předpona | žádná |
Požadovaná práva | sendemail |
Pouze příspěvek? | Ano |
Zdroj nápovědy | Aktuální |
Přidaná verze |
≥ 1.13
|
Dokumentace API
action=emailuser
- This module requires read rights.
- This module requires write rights.
- This module only accepts POST requests.
- Source: MediaWiki
- License: GPL-2.0-or-later
Email a user.
- target
User to send the email to.
- This parameter is required.
- subject
Subject header.
- This parameter is required.
- text
Email body.
- This parameter is required.
- ccme
Send a copy of this mail to me.
- Type: boolean (details)
- token
A "csrf" token retrieved from action=query&meta=tokens
- This parameter is required.
- Send an email to the user WikiSysop with the text Content.
- api.php?action=emailuser&target=WikiSysop&text=Content&token=123ABC [open in sandbox]
Token (symbol)
K odeslání e-mailu je vyžadován e-mailový token. Tento token se rovná tokenu úprav a je stejný pro všechny příjemce, ale mění se při každém přihlášení. E-mailové tokeny lze získat na action=query&meta=tokens nebo pomocí následující metody:
Výsledek |
---|
{ "batchcomplete":"", "query":{ "tokens":{ "csrftoken":"7773cbfff263682c97ffc74b8672cbf25a5e0045+\\" } } } |
Odesílání e-mailů uživatelům
Můžete poslat e-mail uživatelům, kteří mají potvrzenou e-mailovou adresu s action=emailuser. Odesílání e-mailů podléhá limitům sazby.
Parametry
target
: Uživatel, kterému chcete poslat e-mailsubject
: Předmět zprávytext
: Zprávatoken
: Token získaný v předchozím požadavku. Dejte pozor, abyste zakódovali+
jako%2B
ccme
: Pokud je nastaveno, bude vám zaslána kopie e-mailu
Příklady
Výsledek |
---|
<?xml version="1.0" encoding="utf-8"?> <api> <emailuserresult="Success"/> </api> |
Ukázkový kód
Python
#!/usr/bin/python3 """ send_email.py MediaWiki API Demos Demo of `Emailuser` module: sending POST request to send email to wiki user Author: Jayprakash12345 MIT license """ import requests S = requests.Session() URL = "https://test.wikipedia.org/w/api.php" # Step 1: GET request to fetch login token PARAMS_0 = { "action": "query", "meta": "tokens", "type": "login", "format": "json" } R = S.get(url=URL, params=PARAMS_0) DATA = R.json() LOGIN_TOKEN = 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 PARAMS_1 = { "action": "login", "lgname": "your_bot_username", "lgpassword": "your_bot_password", "lgtoken": LOGIN_TOKEN, "format": "json" } R = S.post(URL, data=PARAMS_1) # Step 3: GET request to fetch Email token PARAMS_2 = { "action": "query", "meta": "tokens", "format": "json" } R = S.get(url=URL, params=PARAMS_2) DATA = R.json() EMAIL_TOKEN = DATA['query']['tokens']['csrftoken'] # Step 4: POST request to send an email PARAMS_3 = { "action": "emailuser", "target": "Test", "subject": "Hi", "text": "Just wanted to say hi", "token": EMAIL_TOKEN, "format": "json" } R = S.post(URL, data=PARAMS_3) DATA = R.text print(DATA)
PHP
<?php /* send_email.php MediaWiki API Demos Demo of `Emailuser` module: sending POST request to send email to wiki user MIT license */ $endPoint = "https://en.wikipedia.org/w/api.php"; $login_Token = getLoginToken(); // Step 1 loginRequest( $login_Token ); // Step 2 $csrf_Token = getCSRFToken(); // Step 3 sendemail( $csrf_Token ); // Step 4 // 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: 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( $logintoken ) { global $endPoint; $params2 = [ "action" => "login", "lgname" => "your_bot_username", "lgpassword" => "your_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: GET request to fetch CSRF token function getCSRFToken() { global $endPoint; $params3 = [ "action" => "query", "meta" => "tokens", "format" => "json" ]; $url = $endPoint . "?" . http_build_query( $params3 ); $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"]["csrftoken"]; } // Step 4: POST request to send an email function sendemail( $csrftoken ) { global $endPoint; $params4 = [ "action" => "emailuser", "target" => "ABCD", "subject" => "API test", "text" => "Good to see you", "token" => $csrftoken, "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( $params4 ) ); 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 ); echo ( $output ); }
JavaScript
/* send_email.js MediaWiki API Demos Demo of `Emailuser` module: sending POST request to send email to wiki user MIT license */ varrequest=require('request').defaults({jar:true}), url="https://en.wikipedia.org/w/api.php"; // Step 1: GET request to fetch login token functiongetLoginToken(){ varparams_0={ action:"query", meta:"tokens", type:"login", format:"json" }; request.get({url:url,qs:params_0},function(error,res,body){ if(error){ return; } vardata=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 functionloginRequest(login_token){ varparams_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; } getCsrfToken(); }); } // Step 3: GET request to fetch CSRF token functiongetCsrfToken(){ varparams_2={ action:"query", meta:"tokens", format:"json" }; request.get({url:url,qs:params_2},function(error,res,body){ if(error){ return; } vardata=JSON.parse(body); send_email(data.query.tokens.csrftoken); }); } // Step 4: POST request to send an email functionsend_email(csrf_token){ varparams_3={ action:"emailuser", target:"ABCD", subject:"API Test", text:"Hello", token:csrf_token, format:"json" }; request.post({url:url,form:params_3},function(error,res,body){ if(error){ return; } console.log(body); }); } // Start From Step 1 getLoginToken();
MediaWiki JS
/* send_email.js MediaWiki API Demos Demo of `Emailuser` module: sending POST request to send email to wiki user MIT License */ varparams={ action:'emailuser', target:'ABC', subject:'Hi', text:'Just wanted to say hi', format:'json' }, api=newmw.Api(); api.postWithToken('csrf',params).done(function(data){ console.log(data); });
Možné chyby
Kromě obvyklých věcí :
Kód | Popis |
---|---|
cantsend | You are not logged in, you do not have a confirmed email address, or you are not allowed to send email to other users, so you cannot send email. |
blockedfrommail | You have been blocked from sending email. |
usermaildisabled | E-mail uživatele byl zakázán |
notarget | ⧼apierror-notarget⧽ |
noemail | Tento uživatel nezadal platnou e-mailovou adresu. |
nowikiemail | Tento uživatel si nepřeje dostávat e-maily od ostatních uživatelů. |
Kontrola stavu odeslání e-mailem
Před pokusem o odeslání e-mailu se doporučuje nejprve zkontrolovat, zda je uživatel schopen odeslat e-mail. Chcete-li to provést, můžete provést dotaz na seznam na uživatele (nebo několik uživatelů najednou). Zde je příklad použití Ajaxu:
newmw.Api().get({ action:'query', list:'users', ususers:mw.config.get('wgTitle'), usprop:'emailable', rawcontinue:'' }).done(function(getEmailable){ alert((getEmailable.query.users[0]['emailable']!==undefined)?'emailable':'not emailable'); });
Pokud testujete ze skriptu na straně klienta, je také možné jednoduše zkontrolovat existenci položky seznamu t-emailuser:
emailable=$('#t-emailuser').length?true:false;
action=emailuser
- This module requires read rights.
- This module requires write rights.
- This module only accepts POST requests.
- Source: MediaWiki
- License: GPL-2.0-or-later
Email a user.
- target
User to send the email to.
- This parameter is required.
- subject
Subject header.
- This parameter is required.
- text
Email body.
- This parameter is required.
- ccme
Send a copy of this mail to me.
- Type: boolean (details)
- token
A "csrf" token retrieved from action=query&meta=tokens
- This parameter is required.
- Send an email to the user WikiSysop with the text Content.
- api.php?action=emailuser&target=WikiSysop&text=Content&token=123ABC [open in sandbox]