cli) {
return true;
}
$this->authUser = $this->getAuthUser();
if (!$this->authUser) {
return false;
}
return true;
}
function relPath($base, $url)
{
if (preg_match('/^(http|https|mailto):/',$url)) {
return $url;
}
$ui = parse_url($base);
if (substr($url,0,2) == '//') {
return $ui['scheme'] .':' . $url;
}
if (substr($url,0,1) == '/') {
return $ui['scheme'] .'://'.$ui['host']. $url;
}
if (substr($ui['path'], -1) == '/') {
return $ui['scheme'] .'://'.$ui['host']. $ui['path'] . $url;
}
if (!strlen($ui['path'])) {
return $ui['scheme'] .'://'.$ui['host']. '/' . $url;
}
return $ui['scheme'] .'://'.$ui['host']. $ui['path'] . '/../'. $url;
}
function checkHeader($url)
{
if(strpos($url, 'https') !== false)
{
$this->jerr('accept HTTP url only!');
}
$headers = get_headers($url, 1);
if(strpos(is_array($headers['Content-Type']) ? $headers['Content-Type'][0] : $headers['Content-Type'], 'text/html') === false)
{
$this->jerr('accept html file only!');
}
return;
}
var $styleSheets = array();
function convertStyle($url, $file, $is_url = false)
{
// if(!empty($url))
// {
// $host = parse_url($url);
// require_once 'System.php';
// $wget = System::which('wget');
// if (!$wget) {
// $this->jerr("no wget");
// }
// $cmd = $wget . ' -q -O - ' . escapeshellarg($url);
//
// //echo $cmd; exit;
// $data = `$cmd`;
//
// if (!trim(strlen($data))) {
// $this->jerr("url returned an empty string");
// }
// }
if(!$is_url){
$data = file_get_contents($file);
}
libxml_use_internal_errors (true);
$doc = new DOMDocument('1.0', 'UTF-8');
$doc->loadHTML(''.$data);
$doc->formatOutput = true;
$xpath = new DOMXpath($doc);
foreach ($xpath->query('//img[@src]') as $img) {
$href = $img->getAttribute('src');
if (!preg_match("/^http(.*)$/", $href, $matches)) {
if(!empty($url)){
$img->setAttribute('src', $this->relPath($url, $href));
continue;
}
$this->jerr('Please use the absolutely url for image src!');
}
}
foreach ($xpath->query('//a[@href]') as $a) {
$href = $a->getAttribute('href');
if (!preg_match("/^http|mailto|#(.*)$/", $href, $matches)) {
if(!empty($url)){
$a->setAttribute('href', $this->relPath($url, $href));
continue;
}
$this->jerr('Please use the absolutely url for a href!');
}
}
foreach ($xpath->query('//link[@href]') as $l) {
if($l->getAttribute('rel') == 'stylesheet'){
$href = $l->getAttribute('href');
if(!preg_match("/^http(.*)$/", $href, $matches)){
if(!empty($url)){
$href = $this->relPath($url, $href);
}
$this->jerr('Please use the absolutely url for link href!');
}
$this->styleSheets[$href] = $this->replaceImageUrl(file_get_contents($href),$href);
}
}
foreach ($xpath->query('//style') as $s){
$this->styleSheets[] = $this->replaceImageUrl($s->nodeValue, $url);
}
$data = $doc->saveHTML();
$htmldoc = new HTML_CSS_InlineStyle($data);
if(count($this->styleSheets) > 0){
foreach ($this->styleSheets as $styleSheet){
$htmldoc->applyStylesheet($styleSheet);
}
}
$html = $htmldoc->getHTML();
libxml_use_internal_errors (false);
if (!function_exists('tidy_repair_string')) {
return "INSTALL TIDY ON SERVER " . $html;
}
$html = tidy_repair_string(
$html,
array(
'indent' => TRUE,
'output-xhtml' => TRUE,
'wrap' => 120
),
'UTF8'
);
return $html;
}
function replaceImageUrl($stylesheet,$href)
{
$base = explode("/", $href);
$s = preg_split('/url\(([\'\"]?)/', $stylesheet);
foreach($s as $k => $v){
if($k == 0){
continue;
}
array_pop($base);
array_push($base, $v);
$s[$k] = implode("/", $base);
}
$r = implode("url(", $s);
$this->checkImportCss($r);
return $r;
}
function checkImportCss($r)
{
if(preg_match("/@import url/", $r, $matches)){
$importCss = explode("@import url", $r);
foreach ($importCss as $css){
if(preg_match("/\.css/", $css, $matches)){
$cssFileName = explode(".css", $css);
$name = preg_replace("/[\(\'\"]/", '', $cssFileName[0]);
$p = $name . '.css';
$this->styleSheets[$p] = $this->replaceImageUrl(file_get_contents($p),$p);
}
}
}
return;
}
}