Whoops \ Exception \ ErrorException (E_NOTICE)
Undefined variable: pretty_time Whoops\Exception\ErrorException thrown with message "Undefined variable: pretty_time" Stacktrace: #8 Whoops\Exception\ErrorException in /opt/bitnami/apache2/htdocs/site/templates/episode.php:54 #7 Whoops\Run:handleError in /opt/bitnami/apache2/htdocs/site/templates/episode.php:54 #6 require in /opt/bitnami/apache2/htdocs/kirby/vendor/getkirby/toolkit/lib/tpl.php:22 #5 Tpl:load in /opt/bitnami/apache2/htdocs/kirby/kirby/component/template.php:103 #4 Kirby\Component\Template:render in /opt/bitnami/apache2/htdocs/kirby/kirby.php:681 #3 Kirby:template in /opt/bitnami/apache2/htdocs/kirby/kirby.php:669 #2 Kirby:render in /opt/bitnami/apache2/htdocs/kirby/kirby/component/response.php:29 #1 Kirby\Component\Response:make in /opt/bitnami/apache2/htdocs/kirby/kirby.php:751 #0 Kirby:launch in /opt/bitnami/apache2/htdocs/index.php:16
Stack frames (9)
8
Whoops
\
Exception
\
ErrorException
/
opt
/
bitnami
/
apache2
/
htdocs
/
site
/
templates
/
episode.php
54
7
Whoops
\
Run
handleError
/
opt
/
bitnami
/
apache2
/
htdocs
/
site
/
templates
/
episode.php
54
6
require
/
vendor
/
getkirby
/
toolkit
/
lib
/
tpl.php
22
5
Tpl
load
/
kirby
/
component
/
template.php
103
4
Kirby
\
Component
\
Template
render
/
kirby.php
681
3
Kirby
template
/
kirby.php
669
2
Kirby
render
/
kirby
/
component
/
response.php
29
1
Kirby
\
Component
\
Response
make
/
kirby.php
751
0
Kirby
launch
/
opt
/
bitnami
/
apache2
/
htdocs
/
index.php
16
/
opt
/
bitnami
/
apache2
/
htdocs
/
site
/
templates
/
episode.php
        $chapter_positions .= ',';    
    }
    $c++;
}
?>
 
    <div id="content">
        <article class="hentry">
            <?php 
                $coverimage = $page->coverimage()->toFile();
                $cover_resized = thumb($coverimage, array('width' => 1600, 'crop' => false, 'quality' => 60))->url();
            ?>
            <div class="article_banner" style="background-image: url('<?= $cover_resized ?>');">
                <div class="article_banner_content">
                    <h2 class="entry-title"><?= $page->title() ?></h2>
                    <div class="excerpt">
                        <?= $page->excerpt() ?>
                    </div>
                    <?php if ($feed_content !== false) { ?>
                    <button class="audio_control" style="cursor: pointer;" episode_id="<?= $episode_id ?>" audio_url="<?= $audio_url ?>" class="play" onclick='playPauseEpisode("<?= $episode_id ?>", "<?= $audio_url ?>", "<?= $page->title() ?>", "<?= $page->url() ?>", "<?= $pretty_time ?>", "<?= $chapter_positions ?>")'>Play/Pause</button>
                    <div class="duration"><?= $pretty_time ?></div>
                    <?php } ?>
                </div>
                <div class="article_banner_gradient"></div>
            </div>
            <div class="article_content">
                <div class="meta_info">
                    <div class="byline author">
                        <?= $page->byline() ?>
                    </div>
                    <div class="date published" datetime="<?= $page->date('Y-m-d') ?>">
                        <?= $page->date('F j, Y') ?>
                    </div>
                    <div class="share">
                        <a href="http://www.facebook.com/sharer/sharer.php?u=<?= urlencode(url::current()) ?>"><i class="fab fa-facebook-square"></i></a>
                        <a href="https://twitter.com/intent/tweet?text=<?= urlencode($page->title()) ?>&amp;url=<?= urlencode(url::current()) ?>&amp;via=IEReporter"><i class="fab fa-twitter-square"></i></a>
                        <a href="mailto:?subject=<?= htmlentities($page->title()) ?>&amp;body=<?= htmlentities($page->title()) ?>%20on%20the%20Indiana%20Environmental%20Reporter%0A%0A<?= htmlentities(url::current()) ?>"><i class="fas fa-envelope"></i></a>
                    </div>
                </div>
                <div class="article_body entry-content">
/
opt
/
bitnami
/
apache2
/
htdocs
/
site
/
templates
/
episode.php
        $chapter_positions .= ',';    
    }
    $c++;
}
?>
 
    <div id="content">
        <article class="hentry">
            <?php 
                $coverimage = $page->coverimage()->toFile();
                $cover_resized = thumb($coverimage, array('width' => 1600, 'crop' => false, 'quality' => 60))->url();
            ?>
            <div class="article_banner" style="background-image: url('<?= $cover_resized ?>');">
                <div class="article_banner_content">
                    <h2 class="entry-title"><?= $page->title() ?></h2>
                    <div class="excerpt">
                        <?= $page->excerpt() ?>
                    </div>
                    <?php if ($feed_content !== false) { ?>
                    <button class="audio_control" style="cursor: pointer;" episode_id="<?= $episode_id ?>" audio_url="<?= $audio_url ?>" class="play" onclick='playPauseEpisode("<?= $episode_id ?>", "<?= $audio_url ?>", "<?= $page->title() ?>", "<?= $page->url() ?>", "<?= $pretty_time ?>", "<?= $chapter_positions ?>")'>Play/Pause</button>
                    <div class="duration"><?= $pretty_time ?></div>
                    <?php } ?>
                </div>
                <div class="article_banner_gradient"></div>
            </div>
            <div class="article_content">
                <div class="meta_info">
                    <div class="byline author">
                        <?= $page->byline() ?>
                    </div>
                    <div class="date published" datetime="<?= $page->date('Y-m-d') ?>">
                        <?= $page->date('F j, Y') ?>
                    </div>
                    <div class="share">
                        <a href="http://www.facebook.com/sharer/sharer.php?u=<?= urlencode(url::current()) ?>"><i class="fab fa-facebook-square"></i></a>
                        <a href="https://twitter.com/intent/tweet?text=<?= urlencode($page->title()) ?>&amp;url=<?= urlencode(url::current()) ?>&amp;via=IEReporter"><i class="fab fa-twitter-square"></i></a>
                        <a href="mailto:?subject=<?= htmlentities($page->title()) ?>&amp;body=<?= htmlentities($page->title()) ?>%20on%20the%20Indiana%20Environmental%20Reporter%0A%0A<?= htmlentities(url::current()) ?>"><i class="fas fa-envelope"></i></a>
                    </div>
                </div>
                <div class="article_body entry-content">
/
opt
/
bitnami
/
apache2
/
htdocs
/
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;
  }
 
}
/
opt
/
bitnami
/
apache2
/
htdocs
/
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;
 
  }
 
}
 
/
opt
/
bitnami
/
apache2
/
htdocs
/
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
   */
/
opt
/
bitnami
/
apache2
/
htdocs
/
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() {
/
opt
/
bitnami
/
apache2
/
htdocs
/
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;
    }
 
  }
 
}
/
opt
/
bitnami
/
apache2
/
htdocs
/
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
   */
/
opt
/
bitnami
/
apache2
/
htdocs
/
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.5.11
Kirby CMS v2.5.11
empty
empty
empty
empty
empty
Key Value
FREETDSLOCALES /opt/bitnami/common/etc/locales.conf
FREETDSCONF /opt/bitnami/common/etc/freetds.conf
OPENSSL_ENGINES /opt/bitnami/common/lib/engines
OPENSSL_CONF /opt/bitnami/common/openssl/openssl.cnf
SSL_CERT_FILE /opt/bitnami/common/openssl/certs/curl-ca-bundle.crt
CURL_CA_BUNDLE /opt/bitnami/common/openssl/certs/curl-ca-bundle.crt
LDAPCONF /opt/bitnami/common/etc/openldap/ldap.conf
GS_LIB /opt/bitnami/common/share/ghostscript/fonts
MAGICK_CODER_MODULE_PATH /opt/bitnami/common/lib/ImageMagick-6.9.8/modules-Q16/coders
MAGICK_CONFIGURE_PATH /opt/bitnami/common/lib/ImageMagick-6.9.8/config-Q16:/opt/bitnami/common/
MAGICK_HOME /opt/bitnami/common
PATH /opt/bitnami/frameworks/cakephp/bin:/opt/bitnami/frameworks/codeigniter/bin:/opt/bitnami/frameworks/zendframework/app/Console:/opt/bitnami/git/bin:/opt/bitnami/varnish/bin:/opt/bitnami/sqlite/bin:/opt/bitnami/php/bin:/opt/bitnami/mysql/bin:/opt/bitnami/apache2/bin:/opt/bitnami/common/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/snap/bin
USER daemon
HOME /usr/sbin
FCGI_ROLE RESPONDER
REDIRECT_SCRIPT_URL /episodes/on-air-with-ier-episode-115
REDIRECT_SCRIPT_URI http://www.indianaenvironmentalreporter.org/episodes/on-air-with-ier-episode-115
REDIRECT_STATUS 200
SCRIPT_URL /episodes/on-air-with-ier-episode-115
SCRIPT_URI http://www.indianaenvironmentalreporter.org/episodes/on-air-with-ier-episode-115
HTTP_X_FORWARDED_FOR 52.205.218.160
HTTP_X_FORWARDED_PROTO https
HTTP_X_FORWARDED_PORT 443
HTTP_HOST www.indianaenvironmentalreporter.org
HTTP_X_AMZN_TRACE_ID Root=1-65f93564-5d45f5fe20e5d33850c41a97
HTTP_ACCEPT */*
HTTP_USER_AGENT claudebot
LD_LIBRARY_PATH /opt/bitnami/sqlite/lib:/opt/bitnami/mysql/lib:/opt/bitnami/apache2/lib:/opt/bitnami/common/lib:/opt/bitnami/sqlite/lib:/opt/bitnami/mysql/lib:/opt/bitnami/apache2/lib:/opt/bitnami/common/lib:/opt/bitnami/git/lib:/opt/bitnami/varnish/lib:/opt/bitnami/varnish/lib/varnish:/opt/bitnami/varnish/lib/varnish/vmods:/opt/bitnami/sqlite/lib:/opt/bitnami/mysql/lib:/opt/bitnami/apache2/lib:/opt/bitnami/common/lib:
SERVER_SIGNATURE
SERVER_SOFTWARE Apache
SERVER_NAME www.indianaenvironmentalreporter.org
SERVER_ADDR 172.26.10.185
SERVER_PORT 80
REMOTE_ADDR 172.26.42.201
DOCUMENT_ROOT /opt/bitnami/apache2/htdocs
REQUEST_SCHEME http
CONTEXT_PREFIX
CONTEXT_DOCUMENT_ROOT /opt/bitnami/apache2/htdocs
SERVER_ADMIN you@example.com
SCRIPT_FILENAME /opt/bitnami/apache2/htdocs/index.php
REMOTE_PORT 25042
REDIRECT_URL /episodes/on-air-with-ier-episode-115
GATEWAY_INTERFACE CGI/1.1
SERVER_PROTOCOL HTTP/1.1
REQUEST_METHOD GET
QUERY_STRING
REQUEST_URI /episodes/on-air-with-ier-episode-115
SCRIPT_NAME /index.php
PHP_SELF /index.php
REQUEST_TIME_FLOAT 1710830948.309
REQUEST_TIME 1710830948
empty
0. Whoops\Handler\PrettyPageHandler