forked from Wavyzz/dolibarr
855 lines
33 KiB
PHP
855 lines
33 KiB
PHP
<?php
|
|
/* Copyright (C) 2017 Laurent Destailleur <eldy@users.sourceforge.net>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/**
|
|
* \file htdocs/core/lib/website.lib.php
|
|
* \ingroup website
|
|
* \brief Library for website module
|
|
*/
|
|
|
|
|
|
/**
|
|
* Convert a page content to have correct links (based on DOL_URL_ROOT) into an html content.
|
|
* Used to ouput the page on the Preview from backoffice.
|
|
*
|
|
* @param Website $website Web site object
|
|
* @param string $content Content to replace
|
|
* @param int $removephppart 0=Replace PHP sections with a PHP badge. 1=Remove completely PHP sections.
|
|
* @return boolean True if OK
|
|
* @see dolWebsiteOutput() for function used to replace content in a web server context
|
|
*/
|
|
function dolWebsiteReplacementOfLinks($website, $content, $removephppart = 0)
|
|
{
|
|
$nbrep = 0;
|
|
|
|
dol_syslog('dolWebsiteReplacementOfLinks start', LOG_DEBUG);
|
|
|
|
// Replace php code. Note $content may come from database and does not contains body tags.
|
|
$replacewith='...php...';
|
|
if ($removephppart) $replacewith='';
|
|
$content = preg_replace('/value="<\?php((?!\?>).)*\?>\n*/ims', 'value="'.$replacewith.'"', $content);
|
|
|
|
$replacewith='"callto=#';
|
|
if ($removephppart) $replacewith='';
|
|
$content = preg_replace('/"callto:<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
|
|
|
|
$replacewith='"mailto=#';
|
|
if ($removephppart) $replacewith='';
|
|
$content = preg_replace('/"mailto:<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
|
|
|
|
$replacewith='src="php';
|
|
if ($removephppart) $replacewith='';
|
|
$content = preg_replace('/src="<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
|
|
|
|
$replacewith='href="php';
|
|
if ($removephppart) $replacewith='';
|
|
$content = preg_replace('/href="<\?php((?!\?>).)*\?>\n*/ims', $replacewith, $content);
|
|
|
|
//$replacewith='<span class="phptag">...php...</span>';
|
|
$replacewith='<span class="phptag">...php...</span>';
|
|
if ($removephppart) $replacewith='';
|
|
//$content = preg_replace('/<\?php((?!\?toremove>).)*\?toremove>\n*/ims', $replacewith, $content);
|
|
/*if ($content === null) {
|
|
if (preg_last_error() == PREG_JIT_STACKLIMIT_ERROR) $content = 'preg_replace error (when removing php tags) PREG_JIT_STACKLIMIT_ERROR';
|
|
}*/
|
|
$content = dolStripPhpCode($content, $replacewith);
|
|
//var_dump($content);
|
|
|
|
// Replace relative link / with dolibarr URL
|
|
$content = preg_replace('/(href=")\/\"/', '\1'.DOL_URL_ROOT.'/website/index.php?website='.$website->ref.'&pageid='.$website->fk_default_home.'"', $content, -1, $nbrep);
|
|
// Replace relative link /xxx.php with dolibarr URL
|
|
$content = preg_replace('/(href=")\/?([^:\"]*)(\.php\")/', '\1'.DOL_URL_ROOT.'/website/index.php?website='.$website->ref.'&pageref=\2"', $content, -1, $nbrep);
|
|
|
|
// Fix relative link into medias with correct URL after the DOL_URL_ROOT: ../url("medias/
|
|
$content = preg_replace('/url\((["\']?)medias\//', 'url(\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
$content = preg_replace('/data-slide-bg=(["\']?)medias\//', 'data-slide-bg=\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
|
|
// <img src="medias/image.png... => <img src="dolibarr/viewimage.php/modulepart=medias&file=image.png...
|
|
$content = preg_replace('/(<img[^>]*src=")(medias\/)/', '\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
// <img src="image.png... => <img src="dolibarr/viewimage.php/modulepart=medias&file=image.png...
|
|
$content = preg_replace('/(<img[^>]*src=")(?!(http|\/?viewimage|'.preg_quote(DOL_URL_ROOT, '/').'\/viewimage))/', '\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
// <img src="viewimage.php/modulepart=medias&file=image.png" => <img src="dolibarr/viewimage.php/modulepart=medias&file=image.png"
|
|
$content = preg_replace('/(<img[^>]*src=")(\/?viewimage\.php)/', '\1'.DOL_URL_ROOT.'/viewimage.php', $content, -1, $nbrep);
|
|
|
|
// action="newpage.php" => action="dolibarr/website/index.php?website=...&pageref=newpage
|
|
$content = preg_replace('/(action=")\/?([^:\"]*)(\.php\")/', '\1'.DOL_URL_ROOT.'/website/index.php?website='.$website->ref.'&pageref=\2"', $content, -1, $nbrep);
|
|
|
|
// Fix relative link /document.php with correct URL after the DOL_URL_ROOT: ...href="/document.php?modulepart="
|
|
$content=preg_replace('/(href=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/', '\1'.DOL_URL_ROOT.'\2\3', $content, -1, $nbrep);
|
|
$content=preg_replace('/(src=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/', '\1'.DOL_URL_ROOT.'\2\3', $content, -1, $nbrep);
|
|
|
|
dol_syslog('dolWebsiteReplacementOfLinks end', LOG_DEBUG);
|
|
|
|
return $content;
|
|
}
|
|
|
|
|
|
/**
|
|
* Remove PHP code part from a string.
|
|
*
|
|
* @param string $str String to clean
|
|
* @param string $replacewith String to use as replacement
|
|
* @return string Result string without php code
|
|
* @see dolKeepOnlyPhpCode()
|
|
*/
|
|
function dolStripPhpCode($str, $replacewith = '')
|
|
{
|
|
$newstr = '';
|
|
|
|
//split on each opening tag
|
|
$parts = explode('<?php', $str);
|
|
if (!empty($parts))
|
|
{
|
|
$i=0;
|
|
foreach($parts as $part)
|
|
{
|
|
if ($i == 0) // The first part is never php code
|
|
{
|
|
$i++;
|
|
$newstr .= $part;
|
|
continue;
|
|
}
|
|
//split on closing tag
|
|
$partlings = explode('?>', $part);
|
|
if (!empty($partlings))
|
|
{
|
|
//remove content before closing tag
|
|
if (count($partlings) > 1) $partlings[0] = '';
|
|
//append to out string
|
|
$newstr .= $replacewith.implode('', $partlings);
|
|
}
|
|
}
|
|
}
|
|
return $newstr;
|
|
}
|
|
|
|
/**
|
|
* Keep only PHP code part from a HTML string page.
|
|
*
|
|
* @param string $str String to clean
|
|
* @return string Result string with php code only
|
|
* @see dolStripPhpCode()
|
|
*/
|
|
function dolKeepOnlyPhpCode($str)
|
|
{
|
|
$newstr = '';
|
|
|
|
//split on each opening tag
|
|
$parts = explode('<?php', $str);
|
|
if (!empty($parts))
|
|
{
|
|
$i=0;
|
|
foreach($parts as $part)
|
|
{
|
|
if ($i == 0) // The first part is never php code
|
|
{
|
|
$i++;
|
|
continue;
|
|
}
|
|
$newstr.='<?php';
|
|
//split on closing tag
|
|
$partlings = explode('?>', $part, 2);
|
|
if (!empty($partlings))
|
|
{
|
|
$newstr .= $partlings[0].'?>';
|
|
}
|
|
else
|
|
{
|
|
$newstr .= $part.'?>';
|
|
}
|
|
}
|
|
}
|
|
return $newstr;
|
|
}
|
|
|
|
/**
|
|
* Render a string of an HTML content and output it.
|
|
* Used to ouput the page when viewed from server (Dolibarr or Apache).
|
|
*
|
|
* @param string $content Content string
|
|
* @param string $contenttype Content type
|
|
* @return void
|
|
* @see dolWebsiteReplacementOfLinks() for function used to replace content in the backoffice context when USEDOLIBARREDITOR is not on
|
|
*/
|
|
function dolWebsiteOutput($content, $contenttype='html')
|
|
{
|
|
global $db, $langs, $conf, $user;
|
|
global $dolibarr_main_url_root, $dolibarr_main_data_root;
|
|
|
|
dol_syslog("dolWebsiteOutput start (contenttype=".$contenttype." USEDOLIBARRSERVER=".(defined('USEDOLIBARRSERVER')?'1':'')." USEDOLIBARREDITOR=".(defined('USEDOLIBARREDITOR')?'1':'').')');
|
|
|
|
// Define $urlwithroot
|
|
$urlwithouturlroot=preg_replace('/'.preg_quote(DOL_URL_ROOT, '/').'$/i', '', trim($dolibarr_main_url_root));
|
|
$urlwithroot=$urlwithouturlroot.DOL_URL_ROOT; // This is to use external domain name found into config file
|
|
//$urlwithroot=DOL_MAIN_URL_ROOT; // This is to use same domain name than current
|
|
|
|
if (defined('USEDOLIBARREDITOR')) // REPLACEMENT OF LINKS When page called from Dolibarr editor
|
|
{
|
|
// We remove the <head> part of content
|
|
if ($contenttype == 'html')
|
|
{
|
|
$content = preg_replace('/<head>.*<\/head>/ims', '', $content);
|
|
$content = preg_replace('/^.*<body(\s[^>]*)*>/ims', '', $content);
|
|
$content = preg_replace('/<\/body(\s[^>]*)*>.*$/ims', '', $content);
|
|
}
|
|
}
|
|
elseif (defined('USEDOLIBARRSERVER')) // REPLACEMENT OF LINKS When page called from Dolibarr server
|
|
{
|
|
global $website;
|
|
|
|
// Replace relative link / with dolibarr URL: ...href="/"...
|
|
$content=preg_replace('/(href=")\/\"/', '\1'.DOL_URL_ROOT.'/public/website/index.php?website='.$website->ref.'"', $content, -1, $nbrep);
|
|
// Replace relative link /xxx.php with dolibarr URL: ...href="....php"
|
|
$content=preg_replace('/(href=")\/?([^:\"]*)(\.php\")/', '\1'.DOL_URL_ROOT.'/public/website/index.php?website='.$website->ref.'&pageref=\2"', $content, -1, $nbrep);
|
|
// Replace relative link /xxx with dolibarr URL: ...href="....php"
|
|
$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);
|
|
$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);
|
|
|
|
// Fix relative link /document.php with correct URL after the DOL_URL_ROOT: href="/document.php?modulepart=" => href="/dolibarr/document.php?modulepart="
|
|
$content=preg_replace('/(href=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/', '\1'.DOL_URL_ROOT.'\2\3', $content, -1, $nbrep);
|
|
$content=preg_replace('/(src=")(\/?document\.php\?[^\"]*modulepart=[^\"]*)(\")/', '\1'.DOL_URL_ROOT.'\2\3', $content, -1, $nbrep);
|
|
|
|
// Fix relative link /viewimage.php with correct URL after the DOL_URL_ROOT: href="/viewimage.php?modulepart=" => href="/dolibarr/viewimage.php?modulepart="
|
|
$content=preg_replace('/(href=")(\/?viewimage\.php\?[^\"]*modulepart=[^\"]*)(\")/', '\1'.DOL_URL_ROOT.'\2\3', $content, -1, $nbrep);
|
|
$content=preg_replace('/(src=")(\/?viewimage\.php\?[^\"]*modulepart=[^\"]*)(\")/', '\1'.DOL_URL_ROOT.'\2\3', $content, -1, $nbrep);
|
|
|
|
// Fix relative link into medias with correct URL after the DOL_URL_ROOT: ../url("medias/
|
|
$content=preg_replace('/url\((["\']?)medias\//', 'url(\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
$content=preg_replace('/data-slide-bg=(["\']?)medias\//', 'data-slide-bg=\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
|
|
// <img src="medias/image.png... => <img src="dolibarr/viewimage.php/modulepart=medias&file=image.png...
|
|
$content = preg_replace('/(<img[^>]*src=")(medias\/)/', '\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
// <img src="image.png... => <img src="dolibarr/viewimage.php/modulepart=medias&file=image.png...
|
|
$content = preg_replace('/(<img[^>]*src=")(?!(http|\/?viewimage|'.preg_quote(DOL_URL_ROOT, '/').'\/viewimage))/', '\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
// <img src="viewimage.php/modulepart=medias&file=image.png" => <img src="dolibarr/viewimage.php/modulepart=medias&file=image.png"
|
|
$content = preg_replace('/(<img[^>]*src=")(\/?viewimage\.php)/', '\1'.DOL_URL_ROOT.'/viewimage.php', $content, -1, $nbrep);
|
|
|
|
// action="newpage.php" => action="dolibarr/website/index.php?website=...&pageref=newpage
|
|
$content = preg_replace('/(action=")\/?([^:\"]*)(\.php\")/', '\1'.DOL_URL_ROOT.'/public/website/index.php?website='.$website->ref.'&pageref=\2"', $content, -1, $nbrep);
|
|
}
|
|
else // REPLACEMENT OF LINKS When page called from virtual host
|
|
{
|
|
$symlinktomediaexists=1;
|
|
|
|
// Make a change into HTML code to allow to include images from medias directory correct with direct link for virtual server
|
|
// <img alt="" src="/dolibarr_dev/htdocs/viewimage.php?modulepart=medias&entity=1&file=image/ldestailleur_166x166.jpg" style="height:166px; width:166px" />
|
|
// become
|
|
// <img alt="" src="'.$urlwithroot.'/medias/image/ldestailleur_166x166.jpg" style="height:166px; width:166px" />
|
|
$nbrep=0;
|
|
if (! $symlinktomediaexists)
|
|
{
|
|
$content=preg_replace('/(<script[^>]*src=")[^\"]*document\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/', '\wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
|
|
|
|
$content=preg_replace('/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
|
|
$content=preg_replace('/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
|
|
$content=preg_replace('/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)modulepart=medias([^\)]*)file=([^\)]*)(["\']?\))/', '\1/wrapper.php\2modulepart=medias\3file=\4\5', $content, -1, $nbrep);
|
|
|
|
$content=preg_replace('/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
|
|
$content=preg_replace('/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
|
|
$content=preg_replace('/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)hashp=([^\)]*)(["\']?\))/', '\1/wrapper.php\2hashp\3\4', $content, -1, $nbrep);
|
|
|
|
$content=preg_replace('/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=mycompany([^\"]*)file=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2modulepart=mycompany\3file=\4\5', $content, -1, $nbrep);
|
|
}
|
|
else
|
|
{
|
|
$content=preg_replace('/(<script[^>]*src=")[^\"]*document\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/', '\1medias/\4\5', $content, -1, $nbrep);
|
|
|
|
$content=preg_replace('/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/', '\1medias/\4\5', $content, -1, $nbrep);
|
|
$content=preg_replace('/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=medias([^\"]*)file=([^\"]*)("[^>]*>)/', '\1medias/\4\5', $content, -1, $nbrep);
|
|
$content=preg_replace('/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)modulepart=medias([^\)]*)file=([^\)]*)(["\']?\))/', '\1medias/\4\5', $content, -1, $nbrep);
|
|
|
|
$content=preg_replace('/(<a[^>]*href=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
|
|
$content=preg_replace('/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)hashp=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
|
|
$content=preg_replace('/(url\(["\']?)[^\)]*viewimage\.php([^\)]*)hashp=([^\)]*)(["\']?\))/', '\1/wrapper.php\2hashp=\3\4', $content, -1, $nbrep);
|
|
|
|
$content=preg_replace('/(<img[^>]*src=")[^\"]*viewimage\.php([^\"]*)modulepart=mycompany([^\"]*)file=([^\"]*)("[^>]*>)/', '\1/wrapper.php\2modulepart=mycompany\3file=\4\5', $content, -1, $nbrep);
|
|
}
|
|
}
|
|
|
|
$content=preg_replace('/ contenteditable="true"/', ' contenteditable="false"', $content, -1, $nbrep);
|
|
|
|
dol_syslog("dolWebsiteOutput end");
|
|
|
|
print $content;
|
|
}
|
|
|
|
|
|
/**
|
|
* Format img tags to introduce viewimage on img src.
|
|
*
|
|
* @param string $content Content string
|
|
* @return void
|
|
* @see dolWebsiteOutput
|
|
*/
|
|
/*
|
|
function dolWebsiteSaveContent($content)
|
|
{
|
|
global $db, $langs, $conf, $user;
|
|
global $dolibarr_main_url_root, $dolibarr_main_data_root;
|
|
|
|
//dol_syslog("dolWebsiteSaveContent start (mode=".(defined('USEDOLIBARRSERVER')?'USEDOLIBARRSERVER':'').')');
|
|
|
|
// Define $urlwithroot
|
|
$urlwithouturlroot=preg_replace('/'.preg_quote(DOL_URL_ROOT,'/').'$/i','',trim($dolibarr_main_url_root));
|
|
$urlwithroot=$urlwithouturlroot.DOL_URL_ROOT; // This is to use external domain name found into config file
|
|
//$urlwithroot=DOL_MAIN_URL_ROOT; // This is to use same domain name than current
|
|
|
|
//$content = preg_replace('/(<img.*src=")(?!(http|'.preg_quote(DOL_URL_ROOT,'/').'\/viewimage))/', '\1'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file=', $content, -1, $nbrep);
|
|
|
|
return $content;
|
|
}
|
|
*/
|
|
|
|
|
|
/**
|
|
* Make a redirect to another container.
|
|
*
|
|
* @param string $containerref Ref of container to redirect to (must be a page from website root. Example: 'mypage.php' means 'mywebsite/mypage.php').
|
|
* @param string $containeraliasalt Ref of alternative aliases to redirect to.
|
|
* @param int $containerid Id of container.
|
|
* @return void
|
|
*/
|
|
function redirectToContainer($containerref, $containeraliasalt = '', $containerid = 0)
|
|
{
|
|
global $db, $website;
|
|
|
|
$newurl = '';
|
|
$result=0;
|
|
|
|
// We make redirect using the alternative alias, we must find the real $containerref
|
|
if ($containeraliasalt)
|
|
{
|
|
include_once DOL_DOCUMENT_ROOT.'/website/class/websitepage.class.php';
|
|
$tmpwebsitepage=new WebsitePage($db);
|
|
$result = $tmpwebsitepage->fetch(0, $website->id, '', $containeraliasalt);
|
|
if ($result > 0)
|
|
{
|
|
$containerref = $tmpwebsitepage->pageurl;
|
|
}
|
|
else
|
|
{
|
|
print "Error, page contains a redirect to the alternative alias '".$containeraliasalt."' that does not exists in web site (".$website->id." / ".$website->ref.")";
|
|
exit;
|
|
}
|
|
}
|
|
|
|
if (defined('USEDOLIBARREDITOR'))
|
|
{
|
|
print '<div class="margintoponly marginleftonly">';
|
|
print "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.";
|
|
print '</div>';
|
|
return;
|
|
}
|
|
|
|
if (defined('USEDOLIBARRSERVER')) // When page called from Dolibarr server
|
|
{
|
|
// Check new container exists
|
|
if (! $containeraliasalt) // If containeraliasalt set, we already did the test
|
|
{
|
|
include_once DOL_DOCUMENT_ROOT.'/website/class/websitepage.class.php';
|
|
$tmpwebsitepage=new WebsitePage($db);
|
|
$result = $tmpwebsitepage->fetch(0, $website->id, $containerref);
|
|
unset($tmpwebsitepage);
|
|
}
|
|
if ($result > 0)
|
|
{
|
|
$currenturi = $_SERVER["REQUEST_URI"];
|
|
if (preg_match('/&pageref=([^&]+)/', $currenturi, $regtmp))
|
|
{
|
|
if ($regtmp[0] == $containerref)
|
|
{
|
|
print "Error, page with uri '.$currenturi.' try a redirect to the same alias page '".$containerref."' in web site '".$website->ref."'";
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
$newurl = preg_replace('/&pageref=([^&]+)/', '&pageref='.$containerref, $currenturi);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$newurl = $currenturi.'&pageref='.urlencode($containerref);
|
|
}
|
|
}
|
|
}
|
|
else // When page called from virtual host server
|
|
{
|
|
$newurl = '/'.$containerref.'.php';
|
|
}
|
|
|
|
if ($newurl)
|
|
{
|
|
header("Location: ".$newurl);
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
print "Error, page contains a redirect to the alias page '".$containerref."' that does not exists in web site (".$website->id." / ".$website->ref.")";
|
|
exit;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Clean an HTML page to report only content, so we can include it into another page.
|
|
* It outputs content of file sanitized from html and body part.
|
|
*
|
|
* @param string $containerref Path to file to include (must be a page from website root. Example: 'mypage.php' means 'mywebsite/mypage.php')
|
|
* @return void
|
|
*/
|
|
function includeContainer($containerref)
|
|
{
|
|
global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs; // Very important. Required to have var available when running included containers.
|
|
global $includehtmlcontentopened;
|
|
global $websitekey, $websitepagefile;
|
|
|
|
$MAXLEVEL=20;
|
|
|
|
if (! preg_match('/\.php$/i', $containerref)) $containerref.='.php';
|
|
|
|
$fullpathfile=DOL_DATA_ROOT.'/website/'.$websitekey.'/'.$containerref;
|
|
|
|
if (empty($includehtmlcontentopened)) $includehtmlcontentopened=0;
|
|
$includehtmlcontentopened++;
|
|
if ($includehtmlcontentopened > $MAXLEVEL)
|
|
{
|
|
print 'ERROR: RECURSIVE CONTENT LEVEL. Depth of recursive call is more than the limit of '.$MAXLEVEL.".\n";
|
|
return;
|
|
}
|
|
// file_get_contents is not possible. We must execute code with include
|
|
//$content = file_get_contents($fullpathfile);
|
|
//print preg_replace(array('/^.*<body[^>]*>/ims','/<\/body>.*$/ims'), array('', ''), $content);*/
|
|
|
|
ob_start();
|
|
$res = include $fullpathfile; // Include because we want to execute code content
|
|
$tmpoutput = ob_get_contents();
|
|
ob_end_clean();
|
|
|
|
print "\n".'<!-- include '.$fullpathfile.' level = '.$includehtmlcontentopened.' -->'."\n";
|
|
print preg_replace(array('/^.*<body[^>]*>/ims','/<\/body>.*$/ims'), array('', ''), $tmpoutput);
|
|
|
|
if (! $res)
|
|
{
|
|
print 'ERROR: FAILED TO INCLUDE PAGE '.$containerref.".\n";
|
|
}
|
|
|
|
$includehtmlcontentopened--;
|
|
}
|
|
|
|
/**
|
|
* Return HTML content to add structured data for an article, news or Blog Post.
|
|
*
|
|
* @param string $type 'blogpost', 'product', 'software'...
|
|
* @param array $data Array of data parameters for structured data
|
|
* @return string HTML content
|
|
*/
|
|
function getStructuredData($type, $data = array())
|
|
{
|
|
global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs; // Very important. Required to have var available when running inluded containers.
|
|
|
|
if ($type == 'software')
|
|
{
|
|
$ret = '<!-- Add structured data for blog post -->'."\n";
|
|
$ret .= '<script type="application/ld+json">'."\n";
|
|
$ret .= '{
|
|
"@context": "https://schema.org",
|
|
"@type": "SoftwareApplication",
|
|
"name": "'.$data['name'].'",
|
|
"operatingSystem": "'.$data['os'].'",
|
|
"applicationCategory": "https://schema.org/GameApplication",
|
|
"aggregateRating": {
|
|
"@type": "AggregateRating",
|
|
"ratingValue": "'.$data['ratingvalue'].'",
|
|
"ratingCount": "'.$data['ratingcount'].'"
|
|
},
|
|
"offers": {
|
|
"@type": "Offer",
|
|
"price": "'.$data['price'].'",
|
|
"priceCurrency": "'.($data['currency']?$data['currency']:$conf->currency).'"
|
|
}
|
|
}'."\n";
|
|
$ret .= '</script>'."\n";
|
|
}
|
|
elseif ($type == 'blogpost')
|
|
{
|
|
if ($websitepage->fk_user_creat > 0)
|
|
{
|
|
include_once DOL_DOCUMENT_ROOT.'/user/class/user.class.php';
|
|
$tmpuser = new User($db);
|
|
$restmpuser = $tmpuser->fetch($websitepage->fk_user_creat);
|
|
|
|
if ($restmpuser > 0)
|
|
{
|
|
$ret = '<!-- Add structured data for blog post -->'."\n";
|
|
$ret .= '<script type="application/ld+json">'."\n";
|
|
$ret .= '{
|
|
"@context": "https://schema.org",
|
|
"@type": "NewsArticle",
|
|
"mainEntityOfPage": {
|
|
"@type": "WebPage",
|
|
"@id": "'.$websitepage->pageurl.'"
|
|
},
|
|
"headline": "'.$websitepage->title.'",
|
|
"image": [
|
|
"'.$websitepage->image.'"
|
|
],
|
|
"datePublished": "'.dol_print_date($websitepage->date_creation, 'dayhourrfc').'",
|
|
"dateModified": "'.dol_print_date($websitepage->date_modification, 'dayhourrfc').'",
|
|
"author": {
|
|
"@type": "Person",
|
|
"name": "'.$tmpuser->getFullName($weblangs).'"
|
|
},
|
|
"publisher": {
|
|
"@type": "Organization",
|
|
"name": "'.$mysoc->name.'",
|
|
"logo": {
|
|
"@type": "ImageObject",
|
|
"url": "/viewimage.php?modulepart=mycompany&file=logos%2F'.urlencode($mysoc->logo).'"
|
|
}
|
|
},
|
|
"description": "'.$websitepage->description.'"
|
|
}'."\n";
|
|
$ret .= '</script>'."\n";
|
|
}
|
|
}
|
|
}
|
|
elseif ($type == 'product')
|
|
{
|
|
$ret = '<!-- Add structured data for blog post -->'."\n";
|
|
$ret.= '<script type="application/ld+json">'."\n";
|
|
$ret.= '{
|
|
"@context": "https://schema.org/",
|
|
"@type": "Product",
|
|
"name": "'.$data['label'].'",
|
|
"image": [
|
|
"'.$data['image'].'",
|
|
],
|
|
"description": "'.$data['description'].'",
|
|
"sku": "'.$data['ref'].'",
|
|
"brand": {
|
|
"@type": "Thing",
|
|
"name": "'.$data['brand'].'"
|
|
},
|
|
"author": {
|
|
"@type": "Person",
|
|
"name": "'.$data['author'].'"
|
|
}
|
|
},
|
|
"offers": {
|
|
"@type": "Offer",
|
|
"url": "https://example.com/anvil",
|
|
"priceCurrency": "'.($data['currency']?$data['currency']:$conf->currency).'",
|
|
"price": "'.$data['price'].'",
|
|
"itemCondition": "https://schema.org/UsedCondition",
|
|
"availability": "https://schema.org/InStock",
|
|
"seller": {
|
|
"@type": "Organization",
|
|
"name": "'.$mysoc->name.'"
|
|
}
|
|
}
|
|
}'."\n";
|
|
$ret.= '</script>'."\n";
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* Return list of containers object that match a criteria
|
|
*
|
|
* @param string $type Type of container to search into (Example: 'page')
|
|
* @param string $algo Algorithm used for search (Example: 'meta' is searching into meta information like title and description, 'metacontent')
|
|
* @param string $searchstring Search string
|
|
* @param int $max Max number of answers
|
|
* @return string HTML content
|
|
*/
|
|
function getPagesFromSearchCriterias($type, $algo, $searchstring, $max = 25)
|
|
{
|
|
global $conf, $db, $hookmanager, $langs, $mysoc, $user, $website, $websitepage, $weblangs; // Very important. Required to have var available when running inluded containers.
|
|
|
|
$error = 0;
|
|
$arrayresult = array('code'=>'', 'list'=>array());
|
|
|
|
if (! is_object($weblangs)) $weblangs = $langs;
|
|
|
|
if (empty($searchstring))
|
|
{
|
|
$error++;
|
|
$arrayresult['code']='KO';
|
|
$arrayresult['message']=$weblangs->trans("EmptySearchString");
|
|
}
|
|
elseif (dol_strlen($searchstring) < 2)
|
|
{
|
|
$weblangs->load("errors");
|
|
$error++;
|
|
$arrayresult['code']='KO';
|
|
$arrayresult['message']=$weblangs->trans("ErrorSearchCriteriaTooSmall");
|
|
}
|
|
elseif (! in_array($type, array('', 'page')))
|
|
{
|
|
$error++;
|
|
$arrayresult['code']='KO';
|
|
$arrayresult['message']='Bad value for parameter $type';
|
|
}
|
|
|
|
$searchdone = 0;
|
|
|
|
if (! $error && in_array($algo, array('meta', 'metacontent', 'content')))
|
|
{
|
|
$sql = 'SELECT rowid FROM '.MAIN_DB_PREFIX.'website_page';
|
|
$sql.= " WHERE fk_website = ".$website->id;
|
|
if ($type) $sql.= " AND type_container = '".$db->escape($type)."'";
|
|
$sql.= " AND (";
|
|
$searchalgo = '';
|
|
if ($algo == 'meta' || $algo == 'metacontent')
|
|
{
|
|
$searchalgo.= ($searchalgo?' OR ':'')."title LIKE '%".$db->escape($searchstring)."%' OR description LIKE '%".$db->escape($searchstring)."%'";
|
|
$searchalgo.= ($searchalgo?' OR ':'')."keywords LIKE '".$db->escape($searchstring).",%' OR keywords LIKE '% ".$db->escape($searchstring)."%'"; // TODO Use a better way to scan keywords
|
|
}
|
|
if ($algo == 'metacontent' || $algo == 'content')
|
|
{
|
|
$searchalgo.= ($searchalgo?' OR ':'')."content LIKE '%".$db->escape($searchstring)."%'";
|
|
}
|
|
$sql.=$searchalgo;
|
|
$sql.= ")";
|
|
$sql.= $db->plimit($max);
|
|
|
|
$resql = $db->query($sql);
|
|
if ($resql)
|
|
{
|
|
$i = 0;
|
|
while (($obj = $db->fetch_object($resql)) && ($i < $max || $max == 0))
|
|
{
|
|
if ($obj->rowid > 0)
|
|
{
|
|
$tmpwebsitepage = new WebsitePage($db);
|
|
$tmpwebsitepage->fetch($obj->rowid);
|
|
if ($tmpwebsitepage->id > 0) $arrayresult['list'][]=$tmpwebsitepage;
|
|
}
|
|
$i++;
|
|
}
|
|
|
|
$arrayresult['code']='OK';
|
|
if (empty($arrayresult['list']))
|
|
{
|
|
$arrayresult['code']='KO';
|
|
$arrayresult['message']=$weblangs->trans("NoRecordFound");
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$error++;
|
|
$arrayresult['code']=$db->lasterrno();
|
|
$arrayresult['message']=$db->lasterror();
|
|
}
|
|
|
|
$searchdone = 1;
|
|
}
|
|
|
|
if (! $searchdone)
|
|
{
|
|
$error++;
|
|
$arrayresult['code']='KO';
|
|
$arrayresult['message']='No supported algorithm found';
|
|
}
|
|
|
|
return $arrayresult;
|
|
}
|
|
|
|
/**
|
|
* Download all images found into page content $tmp.
|
|
* If $modifylinks is set, links to images will be replace with a link to viewimage wrapper.
|
|
*
|
|
* @param Website $object Object website
|
|
* @param WebsitePage $objectpage Object website page
|
|
* @param string $urltograb URL to grab (exemple: http://www.nltechno.com/ or http://www.nltechno.com/dir1/ or http://www.nltechno.com/dir1/mapage1)
|
|
* @param string $tmp Content to parse
|
|
* @param string $action Var $action
|
|
* @param string $modifylinks 0=Do not modify content, 1=Replace links with a link to viewimage
|
|
* @param int $grabimages 0=Do not grab images, 1=Grab images
|
|
* @param string $grabimagesinto 'root' or 'subpage'
|
|
* @return void
|
|
*/
|
|
function getAllImages($object, $objectpage, $urltograb, &$tmp, &$action, $modifylinks = 0, $grabimages = 1, $grabimagesinto = 'subpage')
|
|
{
|
|
global $conf;
|
|
|
|
$error=0;
|
|
|
|
dol_syslog("Call getAllImages with grabimagesinto=".$grabimagesinto);
|
|
|
|
$alreadygrabbed=array();
|
|
|
|
if (preg_match('/\/$/', $urltograb)) $urltograb.='.';
|
|
$urltograb = dirname($urltograb); // So urltograb is now http://www.nltechno.com or http://www.nltechno.com/dir1
|
|
|
|
// Search X in "img...src=X"
|
|
preg_match_all('/<img([^\.\/]+)src="([^>"]+)"([^>]*)>/i', $tmp, $regs);
|
|
|
|
foreach ($regs[0] as $key => $val)
|
|
{
|
|
if (preg_match('/^data:image/i', $regs[2][$key])) continue; // We do nothing for such images
|
|
|
|
if (preg_match('/^\//', $regs[2][$key]))
|
|
{
|
|
$urltograbdirrootwithoutslash = getRootURLFromURL($urltograb);
|
|
$urltograbbis = $urltograbdirrootwithoutslash.$regs[2][$key]; // We use dirroot
|
|
}
|
|
else
|
|
{
|
|
$urltograbbis = $urltograb.'/'.$regs[2][$key]; // We use dir of grabbed file
|
|
}
|
|
|
|
$linkwithoutdomain = $regs[2][$key];
|
|
$dirforimages = '/'.$objectpage->pageurl;
|
|
if ($grabimagesinto == 'root') $dirforimages='';
|
|
|
|
// Define $filetosave and $filename
|
|
$filetosave = $conf->medias->multidir_output[$conf->entity].'/image/'.$object->ref.$dirforimages.(preg_match('/^\//', $regs[2][$key])?'':'/').$regs[2][$key];
|
|
if (preg_match('/^http/', $regs[2][$key]))
|
|
{
|
|
$urltograbbis = $regs[2][$key];
|
|
$linkwithoutdomain = preg_replace('/^https?:\/\/[^\/]+\//i', '', $regs[2][$key]);
|
|
$filetosave = $conf->medias->multidir_output[$conf->entity].'/image/'.$object->ref.$dirforimages.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
|
|
}
|
|
$filename = 'image/'.$object->ref.$dirforimages.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
|
|
|
|
// Clean the aa/bb/../cc into aa/cc
|
|
$filetosave = preg_replace('/\/[^\/]+\/\.\./', '', $filetosave);
|
|
$filename = preg_replace('/\/[^\/]+\/\.\./', '', $filename);
|
|
|
|
//var_dump($filetosave);
|
|
//var_dump($filename);
|
|
//exit;
|
|
|
|
if (empty($alreadygrabbed[$urltograbbis]))
|
|
{
|
|
if ($grabimages)
|
|
{
|
|
$tmpgeturl = getURLContent($urltograbbis);
|
|
if ($tmpgeturl['curl_error_no'])
|
|
{
|
|
$error++;
|
|
setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['curl_error_msg'], null, 'errors');
|
|
$action='create';
|
|
}
|
|
elseif ($tmpgeturl['http_code'] != '200')
|
|
{
|
|
$error++;
|
|
setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['http_code'], null, 'errors');
|
|
$action='create';
|
|
}
|
|
else
|
|
{
|
|
$alreadygrabbed[$urltograbbis]=1; // Track that file was alreay grabbed.
|
|
|
|
dol_mkdir(dirname($filetosave));
|
|
|
|
$fp = fopen($filetosave, "w");
|
|
fputs($fp, $tmpgeturl['content']);
|
|
fclose($fp);
|
|
if (! empty($conf->global->MAIN_UMASK))
|
|
@chmod($filetosave, octdec($conf->global->MAIN_UMASK));
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($modifylinks)
|
|
{
|
|
$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);
|
|
}
|
|
}
|
|
|
|
// Search X in "background...url(X)"
|
|
preg_match_all('/background([^\.\/\(;]+)url\([\"\']?([^\)\"\']*)[\"\']?\)/i', $tmp, $regs);
|
|
|
|
foreach ($regs[0] as $key => $val)
|
|
{
|
|
if (preg_match('/^data:image/i', $regs[2][$key])) continue; // We do nothing for such images
|
|
|
|
if (preg_match('/^\//', $regs[2][$key]))
|
|
{
|
|
$urltograbdirrootwithoutslash = getRootURLFromURL($urltograb);
|
|
$urltograbbis = $urltograbdirrootwithoutslash.$regs[2][$key]; // We use dirroot
|
|
}
|
|
else
|
|
{
|
|
$urltograbbis = $urltograb.'/'.$regs[2][$key]; // We use dir of grabbed file
|
|
}
|
|
|
|
$linkwithoutdomain = $regs[2][$key];
|
|
|
|
$dirforimages = '/'.$objectpage->pageurl;
|
|
if ($grabimagesinto == 'root') $dirforimages='';
|
|
|
|
$filetosave = $conf->medias->multidir_output[$conf->entity].'/image/'.$object->ref.$dirforimages.(preg_match('/^\//', $regs[2][$key])?'':'/').$regs[2][$key];
|
|
|
|
if (preg_match('/^http/', $regs[2][$key]))
|
|
{
|
|
$urltograbbis = $regs[2][$key];
|
|
$linkwithoutdomain = preg_replace('/^https?:\/\/[^\/]+\//i', '', $regs[2][$key]);
|
|
$filetosave = $conf->medias->multidir_output[$conf->entity].'/image/'.$object->ref.$dirforimages.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
|
|
}
|
|
|
|
$filename = 'image/'.$object->ref.$dirforimages.(preg_match('/^\//', $linkwithoutdomain)?'':'/').$linkwithoutdomain;
|
|
|
|
// Clean the aa/bb/../cc into aa/cc
|
|
$filetosave = preg_replace('/\/[^\/]+\/\.\./', '', $filetosave);
|
|
$filename = preg_replace('/\/[^\/]+\/\.\./', '', $filename);
|
|
|
|
//var_dump($filetosave);
|
|
//var_dump($filename);
|
|
//exit;
|
|
|
|
if (empty($alreadygrabbed[$urltograbbis]))
|
|
{
|
|
if ($grabimages)
|
|
{
|
|
$tmpgeturl = getURLContent($urltograbbis);
|
|
if ($tmpgeturl['curl_error_no'])
|
|
{
|
|
$error++;
|
|
setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['curl_error_msg'], null, 'errors');
|
|
$action='create';
|
|
}
|
|
elseif ($tmpgeturl['http_code'] != '200')
|
|
{
|
|
$error++;
|
|
setEventMessages('Error getting '.$urltograbbis.': '.$tmpgeturl['http_code'], null, 'errors');
|
|
$action='create';
|
|
}
|
|
else
|
|
{
|
|
$alreadygrabbed[$urltograbbis]=1; // Track that file was alreay grabbed.
|
|
|
|
dol_mkdir(dirname($filetosave));
|
|
|
|
$fp = fopen($filetosave, "w");
|
|
fputs($fp, $tmpgeturl['content']);
|
|
fclose($fp);
|
|
if (! empty($conf->global->MAIN_UMASK))
|
|
@chmod($filetosave, octdec($conf->global->MAIN_UMASK));
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($modifylinks)
|
|
{
|
|
$tmp = preg_replace('/'.preg_quote($regs[0][$key], '/').'/i', 'background'.$regs[1][$key].'url("'.DOL_URL_ROOT.'/viewimage.php?modulepart=medias&file='.$filename.'")', $tmp);
|
|
}
|
|
}
|
|
}
|