本文整理匯總了PHP中EditPage::spamPageWithContent方法的典型用法代碼示例。如果您正苦於以下問題:PHP EditPage::spamPageWithContent方法的具體用法?PHP EditPage::spamPageWithContent怎麽用?PHP EditPage::spamPageWithContent使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類EditPage
的用法示例。
在下文中一共展示了EditPage::spamPageWithContent方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: wfAntiSpamInputCheck
function wfAntiSpamInputCheck()
{
if (!empty($_POST['antispam'])) {
$title = new Title();
$article = new Article($title);
$edit = new EditPage($article);
$edit->spamPageWithContent();
return false;
} else {
return true;
}
}
示例2: execute
public function execute($par)
{
global $wgUser, $wgRequest, $wgOut, $wgCommentboxNamespaces;
if (!$wgRequest->wasPosted()) {
$wgOut->redirect(Title::newMainPage()->getFullURL());
return;
}
$this->setHeaders();
$Pagename = $wgRequest->getText('wpPageName');
$Author = $wgRequest->getText('wpAuthor', '');
$Comment = $wgRequest->getText('wpComment', '');
$title = Title::newFromText($Pagename);
if ($title == NULL || !$title->exists()) {
$this->fail('commentbox-error-page-nonexistent');
return;
}
if (!array_key_exists($title->getNamespace(), $wgCommentboxNamespaces) || !$wgCommentboxNamespaces[$title->getNamespace()]) {
$this->fail('commentbox-error-namespace', $title);
return;
}
if ($Comment == '' || $Comment == wfMsgNoTrans('commentbox-prefill')) {
$this->fail('commentbox-error-empty-comment', $title);
return;
}
if (!$title->userCan('edit')) {
$this->displayRestrictionError();
return;
}
// TODO: Integrate with SpamBlacklist etc.
// Currently, no http/https-links are allowed at all
$matches = array();
if (preg_match('@https?://[-.\\w]+@', $Comment, $matches) || preg_match('@https?://[-.\\w]+@', $Author, $matches)) {
$wgOut->setPageTitle(wfMsg('spamprotectiontitle'));
$wgOut->setRobotPolicy('noindex,nofollow');
$wgOut->setArticleRelated(false);
$wgOut->addWikiMsg('spamprotectiontext');
$wgOut->addWikiMsg('spamprotectionmatch', "<nowiki>{$matches[0]}</nowiki>");
$wgOut->returnToMain(false, $title);
return;
}
$article = new Article($title);
$text = $article->getContent();
$subject = '';
if (!preg_match(wfMsgForContentNoTrans('commentbox-regex'), $text)) {
$subject = wfMsgForContent('commentbox-first-comment-heading') . "\n";
}
$sig = $wgUser->isLoggedIn() ? "-- ~~~~" : "-- {$Author} ~~~~~";
// Append <br /> after each newline, except if the user started a new paragraph
$Comment = preg_replace('/(?<!\\n)\\n(?!\\n)/', "<br />\n", $Comment);
$text .= "\n\n" . $subject . $Comment . "\n<br />" . $sig;
$reqArr = array('wpTextbox1' => $text, 'wpSummary' => wfMsgForContent('commentbox-log'), 'wpEditToken' => $wgUser->editToken(), 'wpIgnoreBlankSummary' => '', 'wpStarttime' => wfTimestampNow(), 'wpEdittime' => $article->getTimestamp());
$request = new FauxRequest($reqArr, true);
$ep = new EditPage($article);
$ep->setContextTitle($title);
$ep->importFormData($request);
$details = array();
// Passed by ref
$status = $ep->internalAttemptSave($details);
$retval = $status->value;
switch ($retval) {
case EditPage::AS_SUCCESS_UPDATE:
$wgOut->redirect($title->getFullURL());
break;
case EditPage::AS_SPAM_ERROR:
$ep->spamPageWithContent($details['spam']);
break;
case EditPage::AS_BLOCKED_PAGE_FOR_USER:
$wgOut->blockedPage();
break;
case EditPage::AS_READ_ONLY_PAGE_ANON:
case EditPage::AS_READ_ONLY_PAGE_LOGGED:
$wgOut->permissionRequired('edit');
break;
case EditPage::AS_READ_ONLY_PAGE:
$wgOut->readOnlyPage();
}
}
示例3: execute
/**
* Show the special page.
*
* @param $par Mixed: parameter passed to the special page or null
*/
public function execute($par)
{
global $wgRequest, $wgOut, $wgUser;
if (wfReadOnly()) {
$wgOut->readOnlyPage();
return;
}
$this->setHeaders();
if ($wgRequest->wasPosted()) {
// 1. Retrieve POST vars. First, we want "crOrigTitle", holding the
// title of the page we're writing to, and "crRedirectTitle",
// holding the title of the page we're redirecting to.
$crOrigTitle = $wgRequest->getText('crOrigTitle');
$crRedirectTitle = $wgRequest->getText('crRedirectTitle');
// 2. We need to construct a "FauxRequest", or fake a request that
// MediaWiki would otherwise get naturally by a client browser to
// do whatever it has to do. Let's put together the params.
$title = $crOrigTitle;
// a. We know our title, so we can instantiate a "Title" and
// "Article" object. We don't actually plug this into the
// FauxRequest, but they're required for the writing process,
// and they contain important information on the article in
// question that's being edited.
$crEditTitle = Title::newFromText($crOrigTitle);
// First, construct "Title". "Article" relies on the former object being set.
$crEditArticle = new Article($crEditTitle, 0);
// Then, construct "Article". This is where most of the article's information is.
$wpStarttime = wfTimestampNow();
// POST var "wpStarttime" stores when the edit was started.
$wpEdittime = $crEditArticle->getTimestamp();
// POST var "wpEdittime" stores when the article was ''last edited''. This is used to check against edit conflicts, and also why we needed to construct "Article" so early. "Article" contains the article's last edittime.
$wpTextbox1 = "#REDIRECT [[{$crRedirectTitle}]]\r\n";
// POST var "wpTextbox1" stores the content that's actually going to be written. This is where we write the #REDIRECT [[Article]] stuff. We plug in $crRedirectTitle here.
$wpSave = 1;
$wpMinoredit = 1;
// TODO: Decide on this; should this really be marked and hardcoded as a minor edit, or not? Or should we provide an option? --Digi 11/4/07
$wpEditToken = htmlspecialchars($wgUser->editToken());
// 3. Put together the params that we'll use in "FauxRequest" into a single array.
$crRequestParams = array('title' => $title, 'wpStarttime' => $wpStarttime, 'wpEdittime' => $wpEdittime, 'wpTextbox1' => $wpTextbox1, 'wpSave' => $wpSave, 'wpMinoredit' => $wpMinoredit, 'wpEditToken' => $wpEditToken);
// 4. Construct "FauxRequest"! Using a FauxRequest object allows
// for a transparent interface of generated request params that
// aren't retrieved from the client itself (i.e. $_REQUEST).
// It's a very useful tool.
$crRequest = new FauxRequest($crRequestParams, true);
// 5. Construct "EditPage", which contains routines to write all
// the data. This is where all the magic happens.
$crEdit = new EditPage($crEditArticle);
// We plug in the "Article" object here so EditPage can center on the article that we need to edit.
// a. We have to plug in the correct information that we just
// generated. While we fed EditPage with the correct "Article"
// object, it doesn't have the correct "Title" object.
// The "Title" object actually points to Special:CreateRedirect,
// which don't do us any good. Instead, explicitly plug in the
// correct objects; the objects "Article" and "Title" that we
// generated earlier. This will center EditPage on the correct article.
$crEdit->mArticle = $crEditArticle;
$crEdit->mTitle = $crEditTitle;
// b. Then import the "form data" (or the FauxRequest object that
// we just constructed). EditPage now has all the information we
// generated.
$crEdit->importFormData($crRequest);
$permErrors = $crEditTitle->getUserPermissionsErrors('edit', $wgUser);
// Can this title be created?
if (!$crEditTitle->exists()) {
$permErrors = array_merge($permErrors, wfArrayDiff2($crEditTitle->getUserPermissionsErrors('create', $wgUser), $permErrors));
}
if ($permErrors) {
wfDebug(__METHOD__ . ": User can't edit\n");
$wgOut->addWikiText($crEdit->formatPermissionsErrorMessage($permErrors, 'edit'));
wfProfileOut(__METHOD__);
return;
}
$resultDetails = false;
$status = $crEdit->internalAttemptSave($resultDetails, $wgUser->isAllowed('bot') && $wgRequest->getBool('bot', true));
$value = $status->value;
if ($value == EditPage::AS_SUCCESS_UPDATE || $value == EditPage::AS_SUCCESS_NEW_ARTICLE) {
$wgOut->wrapWikiMsg("<div class=\"mw-createredirect-done\">\n\$1</div>", array('createredirect-redirect-done', $crOrigTitle, $crRedirectTitle));
}
switch ($value) {
case EditPage::AS_SPAM_ERROR:
$crEdit->spamPageWithContent($resultDetails['spam']);
return;
case EditPage::AS_BLOCKED_PAGE_FOR_USER:
$crEdit->blockedPage();
return;
case EditPage::AS_READ_ONLY_PAGE_ANON:
$crEdit->userNotLoggedInPage();
return;
case EditPage::AS_READ_ONLY_PAGE_LOGGED:
case EditPage::AS_READ_ONLY_PAGE:
$wgOut->readOnlyPage();
return;
case EditPage::AS_RATE_LIMITED:
$wgOut->rateLimited();
break;
//.........這裏部分代碼省略.........