<?php
namespace Koselig\Routing;
use Illuminate\Http\Request;
use Illuminate\Routing\Route;
use Koselig\Models\Post;
use Koselig\Support\Wordpress;
use ReflectionFunction;
* Template route, this route is matched then the Wordpress
* template set in the backend equals the slug of this route.
*
* @author Jordan Doyle <jordan@doyle.wf>
*/
class TemplateRoute extends Route
{
* Format a nice string for php artisan route:list.
*
* @return string
*/
public function uri()
{
return 'template/' . parent::uri();
}
* Run the route action and return the response.
*
* @return mixed
*/
protected function runCallable()
{
$function = new ReflectionFunction($this->action['uses']);
$params = $function->getParameters();
foreach ($params as $param) {
if ($param->getClass()
&& ($param->getClass()->isSubclassOf(Post::class) || $param->getClass()->getName() === Post::class)) {
$builder = $param->getClass()->getMethod('query')->invoke(null);
$post = $builder->find(Wordpress::id());
$this->setParameter($param->getName(), $post);
}
}
return parent::runCallable();
}
* Determine if the route matches given request.
*
* @param \Illuminate\Http\Request $request
* @param bool $includingMethod
* @return bool
*/
public function matches(Request $request, $includingMethod = true)
{
$slug = Wordpress::templateSlug();
if (!$slug) {
return false;
}
if (!empty($this->getAction()['domain']) && !Wordpress::multisite($this->getAction()['domain'])) {
return false;
}
return $this->uri === $slug;
}
}