2016-10-20 22:09:36 -04:00
|
|
|
<?php declare(strict_types=1);
|
2015-09-14 19:54:34 -04:00
|
|
|
/**
|
2017-02-16 11:09:37 -05:00
|
|
|
* Hummingbird Anime List Client
|
2015-11-16 11:40:01 -05:00
|
|
|
*
|
2017-02-16 11:09:37 -05:00
|
|
|
* An API client for Kitsu and MyAnimeList to manage anime and manga watch lists
|
2015-11-16 11:40:01 -05:00
|
|
|
*
|
2016-10-20 22:09:36 -04:00
|
|
|
* PHP version 7
|
2016-08-30 10:01:18 -04:00
|
|
|
*
|
2015-11-16 11:40:01 -05:00
|
|
|
* @package HummingbirdAnimeClient
|
2016-08-30 10:01:18 -04:00
|
|
|
* @author Timothy J. Warren <tim@timshomepage.net>
|
2017-02-16 11:09:37 -05:00
|
|
|
* @copyright 2015 - 2017 Timothy J. Warren
|
2016-08-30 10:01:18 -04:00
|
|
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
2017-02-16 11:09:37 -05:00
|
|
|
* @version 4.0
|
2017-03-07 20:53:58 -05:00
|
|
|
* @link https://git.timshomepage.net/timw4mail/HummingBirdAnimeClient
|
2015-09-14 19:54:34 -04:00
|
|
|
*/
|
2016-10-20 22:09:36 -04:00
|
|
|
|
2015-09-15 13:19:29 -04:00
|
|
|
namespace Aviat\AnimeClient;
|
2015-06-26 16:39:10 -04:00
|
|
|
|
2015-10-20 15:59:51 -04:00
|
|
|
use Aviat\Ion\Di\ContainerInterface;
|
2017-02-15 15:56:10 -05:00
|
|
|
use InvalidArgumentException;
|
2015-10-20 15:59:51 -04:00
|
|
|
|
2015-06-26 12:03:42 -04:00
|
|
|
/**
|
2015-09-14 10:54:50 -04:00
|
|
|
* UrlGenerator class.
|
2015-06-26 12:03:42 -04:00
|
|
|
*/
|
2015-09-14 15:49:20 -04:00
|
|
|
class UrlGenerator extends RoutingBase {
|
2015-07-02 14:04:04 -04:00
|
|
|
|
2015-10-20 15:59:51 -04:00
|
|
|
/**
|
|
|
|
* The current HTTP host
|
2016-08-30 10:57:41 -04:00
|
|
|
* @var string
|
2015-10-20 15:59:51 -04:00
|
|
|
*/
|
|
|
|
protected $host;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*
|
|
|
|
* @param ContainerInterface $container
|
|
|
|
*/
|
|
|
|
public function __construct(ContainerInterface $container)
|
|
|
|
{
|
|
|
|
parent::__construct($container);
|
2016-02-16 16:28:44 -05:00
|
|
|
$this->host = $container->get('request')->getServerParams()['HTTP_HOST'];
|
2015-10-20 15:59:51 -04:00
|
|
|
}
|
|
|
|
|
2015-07-02 14:04:04 -04:00
|
|
|
/**
|
|
|
|
* Get the base url for css/js/images
|
|
|
|
*
|
2017-02-17 10:55:17 -05:00
|
|
|
* @param string ...$args url segments to apend to the base asset url
|
2015-07-02 14:04:04 -04:00
|
|
|
* @return string
|
|
|
|
*/
|
2017-02-17 10:55:17 -05:00
|
|
|
public function assetUrl(...$args): string
|
2015-07-02 14:04:04 -04:00
|
|
|
{
|
2017-02-15 15:56:10 -05:00
|
|
|
$baseUrl = rtrim($this->url(""), '/');
|
|
|
|
$baseUrl = "{$baseUrl}" . $this->__get("asset_path");
|
2015-09-14 15:49:20 -04:00
|
|
|
|
2017-02-15 15:56:10 -05:00
|
|
|
array_unshift($args, $baseUrl);
|
2015-07-02 14:04:04 -04:00
|
|
|
|
|
|
|
return implode("/", $args);
|
|
|
|
}
|
|
|
|
|
2015-09-14 10:54:50 -04:00
|
|
|
/**
|
|
|
|
* Generate a proper url from the path
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-02-17 10:55:17 -05:00
|
|
|
public function url(string $path): string
|
2015-09-14 10:54:50 -04:00
|
|
|
{
|
|
|
|
$path = trim($path, '/');
|
|
|
|
|
|
|
|
$path = preg_replace('`{/.*?}`i', '', $path);
|
|
|
|
|
2015-10-20 15:59:51 -04:00
|
|
|
// Remove any optional parameters from the route
|
|
|
|
// and replace them with existing route parameters, if they exist
|
|
|
|
$path_segments = explode('/', $path);
|
2015-11-04 16:53:22 -05:00
|
|
|
$segment_count = count($path_segments);
|
2015-10-20 15:59:51 -04:00
|
|
|
$segments = $this->segments();
|
|
|
|
|
2015-11-04 16:53:22 -05:00
|
|
|
for ($i = 0; $i < $segment_count; $i++)
|
2015-10-20 15:59:51 -04:00
|
|
|
{
|
|
|
|
if ( ! array_key_exists($i + 1, $segments))
|
|
|
|
{
|
|
|
|
$segments[$i + 1] = "";
|
|
|
|
}
|
|
|
|
|
|
|
|
$path_segments[$i] = preg_replace('`{.*?}`i', $segments[$i + 1], $path_segments[$i]);
|
|
|
|
}
|
|
|
|
$path = implode('/', $path_segments);
|
2015-09-14 10:54:50 -04:00
|
|
|
|
2015-10-20 15:59:51 -04:00
|
|
|
return "//{$this->host}/{$path}";
|
2015-09-14 10:54:50 -04:00
|
|
|
}
|
|
|
|
|
2015-09-14 15:49:20 -04:00
|
|
|
/**
|
|
|
|
* Full default path for the list pages
|
|
|
|
*
|
|
|
|
* @param string $type
|
2017-02-15 15:56:10 -05:00
|
|
|
* @throws InvalidArgumentException
|
2015-09-14 15:49:20 -04:00
|
|
|
* @return string
|
|
|
|
*/
|
2017-02-17 10:55:17 -05:00
|
|
|
public function defaultUrl(string $type): string
|
2015-09-14 10:54:50 -04:00
|
|
|
{
|
|
|
|
$type = trim($type);
|
2017-02-15 15:56:10 -05:00
|
|
|
$defaultPath = $this->__get("default_{$type}_list_path");
|
2015-09-14 10:54:50 -04:00
|
|
|
|
2017-02-15 15:56:10 -05:00
|
|
|
if ( ! is_null($defaultPath))
|
2015-09-14 10:54:50 -04:00
|
|
|
{
|
2017-02-15 15:56:10 -05:00
|
|
|
return $this->url("{$type}/{$defaultPath}");
|
2015-09-14 10:54:50 -04:00
|
|
|
}
|
|
|
|
|
2017-02-15 15:56:10 -05:00
|
|
|
throw new InvalidArgumentException("Invalid default type: '{$type}'");
|
2015-09-14 10:54:50 -04:00
|
|
|
}
|
|
|
|
|
2015-07-02 14:04:04 -04:00
|
|
|
/**
|
|
|
|
* Generate full url path from the route path based on config
|
|
|
|
*
|
|
|
|
* @param string $path - (optional) The route path
|
|
|
|
* @param string $type - (optional) The controller (anime or manga), defaults to anime
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-02-17 10:55:17 -05:00
|
|
|
public function fullUrl(string $path = "", string $type = "anime"): string
|
2015-07-02 14:04:04 -04:00
|
|
|
{
|
2017-02-17 10:55:17 -05:00
|
|
|
$configDefaultRoute = $this->__get("default_{$type}_path");
|
2015-07-02 14:04:04 -04:00
|
|
|
|
|
|
|
// Remove beginning/trailing slashes
|
|
|
|
$path = trim($path, '/');
|
|
|
|
|
|
|
|
// Set the default view
|
|
|
|
if ($path === '')
|
|
|
|
{
|
2017-02-17 10:55:17 -05:00
|
|
|
$path .= trim($configDefaultRoute, '/');
|
2015-11-09 11:10:15 -05:00
|
|
|
if ($this->__get('default_to_list_view'))
|
|
|
|
{
|
|
|
|
$path .= '/list';
|
|
|
|
}
|
2015-07-02 14:04:04 -04:00
|
|
|
}
|
|
|
|
|
2015-10-20 15:59:51 -04:00
|
|
|
return $this->url($path);
|
2015-07-02 14:04:04 -04:00
|
|
|
}
|
2015-06-26 12:03:42 -04:00
|
|
|
}
|
2015-10-06 12:15:19 -04:00
|
|
|
// End of UrlGenerator.php
|