52 lines (43 sloc) 1.31 KB Kirby CMS Debugger
Whoops \ Exception \ ErrorException (E_WARNING)
session_name(): Cannot change session name when headers already sent Whoops\Exception\ErrorException thrown with message "session_name(): Cannot change session name when headers already sent" Stacktrace: #13 Whoops\Exception\ErrorException in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/vendor/getkirby/toolkit/lib/s.php:48 #12 session_name in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/vendor/getkirby/toolkit/lib/s.php:48 #11 S:start in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/vendor/getkirby/toolkit/lib/s.php:188 #10 S:get in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/site/plugins/uniform/lib/UniForm.php:112 #9 UniForm:__construct in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/site/plugins/uniform/uniform.php:11 #8 uniform in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/site/controllers/default.php:8 #7 Kirby\Registry\Controller:{closure} in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/core/page.php:1510 #6 PageAbstract:controller in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/kirby/component/template.php:35 #5 Kirby\Component\Template:data in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/kirby/component/template.php:87 #4 Kirby\Component\Template:render in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/kirby.php:635 #3 Kirby:template in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/kirby.php:623 #2 Kirby:render in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/kirby/component/response.php:29 #1 Kirby\Component\Response:make in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/kirby/kirby.php:705 #0 Kirby:launch in /nfs/c11/h01/mnt/202202/domains/peterbinks.net/html/index.php:16
Stack frames (14)
13
Whoops
\
Exception
\
ErrorException
/
vendor
/
getkirby
/
toolkit
/
lib
/
s.php
48
12
session_name
/
vendor
/
getkirby
/
toolkit
/
lib
/
s.php
48
11
S
start
/
vendor
/
getkirby
/
toolkit
/
lib
/
s.php
188
10
S
get
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
site
/
plugins
/
uniform
/
lib
/
UniForm.php
112
9
UniForm
__construct
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
site
/
plugins
/
uniform
/
uniform.php
11
8
uniform
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
site
/
controllers
/
default.php
8
7
Kirby
\
Registry
\
Controller
{closure}
/
core
/
page.php
1510
6
PageAbstract
controller
/
kirby
/
component
/
template.php
35
5
Kirby
\
Component
\
Template
data
/
kirby
/
component
/
template.php
87
4
Kirby
\
Component
\
Template
render
/
kirby.php
635
3
Kirby
template
/
kirby.php
623
2
Kirby
render
/
kirby
/
component
/
response.php
29
1
Kirby
\
Component
\
Response
make
/
kirby.php
705
0
Kirby
launch
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
index.php
16
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
vendor
/
getkirby
/
toolkit
/
lib
/
s.php
   * // do whatever you want with the session now
   * 
   * </code>
   * 
   */  
  public static function start() {
 
    if(session_status() === PHP_SESSION_ACTIVE) return true;
 
    // store the session name
    static::$cookie += array(
      'lifetime' => 0,
      'path'     => ini_get('session.cookie_path'),
      'domain'   => ini_get('session.cookie_domain'),
      'secure'   => r::secure(),
      'httponly' => true      
    );
 
    // set the custom session name
    session_name(static::$name); 
 
    // make sure to use cookies only
    ini_set('session.use_cookies', 1);
    ini_set('session.use_only_cookies', 1);
 
    // try to start the session
    if(!session_start()) return false;
 
    if(!setcookie(
      static::$name, 
      session_id(), 
      cookie::lifetime(static::$cookie['lifetime']), 
      static::$cookie['path'], 
      static::$cookie['domain'], 
      static::$cookie['secure'], 
      static::$cookie['httponly']
    )) {
      return false;
    }
 
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
vendor
/
getkirby
/
toolkit
/
lib
/
s.php
   * // do whatever you want with the session now
   * 
   * </code>
   * 
   */  
  public static function start() {
 
    if(session_status() === PHP_SESSION_ACTIVE) return true;
 
    // store the session name
    static::$cookie += array(
      'lifetime' => 0,
      'path'     => ini_get('session.cookie_path'),
      'domain'   => ini_get('session.cookie_domain'),
      'secure'   => r::secure(),
      'httponly' => true      
    );
 
    // set the custom session name
    session_name(static::$name); 
 
    // make sure to use cookies only
    ini_set('session.use_cookies', 1);
    ini_set('session.use_only_cookies', 1);
 
    // try to start the session
    if(!session_start()) return false;
 
    if(!setcookie(
      static::$name, 
      session_id(), 
      cookie::lifetime(static::$cookie['lifetime']), 
      static::$cookie['path'], 
      static::$cookie['domain'], 
      static::$cookie['secure'], 
      static::$cookie['httponly']
    )) {
      return false;
    }
 
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
vendor
/
getkirby
/
toolkit
/
lib
/
s.php
  /**
   * Gets a session value by key
   * 
   * <code>
   * 
   * s::get('username', 'bastian');
   * // saves the username in the session
   * 
   * echo s::get('username');
   * // output: 'bastian'
   * 
   * </code>   
   *
   * @param  mixed    $key The key to look for. Pass false or null to return the entire session array. 
   * @param  mixed    $default Optional default value, which should be returned if no element has been found
   * @return mixed
   */  
  public static function get($key = false, $default = null) {
 
    static::start(static::$name, static::$timeout, static::$cookie);
 
    if(!isset($_SESSION)) return false;
    if(empty($key)) return $_SESSION;
    return isset($_SESSION[$key]) ? $_SESSION[$key] : $default;
 
  }
 
  /**
   * Retrieves an item and removes it afterwards
   * 
   * @param string $key
   * @param mixed $default
   * @return mixed
   */
  public static function pull($key, $default = null) {
    $value = s::get($key, $default); 
    s::remove($key);
    return $value;
  }
 
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
site
/
plugins
/
uniform
/
lib
/
UniForm.php
			'actions'  => a::get($options, 'actions', array()),
		);
 
		// required fields will also be validated by default
		$this->options['validate'] = a::merge(
			$this->options['validate'],
			$this->options['required']
		);
 
		// initialize output array with the output of the plugin itself
		$this->actionOutput = array(
			'_uniform' => array(
				'success' => false,
				'message' => ''
			)
		);
 
		// the token is stored as session variable until the form is sent
		// successfully
		$this->token = s::get($this->id);
 
		if (!$this->token) $this->generateToken();
 
		// get the data to be sent (if there is any)
		$this->data = get();
 
		if ($this->requestValid())
		{
			// remove uniform specific fields from form data
			unset($this->data['_submit']);
 
			if (empty($this->options['actions']))
			{
				throw new Error('No Uniform actions were given.');
			}
 
			if ($this->dataValid())
			{
				// uniform is done, now it's the actions turn
				$this->actionOutput['_uniform']['success'] = true;
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
site
/
plugins
/
uniform
/
uniform.php
<?php
 
/**
 * A simple Kirby 2 plugin to handle form data.
 */
if(!class_exists('UniForm')) {
	require_once(__DIR__ . DS . 'lib' . DS . 'UniForm.php');
}
 
function uniform($id, $options = array()) {
	$form = new UniForm($id, $options);
	$form->execute();
	return $form;
}
 
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
site
/
controllers
/
default.php
<?php
 
return function($site, $pages, $page) {
 
   $form = uniform(
      'contact-form', 
      array(
         'required' => array(
            'name'  => 'name',
            '_from' => 'email'
            ),
 
         'actions'  => array(
            array(
               '_action' => 'email',
               'to'      => 'private@mail.tld',
               'sender'  => 'info@my-domain.tld',
            )
         )
      )
   );
 
   return compact('form');
};
 
?>
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
core
/
page.php
   *
   * @return array
   */
  public function controller($arguments = array()) {
 
    // first try to get a controller for the representation
    $controller = null;
    if($representation = $this->representation()) {
      $controller = $this->kirby->registry->get('controller', $this->template() . '.' . $representation);
    }
 
    // no representation or no special controller: try the normal one
    if(!$controller) $controller = $this->kirby->registry->get('controller', $this->template());
 
    if(is_a($controller, 'Closure')) {
      return (array)call_user_func_array($controller, array(
        $this->site,
        $this->site->children(),
        $this,
        $arguments
      ));
    }
 
    return array();
 
  }
 
  /**
   * Converts the entire page array into 
   * a json string
   * 
   * @param closure $callback Filter callback
   * @return string
   */
  public function toJson($callback = null) {
    return json_encode($this->toArray($callback));
  }
 
  /**
   * Makes it possible to echo the entire object
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
kirby
/
component
/
template.php
 * @link      http://getkirby.com
 * @copyright Bastian Allgeier
 * @license   http://getkirby.com/license
 */
class Template extends \Kirby\Component {
 
  /**
   * Collects all template data by page
   * 
   * @param mixed $page
   * @param array $data
   * @return array
   */
  public function data($page, $data = []) {
 
    if($page instanceof Page) {
      $data = array_merge(
        $page->templateData(), 
        $data, 
        $page->controller($data)
      );
    }
 
    // apply the basic template vars
    return array_merge(array(
      'kirby' => $this->kirby,
      'site'  => $this->kirby->site(),
      'pages' => $this->kirby->site()->children(),
      'page'  => $page
    ), $data);
 
  }
 
  /**
   * Returns all available template files
   *
   * @return array
   */
  public function files() {
    $files = dir::read($this->kirby->roots()->templates());
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
kirby
/
component
/
template.php
   * @return string
   */
  public function file($name) {
    return $this->kirby->roots()->templates() . DS . str_replace('/', DS, $name) . '.php';
  }
 
  /**
   * Renders the template by page with the additional data
   * 
   * @param Page|string $template
   * @param array $data
   * @param boolean $return
   * @return string
   */
  public function render($template, $data = [], $return = true) {
 
    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;
 
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
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
   */
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
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() {
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
html
/
kirby
/
kirby
/
component
/
response.php
 * @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;
    }
 
  }
 
}
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
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
   */
/
nfs
/
c11
/
h01
/
mnt
/
202202
/
domains
/
peterbinks.net
/
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
PATH /usr/local/bin:/usr/bin:/bin
REDIRECT_HANDLER php-latest
REDIRECT_STATUS 200
UNIQUE_ID XJPP9kgv9BYAACvOdv8AAABP
SCRIPT_URL /about
SCRIPT_URI http://peterbinks.net/about
WM_UCONTROL_XMLRPC_SERVER http://10.0.0.13
ACCESS_DOMAIN s202202.gridserver.com
DATABASE_SERVER internal-db.s202202.gridserver.com
SITE_ROOT /home/202202
SITE_CGIROOT /home/202202/cgi-bin
SITE_HTMLROOT /home/202202/domains/peterbinks.net/html
PHPRC /home/202202/etc/
HTTP_USER_AGENT CCBot/2.0 (https://commoncrawl.org/faq/)
HTTP_ACCEPT text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
HTTP_HOST peterbinks.net
HTTP_CONNECTION Keep-Alive
HTTP_ACCEPT_ENCODING gzip
SERVER_SIGNATURE
Apache/2.2.34 Server at peterbinks.net Port 80
SERVER_SOFTWARE Apache/2.2.34
SERVER_NAME peterbinks.net
SERVER_ADDR 72.47.244.143
SERVER_PORT 80
REMOTE_ADDR 54.243.17.113
DOCUMENT_ROOT /home/202202/domains/peterbinks.net/html
SERVER_ADMIN webmaster@peterbinks.net
SCRIPT_FILENAME /home/202202/domains/peterbinks.net/html/index.php
REMOTE_PORT 49226
REDIRECT_URL /index.php
GATEWAY_INTERFACE CGI/1.1
SERVER_PROTOCOL HTTP/1.1
REQUEST_METHOD GET
QUERY_STRING
REQUEST_URI /about
SCRIPT_NAME /index.php
ORIG_SCRIPT_FILENAME /etc/apache2/gs-bin/php-latest
ORIG_PATH_INFO /index.php
ORIG_PATH_TRANSLATED /home/202202/domains/peterbinks.net/html/index.php
ORIG_SCRIPT_NAME /gs-bin/php-latest
PHP_SELF /index.php
REQUEST_TIME_FLOAT 1553190902.1861
REQUEST_TIME 1553190902
argv Array ( )
argc 0
Key Value
PATH /usr/local/bin:/usr/bin:/bin
REDIRECT_HANDLER php-latest
REDIRECT_STATUS 200
UNIQUE_ID XJPP9kgv9BYAACvOdv8AAABP
SCRIPT_URL /about
SCRIPT_URI http://peterbinks.net/about
WM_UCONTROL_XMLRPC_SERVER http://10.0.0.13
ACCESS_DOMAIN s202202.gridserver.com
DATABASE_SERVER internal-db.s202202.gridserver.com
SITE_ROOT /home/202202
SITE_CGIROOT /home/202202/cgi-bin
SITE_HTMLROOT /home/202202/domains/peterbinks.net/html
PHPRC /home/202202/etc/
HTTP_USER_AGENT CCBot/2.0 (https://commoncrawl.org/faq/)
HTTP_ACCEPT text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
HTTP_HOST peterbinks.net
HTTP_CONNECTION Keep-Alive
HTTP_ACCEPT_ENCODING gzip
SERVER_SIGNATURE
Apache/2.2.34 Server at peterbinks.net Port 80
SERVER_SOFTWARE Apache/2.2.34
SERVER_NAME peterbinks.net
SERVER_ADDR 72.47.244.143
SERVER_PORT 80
REMOTE_ADDR 54.243.17.113
DOCUMENT_ROOT /home/202202/domains/peterbinks.net/html
SERVER_ADMIN webmaster@peterbinks.net
SCRIPT_FILENAME /home/202202/domains/peterbinks.net/html/index.php
REMOTE_PORT 49226
REDIRECT_URL /index.php
GATEWAY_INTERFACE CGI/1.1
SERVER_PROTOCOL HTTP/1.1
REQUEST_METHOD GET
QUERY_STRING
REQUEST_URI /about
SCRIPT_NAME /index.php
ORIG_SCRIPT_FILENAME /etc/apache2/gs-bin/php-latest
ORIG_PATH_INFO /index.php
ORIG_PATH_TRANSLATED /home/202202/domains/peterbinks.net/html/index.php
ORIG_SCRIPT_NAME /gs-bin/php-latest
0. Whoops\Handler\PrettyPageHandler