1: <?php
2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14:
15:
16: defined('CON_FRAMEWORK') || die('Illegal call: Missing framework initialization - request aborted.');
17:
18: 19: 20: 21: 22: 23:
24: function checkExistingPlugin($db, $sPluginname) {
25: global $cfg;
26:
27:
28: if ($_SESSION["setuptype"] == "setup") {
29: return true;
30: }
31:
32: $sPluginname = (string) $sPluginname;
33: $sTable = $cfg['tab']['nav_sub'];
34: $sSql = '';
35:
36: switch ($sPluginname) {
37: case 'plugin_cronjob_overview':
38: $sSql = "SELECT * FROM %s WHERE idnavs=950";
39: break;
40: case 'plugin_conman':
41: $sSql = "SELECT * FROM %s WHERE idnavs=900";
42: break;
43: case 'plugin_content_allocation':
44: $sSql = "SELECT * FROM %s WHERE idnavs=800";
45: break;
46: case 'plugin_newsletter':
47: $sSql = "SELECT * FROM %s WHERE idnavs=610";
48: break;
49: case 'plugin_mod_rewrite':
50: $sSql = "SELECT * FROM %s WHERE idnavs=700 OR location='mod_rewrite/xml/;navigation/content/mod_rewrite'";
51: break;
52: default:
53: $sSql = '';
54: break;
55: }
56:
57: if ($sSql) {
58: $db->query($sSql, $sTable);
59: if ($db->nextRecord()) {
60: return true;
61: }
62: }
63:
64: return false;
65: }
66:
67: 68: 69: 70: 71:
72: function updateSystemProperties($db, $table) {
73: $table = cSecurity::escapeDB($table, $db);
74:
75: $aStandardvalues = array(
76: array('type' => 'pw_request', 'name' => 'enable', 'value' => 'true'),
77: array('type' => 'system', 'name' => 'mail_sender_name', 'value' => 'CONTENIDO Backend'),
78: array('type' => 'system', 'name' => 'mail_sender', 'value' => 'info@contenido.org'),
79: array('type' => 'system', 'name' => 'mail_host', 'value' => 'localhost'),
80: array('type' => 'maintenance', 'name' => 'mode', 'value' => 'disabled'),
81: array('type' => 'codemirror', 'name' => 'activated', 'value' => 'true'),
82: array('type' => 'update', 'name' => 'check', 'value' => 'false'),
83: array('type' => 'update', 'name' => 'news_feed', 'value' => 'false'),
84: array('type' => 'update', 'name' => 'check_period', 'value' => '60'),
85: array('type' => 'system', 'name' => 'clickmenu', 'value' => 'false'),
86: array('type' => 'versioning', 'name' => 'activated', 'value' => 'true'),
87: array('type' => 'versioning', 'name' => 'prune_limit', 'value' => ''),
88: array('type' => 'versioning', 'name' => 'path', 'value' => ''),
89: array('type' => 'system', 'name' => 'insite_editing_activated', 'value' => 'true'),
90: array('type' => 'backend', 'name' => 'backend_label', 'value' => ''),
91: array('type' => 'generator', 'name' => 'xhtml', 'value' => 'true'),
92: array('type' => 'generator', 'name' => 'basehref', 'value' => 'true')
93: );
94:
95: foreach ($aStandardvalues as $aData) {
96: $sql = "SELECT `value` FROM `%s` WHERE `type` = '%s' AND `name` = '%s'";
97: $db->query(sprintf($sql, $table, $aData['type'], $aData['name']));
98: if ($db->nextRecord()) {
99: $sValue = $db->f('value');
100: if ($sValue == '') {
101: $sql = "UPDATE `%s` SET `value` = '%s' WHERE `type` = '%s' AND `name` = '%s'";
102: $sql = sprintf($sql, $table, $aData['value'], $aData['type'], $aData['name']);
103: $db->query($sql);
104: }
105: } else {
106: $sql = "INSERT INTO `%s` SET `type` = '%s', `name` = '%s', `value` = '%s'";
107: $sql = sprintf($sql, $table, $aData['type'], $aData['name'], $aData['value']);
108: $db->query($sql);
109: }
110:
111: if ($db->getErrorNumber() != 0) {
112: logSetupFailure("Unable to execute SQL statement:\n" . $sql . "\nMysql Error: " . $db->getErrorMessage() . " (" . $db->getErrorNumber() . ")");
113: }
114: }
115: }
116:
117: 118: 119: 120: 121: 122:
123: function updateContenidoVersion($db, $table, $version) {
124: $sql = "SELECT `idsystemprop` FROM `%s` WHERE `type` = 'system' AND `name` = 'version'";
125: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db)));
126:
127: if ($db->nextRecord()) {
128: $sql = "UPDATE `%s` SET `value` = '%s' WHERE `type` = 'system' AND `name` = 'version'";
129: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db), cSecurity::escapeDB($version, $db)));
130: } else {
131:
132: $sql = "INSERT INTO `%s` SET `type` = 'system', `name` = 'version', `value` = '%s'";
133: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db), cSecurity::escapeDB($version, $db)));
134: }
135: }
136:
137: 138: 139: 140: 141: 142:
143: function getContenidoVersion($db, $table) {
144: $sql = "SELECT `value` FROM `%s` WHERE `type` = 'system' AND `name` = 'version'";
145: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db)));
146:
147: if ($db->nextRecord()) {
148: return $db->f("value");
149: } else {
150: return false;
151: }
152: }
153:
154:
155: function updateSysadminPassword($db, $table, $password, $mail) {
156: $sql = "SELECT password FROM %s WHERE username='sysadmin'";
157: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db)));
158:
159: if ($db->nextRecord()) {
160: $sql = "UPDATE %s SET password='%s', email='%s' WHERE username='sysadmin'";
161: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db), md5($password), $mail));
162: return true;
163: } else {
164:
165: return false;
166: }
167: }
168:
169:
170: function listClients($db, $table) {
171: global $cfgClient;
172:
173: $sql = "SELECT idclient, name FROM %s";
174:
175: $db->query(sprintf($sql, cSecurity::escapeDB($table, $db)));
176:
177: $clients = array();
178:
179: while ($db->nextRecord()) {
180: $frontendPath = $cfgClient[$db->f('idclient')]['path']['frontend'];
181: $htmlPath = $cfgClient[$db->f('idclient')]['path']['htmlpath'];
182: $clients[$db->f("idclient")] = array("name" => $db->f("name"), "frontendpath" => $frontendPath, "htmlpath" => $htmlPath);
183: }
184:
185: return $clients;
186: }
187:
188:
189: function updateClientPath($db, $table, $idclient, $frontendpath, $htmlpath) {
190: global $cfg, $cfgClient;
191: checkAndInclude($cfg['path']['contenido'] . 'includes/functions.general.php');
192:
193: updateClientCache($idclient, $htmlpath, $frontendpath);
194: }
195:
196:
197: function stripLastSlash($sInput) {
198: if (substr($sInput, strlen($sInput) - 1, 1) == "/") {
199: $sInput = substr($sInput, 0, strlen($sInput) - 1);
200: }
201:
202: return $sInput;
203: }
204:
205:
206: function getSystemDirectories($bOriginalPath = false) {
207: $root_path = stripLastSlash(CON_FRONTEND_PATH);
208:
209: $root_http_path = dirname(dirname($_SERVER["PHP_SELF"]));
210: $root_http_path = str_replace("\\", "/", $root_http_path);
211:
212: $port = "";
213: $protocol = "http://";
214:
215: if ($_SERVER["SERVER_PORT"] != 80) {
216: if ($_SERVER["SERVER_PORT"] == 443) {
217: $protocol = "https://";
218: } else {
219: $port = ":" . $_SERVER["SERVER_PORT"];
220: }
221: }
222:
223: $root_http_path = $protocol . $_SERVER["SERVER_NAME"] . $port . $root_http_path;
224:
225: if (substr($root_http_path, strlen($root_http_path) - 1, 1) == "/") {
226: $root_http_path = substr($root_http_path, 0, strlen($root_http_path) - 1);
227: }
228:
229: if ($bOriginalPath == true) {
230: return array($root_path, $root_http_path);
231: }
232:
233: if (isset($_SESSION["override_root_path"])) {
234: $root_path = $_SESSION["override_root_path"];
235: }
236:
237: if (isset($_SESSION["override_root_http_path"])) {
238: $root_http_path = $_SESSION["override_root_http_path"];
239: }
240:
241: $root_path = stripLastSlash($root_path);
242: $root_http_path = stripLastSlash($root_http_path);
243:
244: return array($root_path, $root_http_path);
245: }
246:
247:
248: function findSimilarText($string1, $string2) {
249: for ($i = 0; $i < strlen($string1); $i++) {
250: if (substr($string1, 0, $i) != substr($string2, 0, $i)) {
251: return $i - 1;
252: }
253: }
254:
255: return $i - 1;
256: }
257:
258: ?>