-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathadd.php
114 lines (98 loc) · 3.75 KB
/
add.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?php
/**
* This is the page there a user can add a FAQ record.
*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/.
*
* @package phpMyFAQ
* @author Thorsten Rinne <thorsten@phpmyfaq.de>
* @copyright 2002-2022 phpMyFAQ Team
* @license http://www.mozilla.org/MPL/2.0/ Mozilla Public License Version 2.0
* @link https://www.phpmyfaq.de
* @since 2002-09-16
*/
use phpMyFAQ\Captcha;
use phpMyFAQ\Filter;
use phpMyFAQ\Helper\CaptchaHelper;
use phpMyFAQ\Helper\CategoryHelper as HelperCategory;
use phpMyFAQ\Question;
use phpMyFAQ\Strings;
use phpMyFAQ\User\CurrentUser;
if (!defined('IS_VALID_PHPMYFAQ')) {
http_response_code(400);
exit();
}
// Check user permissions
if (-1 === $user->getUserId() && !$faqConfig->get('records.allowNewFaqsForGuests')) {
header('Location:' . $faqSystem->getSystemUri($faqConfig) . '?action=login');
exit;
}
// Check permission to add new faqs
if (-1 !== $user->getUserId() && !$user->perm->hasPermission($user->getUserId(), 'addfaq')) {
header('Location:' . $faqSystem->getSystemUri($faqConfig));
exit;
}
$captcha = new Captcha($faqConfig);
$captcha->setSessionId($sids);
$questionObject = new Question($faqConfig);
if (!is_null($showCaptcha)) {
$captcha->drawCaptchaImage();
exit;
}
try {
$faqSession->userTracking('new_entry', 0);
} catch (Exception $e) {
// @todo handle the exception
}
// Get possible user input
$selectedQuestion = Filter::filterInput(INPUT_GET, 'question', FILTER_VALIDATE_INT);
$selectedCategory = Filter::filterInput(INPUT_GET, 'cat', FILTER_VALIDATE_INT);
$question = $readonly = '';
if (!is_null($selectedQuestion)) {
$oQuestion = $questionObject->getQuestion($selectedQuestion);
$question = Strings::htmlentities($oQuestion['question']);
if (Strings::strlen($question)) {
$readonly = ' readonly';
}
}
$category->buildCategoryTree();
$categoryHelper = new HelperCategory();
$categoryHelper->setCategory($category);
$captchaHelper = new CaptchaHelper($faqConfig);
// Enable/Disable WYSIWYG editor
if ($faqConfig->get('main.enableWysiwygEditorFrontend')) {
$template->parseBlock(
'mainPageContent',
'enableWysiwygEditor',
[
'currentTimestamp' => $_SERVER['REQUEST_TIME'],
]
);
}
$template->parse(
'mainPageContent',
[
'pageHeader' => $PMF_LANG['msgNewContentHeader'],
'baseHref' => $faqSystem->getSystemUri($faqConfig),
'msgNewContentHeader' => $PMF_LANG['msgNewContentHeader'],
'msgNewContentAddon' => $PMF_LANG['msgNewContentAddon'],
'lang' => $Language->getLanguage(),
'openQuestionID' => $selectedQuestion,
'defaultContentMail' => ($user instanceof CurrentUser) ? $user->getUserData('email') : '',
'defaultContentName' => ($user instanceof CurrentUser) ? $user->getUserData('display_name') : '',
'msgNewContentName' => $PMF_LANG['msgNewContentName'],
'msgNewContentMail' => $PMF_LANG['msgNewContentMail'],
'msgNewContentCategory' => $PMF_LANG['msgNewContentCategory'],
'renderCategoryOptions' => $categoryHelper->renderOptions($selectedCategory),
'msgNewContentTheme' => $PMF_LANG['msgNewContentTheme'],
'readonly' => $readonly,
'printQuestion' => $question,
'msgNewContentArticle' => $PMF_LANG['msgNewContentArticle'],
'msgNewContentKeywords' => $PMF_LANG['msgNewContentKeywords'],
'msgNewContentLink' => $PMF_LANG['msgNewContentLink'],
'captchaFieldset' => $captchaHelper->renderCaptcha($captcha, 'add', $PMF_LANG['msgCaptcha'], $auth),
'msgNewContentSubmit' => $PMF_LANG['msgNewContentSubmit'],
]
);