1
|
<?php
|
2
|
/**
|
3
|
*
|
4
|
* @category backend
|
5
|
* @package wysiwyg
|
6
|
* @author WebsiteBaker Project
|
7
|
* @copyright 2009-2012, Website Baker Org. e.V.
|
8
|
* @link http://www.websitebaker2.org/
|
9
|
* @license http://www.gnu.org/licenses/gpl.html
|
10
|
* @platform WebsiteBaker 2.8.x
|
11
|
* @requirements PHP 5.2.2 and higher
|
12
|
* @version $Id: save.php 1868 2013-02-19 21:07:19Z Luisehahne $
|
13
|
* @filesource $HeadURL: svn://isteam.dynxs.de/wb-archiv/branches/2.8.x/wb/modules/wysiwyg/save.php $
|
14
|
* @lastmodified $Date: 2013-02-19 22:07:19 +0100 (Tue, 19 Feb 2013) $
|
15
|
*
|
16
|
*/
|
17
|
|
18
|
require('../../config.php');
|
19
|
|
20
|
// suppress to print the header, so no new FTAN will be set
|
21
|
$admin_header = false;
|
22
|
// Tells script to update when this page was last updated
|
23
|
$update_when_modified = true;
|
24
|
// Include WB admin wrapper script
|
25
|
require(WB_PATH.'/modules/admin.php');
|
26
|
|
27
|
if (!$admin->checkFTAN()) {
|
28
|
$admin->print_header();
|
29
|
$admin->print_error($MESSAGE['GENERIC_SECURITY_ACCESS'], ADMIN_URL.'/pages/modify.php?page_id='.$page_id);
|
30
|
}
|
31
|
// After check print the header
|
32
|
$admin->print_header();
|
33
|
|
34
|
// Include the WB functions file
|
35
|
require_once(WB_PATH.'/framework/functions.php');
|
36
|
$aErrors = array();
|
37
|
$sMediaUrl = WB_URL.MEDIA_DIRECTORY;
|
38
|
// Update the mod_wysiwygs table with the contents
|
39
|
if(isset($_POST['content'.$section_id])) {
|
40
|
$content = $_POST['content'.$section_id];
|
41
|
if(ini_get('magic_quotes_gpc')==true)
|
42
|
{
|
43
|
$content = $admin->strip_slashes($_POST['content'.$section_id]);
|
44
|
}
|
45
|
$searchfor = '@(<[^>]*=\s*")('.preg_quote($sMediaUrl).')([^">]*".*>)@siU';
|
46
|
$content = preg_replace($searchfor, '$1{SYSVAR:MEDIA_REL}$3', $content);
|
47
|
// searching in $text will be much easier this way
|
48
|
$content = WbDatabase::getInstance()->escapeString ($content);
|
49
|
$text = umlauts_to_entities(strip_tags($content), strtoupper(DEFAULT_CHARSET), 0);
|
50
|
$sql = 'UPDATE `'.TABLE_PREFIX.'mod_wysiwyg` ';
|
51
|
$sql .= 'SET `content`=\''.$content.'\', `text`=\''.$text.'\' ';
|
52
|
$sql .= 'WHERE `section_id`='.(int)$section_id;
|
53
|
if(!$database->query($sql)){
|
54
|
$aErrors[] = $MESSAGE['GENERIC_NOT_UPGRADED'].((defined('DEBUG') && DEBUG) ? '<br />'.$database->get_error() : '');
|
55
|
}
|
56
|
} else {
|
57
|
$aErrors[] = $MESSAGE['GENERIC_NOT_UPGRADED'].((defined('DEBUG') && DEBUG) ? '<br />'.$MESSAGE['FRONTEND_SORRY_NO_ACTIVE_SECTIONS'] : '');
|
58
|
}
|
59
|
|
60
|
$sec_anchor = '#'.(defined( 'SEC_ANCHOR' ) && ( SEC_ANCHOR != '' ) ? SEC_ANCHOR.$section_id : 'section_'.$section_id );
|
61
|
if(defined('EDIT_ONE_SECTION') and EDIT_ONE_SECTION){
|
62
|
$edit_page = ADMIN_URL.'/pages/modify.php?page_id='.$page_id.'&wysiwyg='.$section_id;
|
63
|
} else {
|
64
|
$edit_page = ADMIN_URL.'/pages/modify.php?page_id='.$page_id.$sec_anchor;
|
65
|
}
|
66
|
|
67
|
// Check if there is a database error, otherwise say successful
|
68
|
if(sizeof($aErrors) ) {
|
69
|
$admin->print_error( implode('<br />',$aErrors), $edit_page);
|
70
|
} else {
|
71
|
$admin->print_success($MESSAGE['GENERIC_UPGRADED'], $edit_page );
|
72
|
}
|
73
|
|
74
|
// Print admin footer
|
75
|
$admin->print_footer();
|