Whoops \ Exception \ ErrorException (E_WARNING)
simplexml_load_string(): Entity: line 1: parser error : Extra content at the end of the document Whoops\Exception\ErrorException thrown with message "simplexml_load_string(): Entity: line 1: parser error : Extra content at the end of the document" Stacktrace: #12 Whoops\Exception\ErrorException in /var/www/weedporndaily.com/html/site/snippets/tumblrsingle.php:25 #11 simplexml_load_string in /var/www/weedporndaily.com/html/site/snippets/tumblrsingle.php:25 #10 require in /var/www/weedporndaily.com/html/kirby/vendor/getkirby/toolkit/lib/tpl.php:22 #9 Tpl:load in /var/www/weedporndaily.com/html/kirby/kirby/component/snippet.php:38 #8 Kirby\Component\Snippet:render in /var/www/weedporndaily.com/html/kirby/helpers.php:12 #7 snippet in /var/www/weedporndaily.com/html/site/templates/tumblrpost.php:5 #6 require in /var/www/weedporndaily.com/html/kirby/vendor/getkirby/toolkit/lib/tpl.php:22 #5 Tpl:load in /var/www/weedporndaily.com/html/kirby/kirby/component/template.php:103 #4 Kirby\Component\Template:render in /var/www/weedporndaily.com/html/kirby/kirby.php:635 #3 Kirby:template in /var/www/weedporndaily.com/html/kirby/kirby.php:623 #2 Kirby:render in /var/www/weedporndaily.com/html/kirby/kirby/component/response.php:27 #1 Kirby\Component\Response:make in /var/www/weedporndaily.com/html/kirby/kirby.php:705 #0 Kirby:launch in /var/www/weedporndaily.com/html/index.php:16
Stack frames (13)
12
Whoops
\
Exception
\
ErrorException
/
var
/
www
/
weedporndaily.com
/
html
/
site
/
snippets
/
tumblrsingle.php
25
11
simplexml_load_string
/
var
/
www
/
weedporndaily.com
/
html
/
site
/
snippets
/
tumblrsingle.php
25
10
require
/
vendor
/
getkirby
/
toolkit
/
lib
/
tpl.php
22
9
Tpl
load
/
kirby
/
component
/
snippet.php
38
8
Kirby
\
Component
\
Snippet
render
/
helpers.php
12
7
snippet
/
var
/
www
/
weedporndaily.com
/
html
/
site
/
templates
/
tumblrpost.php
5
6
require
/
vendor
/
getkirby
/
toolkit
/
lib
/
tpl.php
22
5
Tpl
load
/
kirby
/
component
/
template.php
103
4
Kirby
\
Component
\
Template
render
/
kirby.php
635
3
Kirby
template
/
kirby.php
623
2
Kirby
render
/
kirby
/
component
/
response.php
27
1
Kirby
\
Component
\
Response
make
/
kirby.php
705
0
Kirby
launch
/
var
/
www
/
weedporndaily.com
/
html
/
index.php
16
/
var
/
www
/
weedporndaily.com
/
html
/
site
/
snippets
/
tumblrsingle.php
 
The $num parameter can be passed to this snippet to
set the number of posts.
 
```
<?= snippet('tumblrsingle', ['id' => 'weeducation', 'num' => 5]) ?>
```
 
*/
 
$cache_tag = 'tumblr-'.$id;
 
$cache = cache::get($cache_tag);
$data = $cache;
if($cache = '' || !$data) {
  $rssfeed = "http://weedporndaily.tumblr.com/post/".$id."/rss";
  $data = f::read($rssfeed);
  cache::set($cache_tag, $cache, 3600);
}
$feed = simplexml_load_string($data);
 
$content = '';
 
foreach($feed->channel->item as $blog){
  snippet('tumblrpost', array('post' => $blog));
}
echo $content;
 
 
?>
 
/
var
/
www
/
weedporndaily.com
/
html
/
site
/
snippets
/
tumblrsingle.php
 
The $num parameter can be passed to this snippet to
set the number of posts.
 
```
<?= snippet('tumblrsingle', ['id' => 'weeducation', 'num' => 5]) ?>
```
 
*/
 
$cache_tag = 'tumblr-'.$id;
 
$cache = cache::get($cache_tag);
$data = $cache;
if($cache = '' || !$data) {
  $rssfeed = "http://weedporndaily.tumblr.com/post/".$id."/rss";
  $data = f::read($rssfeed);
  cache::set($cache_tag, $cache, 3600);
}
$feed = simplexml_load_string($data);
 
$content = '';
 
foreach($feed->channel->item as $blog){
  snippet('tumblrpost', array('post' => $blog));
}
echo $content;
 
 
?>
 
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
vendor
/
getkirby
/
toolkit
/
lib
/
tpl.php
/**
 * Tpl
 *
 * Super simple template engine
 *
 * @package   Kirby Toolkit
 * @author    Bastian Allgeier <bastian@getkirby.com>
 * @link      http://getkirby.com
 * @copyright Bastian Allgeier
 * @license   http://www.opensource.org/licenses/mit-license.php MIT License
 */
class Tpl extends Silo {
 
  public static $data = array();
 
  public static function load($_file, $_data = array(), $_return = true) {
    if(!file_exists($_file)) return false;
    ob_start();
    extract(array_merge(static::$data, (array)$_data));
    require($_file);
    $_content = ob_get_contents();
    ob_end_clean();
    if($_return) return $_content;
    echo $_content;
  }
 
}
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
kirby
/
component
/
snippet.php
   * Returns a snippet file path by name
   *
   * @param string $name
   * @return string
   */
  public function file($name) {
    return $this->kirby->roots()->snippets() . DS . str_replace('/', DS, $name) . '.php';
  }
 
  /**
   * Renders the snippet with the given data 
   * 
   * @param string $name
   * @param array $data
   * @param boolean $return
   * @return string
   */
  public function render($name, $data = [], $return = false) {
    if(is_object($data)) $data = ['item' => $data];
    return tpl::load($this->kirby->registry->get('snippet', $name), $data, $return);
  }
 
}
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
helpers.php
<?php
 
/**
 * Embeds a snippet from the snippet folder
 *
 * @param string $file
 * @param mixed $data array or object
 * @param boolean $return
 * @return string
 */
function snippet($file, $data = array(), $return = false) {
  return kirby::instance()->component('snippet')->render($file, $data, $return);
}
 
/**
 * Builds a css link tag for relative or absolute urls
 *
 * @param string $url
 * @param string $media
 * @return string
 */
function css() {
  return call([kirby::instance()->component('css'), 'tag'], func_get_args());
}
 
/**
 * Builds a script tag for relative or absolute links
 *
 * @param string $src
 * @param boolean $async
 * @return string
 */
function js($src, $async = false) {
  return call([kirby::instance()->component('js'), 'tag'], func_get_args());
}
 
/**
 * Global markdown parser shortcut
 *
 * @param string $text
/
var
/
www
/
weedporndaily.com
/
html
/
site
/
templates
/
tumblrpost.php
<?php snippet('header') ?>
 
  <main class="main" role="main">
 
    <?php snippet('tumblrsingle', ['id' => $tag, 'type' => 'normal']) ?>
 
    <?php // snippet('prevnext', ['flip' => true]) //insert pagination later ?>
 
  </main>
 
<?php snippet('footer') ?>
 
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
vendor
/
getkirby
/
toolkit
/
lib
/
tpl.php
/**
 * Tpl
 *
 * Super simple template engine
 *
 * @package   Kirby Toolkit
 * @author    Bastian Allgeier <bastian@getkirby.com>
 * @link      http://getkirby.com
 * @copyright Bastian Allgeier
 * @license   http://www.opensource.org/licenses/mit-license.php MIT License
 */
class Tpl extends Silo {
 
  public static $data = array();
 
  public static function load($_file, $_data = array(), $_return = true) {
    if(!file_exists($_file)) return false;
    ob_start();
    extract(array_merge(static::$data, (array)$_data));
    require($_file);
    $_content = ob_get_contents();
    ob_end_clean();
    if($_return) return $_content;
    echo $_content;
  }
 
}
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
kirby
/
component
/
template.php
    if($template instanceof Page) {
      $page = $template;
      $file = $page->templateFile();
      $data = $this->data($page, $data);
    } else {
      $file = $template;
      $data = $this->data(null, $data);
    }
 
    // check for an existing template
    if(!file_exists($file)) {
      throw new Exception('The template could not be found');
    }
 
    // merge and register the template data globally
    $tplData = tpl::$data;
    tpl::$data = array_merge(tpl::$data, $data);
 
    // load the template
    $result = tpl::load($file, null, $return);
 
    // reset the template data
    tpl::$data = $tplData;
 
    return $result;
 
  }
 
}
 
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
kirby.php
      }
 
      return $template;
 
    }
 
    // return a fresh template
    return $this->template($page, $data);
 
  }
 
  /**
   * Template configuration
   *
   * @param Page $page
   * @param array $data
   * @return string
   */
  public function template(Page $page, $data = array()) {
    return $this->component('template')->render($page, $data);
  }
 
  public function request() {
    if(!is_null($this->request)) return $this->request;
    return $this->request = new Request($this);
  }
 
  public function router() {
    return $this->router;
  }
 
  public function route() {
    return $this->route;
  }
 
  /**
   * Starts the router, renders the page and returns the response
   *
   * @return mixed
   */
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
kirby.php
        }
 
      }
 
      // try to fetch the template from cache
      $template = $this->cache()->get($cacheId);
 
      // fetch fresh content if the cache is empty
      if(empty($template)) {
        $template = $this->template($page, $data);
        // store the result for the next round
        $this->cache()->set($cacheId, $template);
      }
 
      return $template;
 
    }
 
    // return a fresh template
    return $this->template($page, $data);
 
  }
 
  /**
   * Template configuration
   *
   * @param Page $page
   * @param array $data
   * @return string
   */
  public function template(Page $page, $data = array()) {
    return $this->component('template')->render($page, $data);
  }
 
  public function request() {
    if(!is_null($this->request)) return $this->request;
    return $this->request = new Request($this);
  }
 
  public function router() {
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
kirby
/
component
/
response.php
 * @package   Kirby CMS
 * @author    Bastian Allgeier <bastian@getkirby.com>
 * @link      http://getkirby.com
 * @copyright Bastian Allgeier
 * @license   http://getkirby.com/license
 */
class Response extends \Kirby\Component {
 
  /**
   * Builds and return the response by various input
   * 
   * @param mixed $response
   * @return mixed
   */
  public function make($response) {
 
    if(is_string($response)) {
      return $this->kirby->render(page($response));
    } else if(is_array($response)) {
      return $this->kirby->render(page($response[0]), $response[1]);
    } else if(is_a($response, 'Page')) {
      return $this->kirby->render($response);      
    } else if(is_a($response, 'Response')) {
      return $response;
    } else {
      return null;
    }
 
  }
 
}
/
var
/
www
/
weedporndaily.com
/
html
/
kirby
/
kirby.php
    // check for a valid route
    if(is_null($this->route)) {
      header::status('500');
      header::type('json');
      die(json_encode(array(
        'status'  => 'error',
        'message' => 'Invalid route or request method'
      )));
    }
 
    // call the router action with all arguments from the pattern
    $response = call($this->route->action(), $this->route->arguments());
 
    // load all language variables
    // this can only be loaded once the router action has been called
    // otherwise the current language is not yet available
    $this->localize();
 
    // build the response
    $this->response = $this->component('response')->make($response);
 
    // store the current language in the session
    if(
        $this->option('language.detect') &&
        $this->site()->multilang() && 
        $this->site()->language()
      ) {      
      s::set('kirby_language', $this->site()->language()->code());
    }
 
    return $this->response;
 
  }
 
  /**
   * Register a new hook
   * 
   * @param string/array $hook The name of the hook
   * @param closure $callback
   */
/
var
/
www
/
weedporndaily.com
/
html
/
index.php
<?php
 
define('DS', DIRECTORY_SEPARATOR);
 
// load kirby
require(__DIR__ . DS . 'kirby' . DS . 'bootstrap.php');
 
// check for a custom site.php
if(file_exists(__DIR__ . DS . 'site.php')) {
  require(__DIR__ . DS . 'site.php');
} else {
  $kirby = kirby();
}
 
// render
echo $kirby->launch();

Environment & details:

Key Value
Kirby Toolkit v2.4.1
Kirby CMS v2.4.1
empty
empty
empty
empty
empty
Key Value
USER www-data
HOME /var/www
HTTP_HOST weedporndaily.com
HTTP_USER_AGENT claudebot
HTTP_ACCEPT */*
REDIRECT_STATUS 200
PATH_INFO /index.php
SCRIPT_FILENAME /var/www/weedporndaily.com/html/index.php
SERVER_NAME weedporndaily.com
SERVER_PORT 80
SERVER_ADDR 162.243.141.208
REMOTE_PORT 39216
REMOTE_ADDR 44.201.64.238
SERVER_SOFTWARE nginx/1.10.3
GATEWAY_INTERFACE CGI/1.1
REQUEST_SCHEME http
SERVER_PROTOCOL HTTP/1.1
DOCUMENT_ROOT /var/www/weedporndaily.com/html
DOCUMENT_URI /index.php
REQUEST_URI /tumblr/post/139578445234
SCRIPT_NAME /index.php
CONTENT_LENGTH
CONTENT_TYPE
REQUEST_METHOD GET
QUERY_STRING
FCGI_ROLE RESPONDER
PHP_SELF /index.php
REQUEST_TIME_FLOAT 1711644411.0703
REQUEST_TIME 1711644411
empty
0. Whoops\Handler\PrettyPageHandler