/** * @inheritdoc */ public function getFileStream(string $uriPath) { $stream = $this->filesystem(['disable_asserts' => true])->readStream($uriPath); if (!$stream) { throw new AssetException('Could not open create the stream for “' . $uriPath . '”'); } return $stream; } /** * @inheritdoc */ public function saveFileLocally(string $uriPath, string $targetPath): int
/** * @inheritdoc */ public function saveFileLocally(string $uriPath, string $targetPath): int { $stream = $this->getFileStream($uriPath); $outputStream = fopen($targetPath, 'wb'); $bytes = stream_copy_to_stream($stream, $outputStream); fclose($stream); fclose($outputStream);
$volume = $this->asset->getVolume(); } catch (InvalidConfigException $e) { Craft::error($e->getMessage(), __METHOD__); throw new ImagerException($e->getMessage(), $e->getCode(), $e); } $volume->saveFileLocally($this->asset->getPath(), $this->getTemporaryFilePath()); if (file_exists($this->getTemporaryFilePath())) { copy($this->getTemporaryFilePath(), $this->getFilePath()); @unlink($this->getTemporaryFilePath()); } }
// Set save options $saveOptions = $this->getSaveOptions($targetModel->extension, $transform); // Do transform if transform doesn't exist, cache is disabled, or cache expired if (ImagerHelpers::shouldCreateTransform($targetModel, $transform)) { // Make sure that we have a local copy. $sourceModel->getLocalCopy(); // Check all the things that could go wrong(tm) if (!file_exists($sourceModel->getFilePath())) { $msg = Craft::t('imager-x', 'Requested image “{fileName}” does not exist in path “{sourcePath}”', ['fileName' => $sourceModel->filename, 'sourcePath' => $sourceModel->path]); Craft::error($msg, __METHOD__); throw new ImagerException($msg);
foreach ($transforms as $transform) { if ($config->getSetting('noop', $transform)) { $msg = Craft::t('imager-x', 'Noop activated, returning “{path}”.', ['path' => $sourceModel->url]); Craft::info($msg, __METHOD__); $transformedImages[] = new NoopImageModel($sourceModel, $transform); } else { $transformedImages[] = $this->getTransformedImage($sourceModel, $transform); } } $taskCreated = false; // Loop over transformed images and do post optimizations and upload to external storage
// Do we have a debug image? if (self::$transformConfig->mockImage !== null) { $image = ImagerHelpers::getTransformableFromConfigSetting(self::$transformConfig->mockImage); } try { $transformedImages = $transformer->transform($image, $transforms); } catch (ImagerException $e) { // If a fallback image is defined, try to transform that instead. if (self::$transformConfig->fallbackImage !== null) { $fallbackImage = ImagerHelpers::getTransformableFromConfigSetting(self::$transformConfig->fallbackImage); if ($fallbackImage) {
* @return mixed * * @throws ImagerException */ public function transformImage($file, $transforms, $transformDefaults = null, $configOverrides = null) { $image = Plugin::$plugin->imagerx->transformImage($file, $transforms, $transformDefaults, $configOverrides); return $image; } /** * Takes an array of models that supports getUrl() and getWidth(), and returns a srcset * and returns a srcset string
$env->getExtension(SandboxExtension::class)->checkMethodAllowed($object, $method, $lineno, $source); } // Some objects throw exceptions when they have __call, and the method we try // to call is not supported. If ignoreStrictCheck is true, we should return null. try { $ret = $object->$method(...$arguments); } catch (\BadMethodCallException $e) { if ($call && ($ignoreStrictCheck || !$env->isStrictVariables())) { return; } throw $e; }
// Add deprecated support for the old DateTime methods if ($object instanceof \DateTime && ($value = self::_dateTimeAttribute($object, $item, $type)) !== false) { return $value; } try { return \twig_get_attribute($env, $source, $object, $item, $arguments, $type, $isDefinedTest, $ignoreStrictCheck); } catch (UnknownMethodException $e) { // Copy twig_get_attribute()'s BadMethodCallException handling if ($ignoreStrictCheck || !$env->isStrictVariables()) { return null; } throw new RuntimeError($e->getMessage(), -1, $source);
{% if block.slideshow and assets|length > 1 %} <div class="simple-slider oh x mb20 | js-simple-slider"> <div class="simple-slider__inner rel oh | js-slides"> <div class="aspect" style="--aspect: 75%"></div> {% for item in assets %} {% set image = craft.imager.transformImage(item, { width: 800 }) %} <figure class="simple-slide abs top left x y img-fill oh | js-slide"> <img src="{{ image.url }}" alt="{{ item.title }}" class="js-slide-img"> </figure> {% endfor %}
return ob_get_clean(); } protected function displayWithErrorHandling(array $context, array $blocks = []) { try { $this->doDisplay($context, $blocks); } catch (Error $e) { if (!$e->getSourceContext()) { $e->setSourceContext($this->getSourceContext()); } // this is mostly useful for \Twig\Error\LoaderError exceptions
{ return $this->blocks; } public function display(array $context, array $blocks = []) { $this->displayWithErrorHandling($this->env->mergeGlobals($context), array_merge($this->blocks, $blocks)); } public function render(array $context) { $level = ob_get_level(); if ($this->env->isDebug()) {
<div class="x m:mcoll2 m:col7"> <p class="small mb10">{{ entry.listSubtitle }}</p> <h1 class="h1">{{ entry.title }}</h1> {% for block in entry.listBlocks.all() %} {% include 'pages/list/blocks/' ~ block.type ~ '.twig' with { item: block } %} {% endfor %} </div> </div>
if (null !== $template && !$template instanceof self) { throw new \LogicException('A block must be a method on a \Twig\Template instance.'); } if (null !== $template) { try { $template->$block($context, $blocks); } catch (Error $e) { if (!$e->getSourceContext()) { $e->setSourceContext($template->getSourceContext()); } // this is mostly useful for \Twig\Error\LoaderError exceptions
{% include '_header.twig' %} {% block content %} {% endblock %} {% include '_footer.twig' %}
return ob_get_clean(); } protected function displayWithErrorHandling(array $context, array $blocks = []) { try { $this->doDisplay($context, $blocks); } catch (Error $e) { if (!$e->getSourceContext()) { $e->setSourceContext($this->getSourceContext()); } // this is mostly useful for \Twig\Error\LoaderError exceptions
{ return $this->blocks; } public function display(array $context, array $blocks = []) { $this->displayWithErrorHandling($this->env->mergeGlobals($context), array_merge($this->blocks, $blocks)); } public function render(array $context) { $level = ob_get_level(); if ($this->env->isDebug()) {
{% extends '_layout.twig' %} {% block content %} <article data-router-view="default" data-theme="dark"> <div class="mt140">
return ob_get_clean(); } protected function displayWithErrorHandling(array $context, array $blocks = []) { try { $this->doDisplay($context, $blocks); } catch (Error $e) { if (!$e->getSourceContext()) { $e->setSourceContext($this->getSourceContext()); } // this is mostly useful for \Twig\Error\LoaderError exceptions
{ return $this->blocks; } public function display(array $context, array $blocks = []) { $this->displayWithErrorHandling($this->env->mergeGlobals($context), array_merge($this->blocks, $blocks)); } public function render(array $context) { $level = ob_get_level(); if ($this->env->isDebug()) {
{% if entry.level == 1 %} {% include 'pages/list/archive.twig' %} {% else %} {% include 'pages/list/single.twig' %} {% endif %}
return ob_get_clean(); } protected function displayWithErrorHandling(array $context, array $blocks = []) { try { $this->doDisplay($context, $blocks); } catch (Error $e) { if (!$e->getSourceContext()) { $e->setSourceContext($this->getSourceContext()); } // this is mostly useful for \Twig\Error\LoaderError exceptions
{ return $this->blocks; } public function display(array $context, array $blocks = []) { $this->displayWithErrorHandling($this->env->mergeGlobals($context), array_merge($this->blocks, $blocks)); } public function render(array $context) { $level = ob_get_level(); if ($this->env->isDebug()) {
if ($this->env->isDebug()) { ob_start(); } else { ob_start(function () { return ''; }); } try { $this->display($context); } catch (\Throwable $e) { while (ob_get_level() > $level) { ob_end_clean(); } throw $e;
* @param array $context An array of parameters to pass to the template */ public function render(array $context = []): string { // using func_get_args() allows to not expose the blocks argument // as it should only be used by internal code return $this->template->render($context, \func_get_args()[1] ?? []); } /** * Displays the template. * * @param array $context An array of parameters to pass to the template
* @throws LoaderError When the template cannot be found * @throws SyntaxError When an error occurred during compilation * @throws RuntimeError When an error occurred during rendering */ public function render($name, array $context = []) { return $this->load($name)->render($context); } /** * Displays a template. * * @param string|TemplateWrapper $name The template name
// Render and return $renderingTemplate = $this->_renderingTemplate; $this->_renderingTemplate = $template; $e = null; try { $output = $this->getTwig()->render($template, $variables); } catch (\Throwable $e) { // throw it later } $this->_renderingTemplate = $renderingTemplate; $this->setTemplateMode($oldTemplateMode);
$isRenderingPageTemplate = $this->_isRenderingPageTemplate; $this->_isRenderingPageTemplate = true; $e = null; try { $this->beginPage(); echo $this->renderTemplate($template, $variables); $this->endPage(); } catch (\Throwable $e) { // throw it later } $this->_isRenderingPageTemplate = $isRenderingPageTemplate;
} // Prevent a response formatter from overriding the content-type header $this->response->format = YiiResponse::FORMAT_RAW; // Render and return the template $this->response->data = $view->renderPageTemplate($template, $variables, $templateMode); // Set the MIME type for the request based on the matched template's file extension (unless the // Content-Type header was already set, perhaps by the template via the {% header %} tag) $headers = $this->response->getHeaders(); if (!$headers->has('content-type')) { $templateFile = StringHelper::removeRight(strtolower($view->resolveTemplate($template)), '.twig');
// Merge any additional route params $routeParams = Craft::$app->getUrlManager()->getRouteParams(); unset($routeParams['template'], $routeParams['template']); $variables = array_merge($variables, $routeParams); return $this->renderTemplate($template, $variables); } /** * Shows the 'offline' template. * * @return Response
$args = $this->controller->bindActionParams($this, $params); Yii::debug('Running action: ' . get_class($this->controller) . '::' . $this->actionMethod . '()', __METHOD__); if (Yii::$app->requestedParams === null) { Yii::$app->requestedParams = $args; } return call_user_func_array([$this->controller, $this->actionMethod], $args); } }
} $result = null; if ($runAction && $this->beforeAction($action)) { // run the action $result = $action->runWithParams($params); $result = $this->afterAction($action, $result); // call afterAction on modules foreach ($modules as $module) { /* @var $module Module */
/** * @inheritdoc */ public function runAction($id, $params = []) { try { return parent::runAction($id, $params); } catch (\Throwable $e) { if ($this->request->getAcceptsJson()) { Craft::$app->getErrorHandler()->logException($e); if (!YII_DEBUG && !$e instanceof UserException) { $message = Craft::t('app', 'A server error occurred.'); } else {
$parts = $this->createController($route); if (is_array($parts)) { /* @var $controller Controller */ list($controller, $actionID) = $parts; $oldController = Yii::$app->controller; Yii::$app->controller = $controller; $result = $controller->runAction($actionID, $params); if ($oldController !== null) { Yii::$app->controller = $oldController; } return $result; }
* @param string $route * @param array $params * @return Response|null The result of the action, normalized into a Response object */ public function runAction($route, $params = []) { $result = parent::runAction($route, $params); if ($result !== null) { if ($result instanceof Response) { return $result; }
$params = $this->catchAll; unset($params[0]); } try { Yii::debug("Route requested: '$route'", __METHOD__); $this->requestedRoute = $route; $result = $this->runAction($route, $params); if ($result instanceof Response) { return $result; } $response = $this->getResponse(); if ($result !== null) {
if (($response = $this->_processActionRequest($request)) !== null) { return $response; } // If we're still here, finally let Yii do it's thing. try { return parent::handleRequest($request); } catch (\Throwable $e) { $this->_unregisterDebugModule(); throw $e; } }
{ try { $this->state = self::STATE_BEFORE_REQUEST; $this->trigger(self::EVENT_BEFORE_REQUEST); $this->state = self::STATE_HANDLING_REQUEST; $response = $this->handleRequest($this->getRequest()); $this->state = self::STATE_AFTER_REQUEST; $this->trigger(self::EVENT_AFTER_REQUEST); $this->state = self::STATE_SENDING_RESPONSE; $response->send();
} // Load and run Craft define('CRAFT_ENVIRONMENT', getenv('ENVIRONMENT') ?: 'production'); /** @var craft\web\Application $app */ $app = require CRAFT_VENDOR_PATH.'/craftcms/cms/bootstrap/web.php'; $app->run();