2017 © Pedro Peláez
 

library url-builder

Url builder

image

petrgrishin/url-builder

Url builder

  • Monday, August 11, 2014
  • by petrgrishin
  • Repository
  • 2 Watchers
  • 2 Stars
  • 11 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

url-builder

Travis CI Coverage Status, (*1)

Url builder, (*2)

Установка

Добавите зависимость для вашего проекта в composer.json:, (*3)

{
    "require": {
        "petrgrishin/url-builder": "~1.0"
    }
}

Постановка проблемы

Необходимо определить знание об адресе контроллеров в одном слое сисстемы. Это позволит быстро и безболезненно производить поиск и рефакторинг контроллеров и их адресов., (*4)

Реализовать проверку достаточности параметров построения адреса, если такое происходит в другом слое, например в представлении или клиентских скриптах., (*5)

Решение

Все адреса контроллеров должны быть определены в самих контроллерах. При необходимости недостающие параметры можно заполнить в слое представления или клиентского скрипта. Для удобной работы необходимо определить помощника - построитель адресов., (*6)

Примеры использования

Определение знания об адресе в контроллере

Базовый абстрактный контроллер. Реализация метода создания обектов построителя адреса, (*7)

class BaseController extends \CController {

    public function createUrlBuilder($route, $params = array()) {
        $urlBuilder = new SimpleUrlBuilder();
        $urlBuilder
            ->setRoute($route)
            ->setParams($params);
        return $urlBuilder;
    }
}

Конкретный контроллер. Использование построителя адреса, (*8)

class SiteController extends BaseController {

    public function actionIndex() {
        return $this->render('index', array(
            'urls' => array(
                'catalog' => $this->createUrlBuilder('site/catalog')
                    ->getUrl(),
                // передана готовая строка адреса /?r=site/catalog
            ),
        ));
    }

    public function actionCatalog() {
        return $this->render('about', array(
            'products' => Product::model()->findAll(),
            'urls' => array(
                'product' => $this->createUrlBuilder('site/product')
                    ->setRequired(array('id')),
                // передан объект построителя с необходимыми знаниями,
                // требуемые параметры заполняются в представлении
            ),
        ));
    }

    public function actionProduct($id) {
        return $this->render('product');
    }
}

Представление вывода каталога товаров, (*9)

/** @var UrlBuilder $productUrlBuilder */
$productUrlBuilder = $this->getParam('urls.product');

foreach ($this->getParam('products') as $product) {
    $productUrl = $productUrlBuilder
        ->copy()
        ->setParam('id', $product->id)
        ->getUrl();

    print($productUrl);
    // строка адреса /?r=site/product&id=1
}

// или передать параметры построителя адреса в клиентский скрипт
$this->setJsParams(array(
    'urls' => array(
        'product' => $productUrlBuilder->toArray(),
    ),
));

The Versions

11/08 2014

dev-master

9999999-dev

Url builder

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

by Petr Grishin

11/08 2014

2.0.0

2.0.0.0

Url builder

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

by Petr Grishin

07/08 2014

1.0.2

1.0.2.0

Url builder

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

by Petr Grishin

05/08 2014

1.0.1

1.0.1.0

Url builder

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

by Petr Grishin

04/08 2014

1.0.0

1.0.0.0

Url builder

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

by Petr Grishin