mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-27 17:22:42 +01:00
8756d82cf6
Summary: I'm pretty sure that `@group` annotations are useless now... see D9855. Also fixed various other minor issues. Test Plan: Eye-ball it. Reviewers: #blessed_reviewers, epriestley, chad Reviewed By: #blessed_reviewers, epriestley Subscribers: epriestley, Korvin, hach-que Differential Revision: https://secure.phabricator.com/D9859
50 lines
1.1 KiB
PHP
50 lines
1.1 KiB
PHP
<?php
|
|
|
|
final class AphrontURIMapper {
|
|
|
|
private $map;
|
|
|
|
final public function __construct(array $map) {
|
|
$this->map = $map;
|
|
}
|
|
|
|
final public function mapPath($path) {
|
|
$map = $this->map;
|
|
foreach ($map as $rule => $value) {
|
|
list($controller, $data) = $this->tryRule($rule, $value, $path);
|
|
if ($controller) {
|
|
foreach ($data as $k => $v) {
|
|
if (is_numeric($k)) {
|
|
unset($data[$k]);
|
|
}
|
|
}
|
|
return array($controller, $data);
|
|
}
|
|
}
|
|
|
|
return array(null, null);
|
|
}
|
|
|
|
final private function tryRule($rule, $value, $path) {
|
|
$match = null;
|
|
$pattern = '#^'.$rule.(is_array($value) ? '' : '$').'#';
|
|
if (!preg_match($pattern, $path, $match)) {
|
|
return array(null, null);
|
|
}
|
|
|
|
if (!is_array($value)) {
|
|
return array($value, $match);
|
|
}
|
|
|
|
$path = substr($path, strlen($match[0]));
|
|
foreach ($value as $srule => $sval) {
|
|
list($controller, $data) = $this->tryRule($srule, $sval, $path);
|
|
if ($controller) {
|
|
return array($controller, $data + $match);
|
|
}
|
|
}
|
|
|
|
return array(null, null);
|
|
}
|
|
|
|
}
|