36 $str = str_replace(
'<?=',
'<?php', $str);
42 $parts = preg_split(
'/'.preg_quote(
'<?php',
'/').
'/i', $str);
46 foreach ($parts as $part) {
53 $partlings = explode(
'?>', $part);
54 if (!empty($partlings)) {
57 if (count($partlings) > 1) {
63 $newstr .=
'<span phptag>'.$replacewith.
'</span>'.implode(
'', $partlings);
80 $str = str_replace(
'<?=',
'<?php', $str);
81 $str = str_replace(
'<?php',
'__LTINTPHP__', $str);
82 $str = str_replace(
'<?',
'<?php', $str);
83 $str = str_replace(
'__LTINTPHP__',
'<?php', $str);
89 $parts = preg_split(
'/'.preg_quote(
'<?php',
'/').
'/i', $str);
93 foreach ($parts as $part) {
100 $partlings = explode(
'?>', $part, 2);
101 if (!empty($partlings)) {
102 $newstr .= $partlings[0].
'?>';
104 $newstr .= $part.
'?>';
127 dol_syslog(
'dolWebsiteReplacementOfLinks start (contenttype='.$contenttype.
" containerid=".$containerid.
" USEDOLIBARREDITOR=".(defined(
'USEDOLIBARREDITOR') ?
'1' :
'').
" USEDOLIBARRSERVER=".(defined(
'USEDOLIBARRSERVER') ?
'1' :
'').
')', LOG_DEBUG);
131 $replacewith =
'...php...';
132 if ($removephppart) {
135 $content = preg_replace(
'/value="<\?php((?!\?>).)*\?>\n*/ims',
'value="'.$replacewith.
'"', $content);
137 $replacewith =
'"callto=#';
138 if ($removephppart) {
141 $content = preg_replace(
'/"callto:<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
143 $replacewith =
'"mailto=#';
144 if ($removephppart) {
147 $content = preg_replace(
'/"mailto:<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
149 $replacewith =
'src="php';
150 if ($removephppart) {
153 $content = preg_replace(
'/src="<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
155 $replacewith =
'href="php';
156 if ($removephppart) {
159 $content = preg_replace(
'/href="<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
162 $replacewith =
'...php...';
163 if ($removephppart) {
173 $content = str_replace(
'href="styles.css.php',
'href="!~!~!~styles.css.php', $content);
174 $content = str_replace(
'src="javascript.js.php',
'src="!~!~!~javascript.js.php', $content);
175 $content = str_replace(
'href="http',
'href="!~!~!~http', $content);
176 $content = str_replace(
'xlink:href="',
'xlink:href="!~!~!~', $content);
177 $content = str_replace(
'href="//',
'href="!~!~!~//', $content);
178 $content = str_replace(
'src="//',
'src="!~!~!~//', $content);
179 $content = str_replace(
'src="viewimage.php',
'src="!~!~!~/viewimage.php', $content);
180 $content = str_replace(
'src="/viewimage.php',
'src="!~!~!~/viewimage.php', $content);
181 $content = str_replace(
'src="'.DOL_URL_ROOT.
'/viewimage.php',
'src="!~!~!~'.DOL_URL_ROOT.
'/viewimage.php', $content);
182 $content = str_replace(
'href="document.php',
'href="!~!~!~/document.php', $content);
183 $content = str_replace(
'href="/document.php',
'href="!~!~!~/document.php', $content);
184 $content = str_replace(
'href="'.DOL_URL_ROOT.
'/document.php',
'href="!~!~!~'.DOL_URL_ROOT.
'/document.php', $content);
187 $content = preg_replace(
'/(href=")\/(#[^\"<>]*)?\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/website/index.php?website='.$website->ref.
'&pageid='.$website->fk_default_home.
'\2"', $content, -1, $nbrep);
189 $content = preg_replace(
'/(href=")\/?([^:\"\!]*)\.php(#[^\"<>]*)?\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/website/index.php?website='.$website->ref.
'&pageref=\2\3"', $content, -1, $nbrep);
191 $content = preg_replace(
'/(href=")\/?([^:\"\!]*)\.php\?([^#\"<>]*)(#[^\"<>]*)?\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/website/index.php?website='.$website->ref.
'&pageref=\2&\3\4"', $content, -1, $nbrep);
194 $content = preg_replace(
'/url\((["\']?)\/?medias\//',
'url(\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
195 $content = preg_replace(
'/data-slide-bg=(["\']?)\/?medias\//',
'data-slide-bg=\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
199 $content = preg_replace(
'/(<img[^>]*src=")\/?medias\//',
'\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
201 $content = preg_replace(
'/(<img[^>]*src=")\/?([^:\"\!]+)\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=\2"', $content, -1, $nbrep);
203 $content = preg_replace(
'/(<img[^>]*src=")(\/?viewimage\.php)/',
'\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php', $content, -1, $nbrep);
206 $content = preg_replace(
'/(action=")\/?([^:\"]*)(\.php\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'/website/index.php?website='.$website->ref.
'&pageref=\2"', $content, -1, $nbrep);
209 $content = preg_replace(
'/(href=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
210 $content = preg_replace(
'/(src=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
213 $content = preg_replace(
'/(url\(")(\/?viewimage\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
216 $content = str_replace(
'src="!~!~!~/viewimage.php',
'src="!~!~!~'.DOL_URL_ROOT.
'/viewimage.php', $content);
217 $content = str_replace(
'href="!~!~!~/document.php',
'href="!~!~!~'.DOL_URL_ROOT.
'/document.php', $content);
219 $content = str_replace(
'!~!~!~',
'', $content);
221 dol_syslog(
'dolWebsiteReplacementOfLinks end', LOG_DEBUG);
236 ":face_with_tears_of_joy:" =>
"\xF0\x9F\x98\x82",
237 ":grinning_face_with_smiling_eyes:" =>
"\xF0\x9F\x98\x81",
238 ":smiling_face_with_open_mouth:" =>
"\xF0\x9F\x98\x83",
239 ":smiling_face_with_open_mouth_and_cold_sweat:" =>
"\xF0\x9F\x98\x85",
240 ":smiling_face_with_open_mouth_and_tightly_closed_eyes:" =>
"\xF0\x9F\x98\x86",
241 ":winking_face:" =>
"\xF0\x9F\x98\x89",
242 ":smiling_face_with_smiling_eyes:" =>
"\xF0\x9F\x98\x8A",
243 ":face_savouring_delicious_food:" =>
"\xF0\x9F\x98\x8B",
244 ":relieved_face:" =>
"\xF0\x9F\x98\x8C",
245 ":smiling_face_with_heart_shaped_eyes:" =>
"\xF0\x9F\x98\x8D",
246 ":smiling_face_with_sunglasses:" =>
"\xF0\x9F\x98\x8E",
247 ":smirking_face:" =>
"\xF0\x9F\x98\x8F",
248 ":neutral_face:" =>
"\xF0\x9F\x98\x90",
249 ":expressionless_face:" =>
"\xF0\x9F\x98\x91",
250 ":unamused_face:" =>
"\xF0\x9F\x98\x92",
251 ":face_with_cold_sweat:" =>
"\xF0\x9F\x98\x93",
252 ":pensive_face:" =>
"\xF0\x9F\x98\x94",
253 ":confused_face:" =>
"\xF0\x9F\x98\x95",
254 ":confounded_face:" =>
"\xF0\x9F\x98\x96",
255 ":kissing_face:" =>
"\xF0\x9F\x98\x97",
256 ":face_throwing_a_kiss:" =>
"\xF0\x9F\x98\x98",
257 ":kissing_face_with_smiling_eyes:" =>
"\xF0\x9F\x98\x99",
258 ":kissing_face_with_closed_eyes:" =>
"\xF0\x9F\x98\x9A",
259 ":face_with_stuck_out_tongue:" =>
"\xF0\x9F\x98\x9B",
260 ":face_with_stuck_out_tongue_and_winking_eye:" =>
"\xF0\x9F\x98\x9C",
261 ":face_with_stuck_out_tongue_and_tightly_closed_eyes:" =>
"\xF0\x9F\x98\x9D",
262 ":disappointed_face:" =>
"\xF0\x9F\x98\x9E",
263 ":worried_face:" =>
"\xF0\x9F\x98\x9F",
264 ":angry_face:" =>
"\xF0\x9F\x98\xA0",
265 ":face_with_symbols_on_mouth:" =>
"\xF0\x9F\x98\xA1",
267 foreach ($map as $key => $value) {
268 $content = str_replace($key, $value, $content);
286 global $db, $langs, $conf, $user;
287 global $dolibarr_main_url_root, $dolibarr_main_data_root;
289 global $includehtmlcontentopened;
293 dol_syslog(
"dolWebsiteOutput start - contenttype=".$contenttype.
" containerid=".$containerid.
" USEDOLIBARREDITOR=".(defined(
'USEDOLIBARREDITOR') ?
'1' :
'').
" USEDOLIBARRSERVER=".(defined(
'USEDOLIBARRSERVER') ?
'1' :
'').
' includehtmlcontentopened='.$includehtmlcontentopened);
298 $urlwithouturlroot = preg_replace(
'/'.preg_quote(DOL_URL_ROOT,
'/').
'$/i',
'', trim($dolibarr_main_url_root));
299 $urlwithroot = $urlwithouturlroot.DOL_URL_ROOT;
302 if (defined(
'USEDOLIBARREDITOR')) {
304 if ($contenttype ==
'html') {
305 $content = preg_replace(
'/<head>.*<\/head>/ims',
'', $content);
306 $content = preg_replace(
'/^.*<body(\s[^>]*)*>/ims',
'', $content);
307 $content = preg_replace(
'/<\/body(\s[^>]*)*>.*$/ims',
'', $content);
309 } elseif (defined(
'USEDOLIBARRSERVER')) {
310 $content = str_replace(
'<link rel="stylesheet" href="/styles.css',
'<link rel="stylesheet" href="styles.css', $content);
311 $content = str_replace(
' async src="/javascript.js',
' async src="javascript.js', $content);
314 $content = str_replace(
'href="styles.css.php',
'href="!~!~!~styles.css.php', $content);
315 $content = str_replace(
'src="javascript.css.php',
'src="!~!~!~javascript.css.php', $content);
316 $content = str_replace(
'href="http',
'href="!~!~!~http', $content);
317 $content = str_replace(
'xlink:href="',
'xlink:href="!~!~!~', $content);
318 $content = str_replace(
'href="//',
'href="!~!~!~//', $content);
319 $content = str_replace(
'src="//',
'src="!~!~!~//', $content);
320 $content = str_replace(array(
'src="viewimage.php',
'src="/viewimage.php'),
'src="!~!~!~/viewimage.php', $content);
321 $content = str_replace(
'src="'.DOL_URL_ROOT.
'/viewimage.php',
'src="!~!~!~'.DOL_URL_ROOT.
'/viewimage.php', $content);
322 $content = str_replace(array(
'href="document.php',
'href="/document.php'),
'href="!~!~!~/document.php', $content);
323 $content = str_replace(
'href="'.DOL_URL_ROOT.
'/document.php',
'href="!~!~!~'.DOL_URL_ROOT.
'/document.php', $content);
326 $content = preg_replace(
'/(href=")\/\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/public/website/index.php?website='.$website->ref.
'"', $content, -1, $nbrep);
328 $content = preg_replace(
'/(href=")\/?([^:\"\!]*)\.php(#[^\"<>]*)?\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/public/website/index.php?website='.$website->ref.
'&pageref=\2\3"', $content, -1, $nbrep);
332 $content = preg_replace(
'/(href=")\/?([^:\"\!]*)\.php\?([^#\"<>]*)(#[^\"<>]*)?\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/public/website/index.php?website='.$website->ref.
'&pageref=\2&\3\4"', $content, -1, $nbrep);
334 $content = preg_replace(
'/([\'"])_service_page_([^\'"]+)\.php\1/',
'\1!~!~!~' . DOL_URL_ROOT .
'/public/website/index.php?website=' . $website->ref .
'&pageref=_service_page_\2\1', $content, -1, $nbrep);
336 $content = preg_replace(
'/([\'"])_library_page_([^\'"]+)\.php\1/',
'\1!~!~!~' . DOL_URL_ROOT .
'/public/website/index.php?website=' . $website->ref .
'&pageref=_library_page_\2\1', $content, -1, $nbrep);
338 $content = preg_replace(
'/(href=")\/?([a-zA-Z0-9\-_#]+)(\"|\?)/',
'\1!~!~!~'.DOL_URL_ROOT.
'/public/website/index.php?website='.$website->ref.
'&pageref=\2\3', $content, -1, $nbrep);
341 $content = preg_replace(
'/(href=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
342 $content = preg_replace(
'/(src=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
345 $content = preg_replace(
'/(href=")(\/?viewimage\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
346 $content = preg_replace(
'/(src=")(\/?viewimage\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
347 $content = preg_replace(
'/(url\(")(\/?viewimage\.php\?[^\"]*modulepart=[^\"]*)(\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'\2\3', $content, -1, $nbrep);
350 $content = preg_replace(
'/url\((["\']?)\/?medias\//',
'url(\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
351 $content = preg_replace(
'/data-slide-bg=(["\']?)\/?medias\//',
'data-slide-bg=\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
355 $content = preg_replace(
'/(<img[^>]*src=")\/?medias\//',
'\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
357 $content = preg_replace(
'/(<img[^>]*src=")\/?([^:\"\!]+)\"/',
'\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file=\2"', $content, -1, $nbrep);
359 $content = preg_replace(
'/(<img[^>]*src=")(\/?viewimage\.php)/',
'\1!~!~!~'.DOL_URL_ROOT.
'/viewimage.php', $content, -1, $nbrep);
362 $content = preg_replace(
'/(action=")\/?([^:\"]*)(\.php\")/',
'\1!~!~!~'.DOL_URL_ROOT.
'/public/website/index.php?website='.$website->ref.
'&pageref=\2"', $content, -1, $nbrep);
365 $content = str_replace(
'src="!~!~!~/viewimage.php',
'src="!~!~!~'.DOL_URL_ROOT.
'/viewimage.php', $content);
366 $content = str_replace(
'href="!~!~!~/document.php',
'href="!~!~!~'.DOL_URL_ROOT.
'/document.php', $content);
369 if (empty($includehtmlcontentopened)) {
370 $content = str_replace(
'!~!~!~',
'', $content);
373 $symlinktomediaexists = 1;
374 if ($website->virtualhost) {
375 $content = preg_replace(
'/^(<link[^>]*rel="canonical" href=")\//m',
'\1'.$website->virtualhost.
'/', $content, -1, $nbrep);
384 if (!$symlinktomediaexists) {
386 $content = preg_replace(
'/(<img[^>]*src=")\/?image\//',
'\1/wrapper.php?modulepart=medias&file=medias/image/', $content, -1, $nbrep);
387 $content = preg_replace(
'/(url\(["\']?)\/?image\//',
'\1/wrapper.php?modulepart=medias&file=medias/image/', $content, -1, $nbrep);
389 $content = preg_replace(
'/(<script[^>]*src=")[^\"]*document\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
390 $content = preg_replace(
'/(<a[^>]*href=")[^\"]*document\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
392 $content = preg_replace(
'/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
393 $content = preg_replace(
'/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
394 $content = preg_replace(
'/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)modulepart=medias([^\)]*)file=([^\)]*)(["\']?\))/',
'\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
396 $content = preg_replace(
'/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
397 $content = preg_replace(
'/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
398 $content = preg_replace(
'/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)hashp=([^\)]*)(["\']?\))/',
'\1/wrapper.php\2hashp\3\4', $content, -1, $nbrep);
400 $content = preg_replace(
'/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=mycompany([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2modulepart=mycompany\3file=\4\5', $content, -1, $nbrep);
403 $content = preg_replace(
'/(<img[^>]*src=")\/?viewimage\.php/',
'\1/wrapper.php', $content, -1, $nbrep);
404 $content = preg_replace(
'/(<a[^>]*href=")\/?documents\.php/',
'\1/wrapper.php', $content, -1, $nbrep);
407 $content = preg_replace(
'/(<img[^>]*src=")\/?image\//',
'\1/medias/image/', $content, -1, $nbrep);
408 $content = preg_replace(
'/(url\(["\']?)\/?image\//',
'\1/medias/image/', $content, -1, $nbrep);
410 $content = preg_replace(
'/(<script[^>]*src=")[^\"]*document\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/medias/\4\5', $content, -1, $nbrep);
411 $content = preg_replace(
'/(<a[^>]*href=")[^\"]*document\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/medias/\4\5', $content, -1, $nbrep);
413 $content = preg_replace(
'/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/medias/\4\5', $content, -1, $nbrep);
414 $content = preg_replace(
'/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/medias/\4\5', $content, -1, $nbrep);
415 $content = preg_replace(
'/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)modulepart=medias([^\)]*)file=([^\)]*)(["\']?\))/',
'\1/medias/\4\5', $content, -1, $nbrep);
417 $content = preg_replace(
'/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
418 $content = preg_replace(
'/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
419 $content = preg_replace(
'/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)hashp=([^\)]*)(["\']?\))/',
'\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
421 $content = preg_replace(
'/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=mycompany([^\"]*)file=([^\"]*)("[^>]*>)/',
'\1/wrapper.php\2modulepart=mycompany\3file=\4\5', $content, -1, $nbrep);
424 $content = preg_replace(
'/(<img[^>]*src=")\/?viewimage\.php/',
'\1/wrapper.php', $content, -1, $nbrep);
425 $content = preg_replace(
'/(<a[^>]*href=")\/?document\.php/',
'\1/wrapper.php', $content, -1, $nbrep);
429 if (!defined(
'USEDOLIBARREDITOR')) {
430 $content = str_replace(
' contenteditable="true"',
' contenteditable="false"', $content);
434 $content = str_replace(
'<body id="bodywebsite" class="bodywebsite',
'<body id="bodywebsite" class="bodywebsite ' .
getDolGlobalString(
'WEBSITE_ADD_CSS_TO_BODY'), $content);
456 if (in_array($websitepagetype, array(
'blogpost',
'page'))) {
461 $sql =
"UPDATE ".$db->prefix().
"website SET ";
462 $sql .=
" pageviews_total = pageviews_total + 1,";
463 $sql .=
" pageviews_month = pageviews_month + 1,";
465 $sql .=
" pageviews_previous_month = ".$db->ifsql(
"lastaccess < '".$db->idate(
dol_mktime(0, 0, 0, $tmpnow[
'mon'], 1, $tmpnow[
'year'],
'gmt', 0),
'gmt').
"'",
'pageviews_month',
'pageviews_previous_month').
",";
466 $sql .=
" lastaccess = '".$db->idate(
dol_now(
'gmt'),
'gmt').
"',";
467 $sql .=
" lastpageid = ".((int) $websitepageid);
468 $sql .=
" WHERE rowid = ".((int) $websiteid);
470 $resql = $db->query(
$sql);
518 function redirectToContainer($containerref, $containeraliasalt =
'', $containerid = 0, $permanent = 0, $parameters = array())
520 global $db, $website;
526 if ($containeraliasalt) {
527 include_once DOL_DOCUMENT_ROOT.
'/website/class/websitepage.class.php';
530 $result = $tmpwebsitepage->fetch(0, $website->id,
'', $containeraliasalt);
532 $containerref = $tmpwebsitepage->pageurl;
534 print
"Error, page contains a redirect to the alternative alias '".$containeraliasalt.
"' that does not exists in web site (".$website->id.
" / ".$website->ref.
")";
539 if (defined(
'USEDOLIBARREDITOR')) {
543 $text =
"This page contains dynamic code that make a redirect to '".$containerref.
"' in your current context. Redirect has been canceled as it is not supported in edition mode.";
544 setEventMessages($text,
null,
'warnings',
'WEBSITEREDIRECTDISABLED'.$containerref);
548 if (defined(
'USEDOLIBARRSERVER')) {
550 if (!$containeraliasalt) {
551 include_once DOL_DOCUMENT_ROOT.
'/website/class/websitepage.class.php';
554 $result = $tmpwebsitepage->fetch(0, $website->id, $containerref);
555 unset($tmpwebsitepage);
558 $currenturi = $_SERVER[
"REQUEST_URI"];
560 if (preg_match(
'/&pageref=([^&]+)/', $currenturi, $regtmp)) {
561 if ($regtmp[0] == $containerref) {
562 print
"Error, page with uri '.$currenturi.' try a redirect to the same alias page '".$containerref.
"' in web site '".$website->ref.
"'";
565 $newurl = preg_replace(
'/&pageref=([^&]+)/',
'&pageref='.$containerref, $currenturi);
568 $newurl = $currenturi.
'&pageref='.urlencode($containerref);
572 $newurl =
'/'.$containerref.
'.php';
573 $newurl = $newurl.(empty($_SERVER[
"QUERY_STRING"]) ?
'' :
'?'.$_SERVER[
"QUERY_STRING"]);
577 if (!empty($parameters)) {
578 $separator = (parse_url($newurl, PHP_URL_QUERY) ==
null) ?
'?' :
'&';
579 $newurl = $newurl . $separator . http_build_query($parameters);
582 header(
"Status: 301 Moved Permanently",
false, 301);
584 header(
"Location: ".$newurl);
587 print
"Error, page contains a redirect to the alias page '".$containerref.
"' that does not exists in web site (".$website->id.
" / ".$website->ref.
")";
602 global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs;
603 global $includehtmlcontentopened;
604 global $websitekey, $websitepagefile;
608 if (!preg_match(
'/\.php$/i', $containerref)) {
609 $containerref .=
'.php';
612 $fullpathfile = DOL_DATA_ROOT.($conf->entity > 1 ?
'/'.$conf->entity :
'').
'/website/'.$websitekey.
'/'.$containerref;
614 if (empty($includehtmlcontentopened)) {
615 $includehtmlcontentopened = 0;
617 $includehtmlcontentopened++;
618 if ($includehtmlcontentopened > $MAXLEVEL) {
619 print
'ERROR: RECURSIVE CONTENT LEVEL. Depth of recursive call is more than the limit of '.((int) $MAXLEVEL).
".\n";
630 $res = @include $fullpathfile;
631 $tmpoutput = ob_get_contents();
634 print
"\n".
'<!-- include '.$websitekey.
'/'.$containerref.(is_object($websitepage) ?
' parent id='.$websitepage->id :
'').
' level = '.$includehtmlcontentopened.
' -->'.
"\n";
635 print preg_replace(array(
'/^.*<body[^>]*>/ims',
'/<\/body>.*$/ims'), array(
'',
''), $tmpoutput);
638 print
'ERROR: FAILED TO INCLUDE PAGE '.$containerref.
".\n";
641 $includehtmlcontentopened--;
656 global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs, $pagelangs;
658 $type = strtolower($type);
660 if ($type ==
'software') {
661 $ret =
'<!-- Add structured data for entry in a software annuary -->'.
"\n";
662 $ret .=
'<script nonce="'.getNonce().
'" type="application/ld+json">'.
"\n";
664 "@context": "https://schema.org",
665 "@type": "SoftwareApplication",
666 "name": "'.dol_escape_json($data[
'name']).
'",
668 "applicationCategory": "https://schema.org/'.
dol_escape_json($data[
'applicationCategory']).
'",';
669 if (!empty($data[
'ratingcount'])) {
672 "@type": "AggregateRating",
673 "ratingValue": "'.dol_escape_json($data[
'ratingvalue']).
'",
680 "price": "'.dol_escape_json($data[
'price']).
'",
681 "priceCurrency": "'.
dol_escape_json($data[
'currency'] ? $data[
'currency'] : $conf->currency).
'"
684 $ret .=
'</script>'.
"\n";
685 } elseif ($type ==
'organization') {
686 $companyname = $mysoc->name;
689 $ret =
'<!-- Add structured data for organization -->'.
"\n";
690 $ret .=
'<script nonce="'.getNonce().
'" type="application/ld+json">'.
"\n";
692 "@context": "https://schema.org",
693 "@type": "Organization",
694 "name": "'.dol_escape_json(!empty($data[
'name']) ? $data[
'name'] : $companyname).
'",
695 "url": "'.
dol_escape_json(!empty($data[
'url']) ? $data[
'url'] : $url).
'",
696 "logo": "'.($data[
'logo'] ?
dol_escape_json($data[
'logo']) :
'/wrapper.php?modulepart=mycompany&file=logos%2F'.urlencode($mysoc->logo)).
'",
698 "@type": "ContactPoint",
699 "contactType": "Contact",
700 "email": "'.
dol_escape_json(!empty($data[
'email']) ? $data[
'email'] : $mysoc->email).
'"
702 if (is_array($mysoc->socialnetworks) && count($mysoc->socialnetworks) > 0) {
704 $ret .=
'"sameAs": [';
706 foreach ($mysoc->socialnetworks as $key => $value) {
707 if ($key ==
'linkedin') {
708 $ret .=
'"https://www.'.$key.
'.com/company/'.
dol_escape_json($value).
'"';
709 } elseif ($key ==
'youtube') {
715 if ($i < count($mysoc->socialnetworks)) {
722 $ret .=
'</script>'.
"\n";
723 } elseif ($type ==
'blogpost') {
724 if (!empty($websitepage->author_alias)) {
729 $pageurl = $websitepage->pageurl;
730 $title = $websitepage->title;
731 $image = $websitepage->image;
732 $companyname = $mysoc->name;
733 $description = $websitepage->description;
735 $pageurl = str_replace(
'__WEBSITE_KEY__', $website->ref, $pageurl);
736 $title = str_replace(
'__WEBSITE_KEY__', $website->ref, $title);
737 $image =
'/medias'.(preg_match(
'/^\//', $image) ?
'' :
'/').str_replace(
'__WEBSITE_KEY__', $website->ref, $image);
738 $companyname = str_replace(
'__WEBSITE_KEY__', $website->ref, $companyname);
739 $description = str_replace(
'__WEBSITE_KEY__', $website->ref, $description);
741 $ret =
'<!-- Add structured data for blog post -->'.
"\n";
742 $ret .=
'<script nonce="'.getNonce().
'" type="application/ld+json">'.
"\n";
744 "@context": "https://schema.org",
745 "@type": "NewsArticle",
746 "mainEntityOfPage": {
748 "@id": "'.dol_escape_json($pageurl).
'"
754 "dateCreated": "'.
dol_print_date($websitepage->date_creation,
'dayhourrfc').
'",
755 "datePublished": "'.
dol_print_date($websitepage->date_creation,
'dayhourrfc').
'",
756 "dateModified": "'.
dol_print_date($websitepage->date_modification,
'dayhourrfc').
'",
762 "@type": "Organization",
765 "@type": "ImageObject",
766 "url": "/wrapper.php?modulepart=mycompany&file=logos%2F'.urlencode($mysoc->logo).
'"
769 if ($websitepage->keywords) {
770 $ret .=
'"keywords": [';
772 $arrayofkeywords = explode(
',', $websitepage->keywords);
773 foreach ($arrayofkeywords as $keyword) {
774 $ret .=
'"'.dol_escape_json($keyword).
'"';
776 if ($i < count($arrayofkeywords)) {
782 $ret .=
'"description": "'.dol_escape_json($description).
'"';
783 $ret .=
"\n".
'}'.
"\n";
784 $ret .=
'</script>'.
"\n";
786 $ret =
'<!-- no structured data inserted inline inside blogpost because no author_alias defined -->'.
"\n";
788 } elseif ($type ==
'product') {
789 $ret =
'<!-- Add structured data for product -->'.
"\n";
790 $ret .=
'<script nonce="'.getNonce().
'" type="application/ld+json">'.
"\n";
792 "@context": "https://schema.org/",
794 "name": "'.dol_escape_json($data[
'label']).
'",
811 "url": "https://example.com/anvil",
812 "priceCurrency": "'.
dol_escape_json($data[
'currency'] ? $data[
'currency'] : $conf->currency).
'",
814 "itemCondition": "https://schema.org/UsedCondition",
815 "availability": "https://schema.org/InStock",
817 "@type": "Organization",
822 $ret .=
'</script>'.
"\n";
823 } elseif ($type ==
'qa') {
824 $ret =
'<!-- Add structured data for QA -->'.
"\n";
825 $ret .=
'<script nonce="'.getNonce().
'" type="application/ld+json">'.
"\n";
827 "@context": "https://schema.org/",
831 "name": "'.dol_escape_json($data[
'name']).
'",
848 $ret .=
'</script>'.
"\n";
863 global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs;
867 if ($website->virtualhost) {
868 $pageurl = $websitepage->pageurl;
869 $title = $websitepage->title;
870 $image = $websitepage->image;
871 $companyname = $mysoc->name;
872 $description = $websitepage->description;
874 $pageurl = str_replace(
'__WEBSITE_KEY__', $website->ref, $pageurl);
875 $title = str_replace(
'__WEBSITE_KEY__', $website->ref, $title);
876 $image =
'/medias'.(preg_match(
'/^\//', $image) ?
'' :
'/').str_replace(
'__WEBSITE_KEY__', $website->ref, $image);
877 $companyname = str_replace(
'__WEBSITE_KEY__', $website->ref, $companyname);
878 $description = str_replace(
'__WEBSITE_KEY__', $website->ref, $description);
881 if ($websitepage->lang) {
882 $shortlangcode = substr($websitepage->lang, 0, 2);
884 if (empty($shortlangcode)) {
885 $shortlangcode = substr($website->lang, 0, 2);
888 $fullurl = $website->virtualhost.
'/'.$websitepage->pageurl.
'.php';
889 $canonicalurl = $website->virtualhost.(($websitepage->id == $website->fk_default_home) ?
'/' : (($shortlangcode != substr($website->lang, 0, 2) ?
'/'.$shortlangcode :
'').
'/'.$websitepage->pageurl.
'.php'));
890 $hashtags = trim(implode(
' #', array_map(
'trim', explode(
',', $websitepage->keywords))));
893 $out .=
'<meta name="og:type" content="website">'.
"\n";
894 $out .=
'<meta name="og:title" content="'.$websitepage->title.
'">'.
"\n";
895 if ($websitepage->image) {
896 $out .=
'<meta name="og:image" content="'.$website->virtualhost.$image.
'">'.
"\n";
898 $out .=
'<meta name="og:url" content="'.$canonicalurl.
'">'.
"\n";
901 $out .=
'<meta name="twitter:card" content="summary">'.
"\n";
902 if (!empty($params) && !empty($params[
'twitter_account'])) {
903 $out .=
'<meta name="twitter:site" content="@'.$params[
'twitter_account'].
'">'.
"\n";
904 $out .=
'<meta name="twitter:creator" content="@'.$params[
'twitter_account'].
'">'.
"\n";
906 $out .=
'<meta name="twitter:title" content="'.$websitepage->title.
'">'.
"\n";
907 if ($websitepage->description) {
908 $out .=
'<meta name="twitter:description" content="'.$websitepage->description.
'">'.
"\n";
910 if ($websitepage->image) {
911 $out .=
'<meta name="twitter:image" content="'.$website->virtualhost.$image.
'">'.
"\n";
937 global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs;
939 $out =
'<!-- section for social network sharing of page -->'.
"\n";
941 if ($website->virtualhost) {
942 $fullurl = $website->virtualhost.
'/'.$websitepage->pageurl.
'.php';
943 $hashtags = trim(implode(
' #', array_map(
'trim', explode(
',', $websitepage->keywords))));
945 $out .=
'<div class="dol-social-share">'.
"\n";
948 $out .=
'<div class="dol-social-share-tw">'.
"\n";
949 $out .=
'<a href="https://twitter.com/share" class="twitter-share-button" data-url="'.$fullurl.
'" data-text="'.
dol_escape_htmltag($websitepage->description).
'" data-lang="'.$websitepage->lang.
'" data-size="small" data-related="" data-hashtags="'.preg_replace(
'/^#/',
'', $hashtags).
'" data-count="horizontal">Tweet</a>';
950 $out .=
'<script nonce="'.getNonce().
'">!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],p=/^http:/.test(d.location)?\'http\':\'https\';if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src=p+\'://platform.twitter.com/widgets.js\';fjs.parentNode.insertBefore(js,fjs);}}(document, \'script\', \'twitter-wjs\');</script>';
951 $out .=
'</div>'.
"\n";
954 $out .=
'<div class="dol-social-share-reddit">'.
"\n";
955 $out .=
'<a href="https://www.reddit.com/submit" target="_blank" rel="noopener noreferrer external" onclick="window.location = \'https://www.reddit.com/submit?url='.$fullurl.
'\';
return false">';
956 $out .= '<span class="dol-social-share-reddit-span
">Reddit</span>';
958 $out .= '</div>'."\n
";
961 $out .= '<div class="dol-social-share-fbl
">'."\n
";
962 $out .= '<div id="fb-root
"></div>'."\n
";
963 $out .= '<script nonce="'.getNonce().'">(function(d, s, id) {
964 var js, fjs = d.getElementsByTagName(s)[0];
965 if (d.getElementById(id)) return;
966 js = d.createElement(s); js.id = id;
968 fjs.parentNode.insertBefore(js, fjs);
969 }(document, \
'script\', \'facebook-jssdk\'));</script>
972 layout="button_count"
977 action="like" ></fb:like>'.
"\n";
978 $out .=
'</div>'.
"\n";
980 $out .=
"\n</div>\n";
982 $out .=
'<!-- virtual host not defined in CMS. No way to add sharing buttons -->'.
"\n";
984 $out .=
'<!-- section end for social network sharing of page -->'.
"\n";
1003 include_once DOL_DOCUMENT_ROOT.
'/core/lib/images.lib.php';
1005 $regexforimg =
'('.$regexforimg.
')$';
1007 $sql =
"SELECT COUNT(rowid) as nb";
1008 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ecm_files";
1009 $sql .=
" WHERE entity IN (".getEntity(
$object->element).
")";
1010 $sql .=
" AND src_object_type = '".$db->escape(
$object->element).
"' AND src_object_id = ".((int)
$object->id);
1011 $sql .=
" AND ".$db->regexpsql(
'filename', $regexforimg, 1);
1012 $sql .=
" AND share IS NOT NULL";
1014 $resql = $db->query(
$sql);
1016 $obj = $db->fetch_object($resql);
1040 include_once DOL_DOCUMENT_ROOT.
'/core/lib/images.lib.php';
1042 $regexforimg =
'('.$regexforimg.
')$';
1044 $sql =
"SELECT rowid, ref, share, filename, cover, position";
1045 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ecm_files";
1046 $sql .=
" WHERE entity IN (".getEntity(
$object->element).
")";
1047 $sql .=
" AND src_object_type = '".$db->escape(
$object->element).
"' AND src_object_id = ".((int)
$object->id);
1048 $sql .=
" AND ".$db->regexpsql(
'filename', $regexforimg, 1);
1049 $sql .= $db->order(
"cover,position,rowid",
"ASC,ASC,ASC");
1051 $resql = $db->query(
$sql);
1053 $num = $db->num_rows($resql);
1056 $foundnotshared = 0;
1058 $obj = $db->fetch_object($resql);
1060 if (empty($obj->share)) {
1065 if (defined(
'USEDOLIBARRSERVER') || defined(
'USEDOLIBARREDITOR')) {
1066 $image_path = DOL_URL_ROOT.
'/viewimage.php?hashp='.urlencode($obj->share);
1068 $image_path =
'/wrapper.php?hashp='.urlencode($obj->share);
1072 $image_path .=
'&extname='.urlencode($extName);
1076 if ($found >= $no) {
1081 if (!$found && $foundnotshared) {
1082 if (defined(
'USEDOLIBARRSERVER') || defined(
'USEDOLIBARREDITOR')) {
1083 $image_path = DOL_URL_ROOT.
'/viewimage.php?modulepart=common&file=nophotopublic.png';
1085 $image_path =
'/wrapper.php?modulepart=common&file=nophotopublic.png';
1090 if (empty($image_path)) {
1091 if (defined(
'USEDOLIBARRSERVER') || defined(
'USEDOLIBARREDITOR')) {
1092 $image_path = DOL_URL_ROOT.
'/viewimage.php?modulepart=common&file=nophoto.png';
1094 $image_path =
'/wrapper.php?modulepart=common&file=nophoto.png';
1117 function getPagesFromSearchCriterias($type, $algo, $searchstring, $max = 25, $sortfield =
'date_creation', $sortorder =
'DESC', $langcode =
'', $otherfilters = [], $status = 1)
1119 global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs;
1122 $arrayresult = array(
'code' =>
'',
'list' => array());
1125 if (!is_object($weblangs)) {
1144 $tmparrayoftype = explode(
',', $type);
1158 if (!$error && (empty($max) || ($found < $max)) && (preg_match(
'/meta/', $algo) || preg_match(
'/content/', $algo))) {
1159 include_once DOL_DOCUMENT_ROOT.
'/website/class/websitepage.class.php';
1161 $sql =
'SELECT wp.rowid FROM '.MAIN_DB_PREFIX.
'website_page as wp';
1162 if (is_array($otherfilters) && !empty($otherfilters[
'category'])) {
1163 $sql .=
', '.MAIN_DB_PREFIX.
'categorie_website_page as cwp';
1165 $sql .=
" WHERE wp.fk_website = ".((int) $website->id);
1167 $sql .=
" AND wp.status = ".((int) $status);
1170 $sql .=
" AND wp.lang = '".$db->escape($langcode).
"'";
1173 $tmparrayoftype = explode(
',', $type);
1175 foreach ($tmparrayoftype as $tmptype) {
1176 $typestring .= ($typestring ?
", " :
"").
"'".$db->escape(trim($tmptype)).
"'";
1178 $sql .=
" AND wp.type_container IN (".$db->sanitize($typestring, 1).
")";
1182 if (preg_match(
'/meta/', $algo)) {
1183 $searchalgo .= ($searchalgo ?
' OR ' :
'').
"wp.title LIKE '%".$db->escape($db->escapeforlike($searchstring)).
"%' OR wp.description LIKE '%".$db->escape($db->escapeforlike($searchstring)).
"%'";
1184 $searchalgo .= ($searchalgo ?
' OR ' :
'').
"wp.keywords LIKE '".$db->escape($db->escapeforlike($searchstring)).
",%' OR wp.keywords LIKE '% ".$db->escape($db->escapeforlike($searchstring)).
"%'";
1186 if (preg_match(
'/content/', $algo)) {
1187 $searchalgo .= ($searchalgo ?
' OR ' :
'').
"wp.content LIKE '%".$db->escape($db->escapeforlike($searchstring)).
"%'";
1189 $sql .= $searchalgo;
1190 if (is_array($otherfilters) && !empty($otherfilters[
'category'])) {
1191 $sql .=
' AND cwp.fk_website_page = wp.rowid AND cwp.fk_categorie = '.((int) $otherfilters[
'category']);
1194 $sql .= $db->order($sortfield, $sortorder);
1195 $sql .= $db->plimit($max);
1198 $resql = $db->query(
$sql);
1202 while (($obj = $db->fetch_object($resql)) && ($i < $max || $max == 0)) {
1203 if ($obj->rowid > 0) {
1205 $tmpwebsitepage->fetch($obj->rowid);
1206 if ($tmpwebsitepage->id > 0) {
1207 $arrayresult[
'list'][$obj->rowid] = $tmpwebsitepage;
1215 $arrayresult[
'code'] = $db->lasterrno();
1216 $arrayresult[
'message'] = $db->lasterror();
1222 if (!$error && (empty($max) || ($found < $max)) && (preg_match(
'/sitefiles/', $algo))) {
1223 global $dolibarr_main_data_root;
1225 $pathofwebsite = $dolibarr_main_data_root.($conf->entity > 1 ?
'/'.$conf->entity :
'').
'/website/'.$website->ref;
1226 $filehtmlheader = $pathofwebsite.
'/htmlheader.html';
1227 $filecss = $pathofwebsite.
'/styles.css.php';
1228 $filejs = $pathofwebsite.
'/javascript.js.php';
1229 $filerobot = $pathofwebsite.
'/robots.txt';
1230 $filehtaccess = $pathofwebsite.
'/.htaccess';
1231 $filemanifestjson = $pathofwebsite.
'/manifest.json.php';
1232 $filereadme = $pathofwebsite.
'/README.md';
1234 $filecontent = file_get_contents($filehtmlheader);
1235 if ((empty($max) || ($found < $max)) && preg_match(
'/'.preg_quote($searchstring,
'/').
'/', $filecontent)) {
1236 $arrayresult[
'list'][] = array(
'type' =>
'website_htmlheadercontent');
1239 $filecontent = file_get_contents($filecss);
1240 if ((empty($max) || ($found < $max)) && preg_match(
'/'.preg_quote($searchstring,
'/').
'/', $filecontent)) {
1241 $arrayresult[
'list'][] = array(
'type' =>
'website_csscontent');
1244 $filecontent = file_get_contents($filejs);
1245 if ((empty($max) || ($found < $max)) && preg_match(
'/'.preg_quote($searchstring,
'/').
'/', $filecontent)) {
1246 $arrayresult[
'list'][] = array(
'type' =>
'website_jscontent');
1249 $filerobot = file_get_contents($filerobot);
1250 if ((empty($max) || ($found < $max)) && preg_match(
'/'.preg_quote($searchstring,
'/').
'/', $filecontent)) {
1251 $arrayresult[
'list'][] = array(
'type' =>
'website_robotcontent');
1259 $arrayresult[
'code'] =
'OK';
1260 if (empty($arrayresult[
'list'])) {
1261 $arrayresult[
'code'] =
'KO';
1262 $arrayresult[
'message'] = $weblangs->trans(
"NoRecordFound");
1266 $arrayresult[
'code'] =
'KO';
1267 $arrayresult[
'message'] =
'No supported algorithm found';
1271 return $arrayresult;
1288 function getAllImages(
$object, $objectpage, $urltograb, &$tmp, &$action, $modifylinks = 0, $grabimages = 1, $grabimagesinto =
'subpage')
1294 dol_syslog(
"Call getAllImages with grabimagesinto=".$grabimagesinto);
1296 $alreadygrabbed = array();
1298 if (preg_match(
'/\/$/', $urltograb)) {
1301 $urltograb = dirname($urltograb);
1305 preg_match_all(
'/<img([^\.\/]+)src="([^>"]+)"([^>]*)>/i', $tmp, $regs);
1307 foreach ($regs[0] as $key => $val) {
1308 if (preg_match(
'/^data:image/i', $regs[2][$key])) {
1312 if (preg_match(
'/^\//', $regs[2][$key])) {
1314 $urltograbbis = $urltograbdirrootwithoutslash.$regs[2][$key];
1316 $urltograbbis = $urltograb.
'/'.$regs[2][$key];
1319 $linkwithoutdomain = $regs[2][$key];
1320 $dirforimages =
'/'.$objectpage->pageurl;
1321 if ($grabimagesinto ==
'root') {
1326 $filetosave = $conf->medias->multidir_output[$conf->entity].
'/image/'.
$object->ref.$dirforimages.(preg_match(
'/^\//', $regs[2][$key]) ?
'' :
'/').$regs[2][$key];
1327 if (preg_match(
'/^http/', $regs[2][$key])) {
1328 $urltograbbis = $regs[2][$key];
1329 $linkwithoutdomain = preg_replace(
'/^https?:\/\/[^\/]+\//i',
'', $regs[2][$key]);
1330 $filetosave = $conf->medias->multidir_output[$conf->entity].
'/image/'.
$object->ref.$dirforimages.(preg_match(
'/^\//', $linkwithoutdomain) ?
'' :
'/').$linkwithoutdomain;
1332 $filename =
'image/'.$object->ref.$dirforimages.(preg_match(
'/^\//', $linkwithoutdomain) ?
'' :
'/').$linkwithoutdomain;
1335 $filetosave = preg_replace(
'/\/[^\/]+\/\.\./',
'', $filetosave);
1336 $filename = preg_replace(
'/\/[^\/]+\/\.\./',
'', $filename);
1338 if (empty($alreadygrabbed[$urltograbbis])) {
1340 $tmpgeturl =
getURLContent($urltograbbis,
'GET',
'', 1, array(), array(
'http',
'https'), 0);
1341 if ($tmpgeturl[
'curl_error_no']) {
1343 setEventMessages(
'Error getting '.$urltograbbis.
': '.$tmpgeturl[
'curl_error_msg'],
null,
'errors');
1345 } elseif ($tmpgeturl[
'http_code'] !=
'200') {
1347 setEventMessages(
'Error getting '.$urltograbbis.
': '.$tmpgeturl[
'http_code'],
null,
'errors');
1350 $alreadygrabbed[$urltograbbis] = 1;
1354 $fp = fopen($filetosave,
"w");
1355 fwrite($fp, $tmpgeturl[
'content']);
1363 $tmp = preg_replace(
'/'.preg_quote($regs[0][$key],
'/').
'/i',
'<img'.$regs[1][$key].
'src="'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file='.$filename.
'"'.$regs[3][$key].
'>', $tmp);
1368 preg_match_all(
'/background([^\.\/\(;]+)url\([\"\']?([^\)\"\']*)[\"\']?\)/i', $tmp, $regs);
1370 foreach ($regs[0] as $key => $val) {
1371 if (preg_match(
'/^data:image/i', $regs[2][$key])) {
1375 if (preg_match(
'/^\//', $regs[2][$key])) {
1377 $urltograbbis = $urltograbdirrootwithoutslash.$regs[2][$key];
1379 $urltograbbis = $urltograb.
'/'.$regs[2][$key];
1382 $linkwithoutdomain = $regs[2][$key];
1384 $dirforimages =
'/'.$objectpage->pageurl;
1385 if ($grabimagesinto ==
'root') {
1389 $filetosave = $conf->medias->multidir_output[$conf->entity].
'/image/'.
$object->ref.$dirforimages.(preg_match(
'/^\//', $regs[2][$key]) ?
'' :
'/').$regs[2][$key];
1391 if (preg_match(
'/^http/', $regs[2][$key])) {
1392 $urltograbbis = $regs[2][$key];
1393 $linkwithoutdomain = preg_replace(
'/^https?:\/\/[^\/]+\//i',
'', $regs[2][$key]);
1394 $filetosave = $conf->medias->multidir_output[$conf->entity].
'/image/'.
$object->ref.$dirforimages.(preg_match(
'/^\//', $linkwithoutdomain) ?
'' :
'/').$linkwithoutdomain;
1397 $filename =
'image/'.$object->ref.$dirforimages.(preg_match(
'/^\//', $linkwithoutdomain) ?
'' :
'/').$linkwithoutdomain;
1400 $filetosave = preg_replace(
'/\/[^\/]+\/\.\./',
'', $filetosave);
1401 $filename = preg_replace(
'/\/[^\/]+\/\.\./',
'', $filename);
1403 if (empty($alreadygrabbed[$urltograbbis])) {
1405 $tmpgeturl =
getURLContent($urltograbbis,
'GET',
'', 1, array(), array(
'http',
'https'), 0);
1406 if ($tmpgeturl[
'curl_error_no']) {
1408 setEventMessages(
'Error getting '.$urltograbbis.
': '.$tmpgeturl[
'curl_error_msg'],
null,
'errors');
1410 } elseif ($tmpgeturl[
'http_code'] !=
'200') {
1412 setEventMessages(
'Error getting '.$urltograbbis.
': '.$tmpgeturl[
'http_code'],
null,
'errors');
1415 $alreadygrabbed[$urltograbbis] = 1;
1419 $fp = fopen($filetosave,
"w");
1420 fwrite($fp, $tmpgeturl[
'content']);
1428 $tmp = preg_replace(
'/'.preg_quote($regs[0][$key],
'/').
'/i',
'background'.$regs[1][$key].
'url("'.DOL_URL_ROOT.
'/viewimage.php?modulepart=medias&file='.$filename.
'")', $tmp);
if($user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
if(isModEnabled('invoice') && $user->hasRight('facture', 'lire')) if((isModEnabled('fournisseur') &&!getDolGlobalString('MAIN_USE_NEW_SUPPLIERMOD') && $user->hasRight("fournisseur", "facture", "lire"))||(isModEnabled('supplier_invoice') && $user->hasRight("supplier_invoice", "lire"))) if(isModEnabled('don') && $user->hasRight('don', 'lire')) if(isModEnabled('tax') && $user->hasRight('tax', 'charges', 'lire')) if(isModEnabled('invoice') &&isModEnabled('order') && $user->hasRight("commande", "lire") &&!getDolGlobalString('WORKFLOW_DISABLE_CREATE_INVOICE_FROM_ORDER')) $sql
Social contributions to pay.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
dol_string_nohtmltag($stringtoclean, $removelinefeed=1, $pagecodeto='UTF-8', $strip_tags=0, $removedoublespaces=1)
Clean a string from all HTML tags and entities.
dolChmod($filepath, $newmask='')
Change mod of a file.
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0)
Set event messages in dol_events session object.
dol_escape_json($stringtoescape)
Returns text escaped for inclusion into javascript code.
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
getRootURLFromURL($url)
Function root url from a long url For example: https://www.abc.mydomain.com/dir/page....
getURLContent($url, $postorget='GET', $param='', $followlocation=1, $addheaders=array(), $allowedschemes=array('http', 'https'), $localurl=0, $ssl_verifypeer=-1)
Function to get a content from an URL (use proxy if proxy defined).
getListOfPossibleImageExt($acceptsvg=0)
Return if a filename is file name of a supported image format.
if(!defined( 'CSRFCHECK_WITH_TOKEN'))
getAllImages($object, $objectpage, $urltograb, &$tmp, &$action, $modifylinks=0, $grabimages=1, $grabimagesinto='subpage')
Download all images found into page content $tmp.
getImagePublicURLOfObject($object, $no=1, $extName='')
Return HTML content to add structured data for an article, news or Blog Post.
redirectToContainer($containerref, $containeraliasalt='', $containerid=0, $permanent=0, $parameters=array())
Format img tags to introduce viewimage on img src.
dolStripPhpCode($str, $replacewith='')
Remove PHP code part from a string.
getNbOfImagePublicURLOfObject($object)
Return HTML content to add structured data for an article, news or Blog Post.
getStructuredData($type, $data=array())
Return HTML content to add structured data for an article, news or Blog Post.
dolWebsiteReplacementOfLinks($website, $content, $removephppart=0, $contenttype='html', $containerid=0)
Convert a page content to have correct links (based on DOL_URL_ROOT) into an html content.
getPagesFromSearchCriterias($type, $algo, $searchstring, $max=25, $sortfield='date_creation', $sortorder='DESC', $langcode='', $otherfilters=[], $status=1)
Return list of containers object that match a criteria.
dolWebsiteIncrementCounter($websiteid, $websitepagetype, $websitepageid)
Increase the website counter of page access.
dolReplaceSmileyCodeWithUTF8($content)
Converts smiley string into the utf8 sequence.
includeContainer($containerref)
Clean an HTML page to report only content, so we can include it into another page.
dolKeepOnlyPhpCode($str)
Keep only PHP code part from a HTML string page.
getSocialNetworkSharingLinks()
Return HTML content to add structured data for an article, news or Blog Post.
dolWebsiteOutput($content, $contenttype='html', $containerid=0)
Render a string of an HTML content and output it.
getSocialNetworkHeaderCards($params=null)
Return HTML content to add as header card for an article, news or Blog Post or home page.