Commit a4b23e811d08175f8c2c7440db89d4a00bff066a

Authored by eduardo.batista
0 parents
Exists in master and in 1 other branch desenv

Primeiro commit

Showing 194 changed files with 19750 additions and 0 deletions   Show diff stats

Too many changes.

To preserve performance only 100 of 194 files displayed.

MdWsSeiRest.php 0 → 100644
  1 +++ a/MdWsSeiRest.php
... ... @@ -0,0 +1,120 @@
  1 +<?
  2 +/**
  3 + * Eduardo Romao
  4 + *
  5 + * 26/03/2017 - criado por ejushiro@gmail.com
  6 + *
  7 + */
  8 +
  9 +class MdWsSeiRest extends SeiIntegracao{
  10 +
  11 + public function __construct(){
  12 + }
  13 +
  14 + public function getNome(){
  15 + return 'Módulo de provisionamento de serviços REST do SEI';
  16 + }
  17 +
  18 + public function getVersao() {
  19 + return '1.0.0';
  20 + }
  21 +
  22 + public function getInstituicao(){
  23 + return 'wssei';
  24 + }
  25 +
  26 + public function inicializar($strVersaoSEI){
  27 + if (substr($strVersaoSEI, 0, 2) != '3.'){
  28 + die('Módulo "'.$this->getNome().'" ('.$this->getVersao().') não e compatível com esta versão do SEI ('.$strVersaoSEI.').');
  29 + }
  30 + }
  31 +
  32 + public function montarBotaoControleProcessos(){
  33 + return array();
  34 + }
  35 +
  36 + public function montarIconeControleProcessos($arrObjProcedimentoAPI){
  37 + return array();
  38 + }
  39 +
  40 + public function montarIconeAcompanhamentoEspecial($arrObjProcedimentoAPI){
  41 + return array();
  42 + }
  43 +
  44 + public function montarIconeProcesso(ProcedimentoAPI $objProcedimentoAPI){
  45 + return array();
  46 + }
  47 +
  48 + public function montarBotaoProcesso(ProcedimentoAPI $objProcedimentoAPI){
  49 + return array();
  50 + }
  51 +
  52 + public function montarIconeDocumento(ProcedimentoAPI $objProcedimentoAPI, $arrObjDocumentoAPI){
  53 + return array();
  54 + }
  55 +
  56 + public function montarBotaoDocumento(ProcedimentoAPI $objProcedimentoAPI, $arrObjDocumentoAPI){
  57 + return array();
  58 + }
  59 +
  60 + public function alterarIconeArvoreDocumento(ProcedimentoAPI $objProcedimentoAPI, $arrObjDocumentoAPI){
  61 + return array();
  62 + }
  63 +
  64 + public function montarMenuPublicacoes(){
  65 + return array();
  66 + }
  67 +
  68 + public function montarMenuUsuarioExterno(){
  69 + return array();
  70 + }
  71 +
  72 + public function montarAcaoControleAcessoExterno($arrObjAcessoExternoAPI){
  73 + return array();
  74 + }
  75 +
  76 + public function montarAcaoDocumentoAcessoExternoAutorizado($arrObjDocumentoAPI){
  77 + return array();
  78 + }
  79 +
  80 + public function montarAcaoProcessoAnexadoAcessoExternoAutorizado($arrObjProcedimentoAPI){
  81 + return array();
  82 + }
  83 +
  84 + public function montarBotaoAcessoExternoAutorizado(ProcedimentoAPI $objProcedimentoAPI){
  85 + return array();
  86 + }
  87 +
  88 + public function montarBotaoControleAcessoExterno(){
  89 + return array();
  90 + }
  91 +
  92 + public function processarControlador($strAcao){
  93 + return false;
  94 + }
  95 +
  96 + public function processarControladorAjax($strAcao){
  97 + return null;
  98 + }
  99 +
  100 + public function processarControladorPublicacoes($strAcao){
  101 + return false;
  102 + }
  103 +
  104 + public function processarControladorExterno($strAcao){
  105 + return false;
  106 + }
  107 +
  108 + public function verificarAcessoProtocolo($arrObjProcedimentoAPI, $arrObjDocumentoAPI){
  109 + return null;
  110 + }
  111 +
  112 + public function verificarAcessoProtocoloExterno($arrObjProcedimentoAPI, $arrObjDocumentoAPI){
  113 + return null;
  114 + }
  115 +
  116 + public function montarMensagemProcesso(ProcedimentoAPI $objProcedimentoAPI){
  117 + return null;
  118 + }
  119 +}
  120 +?>
0 121 \ No newline at end of file
... ...
composer.json 0 → 100644
  1 +++ a/composer.json
... ... @@ -0,0 +1,5 @@
  1 +{
  2 + "require": {
  3 + "slim/slim": "^3.7"
  4 + }
  5 +}
... ...
composer.lock 0 → 100644
  1 +++ a/composer.lock
... ... @@ -0,0 +1,307 @@
  1 +{
  2 + "_readme": [
  3 + "This file locks the dependencies of your project to a known state",
  4 + "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
  5 + "This file is @generated automatically"
  6 + ],
  7 + "content-hash": "4fed3f4a9903f9831848f1f17fe73591",
  8 + "packages": [
  9 + {
  10 + "name": "container-interop/container-interop",
  11 + "version": "1.2.0",
  12 + "source": {
  13 + "type": "git",
  14 + "url": "https://github.com/container-interop/container-interop.git",
  15 + "reference": "79cbf1341c22ec75643d841642dd5d6acd83bdb8"
  16 + },
  17 + "dist": {
  18 + "type": "zip",
  19 + "url": "https://api.github.com/repos/container-interop/container-interop/zipball/79cbf1341c22ec75643d841642dd5d6acd83bdb8",
  20 + "reference": "79cbf1341c22ec75643d841642dd5d6acd83bdb8",
  21 + "shasum": ""
  22 + },
  23 + "require": {
  24 + "psr/container": "^1.0"
  25 + },
  26 + "type": "library",
  27 + "autoload": {
  28 + "psr-4": {
  29 + "Interop\\Container\\": "src/Interop/Container/"
  30 + }
  31 + },
  32 + "notification-url": "https://packagist.org/downloads/",
  33 + "license": [
  34 + "MIT"
  35 + ],
  36 + "description": "Promoting the interoperability of container objects (DIC, SL, etc.)",
  37 + "homepage": "https://github.com/container-interop/container-interop",
  38 + "time": "2017-02-14T19:40:03+00:00"
  39 + },
  40 + {
  41 + "name": "nikic/fast-route",
  42 + "version": "v1.2.0",
  43 + "source": {
  44 + "type": "git",
  45 + "url": "https://github.com/nikic/FastRoute.git",
  46 + "reference": "b5f95749071c82a8e0f58586987627054400cdf6"
  47 + },
  48 + "dist": {
  49 + "type": "zip",
  50 + "url": "https://api.github.com/repos/nikic/FastRoute/zipball/b5f95749071c82a8e0f58586987627054400cdf6",
  51 + "reference": "b5f95749071c82a8e0f58586987627054400cdf6",
  52 + "shasum": ""
  53 + },
  54 + "require": {
  55 + "php": ">=5.4.0"
  56 + },
  57 + "type": "library",
  58 + "autoload": {
  59 + "psr-4": {
  60 + "FastRoute\\": "src/"
  61 + },
  62 + "files": [
  63 + "src/functions.php"
  64 + ]
  65 + },
  66 + "notification-url": "https://packagist.org/downloads/",
  67 + "license": [
  68 + "BSD-3-Clause"
  69 + ],
  70 + "authors": [
  71 + {
  72 + "name": "Nikita Popov",
  73 + "email": "nikic@php.net"
  74 + }
  75 + ],
  76 + "description": "Fast request router for PHP",
  77 + "keywords": [
  78 + "router",
  79 + "routing"
  80 + ],
  81 + "time": "2017-01-19T11:35:12+00:00"
  82 + },
  83 + {
  84 + "name": "pimple/pimple",
  85 + "version": "v3.0.2",
  86 + "source": {
  87 + "type": "git",
  88 + "url": "https://github.com/silexphp/Pimple.git",
  89 + "reference": "a30f7d6e57565a2e1a316e1baf2a483f788b258a"
  90 + },
  91 + "dist": {
  92 + "type": "zip",
  93 + "url": "https://api.github.com/repos/silexphp/Pimple/zipball/a30f7d6e57565a2e1a316e1baf2a483f788b258a",
  94 + "reference": "a30f7d6e57565a2e1a316e1baf2a483f788b258a",
  95 + "shasum": ""
  96 + },
  97 + "require": {
  98 + "php": ">=5.3.0"
  99 + },
  100 + "type": "library",
  101 + "extra": {
  102 + "branch-alias": {
  103 + "dev-master": "3.0.x-dev"
  104 + }
  105 + },
  106 + "autoload": {
  107 + "psr-0": {
  108 + "Pimple": "src/"
  109 + }
  110 + },
  111 + "notification-url": "https://packagist.org/downloads/",
  112 + "license": [
  113 + "MIT"
  114 + ],
  115 + "authors": [
  116 + {
  117 + "name": "Fabien Potencier",
  118 + "email": "fabien@symfony.com"
  119 + }
  120 + ],
  121 + "description": "Pimple, a simple Dependency Injection Container",
  122 + "homepage": "http://pimple.sensiolabs.org",
  123 + "keywords": [
  124 + "container",
  125 + "dependency injection"
  126 + ],
  127 + "time": "2015-09-11T15:10:35+00:00"
  128 + },
  129 + {
  130 + "name": "psr/container",
  131 + "version": "1.0.0",
  132 + "source": {
  133 + "type": "git",
  134 + "url": "https://github.com/php-fig/container.git",
  135 + "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f"
  136 + },
  137 + "dist": {
  138 + "type": "zip",
  139 + "url": "https://api.github.com/repos/php-fig/container/zipball/b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
  140 + "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
  141 + "shasum": ""
  142 + },
  143 + "require": {
  144 + "php": ">=5.3.0"
  145 + },
  146 + "type": "library",
  147 + "extra": {
  148 + "branch-alias": {
  149 + "dev-master": "1.0.x-dev"
  150 + }
  151 + },
  152 + "autoload": {
  153 + "psr-4": {
  154 + "Psr\\Container\\": "src/"
  155 + }
  156 + },
  157 + "notification-url": "https://packagist.org/downloads/",
  158 + "license": [
  159 + "MIT"
  160 + ],
  161 + "authors": [
  162 + {
  163 + "name": "PHP-FIG",
  164 + "homepage": "http://www.php-fig.org/"
  165 + }
  166 + ],
  167 + "description": "Common Container Interface (PHP FIG PSR-11)",
  168 + "homepage": "https://github.com/php-fig/container",
  169 + "keywords": [
  170 + "PSR-11",
  171 + "container",
  172 + "container-interface",
  173 + "container-interop",
  174 + "psr"
  175 + ],
  176 + "time": "2017-02-14T16:28:37+00:00"
  177 + },
  178 + {
  179 + "name": "psr/http-message",
  180 + "version": "1.0.1",
  181 + "source": {
  182 + "type": "git",
  183 + "url": "https://github.com/php-fig/http-message.git",
  184 + "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363"
  185 + },
  186 + "dist": {
  187 + "type": "zip",
  188 + "url": "https://api.github.com/repos/php-fig/http-message/zipball/f6561bf28d520154e4b0ec72be95418abe6d9363",
  189 + "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363",
  190 + "shasum": ""
  191 + },
  192 + "require": {
  193 + "php": ">=5.3.0"
  194 + },
  195 + "type": "library",
  196 + "extra": {
  197 + "branch-alias": {
  198 + "dev-master": "1.0.x-dev"
  199 + }
  200 + },
  201 + "autoload": {
  202 + "psr-4": {
  203 + "Psr\\Http\\Message\\": "src/"
  204 + }
  205 + },
  206 + "notification-url": "https://packagist.org/downloads/",
  207 + "license": [
  208 + "MIT"
  209 + ],
  210 + "authors": [
  211 + {
  212 + "name": "PHP-FIG",
  213 + "homepage": "http://www.php-fig.org/"
  214 + }
  215 + ],
  216 + "description": "Common interface for HTTP messages",
  217 + "homepage": "https://github.com/php-fig/http-message",
  218 + "keywords": [
  219 + "http",
  220 + "http-message",
  221 + "psr",
  222 + "psr-7",
  223 + "request",
  224 + "response"
  225 + ],
  226 + "time": "2016-08-06T14:39:51+00:00"
  227 + },
  228 + {
  229 + "name": "slim/slim",
  230 + "version": "3.7.0",
  231 + "source": {
  232 + "type": "git",
  233 + "url": "https://github.com/slimphp/Slim.git",
  234 + "reference": "4254e40d81559e35cdf856bcbaca5f3af468b7ef"
  235 + },
  236 + "dist": {
  237 + "type": "zip",
  238 + "url": "https://api.github.com/repos/slimphp/Slim/zipball/4254e40d81559e35cdf856bcbaca5f3af468b7ef",
  239 + "reference": "4254e40d81559e35cdf856bcbaca5f3af468b7ef",
  240 + "shasum": ""
  241 + },
  242 + "require": {
  243 + "container-interop/container-interop": "^1.1",
  244 + "nikic/fast-route": "^1.0",
  245 + "php": ">=5.5.0",
  246 + "pimple/pimple": "^3.0",
  247 + "psr/http-message": "^1.0"
  248 + },
  249 + "provide": {
  250 + "psr/http-message-implementation": "1.0"
  251 + },
  252 + "require-dev": {
  253 + "phpunit/phpunit": "^4.0",
  254 + "squizlabs/php_codesniffer": "^2.5"
  255 + },
  256 + "type": "library",
  257 + "autoload": {
  258 + "psr-4": {
  259 + "Slim\\": "Slim"
  260 + }
  261 + },
  262 + "notification-url": "https://packagist.org/downloads/",
  263 + "license": [
  264 + "MIT"
  265 + ],
  266 + "authors": [
  267 + {
  268 + "name": "Rob Allen",
  269 + "email": "rob@akrabat.com",
  270 + "homepage": "http://akrabat.com"
  271 + },
  272 + {
  273 + "name": "Josh Lockhart",
  274 + "email": "hello@joshlockhart.com",
  275 + "homepage": "https://joshlockhart.com"
  276 + },
  277 + {
  278 + "name": "Gabriel Manricks",
  279 + "email": "gmanricks@me.com",
  280 + "homepage": "http://gabrielmanricks.com"
  281 + },
  282 + {
  283 + "name": "Andrew Smith",
  284 + "email": "a.smith@silentworks.co.uk",
  285 + "homepage": "http://silentworks.co.uk"
  286 + }
  287 + ],
  288 + "description": "Slim is a PHP micro framework that helps you quickly write simple yet powerful web applications and APIs",
  289 + "homepage": "https://slimframework.com",
  290 + "keywords": [
  291 + "api",
  292 + "framework",
  293 + "micro",
  294 + "router"
  295 + ],
  296 + "time": "2016-12-20T20:30:47+00:00"
  297 + }
  298 + ],
  299 + "packages-dev": [],
  300 + "aliases": [],
  301 + "minimum-stability": "stable",
  302 + "stability-flags": [],
  303 + "prefer-stable": false,
  304 + "prefer-lowest": false,
  305 + "platform": [],
  306 + "platform-dev": []
  307 +}
... ...
composer.phar 0 → 100644
No preview for this file type
controlador_ws.php 0 → 100644
  1 +++ a/controlador_ws.php
... ... @@ -0,0 +1,104 @@
  1 +<?
  2 +/**
  3 + * Controlador (API v1) de servicos REST usando o framework Slim
  4 + */
  5 +
  6 +require_once dirname(__FILE__).'/../../SEI.php';
  7 +require_once dirname(__FILE__).'/vendor/autoload.php';
  8 +
  9 +class TokenValidationMiddleware{
  10 + public function __invoke($request, $response, $next)
  11 + {
  12 + /** @var $request Slim\Http\Request */
  13 + /** @var $response Slim\Http\Response */
  14 + $token = $request->getHeader('token');
  15 +
  16 + if(!$token){
  17 + return $response->withJson(array('sucesso' => false, 'mensagem' => 'Acesso negado!'), 401);
  18 + }
  19 + $rn = new MdWsSeiUsuarioRN();
  20 + $result = $rn->autenticarToken($token[0]);
  21 + if(!$result['sucesso']){
  22 + var_dump($result);
  23 + return $response->withJson($result, 403);
  24 + }
  25 + $response = $next($request, $response);
  26 + return $response;
  27 + }
  28 +}
  29 +
  30 +$config = array(
  31 + 'settings' => array(
  32 + 'determineRouteBeforeAppMiddleware' => true,
  33 + 'displayErrorDetails' => true
  34 + )
  35 +);
  36 +
  37 +$app = new \Slim\App($config);
  38 +/**
  39 + * Grupo para a versao v1 de servicos REST
  40 + */
  41 +$app->group('/v1',function(){
  42 + /**
  43 + * Grupo de autenticacao <publico>
  44 + */
  45 + $this->post('/autenticar', function($request, $response, $args){
  46 + var_dump(111);exit;
  47 + $rn = new MdWsSeiUsuarioRN();
  48 + $usuarioDTO = new UsuarioDTO();
  49 + $usuarioDTO->setStrSigla($request->getParam('usuario'));
  50 + $usuarioDTO->setStrSenha($request->getParam('senha'));
  51 +
  52 + return $response->withJSON($rn->autenticar($usuarioDTO));
  53 + });
  54 +
  55 + /**
  56 + * Grupo de controlador de anotacao
  57 + */
  58 + $this->group('/anotacao', function(){
  59 + $this->post('/', function($request, $response, $args){
  60 + $rn = new MdWsSeiAnotacaoRN();
  61 + $dto = $rn->encapsulaAnotacao($request->getParams());
  62 + return $response->withJSON($rn->cadastrarAnotacao($dto));
  63 + })->setName('v1_anotacao_cadastrar');
  64 +
  65 + })->add( new TokenValidationMiddleware());
  66 +
  67 + /**
  68 + * Grupo de controlador de bloco
  69 + */
  70 + $this->group('/bloco', function(){
  71 + $this->get('/listar/bloco/unidade/{unidade}', function($request, $response, $args){
  72 + /** @var $request Slim\Http\Request */
  73 + $rn = new MdWsSeiBlocoRN();
  74 + $dto = new UnidadeDTO();
  75 + $dto->setNumIdUnidade($request->getAttribute('route')->getArgument('unidade'));
  76 + $dto->setNumMaxRegistrosRetorno($request->getParam('limit'));
  77 + $dto->setNumPaginaAtual($request->getParam('start'));
  78 + return $response->withJSON($rn->listarBlocoUnidade($dto));
  79 + });
  80 + $this->get('/listar/bloco/documentos/{bloco}', function($request, $response, $args){
  81 + var_dump(111);exit;
  82 + /** @var $request Slim\Http\Request */
  83 + $rn = new MdWsSeiBlocoRN();
  84 + $dto = new BlocoDTO();
  85 + $dto->setNumIdBloco($request->getAttribute('route')->getArgument('bloco'));
  86 + $dto->setNumMaxRegistrosRetorno($request->getParam('limit'));
  87 + $dto->setNumPaginaAtual($request->getParam('start'));
  88 + return $response->withJSON($rn->listarDocumentosBloco($dto));
  89 + });
  90 +
  91 + })->add( new TokenValidationMiddleware());
  92 +});
  93 +
  94 +
  95 +$app->run();
  96 +$c = $app->getContainer();
  97 +$c['errorHandler'] = function ($c) {
  98 + return function ($request, $response, $exception) use ($c) {
  99 + var_dump($exception);exit;
  100 + return $c['response']->withStatus(500)
  101 + ->withHeader('Content-Type', 'text/html')
  102 + ->write('Something went wrong!');
  103 + };
  104 +};
... ...
dto/MdWsSeiProcessoDTO.php 0 → 100644
  1 +++ a/dto/MdWsSeiProcessoDTO.php
... ... @@ -0,0 +1,21 @@
  1 +<?
  2 +
  3 +/**
  4 + * Class MdWsSeiProcessoDTO
  5 + * DTO somente para encapsulamento de dados.
  6 + * OBS: Nao estou usando API pois em modulos do SEI o autoload nao carrega as API's.
  7 + */
  8 +class MdWsSeiProcessoDTO extends InfraDTO{
  9 +
  10 + public function getStrNomeTabela()
  11 + {
  12 + throw new InfraException('DTO nao utilizavel para consulta!');
  13 + }
  14 +
  15 + public function montar(){
  16 + $this->adicionarAtributo(InfraDTO::$PREFIXO_STR, 'Template');
  17 + $this->adicionarAtributo(InfraDTO::$PREFIXO_NUM, 'IdAtividade');
  18 + $this->adicionarAtributo(InfraDTO::$PREFIXO_STR, 'Valor');
  19 + }
  20 +
  21 +}
... ...
dto/MdWsSeiProtocoloDTO.php 0 → 100644
  1 +++ a/dto/MdWsSeiProtocoloDTO.php
... ... @@ -0,0 +1,52 @@
  1 +<?
  2 +
  3 +class MdWsSeiProtocoloDTO extends ProtocoloDTO{
  4 + CONST SIN_TIPO_BUSCA_M = 'M';
  5 + CONST SIN_TIPO_BUSCA_G = 'G';
  6 +
  7 + public function montar(){
  8 + parent::montar();
  9 +
  10 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_NUM,
  11 + 'idGrupoAcompanhamentoProcedimento',
  12 + 'id_grupo_acompanhamento',
  13 + 'acompanhamento');
  14 +
  15 +
  16 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_NUM,
  17 + 'IdUsuarioGeradorAcompanhamento',
  18 + 'id_usuario_gerador',
  19 + 'acompanhamento');
  20 +
  21 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_DTH,
  22 + 'GeracaoAcompanhamento',
  23 + 'dth_geracao',
  24 + 'acompanhamento');
  25 +
  26 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_NUM,
  27 + 'IdUsuarioAtribuicaoAtividade',
  28 + 'id_usuario_atribuicao',
  29 + 'atividade');
  30 +
  31 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_STR,
  32 + 'SinCienciaProcedimento',
  33 + 'p2.sin_ciencia',
  34 + 'procedimento p2');
  35 +
  36 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_DTH,
  37 + 'AberturaAtividade',
  38 + 'dth_abertura',
  39 + 'atividade');
  40 +
  41 + $this->adicionarAtributoTabelaRelacionada(InfraDTO::$PREFIXO_NUM,
  42 + 'IdUnidadeAtividade',
  43 + 'id_unidade',
  44 + 'atividade');
  45 +
  46 + $this->adicionarAtributo(InfraDTO::$PREFIXO_STR, 'SinTipoBusca');
  47 +
  48 + $this->configurarFK('IdProtocolo', 'procedimento p2', 'p2.id_procedimento', InfraDTO::$TIPO_FK_OBRIGATORIA);
  49 + $this->configurarFK('IdProtocolo', 'acompanhamento', 'id_protocolo');
  50 + }
  51 +
  52 +}
... ...
rn/MdWsSeiAcompanhamentoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiAcompanhamentoRN.php
... ... @@ -0,0 +1,63 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiAcompanhamentoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + public function encapsulaAcompanhamento(array $post){
  11 + $acompanhamentoDTO = new AcompanhamentoDTO();
  12 +
  13 + if (isset($post['protocolo'])){
  14 + $acompanhamentoDTO->setDblIdProtocolo($post['protocolo']);
  15 + }
  16 + if (isset($post['unidade'])){
  17 + $acompanhamentoDTO->setNumIdUnidade($post['unidade']);
  18 + }
  19 +
  20 + if (isset($post['grupo'])){
  21 + $acompanhamentoDTO->setNumIdGrupoAcompanhamento($post['grupo']);
  22 + }
  23 + if (isset($post['usuario'])){
  24 + $acompanhamentoDTO->setNumIdUsuarioGerador($post['usuario']);
  25 + }
  26 + if (isset($post['observacao'])){
  27 + $acompanhamentoDTO->setStrObservacao($post['observacao']);
  28 + }
  29 +
  30 + return $acompanhamentoDTO;
  31 +
  32 + }
  33 +
  34 + protected function cadastrarAcompanhamentoControlado(AcompanhamentoDTO $acompanhamentoDTO){
  35 + try{
  36 + $acompanhamentoRN = new AcompanhamentoRN();
  37 + $acompanhamentoDTO->setDthGeracao(InfraData::getStrDataHoraAtual());
  38 + $pesquisaDTO = new AcompanhamentoDTO();
  39 + $pesquisaDTO->setOrdNumIdAcompanhamento(InfraDTO::$TIPO_ORDENACAO_DESC);
  40 + $pesquisaDTO->setNumMaxRegistrosRetorno(1);
  41 + $pesquisaDTO->retNumIdAcompanhamento();
  42 + $result = $acompanhamentoRN->listar($pesquisaDTO);
  43 + $numIdAcompanhamento = 1;
  44 + if(!empty($result)){
  45 + $pesquisaDTO = end($result);
  46 + $numIdAcompanhamento = $pesquisaDTO->getNumIdAcompanhamento()+1;
  47 + }
  48 + $acompanhamentoDTO->setNumIdAcompanhamento($numIdAcompanhamento);
  49 + $acompanhamentoRN->cadastrar($acompanhamentoDTO);
  50 +
  51 + return array (
  52 + "sucesso" => true,
  53 + "mensagem" => 'Acompanhamento realizado com sucesso!'
  54 + );
  55 + }catch (Exception $e){
  56 + return array (
  57 + "sucesso" => false,
  58 + "mensagem" => $e->getMessage(),
  59 + "exception" => $e
  60 + );
  61 + }
  62 + }
  63 +}
0 64 \ No newline at end of file
... ...
rn/MdWsSeiAnotacaoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiAnotacaoRN.php
... ... @@ -0,0 +1,71 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiAnotacaoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + public function encapsulaAnotacao(array $post){
  11 + $anotacaoDTO = new AnotacaoDTO();
  12 + if (isset($post['descricao'])) {
  13 + $anotacaoDTO->setStrDescricao($post['descricao']);
  14 + }
  15 +
  16 +
  17 + if (isset($post['protocolo'])) {
  18 + $anotacaoDTO->setDblIdProtocolo($post['protocolo']);
  19 + }
  20 +
  21 + if (isset($post['unidade'])) {
  22 + $anotacaoDTO->setNumIdUnidade($post['unidade']);
  23 + }
  24 +
  25 + if (isset($post['usuario'])) {
  26 + $anotacaoDTO->setNumIdUsuario($post['usuario']);
  27 + }
  28 +
  29 + $anotacaoDTO->setDthAnotacao(InfraData::getStrDataHoraAtual());
  30 +
  31 + if (isset($post['prioridade'])) {
  32 + $anotacaoDTO->setStrSinPrioridade(
  33 + ($post['prioridade']) ? 'S' : 'N'
  34 + );
  35 + }
  36 + $anotacaoDTO->setStrStaAnotacao('U');
  37 +
  38 + return $anotacaoDTO;
  39 + }
  40 +
  41 + protected function cadastrarAnotacaoControlado(AnotacaoDTO $anotacaoDTO){
  42 + try{
  43 + $anotacaoRN = new AnotacaoRN();
  44 + if(!$anotacaoDTO->getDblIdProtocolo()){
  45 + throw new InfraException('Protocolo não informado.');
  46 + }
  47 + $anotacaoConsulta = new AnotacaoDTO();
  48 + $anotacaoConsulta->setDblIdProtocolo($anotacaoDTO->getDblIdProtocolo());
  49 + $anotacaoConsulta->setNumMaxRegistrosRetorno(1);
  50 + $anotacaoConsulta->retNumIdAnotacao();
  51 + $ret = $anotacaoRN->listar($anotacaoConsulta);
  52 + if($ret){
  53 + $anotacaoDTO->setNumIdAnotacao($ret[0]->getNumIdAnotacao());
  54 + $anotacaoRN->alterar($anotacaoDTO);
  55 + }else{
  56 + $anotacaoRN->cadastrar($anotacaoDTO);
  57 + }
  58 + return array (
  59 + "sucesso" => true,
  60 + "mensagem" => 'Anotação cadastrada com sucesso!'
  61 + );
  62 + }catch (Exception $e){
  63 + return array (
  64 + "sucesso" => false,
  65 + "mensagem" => $e->getMessage(),
  66 + "exception" => $e
  67 + );
  68 + }
  69 + }
  70 +
  71 +}
0 72 \ No newline at end of file
... ...
rn/MdWsSeiAssinanteRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiAssinanteRN.php
... ... @@ -0,0 +1,48 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiAssinanteRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * Retorna todas as funcoes/cargos cadastrados
  12 + * @param AssinanteDTO $assinanteDTO
  13 + * @info Para retornar a consulta paginada e necessario passar dentro do DTO os parametros:
  14 + * - setNumMaxRegistrosRetorno - maximo de registros por pagina (limit)
  15 + * - setNumPaginaAtual - pagina atual (offset)
  16 + * @return array
  17 + */
  18 + protected function listarAssinanteConectado(AssinanteDTO $assinanteDTO){
  19 + try{
  20 + $result = array();
  21 + $assinanteDTO->retNumIdAssinante();
  22 + $assinanteDTO->retStrCargoFuncao();
  23 + $assinanteDTO->setOrdStrCargoFuncao(InfraDTO::$TIPO_ORDENACAO_ASC);
  24 + $assinanteRN = new AssinanteRN();
  25 + $ret = $assinanteRN->pesquisar($assinanteDTO);
  26 + /** @var AssinanteDTO $assinDTO */
  27 + foreach($ret as $assinDTO){
  28 + $result[] = array(
  29 + 'id' => $assinDTO->getNumIdAssinante(),
  30 + 'nome' => $assinDTO->getStrCargoFuncao(),
  31 + );
  32 + }
  33 +
  34 + return array(
  35 + 'sucesso' => true,
  36 + 'data' => $result,
  37 + 'total' => $assinanteDTO->getNumTotalRegistros()
  38 + );
  39 + }catch (Exception $e){
  40 + return array(
  41 + 'sucesso' => false,
  42 + 'mensagem' => $e->getMessage(),
  43 + 'exception' => $e
  44 + );
  45 + }
  46 + }
  47 +
  48 +}
0 49 \ No newline at end of file
... ...
rn/MdWsSeiAtividadeRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiAtividadeRN.php
... ... @@ -0,0 +1,175 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiAtividadeRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + private function traduzirTemplate(AtividadeDTO $atividadeDTO, ProtocoloDTO $protocoloDTO) {
  11 + $arrParameters = ['DOCUMENTO', 'DOCUMENTOS', 'NIVEL_ACESSO', 'GRAU_SIGILO', 'HIPOTESE_LEGAL', 'DATA_AUTUACAO', 'TIPO_CONFERENCIA',
  12 + 'PROCESSO', 'USUARIO', 'USUARIOS', 'UNIDADE', 'BLOCO', 'DATA_HORA', 'USUARIO_ANULACAO', 'INTERESSADO', 'LOCALIZADOR', 'ANEXO',
  13 + 'USUARIO_EXTERNO_NOME', 'USUARIO_EXTERNO_SIGLA', 'DATA', 'DESTINATARIO_NOME', 'DESTINATARIO_EMAIL', 'DATA_VALIDADE', 'DIAS_VALIDADE',
  14 + 'MOTIVO', 'VEICULO', 'TIPO'];
  15 +
  16 + $strTemplate = $atividadeDTO->getStrNomeTarefa();
  17 +
  18 + if ($strTemplate) {
  19 + foreach($arrParameters as $parameter) {
  20 + $parameter = '@' . $parameter . '@';
  21 +
  22 + $restrito = 'não restrito';
  23 +
  24 + $nome = ($atividadeDTO->getNumIdUsuarioOrigem())? $atividadeDTO->getStrNomeUsuarioOrigem() : null;
  25 + $sigla = ($atividadeDTO->getNumIdUsuarioOrigem())? $atividadeDTO->getStrSiglaUsuarioOrigem() : null;
  26 + $usuarioAnulacao = ($atividadeDTO->getNumIdUsuarioConclusao())? $atividadeDTO->getStrNomeUsuarioConclusao() : null;
  27 + $unidade = $atividadeDTO->getStrSiglaUnidade();
  28 + $dataHora = ' '.$atividadeDTO->getDthAbertura();
  29 +
  30 + if ($protocoloDTO->getStrStaNivelAcessoLocal() == 1) {
  31 + $restrito = 'restrito';
  32 + }
  33 +
  34 + if('@DOCUMENTO@' == $parameter) {
  35 + $strTemplate = str_replace($parameter, $protocoloDTO->getStrProtocoloFormatado(), $strTemplate);
  36 + } elseif ('@DOCUMENTOS@' == $parameter) {
  37 + $strTemplate = str_replace($parameter, '', $strTemplate);
  38 + } elseif ('@NIVEL_ACESSO@' == $parameter) {
  39 + $strTemplate = str_replace($parameter, $restrito, $strTemplate);
  40 + } elseif ('@GRAU_SIGILO@' == $parameter) {
  41 + $strTemplate = str_replace($parameter, '', $strTemplate);
  42 + } elseif ('@HIPOTESE_LEGAL@' == $parameter) {
  43 + $strTemplate = str_replace($parameter, '', $strTemplate);
  44 + } elseif ('@DATA_AUTUACAO@' == $parameter) {
  45 + $strTemplate = str_replace($parameter, $dataHora, $strTemplate);
  46 + } elseif ('@TIPO_CONFERENCIA@' == $parameter) {
  47 + $strTemplate = str_replace($parameter, '', $strTemplate);
  48 + } elseif ('@PROCESSO@' == $parameter) {
  49 + $strTemplate = str_replace($parameter, $protocoloDTO->getStrProtocoloFormatado(), $strTemplate);
  50 + } elseif ('@USUARIO@' == $parameter) {
  51 + $strTemplate = str_replace($parameter, $nome, $strTemplate);
  52 + } elseif ('@USUARIOS@' == $parameter) {
  53 + $strTemplate = str_replace($parameter, '', $strTemplate);
  54 + } elseif ('@UNIDADE@' == $parameter) {
  55 + $strTemplate = str_replace($parameter, $unidade, $strTemplate);
  56 + } elseif ('@BLOCO@' == $parameter) {
  57 + $blocoRN = new BlocoRN();
  58 + $blocoDTO = new BlocoDTO();
  59 + $blocoDTO->setNumIdUnidade($atividadeDTO->getNumIdUnidade());
  60 + $blocoDTO->setNumMaxRegistrosRetorno(1);
  61 + $blocoDTO->retStrDescricao();
  62 + $blocoResult = $blocoRN->listarRN1277($blocoDTO);
  63 + if (!empty($blocoResult)) {
  64 + $bloco = $blocoResult[0];
  65 + $strTemplate = str_replace($parameter, $bloco->getStrDescricao(), $strTemplate);
  66 + }
  67 + } elseif ('@DATA_HORA@' == $parameter) {
  68 + $strTemplate = str_replace($parameter, $dataHora, $strTemplate);
  69 + } elseif ('@DATA@' == $parameter) {
  70 + $strTemplate = str_replace($parameter, $dataHora, $strTemplate);
  71 + } elseif ('@USUARIO_ANULACAO@' == $parameter) {
  72 + $strTemplate = str_replace($parameter, $usuarioAnulacao, $strTemplate);
  73 + } elseif ('@INTERESSADO@' == $parameter) {
  74 + $strTemplate = str_replace($parameter, '', $strTemplate);
  75 + } elseif ('@LOCALIZADOR@' == $parameter) {
  76 + $strTemplate = str_replace($parameter, '', $strTemplate);
  77 + } elseif ('@ANEXO@' == $parameter) {
  78 + $strTemplate = str_replace($parameter, '', $strTemplate);
  79 + } elseif ('@USUARIO_EXTERNO_NOME@' == $parameter) {
  80 + $strTemplate = str_replace($parameter, $nome, $strTemplate);
  81 + } elseif ('@USUARIO_EXTERNO_SIGLA@' == $parameter) {
  82 + $strTemplate = str_replace($parameter, $sigla, $strTemplate);
  83 + } elseif ('@DESTINATARIO_NOME@' == $parameter) {
  84 + $strTemplate = str_replace($parameter, '', $strTemplate);
  85 + } elseif ('@DESTINATARIO_EMAIL@' == $parameter) {
  86 + $strTemplate = str_replace($parameter, '', $strTemplate);
  87 + } elseif ('@DATA_VALIDADE@' == $parameter) {
  88 + $strTemplate = str_replace($parameter, '', $strTemplate);
  89 + } elseif ('@DIAS_VALIDADE@' == $parameter) {
  90 + $strTemplate = str_replace($parameter, '', $strTemplate);
  91 + } elseif ('@MOTIVO@' == $parameter) {
  92 + $strTemplate = str_replace($parameter, '', $strTemplate);
  93 + } elseif ('@VEICULO@' == $parameter) {
  94 + $strTemplate = str_replace($parameter, '', $strTemplate);
  95 + } elseif ('@TIPO@' == $parameter) {
  96 + $strTemplate = str_replace($parameter, '', $strTemplate);
  97 + }
  98 + }
  99 + }
  100 +
  101 + return $strTemplate;
  102 + }
  103 +
  104 + /**
  105 + * Para efetuar a paginacao e necessario passar dentro do AtividadeDTO os parametros abaixo:
  106 + * -- setNumPaginaAtual($offset)
  107 + * -- setNumMaxRegistrosRetorno($limit)
  108 + * @param AtividadeDTO $atividadeDTO
  109 + * @return array
  110 + * @throws InfraException
  111 + */
  112 + protected function listarAtividadesProcessoConectado(AtividadeDTO $atividadeDTO){
  113 + try{
  114 + if(!$atividadeDTO->isSetDblIdProtocolo()){
  115 + throw new InfraException('O protocolo deve ser informado!');
  116 + }
  117 + if(!$atividadeDTO->isSetNumIdUnidade()){
  118 + $atividadeDTO->setNumIdUnidade(SessaoSEI::getInstance()->getNumIdUnidadeAtual());
  119 + }
  120 + $protocoloRN = new ProtocoloRN();
  121 + $protocoloDTO = new ProtocoloDTO();
  122 + $protocoloDTO->setDblIdProtocolo($atividadeDTO->getDblIdProtocolo());
  123 + $protocoloDTO->retStrStaNivelAcessoLocal();
  124 + $protocoloDTO->retStrProtocoloFormatado();
  125 + $resultProtocolo = $protocoloRN->listarRN0668($protocoloDTO);
  126 + $protocoloDTO = $resultProtocolo[0];
  127 +
  128 + $atividadeDTO->retDblIdProtocolo();
  129 + $atividadeDTO->retNumIdUnidade();
  130 + $atividadeDTO->retDthAbertura();
  131 + $atividadeDTO->retStrNomeTarefa();
  132 + $atividadeDTO->retNumIdAtividade();
  133 + $atividadeDTO->retNumIdUsuarioOrigem();
  134 + $atividadeDTO->retStrSiglaUsuarioOrigem();
  135 + $atividadeDTO->retStrSiglaUnidade();
  136 + $atividadeDTO->retStrNomeUsuarioOrigem();
  137 + $atividadeDTO->retNumIdUsuarioConclusao();
  138 + $atividadeDTO->retStrNomeUsuarioConclusao();
  139 + $atividadeRN = new AtividadeRN();
  140 + $result = $atividadeRN->listarRN0036($atividadeDTO);
  141 + if (!empty($result)) {
  142 + foreach($result as $value) {
  143 + $dateTime = explode(' ', $value->getDthAbertura());
  144 + $informacao = $this->traduzirTemplate($value, $protocoloDTO);
  145 + $arrayResult[] = [
  146 + "id" => $value->getNumIdAtividade(),
  147 + "atributos" => [
  148 + "idProcesso" => $value->getDblIdProtocolo(),
  149 + "usuario" => ($value->getNumIdUsuarioOrigem())? $value->getStrSiglaUsuarioOrigem() : null,
  150 + "data" => $dateTime[0],
  151 + "hora" => $dateTime[1],
  152 + "unidade" => $value->getStrSiglaUnidade(),
  153 + "informacao" => $informacao
  154 + ]
  155 + ];
  156 + }
  157 + }
  158 +
  159 + return array(
  160 + 'sucesso' => true,
  161 + 'data' => $arrayResult,
  162 + 'total' => $atividadeDTO->getNumTotalRegistros()
  163 + );
  164 + }catch (Exception $e){
  165 + return array(
  166 + 'sucesso' => false,
  167 + 'mensagem' => $e->getMessage(),
  168 + 'exception' => $e
  169 + );
  170 + }
  171 + }
  172 +
  173 +
  174 +
  175 +}
0 176 \ No newline at end of file
... ...
rn/MdWsSeiBlocoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiBlocoRN.php
... ... @@ -0,0 +1,253 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiBlocoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * Consultar Blocos
  12 + * @param UnidadeDTO $unidadeDTO
  13 + * @return array
  14 + */
  15 + protected function listarBlocoUnidadeConectado(UnidadeDTO $unidadeDTO){
  16 + try{
  17 + $result = array();
  18 + $blocoDTOConsulta = new BlocoDTO();
  19 + if(!$unidadeDTO->getNumMaxRegistrosRetorno()){
  20 + $blocoDTOConsulta->setNumMaxRegistrosRetorno(10);
  21 + }else{
  22 + $blocoDTOConsulta->setNumMaxRegistrosRetorno($unidadeDTO->getNumMaxRegistrosRetorno());
  23 + }
  24 + if(is_null($unidadeDTO->getNumPaginaAtual())){
  25 + $blocoDTOConsulta->setNumPaginaAtual(0);
  26 + }else{
  27 + $blocoDTOConsulta->setNumPaginaAtual($unidadeDTO->getNumPaginaAtual());
  28 + }
  29 + if(!$unidadeDTO->isSetNumIdUnidade()){
  30 + $blocoDTOConsulta->setNumIdUnidade(SessaoSEI::getInstance()->getNumIdUnidadeAtual());
  31 + }else{
  32 + $blocoDTOConsulta->setNumIdUnidade($unidadeDTO->getNumIdUnidade());
  33 + }
  34 +
  35 + $blocoRN = new BlocoRN();
  36 + $blocoDTOConsulta->setNumIdUnidadeRelBlocoUnidade($unidadeDTO->getNumIdUnidade());
  37 + $blocoDTOConsulta->setNumIdUnidade($unidadeDTO->getNumIdUnidade());
  38 + $blocoDTOConsulta->adicionarCriterio(
  39 + array('StaTipo', 'StaEstado'),
  40 + array(InfraDTO::$OPER_IGUAL, InfraDTO::$OPER_IN),
  41 + array('A', array('D', 'C', 'R', 'A')),
  42 + InfraDTO::$OPER_LOGICO_AND
  43 + );
  44 + $blocoDTOConsulta->retNumIdBloco();
  45 + $blocoDTOConsulta->retNumIdUnidade();
  46 + $blocoDTOConsulta->retStrSiglaUnidade();
  47 + $blocoDTOConsulta->retStrStaEstado();
  48 + $blocoDTOConsulta->retStrDescricao();
  49 + $blocoDTOConsulta->setOrdNumIdBloco(InfraDTO::$TIPO_ORDENACAO_DESC);
  50 + $ret = $blocoRN->listarRN1277($blocoDTOConsulta);
  51 + /** @var BlocoDTO $blocoDTO */
  52 + foreach($ret as $blocoDTO){
  53 + $arrUnidades[] = array(
  54 + 'idUnidade' => $blocoDTO->getNumIdUnidade(),
  55 + 'unidade' => $blocoDTO->getStrSiglaUnidade()
  56 + );
  57 + $result[] = array(
  58 + 'id' => $blocoDTO->getNumIdBloco(),
  59 + 'atributos' => array(
  60 + 'idBloco' => $blocoDTO->getNumIdBloco(),
  61 + 'idUnidade' => $blocoDTO->getNumIdUnidade(),
  62 + 'siglaUnidade' => $blocoDTO->getStrSiglaUnidade(),
  63 + 'estado' => $blocoDTO->getStrStaEstado(),
  64 + 'descricao' => $blocoDTO->getStrDescricao(),
  65 + 'unidades' => $arrUnidades
  66 + )
  67 + );
  68 + }
  69 + return array(
  70 + 'sucesso' => true,
  71 + 'data' => $result,
  72 + 'total' => !$result ? 0 : $blocoDTOConsulta->getNumTotalRegistros()
  73 + );
  74 + }catch (Exception $e){
  75 + return array(
  76 + 'sucesso' => false,
  77 + 'mensagem' => $e->getMessage(),
  78 + 'exception' => $e
  79 + );
  80 + }
  81 + }
  82 +
  83 + /**
  84 + * Consultar Documentos por Bloco
  85 + * @param BlocoDTO $blocoDTOConsulta
  86 + * @return array
  87 + */
  88 + protected function listarDocumentosBlocoConectado(BlocoDTO $blocoDTOConsulta){
  89 + try{
  90 + if(!$blocoDTOConsulta->getNumIdBloco()){
  91 + throw new InfraException('Bloco nao informado.');
  92 + }
  93 + $relBlocoProtocoloRN = new RelBlocoProtocoloRN();
  94 + $relBlocoProtocoloDTOConsulta = new RelBlocoProtocoloDTO();
  95 + if($blocoDTOConsulta->getNumMaxRegistrosRetorno()){
  96 + $relBlocoProtocoloDTOConsulta->setNumMaxRegistrosRetorno($blocoDTOConsulta->getNumMaxRegistrosRetorno());
  97 + }else{
  98 + $relBlocoProtocoloDTOConsulta->setNumMaxRegistrosRetorno(10);
  99 + }
  100 + if(!is_null($blocoDTOConsulta->getNumPaginaAtual())){
  101 + $relBlocoProtocoloDTOConsulta->setNumPaginaAtual($blocoDTOConsulta->getNumPaginaAtual());
  102 + }else{
  103 + $relBlocoProtocoloDTOConsulta->setNumPaginaAtual(0);
  104 + }
  105 + $result = array();
  106 + $relBlocoProtocoloDTOConsulta->setNumIdBloco($blocoDTOConsulta->getNumIdBloco());
  107 + $relBlocoProtocoloDTOConsulta->setOrdNumIdBloco(InfraDTO::$TIPO_ORDENACAO_DESC);
  108 + $relBlocoProtocoloDTOConsulta->retDblIdProtocolo();
  109 + $relBlocoProtocoloDTOConsulta->retStrAnotacao();
  110 + $arrRelProtocolo = $relBlocoProtocoloRN->listarRN1291($relBlocoProtocoloDTOConsulta);
  111 + if($arrRelProtocolo){
  112 + $anexoRN = new AnexoRN();
  113 + $assinaturaRN = new AssinaturaRN();
  114 + $protocoloRN = new ProtocoloRN();
  115 + /** @var RelBlocoProtocoloDTO $relBlocoProtocoloDTO */
  116 + foreach($arrRelProtocolo as $relBlocoProtocoloDTO){
  117 + $relProtocoloProtocoloRN = new RelProtocoloProtocoloRN();
  118 + $relProtocoloProtocoloDTOConsulta = new RelProtocoloProtocoloDTO();
  119 + $relProtocoloProtocoloDTOConsulta->adicionarCriterio(
  120 + array('IdProtocolo1', 'IdProtocolo2'),
  121 + array(InfraDTO::$OPER_IGUAL, InfraDTO::$OPER_IGUAL),
  122 + array($relBlocoProtocoloDTO->getDblIdProtocolo(), $relBlocoProtocoloDTO->getDblIdProtocolo()),
  123 + InfraDTO::$OPER_LOGICO_OR
  124 + );
  125 + $relProtocoloProtocoloDTOConsulta->retTodos();
  126 + $arrProtocoloProtocolo = $relProtocoloProtocoloRN->listarRN0187($relProtocoloProtocoloDTOConsulta);
  127 + if($arrProtocoloProtocolo){
  128 + $arrResultAssinatura = array();
  129 + /** @var RelProtocoloProtocoloDTO $relProtocoloProtocoloDTO */
  130 + foreach($arrProtocoloProtocolo as $relProtocoloProtocoloDTO){
  131 + $protocoloDTO = new ProtocoloDTO();
  132 + $protocoloDTO->setDblIdProtocolo($relProtocoloProtocoloDTO->getDblIdProtocolo1());
  133 + $protocoloDTO->retTodos();
  134 + $protocoloDTO->retStrNomeTipoProcedimentoProcedimento();
  135 + $protocoloDTO = $protocoloRN->consultarRN0186($protocoloDTO);
  136 + $assinaturaDTOConsulta = new AssinaturaDTO();
  137 + $assinaturaDTOConsulta->setDblIdProcedimentoDocumento($protocoloDTO->getDblIdProtocolo());
  138 + $assinaturaDTOConsulta->setDblIdDocumento($protocoloDTO->getDblIdProtocolo());
  139 + $assinaturaDTOConsulta->retStrNome();
  140 + $assinaturaDTOConsulta->retStrTratamento();
  141 + $arrAssinatura = $assinaturaRN->listarRN1323($assinaturaDTOConsulta);
  142 + /** @var AssinaturaDTO $assinaturaDTO */
  143 + foreach($arrAssinatura as $assinaturaDTO){
  144 + $arrResultAssinatura[] = array(
  145 + 'nome' => $assinaturaDTO->getStrNome(),
  146 + 'cargo' => $assinaturaDTO->getStrTratamento()
  147 + );
  148 + }
  149 + $anexoDTOConsulta = new AnexoDTO();
  150 + $anexoDTOConsulta->retTodos();
  151 + $anexoDTOConsulta->setDblIdProtocolo($protocoloDTO->getDblIdProtocolo());
  152 + $anexoDTOConsulta->setStrSinAtivo('S');
  153 + $anexoDTOConsulta->setNumMaxRegistrosRetorno(1);
  154 + $retAnexo = $anexoRN->listarRN0218($anexoDTOConsulta);
  155 + $mimetype = null;
  156 + if($retAnexo){
  157 + $mimetype = $retAnexo[0]->getStrNome();
  158 + $mimetype = substr($mimetype, strrpos($mimetype, '.')+1);
  159 + }
  160 + $result[] = array(
  161 + 'id' => $protocoloDTO->getDblIdProtocolo(),
  162 + 'atributos' => array(
  163 + 'idDocumento' => $protocoloDTO->getDblIdProtocolo(),
  164 + 'mimeType' => ($mimetype)?$mimetype:'html',
  165 + 'data' => $protocoloDTO->getDtaGeracao(),
  166 + 'numero' => $protocoloDTO->getStrProtocoloFormatado(),
  167 + 'numeroProcesso' => $protocoloDTO->getStrProtocoloFormatado(),
  168 + 'tipo' => $protocoloDTO->getStrNomeTipoProcedimentoProcedimento(),
  169 + 'assinaturas' => $arrResultAssinatura
  170 + ),
  171 + 'anotacao' => $relBlocoProtocoloDTO->getStrAnotacao()
  172 + );
  173 + }
  174 + }
  175 + }
  176 + }
  177 +
  178 + return array(
  179 + 'sucesso' => true,
  180 + 'data' => $result,
  181 + 'total' => $relBlocoProtocoloDTOConsulta->getNumTotalRegistros()
  182 + );
  183 + }catch (Exception $e){
  184 + return array(
  185 + 'sucesso' => false,
  186 + 'mensagem' => $e->getMessage(),
  187 + 'exception' => $e
  188 + );
  189 + }
  190 + }
  191 +
  192 + /**
  193 + * Metodo publico que cadastra a anotacao em um bloco
  194 + * @param array $post
  195 + * @return array
  196 + */
  197 + public function cadastrarAnotacaoBlocoFromRequest(array $post){
  198 + $relBlocoProtocoloDTO = new RelBlocoProtocoloDTO();
  199 + if($post['protocolo']){
  200 + $relBlocoProtocoloDTO->setDblIdProtocolo($post['protocolo']);
  201 + }
  202 + if($post['bloco']){
  203 + $relBlocoProtocoloDTO->setNumIdBloco($post['bloco']);
  204 + }
  205 + if($post['anotacao']){
  206 + $relBlocoProtocoloDTO->setStrAnotacao($post['anotacao']);
  207 + }
  208 +
  209 + return $this->cadastrarAnotacaoBloco($relBlocoProtocoloDTO);
  210 + }
  211 +
  212 + /**
  213 + * Cadastrar Anotacao documento do Bloco
  214 + * @param RelBlocoProtocoloDTO $relBlocoProtocoloDTOParam
  215 + * @return array
  216 + */
  217 + protected function cadastrarAnotacaoBlocoControlado(RelBlocoProtocoloDTO $relBlocoProtocoloDTOParam){
  218 + try{
  219 + if(!$relBlocoProtocoloDTOParam->isSetNumIdBloco()){
  220 + throw new InfraException('O bloco deve ser informado.');
  221 + }
  222 + if(!$relBlocoProtocoloDTOParam->isSetNumIdBloco()){
  223 + throw new InfraException('O protocolo deve ser informado.');
  224 + }
  225 + if(!$relBlocoProtocoloDTOParam->isSetStrAnotacao()){
  226 + throw new InfraException('A anotacao deve ser informada.');
  227 + }
  228 + $relBlocoProtocoloDTO = new RelBlocoProtocoloDTO();
  229 + $relBlocoProtocoloDTO->setNumIdBloco($relBlocoProtocoloDTOParam->getNumIdBloco());
  230 + $relBlocoProtocoloDTO->setDblIdProtocolo($relBlocoProtocoloDTOParam->getDblIdProtocolo());
  231 + $relBlocoProtocoloDTO->retTodos();
  232 + $relBlocoProtocoloRN = new RelBlocoProtocoloRN();
  233 + $relBlocoProtocoloDTO = $relBlocoProtocoloRN->consultarRN1290($relBlocoProtocoloDTO);
  234 + if(!$relBlocoProtocoloDTO){
  235 + throw new InfraException('Documento nao encontrado no bloco informado.');
  236 + }
  237 + $relBlocoProtocoloDTO->setStrAnotacao($relBlocoProtocoloDTOParam->getStrAnotacao());
  238 + $relBlocoProtocoloRN->alterarRN1288($relBlocoProtocoloDTO);
  239 +
  240 + return array(
  241 + 'sucesso' => true,
  242 + 'mensagem' => 'Anotação realizada com sucesso.'
  243 + );
  244 + }catch (Exception $e){
  245 + return array(
  246 + 'sucesso' => false,
  247 + 'mensagem' => $e->getMessage(),
  248 + 'exception' => $e
  249 + );
  250 + }
  251 + }
  252 +
  253 +}
0 254 \ No newline at end of file
... ...
rn/MdWsSeiDocumentoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiDocumentoRN.php
... ... @@ -0,0 +1,252 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiDocumentoRN extends InfraRN {
  5 +
  6 + CONST NOME_ATRIBUTO_ANDAMENTO_DOCUMENTO = 'DOCUMENTO';
  7 +
  8 + protected function inicializarObjInfraIBanco(){
  9 + return BancoSEI::getInstance();
  10 + }
  11 +
  12 + /**
  13 + * Metodo simplificado (abstraido) de assinatura de documentos
  14 + * @param array $arrIdDocumento
  15 + * @param $idOrgao
  16 + * @param $strCargoFuncao
  17 + * @param $siglaUsuario
  18 + * @param $senhaUsuario
  19 + * @param $idUsuario
  20 + * @return array
  21 + */
  22 + public function apiAssinarDocumentos(array $arrIdDocumento, $idOrgao, $strCargoFuncao, $siglaUsuario, $senhaUsuario, $idUsuario){
  23 + $arrDocumentoDTO = array();
  24 + foreach($arrIdDocumento as $dblIdDocumento){
  25 + $documentoDTO = new DocumentoDTO();
  26 + $documentoDTO->setDblIdDocumento($dblIdDocumento);
  27 + $arrDocumentoDTO[] = $documentoDTO;
  28 + }
  29 + $assinaturaDTO = new AssinaturaDTO();
  30 + $assinaturaDTO->setStrSiglaUsuario($siglaUsuario);
  31 + $assinaturaDTO->setStrSenhaUsuario($senhaUsuario);
  32 + $assinaturaDTO->setNumIdUsuario($idUsuario);
  33 + $assinaturaDTO->setNumIdOrgaoUsuario($idOrgao);
  34 + $assinaturaDTO->setStrCargoFuncao($strCargoFuncao);
  35 + $assinaturaDTO->setArrObjDocumentoDTO($arrDocumentoDTO);
  36 + return $this->assinarDocumento($assinaturaDTO);
  37 + }
  38 +
  39 + /**
  40 + * Metodo simplificado (abstraido) de assinatura de documento
  41 + * @param array $arrIdDocumento
  42 + * @param $idOrgao
  43 + * @param $strCargoFuncao
  44 + * @param $siglaUsuario
  45 + * @param $senhaUsuario
  46 + * @param $idUsuario
  47 + * @return array
  48 + */
  49 + public function apiAssinarDocumento($idDocumento, $idOrgao, $strCargoFuncao, $siglaUsuario, $senhaUsuario, $idUsuario){
  50 + $arrDocumentoDTO = array();
  51 + $documentoDTO = new DocumentoDTO();
  52 + $documentoDTO->setDblIdDocumento($idDocumento);
  53 + $arrDocumentoDTO[] = $documentoDTO;
  54 + $assinaturaDTO = new AssinaturaDTO();
  55 + $assinaturaDTO->setStrSiglaUsuario($siglaUsuario);
  56 + $assinaturaDTO->setStrSenhaUsuario($senhaUsuario);
  57 + $assinaturaDTO->setNumIdUsuario($idUsuario);
  58 + $assinaturaDTO->setNumIdOrgaoUsuario($idOrgao);
  59 + $assinaturaDTO->setStrCargoFuncao($strCargoFuncao);
  60 + $assinaturaDTO->setArrObjDocumentoDTO($arrDocumentoDTO);
  61 + return $this->assinarDocumento($assinaturaDTO);
  62 + }
  63 +
  64 + /**
  65 + * Realizar Assinatura Eletrônica
  66 + * @param AssinaturaDTO $assinaturaDTO
  67 + * @return array
  68 + */
  69 + public function assinarDocumentoControlado(AssinaturaDTO $assinaturaDTO){
  70 + try{
  71 + $assinaturaDTO->setStrStaFormaAutenticacao(AssinaturaRN::$TA_SENHA);
  72 + $assinaturaDTO->setNumIdContextoUsuario(null);
  73 + $documentoRN = new DocumentoRN();
  74 + $documentoRN->assinarInterno($assinaturaDTO);
  75 + return array(
  76 + 'sucesso' => true,
  77 + 'mensagem' => 'Documento em bloco assinado com sucesso.'
  78 + );
  79 + }catch (Exception $e){
  80 + return array(
  81 + 'sucesso' => false,
  82 + 'mensagem' => $e->getMessage(),
  83 + 'exception' => $e
  84 + );
  85 + }
  86 + }
  87 +
  88 + /**
  89 + * @param DocumentoDTO $documentoDTO
  90 + * id documento obrigatorio
  91 + * @return array
  92 + */
  93 + protected function darCienciaControlado(DocumentoDTO $documentoDTO){
  94 + try{
  95 + $documentoRN = new DocumentoRN();
  96 + if(!$documentoDTO->getDblIdDocumento()){
  97 + throw new InfraException('O documento não foi informado.');
  98 + }
  99 + $documentoRN->darCiencia($documentoDTO);
  100 + return array(
  101 + 'sucesso' => true,
  102 + 'mensagem' => 'Ciência documento realizado com sucesso.'
  103 + );
  104 + }catch (Exception $e){
  105 + return array(
  106 + 'sucesso' => false,
  107 + 'mensagem' => $e->getMessage(),
  108 + 'exception' => $e
  109 + );
  110 + }
  111 + }
  112 +
  113 + protected function downloadAnexoConectado(ProtocoloDTO $protocoloDTO){
  114 + try{
  115 + if(!$protocoloDTO->isSetDblIdProtocolo() || !$protocoloDTO->getDblIdProtocolo()){
  116 + throw new InfraException('O protocolo deve ser informado!');
  117 + }
  118 + $documentoDTO = new DocumentoDTO();
  119 + $documentoDTO->setDblIdProtocoloProtocolo($protocoloDTO->getDblIdProtocolo());
  120 + $documentoDTO->retStrConteudo();
  121 + $documentoDTO->retStrConteudoAssinatura();
  122 + $documentoBD = new DocumentoRN();
  123 + $resultDocumento = $documentoBD->listarRN0008($documentoDTO);
  124 +
  125 + if(!empty($resultDocumento)){
  126 + $documento = $resultDocumento[0];
  127 + if ($documento->getStrConteudo()) {
  128 + $html = $documento->getStrConteudo() . $documento->getStrConteudoAssinatura();
  129 + return ["html" => $html];
  130 + }
  131 + }
  132 +
  133 + $anexoDTO = new AnexoDTO();
  134 + $anexoDTO->retNumIdAnexo();
  135 + $anexoDTO->retDthInclusao();
  136 + $anexoDTO->retDthInclusao();
  137 + $anexoDTO->retStrNome();
  138 + $anexoDTO->retStrHash();
  139 + $anexoDTO->setDblIdProtocolo($protocoloDTO->getDblIdProtocolo());
  140 + $anexoDTO->setStrSinAtivo('S');
  141 + $anexoRN = new AnexoRN();
  142 + $resultAnexo = $anexoRN->listarRN0218($anexoDTO);
  143 + if(empty($resultAnexo)){
  144 + throw new InfraException('Documento não encontrado!');
  145 + }
  146 + $anexo = $resultAnexo[0];
  147 + SeiINT::download($anexo);
  148 + }catch (Exception $e){
  149 + return array(
  150 + 'sucesso' => false,
  151 + 'mensagem' => $e->getMessage(),
  152 + 'exception' => $e
  153 + );
  154 + }
  155 + }
  156 +
  157 + /**
  158 + * Listar Ciencias realizadas em um Documento
  159 + * @param MdWsSeiProcessoDTO $mdWsSeiProcessoDTOParam
  160 + * *valor = protocoloformatado?
  161 + * @return array
  162 + */
  163 + protected function listarCienciaDocumentoConectado(MdWsSeiProcessoDTO $mdWsSeiProcessoDTOParam){
  164 + try{
  165 + if(!$mdWsSeiProcessoDTOParam->isSetStrValor()){
  166 + throw new InfraException('Número do documento não informado.');
  167 + }
  168 +
  169 + $result = array();
  170 + $atributoAndamentoDTOConsulta = new AtributoAndamentoDTO();
  171 + $atributoAndamentoDTOConsulta->retTodos();
  172 + $atributoAndamentoDTOConsulta->retDthAberturaAtividade();
  173 + $atributoAndamentoDTOConsulta->retStrSiglaUsuarioOrigemAtividade();
  174 + $atributoAndamentoDTOConsulta->retStrSiglaUnidadeOrigemAtividade();
  175 + $atributoAndamentoDTOConsulta->setNumIdTarefaAtividade(TarefaRN::$TI_DOCUMENTO_CIENCIA);
  176 + $atributoAndamentoDTOConsulta->setStrValor($mdWsSeiProcessoDTOParam->getStrValor());
  177 + $atributoAndamentoDTOConsulta->setStrNome(self::NOME_ATRIBUTO_ANDAMENTO_DOCUMENTO);
  178 + $atributoAndamentoRN = new AtributoAndamentoRN();
  179 + $ret = $atributoAndamentoRN->listarRN1367($atributoAndamentoDTOConsulta);
  180 + $tarefaDTO = new TarefaDTO();
  181 + $tarefaDTO->retStrNome();
  182 + $tarefaDTO->setNumIdTarefa($atributoAndamentoDTOConsulta->getNumIdTarefaAtividade());
  183 + $tarefaRN = new TarefaRN();
  184 + $tarefaDTO = $tarefaRN->consultar($tarefaDTO);
  185 + $mdWsSeiProcessoRN = new MdWsSeiProcessoRN();
  186 + /** @var AtributoAndamentoDTO $atributoAndamentoDTO */
  187 + foreach($ret as $atributoAndamentoDTO){
  188 + $mdWsSeiProcessoDTO = new MdWsSeiProcessoDTO();
  189 + $mdWsSeiProcessoDTO->setNumIdAtividade($atributoAndamentoDTO->getNumIdAtividade());
  190 + $mdWsSeiProcessoDTO->setStrTemplate($tarefaDTO->getStrNome());
  191 + $result[] = array(
  192 + 'data' => $atributoAndamentoDTO->getDthAberturaAtividade(),
  193 + 'unidade' => $atributoAndamentoDTO->getStrSiglaUnidadeOrigemAtividade(),
  194 + 'nome' => $atributoAndamentoDTO->getStrSiglaUsuarioOrigemAtividade(),
  195 + 'descricao' => $mdWsSeiProcessoRN->traduzirTemplate($mdWsSeiProcessoDTO)
  196 + );
  197 + }
  198 +
  199 + return array(
  200 + 'sucesso' => true,
  201 + 'data' => $result
  202 + );
  203 + }catch (Exception $e){
  204 + return array(
  205 + 'sucesso' => false,
  206 + 'mensagem' => $e->getMessage(),
  207 + 'exception' => $e
  208 + );
  209 + }
  210 + }
  211 +
  212 + /**
  213 + * Listar assinaturas do documento
  214 + * @param DocumentoDTO $documentoDTOParam
  215 + * @return array
  216 + */
  217 + protected function listarAssinaturasDocumentoConectado(DocumentoDTO $documentoDTOParam){
  218 + try{
  219 + if(!$documentoDTOParam->isSetDblIdDocumento()){
  220 + throw new InfraException('O documento não foi informado.');
  221 + }
  222 +
  223 + $result = array();
  224 + $assinaturaDTOConsulta = new AssinaturaDTO();
  225 + $assinaturaDTOConsulta->retTodos();
  226 + $assinaturaDTOConsulta->retStrSiglaUnidade();
  227 + $assinaturaDTOConsulta->setDblIdDocumento($documentoDTOParam->getDblIdDocumento());
  228 + $assinaturaRN = new AssinaturaRN();
  229 + $ret = $assinaturaRN->listarRN1323($assinaturaDTOConsulta);
  230 + /** @var AssinaturaDTO $assinaturaDTO */
  231 + foreach($ret as $assinaturaDTO){
  232 + $result[] = array(
  233 + 'nome' => $assinaturaDTO->getStrNome(),
  234 + 'cargo' => $assinaturaDTO->getStrTratamento(),
  235 + 'unidade' => $assinaturaDTO->getStrSiglaUnidade()
  236 + );
  237 + }
  238 +
  239 + return array(
  240 + 'sucesso' => true,
  241 + 'data' => $result
  242 + );
  243 + }catch (Exception $e){
  244 + return array(
  245 + 'sucesso' => false,
  246 + 'mensagem' => $e->getMessage(),
  247 + 'exception' => $e
  248 + );
  249 + }
  250 + }
  251 +
  252 +}
0 253 \ No newline at end of file
... ...
rn/MdWsSeiGrupoAcompanhamentoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiGrupoAcompanhamentoRN.php
... ... @@ -0,0 +1,55 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiGrupoAcompanhamentoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * Retorna todos os grupos de acompanhamento
  12 + * @param OrgaoDTO $orgaoDTO
  13 + * @info para paginacao e necessario informar dentro do DTO os parametros abaixo:
  14 + * - setNumMaxRegistrosRetorno
  15 + * - setNumPaginaAtual
  16 + * @return array
  17 + */
  18 + protected function listarGrupoAcompanhamentoConectado(GrupoAcompanhamentoDTO $grupoAcompanhamentoDTO){
  19 + try{
  20 + $result = array();
  21 + $grupoAcompanhamentoRN = new GrupoAcompanhamentoRN();
  22 + if(!$grupoAcompanhamentoDTO->isRetNumIdGrupoAcompanhamento()){
  23 + $grupoAcompanhamentoDTO->retNumIdGrupoAcompanhamento();
  24 + }
  25 + if(!$grupoAcompanhamentoDTO->isRetStrNome()){
  26 + $grupoAcompanhamentoDTO->retStrNome();
  27 + }
  28 + if(!$grupoAcompanhamentoDTO->isSetNumIdUnidade()){
  29 + $grupoAcompanhamentoDTO->setNumIdUnidade(SessaoSEI::getInstance()->getNumIdUnidadeAtual());
  30 + }
  31 + $ret = $grupoAcompanhamentoRN->listar($grupoAcompanhamentoDTO);
  32 + /** @var GrupoAcompanhamentoDTO $grupDTO */
  33 + foreach($ret as $grupDTO){
  34 + $result[] = array(
  35 + 'id' => $grupDTO->getNumIdGrupoAcompanhamento(),
  36 + 'nome' => $grupDTO->getStrNome()
  37 + );
  38 + }
  39 +
  40 +
  41 + return array(
  42 + 'sucesso' => true,
  43 + 'data' => $result,
  44 + 'total' => $grupoAcompanhamentoDTO->getNumTotalRegistros()
  45 + );
  46 + }catch (Exception $e){
  47 + return array(
  48 + 'sucesso' => false,
  49 + 'mensagem' => $e->getMessage(),
  50 + 'exception' => $e
  51 + );
  52 + }
  53 + }
  54 +
  55 +}
0 56 \ No newline at end of file
... ...
rn/MdWsSeiObservacaoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiObservacaoRN.php
... ... @@ -0,0 +1,51 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiObservacaoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + public function encapsulaObservacao(array $post){
  11 + $observacaoDTO = new ObservacaoDTO();
  12 + $observacaoDTO->setStrIdxObservacao(null);
  13 + if (isset($post['unidade'])) {
  14 + $observacaoDTO->setNumIdUnidade($post['unidade']);
  15 + }
  16 +
  17 + if (isset($post['descricao'])) {
  18 + $observacaoDTO->setStrDescricao($post['descricao']);
  19 + }
  20 +
  21 + if (isset($post['protocolo'])) {
  22 + $observacaoDTO->setDblIdProtocolo($post['protocolo']);
  23 + }
  24 +
  25 + return $observacaoDTO;
  26 + }
  27 +
  28 + /**
  29 + * Metodo que cria uma observacao
  30 + * @param ObservacaoDTO $observacaoDTO
  31 + * @info metodo auxiliar encapsulaObservacao para facilitar encapsulamento
  32 + * @return array
  33 + */
  34 + protected function criarObservacaoControlado(ObservacaoDTO $observacaoDTO){
  35 + try{
  36 + $observacaoRN = new ObservacaoRN();
  37 + $observacaoRN->cadastrarRN0222($observacaoDTO);
  38 +
  39 + return array(
  40 + 'sucesso' => true,
  41 + 'mensagem' => 'Observação cadastrada com sucesso!'
  42 + );
  43 + }catch (Exception $e){
  44 + return array(
  45 + 'sucesso' => false,
  46 + 'mensagem' => $e->getMessage(),
  47 + 'exception' => $e
  48 + );
  49 + }
  50 + }
  51 +}
0 52 \ No newline at end of file
... ...
rn/MdWsSeiOrgaoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiOrgaoRN.php
... ... @@ -0,0 +1,59 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiOrgaoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * Retorna todos os orgaos ativos cadastrados
  12 + * @param OrgaoDTO $orgaoDTO
  13 + * @info para páginacao e necessário informar dentro do DTO os parametros abaixo:
  14 + * - setNumMaxRegistrosRetorno
  15 + * - setNumPaginaAtual
  16 + * @return array
  17 + */
  18 + protected function listarOrgaoConectado(OrgaoDTO $orgaoDTO){
  19 + try{
  20 + $result = array();
  21 + $orgaoRN = new OrgaoRN();
  22 + if(!$orgaoDTO->isRetNumIdOrgao()){
  23 + $orgaoDTO->retNumIdOrgao();
  24 + }
  25 + if(!$orgaoDTO->isRetStrSigla()){
  26 + $orgaoDTO->retStrSigla();
  27 + }
  28 + if(!$orgaoDTO->isRetStrDescricao()){
  29 + $orgaoDTO->retStrDescricao();
  30 + }
  31 + if(!$orgaoDTO->isSetStrSinAtivo()){
  32 + $orgaoDTO->setStrSinAtivo('S');
  33 + }
  34 + $ret = $orgaoRN->listarRN1353($orgaoDTO);
  35 + /** @var OrgaoDTO $orgDTO */
  36 + foreach($ret as $orgDTO){
  37 + $result[] = array(
  38 + 'id' => $orgDTO->getNumIdOrgao(),
  39 + 'sigla' => $orgDTO->getStrSigla(),
  40 + 'descricao' => $orgDTO->getStrDescricao()
  41 + );
  42 + }
  43 +
  44 +
  45 + return array(
  46 + 'sucesso' => true,
  47 + 'data' => $result,
  48 + 'total' => $orgaoDTO->getNumTotalRegistros()
  49 + );
  50 + }catch (Exception $e){
  51 + return array(
  52 + 'sucesso' => false,
  53 + 'mensagem' => $e->getMessage(),
  54 + 'exception' => $e
  55 + );
  56 + }
  57 + }
  58 +
  59 +}
0 60 \ No newline at end of file
... ...
rn/MdWsSeiProcedimentoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiProcedimentoRN.php
... ... @@ -0,0 +1,447 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiProcedimentoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * @param $protocolo
  12 + * @return array
  13 + */
  14 + protected function removerSobrestamentoProcessoControlado(ProcedimentoDTO $procedimentoDTOParam){
  15 + try{
  16 + if(!$procedimentoDTOParam->getDblIdProcedimento()){
  17 + throw new InfraException('Procedimento não informado.');
  18 + }
  19 + $seiRN = new SeiRN();
  20 + $entradaRemoverSobrestamentoProcessoAPI = new EntradaRemoverSobrestamentoProcessoAPI();
  21 + $entradaRemoverSobrestamentoProcessoAPI->setIdProcedimento($procedimentoDTOParam->getDblIdProcedimento());
  22 +
  23 + $seiRN->removerSobrestamentoProcesso($entradaRemoverSobrestamentoProcessoAPI);
  24 +
  25 + return array(
  26 + 'sucesso' => true,
  27 + 'mensagem' => 'Sobrestar cancelado com sucesso.'
  28 + );
  29 + }catch (Exception $e){
  30 + return array(
  31 + 'sucesso' => false,
  32 + 'mensagem' => $e->getMessage(),
  33 + 'exception' => $e
  34 + );
  35 + }
  36 + }
  37 +
  38 + protected function listarProcedimentoAcompanhamentoConectado(MdWsSeiProtocoloDTO $mdWsSeiProtocoloDTOConsulta) {
  39 + try{
  40 + $usuarioAtribuicaoAtividade = null;
  41 + $mdWsSeiProtocoloDTO = new MdWsSeiProtocoloDTO();
  42 + if($mdWsSeiProtocoloDTOConsulta->isSetNumIdUsuarioAtribuicaoAtividade()){
  43 + $mdWsSeiProtocoloDTO->setNumIdUsuarioAtribuicaoAtividade($mdWsSeiProtocoloDTOConsulta->getNumIdUsuarioAtribuicaoAtividade());
  44 + $usuarioAtribuicaoAtividade = $mdWsSeiProtocoloDTOConsulta->getNumIdUsuarioAtribuicaoAtividade();
  45 + }
  46 + if(!$mdWsSeiProtocoloDTOConsulta->isSetNumIdUsuarioGeradorAcompanhamento()){
  47 + $mdWsSeiProtocoloDTO->setNumIdUsuarioGeradorAcompanhamento(SessaoSEI::getInstance()->getNumIdUsuario());
  48 + }else{
  49 + $mdWsSeiProtocoloDTO->setNumIdUsuarioGeradorAcompanhamento($mdWsSeiProtocoloDTOConsulta->getNumIdUsuarioGeradorAcompanhamento());
  50 + }
  51 +
  52 + if(is_null($mdWsSeiProtocoloDTOConsulta->getNumPaginaAtual())){
  53 + $mdWsSeiProtocoloDTO->setNumPaginaAtual(0);
  54 + }else{
  55 + $mdWsSeiProtocoloDTO->setNumPaginaAtual($mdWsSeiProtocoloDTOConsulta->getNumPaginaAtual());
  56 + }
  57 +
  58 + if(!$mdWsSeiProtocoloDTOConsulta->isSetNumMaxRegistrosRetorno()){
  59 + $mdWsSeiProtocoloDTO->setNumMaxRegistrosRetorno(10);
  60 + }else{
  61 + $mdWsSeiProtocoloDTO->setNumMaxRegistrosRetorno($mdWsSeiProtocoloDTOConsulta->getNumMaxRegistrosRetorno());
  62 + }
  63 + $protocoloRN = new ProtocoloRN();
  64 + $mdWsSeiProtocoloDTOConsulta->retTodos();
  65 + $mdWsSeiProtocoloDTOConsulta->retStrSinCienciaProcedimento();
  66 + $mdWsSeiProtocoloDTOConsulta->setOrdDthGeracaoAcompanhamento(InfraDTO::$TIPO_ORDENACAO_ASC);
  67 + $mdWsSeiProtocoloDTOConsulta->retStrNomeTipoProcedimentoProcedimento();
  68 + $ret = $protocoloRN->listarRN0668($mdWsSeiProtocoloDTOConsulta);
  69 + $result = $this->montaRetornoListagemProcessos($ret, $usuarioAtribuicaoAtividade);
  70 + return array(
  71 + 'sucesso' => true,
  72 + 'data' => $result,
  73 + 'total' => $mdWsSeiProtocoloDTOConsulta->getNumTotalRegistros()
  74 + );
  75 + }catch (Exception $e){
  76 + return array(
  77 + 'sucesso' => false,
  78 + 'mensagem' => $e->getMessage(),
  79 + 'exception' => $e
  80 + );
  81 + }
  82 + }
  83 +
  84 + /**
  85 + * Metodo que lista os processos
  86 + * @param MdWsSeiProtocoloDTO $mdWsSeiProtocoloDTO
  87 + * @return array
  88 + */
  89 + protected function listarProcessosConectado(MdWsSeiProtocoloDTO $mdWsSeiProtocoloDTOConsulta){
  90 + try{
  91 + $mdWsSeiProtocoloDTO = new MdWsSeiProtocoloDTO();
  92 + $mdWsSeiProtocoloDTO->setDthConclusaoAtividade(null);
  93 + $mdWsSeiProtocoloDTO->retDblIdProtocolo();
  94 + $mdWsSeiProtocoloDTO->retTodos();
  95 + $mdWsSeiProtocoloDTO->retStrNomeTipoProcedimentoProcedimento();
  96 + $mdWsSeiProtocoloDTO->retStrSinCienciaProcedimento();
  97 + $mdWsSeiProtocoloDTO->setOrdDthAberturaAtividade(InfraDTO::$TIPO_ORDENACAO_ASC);
  98 + $usuarioAtribuicaoAtividade = null;
  99 + if($mdWsSeiProtocoloDTO->isSetNumIdUsuarioAtribuicaoAtividade()){
  100 + $usuarioAtribuicaoAtividade = $mdWsSeiProtocoloDTO->getNumIdUsuarioAtribuicaoAtividade();
  101 + }
  102 +
  103 + if(!$mdWsSeiProtocoloDTOConsulta->isSetNumIdUnidadeAtividade()){
  104 + throw new InfraException('É obrigatório informar a unidade.');
  105 + }
  106 + $mdWsSeiProtocoloDTO->setNumIdUnidadeAtividade($mdWsSeiProtocoloDTOConsulta->getNumIdUnidadeAtividade());
  107 +
  108 + if($mdWsSeiProtocoloDTOConsulta->isSetNumIdUsuarioAtribuicaoAtividade()){
  109 + $mdWsSeiProtocoloDTO->setNumIdUsuarioAtribuicaoAtividade($mdWsSeiProtocoloDTOConsulta->getNumIdUsuarioAtribuicaoAtividade());
  110 + }
  111 +
  112 + if(!is_null($mdWsSeiProtocoloDTOConsulta->getNumPaginaAtual())){
  113 + $mdWsSeiProtocoloDTO->setNumPaginaAtual($mdWsSeiProtocoloDTOConsulta->getNumPaginaAtual());
  114 + }else{
  115 + $mdWsSeiProtocoloDTO->setNumPaginaAtual(0);
  116 + }
  117 +
  118 + if($mdWsSeiProtocoloDTOConsulta->isSetNumMaxRegistrosRetorno()){
  119 + $mdWsSeiProtocoloDTO->setNumMaxRegistrosRetorno($mdWsSeiProtocoloDTOConsulta->getNumMaxRegistrosRetorno());
  120 + }else{
  121 + $mdWsSeiProtocoloDTO->setNumMaxRegistrosRetorno(10);
  122 + }
  123 + if(!$mdWsSeiProtocoloDTOConsulta->isSetNumIdUsuarioAtribuicaoAtividade()){
  124 + $mdWsSeiProtocoloDTOConsulta->setNumIdUsuarioAtribuicaoAtividade(SessaoSEI::getInstance()->getNumIdUsuario());
  125 + }
  126 +
  127 + if($mdWsSeiProtocoloDTOConsulta->getStrSinTipoBusca() == MdWsSeiProtocoloDTO::SIN_TIPO_BUSCA_M){
  128 + $mdWsSeiProtocoloDTO->setNumIdUsuarioAtribuicaoAtividade($mdWsSeiProtocoloDTOConsulta->getNumIdUsuarioAtribuicaoAtividade());
  129 + }else if($mdWsSeiProtocoloDTOConsulta->getStrSinTipoBusca() == MdWsSeiProtocoloDTO::SIN_TIPO_BUSCA_G){
  130 + $mdWsSeiProtocoloDTO->adicionarCriterio(
  131 + array('StaEstado', 'SinInicialAtividade'),
  132 + array(InfraDTO::$OPER_DIFERENTE, InfraDTO::$OPER_IGUAL),
  133 + array(1, 'S'),
  134 + InfraDTO::$OPER_LOGICO_AND
  135 + );
  136 + }else{
  137 + $mdWsSeiProtocoloDTO->adicionarCriterio(
  138 + array('StaEstado', 'SinInicialAtividade', 'IdTarefaAtividade'),
  139 + array(InfraDTO::$OPER_DIFERENTE, InfraDTO::$OPER_IGUAL, InfraDTO::$OPER_DIFERENTE),
  140 + array(1, 'N', 1),
  141 + array(InfraDTO::$OPER_LOGICO_AND, InfraDTO::$OPER_LOGICO_AND)
  142 + );
  143 + }
  144 +
  145 + $protocoloRN = new ProtocoloRN();
  146 + $ret = $protocoloRN->listarRN0668($mdWsSeiProtocoloDTO);
  147 + $result = $this->montaRetornoListagemProcessos($ret, $usuarioAtribuicaoAtividade);
  148 + return array(
  149 + 'sucesso' => true,
  150 + 'data' => $result,
  151 + 'total' => $mdWsSeiProtocoloDTO->getNumTotalRegistros()
  152 + );
  153 + }catch (Exception $e){
  154 + return array(
  155 + 'sucesso' => false,
  156 + 'mensagem' => $e->getMessage(),
  157 + 'exception' => $e
  158 + );
  159 + }
  160 +
  161 + }
  162 +
  163 + /**
  164 + * Metodo que monta o retorno da listagem do processo com base no retorno da consulta
  165 + * @param array $ret
  166 + * @param null $usuarioAtribuicaoAtividade
  167 + * @return array
  168 + */
  169 + private function montaRetornoListagemProcessos(array $ret, $usuarioAtribuicaoAtividade = null){
  170 +
  171 + $result = array();
  172 + /** @var MdWsSeiProtocoloDTO $protocoloDTO */
  173 + foreach($ret as $protocoloDTO){
  174 + $usuarioAtribuido = null;
  175 + $documentoNovo = 'N';
  176 + $documentoPublicado = 'N';
  177 + $possuiAnotacao = 'N';
  178 + $possuiAnotacaoPrioridade = 'N';
  179 + $usuarioVisualizacao = 'N';
  180 + $tipoVisualizacao = 'N';
  181 + $retornoProgramado = 'N';
  182 + $retornoAtrasado = 'N';
  183 +
  184 + $atividadeRN = new AtividadeRN();
  185 + $atividadeDTOConsulta = new AtividadeDTO();
  186 + $atividadeDTOConsulta->setDblIdProtocolo($protocoloDTO->getDblIdProtocolo());
  187 + $atividadeDTOConsulta->retTodos(true);
  188 + $atividadeDTOConsulta->setOrdNumIdAtividade(InfraDTO::$TIPO_ORDENACAO_DESC);
  189 + $arrAtividades = $atividadeRN->listarRN0036($atividadeDTOConsulta);
  190 + if($arrAtividades){
  191 + /** @var AtividadeDTO $atividadeDTO */
  192 + $atividadeDTO = $arrAtividades[0];
  193 + $documentoNovo = $atividadeDTO->getNumIdTarefa() == 1 ? 'S' : 'N';
  194 + $usuarioAtribuido = $atividadeDTO->getStrNomeUsuarioAtribuicao();
  195 + $dadosRetornoProgramado = $this->checaRetornoProgramado($atividadeDTO);
  196 + $retornoProgramado = $dadosRetornoProgramado['retornoProgramado'];
  197 + $retornoAtrasado = $dadosRetornoProgramado['expirado'];
  198 + $tipoVisualizacao = $atividadeDTO->getNumTipoVisualizacao() == 0 ? 'S' : 'N';
  199 + if($atividadeDTO->getNumIdUsuarioVisualizacao() == $usuarioAtribuicaoAtividade){
  200 + $usuarioVisualizacao = 'S';
  201 + }
  202 + }
  203 + $documentoRN = new DocumentoRN();
  204 + $documentoDTOConsulta = new DocumentoDTO();
  205 + $documentoDTOConsulta->setDblIdProcedimento($protocoloDTO->getDblIdProtocolo());
  206 + $documentoDTOConsulta->retDblIdDocumento();
  207 + $arrDocumentos = $documentoRN->listarRN0008($documentoDTOConsulta);
  208 + if($arrDocumentos){
  209 + $arrIdDocumentos = array();
  210 + /** @var DocumentoDTO $documentoDTO */
  211 + foreach($arrDocumentos as $documentoDTO){
  212 + $arrIdDocumentos[] = $documentoDTO->getDblIdDocumento();
  213 + }
  214 + $publiacaoRN = new PublicacaoRN();
  215 + $publicacaoDTO = new PublicacaoDTO();
  216 + $publicacaoDTO->retNumIdPublicacao();
  217 + $publicacaoDTO->setNumMaxRegistrosRetorno(1);
  218 + $publicacaoDTO->adicionarCriterio(
  219 + array('IdDocumento'),
  220 + array(InfraDTO::$OPER_IN),
  221 + array($arrIdDocumentos)
  222 + );
  223 + $arrPublicacaoDTO = $publiacaoRN->listarRN1045($publicacaoDTO);
  224 + $documentoPublicado = count($arrPublicacaoDTO) ? 'S' : 'N';
  225 + }
  226 +
  227 + $anotacaoRN = new AnotacaoRN();
  228 + $anotacaoDTO = new AnotacaoDTO();
  229 + $anotacaoDTO->setNumMaxRegistrosRetorno(1);
  230 + $anotacaoDTO->retNumIdAnotacao();
  231 + $anotacaoDTO->setDblIdProtocolo($protocoloDTO->getDblIdProtocolo());
  232 + $arrAnotacao = $anotacaoRN->listar($anotacaoDTO);
  233 + $possuiAnotacao = count($arrAnotacao) ? 'S' : 'N';
  234 + $anotacaoDTO->setStrSinPrioridade('S');
  235 + $arrAnotacaoPrioridade = $anotacaoRN->listar($anotacaoDTO);
  236 + $possuiAnotacaoPrioridade = count($arrAnotacaoPrioridade) ? 'S' : 'N';
  237 +
  238 + $result[] = array(
  239 + 'id' => $protocoloDTO->getDblIdProtocolo(),
  240 + 'status' => $protocoloDTO->getStrStaProtocolo(),
  241 + 'atributos' => array(
  242 + 'idProcedimento' => $protocoloDTO->getDblIdProtocolo(),
  243 + 'idProtocolo' => $protocoloDTO->getDblIdProtocolo(),
  244 + 'numero' => $protocoloDTO->getStrProtocoloFormatado(),
  245 + 'tipoProcesso' => $protocoloDTO->getStrNomeTipoProcedimentoProcedimento(),
  246 + 'descricao' => $protocoloDTO->getStrDescricao(),
  247 + 'usuarioAtribuido' => $usuarioAtribuido,
  248 + 'status' => array(
  249 + 'documentoSigiloso' => $protocoloDTO->getStrStaGrauSigilo(),
  250 + 'documentoRestrito' => $protocoloDTO->getStrStaNivelAcessoLocal() == 1 ? 'S' : 'N',
  251 + 'documentoNovo' => $documentoNovo,
  252 + 'documentoPublicado' => $documentoPublicado,
  253 + 'anotacao' => $possuiAnotacao,
  254 + 'anotacaoPrioridade' => $possuiAnotacaoPrioridade,
  255 + 'ciencia' => $protocoloDTO->getStrSinCienciaProcedimento(),
  256 + 'retornoProgramado' => $retornoProgramado,
  257 + 'retornoAtrasado' => $retornoAtrasado,
  258 + 'processoAcessadoUsuario' => $tipoVisualizacao,
  259 + // foi invertido o processoAcessadoUsuario e processoAcessadoUnidade,
  260 + // pois em todos os outros metodos e igual e somente neste era diferente...
  261 + 'processoAcessadoUnidade' => $usuarioVisualizacao,
  262 + )
  263 + )
  264 + );
  265 + }
  266 +
  267 + return $result;
  268 + }
  269 +
  270 + private function checaRetornoProgramado($atividade){
  271 + $retProgramado = 'N';
  272 + $expirado = 'N';
  273 +
  274 + if ($atividade instanceof AtividadeDTO) {
  275 + $retornoProgramadoRN = new RetornoProgramadoRN();
  276 + $retornoProgramadoDTO = new RetornoProgramadoDTO();
  277 + $retornoProgramadoDTO->adicionarCriterio(
  278 + array('IdAtividadeEnvio', 'IdAtividadeRetorno'),
  279 + array(InfraDTO::$OPER_IGUAL, InfraDTO::$OPER_IGUAL),
  280 + array($atividade->getNumIdAtividade(), null)
  281 + );
  282 + $retornoProgramadoDTO = $retornoProgramadoRN->consultar($retornoProgramadoDTO);
  283 +
  284 + if ($retornoProgramadoDTO) {
  285 + echo 556;
  286 + $expirado = ($retornoProgramadoDTO->getDtaProgramada() < new Datetime());
  287 + $retProgramado = 'S';
  288 + }
  289 + }
  290 +
  291 + return ['retornoProgramado' => $retProgramado, 'expirado' => $expirado];
  292 + }
  293 +
  294 +
  295 + /**
  296 + * Metodo que da ciencia ao processo/procedimento
  297 + * @param ProcedimentoDTO $procedimentoDTO
  298 + * @info E obrigatorio informar o id do procedimento
  299 + * @return array
  300 + */
  301 + protected function darCienciaControlado(ProcedimentoDTO $procedimentoDTO){
  302 + try{
  303 + if(!$procedimentoDTO->isSetDblIdProcedimento()){
  304 + throw new InfraException('E obrigatorio informar o procedimento!');
  305 + }
  306 +
  307 + $procedimentoRN = new ProcedimentoRN();
  308 + $procedimentoRN->darCiencia($procedimentoDTO);
  309 +
  310 + return array(
  311 + 'sucesso' => true,
  312 + 'mensagem' => 'Ciência processo realizado com sucesso!'
  313 + );
  314 + }catch (Exception $e){
  315 + return array(
  316 + 'sucesso' => false,
  317 + 'mensagem' => $e->getMessage(),
  318 + 'exception' => $e
  319 + );
  320 + }
  321 + }
  322 +
  323 + /**
  324 + * Metodo que conclui o procedimento/processo
  325 + * @param EntradaConcluirProcessoAPI $entradaConcluirProcessoAPI
  326 + * @info ele recebe o número do ProtocoloProcedimentoFormatadoPesquisa da tabela protocolo
  327 + * @return array
  328 + */
  329 + protected function concluirProcessoControlado(EntradaConcluirProcessoAPI $entradaConcluirProcessoAPI){
  330 + try{
  331 + if(!$entradaConcluirProcessoAPI->getProtocoloProcedimento()){
  332 + throw new InfraException('E obrigtorio informar o protocolo do procedimento!');
  333 + }
  334 +
  335 + $objSeiRN = new SeiRN();
  336 + $objSeiRN->concluirProcesso($entradaConcluirProcessoAPI);
  337 +
  338 + return array(
  339 + 'sucesso' => true,
  340 + 'mensagem' => 'Processo concluído com sucesso!'
  341 + );
  342 + }catch (Exception $e){
  343 + return array(
  344 + 'sucesso' => false,
  345 + 'mensagem' => $e->getMessage(),
  346 + 'exception' => $e
  347 + );
  348 + }
  349 + }
  350 +
  351 + /**
  352 + * Metodo que atribui o processo a uma pessoa
  353 + * @param EntradaAtribuirProcessoAPI $entradaAtribuirProcessoAPI
  354 + * @info Os parametros IdUsuario, ProtocoloProcedimento e SinReabrir sao obrigatorios. O parametro ProtocoloProcedimento
  355 + * recebe o número do ProtocoloProcedimentoFormatadoPesquisa da tabela protocolo
  356 + * @return array
  357 + */
  358 + protected function atribuirProcessoControlado(EntradaAtribuirProcessoAPI $entradaAtribuirProcessoAPI){
  359 + try{
  360 + if(!$entradaAtribuirProcessoAPI->getProtocoloProcedimento()){
  361 + throw new InfraException('E obrigatorio informar o protocolo do processo!');
  362 + }
  363 + if(!$entradaAtribuirProcessoAPI->getIdUsuario()){
  364 + throw new InfraException('E obrigatorio informar o usuário do processo!');
  365 + }
  366 +
  367 + $objSeiRN = new SeiRN();
  368 + $objSeiRN->atribuirProcesso($entradaAtribuirProcessoAPI);
  369 +
  370 + return array(
  371 + 'sucesso' => true,
  372 + 'mensagem' => 'Processo atribuído com sucesso!'
  373 + );
  374 + }catch (Exception $e){
  375 + return array(
  376 + 'sucesso' => false,
  377 + 'mensagem' => 'Nao foi possível atribuir o processo!',
  378 + 'exception' => $e
  379 + );
  380 + }
  381 + }
  382 +
  383 + /**
  384 + * Encapsula o objeto ENtradaEnviarProcessoAPI para o metodo enviarProcesso
  385 + * @param array $post
  386 + * @return EntradaEnviarProcessoAPI
  387 + */
  388 + public function encapsulaEnviarProcessoEntradaEnviarProcessoAPI(array $post){
  389 + $entradaEnviarProcessoAPI = new EntradaEnviarProcessoAPI();
  390 + if(isset($post['numeroProcesso'])){
  391 + $entradaEnviarProcessoAPI->setProtocoloProcedimento($post['numeroProcesso']);
  392 + }
  393 + if(isset($post['unidadeDestino'])){
  394 + $entradaEnviarProcessoAPI->setUnidadesDestino($post['unidadeDestino']);
  395 + }
  396 + if(isset($post['sinManterAbertoUnidade'])){
  397 + $entradaEnviarProcessoAPI->setSinManterAbertoUnidade($post['sinManterAbertoUnidade']);
  398 + }
  399 + if(isset($post['sinRemoverAnotacao'])){
  400 + $entradaEnviarProcessoAPI->setSinRemoverAnotacao($post['sinRemoverAnotacao']);
  401 + }
  402 + if(isset($post['sinEnviarEmailNotificacao'])){
  403 + $entradaEnviarProcessoAPI->setSinEnviarEmailNotificacao($post['sinEnviarEmailNotificacao']);
  404 + }
  405 + if(isset($post['dataRetornoProgramado'])){
  406 + $entradaEnviarProcessoAPI->setDataRetornoProgramado($post['dataRetornoProgramado']);
  407 + }
  408 + if(isset($post['diasRetornoProgramado'])){
  409 + $entradaEnviarProcessoAPI->setDiasRetornoProgramado($post['diasRetornoProgramado']);
  410 + }
  411 + if(isset($post['sinDiasUteisRetornoProgramado'])){
  412 + $entradaEnviarProcessoAPI->setSinDiasUteisRetornoProgramado($post['sinDiasUteisRetornoProgramado']);
  413 + }
  414 + if(isset($post['sinReabrir'])){
  415 + $entradaEnviarProcessoAPI->setSinReabrir($post['sinReabrir']);
  416 + }
  417 +
  418 + return $entradaEnviarProcessoAPI;
  419 + }
  420 +
  421 + /**
  422 + * Metodo que envia o processo para outra unidade
  423 + * @param EntradaEnviarProcessoAPI $entradaEnviarProcessoAPI
  424 + * @info Metodo auxiliar para encapsular dados encapsulaEnviarProcessoEntradaEnviarProcessoAPI
  425 + * @return array
  426 + */
  427 + protected function enviarProcessoControlado(EntradaEnviarProcessoAPI $entradaEnviarProcessoAPI){
  428 + try{
  429 + $objSeiRN = new SeiRN();
  430 + $objSeiRN->enviarProcesso($entradaEnviarProcessoAPI);
  431 +
  432 + return array(
  433 + 'sucesso' => true,
  434 + 'mensagem' => 'Processo enviado com sucesso!'
  435 + );
  436 + }catch (Exception $e){
  437 + return array(
  438 + 'sucesso' => false,
  439 + 'mensagem' => 'Nao foi possível enviar o processo!',
  440 + 'exception' => $e
  441 + );
  442 + }
  443 + }
  444 +
  445 +
  446 +
  447 +}
0 448 \ No newline at end of file
... ...
rn/MdWsSeiProcessoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiProcessoRN.php
... ... @@ -0,0 +1,57 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiProcessoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * Metodo que traduz o template pelo id da atividade e a string do template
  12 + * @param MdWsSeiProcessoDTO $mdWsSeiProcessoDTO
  13 + * @return string
  14 + */
  15 + protected function traduzirTemplateConectado(MdWsSeiProcessoDTO $mdWsSeiProcessoDTO){
  16 + $strTemplate = $mdWsSeiProcessoDTO->getStrTemplate();
  17 + if ($strTemplate) {
  18 + $atributoAndamentoRN = new AtributoAndamentoRN();
  19 + $atributoAndamentoDTOConsulta = new AtributoAndamentoDTO();
  20 + $atributoAndamentoDTOConsulta->retTodos();
  21 + $atributoAndamentoDTOConsulta->setNumIdAtividade($mdWsSeiProcessoDTO->getNumIdAtividade());
  22 + $ret = $atributoAndamentoRN->listarRN1367($atributoAndamentoDTOConsulta);
  23 + $atividadeDTO = new AtividadeDTO();
  24 + $atividadeDTO->setNumIdAtividade($mdWsSeiProcessoDTO->getNumIdAtividade());
  25 + $atividadeDTO->retDblIdProtocolo();
  26 + $atividadeRN = new AtividadeRN();
  27 + $atividadeDTO = $atividadeRN->consultarRN0033($atividadeDTO);
  28 + $protocoloDTO = new ProtocoloDTO();
  29 + $protocoloDTO->retStrStaGrauSigilo();
  30 + $protocoloDTO->setDblIdProtocolo($atividadeDTO->getDblIdProtocolo());
  31 + $protocoloRN = new ProtocoloRN();
  32 + $protocoloDTO = $protocoloRN->consultarRN0186($protocoloDTO);
  33 +
  34 + if ($ret) {
  35 + /** @var AtributoAndamentoDTO $atributoAndamentoDTO */
  36 + foreach($ret as $atributoAndamentoDTO) {
  37 + $valor = $atributoAndamentoDTO->getStrValor();
  38 +
  39 + if (strripos($valor, '¥')) {
  40 + $valor = explode('¥', $atributoAndamentoDTO->getStrValor());
  41 + $valor = $valor[0];
  42 + }
  43 +
  44 + $strTemplate = str_replace('@' . $atributoAndamentoDTO->getStrNome() . '@', $valor, $strTemplate);
  45 +
  46 + $sigilo = ($protocoloDTO->getStrStaGrauSigilo())? 'sigiloso': 'nao sigiloso';
  47 +
  48 + $strTemplate = str_replace('@GRAU_SIGILO@', $sigilo, $strTemplate);
  49 + $strTemplate = str_replace('@HIPOTESE_LEGAL@', '', $strTemplate);
  50 + }
  51 + }
  52 + }
  53 +
  54 + return $strTemplate;
  55 + }
  56 +
  57 +}
0 58 \ No newline at end of file
... ...
rn/MdWsSeiRetornoProgramadoRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiRetornoProgramadoRN.php
... ... @@ -0,0 +1,56 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiRetornoProgramadoRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + public function encapsulaRetornoProgramado(array $post){
  11 + $retornoProgramadoDTO = new RetornoProgramadoDTO();
  12 + $retornoProgramadoDTO->setNumIdRetornoProgramado(null);
  13 + $retornoProgramadoDTO->setDthAlteracao(null);
  14 + if (isset($post['usuario'])) {
  15 + $retornoProgramadoDTO->setNumIdUsuario($post['usuario']);
  16 + }
  17 +
  18 + if (isset($post['atividadeEnvio'])) {
  19 + $retornoProgramadoDTO->setNumIdAtividadeEnvio($post['atividadeEnvio']);
  20 + }
  21 +
  22 + if (isset($post['unidade'])) {
  23 + $retornoProgramadoDTO->setNumIdUnidade($post['unidade']);
  24 + }
  25 +
  26 + if (isset($post['dtProgramada'])) {
  27 + $retornoProgramadoDTO->setDtaProgramada($post['dtProgramada']);
  28 + }
  29 +
  30 + return $retornoProgramadoDTO;
  31 + }
  32 +
  33 + /**
  34 + * Metodo que agenda um retorno programado
  35 + * @param RetornoProgramadoDTO $retornoProgramadoDTO
  36 + * @info metodo auxiliar encapsulaRetornoProgramado para facilitar encapsulamento
  37 + * @return array
  38 + */
  39 + protected function agendarRetornoProgramadoControlado(RetornoProgramadoDTO $retornoProgramadoDTO){
  40 + try{
  41 + $retornoProgramadoRN = new RetornoProgramadoRN();
  42 + $retornoProgramadoRN->cadastrar($retornoProgramadoDTO);
  43 +
  44 + return array(
  45 + 'sucesso' => true,
  46 + 'mensagem' => 'Retorno Programado agendado com sucesso!'
  47 + );
  48 + }catch (Exception $e){
  49 + return array(
  50 + 'sucesso' => false,
  51 + 'mensagem' => $e->getMessage(),
  52 + 'exception' => $e
  53 + );
  54 + }
  55 + }
  56 +}
0 57 \ No newline at end of file
... ...
rn/MdWsSeiUnidadeRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiUnidadeRN.php
... ... @@ -0,0 +1,43 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiUnidadeRN extends InfraRN {
  5 +
  6 + protected function inicializarObjInfraIBanco(){
  7 + return BancoSEI::getInstance();
  8 + }
  9 +
  10 + /**
  11 + * Retorna todas as unidades cadastradas
  12 + */
  13 + protected function listarUnidadesConectado(){
  14 + try{
  15 + $unidadeRN = new UnidadeRN();
  16 + $unidadeDTO = new UnidadeDTO();
  17 + $unidadeDTO->retNumIdUnidade();
  18 + $unidadeDTO->retStrSigla();
  19 + $unidadeDTO->retStrDescricao();
  20 + $ret = $unidadeRN->listarRN0127($unidadeDTO);
  21 + $result = array();
  22 + /** @var UnidadeDTO $unDTO */
  23 + foreach($ret as $unDTO){
  24 + $result[] = array(
  25 + 'id' => $unDTO->getNumIdUnidade(),
  26 + 'sigla' => $unDTO->getStrSigla(),
  27 + 'descricao' => $unDTO->getStrDescricao()
  28 + );
  29 + }
  30 + return array(
  31 + 'sucesso' => true,
  32 + 'data' => $result
  33 + );
  34 + }catch (Exception $e){
  35 + return array(
  36 + 'sucesso' => false,
  37 + 'mensagem' => $e->getMessage(),
  38 + 'exception' => $e
  39 + );
  40 + }
  41 + }
  42 +
  43 +}
0 44 \ No newline at end of file
... ...
rn/MdWsSeiUsuarioRN.php 0 → 100644
  1 +++ a/rn/MdWsSeiUsuarioRN.php
... ... @@ -0,0 +1,215 @@
  1 +<?
  2 +require_once dirname(__FILE__).'/../../../SEI.php';
  3 +
  4 +class MdWsSeiUsuarioRN extends InfraRN {
  5 +
  6 + CONST TOKEN_SECRET = '<!RWR1YXJkbyBSb23Do28!>';
  7 +
  8 + protected function inicializarObjInfraIBanco(){
  9 + return BancoSEI::getInstance();
  10 + }
  11 +
  12 + /**
  13 + * Método que retorna o serviço SOAP do SIP
  14 + * @return SoapClient
  15 + * @throws InfraException
  16 + */
  17 + private function retornaServicoSip(){
  18 + $strWSDL = ConfiguracaoSEI::getInstance()->getValor('SessaoSEI', 'SipWsdl');
  19 + try{
  20 + if (!InfraUtil::isBolUrlValida($strWSDL)){
  21 + if(!@file_get_contents($strWSDL)) {
  22 + throw new InfraException('Arquivo WSDL '.$strWSDL.' n?o encontrado.');
  23 + }
  24 + }
  25 + }catch(Exception $e){
  26 + throw new InfraException('Falha na conexção com o Sistema de Permissões.',$e);
  27 + }
  28 +
  29 + try{
  30 + $objSipWS = new SoapClient($strWSDL, array('encoding'=>'ISO-8859-1'));
  31 + return $objSipWS;
  32 + }catch(Exception $e){
  33 + throw new InfraException('Erro acessando o Sistema de Permissões.');
  34 + }
  35 + }
  36 +
  37 + /**
  38 + * Método que descriptografa o token
  39 + * @param $token
  40 + * @return string
  41 + */
  42 + public function tokenDecode($token){
  43 + $fase1 = base64_decode($token);
  44 + $fase2 = str_replace($this->getSecret(), '', $fase1);
  45 + $fase3 = base64_decode($fase2);
  46 + $tokenData = explode('||', $fase3);
  47 + if(count($tokenData) != 2){
  48 + return null;
  49 + }
  50 + $tokenData[0] = $this->decriptaSenha($tokenData[0]);
  51 + $tokenData[1] = $this->decriptaSenha($tokenData[1]);
  52 +
  53 + return $tokenData;
  54 + }
  55 +
  56 + /**
  57 + * Método que criptografa o token
  58 + * @param $sigla
  59 + * @param $senha
  60 + * @return string
  61 + */
  62 + public function tokenEncode($sigla, $senha){
  63 + $token = base64_encode($this->getSecret().base64_encode($this->encriptaSenha($sigla).'||'.$this->encriptaSenha($senha)));
  64 +
  65 + return $token;
  66 + }
  67 +
  68 + /**
  69 + * Retorna a chave da criptografia
  70 + * @return string
  71 + */
  72 + private function getSecret(){
  73 + $data = new DateTime();
  74 + $strData = $data->format('Ymd');
  75 + $secret = sha1(self::TOKEN_SECRET.$strData);
  76 + return $secret;
  77 + }
  78 +
  79 + /**
  80 + * Go horse para autenticar usuário... Não ha como instanciar o SessaoSEI por metodos convencionais.
  81 + * @param stdClass $loginData
  82 + */
  83 + private function setaVariaveisAutenticacao(stdClass $loginData){
  84 + $_GET['id_login'] = $loginData->id_login;
  85 + $_GET['id_sistema'] = $loginData->id_sistema;
  86 + $_GET['id_usuario'] = $loginData->id_usuario;
  87 + $_GET['hash_agente'] = SessaoSEI::gerarHashAgente();
  88 + $_GET['infra_sip'] = true;
  89 + $_GET['id_contexto'] = '';
  90 + }
  91 +
  92 + /**
  93 + * Método que autentica o usuário pelo token
  94 + * @param $token
  95 + * @return bool
  96 + * @throws InfraException
  97 + */
  98 + public function autenticarToken($token){
  99 + try{
  100 +
  101 + $tokenData = $this->tokenDecode($token);
  102 + if(!$tokenData){
  103 + throw new InfraException('Token inválido!');
  104 + }
  105 +
  106 + $usuarioDTO = new UsuarioDTO();
  107 + $usuarioDTO->setStrSigla($tokenData[0]);
  108 + $usuarioDTO->setStrSenha($tokenData[1]);
  109 + $result = $this->autenticar($usuarioDTO);
  110 + if(!$result['sucesso']){
  111 + return $result;
  112 + }
  113 + $this->setaVariaveisAutenticacao($result['data']);
  114 +
  115 + return $result;
  116 + }catch (Exception $e){
  117 + return array(
  118 + 'sucesso' => false,
  119 + 'mensagem' => $e->getMessage(),
  120 + 'exception' => $e
  121 + );
  122 + }
  123 + }
  124 +
  125 + /**
  126 + * MÈtodo de autenticação de usuários usando SIP
  127 + * @param UsuarioDTO
  128 + * @param $sigla
  129 + * @param $senha
  130 + * @param $IdOrgao
  131 + */
  132 + protected function autenticarConectado(UsuarioDTO $usuarioDTO){
  133 + try{
  134 + if(!$usuarioDTO->isSetNumIdOrgao()){
  135 + $orgaoRN = new OrgaoRN();
  136 + $objOrgaoDTO = new OrgaoDTO();
  137 + $objOrgaoDTO->setBolExclusaoLogica(false);
  138 + $objOrgaoDTO->retNumIdOrgao();
  139 + $objOrgaoDTO->setStrSigla(ConfiguracaoSEI::getInstance()->getValor('SessaoSEI', 'SiglaOrgaoSistema'));
  140 + /**
  141 + * @var $orgaoCarregdo OrgaoDTO
  142 + * Orgao da sessao do sistema
  143 + */
  144 + $orgaoCarregdo = $orgaoRN->consultarRN1352($objOrgaoDTO);
  145 + $usuarioDTO->setNumIdOrgao($orgaoCarregdo->getNumIdOrgao());
  146 + }
  147 + $objSipWs = $this->retornaServicoSip();
  148 + $ret = $objSipWs->autenticar(
  149 + $usuarioDTO->getNumIdOrgao(),
  150 + null,
  151 + $usuarioDTO->getStrSigla(),
  152 + $this->encriptaSenha($usuarioDTO->getStrSenha()),
  153 + ConfiguracaoSEI::getInstance()->getValor('SessaoSEI', 'SiglaSistema'),
  154 + ConfiguracaoSEI::getInstance()->getValor('SessaoSEI', 'SiglaOrgaoSistema')
  155 + );
  156 + if(!$ret){
  157 + throw new InfraException('Usuário ou senha inválido!');
  158 + }
  159 + return array(
  160 + 'sucesso' => true,
  161 + 'data' => $ret,
  162 + 'token' => $this->tokenEncode($usuarioDTO->getStrSigla(), $usuarioDTO->getStrSenha())
  163 + );
  164 + }catch (Exception $e){
  165 + return array(
  166 + 'sucesso' => false,
  167 + 'mensagem' => $e->getMessage(),
  168 + 'exception' => $e
  169 + );
  170 + }
  171 +
  172 + }
  173 +
  174 + /**
  175 + * Retorna a lista de usuários por unidade
  176 + * @param UsuarioDTO
  177 + * @param $idUsuario
  178 + */
  179 + protected function listarUsuariosConectado(UsuarioDTO $usuarioDTO){
  180 + try{
  181 + $objEntradaListarUsuariosAPI = new EntradaListarUsuariosAPI();
  182 + $objEntradaListarUsuariosAPI->setIdUsuario($usuarioDTO->getNumIdUsuario());
  183 + $objSeiRN = new SeiRN();
  184 + $result = $objSeiRN->listarUsuarios($objEntradaListarUsuariosAPI);
  185 + return array(
  186 + 'sucesso' => true,
  187 + 'data' => $result
  188 + );
  189 + }catch(Exception $e){
  190 + return array(
  191 + 'sucesso' => false,
  192 + 'mensagem' => 'Erro no serviço de listagem de usuários.',
  193 + 'exception' => $e
  194 + );
  195 + }
  196 + }
  197 +
  198 + private function decriptaSenha($senha){
  199 + $decoded = base64_decode($senha);
  200 + for($i = 0; $i < strlen($decoded); $i++){
  201 + $decoded[$i] = ~$decoded[$i];
  202 + }
  203 +
  204 + return $decoded;
  205 + }
  206 +
  207 + private function encriptaSenha($senha){
  208 + for($i = 0; $i < strlen($senha); $i++){
  209 + $senha[$i] = ~$senha[$i];
  210 + }
  211 +
  212 + return base64_encode($senha);
  213 + }
  214 +
  215 +}
0 216 \ No newline at end of file
... ...
teste.php 0 → 100644
  1 +++ a/teste.php
... ... @@ -0,0 +1,284 @@
  1 +<?
  2 +
  3 +require_once __DIR__.'/../../SEI.php';
  4 +
  5 +ini_set('xdebug.var_display_max_depth', 100);
  6 +ini_set('xdebug.var_display_max_children', 100);
  7 +ini_set('xdebug.var_display_max_data', 2048);
  8 +
  9 +
  10 +class TesteBloco {
  11 +
  12 + public function listarBlocoUnidadeConectado(){
  13 + $rn = new MdWsSeiBlocoRN();
  14 + $dto = new UnidadeDTO();
  15 + $dto->setNumIdUnidade(110000001);
  16 + var_dump($rn->listarBlocoUnidade($dto));
  17 + }
  18 +
  19 + public function listarDocumentosBlocoConectado(){
  20 + $rn = new MdWsSeiBlocoRN();
  21 + $dto = new BlocoDTO();
  22 + $dto->setNumIdBloco(1);
  23 + var_dump($rn->listarDocumentosBloco($dto));
  24 + }
  25 +
  26 + public function cadastrarAnotacaoBlocoControlado(){
  27 + $rn = new MdWsSeiBlocoRN();
  28 + $dto = new RelBlocoProtocoloDTO();
  29 + $dto->setNumIdBloco(1);
  30 + $dto->setDblIdProtocolo(4);
  31 + $dto->setStrAnotacao('Teste');
  32 + var_dump($rn->cadastrarAnotacaoBloco($dto));
  33 + }
  34 +
  35 +}
  36 +
  37 +class TesteDocumento {
  38 +
  39 + public function listarCienciaDocumentoConectado(){
  40 + $rn = new MdWsSeiDocumentoRN();
  41 + $dto = new MdWsSeiProcessoDTO();
  42 + $dto->setStrValor('0000007');
  43 + var_dump($rn->listarCienciaDocumento($dto));
  44 + }
  45 +
  46 + public function listarAssinaturasDocumentoConectado(){
  47 + $rn = new MdWsSeiDocumentoRN();
  48 + $dto = new DocumentoDTO();
  49 + $dto->setDblIdDocumento(3);
  50 + var_dump($rn->listarAssinaturasDocumento($dto));
  51 + }
  52 + public function darCienciaControlado(){
  53 + $dto = new DocumentoDTO();
  54 + $dto->setDblIdDocumento(18);
  55 + $rn = new MdWsSeiDocumentoRN();
  56 + var_dump($rn->darCiencia($dto));
  57 + }
  58 +
  59 + public function assinarDocumentoControlado(){
  60 + $dto = new AssinaturaDTO();
  61 + $dto->setStrSenhaUsuario('teste');
  62 + $dto->setStrSiglaUsuario('teste');
  63 + $dto->setNumIdUsuario(100000001);
  64 + $dto->setNumIdContextoUsuario(null);
  65 + $dto->setStrStaFormaAutenticacao(AssinaturaRN::$TA_SENHA);
  66 + $dto->setStrCargoFuncao('Fiscal de Contrato - Administrativo');
  67 + $dto->setNumIdOrgaoUsuario(0);
  68 + $doc1 = new DocumentoDTO();
  69 + $doc1->setDblIdDocumento(19);
  70 + $doc2 = new DocumentoDTO();
  71 + $doc2->setDblIdDocumento(20);
  72 + $documentos = array(
  73 + $doc1,
  74 + $doc2
  75 + );
  76 + $dto->setArrObjDocumentoDTO($documentos);
  77 + $rn = new MdWsSeiDocumentoRN();
  78 + var_dump($rn->assinarDocumento($dto));
  79 + }
  80 +
  81 + public function apiAssinarDocumentos(){
  82 + $arrDocumentos = array(21, 22);
  83 + $rn = new MdWsSeiDocumentoRN();
  84 + var_dump($rn->apiAssinarDocumentos($arrDocumentos, 0, 'Fiscal de Contrato - Administrativo', 'teste', 'teste', 100000001));
  85 + }
  86 +
  87 + public function apiAssinarDocumento(){
  88 + $rn = new MdWsSeiDocumentoRN();
  89 + var_dump($rn->apiAssinarDocumento(22, 0, 'Fiscal de Contrato - Administrativo', 'teste', 'teste', 100000001));
  90 + }
  91 +
  92 +}
  93 +
  94 +
  95 +class TesteProcedimento {
  96 +
  97 + public function removerSobrestamentoProcessoControlado(){
  98 + $rn = new MdWsSeiProcedimentoRN();
  99 + $dto = new ProcedimentoDTO();
  100 + $dto->setDblIdProcedimento(15);
  101 + var_dump($rn->removerSobrestamentoProcesso($dto));
  102 + }
  103 +
  104 + //o-----
  105 +
  106 + public function concluirProcessoControlado(){
  107 + $api = new EntradaConcluirProcessoAPI();
  108 + $api->setProtocoloProcedimento('99990000001201762');
  109 + $rn = new MdWsSeiProcedimentoRN();
  110 + var_dump($rn->concluirProcesso($api));
  111 + }
  112 +
  113 + public function atribuirProcessoControlado(){
  114 + $api = new EntradaAtribuirProcessoAPI();
  115 + $api->setProtocoloProcedimento('99990000001201762');
  116 + $api->setIdUsuario('100000001');
  117 + $rn = new MdWsSeiProcedimentoRN();
  118 + var_dump($rn->atribuirProcesso($api));
  119 + }
  120 +
  121 + public function listarProcedimentoAcompanhamentoConectado(){
  122 + $dto = new MdWsSeiProtocoloDTO();
  123 + $rn = new MdWsSeiProcedimentoRN();
  124 + $dto->setNumIdUsuarioGeradorAcompanhamento('100000001');
  125 + //$dto->setNumidGrupoAcompanhamentoProcedimento(1);
  126 + $dto->setNumPaginaAtual(0);
  127 + $dto->setNumMaxRegistrosRetorno(10);
  128 +
  129 + var_dump($rn->listarProcedimentoAcompanhamento($dto));
  130 + }
  131 +
  132 + public function listarProcessosConectado(){
  133 + $rn = new MdWsSeiProcedimentoRN();
  134 + $dto = new MdWsSeiProtocoloDTO();
  135 + $dto->setNumIdUsuarioAtribuicaoAtividade('100000001');
  136 + $dto->setNumIdUnidadeAtividade('110000001');
  137 + $dto->setStrSinTipoBusca(MdWsSeiProtocoloDTO::SIN_TIPO_BUSCA_M);
  138 + $dto->setNumPaginaAtual(0);
  139 + $dto->setNumMaxRegistrosRetorno(10);
  140 +
  141 + var_dump($rn->listarProcessos($dto));
  142 + }
  143 +}
  144 +
  145 +
  146 +
  147 +
  148 +
  149 +
  150 +
  151 +
  152 +
  153 +
  154 +//o-----
  155 +class TesteUnidade {
  156 +
  157 + public function listarUnidadesConectado(){
  158 + $mdUnidade = new MdWsSeiUnidadeRN();
  159 + var_dump($mdUnidade->listarUnidades());
  160 + }
  161 +}
  162 +class TesteOrgao {
  163 +
  164 + public function listarOrgaoConectado(){
  165 + $orgaoDTO = new OrgaoDTO();
  166 + $orgaoDTO->setNumMaxRegistrosRetorno(10);
  167 + $orgaoDTO->setNumPaginaAtual(0);
  168 + $mdUnidade = new MdWsSeiOrgaoRN();
  169 + var_dump($mdUnidade->listarOrgao($orgaoDTO));
  170 + }
  171 +}
  172 +
  173 +class TesteGrupoAcompanhamento {
  174 +
  175 + public function listarGrupoAcompanhamentoConectado(){
  176 + $dto = new GrupoAcompanhamentoDTO();
  177 + $dto->setNumMaxRegistrosRetorno(10);
  178 + $dto->setNumPaginaAtual(0);
  179 + $dto->setNumIdUnidade('110000001');
  180 + $rn = new MdWsSeiGrupoAcompanhamentoRN();
  181 + var_dump($rn->listarGrupoAcompanhamento($dto));
  182 + }
  183 +}
  184 +
  185 +class TesteRetornoProgramado {
  186 +
  187 + public function agendarRetornoProgramadoControlado(){
  188 + $post = array(
  189 + 'dtProgramada' => '28/09/2017',
  190 + 'unidade' => '110000001',
  191 + 'usuario' => '100000001',
  192 + 'atividadeEnvio' => 1
  193 + );
  194 + $rn = new MdWsSeiRetornoProgramadoRN();
  195 + $dto = $rn->encapsulaRetornoProgramado($post);
  196 + var_dump($rn->agendarRetornoProgramado($dto));
  197 + }
  198 +}
  199 +
  200 +
  201 +class TesteObservacao {
  202 +
  203 + public function criarObservacaoControlado(){
  204 + $post = array(
  205 + 'unidade' => '110000001',
  206 + 'descricao' => 'dsadsadas dsa',
  207 + 'protocolo' => 1
  208 + );
  209 + $rn = new MdWsSeiObservacaoRN();
  210 + $dto = $rn->encapsulaObservacao($post);
  211 + var_dump($rn->criarObservacao($dto));
  212 + }
  213 +}
  214 +
  215 +
  216 +class TesteAnotacao {
  217 +
  218 + public function cadastrarAnotacaoControlado(){
  219 + $post = array(
  220 + 'unidade' => '110000001',
  221 + 'descricao' => 'aaa nov',
  222 + 'protocolo' => 1,
  223 + 'usuario' => '100000001',
  224 + 'prioridade' => 'S'
  225 + );
  226 + $rn = new MdWsSeiAnotacaoRN();
  227 + $dto = $rn->encapsulaAnotacao($post);
  228 + var_dump($rn->cadastrarAnotacao($dto));
  229 + }
  230 +}
  231 +
  232 +class TesteUsuario {
  233 +
  234 + public function autenticarWSDL(){
  235 + $login = 'teste';
  236 + $senha = 'teste';
  237 + for ($i = 0; $i < strlen($senha); $i++) {
  238 + $senha[$i] = ~$senha[$i];
  239 + }
  240 + $pass = base64_encode($senha);
  241 + $soap = new \SoapClient('http://localhost/sip/controlador_ws.php?servico=wsdl', array('encoding'=>'ISO-8859-1'));
  242 + /*
  243 + $loginData = $soap->autenticar(
  244 + 0,
  245 + null,
  246 + $login,
  247 + $pass,
  248 + ConfiguracaoSEI::getInstance()->getValor('SessaoSEI', 'SiglaSistema'),
  249 + ConfiguracaoSEI::getInstance()->getValor('SessaoSEI', 'SiglaOrgaoSistema')
  250 + );
  251 + */
  252 + //$ret = $soap->validarLogin($loginData->id_login, $loginData->id_sistema, $loginData->id_usuario, $loginData->hash_agente);
  253 + //var_dump($ret);
  254 +
  255 + $b = new MdWsSeiUsuarioRN();
  256 + $token = $b->tokenEncode('teste', 'teste');
  257 + var_dump($b->autenticarToken($token));
  258 +
  259 + }
  260 +}
  261 +
  262 +class TesteAssinante {
  263 +
  264 + public function listarAssinanteConectado(){
  265 + $dto = new AssinanteDTO();
  266 + $dto->setNumMaxRegistrosRetorno(3);
  267 + $dto->setNumPaginaAtual(0);
  268 + $dto->setNumIdUnidade('110000001');
  269 + $rn = new MdWsSeiAssinanteRN();
  270 + var_dump($rn->listarAssinante($dto));
  271 + }
  272 +}
  273 +
  274 +
  275 +
  276 +if($_REQUEST['controller'] && $_REQUEST['action']){
  277 + try{
  278 + $controller = new $_REQUEST['controller'];
  279 + echo 'Resposta teste <b>'.$_REQUEST['controller'].'->'.$_REQUEST['action'].'()</b>:';
  280 + $controller->$_REQUEST['action']();
  281 + }catch (Exception $e){
  282 + var_dump($e);
  283 + }
  284 +}
0 285 \ No newline at end of file
... ...
vendor/autoload.php 0 → 100644
  1 +++ a/vendor/autoload.php
... ... @@ -0,0 +1,7 @@
  1 +<?php
  2 +
  3 +// autoload.php @generated by Composer
  4 +
  5 +require_once __DIR__ . '/composer/autoload_real.php';
  6 +
  7 +return ComposerAutoloaderInit29a4728604e52c048eac8a5ee4c40a9d::getLoader();
... ...
vendor/composer/ClassLoader.php 0 → 100644
  1 +++ a/vendor/composer/ClassLoader.php
... ... @@ -0,0 +1,445 @@
  1 +<?php
  2 +
  3 +/*
  4 + * This file is part of Composer.
  5 + *
  6 + * (c) Nils Adermann <naderman@naderman.de>
  7 + * Jordi Boggiano <j.boggiano@seld.be>
  8 + *
  9 + * For the full copyright and license information, please view the LICENSE
  10 + * file that was distributed with this source code.
  11 + */
  12 +
  13 +namespace Composer\Autoload;
  14 +
  15 +/**
  16 + * ClassLoader implements a PSR-0, PSR-4 and classmap class loader.
  17 + *
  18 + * $loader = new \Composer\Autoload\ClassLoader();
  19 + *
  20 + * // register classes with namespaces
  21 + * $loader->add('Symfony\Component', __DIR__.'/component');
  22 + * $loader->add('Symfony', __DIR__.'/framework');
  23 + *
  24 + * // activate the autoloader
  25 + * $loader->register();
  26 + *
  27 + * // to enable searching the include path (eg. for PEAR packages)
  28 + * $loader->setUseIncludePath(true);
  29 + *
  30 + * In this example, if you try to use a class in the Symfony\Component
  31 + * namespace or one of its children (Symfony\Component\Console for instance),
  32 + * the autoloader will first look for the class under the component/
  33 + * directory, and it will then fallback to the framework/ directory if not
  34 + * found before giving up.
  35 + *
  36 + * This class is loosely based on the Symfony UniversalClassLoader.
  37 + *
  38 + * @author Fabien Potencier <fabien@symfony.com>
  39 + * @author Jordi Boggiano <j.boggiano@seld.be>
  40 + * @see http://www.php-fig.org/psr/psr-0/
  41 + * @see http://www.php-fig.org/psr/psr-4/
  42 + */
  43 +class ClassLoader
  44 +{
  45 + // PSR-4
  46 + private $prefixLengthsPsr4 = array();
  47 + private $prefixDirsPsr4 = array();
  48 + private $fallbackDirsPsr4 = array();
  49 +
  50 + // PSR-0
  51 + private $prefixesPsr0 = array();
  52 + private $fallbackDirsPsr0 = array();
  53 +
  54 + private $useIncludePath = false;
  55 + private $classMap = array();
  56 + private $classMapAuthoritative = false;
  57 + private $missingClasses = array();
  58 + private $apcuPrefix;
  59 +
  60 + public function getPrefixes()
  61 + {
  62 + if (!empty($this->prefixesPsr0)) {
  63 + return call_user_func_array('array_merge', $this->prefixesPsr0);
  64 + }
  65 +
  66 + return array();
  67 + }
  68 +
  69 + public function getPrefixesPsr4()
  70 + {
  71 + return $this->prefixDirsPsr4;
  72 + }
  73 +
  74 + public function getFallbackDirs()
  75 + {
  76 + return $this->fallbackDirsPsr0;
  77 + }
  78 +
  79 + public function getFallbackDirsPsr4()
  80 + {
  81 + return $this->fallbackDirsPsr4;
  82 + }
  83 +
  84 + public function getClassMap()
  85 + {
  86 + return $this->classMap;
  87 + }
  88 +
  89 + /**
  90 + * @param array $classMap Class to filename map
  91 + */
  92 + public function addClassMap(array $classMap)
  93 + {
  94 + if ($this->classMap) {
  95 + $this->classMap = array_merge($this->classMap, $classMap);
  96 + } else {
  97 + $this->classMap = $classMap;
  98 + }
  99 + }
  100 +
  101 + /**
  102 + * Registers a set of PSR-0 directories for a given prefix, either
  103 + * appending or prepending to the ones previously set for this prefix.
  104 + *
  105 + * @param string $prefix The prefix
  106 + * @param array|string $paths The PSR-0 root directories
  107 + * @param bool $prepend Whether to prepend the directories
  108 + */
  109 + public function add($prefix, $paths, $prepend = false)
  110 + {
  111 + if (!$prefix) {
  112 + if ($prepend) {
  113 + $this->fallbackDirsPsr0 = array_merge(
  114 + (array) $paths,
  115 + $this->fallbackDirsPsr0
  116 + );
  117 + } else {
  118 + $this->fallbackDirsPsr0 = array_merge(
  119 + $this->fallbackDirsPsr0,
  120 + (array) $paths
  121 + );
  122 + }
  123 +
  124 + return;
  125 + }
  126 +
  127 + $first = $prefix[0];
  128 + if (!isset($this->prefixesPsr0[$first][$prefix])) {
  129 + $this->prefixesPsr0[$first][$prefix] = (array) $paths;
  130 +
  131 + return;
  132 + }
  133 + if ($prepend) {
  134 + $this->prefixesPsr0[$first][$prefix] = array_merge(
  135 + (array) $paths,
  136 + $this->prefixesPsr0[$first][$prefix]
  137 + );
  138 + } else {
  139 + $this->prefixesPsr0[$first][$prefix] = array_merge(
  140 + $this->prefixesPsr0[$first][$prefix],
  141 + (array) $paths
  142 + );
  143 + }
  144 + }
  145 +
  146 + /**
  147 + * Registers a set of PSR-4 directories for a given namespace, either
  148 + * appending or prepending to the ones previously set for this namespace.
  149 + *
  150 + * @param string $prefix The prefix/namespace, with trailing '\\'
  151 + * @param array|string $paths The PSR-4 base directories
  152 + * @param bool $prepend Whether to prepend the directories
  153 + *
  154 + * @throws \InvalidArgumentException
  155 + */
  156 + public function addPsr4($prefix, $paths, $prepend = false)
  157 + {
  158 + if (!$prefix) {
  159 + // Register directories for the root namespace.
  160 + if ($prepend) {
  161 + $this->fallbackDirsPsr4 = array_merge(
  162 + (array) $paths,
  163 + $this->fallbackDirsPsr4
  164 + );
  165 + } else {
  166 + $this->fallbackDirsPsr4 = array_merge(
  167 + $this->fallbackDirsPsr4,
  168 + (array) $paths
  169 + );
  170 + }
  171 + } elseif (!isset($this->prefixDirsPsr4[$prefix])) {
  172 + // Register directories for a new namespace.
  173 + $length = strlen($prefix);
  174 + if ('\\' !== $prefix[$length - 1]) {
  175 + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
  176 + }
  177 + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
  178 + $this->prefixDirsPsr4[$prefix] = (array) $paths;
  179 + } elseif ($prepend) {
  180 + // Prepend directories for an already registered namespace.
  181 + $this->prefixDirsPsr4[$prefix] = array_merge(
  182 + (array) $paths,
  183 + $this->prefixDirsPsr4[$prefix]
  184 + );
  185 + } else {
  186 + // Append directories for an already registered namespace.
  187 + $this->prefixDirsPsr4[$prefix] = array_merge(
  188 + $this->prefixDirsPsr4[$prefix],
  189 + (array) $paths
  190 + );
  191 + }
  192 + }
  193 +
  194 + /**
  195 + * Registers a set of PSR-0 directories for a given prefix,
  196 + * replacing any others previously set for this prefix.
  197 + *
  198 + * @param string $prefix The prefix
  199 + * @param array|string $paths The PSR-0 base directories
  200 + */
  201 + public function set($prefix, $paths)
  202 + {
  203 + if (!$prefix) {
  204 + $this->fallbackDirsPsr0 = (array) $paths;
  205 + } else {
  206 + $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths;
  207 + }
  208 + }
  209 +
  210 + /**
  211 + * Registers a set of PSR-4 directories for a given namespace,
  212 + * replacing any others previously set for this namespace.
  213 + *
  214 + * @param string $prefix The prefix/namespace, with trailing '\\'
  215 + * @param array|string $paths The PSR-4 base directories
  216 + *
  217 + * @throws \InvalidArgumentException
  218 + */
  219 + public function setPsr4($prefix, $paths)
  220 + {
  221 + if (!$prefix) {
  222 + $this->fallbackDirsPsr4 = (array) $paths;
  223 + } else {
  224 + $length = strlen($prefix);
  225 + if ('\\' !== $prefix[$length - 1]) {
  226 + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
  227 + }
  228 + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
  229 + $this->prefixDirsPsr4[$prefix] = (array) $paths;
  230 + }
  231 + }
  232 +
  233 + /**
  234 + * Turns on searching the include path for class files.
  235 + *
  236 + * @param bool $useIncludePath
  237 + */
  238 + public function setUseIncludePath($useIncludePath)
  239 + {
  240 + $this->useIncludePath = $useIncludePath;
  241 + }
  242 +
  243 + /**
  244 + * Can be used to check if the autoloader uses the include path to check
  245 + * for classes.
  246 + *
  247 + * @return bool
  248 + */
  249 + public function getUseIncludePath()
  250 + {
  251 + return $this->useIncludePath;
  252 + }
  253 +
  254 + /**
  255 + * Turns off searching the prefix and fallback directories for classes
  256 + * that have not been registered with the class map.
  257 + *
  258 + * @param bool $classMapAuthoritative
  259 + */
  260 + public function setClassMapAuthoritative($classMapAuthoritative)
  261 + {
  262 + $this->classMapAuthoritative = $classMapAuthoritative;
  263 + }
  264 +
  265 + /**
  266 + * Should class lookup fail if not found in the current class map?
  267 + *
  268 + * @return bool
  269 + */
  270 + public function isClassMapAuthoritative()
  271 + {
  272 + return $this->classMapAuthoritative;
  273 + }
  274 +
  275 + /**
  276 + * APCu prefix to use to cache found/not-found classes, if the extension is enabled.
  277 + *
  278 + * @param string|null $apcuPrefix
  279 + */
  280 + public function setApcuPrefix($apcuPrefix)
  281 + {
  282 + $this->apcuPrefix = function_exists('apcu_fetch') && ini_get('apc.enabled') ? $apcuPrefix : null;
  283 + }
  284 +
  285 + /**
  286 + * The APCu prefix in use, or null if APCu caching is not enabled.
  287 + *
  288 + * @return string|null
  289 + */
  290 + public function getApcuPrefix()
  291 + {
  292 + return $this->apcuPrefix;
  293 + }
  294 +
  295 + /**
  296 + * Registers this instance as an autoloader.
  297 + *
  298 + * @param bool $prepend Whether to prepend the autoloader or not
  299 + */
  300 + public function register($prepend = false)
  301 + {
  302 + spl_autoload_register(array($this, 'loadClass'), true, $prepend);
  303 + }
  304 +
  305 + /**
  306 + * Unregisters this instance as an autoloader.
  307 + */
  308 + public function unregister()
  309 + {
  310 + spl_autoload_unregister(array($this, 'loadClass'));
  311 + }
  312 +
  313 + /**
  314 + * Loads the given class or interface.
  315 + *
  316 + * @param string $class The name of the class
  317 + * @return bool|null True if loaded, null otherwise
  318 + */
  319 + public function loadClass($class)
  320 + {
  321 + if ($file = $this->findFile($class)) {
  322 + includeFile($file);
  323 +
  324 + return true;
  325 + }
  326 + }
  327 +
  328 + /**
  329 + * Finds the path to the file where the class is defined.
  330 + *
  331 + * @param string $class The name of the class
  332 + *
  333 + * @return string|false The path if found, false otherwise
  334 + */
  335 + public function findFile($class)
  336 + {
  337 + // class map lookup
  338 + if (isset($this->classMap[$class])) {
  339 + return $this->classMap[$class];
  340 + }
  341 + if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
  342 + return false;
  343 + }
  344 + if (null !== $this->apcuPrefix) {
  345 + $file = apcu_fetch($this->apcuPrefix.$class, $hit);
  346 + if ($hit) {
  347 + return $file;
  348 + }
  349 + }
  350 +
  351 + $file = $this->findFileWithExtension($class, '.php');
  352 +
  353 + // Search for Hack files if we are running on HHVM
  354 + if (false === $file && defined('HHVM_VERSION')) {
  355 + $file = $this->findFileWithExtension($class, '.hh');
  356 + }
  357 +
  358 + if (null !== $this->apcuPrefix) {
  359 + apcu_add($this->apcuPrefix.$class, $file);
  360 + }
  361 +
  362 + if (false === $file) {
  363 + // Remember that this class does not exist.
  364 + $this->missingClasses[$class] = true;
  365 + }
  366 +
  367 + return $file;
  368 + }
  369 +
  370 + private function findFileWithExtension($class, $ext)
  371 + {
  372 + // PSR-4 lookup
  373 + $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
  374 +
  375 + $first = $class[0];
  376 + if (isset($this->prefixLengthsPsr4[$first])) {
  377 + $subPath = $class;
  378 + while (false !== $lastPos = strrpos($subPath, '\\')) {
  379 + $subPath = substr($subPath, 0, $lastPos);
  380 + $search = $subPath.'\\';
  381 + if (isset($this->prefixDirsPsr4[$search])) {
  382 + foreach ($this->prefixDirsPsr4[$search] as $dir) {
  383 + $length = $this->prefixLengthsPsr4[$first][$search];
  384 + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) {
  385 + return $file;
  386 + }
  387 + }
  388 + }
  389 + }
  390 + }
  391 +
  392 + // PSR-4 fallback dirs
  393 + foreach ($this->fallbackDirsPsr4 as $dir) {
  394 + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
  395 + return $file;
  396 + }
  397 + }
  398 +
  399 + // PSR-0 lookup
  400 + if (false !== $pos = strrpos($class, '\\')) {
  401 + // namespaced class name
  402 + $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
  403 + . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
  404 + } else {
  405 + // PEAR-like class name
  406 + $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
  407 + }
  408 +
  409 + if (isset($this->prefixesPsr0[$first])) {
  410 + foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
  411 + if (0 === strpos($class, $prefix)) {
  412 + foreach ($dirs as $dir) {
  413 + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
  414 + return $file;
  415 + }
  416 + }
  417 + }
  418 + }
  419 + }
  420 +
  421 + // PSR-0 fallback dirs
  422 + foreach ($this->fallbackDirsPsr0 as $dir) {
  423 + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
  424 + return $file;
  425 + }
  426 + }
  427 +
  428 + // PSR-0 include paths.
  429 + if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
  430 + return $file;
  431 + }
  432 +
  433 + return false;
  434 + }
  435 +}
  436 +
  437 +/**
  438 + * Scope isolated include.
  439 + *
  440 + * Prevents access to $this/self from included files.
  441 + */
  442 +function includeFile($file)
  443 +{
  444 + include $file;
  445 +}
... ...
vendor/composer/LICENSE 0 → 100644
  1 +++ a/vendor/composer/LICENSE
... ... @@ -0,0 +1,21 @@
  1 +
  2 +Copyright (c) Nils Adermann, Jordi Boggiano
  3 +
  4 +Permission is hereby granted, free of charge, to any person obtaining a copy
  5 +of this software and associated documentation files (the "Software"), to deal
  6 +in the Software without restriction, including without limitation the rights
  7 +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8 +copies of the Software, and to permit persons to whom the Software is furnished
  9 +to do so, subject to the following conditions:
  10 +
  11 +The above copyright notice and this permission notice shall be included in all
  12 +copies or substantial portions of the Software.
  13 +
  14 +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15 +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16 +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17 +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18 +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19 +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  20 +THE SOFTWARE.
  21 +
... ...
vendor/composer/autoload_classmap.php 0 → 100644
  1 +++ a/vendor/composer/autoload_classmap.php
... ... @@ -0,0 +1,9 @@
  1 +<?php
  2 +
  3 +// autoload_classmap.php @generated by Composer
  4 +
  5 +$vendorDir = dirname(dirname(__FILE__));
  6 +$baseDir = dirname($vendorDir);
  7 +
  8 +return array(
  9 +);
... ...
vendor/composer/autoload_files.php 0 → 100644
  1 +++ a/vendor/composer/autoload_files.php
... ... @@ -0,0 +1,10 @@
  1 +<?php
  2 +
  3 +// autoload_files.php @generated by Composer
  4 +
  5 +$vendorDir = dirname(dirname(__FILE__));
  6 +$baseDir = dirname($vendorDir);
  7 +
  8 +return array(
  9 + '253c157292f75eb38082b5acb06f3f01' => $vendorDir . '/nikic/fast-route/src/functions.php',
  10 +);
... ...
vendor/composer/autoload_namespaces.php 0 → 100644
  1 +++ a/vendor/composer/autoload_namespaces.php
... ... @@ -0,0 +1,10 @@
  1 +<?php
  2 +
  3 +// autoload_namespaces.php @generated by Composer
  4 +
  5 +$vendorDir = dirname(dirname(__FILE__));
  6 +$baseDir = dirname($vendorDir);
  7 +
  8 +return array(
  9 + 'Pimple' => array($vendorDir . '/pimple/pimple/src'),
  10 +);
... ...
vendor/composer/autoload_psr4.php 0 → 100644
  1 +++ a/vendor/composer/autoload_psr4.php
... ... @@ -0,0 +1,14 @@
  1 +<?php
  2 +
  3 +// autoload_psr4.php @generated by Composer
  4 +
  5 +$vendorDir = dirname(dirname(__FILE__));
  6 +$baseDir = dirname($vendorDir);
  7 +
  8 +return array(
  9 + 'Slim\\' => array($vendorDir . '/slim/slim/Slim'),
  10 + 'Psr\\Http\\Message\\' => array($vendorDir . '/psr/http-message/src'),
  11 + 'Psr\\Container\\' => array($vendorDir . '/psr/container/src'),
  12 + 'Interop\\Container\\' => array($vendorDir . '/container-interop/container-interop/src/Interop/Container'),
  13 + 'FastRoute\\' => array($vendorDir . '/nikic/fast-route/src'),
  14 +);
... ...
vendor/composer/autoload_real.php 0 → 100644
  1 +++ a/vendor/composer/autoload_real.php
... ... @@ -0,0 +1,70 @@
  1 +<?php
  2 +
  3 +// autoload_real.php @generated by Composer
  4 +
  5 +class ComposerAutoloaderInit29a4728604e52c048eac8a5ee4c40a9d
  6 +{
  7 + private static $loader;
  8 +
  9 + public static function loadClassLoader($class)
  10 + {
  11 + if ('Composer\Autoload\ClassLoader' === $class) {
  12 + require __DIR__ . '/ClassLoader.php';
  13 + }
  14 + }
  15 +
  16 + public static function getLoader()
  17 + {
  18 + if (null !== self::$loader) {
  19 + return self::$loader;
  20 + }
  21 +
  22 + spl_autoload_register(array('ComposerAutoloaderInit29a4728604e52c048eac8a5ee4c40a9d', 'loadClassLoader'), true, true);
  23 + self::$loader = $loader = new \Composer\Autoload\ClassLoader();
  24 + spl_autoload_unregister(array('ComposerAutoloaderInit29a4728604e52c048eac8a5ee4c40a9d', 'loadClassLoader'));
  25 +
  26 + $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
  27 + if ($useStaticLoader) {
  28 + require_once __DIR__ . '/autoload_static.php';
  29 +
  30 + call_user_func(\Composer\Autoload\ComposerStaticInit29a4728604e52c048eac8a5ee4c40a9d::getInitializer($loader));
  31 + } else {
  32 + $map = require __DIR__ . '/autoload_namespaces.php';
  33 + foreach ($map as $namespace => $path) {
  34 + $loader->set($namespace, $path);
  35 + }
  36 +
  37 + $map = require __DIR__ . '/autoload_psr4.php';
  38 + foreach ($map as $namespace => $path) {
  39 + $loader->setPsr4($namespace, $path);
  40 + }
  41 +
  42 + $classMap = require __DIR__ . '/autoload_classmap.php';
  43 + if ($classMap) {
  44 + $loader->addClassMap($classMap);
  45 + }
  46 + }
  47 +
  48 + $loader->register(true);
  49 +
  50 + if ($useStaticLoader) {
  51 + $includeFiles = Composer\Autoload\ComposerStaticInit29a4728604e52c048eac8a5ee4c40a9d::$files;
  52 + } else {
  53 + $includeFiles = require __DIR__ . '/autoload_files.php';
  54 + }
  55 + foreach ($includeFiles as $fileIdentifier => $file) {
  56 + composerRequire29a4728604e52c048eac8a5ee4c40a9d($fileIdentifier, $file);
  57 + }
  58 +
  59 + return $loader;
  60 + }
  61 +}
  62 +
  63 +function composerRequire29a4728604e52c048eac8a5ee4c40a9d($fileIdentifier, $file)
  64 +{
  65 + if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
  66 + require $file;
  67 +
  68 + $GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;
  69 + }
  70 +}
... ...
vendor/composer/autoload_static.php 0 → 100644
  1 +++ a/vendor/composer/autoload_static.php
... ... @@ -0,0 +1,75 @@
  1 +<?php
  2 +
  3 +// autoload_static.php @generated by Composer
  4 +
  5 +namespace Composer\Autoload;
  6 +
  7 +class ComposerStaticInit29a4728604e52c048eac8a5ee4c40a9d
  8 +{
  9 + public static $files = array (
  10 + '253c157292f75eb38082b5acb06f3f01' => __DIR__ . '/..' . '/nikic/fast-route/src/functions.php',
  11 + );
  12 +
  13 + public static $prefixLengthsPsr4 = array (
  14 + 'S' =>
  15 + array (
  16 + 'Slim\\' => 5,
  17 + ),
  18 + 'P' =>
  19 + array (
  20 + 'Psr\\Http\\Message\\' => 17,
  21 + 'Psr\\Container\\' => 14,
  22 + ),
  23 + 'I' =>
  24 + array (
  25 + 'Interop\\Container\\' => 18,
  26 + ),
  27 + 'F' =>
  28 + array (
  29 + 'FastRoute\\' => 10,
  30 + ),
  31 + );
  32 +
  33 + public static $prefixDirsPsr4 = array (
  34 + 'Slim\\' =>
  35 + array (
  36 + 0 => __DIR__ . '/..' . '/slim/slim/Slim',
  37 + ),
  38 + 'Psr\\Http\\Message\\' =>
  39 + array (
  40 + 0 => __DIR__ . '/..' . '/psr/http-message/src',
  41 + ),
  42 + 'Psr\\Container\\' =>
  43 + array (
  44 + 0 => __DIR__ . '/..' . '/psr/container/src',
  45 + ),
  46 + 'Interop\\Container\\' =>
  47 + array (
  48 + 0 => __DIR__ . '/..' . '/container-interop/container-interop/src/Interop/Container',
  49 + ),
  50 + 'FastRoute\\' =>
  51 + array (
  52 + 0 => __DIR__ . '/..' . '/nikic/fast-route/src',
  53 + ),
  54 + );
  55 +
  56 + public static $prefixesPsr0 = array (
  57 + 'P' =>
  58 + array (
  59 + 'Pimple' =>
  60 + array (
  61 + 0 => __DIR__ . '/..' . '/pimple/pimple/src',
  62 + ),
  63 + ),
  64 + );
  65 +
  66 + public static function getInitializer(ClassLoader $loader)
  67 + {
  68 + return \Closure::bind(function () use ($loader) {
  69 + $loader->prefixLengthsPsr4 = ComposerStaticInit29a4728604e52c048eac8a5ee4c40a9d::$prefixLengthsPsr4;
  70 + $loader->prefixDirsPsr4 = ComposerStaticInit29a4728604e52c048eac8a5ee4c40a9d::$prefixDirsPsr4;
  71 + $loader->prefixesPsr0 = ComposerStaticInit29a4728604e52c048eac8a5ee4c40a9d::$prefixesPsr0;
  72 +
  73 + }, null, ClassLoader::class);
  74 + }
  75 +}
... ...
vendor/composer/installed.json 0 → 100644
  1 +++ a/vendor/composer/installed.json
... ... @@ -0,0 +1,303 @@
  1 +[
  2 + {
  3 + "name": "psr/container",
  4 + "version": "1.0.0",
  5 + "version_normalized": "1.0.0.0",
  6 + "source": {
  7 + "type": "git",
  8 + "url": "https://github.com/php-fig/container.git",
  9 + "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f"
  10 + },
  11 + "dist": {
  12 + "type": "zip",
  13 + "url": "https://api.github.com/repos/php-fig/container/zipball/b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
  14 + "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
  15 + "shasum": ""
  16 + },
  17 + "require": {
  18 + "php": ">=5.3.0"
  19 + },
  20 + "time": "2017-02-14T16:28:37+00:00",
  21 + "type": "library",
  22 + "extra": {
  23 + "branch-alias": {
  24 + "dev-master": "1.0.x-dev"
  25 + }
  26 + },
  27 + "installation-source": "dist",
  28 + "autoload": {
  29 + "psr-4": {
  30 + "Psr\\Container\\": "src/"
  31 + }
  32 + },
  33 + "notification-url": "https://packagist.org/downloads/",
  34 + "license": [
  35 + "MIT"
  36 + ],
  37 + "authors": [
  38 + {
  39 + "name": "PHP-FIG",
  40 + "homepage": "http://www.php-fig.org/"
  41 + }
  42 + ],
  43 + "description": "Common Container Interface (PHP FIG PSR-11)",
  44 + "homepage": "https://github.com/php-fig/container",
  45 + "keywords": [
  46 + "PSR-11",
  47 + "container",
  48 + "container-interface",
  49 + "container-interop",
  50 + "psr"
  51 + ]
  52 + },
  53 + {
  54 + "name": "container-interop/container-interop",
  55 + "version": "1.2.0",
  56 + "version_normalized": "1.2.0.0",
  57 + "source": {
  58 + "type": "git",
  59 + "url": "https://github.com/container-interop/container-interop.git",
  60 + "reference": "79cbf1341c22ec75643d841642dd5d6acd83bdb8"
  61 + },
  62 + "dist": {
  63 + "type": "zip",
  64 + "url": "https://api.github.com/repos/container-interop/container-interop/zipball/79cbf1341c22ec75643d841642dd5d6acd83bdb8",
  65 + "reference": "79cbf1341c22ec75643d841642dd5d6acd83bdb8",
  66 + "shasum": ""
  67 + },
  68 + "require": {
  69 + "psr/container": "^1.0"
  70 + },
  71 + "time": "2017-02-14T19:40:03+00:00",
  72 + "type": "library",
  73 + "installation-source": "dist",
  74 + "autoload": {
  75 + "psr-4": {
  76 + "Interop\\Container\\": "src/Interop/Container/"
  77 + }
  78 + },
  79 + "notification-url": "https://packagist.org/downloads/",
  80 + "license": [
  81 + "MIT"
  82 + ],
  83 + "description": "Promoting the interoperability of container objects (DIC, SL, etc.)",
  84 + "homepage": "https://github.com/container-interop/container-interop"
  85 + },
  86 + {
  87 + "name": "nikic/fast-route",
  88 + "version": "v1.2.0",
  89 + "version_normalized": "1.2.0.0",
  90 + "source": {
  91 + "type": "git",
  92 + "url": "https://github.com/nikic/FastRoute.git",
  93 + "reference": "b5f95749071c82a8e0f58586987627054400cdf6"
  94 + },
  95 + "dist": {
  96 + "type": "zip",
  97 + "url": "https://api.github.com/repos/nikic/FastRoute/zipball/b5f95749071c82a8e0f58586987627054400cdf6",
  98 + "reference": "b5f95749071c82a8e0f58586987627054400cdf6",
  99 + "shasum": ""
  100 + },
  101 + "require": {
  102 + "php": ">=5.4.0"
  103 + },
  104 + "time": "2017-01-19T11:35:12+00:00",
  105 + "type": "library",
  106 + "installation-source": "dist",
  107 + "autoload": {
  108 + "psr-4": {
  109 + "FastRoute\\": "src/"
  110 + },
  111 + "files": [
  112 + "src/functions.php"
  113 + ]
  114 + },
  115 + "notification-url": "https://packagist.org/downloads/",
  116 + "license": [
  117 + "BSD-3-Clause"
  118 + ],
  119 + "authors": [
  120 + {
  121 + "name": "Nikita Popov",
  122 + "email": "nikic@php.net"
  123 + }
  124 + ],
  125 + "description": "Fast request router for PHP",
  126 + "keywords": [
  127 + "router",
  128 + "routing"
  129 + ]
  130 + },
  131 + {
  132 + "name": "psr/http-message",
  133 + "version": "1.0.1",
  134 + "version_normalized": "1.0.1.0",
  135 + "source": {
  136 + "type": "git",
  137 + "url": "https://github.com/php-fig/http-message.git",
  138 + "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363"
  139 + },
  140 + "dist": {
  141 + "type": "zip",
  142 + "url": "https://api.github.com/repos/php-fig/http-message/zipball/f6561bf28d520154e4b0ec72be95418abe6d9363",
  143 + "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363",
  144 + "shasum": ""
  145 + },
  146 + "require": {
  147 + "php": ">=5.3.0"
  148 + },
  149 + "time": "2016-08-06T14:39:51+00:00",
  150 + "type": "library",
  151 + "extra": {
  152 + "branch-alias": {
  153 + "dev-master": "1.0.x-dev"
  154 + }
  155 + },
  156 + "installation-source": "dist",
  157 + "autoload": {
  158 + "psr-4": {
  159 + "Psr\\Http\\Message\\": "src/"
  160 + }
  161 + },
  162 + "notification-url": "https://packagist.org/downloads/",
  163 + "license": [
  164 + "MIT"
  165 + ],
  166 + "authors": [
  167 + {
  168 + "name": "PHP-FIG",
  169 + "homepage": "http://www.php-fig.org/"
  170 + }
  171 + ],
  172 + "description": "Common interface for HTTP messages",
  173 + "homepage": "https://github.com/php-fig/http-message",
  174 + "keywords": [
  175 + "http",
  176 + "http-message",
  177 + "psr",
  178 + "psr-7",
  179 + "request",
  180 + "response"
  181 + ]
  182 + },
  183 + {
  184 + "name": "pimple/pimple",
  185 + "version": "v3.0.2",
  186 + "version_normalized": "3.0.2.0",
  187 + "source": {
  188 + "type": "git",
  189 + "url": "https://github.com/silexphp/Pimple.git",
  190 + "reference": "a30f7d6e57565a2e1a316e1baf2a483f788b258a"
  191 + },
  192 + "dist": {
  193 + "type": "zip",
  194 + "url": "https://api.github.com/repos/silexphp/Pimple/zipball/a30f7d6e57565a2e1a316e1baf2a483f788b258a",
  195 + "reference": "a30f7d6e57565a2e1a316e1baf2a483f788b258a",
  196 + "shasum": ""
  197 + },
  198 + "require": {
  199 + "php": ">=5.3.0"
  200 + },
  201 + "time": "2015-09-11T15:10:35+00:00",
  202 + "type": "library",
  203 + "extra": {
  204 + "branch-alias": {
  205 + "dev-master": "3.0.x-dev"
  206 + }
  207 + },
  208 + "installation-source": "dist",
  209 + "autoload": {
  210 + "psr-0": {
  211 + "Pimple": "src/"
  212 + }
  213 + },
  214 + "notification-url": "https://packagist.org/downloads/",
  215 + "license": [
  216 + "MIT"
  217 + ],
  218 + "authors": [
  219 + {
  220 + "name": "Fabien Potencier",
  221 + "email": "fabien@symfony.com"
  222 + }
  223 + ],
  224 + "description": "Pimple, a simple Dependency Injection Container",
  225 + "homepage": "http://pimple.sensiolabs.org",
  226 + "keywords": [
  227 + "container",
  228 + "dependency injection"
  229 + ]
  230 + },
  231 + {
  232 + "name": "slim/slim",
  233 + "version": "3.7.0",
  234 + "version_normalized": "3.7.0.0",
  235 + "source": {
  236 + "type": "git",
  237 + "url": "https://github.com/slimphp/Slim.git",
  238 + "reference": "4254e40d81559e35cdf856bcbaca5f3af468b7ef"
  239 + },
  240 + "dist": {
  241 + "type": "zip",
  242 + "url": "https://api.github.com/repos/slimphp/Slim/zipball/4254e40d81559e35cdf856bcbaca5f3af468b7ef",
  243 + "reference": "4254e40d81559e35cdf856bcbaca5f3af468b7ef",
  244 + "shasum": ""
  245 + },
  246 + "require": {
  247 + "container-interop/container-interop": "^1.1",
  248 + "nikic/fast-route": "^1.0",
  249 + "php": ">=5.5.0",
  250 + "pimple/pimple": "^3.0",
  251 + "psr/http-message": "^1.0"
  252 + },
  253 + "provide": {
  254 + "psr/http-message-implementation": "1.0"
  255 + },
  256 + "require-dev": {
  257 + "phpunit/phpunit": "^4.0",
  258 + "squizlabs/php_codesniffer": "^2.5"
  259 + },
  260 + "time": "2016-12-20T20:30:47+00:00",
  261 + "type": "library",
  262 + "installation-source": "dist",
  263 + "autoload": {
  264 + "psr-4": {
  265 + "Slim\\": "Slim"
  266 + }
  267 + },
  268 + "notification-url": "https://packagist.org/downloads/",
  269 + "license": [
  270 + "MIT"
  271 + ],
  272 + "authors": [
  273 + {
  274 + "name": "Rob Allen",
  275 + "email": "rob@akrabat.com",
  276 + "homepage": "http://akrabat.com"
  277 + },
  278 + {
  279 + "name": "Josh Lockhart",
  280 + "email": "hello@joshlockhart.com",
  281 + "homepage": "https://joshlockhart.com"
  282 + },
  283 + {
  284 + "name": "Gabriel Manricks",
  285 + "email": "gmanricks@me.com",
  286 + "homepage": "http://gabrielmanricks.com"
  287 + },
  288 + {
  289 + "name": "Andrew Smith",
  290 + "email": "a.smith@silentworks.co.uk",
  291 + "homepage": "http://silentworks.co.uk"
  292 + }
  293 + ],
  294 + "description": "Slim is a PHP micro framework that helps you quickly write simple yet powerful web applications and APIs",
  295 + "homepage": "https://slimframework.com",
  296 + "keywords": [
  297 + "api",
  298 + "framework",
  299 + "micro",
  300 + "router"
  301 + ]
  302 + }
  303 +]
... ...
vendor/container-interop/container-interop/.gitignore 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/.gitignore
... ... @@ -0,0 +1,3 @@
  1 +composer.lock
  2 +composer.phar
  3 +/vendor/
... ...
vendor/container-interop/container-interop/LICENSE 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/LICENSE
... ... @@ -0,0 +1,20 @@
  1 +The MIT License (MIT)
  2 +
  3 +Copyright (c) 2013 container-interop
  4 +
  5 +Permission is hereby granted, free of charge, to any person obtaining a copy of
  6 +this software and associated documentation files (the "Software"), to deal in
  7 +the Software without restriction, including without limitation the rights to
  8 +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  9 +the Software, and to permit persons to whom the Software is furnished to do so,
  10 +subject to the following conditions:
  11 +
  12 +The above copyright notice and this permission notice shall be included in all
  13 +copies or substantial portions of the Software.
  14 +
  15 +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16 +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  17 +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  18 +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  19 +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  20 +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
... ...
vendor/container-interop/container-interop/README.md 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/README.md
... ... @@ -0,0 +1,148 @@
  1 +# Container Interoperability
  2 +
  3 +[![Latest Stable Version](https://poser.pugx.org/container-interop/container-interop/v/stable.png)](https://packagist.org/packages/container-interop/container-interop)
  4 +[![Total Downloads](https://poser.pugx.org/container-interop/container-interop/downloads.svg)](https://packagist.org/packages/container-interop/container-interop)
  5 +
  6 +## Deprecation warning!
  7 +
  8 +Starting Feb. 13th 2017, container-interop is officially deprecated in favor of [PSR-11](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-11-container.md).
  9 +Container-interop has been the test-bed of PSR-11. From v1.2, container-interop directly extends PSR-11 interfaces.
  10 +Therefore, all containers implementing container-interop are now *de-facto* compatible with PSR-11.
  11 +
  12 +- Projects implementing container-interop interfaces are encouraged to directly implement PSR-11 interfaces instead.
  13 +- Projects consuming container-interop interfaces are very strongly encouraged to directly type-hint on PSR-11 interfaces, in order to be compatible with PSR-11 containers that are not compatible with container-interop.
  14 +
  15 +Regarding the delegate lookup feature, that is present in container-interop and not in PSR-11, the feature is actually a design pattern. It is therefore not deprecated. Documentation regarding this design pattern will be migrated from this repository into a separate website in the future.
  16 +
  17 +## About
  18 +
  19 +*container-interop* tries to identify and standardize features in *container* objects (service locators,
  20 +dependency injection containers, etc.) to achieve interoperability.
  21 +
  22 +Through discussions and trials, we try to create a standard, made of common interfaces but also recommendations.
  23 +
  24 +If PHP projects that provide container implementations begin to adopt these common standards, then PHP
  25 +applications and projects that use containers can depend on the common interfaces instead of specific
  26 +implementations. This facilitates a high-level of interoperability and flexibility that allows users to consume
  27 +*any* container implementation that can be adapted to these interfaces.
  28 +
  29 +The work done in this project is not officially endorsed by the [PHP-FIG](http://www.php-fig.org/), but it is being
  30 +worked on by members of PHP-FIG and other good developers. We adhere to the spirit and ideals of PHP-FIG, and hope
  31 +this project will pave the way for one or more future PSRs.
  32 +
  33 +
  34 +## Installation
  35 +
  36 +You can install this package through Composer:
  37 +
  38 +```json
  39 +composer require container-interop/container-interop
  40 +```
  41 +
  42 +The packages adheres to the [SemVer](http://semver.org/) specification, and there will be full backward compatibility
  43 +between minor versions.
  44 +
  45 +## Standards
  46 +
  47 +### Available
  48 +
  49 +- [`ContainerInterface`](src/Interop/Container/ContainerInterface.php).
  50 +[Description](docs/ContainerInterface.md) [Meta Document](docs/ContainerInterface-meta.md).
  51 +Describes the interface of a container that exposes methods to read its entries.
  52 +- [*Delegate lookup feature*](docs/Delegate-lookup.md).
  53 +[Meta Document](docs/Delegate-lookup-meta.md).
  54 +Describes the ability for a container to delegate the lookup of its dependencies to a third-party container. This
  55 +feature lets several containers work together in a single application.
  56 +
  57 +### Proposed
  58 +
  59 +View open [request for comments](https://github.com/container-interop/container-interop/labels/RFC)
  60 +
  61 +## Compatible projects
  62 +
  63 +### Projects implementing `ContainerInterface`
  64 +
  65 +- [Acclimate](https://github.com/jeremeamia/acclimate-container): Adapters for
  66 + Aura.Di, Laravel, Nette DI, Pimple, Symfony DI, ZF2 Service manager, ZF2
  67 + Dependency injection and any container using `ArrayAccess`
  68 +- [Aura.Di](https://github.com/auraphp/Aura.Di)
  69 +- [auryn-container-interop](https://github.com/elazar/auryn-container-interop)
  70 +- [Burlap](https://github.com/codeeverything/burlap)
  71 +- [Chernozem](https://github.com/pyrsmk/Chernozem)
  72 +- [Data Manager](https://github.com/chrismichaels84/data-manager)
  73 +- [Disco](https://github.com/bitexpert/disco)
  74 +- [InDI](https://github.com/idealogica/indi)
  75 +- [League/Container](http://container.thephpleague.com/)
  76 +- [Mouf](http://mouf-php.com)
  77 +- [Njasm Container](https://github.com/njasm/container)
  78 +- [PHP-DI](http://php-di.org)
  79 +- [Picotainer](https://github.com/thecodingmachine/picotainer)
  80 +- [PimpleInterop](https://github.com/moufmouf/pimple-interop)
  81 +- [Pimple3-ContainerInterop](https://github.com/Sam-Burns/pimple3-containerinterop) (using Pimple v3)
  82 +- [SitePoint Container](https://github.com/sitepoint/Container)
  83 +- [Thruster Container](https://github.com/ThrusterIO/container) (PHP7 only)
  84 +- [Ultra-Lite Container](https://github.com/ultra-lite/container)
  85 +- [Unbox](https://github.com/mindplay-dk/unbox)
  86 +- [XStatic](https://github.com/jeremeamia/xstatic)
  87 +- [Zend\ServiceManager](https://github.com/zendframework/zend-servicemanager)
  88 +- [Zit](https://github.com/inxilpro/Zit)
  89 +
  90 +### Projects implementing the *delegate lookup* feature
  91 +
  92 +- [Aura.Di](https://github.com/auraphp/Aura.Di)
  93 +- [Burlap](https://github.com/codeeverything/burlap)
  94 +- [Chernozem](https://github.com/pyrsmk/Chernozem)
  95 +- [InDI](https://github.com/idealogica/indi)
  96 +- [League/Container](http://container.thephpleague.com/)
  97 +- [Mouf](http://mouf-php.com)
  98 +- [Picotainer](https://github.com/thecodingmachine/picotainer)
  99 +- [PHP-DI](http://php-di.org)
  100 +- [PimpleInterop](https://github.com/moufmouf/pimple-interop)
  101 +- [Ultra-Lite Container](https://github.com/ultra-lite/container)
  102 +
  103 +### Middlewares implementing `ContainerInterface`
  104 +
  105 +- [Alias-Container](https://github.com/thecodingmachine/alias-container): add
  106 + aliases support to any container
  107 +- [Prefixer-Container](https://github.com/thecodingmachine/prefixer-container):
  108 + dynamically prefix identifiers
  109 +- [Lazy-Container](https://github.com/snapshotpl/lazy-container): lazy services
  110 +
  111 +### Projects using `ContainerInterface`
  112 +
  113 +The list below contains only a sample of all the projects consuming `ContainerInterface`. For a more complete list have a look [here](http://packanalyst.com/class?q=Interop%5CContainer%5CContainerInterface).
  114 +
  115 +| | Downloads |
  116 +| --- | --- |
  117 +| [Adroit](https://github.com/bitexpert/adroit) | ![](https://img.shields.io/packagist/dt/bitexpert/adroit.svg) |
  118 +| [Behat](https://github.com/Behat/Behat/pull/974) | ![](https://img.shields.io/packagist/dt/behat/behat.svg) |
  119 +| [blast-facades](https://github.com/phpthinktank/blast-facades): Minimize complexity and represent dependencies as facades. | ![](https://img.shields.io/packagist/dt/blast/facades.svg) |
  120 +| [interop.silex.di](https://github.com/thecodingmachine/interop.silex.di): an extension to [Silex](http://silex.sensiolabs.org/) that adds support for any *container-interop* compatible container | ![](https://img.shields.io/packagist/dt/mouf/interop.silex.di.svg) |
  121 +| [mindplay/walkway](https://github.com/mindplay-dk/walkway): a modular request router | ![](https://img.shields.io/packagist/dt/mindplay/walkway.svg) |
  122 +| [mindplay/middleman](https://github.com/mindplay-dk/middleman): minimalist PSR-7 middleware dispatcher | ![](https://img.shields.io/packagist/dt/mindplay/middleman.svg) |
  123 +| [PHP-DI/Invoker](https://github.com/PHP-DI/Invoker): extensible and configurable invoker/dispatcher | ![](https://img.shields.io/packagist/dt/php-di/invoker.svg) |
  124 +| [Prophiler](https://github.com/fabfuel/prophiler) | ![](https://img.shields.io/packagist/dt/fabfuel/prophiler.svg) |
  125 +| [Silly](https://github.com/mnapoli/silly): CLI micro-framework | ![](https://img.shields.io/packagist/dt/mnapoli/silly.svg) |
  126 +| [Slim v3](https://github.com/slimphp/Slim) | ![](https://img.shields.io/packagist/dt/slim/slim.svg) |
  127 +| [Splash](http://mouf-php.com/packages/mouf/mvc.splash-common/version/8.0-dev/README.md) | ![](https://img.shields.io/packagist/dt/mouf/mvc.splash-common.svg) |
  128 +| [Woohoo Labs. Harmony](https://github.com/woohoolabs/harmony): a flexible micro-framework | ![](https://img.shields.io/packagist/dt/woohoolabs/harmony.svg) |
  129 +| [zend-expressive](https://github.com/zendframework/zend-expressive) | ![](https://img.shields.io/packagist/dt/zendframework/zend-expressive.svg) |
  130 +
  131 +
  132 +## Workflow
  133 +
  134 +Everyone is welcome to join and contribute.
  135 +
  136 +The general workflow looks like this:
  137 +
  138 +1. Someone opens a discussion (GitHub issue) to suggest an interface
  139 +1. Feedback is gathered
  140 +1. The interface is added to a development branch
  141 +1. We release alpha versions so that the interface can be experimented with
  142 +1. Discussions and edits ensue until the interface is deemed stable by a general consensus
  143 +1. A new minor version of the package is released
  144 +
  145 +We try to not break BC by creating new interfaces instead of editing existing ones.
  146 +
  147 +While we currently work on interfaces, we are open to anything that might help towards interoperability, may that
  148 +be code, best practices, etc.
... ...
vendor/container-interop/container-interop/composer.json 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/composer.json
... ... @@ -0,0 +1,15 @@
  1 +{
  2 + "name": "container-interop/container-interop",
  3 + "type": "library",
  4 + "description": "Promoting the interoperability of container objects (DIC, SL, etc.)",
  5 + "homepage": "https://github.com/container-interop/container-interop",
  6 + "license": "MIT",
  7 + "autoload": {
  8 + "psr-4": {
  9 + "Interop\\Container\\": "src/Interop/Container/"
  10 + }
  11 + },
  12 + "require": {
  13 + "psr/container": "^1.0"
  14 + }
  15 +}
... ...
vendor/container-interop/container-interop/docs/ContainerInterface-meta.md 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/docs/ContainerInterface-meta.md
... ... @@ -0,0 +1,114 @@
  1 +# ContainerInterface Meta Document
  2 +
  3 +## Introduction
  4 +
  5 +This document describes the process and discussions that lead to the `ContainerInterface`.
  6 +Its goal is to explain the reasons behind each decision.
  7 +
  8 +## Goal
  9 +
  10 +The goal set by `ContainerInterface` is to standardize how frameworks and libraries make use of a
  11 +container to obtain objects and parameters.
  12 +
  13 +By standardizing such a behavior, frameworks and libraries using the `ContainerInterface`
  14 +could work with any compatible container.
  15 +That would allow end users to choose their own container based on their own preferences.
  16 +
  17 +It is important to distinguish the two usages of a container:
  18 +
  19 +- configuring entries
  20 +- fetching entries
  21 +
  22 +Most of the time, those two sides are not used by the same party.
  23 +While it is often end users who tend to configure entries, it is generally the framework that fetch
  24 +entries to build the application.
  25 +
  26 +This is why this interface focuses only on how entries can be fetched from a container.
  27 +
  28 +## Interface name
  29 +
  30 +The interface name has been thoroughly discussed and was decided by a vote.
  31 +
  32 +The list of options considered with their respective votes are:
  33 +
  34 +- `ContainerInterface`: +8
  35 +- `ProviderInterface`: +2
  36 +- `LocatorInterface`: 0
  37 +- `ReadableContainerInterface`: -5
  38 +- `ServiceLocatorInterface`: -6
  39 +- `ObjectFactory`: -6
  40 +- `ObjectStore`: -8
  41 +- `ConsumerInterface`: -9
  42 +
  43 +[Full results of the vote](https://github.com/container-interop/container-interop/wiki/%231-interface-name:-Vote)
  44 +
  45 +The complete discussion can be read in [the issue #1](https://github.com/container-interop/container-interop/issues/1).
  46 +
  47 +## Interface methods
  48 +
  49 +The choice of which methods the interface would contain was made after a statistical analysis of existing containers.
  50 +The results of this analysis are available [in this document](https://gist.github.com/mnapoli/6159681).
  51 +
  52 +The summary of the analysis showed that:
  53 +
  54 +- all containers offer a method to get an entry by its id
  55 +- a large majority name such method `get()`
  56 +- for all containers, the `get()` method has 1 mandatory parameter of type string
  57 +- some containers have an optional additional argument for `get()`, but it doesn't have the same purpose between containers
  58 +- a large majority of the containers offer a method to test if it can return an entry by its id
  59 +- a majority name such method `has()`
  60 +- for all containers offering `has()`, the method has exactly 1 parameter of type string
  61 +- a large majority of the containers throw an exception rather than returning null when an entry is not found in `get()`
  62 +- a large majority of the containers don't implement `ArrayAccess`
  63 +
  64 +The question of whether to include methods to define entries has been discussed in
  65 +[issue #1](https://github.com/container-interop/container-interop/issues/1).
  66 +It has been judged that such methods do not belong in the interface described here because it is out of its scope
  67 +(see the "Goal" section).
  68 +
  69 +As a result, the `ContainerInterface` contains two methods:
  70 +
  71 +- `get()`, returning anything, with one mandatory string parameter. Should throw an exception if the entry is not found.
  72 +- `has()`, returning a boolean, with one mandatory string parameter.
  73 +
  74 +### Number of parameters in `get()` method
  75 +
  76 +While `ContainerInterface` only defines one mandatory parameter in `get()`, it is not incompatible with
  77 +existing containers that have additional optional parameters. PHP allows an implementation to offer more parameters
  78 +as long as they are optional, because the implementation *does* satisfy the interface.
  79 +
  80 +This issue has been discussed in [issue #6](https://github.com/container-interop/container-interop/issues/6).
  81 +
  82 +### Type of the `$id` parameter
  83 +
  84 +The type of the `$id` parameter in `get()` and `has()` has been discussed in
  85 +[issue #6](https://github.com/container-interop/container-interop/issues/6).
  86 +While `string` is used in all the containers that were analyzed, it was suggested that allowing
  87 +anything (such as objects) could allow containers to offer a more advanced query API.
  88 +
  89 +An example given was to use the container as an object builder. The `$id` parameter would then be an
  90 +object that would describe how to create an instance.
  91 +
  92 +The conclusion of the discussion was that this was beyond the scope of getting entries from a container without
  93 +knowing how the container provided them, and it was more fit for a factory.
  94 +
  95 +## Contributors
  96 +
  97 +Are listed here all people that contributed in the discussions or votes, by alphabetical order:
  98 +
  99 +- [Amy Stephen](https://github.com/AmyStephen)
  100 +- [David Negrier](https://github.com/moufmouf)
  101 +- [Don Gilbert](https://github.com/dongilbert)
  102 +- [Jason Judge](https://github.com/judgej)
  103 +- [Jeremy Lindblom](https://github.com/jeremeamia)
  104 +- [Marco Pivetta](https://github.com/Ocramius)
  105 +- [Matthieu Napoli](https://github.com/mnapoli)
  106 +- [Paul M. Jones](https://github.com/pmjones)
  107 +- [Stephan Hochdörfer](https://github.com/shochdoerfer)
  108 +- [Taylor Otwell](https://github.com/taylorotwell)
  109 +
  110 +## Relevant links
  111 +
  112 +- [`ContainerInterface.php`](https://github.com/container-interop/container-interop/blob/master/src/Interop/Container/ContainerInterface.php)
  113 +- [List of all issues](https://github.com/container-interop/container-interop/issues?labels=ContainerInterface&milestone=&page=1&state=closed)
  114 +- [Vote for the interface name](https://github.com/container-interop/container-interop/wiki/%231-interface-name:-Vote)
... ...
vendor/container-interop/container-interop/docs/ContainerInterface.md 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/docs/ContainerInterface.md
... ... @@ -0,0 +1,158 @@
  1 +Container interface
  2 +===================
  3 +
  4 +This document describes a common interface for dependency injection containers.
  5 +
  6 +The goal set by `ContainerInterface` is to standardize how frameworks and libraries make use of a
  7 +container to obtain objects and parameters (called *entries* in the rest of this document).
  8 +
  9 +The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD",
  10 +"SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be
  11 +interpreted as described in [RFC 2119][].
  12 +
  13 +The word `implementor` in this document is to be interpreted as someone
  14 +implementing the `ContainerInterface` in a dependency injection-related library or framework.
  15 +Users of dependency injections containers (DIC) are referred to as `user`.
  16 +
  17 +[RFC 2119]: http://tools.ietf.org/html/rfc2119
  18 +
  19 +1. Specification
  20 +-----------------
  21 +
  22 +### 1.1 Basics
  23 +
  24 +- The `Interop\Container\ContainerInterface` exposes two methods : `get` and `has`.
  25 +
  26 +- `get` takes one mandatory parameter: an entry identifier. It MUST be a string.
  27 + A call to `get` can return anything (a *mixed* value), or throws an exception if the identifier
  28 + is not known to the container. Two successive calls to `get` with the same
  29 + identifier SHOULD return the same value. However, depending on the `implementor`
  30 + design and/or `user` configuration, different values might be returned, so
  31 + `user` SHOULD NOT rely on getting the same value on 2 successive calls.
  32 + While `ContainerInterface` only defines one mandatory parameter in `get()`, implementations
  33 + MAY accept additional optional parameters.
  34 +
  35 +- `has` takes one unique parameter: an entry identifier. It MUST return `true`
  36 + if an entry identifier is known to the container and `false` if it is not.
  37 + `has($id)` returning true does not mean that `get($id)` will not throw an exception.
  38 + It does however mean that `get($id)` will not throw a `NotFoundException`.
  39 +
  40 +### 1.2 Exceptions
  41 +
  42 +Exceptions directly thrown by the container MUST implement the
  43 +[`Interop\Container\Exception\ContainerException`](../src/Interop/Container/Exception/ContainerException.php).
  44 +
  45 +A call to the `get` method with a non-existing id SHOULD throw a
  46 +[`Interop\Container\Exception\NotFoundException`](../src/Interop/Container/Exception/NotFoundException.php).
  47 +
  48 +### 1.3 Additional features
  49 +
  50 +This section describes additional features that MAY be added to a container. Containers are not
  51 +required to implement these features to respect the ContainerInterface.
  52 +
  53 +#### 1.3.1 Delegate lookup feature
  54 +
  55 +The goal of the *delegate lookup* feature is to allow several containers to share entries.
  56 +Containers implementing this feature can perform dependency lookups in other containers.
  57 +
  58 +Containers implementing this feature will offer a greater lever of interoperability
  59 +with other containers. Implementation of this feature is therefore RECOMMENDED.
  60 +
  61 +A container implementing this feature:
  62 +
  63 +- MUST implement the `ContainerInterface`
  64 +- MUST provide a way to register a delegate container (using a constructor parameter, or a setter,
  65 + or any possible way). The delegate container MUST implement the `ContainerInterface`.
  66 +
  67 +When a container is configured to use a delegate container for dependencies:
  68 +
  69 +- Calls to the `get` method should only return an entry if the entry is part of the container.
  70 + If the entry is not part of the container, an exception should be thrown
  71 + (as requested by the `ContainerInterface`).
  72 +- Calls to the `has` method should only return `true` if the entry is part of the container.
  73 + If the entry is not part of the container, `false` should be returned.
  74 +- If the fetched entry has dependencies, **instead** of performing
  75 + the dependency lookup in the container, the lookup is performed on the *delegate container*.
  76 +
  77 +Important! By default, the lookup SHOULD be performed on the delegate container **only**, not on the container itself.
  78 +
  79 +It is however allowed for containers to provide exception cases for special entries, and a way to lookup
  80 +into the same container (or another container) instead of the delegate container.
  81 +
  82 +2. Package
  83 +----------
  84 +
  85 +The interfaces and classes described as well as relevant exception are provided as part of the
  86 +[container-interop/container-interop](https://packagist.org/packages/container-interop/container-interop) package.
  87 +
  88 +3. `Interop\Container\ContainerInterface`
  89 +-----------------------------------------
  90 +
  91 +```php
  92 +<?php
  93 +namespace Interop\Container;
  94 +
  95 +use Interop\Container\Exception\ContainerException;
  96 +use Interop\Container\Exception\NotFoundException;
  97 +
  98 +/**
  99 + * Describes the interface of a container that exposes methods to read its entries.
  100 + */
  101 +interface ContainerInterface
  102 +{
  103 + /**
  104 + * Finds an entry of the container by its identifier and returns it.
  105 + *
  106 + * @param string $id Identifier of the entry to look for.
  107 + *
  108 + * @throws NotFoundException No entry was found for this identifier.
  109 + * @throws ContainerException Error while retrieving the entry.
  110 + *
  111 + * @return mixed Entry.
  112 + */
  113 + public function get($id);
  114 +
  115 + /**
  116 + * Returns true if the container can return an entry for the given identifier.
  117 + * Returns false otherwise.
  118 + *
  119 + * `has($id)` returning true does not mean that `get($id)` will not throw an exception.
  120 + * It does however mean that `get($id)` will not throw a `NotFoundException`.
  121 + *
  122 + * @param string $id Identifier of the entry to look for.
  123 + *
  124 + * @return boolean
  125 + */
  126 + public function has($id);
  127 +}
  128 +```
  129 +
  130 +4. `Interop\Container\Exception\ContainerException`
  131 +---------------------------------------------------
  132 +
  133 +```php
  134 +<?php
  135 +namespace Interop\Container\Exception;
  136 +
  137 +/**
  138 + * Base interface representing a generic exception in a container.
  139 + */
  140 +interface ContainerException
  141 +{
  142 +}
  143 +```
  144 +
  145 +5. `Interop\Container\Exception\NotFoundException`
  146 +---------------------------------------------------
  147 +
  148 +```php
  149 +<?php
  150 +namespace Interop\Container\Exception;
  151 +
  152 +/**
  153 + * No entry was found in the container.
  154 + */
  155 +interface NotFoundException extends ContainerException
  156 +{
  157 +}
  158 +```
... ...
vendor/container-interop/container-interop/docs/Delegate-lookup-meta.md 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/docs/Delegate-lookup-meta.md
... ... @@ -0,0 +1,259 @@
  1 +Delegate lookup feature Meta Document
  2 +=====================================
  3 +
  4 +1. Summary
  5 +----------
  6 +
  7 +This document describes the *delegate lookup feature*.
  8 +Containers are not required to implement this feature to respect the `ContainerInterface`.
  9 +However, containers implementing this feature will offer a greater lever of interoperability
  10 +with other containers, allowing multiple containers to share entries in the same application.
  11 +Implementation of this feature is therefore recommanded.
  12 +
  13 +2. Why Bother?
  14 +--------------
  15 +
  16 +The [`ContainerInterface`](../src/Interop/Container/ContainerInterface.php) ([meta doc](ContainerInterface.md))
  17 +standardizes how frameworks and libraries make use of a container to obtain objects and parameters.
  18 +
  19 +By standardizing such a behavior, frameworks and libraries relying on the `ContainerInterface`
  20 +could work with any compatible container.
  21 +That would allow end users to choose their own container based on their own preferences.
  22 +
  23 +The `ContainerInterface` is also enough if we want to have several containers side-by-side in the same
  24 +application. For instance, this is what the [CompositeContainer](https://github.com/jeremeamia/acclimate-container/blob/master/src/CompositeContainer.php)
  25 +class of [Acclimate](https://github.com/jeremeamia/acclimate-container) is designed for:
  26 +
  27 +![Side by side containers](images/side_by_side_containers.png)
  28 +
  29 +However, an instance in container 1 cannot reference an instance in container 2.
  30 +
  31 +It would be better if an instance of container 1 could reference an instance in container 2,
  32 +and the opposite should be true.
  33 +
  34 +![Interoperating containers](images/interoperating_containers.png)
  35 +
  36 +In the sample above, entry 1 in container 1 is referencing entry 3 in container 2.
  37 +
  38 +3. Scope
  39 +--------
  40 +
  41 +### 3.1 Goals
  42 +
  43 +The goal of the *delegate lookup* feature is to allow several containers to share entries.
  44 +
  45 +4. Approaches
  46 +-------------
  47 +
  48 +### 4.1 Chosen Approach
  49 +
  50 +Containers implementing this feature can perform dependency lookups in other containers.
  51 +
  52 +A container implementing this feature:
  53 +
  54 +- must implement the `ContainerInterface`
  55 +- must provide a way to register a *delegate container* (using a constructor parameter, or a setter, or any
  56 +possible way). The *delegate container* must implement the `ContainerInterface`.
  57 +
  58 +When a *delegate container* is configured on a container:
  59 +
  60 +- Calls to the `get` method should only return an entry if the entry is part of the container.
  61 +If the entry is not part of the container, an exception should be thrown (as required in the `ContainerInterface`).
  62 +- Calls to the `has` method should only return *true* if the entry is part of the container.
  63 +If the entry is not part of the container, *false* should be returned.
  64 + - Finally, the important part: if the entry we are fetching has dependencies,
  65 +**instead** of perfoming the dependency lookup in the container, the lookup is performed on the *delegate container*.
  66 +
  67 +Important! By default, the lookup should be performed on the delegate container **only**, not on the container itself.
  68 +
  69 +It is however allowed for containers to provide exception cases for special entries, and a way to lookup into
  70 +the same container (or another container) instead of the delegate container.
  71 +
  72 +### 4.2 Typical usage
  73 +
  74 +The *delegate container* will usually be a composite container. A composite container is a container that
  75 +contains several other containers. When performing a lookup on a composite container, the inner containers are
  76 +queried until one container returns an entry.
  77 +An inner container implementing the *delegate lookup feature* will return entries it contains, but if these
  78 +entries have dependencies, the dependencies lookup calls will be performed on the composite container, giving
  79 +a chance to all containers to answer.
  80 +
  81 +Interestingly enough, the order in which containers are added in the composite container matters. Indeed,
  82 +the first containers to be added in the composite container can "override" the entries of containers with
  83 +lower priority.
  84 +
  85 +![Containers priority](images/priority.png)
  86 +
  87 +In the example above, "container 2" contains a controller "myController" and the controller is referencing an
  88 +"entityManager" entry. "Container 1" contains also an entry named "entityManager".
  89 +Without the *delegate lookup* feature, when requesting the "myController" instance to container 2, it would take
  90 +in charge the instanciation of both entries.
  91 +
  92 +However, using the *delegate lookup* feature, here is what happens when we ask the composite container for the
  93 +"myController" instance:
  94 +
  95 +- The composite container asks container 1 if if contains the "myController" instance. The answer is no.
  96 +- The composite container asks container 2 if if contains the "myController" instance. The answer is yes.
  97 +- The composite container performs a `get` call on container 2 for the "myController" instance.
  98 +- Container 2 sees that "myController" has a dependency on "entityManager".
  99 +- Container 2 delegates the lookup of "entityManager" to the composite container.
  100 +- The composite container asks container 1 if if contains the "entityManager" instance. The answer is yes.
  101 +- The composite container performs a `get` call on container 1 for the "entityManager" instance.
  102 +
  103 +In the end, we get a controller instanciated by container 2 that references an entityManager instanciated
  104 +by container 1.
  105 +
  106 +### 4.3 Alternative: the fallback strategy
  107 +
  108 +The first proposed approach we tried was to perform all the lookups in the "local" container,
  109 +and if a lookup fails in the container, to use the delegate container. In this scenario, the
  110 +delegate container is used in "fallback" mode.
  111 +
  112 +This strategy has been described in @moufmouf blog post: http://mouf-php.com/container-interop-whats-next (solution 1).
  113 +It was also discussed [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-33570697) and
  114 +[here](https://github.com/container-interop/container-interop/pull/20#issuecomment-56599631).
  115 +
  116 +Problems with this strategy:
  117 +
  118 +- Heavy problem regarding infinite loops
  119 +- Unable to overload a container entry with the delegate container entry
  120 +
  121 +### 4.4 Alternative: force implementing an interface
  122 +
  123 +The first proposed approach was to develop a `ParentAwareContainerInterface` interface.
  124 +It was proposed here: https://github.com/container-interop/container-interop/pull/8
  125 +
  126 +The interface would have had the behaviour of the delegate lookup feature but would have forced the addition of
  127 +a `setParentContainter` method:
  128 +
  129 +```php
  130 +interface ParentAwareContainerInterface extends ReadableContainerInterface {
  131 + /**
  132 + * Sets the parent container associated to that container. This container will call
  133 + * the parent container to fetch dependencies.
  134 + *
  135 + * @param ContainerInterface $container
  136 + */
  137 + public function setParentContainer(ContainerInterface $container);
  138 +}
  139 +```
  140 +
  141 +The interface idea was first questioned by @Ocramius [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-51721777).
  142 +@Ocramius expressed the idea that an interface should not contain setters, otherwise, it is forcing implementation
  143 +details on the class implementing the interface.
  144 +Then @mnapoli made a proposal for a "convention" [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-51841079),
  145 +this idea was further discussed until all participants in the discussion agreed to remove the interface idea
  146 +and replace it with a "standard" feature.
  147 +
  148 +**Pros:**
  149 +
  150 +If we had had an interface, we could have delegated the registration of the delegate/composite container to the
  151 +the delegate/composite container itself.
  152 +For instance:
  153 +
  154 +```php
  155 +$containerA = new ContainerA();
  156 +$containerB = new ContainerB();
  157 +
  158 +$compositeContainer = new CompositeContainer([$containerA, $containerB]);
  159 +
  160 +// The call to 'setParentContainer' is delegated to the CompositeContainer
  161 +// It is not the responsibility of the user anymore.
  162 +class CompositeContainer {
  163 + ...
  164 +
  165 + public function __construct($containers) {
  166 + foreach ($containers as $container) {
  167 + if ($container instanceof ParentAwareContainerInterface) {
  168 + $container->setParentContainer($this);
  169 + }
  170 + }
  171 + ...
  172 + }
  173 +}
  174 +
  175 +```
  176 +
  177 +**Cons:**
  178 +
  179 +Cons have been extensively discussed [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-51721777).
  180 +Basically, forcing a setter into an interface is a bad idea. Setters are similar to constructor arguments,
  181 +and it's a bad idea to standardize a constructor: how the delegate container is configured into a container is an implementation detail. This outweights the benefits of the interface.
  182 +
  183 +### 4.4 Alternative: no exception case for delegate lookups
  184 +
  185 +Originally, the proposed wording for delegate lookup calls was:
  186 +
  187 +> Important! The lookup MUST be performed on the delegate container **only**, not on the container itself.
  188 +
  189 +This was later replaced by:
  190 +
  191 +> Important! By default, the lookup SHOULD be performed on the delegate container **only**, not on the container itself.
  192 +>
  193 +> It is however allowed for containers to provide exception cases for special entries, and a way to lookup
  194 +> into the same container (or another container) instead of the delegate container.
  195 +
  196 +Exception cases have been allowed to avoid breaking dependencies with some services that must be provided
  197 +by the container (on @njasm proposal). This was proposed here: https://github.com/container-interop/container-interop/pull/20#issuecomment-56597235
  198 +
  199 +### 4.5 Alternative: having one of the containers act as the composite container
  200 +
  201 +In real-life scenarios, we usually have a big framework (Symfony 2, Zend Framework 2, etc...) and we want to
  202 +add another DI container to this container. Most of the time, the "big" framework will be responsible for
  203 +creating the controller's instances, using it's own DI container. Until *container-interop* is fully adopted,
  204 +the "big" framework will not be aware of the existence of a composite container that it should use instead
  205 +of its own container.
  206 +
  207 +For this real-life use cases, @mnapoli and @moufmouf proposed to extend the "big" framework's DI container
  208 +to make it act as a composite container.
  209 +
  210 +This has been discussed [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-40367194)
  211 +and [here](http://mouf-php.com/container-interop-whats-next#solution4).
  212 +
  213 +This was implemented in Symfony 2 using:
  214 +
  215 +- [interop.symfony.di](https://github.com/thecodingmachine/interop.symfony.di/tree/v0.1.0)
  216 +- [framework interop](https://github.com/mnapoli/framework-interop/)
  217 +
  218 +This was implemented in Silex using:
  219 +
  220 +- [interop.silex.di](https://github.com/thecodingmachine/interop.silex.di)
  221 +
  222 +Having a container act as the composite container is not part of the delegate lookup standard because it is
  223 +simply a temporary design pattern used to make existing frameworks that do not support yet ContainerInterop
  224 +play nice with other DI containers.
  225 +
  226 +
  227 +5. Implementations
  228 +------------------
  229 +
  230 +The following projects already implement the delegate lookup feature:
  231 +
  232 +- [Mouf](http://mouf-php.com), through the [`setDelegateLookupContainer` method](https://github.com/thecodingmachine/mouf/blob/2.0/src/Mouf/MoufManager.php#L2120)
  233 +- [PHP-DI](http://php-di.org/), through the [`$wrapperContainer` parameter of the constructor](https://github.com/mnapoli/PHP-DI/blob/master/src/DI/Container.php#L72)
  234 +- [pimple-interop](https://github.com/moufmouf/pimple-interop), through the [`$container` parameter of the constructor](https://github.com/moufmouf/pimple-interop/blob/master/src/Interop/Container/Pimple/PimpleInterop.php#L62)
  235 +
  236 +6. People
  237 +---------
  238 +
  239 +Are listed here all people that contributed in the discussions, by alphabetical order:
  240 +
  241 +- [Alexandru Pătrănescu](https://github.com/drealecs)
  242 +- [Ben Peachey](https://github.com/potherca)
  243 +- [David Negrier](https://github.com/moufmouf)
  244 +- [Jeremy Lindblom](https://github.com/jeremeamia)
  245 +- [Marco Pivetta](https://github.com/Ocramius)
  246 +- [Matthieu Napoli](https://github.com/mnapoli)
  247 +- [Nelson J Morais](https://github.com/njasm)
  248 +- [Phil Sturgeon](https://github.com/philsturgeon)
  249 +- [Stephan Hochdörfer](https://github.com/shochdoerfer)
  250 +
  251 +7. Relevant Links
  252 +-----------------
  253 +
  254 +_**Note:** Order descending chronologically._
  255 +
  256 +- [Pull request on the delegate lookup feature](https://github.com/container-interop/container-interop/pull/20)
  257 +- [Pull request on the interface idea](https://github.com/container-interop/container-interop/pull/8)
  258 +- [Original article exposing the delegate lookup idea along many others](http://mouf-php.com/container-interop-whats-next)
  259 +
... ...
vendor/container-interop/container-interop/docs/Delegate-lookup.md 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/docs/Delegate-lookup.md
... ... @@ -0,0 +1,60 @@
  1 +Delegate lookup feature
  2 +=======================
  3 +
  4 +This document describes a standard for dependency injection containers.
  5 +
  6 +The goal set by the *delegate lookup* feature is to allow several containers to share entries.
  7 +Containers implementing this feature can perform dependency lookups in other containers.
  8 +
  9 +Containers implementing this feature will offer a greater lever of interoperability
  10 +with other containers. Implementation of this feature is therefore RECOMMENDED.
  11 +
  12 +The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD",
  13 +"SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be
  14 +interpreted as described in [RFC 2119][].
  15 +
  16 +The word `implementor` in this document is to be interpreted as someone
  17 +implementing the delegate lookup feature in a dependency injection-related library or framework.
  18 +Users of dependency injections containers (DIC) are referred to as `user`.
  19 +
  20 +[RFC 2119]: http://tools.ietf.org/html/rfc2119
  21 +
  22 +1. Vocabulary
  23 +-------------
  24 +
  25 +In a dependency injection container, the container is used to fetch entries.
  26 +Entries can have dependencies on other entries. Usually, these other entries are fetched by the container.
  27 +
  28 +The *delegate lookup* feature is the ability for a container to fetch dependencies in
  29 +another container. In the rest of the document, the word "container" will reference the container
  30 +implemented by the implementor. The word "delegate container" will reference the container we are
  31 +fetching the dependencies from.
  32 +
  33 +2. Specification
  34 +----------------
  35 +
  36 +A container implementing the *delegate lookup* feature:
  37 +
  38 +- MUST implement the [`ContainerInterface`](ContainerInterface.md)
  39 +- MUST provide a way to register a delegate container (using a constructor parameter, or a setter,
  40 + or any possible way). The delegate container MUST implement the [`ContainerInterface`](ContainerInterface.md).
  41 +
  42 +When a container is configured to use a delegate container for dependencies:
  43 +
  44 +- Calls to the `get` method should only return an entry if the entry is part of the container.
  45 + If the entry is not part of the container, an exception should be thrown
  46 + (as requested by the [`ContainerInterface`](ContainerInterface.md)).
  47 +- Calls to the `has` method should only return `true` if the entry is part of the container.
  48 + If the entry is not part of the container, `false` should be returned.
  49 +- If the fetched entry has dependencies, **instead** of performing
  50 + the dependency lookup in the container, the lookup is performed on the *delegate container*.
  51 +
  52 +Important: By default, the dependency lookups SHOULD be performed on the delegate container **only**, not on the container itself.
  53 +
  54 +It is however allowed for containers to provide exception cases for special entries, and a way to lookup
  55 +into the same container (or another container) instead of the delegate container.
  56 +
  57 +3. Package / Interface
  58 +----------------------
  59 +
  60 +This feature is not tied to any code, interface or package.
... ...
vendor/container-interop/container-interop/docs/images/interoperating_containers.png 0 → 100644

25.1 KB

vendor/container-interop/container-interop/docs/images/priority.png 0 → 100644

15.9 KB

vendor/container-interop/container-interop/docs/images/side_by_side_containers.png 0 → 100644

15.9 KB

vendor/container-interop/container-interop/src/Interop/Container/ContainerInterface.php 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/src/Interop/Container/ContainerInterface.php
... ... @@ -0,0 +1,15 @@
  1 +<?php
  2 +/**
  3 + * @license http://www.opensource.org/licenses/mit-license.php MIT (see the LICENSE file)
  4 + */
  5 +
  6 +namespace Interop\Container;
  7 +
  8 +use Psr\Container\ContainerInterface as PsrContainerInterface;
  9 +
  10 +/**
  11 + * Describes the interface of a container that exposes methods to read its entries.
  12 + */
  13 +interface ContainerInterface extends PsrContainerInterface
  14 +{
  15 +}
... ...
vendor/container-interop/container-interop/src/Interop/Container/Exception/ContainerException.php 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/src/Interop/Container/Exception/ContainerException.php
... ... @@ -0,0 +1,15 @@
  1 +<?php
  2 +/**
  3 + * @license http://www.opensource.org/licenses/mit-license.php MIT (see the LICENSE file)
  4 + */
  5 +
  6 +namespace Interop\Container\Exception;
  7 +
  8 +use Psr\Container\ContainerExceptionInterface as PsrContainerException;
  9 +
  10 +/**
  11 + * Base interface representing a generic exception in a container.
  12 + */
  13 +interface ContainerException extends PsrContainerException
  14 +{
  15 +}
... ...
vendor/container-interop/container-interop/src/Interop/Container/Exception/NotFoundException.php 0 → 100644
  1 +++ a/vendor/container-interop/container-interop/src/Interop/Container/Exception/NotFoundException.php
... ... @@ -0,0 +1,15 @@
  1 +<?php
  2 +/**
  3 + * @license http://www.opensource.org/licenses/mit-license.php MIT (see the LICENSE file)
  4 + */
  5 +
  6 +namespace Interop\Container\Exception;
  7 +
  8 +use Psr\Container\NotFoundExceptionInterface as PsrNotFoundException;
  9 +
  10 +/**
  11 + * No entry was found in the container.
  12 + */
  13 +interface NotFoundException extends ContainerException, PsrNotFoundException
  14 +{
  15 +}
... ...
vendor/nikic/fast-route/.gitignore 0 → 100644
  1 +++ a/vendor/nikic/fast-route/.gitignore
... ... @@ -0,0 +1,5 @@
  1 +/vendor/
  2 +.idea/
  3 +
  4 +# ignore lock file since we have no extra dependencies
  5 +composer.lock
... ...
vendor/nikic/fast-route/.hhconfig 0 → 100644
  1 +++ a/vendor/nikic/fast-route/.hhconfig
... ... @@ -0,0 +1 @@
  1 +assume_php=false
... ...
vendor/nikic/fast-route/.travis.yml 0 → 100644
  1 +++ a/vendor/nikic/fast-route/.travis.yml
... ... @@ -0,0 +1,12 @@
  1 +language: php
  2 +
  3 +php:
  4 + - 5.4
  5 + - 5.5
  6 + - 5.6
  7 + - 7.0
  8 + - hhvm
  9 +
  10 +matrix:
  11 + allow_failures:
  12 + - php: 7.0
... ...
vendor/nikic/fast-route/FastRoute.hhi 0 → 100644
  1 +++ a/vendor/nikic/fast-route/FastRoute.hhi
... ... @@ -0,0 +1,126 @@
  1 +<?hh // decl
  2 +
  3 +namespace FastRoute {
  4 + class BadRouteException extends \LogicException {
  5 + }
  6 +
  7 + interface RouteParser {
  8 + public function parse(string $route): array<array>;
  9 + }
  10 +
  11 + class RouteCollector {
  12 + public function __construct(RouteParser $routeParser, DataGenerator $dataGenerator);
  13 + public function addRoute(mixed $httpMethod, string $route, mixed $handler): void;
  14 + public function getData(): array;
  15 + }
  16 +
  17 + class Route {
  18 + public function __construct(string $httpMethod, mixed $handler, string $regex, array $variables);
  19 + public function matches(string $str): bool;
  20 + }
  21 +
  22 + interface DataGenerator {
  23 + public function addRoute(string $httpMethod, array $routeData, mixed $handler);
  24 + public function getData(): array;
  25 + }
  26 +
  27 + interface Dispatcher {
  28 + const int NOT_FOUND = 0;
  29 + const int FOUND = 1;
  30 + const int METHOD_NOT_ALLOWED = 2;
  31 + public function dispatch(string $httpMethod, string $uri): array;
  32 + }
  33 +
  34 + function simpleDispatcher(
  35 + (function(RouteCollector): void) $routeDefinitionCallback,
  36 + shape(
  37 + 'routeParser' => ?classname<RouteParser>,
  38 + 'dataGenerator' => ?classname<DataGenerator>,
  39 + 'dispatcher' => ?classname<Dispatcher>,
  40 + 'routeCollector' => ?classname<RouteCollector>,
  41 + ) $options = shape()): Dispatcher;
  42 +
  43 + function cachedDispatcher(
  44 + (function(RouteCollector): void) $routeDefinitionCallback,
  45 + shape(
  46 + 'routeParser' => ?classname<RouteParser>,
  47 + 'dataGenerator' => ?classname<DataGenerator>,
  48 + 'dispatcher' => ?classname<Dispatcher>,
  49 + 'routeCollector' => ?classname<RouteCollector>,
  50 + 'cacheDisabled' => ?bool,
  51 + 'cacheFile' => ?string,
  52 + ) $options = shape()): Dispatcher;
  53 +}
  54 +
  55 +namespace FastRoute\DataGenerator {
  56 + abstract class RegexBasedAbstract implements \FastRoute\DataGenerator {
  57 + protected abstract function getApproxChunkSize();
  58 + protected abstract function processChunk($regexToRoutesMap);
  59 +
  60 + public function addRoute(string $httpMethod, array $routeData, mixed $handler): void;
  61 + public function getData(): array;
  62 + }
  63 +
  64 + class CharCountBased extends RegexBasedAbstract {
  65 + protected function getApproxChunkSize(): int;
  66 + protected function processChunk(array<string, string> $regexToRoutesMap): array<string, mixed>;
  67 + }
  68 +
  69 + class GroupCountBased extends RegexBasedAbstract {
  70 + protected function getApproxChunkSize(): int;
  71 + protected function processChunk(array<string, string> $regexToRoutesMap): array<string, mixed>;
  72 + }
  73 +
  74 + class GroupPosBased extends RegexBasedAbstract {
  75 + protected function getApproxChunkSize(): int;
  76 + protected function processChunk(array<string, string> $regexToRoutesMap): array<string, mixed>;
  77 + }
  78 +
  79 + class MarkBased extends RegexBasedAbstract {
  80 + protected function getApproxChunkSize(): int;
  81 + protected function processChunk(array<string, string> $regexToRoutesMap): array<string, mixed>;
  82 + }
  83 +}
  84 +
  85 +namespace FastRoute\Dispatcher {
  86 + abstract class RegexBasedAbstract implements \FastRoute\Dispatcher {
  87 + protected abstract function dispatchVariableRoute(array<array> $routeData, string $uri): array;
  88 +
  89 + public function dispatch(string $httpMethod, string $uri): array;
  90 + }
  91 +
  92 + class GroupPosBased extends RegexBasedAbstract {
  93 + public function __construct(array $data);
  94 + protected function dispatchVariableRoute(array<array> $routeData, string $uri): array;
  95 + }
  96 +
  97 + class GroupCountBased extends RegexBasedAbstract {
  98 + public function __construct(array $data);
  99 + protected function dispatchVariableRoute(array<array> $routeData, string $uri): array;
  100 + }
  101 +
  102 + class CharCountBased extends RegexBasedAbstract {
  103 + public function __construct(array $data);
  104 + protected function dispatchVariableRoute(array<array> $routeData, string $uri): array;
  105 + }
  106 +
  107 + class MarkBased extends RegexBasedAbstract {
  108 + public function __construct(array $data);
  109 + protected function dispatchVariableRoute(array<array> $routeData, string $uri): array;
  110 + }
  111 +}
  112 +
  113 +namespace FastRoute\RouteParser {
  114 + class Std implements \FastRoute\RouteParser {
  115 + const string VARIABLE_REGEX = <<<'REGEX'
  116 +\{
  117 + \s* ([a-zA-Z][a-zA-Z0-9_]*) \s*
  118 + (?:
  119 + : \s* ([^{}]*(?:\{(?-1)\}[^{}]*)*)
  120 + )?
  121 +\}
  122 +REGEX;
  123 + const string DEFAULT_DISPATCH_REGEX = '[^/]+';
  124 + public function parse(string $route): array<array>;
  125 + }
  126 +}
... ...
vendor/nikic/fast-route/LICENSE 0 → 100644
  1 +++ a/vendor/nikic/fast-route/LICENSE
... ... @@ -0,0 +1,31 @@
  1 +Copyright (c) 2013 by Nikita Popov.
  2 +
  3 +Some rights reserved.
  4 +
  5 +Redistribution and use in source and binary forms, with or without
  6 +modification, are permitted provided that the following conditions are
  7 +met:
  8 +
  9 + * Redistributions of source code must retain the above copyright
  10 + notice, this list of conditions and the following disclaimer.
  11 +
  12 + * Redistributions in binary form must reproduce the above
  13 + copyright notice, this list of conditions and the following
  14 + disclaimer in the documentation and/or other materials provided
  15 + with the distribution.
  16 +
  17 + * The names of the contributors may not be used to endorse or
  18 + promote products derived from this software without specific
  19 + prior written permission.
  20 +
  21 +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  22 +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  23 +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  24 +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  25 +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  26 +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  27 +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  28 +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  29 +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  30 +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  31 +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
... ...
vendor/nikic/fast-route/README.md 0 → 100644
  1 +++ a/vendor/nikic/fast-route/README.md
... ... @@ -0,0 +1,313 @@
  1 +FastRoute - Fast request router for PHP
  2 +=======================================
  3 +
  4 +This library provides a fast implementation of a regular expression based router. [Blog post explaining how the
  5 +implementation works and why it is fast.][blog_post]
  6 +
  7 +Install
  8 +-------
  9 +
  10 +To install with composer:
  11 +
  12 +```sh
  13 +composer require nikic/fast-route
  14 +```
  15 +
  16 +Requires PHP 5.4 or newer.
  17 +
  18 +Usage
  19 +-----
  20 +
  21 +Here's a basic usage example:
  22 +
  23 +```php
  24 +<?php
  25 +
  26 +require '/path/to/vendor/autoload.php';
  27 +
  28 +$dispatcher = FastRoute\simpleDispatcher(function(FastRoute\RouteCollector $r) {
  29 + $r->addRoute('GET', '/users', 'get_all_users_handler');
  30 + // {id} must be a number (\d+)
  31 + $r->addRoute('GET', '/user/{id:\d+}', 'get_user_handler');
  32 + // The /{title} suffix is optional
  33 + $r->addRoute('GET', '/articles/{id:\d+}[/{title}]', 'get_article_handler');
  34 +});
  35 +
  36 +// Fetch method and URI from somewhere
  37 +$httpMethod = $_SERVER['REQUEST_METHOD'];
  38 +$uri = $_SERVER['REQUEST_URI'];
  39 +
  40 +// Strip query string (?foo=bar) and decode URI
  41 +if (false !== $pos = strpos($uri, '?')) {
  42 + $uri = substr($uri, 0, $pos);
  43 +}
  44 +$uri = rawurldecode($uri);
  45 +
  46 +$routeInfo = $dispatcher->dispatch($httpMethod, $uri);
  47 +switch ($routeInfo[0]) {
  48 + case FastRoute\Dispatcher::NOT_FOUND:
  49 + // ... 404 Not Found
  50 + break;
  51 + case FastRoute\Dispatcher::METHOD_NOT_ALLOWED:
  52 + $allowedMethods = $routeInfo[1];
  53 + // ... 405 Method Not Allowed
  54 + break;
  55 + case FastRoute\Dispatcher::FOUND:
  56 + $handler = $routeInfo[1];
  57 + $vars = $routeInfo[2];
  58 + // ... call $handler with $vars
  59 + break;
  60 +}
  61 +```
  62 +
  63 +### Defining routes
  64 +
  65 +The routes are defined by calling the `FastRoute\simpleDispatcher()` function, which accepts
  66 +a callable taking a `FastRoute\RouteCollector` instance. The routes are added by calling
  67 +`addRoute()` on the collector instance:
  68 +
  69 +```php
  70 +$r->addRoute($method, $routePattern, $handler);
  71 +```
  72 +
  73 +The `$method` is an uppercase HTTP method string for which a certain route should match. It
  74 +is possible to specify multiple valid methods using an array:
  75 +
  76 +```php
  77 +// These two calls
  78 +$r->addRoute('GET', '/test', 'handler');
  79 +$r->addRoute('POST', '/test', 'handler');
  80 +// Are equivalent to this one call
  81 +$r->addRoute(['GET', 'POST'], '/test', 'handler');
  82 +```
  83 +
  84 +By default the `$routePattern` uses a syntax where `{foo}` specifies a placeholder with name `foo`
  85 +and matching the regex `[^/]+`. To adjust the pattern the placeholder matches, you can specify
  86 +a custom pattern by writing `{bar:[0-9]+}`. Some examples:
  87 +
  88 +```php
  89 +// Matches /user/42, but not /user/xyz
  90 +$r->addRoute('GET', '/user/{id:\d+}', 'handler');
  91 +
  92 +// Matches /user/foobar, but not /user/foo/bar
  93 +$r->addRoute('GET', '/user/{name}', 'handler');
  94 +
  95 +// Matches /user/foo/bar as well
  96 +$r->addRoute('GET', '/user/{name:.+}', 'handler');
  97 +```
  98 +
  99 +Custom patterns for route placeholders cannot use capturing groups. For example `{lang:(en|de)}`
  100 +is not a valid placeholder, because `()` is a capturing group. Instead you can use either
  101 +`{lang:en|de}` or `{lang:(?:en|de)}`.
  102 +
  103 +Furthermore parts of the route enclosed in `[...]` are considered optional, so that `/foo[bar]`
  104 +will match both `/foo` and `/foobar`. Optional parts are only supported in a trailing position,
  105 +not in the middle of a route.
  106 +
  107 +```php
  108 +// This route
  109 +$r->addRoute('GET', '/user/{id:\d+}[/{name}]', 'handler');
  110 +// Is equivalent to these two routes
  111 +$r->addRoute('GET', '/user/{id:\d+}', 'handler');
  112 +$r->addRoute('GET', '/user/{id:\d+}/{name}', 'handler');
  113 +
  114 +// Multiple nested optional parts are possible as well
  115 +$r->addRoute('GET', '/user[/{id:\d+}[/{name}]]', 'handler');
  116 +
  117 +// This route is NOT valid, because optional parts can only occur at the end
  118 +$r->addRoute('GET', '/user[/{id:\d+}]/{name}', 'handler');
  119 +```
  120 +
  121 +The `$handler` parameter does not necessarily have to be a callback, it could also be a controller
  122 +class name or any other kind of data you wish to associate with the route. FastRoute only tells you
  123 +which handler corresponds to your URI, how you interpret it is up to you.
  124 +
  125 +#### Shorcut methods for common request methods
  126 +
  127 +For the `GET`, `POST`, `PUT`, `PATCH`, `DELETE` and `HEAD` request methods shortcut methods are available. For example:
  128 +
  129 +```php
  130 +$r->get('/get-route', 'get_handler');
  131 +$r->post('/post-route', 'post_handler');
  132 +```
  133 +
  134 +Is equivalent to:
  135 +
  136 +```php
  137 +$r->addRoute('GET', '/get-route', 'get_handler');
  138 +$r->addRoute('POST', '/post-route', 'post_handler');
  139 +```
  140 +
  141 +#### Route Groups
  142 +
  143 +Additionally, you can specify routes inside of a group. All routes defined inside a group will have a common prefix.
  144 +
  145 +For example, defining your routes as:
  146 +
  147 +```php
  148 +$r->addGroup('/admin', function (RouteCollector $r) {
  149 + $r->addRoute('GET', '/do-something', 'handler');
  150 + $r->addRoute('GET', '/do-another-thing', 'handler');
  151 + $r->addRoute('GET', '/do-something-else', 'handler');
  152 +});
  153 +```
  154 +
  155 +Will have the same result as:
  156 +
  157 + ```php
  158 +$r->addRoute('GET', '/admin/do-something', 'handler');
  159 +$r->addRoute('GET', '/admin/do-another-thing', 'handler');
  160 +$r->addRoute('GET', '/admin/do-something-else', 'handler');
  161 + ```
  162 +
  163 +Nested groups are also supported, in which case the prefixes of all the nested groups are combined.
  164 +
  165 +### Caching
  166 +
  167 +The reason `simpleDispatcher` accepts a callback for defining the routes is to allow seamless
  168 +caching. By using `cachedDispatcher` instead of `simpleDispatcher` you can cache the generated
  169 +routing data and construct the dispatcher from the cached information:
  170 +
  171 +```php
  172 +<?php
  173 +
  174 +$dispatcher = FastRoute\cachedDispatcher(function(FastRoute\RouteCollector $r) {
  175 + $r->addRoute('GET', '/user/{name}/{id:[0-9]+}', 'handler0');
  176 + $r->addRoute('GET', '/user/{id:[0-9]+}', 'handler1');
  177 + $r->addRoute('GET', '/user/{name}', 'handler2');
  178 +}, [
  179 + 'cacheFile' => __DIR__ . '/route.cache', /* required */
  180 + 'cacheDisabled' => IS_DEBUG_ENABLED, /* optional, enabled by default */
  181 +]);
  182 +```
  183 +
  184 +The second parameter to the function is an options array, which can be used to specify the cache
  185 +file location, among other things.
  186 +
  187 +### Dispatching a URI
  188 +
  189 +A URI is dispatched by calling the `dispatch()` method of the created dispatcher. This method
  190 +accepts the HTTP method and a URI. Getting those two bits of information (and normalizing them
  191 +appropriately) is your job - this library is not bound to the PHP web SAPIs.
  192 +
  193 +The `dispatch()` method returns an array whose first element contains a status code. It is one
  194 +of `Dispatcher::NOT_FOUND`, `Dispatcher::METHOD_NOT_ALLOWED` and `Dispatcher::FOUND`. For the
  195 +method not allowed status the second array element contains a list of HTTP methods allowed for
  196 +the supplied URI. For example:
  197 +
  198 + [FastRoute\Dispatcher::METHOD_NOT_ALLOWED, ['GET', 'POST']]
  199 +
  200 +> **NOTE:** The HTTP specification requires that a `405 Method Not Allowed` response include the
  201 +`Allow:` header to detail available methods for the requested resource. Applications using FastRoute
  202 +should use the second array element to add this header when relaying a 405 response.
  203 +
  204 +For the found status the second array element is the handler that was associated with the route
  205 +and the third array element is a dictionary of placeholder names to their values. For example:
  206 +
  207 + /* Routing against GET /user/nikic/42 */
  208 +
  209 + [FastRoute\Dispatcher::FOUND, 'handler0', ['name' => 'nikic', 'id' => '42']]
  210 +
  211 +### Overriding the route parser and dispatcher
  212 +
  213 +The routing process makes use of three components: A route parser, a data generator and a
  214 +dispatcher. The three components adhere to the following interfaces:
  215 +
  216 +```php
  217 +<?php
  218 +
  219 +namespace FastRoute;
  220 +
  221 +interface RouteParser {
  222 + public function parse($route);
  223 +}
  224 +
  225 +interface DataGenerator {
  226 + public function addRoute($httpMethod, $routeData, $handler);
  227 + public function getData();
  228 +}
  229 +
  230 +interface Dispatcher {
  231 + const NOT_FOUND = 0, FOUND = 1, METHOD_NOT_ALLOWED = 2;
  232 +
  233 + public function dispatch($httpMethod, $uri);
  234 +}
  235 +```
  236 +
  237 +The route parser takes a route pattern string and converts it into an array of route infos, where
  238 +each route info is again an array of it's parts. The structure is best understood using an example:
  239 +
  240 + /* The route /user/{id:\d+}[/{name}] converts to the following array: */
  241 + [
  242 + [
  243 + '/user/',
  244 + ['id', '\d+'],
  245 + ],
  246 + [
  247 + '/user/',
  248 + ['id', '\d+'],
  249 + '/',
  250 + ['name', '[^/]+'],
  251 + ],
  252 + ]
  253 +
  254 +This array can then be passed to the `addRoute()` method of a data generator. After all routes have
  255 +been added the `getData()` of the generator is invoked, which returns all the routing data required
  256 +by the dispatcher. The format of this data is not further specified - it is tightly coupled to
  257 +the corresponding dispatcher.
  258 +
  259 +The dispatcher accepts the routing data via a constructor and provides a `dispatch()` method, which
  260 +you're already familiar with.
  261 +
  262 +The route parser can be overwritten individually (to make use of some different pattern syntax),
  263 +however the data generator and dispatcher should always be changed as a pair, as the output from
  264 +the former is tightly coupled to the input of the latter. The reason the generator and the
  265 +dispatcher are separate is that only the latter is needed when using caching (as the output of
  266 +the former is what is being cached.)
  267 +
  268 +When using the `simpleDispatcher` / `cachedDispatcher` functions from above the override happens
  269 +through the options array:
  270 +
  271 +```php
  272 +<?php
  273 +
  274 +$dispatcher = FastRoute\simpleDispatcher(function(FastRoute\RouteCollector $r) {
  275 + /* ... */
  276 +}, [
  277 + 'routeParser' => 'FastRoute\\RouteParser\\Std',
  278 + 'dataGenerator' => 'FastRoute\\DataGenerator\\GroupCountBased',
  279 + 'dispatcher' => 'FastRoute\\Dispatcher\\GroupCountBased',
  280 +]);
  281 +```
  282 +
  283 +The above options array corresponds to the defaults. By replacing `GroupCountBased` by
  284 +`GroupPosBased` you could switch to a different dispatching strategy.
  285 +
  286 +### A Note on HEAD Requests
  287 +
  288 +The HTTP spec requires servers to [support both GET and HEAD methods][2616-511]:
  289 +
  290 +> The methods GET and HEAD MUST be supported by all general-purpose servers
  291 +
  292 +To avoid forcing users to manually register HEAD routes for each resource we fallback to matching an
  293 +available GET route for a given resource. The PHP web SAPI transparently removes the entity body
  294 +from HEAD responses so this behavior has no effect on the vast majority of users.
  295 +
  296 +However, implementers using FastRoute outside the web SAPI environment (e.g. a custom server) MUST
  297 +NOT send entity bodies generated in response to HEAD requests. If you are a non-SAPI user this is
  298 +*your responsibility*; FastRoute has no purview to prevent you from breaking HTTP in such cases.
  299 +
  300 +Finally, note that applications MAY always specify their own HEAD method route for a given
  301 +resource to bypass this behavior entirely.
  302 +
  303 +### Credits
  304 +
  305 +This library is based on a router that [Levi Morrison][levi] implemented for the Aerys server.
  306 +
  307 +A large number of tests, as well as HTTP compliance considerations, were provided by [Daniel Lowrey][rdlowrey].
  308 +
  309 +
  310 +[2616-511]: http://www.w3.org/Protocols/rfc2616/rfc2616-sec5.html#sec5.1.1 "RFC 2616 Section 5.1.1"
  311 +[blog_post]: http://nikic.github.io/2014/02/18/Fast-request-routing-using-regular-expressions.html
  312 +[levi]: https://github.com/morrisonlevi
  313 +[rdlowrey]: https://github.com/rdlowrey
... ...
vendor/nikic/fast-route/composer.json 0 → 100644
  1 +++ a/vendor/nikic/fast-route/composer.json
... ... @@ -0,0 +1,21 @@
  1 +{
  2 + "name": "nikic/fast-route",
  3 + "description": "Fast request router for PHP",
  4 + "keywords": ["routing", "router"],
  5 + "license": "BSD-3-Clause",
  6 + "authors": [
  7 + {
  8 + "name": "Nikita Popov",
  9 + "email": "nikic@php.net"
  10 + }
  11 + ],
  12 + "require": {
  13 + "php": ">=5.4.0"
  14 + },
  15 + "autoload": {
  16 + "psr-4": {
  17 + "FastRoute\\": "src/"
  18 + },
  19 + "files": ["src/functions.php"]
  20 + }
  21 +}
... ...
vendor/nikic/fast-route/phpunit.xml 0 → 100644
  1 +++ a/vendor/nikic/fast-route/phpunit.xml
... ... @@ -0,0 +1,24 @@
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +
  3 +<phpunit backupGlobals="false"
  4 + backupStaticAttributes="false"
  5 + colors="true"
  6 + convertErrorsToExceptions="true"
  7 + convertNoticesToExceptions="true"
  8 + convertWarningsToExceptions="true"
  9 + processIsolation="false"
  10 + syntaxCheck="false"
  11 + bootstrap="test/bootstrap.php"
  12 + >
  13 + <testsuites>
  14 + <testsuite name="FastRoute Tests">
  15 + <directory>./test/</directory>
  16 + </testsuite>
  17 + </testsuites>
  18 +
  19 + <filter>
  20 + <whitelist>
  21 + <directory>./src/</directory>
  22 + </whitelist>
  23 + </filter>
  24 +</phpunit>
... ...
vendor/nikic/fast-route/src/BadRouteException.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/BadRouteException.php
... ... @@ -0,0 +1,6 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +class BadRouteException extends \LogicException {
  6 +}
... ...
vendor/nikic/fast-route/src/DataGenerator.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/DataGenerator.php
... ... @@ -0,0 +1,25 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +interface DataGenerator {
  6 + /**
  7 + * Adds a route to the data generator. The route data uses the
  8 + * same format that is returned by RouterParser::parser().
  9 + *
  10 + * The handler doesn't necessarily need to be a callable, it
  11 + * can be arbitrary data that will be returned when the route
  12 + * matches.
  13 + *
  14 + * @param string $httpMethod
  15 + * @param array $routeData
  16 + * @param mixed $handler
  17 + */
  18 + public function addRoute($httpMethod, $routeData, $handler);
  19 +
  20 + /**
  21 + * Returns dispatcher data in some unspecified format, which
  22 + * depends on the used method of dispatch.
  23 + */
  24 + public function getData();
  25 +}
... ...
vendor/nikic/fast-route/src/DataGenerator/CharCountBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/DataGenerator/CharCountBased.php
... ... @@ -0,0 +1,28 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\DataGenerator;
  4 +
  5 +class CharCountBased extends RegexBasedAbstract {
  6 + protected function getApproxChunkSize() {
  7 + return 30;
  8 + }
  9 +
  10 + protected function processChunk($regexToRoutesMap) {
  11 + $routeMap = [];
  12 + $regexes = [];
  13 +
  14 + $suffixLen = 0;
  15 + $suffix = '';
  16 + $count = count($regexToRoutesMap);
  17 + foreach ($regexToRoutesMap as $regex => $route) {
  18 + $suffixLen++;
  19 + $suffix .= "\t";
  20 +
  21 + $regexes[] = '(?:' . $regex . '/(\t{' . $suffixLen . '})\t{' . ($count - $suffixLen) . '})';
  22 + $routeMap[$suffix] = [$route->handler, $route->variables];
  23 + }
  24 +
  25 + $regex = '~^(?|' . implode('|', $regexes) . ')$~';
  26 + return ['regex' => $regex, 'suffix' => '/' . $suffix, 'routeMap' => $routeMap];
  27 + }
  28 +}
... ...
vendor/nikic/fast-route/src/DataGenerator/GroupCountBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/DataGenerator/GroupCountBased.php
... ... @@ -0,0 +1,28 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\DataGenerator;
  4 +
  5 +class GroupCountBased extends RegexBasedAbstract {
  6 + protected function getApproxChunkSize() {
  7 + return 10;
  8 + }
  9 +
  10 + protected function processChunk($regexToRoutesMap) {
  11 + $routeMap = [];
  12 + $regexes = [];
  13 + $numGroups = 0;
  14 + foreach ($regexToRoutesMap as $regex => $route) {
  15 + $numVariables = count($route->variables);
  16 + $numGroups = max($numGroups, $numVariables);
  17 +
  18 + $regexes[] = $regex . str_repeat('()', $numGroups - $numVariables);
  19 + $routeMap[$numGroups + 1] = [$route->handler, $route->variables];
  20 +
  21 + ++$numGroups;
  22 + }
  23 +
  24 + $regex = '~^(?|' . implode('|', $regexes) . ')$~';
  25 + return ['regex' => $regex, 'routeMap' => $routeMap];
  26 + }
  27 +}
  28 +
... ...
vendor/nikic/fast-route/src/DataGenerator/GroupPosBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/DataGenerator/GroupPosBased.php
... ... @@ -0,0 +1,25 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\DataGenerator;
  4 +
  5 +class GroupPosBased extends RegexBasedAbstract {
  6 + protected function getApproxChunkSize() {
  7 + return 10;
  8 + }
  9 +
  10 + protected function processChunk($regexToRoutesMap) {
  11 + $routeMap = [];
  12 + $regexes = [];
  13 + $offset = 1;
  14 + foreach ($regexToRoutesMap as $regex => $route) {
  15 + $regexes[] = $regex;
  16 + $routeMap[$offset] = [$route->handler, $route->variables];
  17 +
  18 + $offset += count($route->variables);
  19 + }
  20 +
  21 + $regex = '~^(?:' . implode('|', $regexes) . ')$~';
  22 + return ['regex' => $regex, 'routeMap' => $routeMap];
  23 + }
  24 +}
  25 +
... ...
vendor/nikic/fast-route/src/DataGenerator/MarkBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/DataGenerator/MarkBased.php
... ... @@ -0,0 +1,25 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\DataGenerator;
  4 +
  5 +class MarkBased extends RegexBasedAbstract {
  6 + protected function getApproxChunkSize() {
  7 + return 30;
  8 + }
  9 +
  10 + protected function processChunk($regexToRoutesMap) {
  11 + $routeMap = [];
  12 + $regexes = [];
  13 + $markName = 'a';
  14 + foreach ($regexToRoutesMap as $regex => $route) {
  15 + $regexes[] = $regex . '(*MARK:' . $markName . ')';
  16 + $routeMap[$markName] = [$route->handler, $route->variables];
  17 +
  18 + ++$markName;
  19 + }
  20 +
  21 + $regex = '~^(?|' . implode('|', $regexes) . ')$~';
  22 + return ['regex' => $regex, 'routeMap' => $routeMap];
  23 + }
  24 +}
  25 +
... ...
vendor/nikic/fast-route/src/DataGenerator/RegexBasedAbstract.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/DataGenerator/RegexBasedAbstract.php
... ... @@ -0,0 +1,144 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\DataGenerator;
  4 +
  5 +use FastRoute\DataGenerator;
  6 +use FastRoute\BadRouteException;
  7 +use FastRoute\Route;
  8 +
  9 +abstract class RegexBasedAbstract implements DataGenerator {
  10 + protected $staticRoutes = [];
  11 + protected $methodToRegexToRoutesMap = [];
  12 +
  13 + protected abstract function getApproxChunkSize();
  14 + protected abstract function processChunk($regexToRoutesMap);
  15 +
  16 + public function addRoute($httpMethod, $routeData, $handler) {
  17 + if ($this->isStaticRoute($routeData)) {
  18 + $this->addStaticRoute($httpMethod, $routeData, $handler);
  19 + } else {
  20 + $this->addVariableRoute($httpMethod, $routeData, $handler);
  21 + }
  22 + }
  23 +
  24 + public function getData() {
  25 + if (empty($this->methodToRegexToRoutesMap)) {
  26 + return [$this->staticRoutes, []];
  27 + }
  28 +
  29 + return [$this->staticRoutes, $this->generateVariableRouteData()];
  30 + }
  31 +
  32 + private function generateVariableRouteData() {
  33 + $data = [];
  34 + foreach ($this->methodToRegexToRoutesMap as $method => $regexToRoutesMap) {
  35 + $chunkSize = $this->computeChunkSize(count($regexToRoutesMap));
  36 + $chunks = array_chunk($regexToRoutesMap, $chunkSize, true);
  37 + $data[$method] = array_map([$this, 'processChunk'], $chunks);
  38 + }
  39 + return $data;
  40 + }
  41 +
  42 + private function computeChunkSize($count) {
  43 + $numParts = max(1, round($count / $this->getApproxChunkSize()));
  44 + return ceil($count / $numParts);
  45 + }
  46 +
  47 + private function isStaticRoute($routeData) {
  48 + return count($routeData) === 1 && is_string($routeData[0]);
  49 + }
  50 +
  51 + private function addStaticRoute($httpMethod, $routeData, $handler) {
  52 + $routeStr = $routeData[0];
  53 +
  54 + if (isset($this->staticRoutes[$httpMethod][$routeStr])) {
  55 + throw new BadRouteException(sprintf(
  56 + 'Cannot register two routes matching "%s" for method "%s"',
  57 + $routeStr, $httpMethod
  58 + ));
  59 + }
  60 +
  61 + if (isset($this->methodToRegexToRoutesMap[$httpMethod])) {
  62 + foreach ($this->methodToRegexToRoutesMap[$httpMethod] as $route) {
  63 + if ($route->matches($routeStr)) {
  64 + throw new BadRouteException(sprintf(
  65 + 'Static route "%s" is shadowed by previously defined variable route "%s" for method "%s"',
  66 + $routeStr, $route->regex, $httpMethod
  67 + ));
  68 + }
  69 + }
  70 + }
  71 +
  72 + $this->staticRoutes[$httpMethod][$routeStr] = $handler;
  73 + }
  74 +
  75 + private function addVariableRoute($httpMethod, $routeData, $handler) {
  76 + list($regex, $variables) = $this->buildRegexForRoute($routeData);
  77 +
  78 + if (isset($this->methodToRegexToRoutesMap[$httpMethod][$regex])) {
  79 + throw new BadRouteException(sprintf(
  80 + 'Cannot register two routes matching "%s" for method "%s"',
  81 + $regex, $httpMethod
  82 + ));
  83 + }
  84 +
  85 + $this->methodToRegexToRoutesMap[$httpMethod][$regex] = new Route(
  86 + $httpMethod, $handler, $regex, $variables
  87 + );
  88 + }
  89 +
  90 + private function buildRegexForRoute($routeData) {
  91 + $regex = '';
  92 + $variables = [];
  93 + foreach ($routeData as $part) {
  94 + if (is_string($part)) {
  95 + $regex .= preg_quote($part, '~');
  96 + continue;
  97 + }
  98 +
  99 + list($varName, $regexPart) = $part;
  100 +
  101 + if (isset($variables[$varName])) {
  102 + throw new BadRouteException(sprintf(
  103 + 'Cannot use the same placeholder "%s" twice', $varName
  104 + ));
  105 + }
  106 +
  107 + if ($this->regexHasCapturingGroups($regexPart)) {
  108 + throw new BadRouteException(sprintf(
  109 + 'Regex "%s" for parameter "%s" contains a capturing group',
  110 + $regexPart, $varName
  111 + ));
  112 + }
  113 +
  114 + $variables[$varName] = $varName;
  115 + $regex .= '(' . $regexPart . ')';
  116 + }
  117 +
  118 + return [$regex, $variables];
  119 + }
  120 +
  121 + private function regexHasCapturingGroups($regex) {
  122 + if (false === strpos($regex, '(')) {
  123 + // Needs to have at least a ( to contain a capturing group
  124 + return false;
  125 + }
  126 +
  127 + // Semi-accurate detection for capturing groups
  128 + return preg_match(
  129 + '~
  130 + (?:
  131 + \(\?\(
  132 + | \[ [^\]\\\\]* (?: \\\\ . [^\]\\\\]* )* \]
  133 + | \\\\ .
  134 + ) (*SKIP)(*FAIL) |
  135 + \(
  136 + (?!
  137 + \? (?! <(?![!=]) | P< | \' )
  138 + | \*
  139 + )
  140 + ~x',
  141 + $regex
  142 + );
  143 + }
  144 +}
... ...
vendor/nikic/fast-route/src/Dispatcher.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Dispatcher.php
... ... @@ -0,0 +1,25 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +interface Dispatcher {
  6 + const NOT_FOUND = 0;
  7 + const FOUND = 1;
  8 + const METHOD_NOT_ALLOWED = 2;
  9 +
  10 + /**
  11 + * Dispatches against the provided HTTP method verb and URI.
  12 + *
  13 + * Returns array with one of the following formats:
  14 + *
  15 + * [self::NOT_FOUND]
  16 + * [self::METHOD_NOT_ALLOWED, ['GET', 'OTHER_ALLOWED_METHODS']]
  17 + * [self::FOUND, $handler, ['varName' => 'value', ...]]
  18 + *
  19 + * @param string $httpMethod
  20 + * @param string $uri
  21 + *
  22 + * @return array
  23 + */
  24 + public function dispatch($httpMethod, $uri);
  25 +}
... ...
vendor/nikic/fast-route/src/Dispatcher/CharCountBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Dispatcher/CharCountBased.php
... ... @@ -0,0 +1,28 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class CharCountBased extends RegexBasedAbstract {
  6 + public function __construct($data) {
  7 + list($this->staticRouteMap, $this->variableRouteData) = $data;
  8 + }
  9 +
  10 + protected function dispatchVariableRoute($routeData, $uri) {
  11 + foreach ($routeData as $data) {
  12 + if (!preg_match($data['regex'], $uri . $data['suffix'], $matches)) {
  13 + continue;
  14 + }
  15 +
  16 + list($handler, $varNames) = $data['routeMap'][end($matches)];
  17 +
  18 + $vars = [];
  19 + $i = 0;
  20 + foreach ($varNames as $varName) {
  21 + $vars[$varName] = $matches[++$i];
  22 + }
  23 + return [self::FOUND, $handler, $vars];
  24 + }
  25 +
  26 + return [self::NOT_FOUND];
  27 + }
  28 +}
... ...
vendor/nikic/fast-route/src/Dispatcher/GroupCountBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Dispatcher/GroupCountBased.php
... ... @@ -0,0 +1,28 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class GroupCountBased extends RegexBasedAbstract {
  6 + public function __construct($data) {
  7 + list($this->staticRouteMap, $this->variableRouteData) = $data;
  8 + }
  9 +
  10 + protected function dispatchVariableRoute($routeData, $uri) {
  11 + foreach ($routeData as $data) {
  12 + if (!preg_match($data['regex'], $uri, $matches)) {
  13 + continue;
  14 + }
  15 +
  16 + list($handler, $varNames) = $data['routeMap'][count($matches)];
  17 +
  18 + $vars = [];
  19 + $i = 0;
  20 + foreach ($varNames as $varName) {
  21 + $vars[$varName] = $matches[++$i];
  22 + }
  23 + return [self::FOUND, $handler, $vars];
  24 + }
  25 +
  26 + return [self::NOT_FOUND];
  27 + }
  28 +}
... ...
vendor/nikic/fast-route/src/Dispatcher/GroupPosBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Dispatcher/GroupPosBased.php
... ... @@ -0,0 +1,30 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class GroupPosBased extends RegexBasedAbstract {
  6 + public function __construct($data) {
  7 + list($this->staticRouteMap, $this->variableRouteData) = $data;
  8 + }
  9 +
  10 + protected function dispatchVariableRoute($routeData, $uri) {
  11 + foreach ($routeData as $data) {
  12 + if (!preg_match($data['regex'], $uri, $matches)) {
  13 + continue;
  14 + }
  15 +
  16 + // find first non-empty match
  17 + for ($i = 1; '' === $matches[$i]; ++$i);
  18 +
  19 + list($handler, $varNames) = $data['routeMap'][$i];
  20 +
  21 + $vars = [];
  22 + foreach ($varNames as $varName) {
  23 + $vars[$varName] = $matches[$i++];
  24 + }
  25 + return [self::FOUND, $handler, $vars];
  26 + }
  27 +
  28 + return [self::NOT_FOUND];
  29 + }
  30 +}
... ...
vendor/nikic/fast-route/src/Dispatcher/MarkBased.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Dispatcher/MarkBased.php
... ... @@ -0,0 +1,28 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class MarkBased extends RegexBasedAbstract {
  6 + public function __construct($data) {
  7 + list($this->staticRouteMap, $this->variableRouteData) = $data;
  8 + }
  9 +
  10 + protected function dispatchVariableRoute($routeData, $uri) {
  11 + foreach ($routeData as $data) {
  12 + if (!preg_match($data['regex'], $uri, $matches)) {
  13 + continue;
  14 + }
  15 +
  16 + list($handler, $varNames) = $data['routeMap'][$matches['MARK']];
  17 +
  18 + $vars = [];
  19 + $i = 0;
  20 + foreach ($varNames as $varName) {
  21 + $vars[$varName] = $matches[++$i];
  22 + }
  23 + return [self::FOUND, $handler, $vars];
  24 + }
  25 +
  26 + return [self::NOT_FOUND];
  27 + }
  28 +}
... ...
vendor/nikic/fast-route/src/Dispatcher/RegexBasedAbstract.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Dispatcher/RegexBasedAbstract.php
... ... @@ -0,0 +1,80 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +use FastRoute\Dispatcher;
  6 +
  7 +abstract class RegexBasedAbstract implements Dispatcher {
  8 + protected $staticRouteMap;
  9 + protected $variableRouteData;
  10 +
  11 + protected abstract function dispatchVariableRoute($routeData, $uri);
  12 +
  13 + public function dispatch($httpMethod, $uri) {
  14 + if (isset($this->staticRouteMap[$httpMethod][$uri])) {
  15 + $handler = $this->staticRouteMap[$httpMethod][$uri];
  16 + return [self::FOUND, $handler, []];
  17 + }
  18 +
  19 + $varRouteData = $this->variableRouteData;
  20 + if (isset($varRouteData[$httpMethod])) {
  21 + $result = $this->dispatchVariableRoute($varRouteData[$httpMethod], $uri);
  22 + if ($result[0] === self::FOUND) {
  23 + return $result;
  24 + }
  25 + }
  26 +
  27 + // For HEAD requests, attempt fallback to GET
  28 + if ($httpMethod === 'HEAD') {
  29 + if (isset($this->staticRouteMap['GET'][$uri])) {
  30 + $handler = $this->staticRouteMap['GET'][$uri];
  31 + return [self::FOUND, $handler, []];
  32 + }
  33 + if (isset($varRouteData['GET'])) {
  34 + $result = $this->dispatchVariableRoute($varRouteData['GET'], $uri);
  35 + if ($result[0] === self::FOUND) {
  36 + return $result;
  37 + }
  38 + }
  39 + }
  40 +
  41 + // If nothing else matches, try fallback routes
  42 + if (isset($this->staticRouteMap['*'][$uri])) {
  43 + $handler = $this->staticRouteMap['*'][$uri];
  44 + return [self::FOUND, $handler, []];
  45 + }
  46 + if (isset($varRouteData['*'])) {
  47 + $result = $this->dispatchVariableRoute($varRouteData['*'], $uri);
  48 + if ($result[0] === self::FOUND) {
  49 + return $result;
  50 + }
  51 + }
  52 +
  53 + // Find allowed methods for this URI by matching against all other HTTP methods as well
  54 + $allowedMethods = [];
  55 +
  56 + foreach ($this->staticRouteMap as $method => $uriMap) {
  57 + if ($method !== $httpMethod && isset($uriMap[$uri])) {
  58 + $allowedMethods[] = $method;
  59 + }
  60 + }
  61 +
  62 + foreach ($varRouteData as $method => $routeData) {
  63 + if ($method === $httpMethod) {
  64 + continue;
  65 + }
  66 +
  67 + $result = $this->dispatchVariableRoute($routeData, $uri);
  68 + if ($result[0] === self::FOUND) {
  69 + $allowedMethods[] = $method;
  70 + }
  71 + }
  72 +
  73 + // If there are no allowed methods the route simply does not exist
  74 + if ($allowedMethods) {
  75 + return [self::METHOD_NOT_ALLOWED, $allowedMethods];
  76 + } else {
  77 + return [self::NOT_FOUND];
  78 + }
  79 + }
  80 +}
... ...
vendor/nikic/fast-route/src/Route.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/Route.php
... ... @@ -0,0 +1,38 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +class Route {
  6 + public $httpMethod;
  7 + public $regex;
  8 + public $variables;
  9 + public $handler;
  10 +
  11 + /**
  12 + * Constructs a route (value object).
  13 + *
  14 + * @param string $httpMethod
  15 + * @param mixed $handler
  16 + * @param string $regex
  17 + * @param array $variables
  18 + */
  19 + public function __construct($httpMethod, $handler, $regex, $variables) {
  20 + $this->httpMethod = $httpMethod;
  21 + $this->handler = $handler;
  22 + $this->regex = $regex;
  23 + $this->variables = $variables;
  24 + }
  25 +
  26 + /**
  27 + * Tests whether this route matches the given string.
  28 + *
  29 + * @param string $str
  30 + *
  31 + * @return bool
  32 + */
  33 + public function matches($str) {
  34 + $regex = '~^' . $this->regex . '$~';
  35 + return (bool) preg_match($regex, $str);
  36 + }
  37 +}
  38 +
... ...
vendor/nikic/fast-route/src/RouteCollector.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/RouteCollector.php
... ... @@ -0,0 +1,136 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +class RouteCollector {
  6 + protected $routeParser;
  7 + protected $dataGenerator;
  8 + protected $currentGroupPrefix;
  9 +
  10 + /**
  11 + * Constructs a route collector.
  12 + *
  13 + * @param RouteParser $routeParser
  14 + * @param DataGenerator $dataGenerator
  15 + */
  16 + public function __construct(RouteParser $routeParser, DataGenerator $dataGenerator) {
  17 + $this->routeParser = $routeParser;
  18 + $this->dataGenerator = $dataGenerator;
  19 + $this->currentGroupPrefix = '';
  20 + }
  21 +
  22 + /**
  23 + * Adds a route to the collection.
  24 + *
  25 + * The syntax used in the $route string depends on the used route parser.
  26 + *
  27 + * @param string|string[] $httpMethod
  28 + * @param string $route
  29 + * @param mixed $handler
  30 + */
  31 + public function addRoute($httpMethod, $route, $handler) {
  32 + $route = $this->currentGroupPrefix . $route;
  33 + $routeDatas = $this->routeParser->parse($route);
  34 + foreach ((array) $httpMethod as $method) {
  35 + foreach ($routeDatas as $routeData) {
  36 + $this->dataGenerator->addRoute($method, $routeData, $handler);
  37 + }
  38 + }
  39 + }
  40 +
  41 + /**
  42 + * Create a route group with a common prefix.
  43 + *
  44 + * All routes created in the passed callback will have the given group prefix prepended.
  45 + *
  46 + * @param string $prefix
  47 + * @param callable $callback
  48 + */
  49 + public function addGroup($prefix, callable $callback) {
  50 + $previousGroupPrefix = $this->currentGroupPrefix;
  51 + $this->currentGroupPrefix = $previousGroupPrefix . $prefix;
  52 + $callback($this);
  53 + $this->currentGroupPrefix = $previousGroupPrefix;
  54 + }
  55 +
  56 + /**
  57 + * Adds a GET route to the collection
  58 + *
  59 + * This is simply an alias of $this->addRoute('GET', $route, $handler)
  60 + *
  61 + * @param string $route
  62 + * @param mixed $handler
  63 + */
  64 + public function get($route, $handler) {
  65 + $this->addRoute('GET', $route, $handler);
  66 + }
  67 +
  68 + /**
  69 + * Adds a POST route to the collection
  70 + *
  71 + * This is simply an alias of $this->addRoute('POST', $route, $handler)
  72 + *
  73 + * @param string $route
  74 + * @param mixed $handler
  75 + */
  76 + public function post($route, $handler) {
  77 + $this->addRoute('POST', $route, $handler);
  78 + }
  79 +
  80 + /**
  81 + * Adds a PUT route to the collection
  82 + *
  83 + * This is simply an alias of $this->addRoute('PUT', $route, $handler)
  84 + *
  85 + * @param string $route
  86 + * @param mixed $handler
  87 + */
  88 + public function put($route, $handler) {
  89 + $this->addRoute('PUT', $route, $handler);
  90 + }
  91 +
  92 + /**
  93 + * Adds a DELETE route to the collection
  94 + *
  95 + * This is simply an alias of $this->addRoute('DELETE', $route, $handler)
  96 + *
  97 + * @param string $route
  98 + * @param mixed $handler
  99 + */
  100 + public function delete($route, $handler) {
  101 + $this->addRoute('DELETE', $route, $handler);
  102 + }
  103 +
  104 + /**
  105 + * Adds a PATCH route to the collection
  106 + *
  107 + * This is simply an alias of $this->addRoute('PATCH', $route, $handler)
  108 + *
  109 + * @param string $route
  110 + * @param mixed $handler
  111 + */
  112 + public function patch($route, $handler) {
  113 + $this->addRoute('PATCH', $route, $handler);
  114 + }
  115 +
  116 + /**
  117 + * Adds a HEAD route to the collection
  118 + *
  119 + * This is simply an alias of $this->addRoute('HEAD', $route, $handler)
  120 + *
  121 + * @param string $route
  122 + * @param mixed $handler
  123 + */
  124 + public function head($route, $handler) {
  125 + $this->addRoute('HEAD', $route, $handler);
  126 + }
  127 +
  128 + /**
  129 + * Returns the collected route data, as provided by the data generator.
  130 + *
  131 + * @return array
  132 + */
  133 + public function getData() {
  134 + return $this->dataGenerator->getData();
  135 + }
  136 +}
... ...
vendor/nikic/fast-route/src/RouteParser.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/RouteParser.php
... ... @@ -0,0 +1,36 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +interface RouteParser {
  6 + /**
  7 + * Parses a route string into multiple route data arrays.
  8 + *
  9 + * The expected output is defined using an example:
  10 + *
  11 + * For the route string "/fixedRoutePart/{varName}[/moreFixed/{varName2:\d+}]", if {varName} is interpreted as
  12 + * a placeholder and [...] is interpreted as an optional route part, the expected result is:
  13 + *
  14 + * [
  15 + * // first route: without optional part
  16 + * [
  17 + * "/fixedRoutePart/",
  18 + * ["varName", "[^/]+"],
  19 + * ],
  20 + * // second route: with optional part
  21 + * [
  22 + * "/fixedRoutePart/",
  23 + * ["varName", "[^/]+"],
  24 + * "/moreFixed/",
  25 + * ["varName2", [0-9]+"],
  26 + * ],
  27 + * ]
  28 + *
  29 + * Here one route string was converted into two route data arrays.
  30 + *
  31 + * @param string $route Route string to parse
  32 + *
  33 + * @return mixed[][] Array of route data arrays
  34 + */
  35 + public function parse($route);
  36 +}
... ...
vendor/nikic/fast-route/src/RouteParser/Std.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/RouteParser/Std.php
... ... @@ -0,0 +1,81 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\RouteParser;
  4 +
  5 +use FastRoute\BadRouteException;
  6 +use FastRoute\RouteParser;
  7 +
  8 +/**
  9 + * Parses route strings of the following form:
  10 + *
  11 + * "/user/{name}[/{id:[0-9]+}]"
  12 + */
  13 +class Std implements RouteParser {
  14 + const VARIABLE_REGEX = <<<'REGEX'
  15 +\{
  16 + \s* ([a-zA-Z_][a-zA-Z0-9_-]*) \s*
  17 + (?:
  18 + : \s* ([^{}]*(?:\{(?-1)\}[^{}]*)*)
  19 + )?
  20 +\}
  21 +REGEX;
  22 + const DEFAULT_DISPATCH_REGEX = '[^/]+';
  23 +
  24 + public function parse($route) {
  25 + $routeWithoutClosingOptionals = rtrim($route, ']');
  26 + $numOptionals = strlen($route) - strlen($routeWithoutClosingOptionals);
  27 +
  28 + // Split on [ while skipping placeholders
  29 + $segments = preg_split('~' . self::VARIABLE_REGEX . '(*SKIP)(*F) | \[~x', $routeWithoutClosingOptionals);
  30 + if ($numOptionals !== count($segments) - 1) {
  31 + // If there are any ] in the middle of the route, throw a more specific error message
  32 + if (preg_match('~' . self::VARIABLE_REGEX . '(*SKIP)(*F) | \]~x', $routeWithoutClosingOptionals)) {
  33 + throw new BadRouteException("Optional segments can only occur at the end of a route");
  34 + }
  35 + throw new BadRouteException("Number of opening '[' and closing ']' does not match");
  36 + }
  37 +
  38 + $currentRoute = '';
  39 + $routeDatas = [];
  40 + foreach ($segments as $n => $segment) {
  41 + if ($segment === '' && $n !== 0) {
  42 + throw new BadRouteException("Empty optional part");
  43 + }
  44 +
  45 + $currentRoute .= $segment;
  46 + $routeDatas[] = $this->parsePlaceholders($currentRoute);
  47 + }
  48 + return $routeDatas;
  49 + }
  50 +
  51 + /**
  52 + * Parses a route string that does not contain optional segments.
  53 + */
  54 + private function parsePlaceholders($route) {
  55 + if (!preg_match_all(
  56 + '~' . self::VARIABLE_REGEX . '~x', $route, $matches,
  57 + PREG_OFFSET_CAPTURE | PREG_SET_ORDER
  58 + )) {
  59 + return [$route];
  60 + }
  61 +
  62 + $offset = 0;
  63 + $routeData = [];
  64 + foreach ($matches as $set) {
  65 + if ($set[0][1] > $offset) {
  66 + $routeData[] = substr($route, $offset, $set[0][1] - $offset);
  67 + }
  68 + $routeData[] = [
  69 + $set[1][0],
  70 + isset($set[2]) ? trim($set[2][0]) : self::DEFAULT_DISPATCH_REGEX
  71 + ];
  72 + $offset = $set[0][1] + strlen($set[0][0]);
  73 + }
  74 +
  75 + if ($offset != strlen($route)) {
  76 + $routeData[] = substr($route, $offset);
  77 + }
  78 +
  79 + return $routeData;
  80 + }
  81 +}
... ...
vendor/nikic/fast-route/src/bootstrap.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/bootstrap.php
... ... @@ -0,0 +1,12 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +require __DIR__ . '/functions.php';
  6 +
  7 +spl_autoload_register(function($class) {
  8 + if (strpos($class, 'FastRoute\\') === 0) {
  9 + $name = substr($class, strlen('FastRoute'));
  10 + require __DIR__ . strtr($name, '\\', DIRECTORY_SEPARATOR) . '.php';
  11 + }
  12 +});
... ...
vendor/nikic/fast-route/src/functions.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/src/functions.php
... ... @@ -0,0 +1,72 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +if (!function_exists('FastRoute\simpleDispatcher')) {
  6 + /**
  7 + * @param callable $routeDefinitionCallback
  8 + * @param array $options
  9 + *
  10 + * @return Dispatcher
  11 + */
  12 + function simpleDispatcher(callable $routeDefinitionCallback, array $options = []) {
  13 + $options += [
  14 + 'routeParser' => 'FastRoute\\RouteParser\\Std',
  15 + 'dataGenerator' => 'FastRoute\\DataGenerator\\GroupCountBased',
  16 + 'dispatcher' => 'FastRoute\\Dispatcher\\GroupCountBased',
  17 + 'routeCollector' => 'FastRoute\\RouteCollector',
  18 + ];
  19 +
  20 + /** @var RouteCollector $routeCollector */
  21 + $routeCollector = new $options['routeCollector'](
  22 + new $options['routeParser'], new $options['dataGenerator']
  23 + );
  24 + $routeDefinitionCallback($routeCollector);
  25 +
  26 + return new $options['dispatcher']($routeCollector->getData());
  27 + }
  28 +
  29 + /**
  30 + * @param callable $routeDefinitionCallback
  31 + * @param array $options
  32 + *
  33 + * @return Dispatcher
  34 + */
  35 + function cachedDispatcher(callable $routeDefinitionCallback, array $options = []) {
  36 + $options += [
  37 + 'routeParser' => 'FastRoute\\RouteParser\\Std',
  38 + 'dataGenerator' => 'FastRoute\\DataGenerator\\GroupCountBased',
  39 + 'dispatcher' => 'FastRoute\\Dispatcher\\GroupCountBased',
  40 + 'routeCollector' => 'FastRoute\\RouteCollector',
  41 + 'cacheDisabled' => false,
  42 + ];
  43 +
  44 + if (!isset($options['cacheFile'])) {
  45 + throw new \LogicException('Must specify "cacheFile" option');
  46 + }
  47 +
  48 + if (!$options['cacheDisabled'] && file_exists($options['cacheFile'])) {
  49 + $dispatchData = require $options['cacheFile'];
  50 + if (!is_array($dispatchData)) {
  51 + throw new \RuntimeException('Invalid cache file "' . $options['cacheFile'] . '"');
  52 + }
  53 + return new $options['dispatcher']($dispatchData);
  54 + }
  55 +
  56 + $routeCollector = new $options['routeCollector'](
  57 + new $options['routeParser'], new $options['dataGenerator']
  58 + );
  59 + $routeDefinitionCallback($routeCollector);
  60 +
  61 + /** @var RouteCollector $routeCollector */
  62 + $dispatchData = $routeCollector->getData();
  63 + if (!$options['cacheDisabled']) {
  64 + file_put_contents(
  65 + $options['cacheFile'],
  66 + '<?php return ' . var_export($dispatchData, true) . ';'
  67 + );
  68 + }
  69 +
  70 + return new $options['dispatcher']($dispatchData);
  71 + }
  72 +}
... ...
vendor/nikic/fast-route/test/Dispatcher/CharCountBasedTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/Dispatcher/CharCountBasedTest.php
... ... @@ -0,0 +1,13 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class CharCountBasedTest extends DispatcherTest {
  6 + protected function getDispatcherClass() {
  7 + return 'FastRoute\\Dispatcher\\CharCountBased';
  8 + }
  9 +
  10 + protected function getDataGeneratorClass() {
  11 + return 'FastRoute\\DataGenerator\\CharCountBased';
  12 + }
  13 +}
... ...
vendor/nikic/fast-route/test/Dispatcher/DispatcherTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/Dispatcher/DispatcherTest.php
... ... @@ -0,0 +1,561 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +use FastRoute\RouteCollector;
  6 +
  7 +abstract class DispatcherTest extends \PHPUnit_Framework_TestCase {
  8 +
  9 + /**
  10 + * Delegate dispatcher selection to child test classes
  11 + */
  12 + abstract protected function getDispatcherClass();
  13 +
  14 + /**
  15 + * Delegate dataGenerator selection to child test classes
  16 + */
  17 + abstract protected function getDataGeneratorClass();
  18 +
  19 + /**
  20 + * Set appropriate options for the specific Dispatcher class we're testing
  21 + */
  22 + private function generateDispatcherOptions() {
  23 + return [
  24 + 'dataGenerator' => $this->getDataGeneratorClass(),
  25 + 'dispatcher' => $this->getDispatcherClass()
  26 + ];
  27 + }
  28 +
  29 + /**
  30 + * @dataProvider provideFoundDispatchCases
  31 + */
  32 + public function testFoundDispatches($method, $uri, $callback, $handler, $argDict) {
  33 + $dispatcher = \FastRoute\simpleDispatcher($callback, $this->generateDispatcherOptions());
  34 + $info = $dispatcher->dispatch($method, $uri);
  35 + $this->assertSame($dispatcher::FOUND, $info[0]);
  36 + $this->assertSame($handler, $info[1]);
  37 + $this->assertSame($argDict, $info[2]);
  38 + }
  39 +
  40 + /**
  41 + * @dataProvider provideNotFoundDispatchCases
  42 + */
  43 + public function testNotFoundDispatches($method, $uri, $callback) {
  44 + $dispatcher = \FastRoute\simpleDispatcher($callback, $this->generateDispatcherOptions());
  45 + $routeInfo = $dispatcher->dispatch($method, $uri);
  46 + $this->assertFalse(isset($routeInfo[1]),
  47 + "NOT_FOUND result must only contain a single element in the returned info array"
  48 + );
  49 + $this->assertSame($dispatcher::NOT_FOUND, $routeInfo[0]);
  50 + }
  51 +
  52 + /**
  53 + * @dataProvider provideMethodNotAllowedDispatchCases
  54 + */
  55 + public function testMethodNotAllowedDispatches($method, $uri, $callback, $availableMethods) {
  56 + $dispatcher = \FastRoute\simpleDispatcher($callback, $this->generateDispatcherOptions());
  57 + $routeInfo = $dispatcher->dispatch($method, $uri);
  58 + $this->assertTrue(isset($routeInfo[1]),
  59 + "METHOD_NOT_ALLOWED result must return an array of allowed methods at index 1"
  60 + );
  61 +
  62 + list($routedStatus, $methodArray) = $dispatcher->dispatch($method, $uri);
  63 + $this->assertSame($dispatcher::METHOD_NOT_ALLOWED, $routedStatus);
  64 + $this->assertSame($availableMethods, $methodArray);
  65 + }
  66 +
  67 + /**
  68 + * @expectedException \FastRoute\BadRouteException
  69 + * @expectedExceptionMessage Cannot use the same placeholder "test" twice
  70 + */
  71 + public function testDuplicateVariableNameError() {
  72 + \FastRoute\simpleDispatcher(function(RouteCollector $r) {
  73 + $r->addRoute('GET', '/foo/{test}/{test:\d+}', 'handler0');
  74 + }, $this->generateDispatcherOptions());
  75 + }
  76 +
  77 + /**
  78 + * @expectedException \FastRoute\BadRouteException
  79 + * @expectedExceptionMessage Cannot register two routes matching "/user/([^/]+)" for method "GET"
  80 + */
  81 + public function testDuplicateVariableRoute() {
  82 + \FastRoute\simpleDispatcher(function(RouteCollector $r) {
  83 + $r->addRoute('GET', '/user/{id}', 'handler0'); // oops, forgot \d+ restriction ;)
  84 + $r->addRoute('GET', '/user/{name}', 'handler1');
  85 + }, $this->generateDispatcherOptions());
  86 + }
  87 +
  88 + /**
  89 + * @expectedException \FastRoute\BadRouteException
  90 + * @expectedExceptionMessage Cannot register two routes matching "/user" for method "GET"
  91 + */
  92 + public function testDuplicateStaticRoute() {
  93 + \FastRoute\simpleDispatcher(function(RouteCollector $r) {
  94 + $r->addRoute('GET', '/user', 'handler0');
  95 + $r->addRoute('GET', '/user', 'handler1');
  96 + }, $this->generateDispatcherOptions());
  97 + }
  98 +
  99 + /**
  100 + * @expectedException \FastRoute\BadRouteException
  101 + * @expectedExceptionMessage Static route "/user/nikic" is shadowed by previously defined variable route "/user/([^/]+)" for method "GET"
  102 + */
  103 + public function testShadowedStaticRoute() {
  104 + \FastRoute\simpleDispatcher(function(RouteCollector $r) {
  105 + $r->addRoute('GET', '/user/{name}', 'handler0');
  106 + $r->addRoute('GET', '/user/nikic', 'handler1');
  107 + }, $this->generateDispatcherOptions());
  108 + }
  109 +
  110 + /**
  111 + * @expectedException \FastRoute\BadRouteException
  112 + * @expectedExceptionMessage Regex "(en|de)" for parameter "lang" contains a capturing group
  113 + */
  114 + public function testCapturing() {
  115 + \FastRoute\simpleDispatcher(function(RouteCollector $r) {
  116 + $r->addRoute('GET', '/{lang:(en|de)}', 'handler0');
  117 + }, $this->generateDispatcherOptions());
  118 + }
  119 +
  120 + public function provideFoundDispatchCases() {
  121 + $cases = [];
  122 +
  123 + // 0 -------------------------------------------------------------------------------------->
  124 +
  125 + $callback = function(RouteCollector $r) {
  126 + $r->addRoute('GET', '/resource/123/456', 'handler0');
  127 + };
  128 +
  129 + $method = 'GET';
  130 + $uri = '/resource/123/456';
  131 + $handler = 'handler0';
  132 + $argDict = [];
  133 +
  134 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  135 +
  136 + // 1 -------------------------------------------------------------------------------------->
  137 +
  138 + $callback = function(RouteCollector $r) {
  139 + $r->addRoute('GET', '/handler0', 'handler0');
  140 + $r->addRoute('GET', '/handler1', 'handler1');
  141 + $r->addRoute('GET', '/handler2', 'handler2');
  142 + };
  143 +
  144 + $method = 'GET';
  145 + $uri = '/handler2';
  146 + $handler = 'handler2';
  147 + $argDict = [];
  148 +
  149 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  150 +
  151 + // 2 -------------------------------------------------------------------------------------->
  152 +
  153 + $callback = function(RouteCollector $r) {
  154 + $r->addRoute('GET', '/user/{name}/{id:[0-9]+}', 'handler0');
  155 + $r->addRoute('GET', '/user/{id:[0-9]+}', 'handler1');
  156 + $r->addRoute('GET', '/user/{name}', 'handler2');
  157 + };
  158 +
  159 + $method = 'GET';
  160 + $uri = '/user/rdlowrey';
  161 + $handler = 'handler2';
  162 + $argDict = ['name' => 'rdlowrey'];
  163 +
  164 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  165 +
  166 + // 3 -------------------------------------------------------------------------------------->
  167 +
  168 + // reuse $callback from #2
  169 +
  170 + $method = 'GET';
  171 + $uri = '/user/12345';
  172 + $handler = 'handler1';
  173 + $argDict = ['id' => '12345'];
  174 +
  175 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  176 +
  177 + // 4 -------------------------------------------------------------------------------------->
  178 +
  179 + // reuse $callback from #3
  180 +
  181 + $method = 'GET';
  182 + $uri = '/user/NaN';
  183 + $handler = 'handler2';
  184 + $argDict = ['name' => 'NaN'];
  185 +
  186 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  187 +
  188 + // 5 -------------------------------------------------------------------------------------->
  189 +
  190 + // reuse $callback from #4
  191 +
  192 + $method = 'GET';
  193 + $uri = '/user/rdlowrey/12345';
  194 + $handler = 'handler0';
  195 + $argDict = ['name' => 'rdlowrey', 'id' => '12345'];
  196 +
  197 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  198 +
  199 + // 6 -------------------------------------------------------------------------------------->
  200 +
  201 + $callback = function(RouteCollector $r) {
  202 + $r->addRoute('GET', '/user/{id:[0-9]+}', 'handler0');
  203 + $r->addRoute('GET', '/user/12345/extension', 'handler1');
  204 + $r->addRoute('GET', '/user/{id:[0-9]+}.{extension}', 'handler2');
  205 +
  206 + };
  207 +
  208 + $method = 'GET';
  209 + $uri = '/user/12345.svg';
  210 + $handler = 'handler2';
  211 + $argDict = ['id' => '12345', 'extension' => 'svg'];
  212 +
  213 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  214 +
  215 + // 7 ----- Test GET method fallback on HEAD route miss ------------------------------------>
  216 +
  217 + $callback = function(RouteCollector $r) {
  218 + $r->addRoute('GET', '/user/{name}', 'handler0');
  219 + $r->addRoute('GET', '/user/{name}/{id:[0-9]+}', 'handler1');
  220 + $r->addRoute('GET', '/static0', 'handler2');
  221 + $r->addRoute('GET', '/static1', 'handler3');
  222 + $r->addRoute('HEAD', '/static1', 'handler4');
  223 + };
  224 +
  225 + $method = 'HEAD';
  226 + $uri = '/user/rdlowrey';
  227 + $handler = 'handler0';
  228 + $argDict = ['name' => 'rdlowrey'];
  229 +
  230 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  231 +
  232 + // 8 ----- Test GET method fallback on HEAD route miss ------------------------------------>
  233 +
  234 + // reuse $callback from #7
  235 +
  236 + $method = 'HEAD';
  237 + $uri = '/user/rdlowrey/1234';
  238 + $handler = 'handler1';
  239 + $argDict = ['name' => 'rdlowrey', 'id' => '1234'];
  240 +
  241 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  242 +
  243 + // 9 ----- Test GET method fallback on HEAD route miss ------------------------------------>
  244 +
  245 + // reuse $callback from #8
  246 +
  247 + $method = 'HEAD';
  248 + $uri = '/static0';
  249 + $handler = 'handler2';
  250 + $argDict = [];
  251 +
  252 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  253 +
  254 + // 10 ---- Test existing HEAD route used if available (no fallback) ----------------------->
  255 +
  256 + // reuse $callback from #9
  257 +
  258 + $method = 'HEAD';
  259 + $uri = '/static1';
  260 + $handler = 'handler4';
  261 + $argDict = [];
  262 +
  263 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  264 +
  265 + // 11 ---- More specified routes are not shadowed by less specific of another method ------>
  266 +
  267 + $callback = function(RouteCollector $r) {
  268 + $r->addRoute('GET', '/user/{name}', 'handler0');
  269 + $r->addRoute('POST', '/user/{name:[a-z]+}', 'handler1');
  270 + };
  271 +
  272 + $method = 'POST';
  273 + $uri = '/user/rdlowrey';
  274 + $handler = 'handler1';
  275 + $argDict = ['name' => 'rdlowrey'];
  276 +
  277 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  278 +
  279 + // 12 ---- Handler of more specific routes is used, if it occurs first -------------------->
  280 +
  281 + $callback = function(RouteCollector $r) {
  282 + $r->addRoute('GET', '/user/{name}', 'handler0');
  283 + $r->addRoute('POST', '/user/{name:[a-z]+}', 'handler1');
  284 + $r->addRoute('POST', '/user/{name}', 'handler2');
  285 + };
  286 +
  287 + $method = 'POST';
  288 + $uri = '/user/rdlowrey';
  289 + $handler = 'handler1';
  290 + $argDict = ['name' => 'rdlowrey'];
  291 +
  292 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  293 +
  294 + // 13 ---- Route with constant suffix ----------------------------------------------------->
  295 +
  296 + $callback = function(RouteCollector $r) {
  297 + $r->addRoute('GET', '/user/{name}', 'handler0');
  298 + $r->addRoute('GET', '/user/{name}/edit', 'handler1');
  299 + };
  300 +
  301 + $method = 'GET';
  302 + $uri = '/user/rdlowrey/edit';
  303 + $handler = 'handler1';
  304 + $argDict = ['name' => 'rdlowrey'];
  305 +
  306 + $cases[] = [$method, $uri, $callback, $handler, $argDict];
  307 +
  308 + // 14 ---- Handle multiple methods with the same handler ---------------------------------->
  309 +
  310 + $callback = function(RouteCollector $r) {
  311 + $r->addRoute(['GET', 'POST'], '/user', 'handlerGetPost');
  312 + $r->addRoute(['DELETE'], '/user', 'handlerDelete');
  313 + $r->addRoute([], '/user', 'handlerNone');
  314 + };
  315 +
  316 + $argDict = [];
  317 + $cases[] = ['GET', '/user', $callback, 'handlerGetPost', $argDict];
  318 + $cases[] = ['POST', '/user', $callback, 'handlerGetPost', $argDict];
  319 + $cases[] = ['DELETE', '/user', $callback, 'handlerDelete', $argDict];
  320 +
  321 + // 15 ----
  322 +
  323 + $callback = function(RouteCollector $r) {
  324 + $r->addRoute('POST', '/user.json', 'handler0');
  325 + $r->addRoute('GET', '/{entity}.json', 'handler1');
  326 + };
  327 +
  328 + $cases[] = ['GET', '/user.json', $callback, 'handler1', ['entity' => 'user']];
  329 +
  330 + // 16 ----
  331 +
  332 + $callback = function(RouteCollector $r) {
  333 + $r->addRoute('GET', '', 'handler0');
  334 + };
  335 +
  336 + $cases[] = ['GET', '', $callback, 'handler0', []];
  337 +
  338 + // 17 ----
  339 +
  340 + $callback = function(RouteCollector $r) {
  341 + $r->addRoute('HEAD', '/a/{foo}', 'handler0');
  342 + $r->addRoute('GET', '/b/{foo}', 'handler1');
  343 + };
  344 +
  345 + $cases[] = ['HEAD', '/b/bar', $callback, 'handler1', ['foo' => 'bar']];
  346 +
  347 + // 18 ----
  348 +
  349 + $callback = function(RouteCollector $r) {
  350 + $r->addRoute('HEAD', '/a', 'handler0');
  351 + $r->addRoute('GET', '/b', 'handler1');
  352 + };
  353 +
  354 + $cases[] = ['HEAD', '/b', $callback, 'handler1', []];
  355 +
  356 + // 19 ----
  357 +
  358 + $callback = function(RouteCollector $r) {
  359 + $r->addRoute('GET', '/foo', 'handler0');
  360 + $r->addRoute('HEAD', '/{bar}', 'handler1');
  361 + };
  362 +
  363 + $cases[] = ['HEAD', '/foo', $callback, 'handler1', ['bar' => 'foo']];
  364 +
  365 + // 20 ----
  366 +
  367 + $callback = function(RouteCollector $r) {
  368 + $r->addRoute('*', '/user', 'handler0');
  369 + $r->addRoute('*', '/{user}', 'handler1');
  370 + $r->addRoute('GET', '/user', 'handler2');
  371 + };
  372 +
  373 + $cases[] = ['GET', '/user', $callback, 'handler2', []];
  374 +
  375 + // 21 ----
  376 +
  377 + $callback = function(RouteCollector $r) {
  378 + $r->addRoute('*', '/user', 'handler0');
  379 + $r->addRoute('GET', '/user', 'handler1');
  380 + };
  381 +
  382 + $cases[] = ['POST', '/user', $callback, 'handler0', []];
  383 +
  384 + // 22 ----
  385 +
  386 + $cases[] = ['HEAD', '/user', $callback, 'handler1', []];
  387 +
  388 + // 23 ----
  389 +
  390 + $callback = function(RouteCollector $r) {
  391 + $r->addRoute('GET', '/{bar}', 'handler0');
  392 + $r->addRoute('*', '/foo', 'handler1');
  393 + };
  394 +
  395 + $cases[] = ['GET', '/foo', $callback, 'handler0', ['bar' => 'foo']];
  396 +
  397 + // x -------------------------------------------------------------------------------------->
  398 +
  399 + return $cases;
  400 + }
  401 +
  402 + public function provideNotFoundDispatchCases() {
  403 + $cases = [];
  404 +
  405 + // 0 -------------------------------------------------------------------------------------->
  406 +
  407 + $callback = function(RouteCollector $r) {
  408 + $r->addRoute('GET', '/resource/123/456', 'handler0');
  409 + };
  410 +
  411 + $method = 'GET';
  412 + $uri = '/not-found';
  413 +
  414 + $cases[] = [$method, $uri, $callback];
  415 +
  416 + // 1 -------------------------------------------------------------------------------------->
  417 +
  418 + // reuse callback from #0
  419 + $method = 'POST';
  420 + $uri = '/not-found';
  421 +
  422 + $cases[] = [$method, $uri, $callback];
  423 +
  424 + // 2 -------------------------------------------------------------------------------------->
  425 +
  426 + // reuse callback from #1
  427 + $method = 'PUT';
  428 + $uri = '/not-found';
  429 +
  430 + $cases[] = [$method, $uri, $callback];
  431 +
  432 + // 3 -------------------------------------------------------------------------------------->
  433 +
  434 + $callback = function(RouteCollector $r) {
  435 + $r->addRoute('GET', '/handler0', 'handler0');
  436 + $r->addRoute('GET', '/handler1', 'handler1');
  437 + $r->addRoute('GET', '/handler2', 'handler2');
  438 + };
  439 +
  440 + $method = 'GET';
  441 + $uri = '/not-found';
  442 +
  443 + $cases[] = [$method, $uri, $callback];
  444 +
  445 + // 4 -------------------------------------------------------------------------------------->
  446 +
  447 + $callback = function(RouteCollector $r) {
  448 + $r->addRoute('GET', '/user/{name}/{id:[0-9]+}', 'handler0');
  449 + $r->addRoute('GET', '/user/{id:[0-9]+}', 'handler1');
  450 + $r->addRoute('GET', '/user/{name}', 'handler2');
  451 + };
  452 +
  453 + $method = 'GET';
  454 + $uri = '/not-found';
  455 +
  456 + $cases[] = [$method, $uri, $callback];
  457 +
  458 + // 5 -------------------------------------------------------------------------------------->
  459 +
  460 + // reuse callback from #4
  461 + $method = 'GET';
  462 + $uri = '/user/rdlowrey/12345/not-found';
  463 +
  464 + $cases[] = [$method, $uri, $callback];
  465 +
  466 + // 6 -------------------------------------------------------------------------------------->
  467 +
  468 + // reuse callback from #5
  469 + $method = 'HEAD';
  470 +
  471 + $cases[] = array($method, $uri, $callback);
  472 +
  473 + // x -------------------------------------------------------------------------------------->
  474 +
  475 + return $cases;
  476 + }
  477 +
  478 + public function provideMethodNotAllowedDispatchCases() {
  479 + $cases = [];
  480 +
  481 + // 0 -------------------------------------------------------------------------------------->
  482 +
  483 + $callback = function(RouteCollector $r) {
  484 + $r->addRoute('GET', '/resource/123/456', 'handler0');
  485 + };
  486 +
  487 + $method = 'POST';
  488 + $uri = '/resource/123/456';
  489 + $allowedMethods = ['GET'];
  490 +
  491 + $cases[] = [$method, $uri, $callback, $allowedMethods];
  492 +
  493 + // 1 -------------------------------------------------------------------------------------->
  494 +
  495 + $callback = function(RouteCollector $r) {
  496 + $r->addRoute('GET', '/resource/123/456', 'handler0');
  497 + $r->addRoute('POST', '/resource/123/456', 'handler1');
  498 + $r->addRoute('PUT', '/resource/123/456', 'handler2');
  499 + $r->addRoute('*', '/', 'handler3');
  500 + };
  501 +
  502 + $method = 'DELETE';
  503 + $uri = '/resource/123/456';
  504 + $allowedMethods = ['GET', 'POST', 'PUT'];
  505 +
  506 + $cases[] = [$method, $uri, $callback, $allowedMethods];
  507 +
  508 + // 2 -------------------------------------------------------------------------------------->
  509 +
  510 + $callback = function(RouteCollector $r) {
  511 + $r->addRoute('GET', '/user/{name}/{id:[0-9]+}', 'handler0');
  512 + $r->addRoute('POST', '/user/{name}/{id:[0-9]+}', 'handler1');
  513 + $r->addRoute('PUT', '/user/{name}/{id:[0-9]+}', 'handler2');
  514 + $r->addRoute('PATCH', '/user/{name}/{id:[0-9]+}', 'handler3');
  515 + };
  516 +
  517 + $method = 'DELETE';
  518 + $uri = '/user/rdlowrey/42';
  519 + $allowedMethods = ['GET', 'POST', 'PUT', 'PATCH'];
  520 +
  521 + $cases[] = [$method, $uri, $callback, $allowedMethods];
  522 +
  523 + // 3 -------------------------------------------------------------------------------------->
  524 +
  525 + $callback = function(RouteCollector $r) {
  526 + $r->addRoute('POST', '/user/{name}', 'handler1');
  527 + $r->addRoute('PUT', '/user/{name:[a-z]+}', 'handler2');
  528 + $r->addRoute('PATCH', '/user/{name:[a-z]+}', 'handler3');
  529 + };
  530 +
  531 + $method = 'GET';
  532 + $uri = '/user/rdlowrey';
  533 + $allowedMethods = ['POST', 'PUT', 'PATCH'];
  534 +
  535 + $cases[] = [$method, $uri, $callback, $allowedMethods];
  536 +
  537 + // 4 -------------------------------------------------------------------------------------->
  538 +
  539 + $callback = function(RouteCollector $r) {
  540 + $r->addRoute(['GET', 'POST'], '/user', 'handlerGetPost');
  541 + $r->addRoute(['DELETE'], '/user', 'handlerDelete');
  542 + $r->addRoute([], '/user', 'handlerNone');
  543 + };
  544 +
  545 + $cases[] = ['PUT', '/user', $callback, ['GET', 'POST', 'DELETE']];
  546 +
  547 + // 5
  548 +
  549 + $callback = function(RouteCollector $r) {
  550 + $r->addRoute('POST', '/user.json', 'handler0');
  551 + $r->addRoute('GET', '/{entity}.json', 'handler1');
  552 + };
  553 +
  554 + $cases[] = ['PUT', '/user.json', $callback, ['POST', 'GET']];
  555 +
  556 + // x -------------------------------------------------------------------------------------->
  557 +
  558 + return $cases;
  559 + }
  560 +
  561 +}
... ...
vendor/nikic/fast-route/test/Dispatcher/GroupCountBasedTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/Dispatcher/GroupCountBasedTest.php
... ... @@ -0,0 +1,13 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class GroupCountBasedTest extends DispatcherTest {
  6 + protected function getDispatcherClass() {
  7 + return 'FastRoute\\Dispatcher\\GroupCountBased';
  8 + }
  9 +
  10 + protected function getDataGeneratorClass() {
  11 + return 'FastRoute\\DataGenerator\\GroupCountBased';
  12 + }
  13 +}
... ...
vendor/nikic/fast-route/test/Dispatcher/GroupPosBasedTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/Dispatcher/GroupPosBasedTest.php
... ... @@ -0,0 +1,13 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class GroupPosBasedTest extends DispatcherTest {
  6 + protected function getDispatcherClass() {
  7 + return 'FastRoute\\Dispatcher\\GroupPosBased';
  8 + }
  9 +
  10 + protected function getDataGeneratorClass() {
  11 + return 'FastRoute\\DataGenerator\\GroupPosBased';
  12 + }
  13 +}
... ...
vendor/nikic/fast-route/test/Dispatcher/MarkBasedTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/Dispatcher/MarkBasedTest.php
... ... @@ -0,0 +1,20 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\Dispatcher;
  4 +
  5 +class MarkBasedTest extends DispatcherTest {
  6 + public function setUp() {
  7 + preg_match('/(*MARK:A)a/', 'a', $matches);
  8 + if (!isset($matches['MARK'])) {
  9 + $this->markTestSkipped('PHP 5.6 required for MARK support');
  10 + }
  11 + }
  12 +
  13 + protected function getDispatcherClass() {
  14 + return 'FastRoute\\Dispatcher\\MarkBased';
  15 + }
  16 +
  17 + protected function getDataGeneratorClass() {
  18 + return 'FastRoute\\DataGenerator\\MarkBased';
  19 + }
  20 +}
... ...
vendor/nikic/fast-route/test/HackTypechecker/HackTypecheckerTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/HackTypechecker/HackTypecheckerTest.php
... ... @@ -0,0 +1,39 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +class HackTypecheckerTest extends \PhpUnit_Framework_TestCase {
  6 + const SERVER_ALREADY_RUNNING_CODE = 77;
  7 + public function testTypechecks($recurse = true) {
  8 + if (!defined('HHVM_VERSION')) {
  9 + $this->markTestSkipped("HHVM only");
  10 + }
  11 + if (!version_compare(HHVM_VERSION, '3.9.0', '>=')) {
  12 + $this->markTestSkipped('classname<T> requires HHVM 3.9+');
  13 + }
  14 +
  15 + // The typechecker recurses the whole tree, so it makes sure
  16 + // that everything in fixtures/ is valid when this runs.
  17 +
  18 + $output = array();
  19 + $exit_code = null;
  20 + exec(
  21 + 'hh_server --check '.escapeshellarg(__DIR__.'/../../').' 2>&1',
  22 + $output,
  23 + $exit_code
  24 + );
  25 + if ($exit_code === self::SERVER_ALREADY_RUNNING_CODE) {
  26 + $this->assertTrue(
  27 + $recurse,
  28 + "Typechecker still running after running hh_client stop"
  29 + );
  30 + // Server already running - 3.10 => 3.11 regression:
  31 + // https://github.com/facebook/hhvm/issues/6646
  32 + exec('hh_client stop 2>/dev/null');
  33 + $this->testTypechecks(/* recurse = */ false);
  34 + return;
  35 +
  36 + }
  37 + $this->assertSame(0, $exit_code, implode("\n", $output));
  38 + }
  39 +}
... ...
vendor/nikic/fast-route/test/HackTypechecker/fixtures/all_options.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/HackTypechecker/fixtures/all_options.php
... ... @@ -0,0 +1,29 @@
  1 +<?hh
  2 +
  3 +namespace FastRoute\TestFixtures;
  4 +
  5 +function all_options_simple(): \FastRoute\Dispatcher {
  6 + return \FastRoute\simpleDispatcher(
  7 + $collector ==> {},
  8 + shape(
  9 + 'routeParser' => \FastRoute\RouteParser\Std::class,
  10 + 'dataGenerator' => \FastRoute\DataGenerator\GroupCountBased::class,
  11 + 'dispatcher' => \FastRoute\Dispatcher\GroupCountBased::class,
  12 + 'routeCollector' => \FastRoute\RouteCollector::class,
  13 + ),
  14 + );
  15 +}
  16 +
  17 +function all_options_cached(): \FastRoute\Dispatcher {
  18 + return \FastRoute\cachedDispatcher(
  19 + $collector ==> {},
  20 + shape(
  21 + 'routeParser' => \FastRoute\RouteParser\Std::class,
  22 + 'dataGenerator' => \FastRoute\DataGenerator\GroupCountBased::class,
  23 + 'dispatcher' => \FastRoute\Dispatcher\GroupCountBased::class,
  24 + 'routeCollector' => \FastRoute\RouteCollector::class,
  25 + 'cacheFile' => '/dev/null',
  26 + 'cacheDisabled' => false,
  27 + ),
  28 + );
  29 +}
... ...
vendor/nikic/fast-route/test/HackTypechecker/fixtures/empty_options.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/HackTypechecker/fixtures/empty_options.php
... ... @@ -0,0 +1,11 @@
  1 +<?hh
  2 +
  3 +namespace FastRoute\TestFixtures;
  4 +
  5 +function empty_options_simple(): \FastRoute\Dispatcher {
  6 + return \FastRoute\simpleDispatcher($collector ==> {}, shape());
  7 +}
  8 +
  9 +function empty_options_cached(): \FastRoute\Dispatcher {
  10 + return \FastRoute\cachedDispatcher($collector ==> {}, shape());
  11 +}
... ...
vendor/nikic/fast-route/test/HackTypechecker/fixtures/no_options.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/HackTypechecker/fixtures/no_options.php
... ... @@ -0,0 +1,11 @@
  1 +<?hh
  2 +
  3 +namespace FastRoute\TestFixtures;
  4 +
  5 +function no_options_simple(): \FastRoute\Dispatcher {
  6 + return \FastRoute\simpleDispatcher($collector ==> {});
  7 +}
  8 +
  9 +function no_options_cached(): \FastRoute\Dispatcher {
  10 + return \FastRoute\cachedDispatcher($collector ==> {});
  11 +}
... ...
vendor/nikic/fast-route/test/RouteCollectorTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/RouteCollectorTest.php
... ... @@ -0,0 +1,97 @@
  1 +<?php
  2 +
  3 +namespace FastRoute;
  4 +
  5 +class RouteCollectorTest extends \PHPUnit_Framework_TestCase {
  6 + public function testShortcuts() {
  7 + $r = new DummyRouteCollector();
  8 +
  9 + $r->delete('/delete', 'delete');
  10 + $r->get('/get', 'get');
  11 + $r->head('/head', 'head');
  12 + $r->patch('/patch', 'patch');
  13 + $r->post('/post', 'post');
  14 + $r->put('/put', 'put');
  15 +
  16 + $expected = [
  17 + ['DELETE', '/delete', 'delete'],
  18 + ['GET', '/get', 'get'],
  19 + ['HEAD', '/head', 'head'],
  20 + ['PATCH', '/patch', 'patch'],
  21 + ['POST', '/post', 'post'],
  22 + ['PUT', '/put', 'put'],
  23 + ];
  24 +
  25 + $this->assertSame($expected, $r->routes);
  26 + }
  27 +
  28 + public function testGroups() {
  29 + $r = new DummyRouteCollector();
  30 +
  31 + $r->delete('/delete', 'delete');
  32 + $r->get('/get', 'get');
  33 + $r->head('/head', 'head');
  34 + $r->patch('/patch', 'patch');
  35 + $r->post('/post', 'post');
  36 + $r->put('/put', 'put');
  37 +
  38 + $r->addGroup('/group-one', function (DummyRouteCollector $r) {
  39 + $r->delete('/delete', 'delete');
  40 + $r->get('/get', 'get');
  41 + $r->head('/head', 'head');
  42 + $r->patch('/patch', 'patch');
  43 + $r->post('/post', 'post');
  44 + $r->put('/put', 'put');
  45 +
  46 + $r->addGroup('/group-two', function (DummyRouteCollector $r) {
  47 + $r->delete('/delete', 'delete');
  48 + $r->get('/get', 'get');
  49 + $r->head('/head', 'head');
  50 + $r->patch('/patch', 'patch');
  51 + $r->post('/post', 'post');
  52 + $r->put('/put', 'put');
  53 + });
  54 + });
  55 +
  56 + $r->addGroup('/admin', function (DummyRouteCollector $r) {
  57 + $r->get('-some-info', 'admin-some-info');
  58 + });
  59 + $r->addGroup('/admin-', function (DummyRouteCollector $r) {
  60 + $r->get('more-info', 'admin-more-info');
  61 + });
  62 +
  63 + $expected = [
  64 + ['DELETE', '/delete', 'delete'],
  65 + ['GET', '/get', 'get'],
  66 + ['HEAD', '/head', 'head'],
  67 + ['PATCH', '/patch', 'patch'],
  68 + ['POST', '/post', 'post'],
  69 + ['PUT', '/put', 'put'],
  70 + ['DELETE', '/group-one/delete', 'delete'],
  71 + ['GET', '/group-one/get', 'get'],
  72 + ['HEAD', '/group-one/head', 'head'],
  73 + ['PATCH', '/group-one/patch', 'patch'],
  74 + ['POST', '/group-one/post', 'post'],
  75 + ['PUT', '/group-one/put', 'put'],
  76 + ['DELETE', '/group-one/group-two/delete', 'delete'],
  77 + ['GET', '/group-one/group-two/get', 'get'],
  78 + ['HEAD', '/group-one/group-two/head', 'head'],
  79 + ['PATCH', '/group-one/group-two/patch', 'patch'],
  80 + ['POST', '/group-one/group-two/post', 'post'],
  81 + ['PUT', '/group-one/group-two/put', 'put'],
  82 + ['GET', '/admin-some-info', 'admin-some-info'],
  83 + ['GET', '/admin-more-info', 'admin-more-info'],
  84 + ];
  85 +
  86 + $this->assertSame($expected, $r->routes);
  87 + }
  88 +}
  89 +
  90 +class DummyRouteCollector extends RouteCollector {
  91 + public $routes = [];
  92 + public function __construct() {}
  93 + public function addRoute($method, $route, $handler) {
  94 + $route = $this->currentGroupPrefix . $route;
  95 + $this->routes[] = [$method, $route, $handler];
  96 + }
  97 +}
0 98 \ No newline at end of file
... ...
vendor/nikic/fast-route/test/RouteParser/StdTest.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/RouteParser/StdTest.php
... ... @@ -0,0 +1,147 @@
  1 +<?php
  2 +
  3 +namespace FastRoute\RouteParser;
  4 +
  5 +class StdTest extends \PhpUnit_Framework_TestCase {
  6 + /** @dataProvider provideTestParse */
  7 + public function testParse($routeString, $expectedRouteDatas) {
  8 + $parser = new Std();
  9 + $routeDatas = $parser->parse($routeString);
  10 + $this->assertSame($expectedRouteDatas, $routeDatas);
  11 + }
  12 +
  13 + /** @dataProvider provideTestParseError */
  14 + public function testParseError($routeString, $expectedExceptionMessage) {
  15 + $parser = new Std();
  16 + $this->setExpectedException('FastRoute\\BadRouteException', $expectedExceptionMessage);
  17 + $parser->parse($routeString);
  18 + }
  19 +
  20 + public function provideTestParse() {
  21 + return [
  22 + [
  23 + '/test',
  24 + [
  25 + ['/test'],
  26 + ]
  27 + ],
  28 + [
  29 + '/test/{param}',
  30 + [
  31 + ['/test/', ['param', '[^/]+']],
  32 + ]
  33 + ],
  34 + [
  35 + '/te{ param }st',
  36 + [
  37 + ['/te', ['param', '[^/]+'], 'st']
  38 + ]
  39 + ],
  40 + [
  41 + '/test/{param1}/test2/{param2}',
  42 + [
  43 + ['/test/', ['param1', '[^/]+'], '/test2/', ['param2', '[^/]+']]
  44 + ]
  45 + ],
  46 + [
  47 + '/test/{param:\d+}',
  48 + [
  49 + ['/test/', ['param', '\d+']]
  50 + ]
  51 + ],
  52 + [
  53 + '/test/{ param : \d{1,9} }',
  54 + [
  55 + ['/test/', ['param', '\d{1,9}']]
  56 + ]
  57 + ],
  58 + [
  59 + '/test[opt]',
  60 + [
  61 + ['/test'],
  62 + ['/testopt'],
  63 + ]
  64 + ],
  65 + [
  66 + '/test[/{param}]',
  67 + [
  68 + ['/test'],
  69 + ['/test/', ['param', '[^/]+']],
  70 + ]
  71 + ],
  72 + [
  73 + '/{param}[opt]',
  74 + [
  75 + ['/', ['param', '[^/]+']],
  76 + ['/', ['param', '[^/]+'], 'opt']
  77 + ]
  78 + ],
  79 + [
  80 + '/test[/{name}[/{id:[0-9]+}]]',
  81 + [
  82 + ['/test'],
  83 + ['/test/', ['name', '[^/]+']],
  84 + ['/test/', ['name', '[^/]+'], '/', ['id', '[0-9]+']],
  85 + ]
  86 + ],
  87 + [
  88 + '',
  89 + [
  90 + [''],
  91 + ]
  92 + ],
  93 + [
  94 + '[test]',
  95 + [
  96 + [''],
  97 + ['test'],
  98 + ]
  99 + ],
  100 + [
  101 + '/{foo-bar}',
  102 + [
  103 + ['/', ['foo-bar', '[^/]+']]
  104 + ]
  105 + ],
  106 + [
  107 + '/{_foo:.*}',
  108 + [
  109 + ['/', ['_foo', '.*']]
  110 + ]
  111 + ],
  112 + ];
  113 + }
  114 +
  115 + public function provideTestParseError() {
  116 + return [
  117 + [
  118 + '/test[opt',
  119 + "Number of opening '[' and closing ']' does not match"
  120 + ],
  121 + [
  122 + '/test[opt[opt2]',
  123 + "Number of opening '[' and closing ']' does not match"
  124 + ],
  125 + [
  126 + '/testopt]',
  127 + "Number of opening '[' and closing ']' does not match"
  128 + ],
  129 + [
  130 + '/test[]',
  131 + "Empty optional part"
  132 + ],
  133 + [
  134 + '/test[[opt]]',
  135 + "Empty optional part"
  136 + ],
  137 + [
  138 + '[[test]]',
  139 + "Empty optional part"
  140 + ],
  141 + [
  142 + '/test[/opt]/required',
  143 + "Optional segments can only occur at the end of a route"
  144 + ],
  145 + ];
  146 + }
  147 +}
... ...
vendor/nikic/fast-route/test/bootstrap.php 0 → 100644
  1 +++ a/vendor/nikic/fast-route/test/bootstrap.php
... ... @@ -0,0 +1,11 @@
  1 +<?php
  2 +
  3 +require_once __DIR__ . '/../src/functions.php';
  4 +
  5 +spl_autoload_register(function($class) {
  6 + if (strpos($class, 'FastRoute\\') === 0) {
  7 + $dir = strcasecmp(substr($class, -4), 'Test') ? 'src/' : 'test/';
  8 + $name = substr($class, strlen('FastRoute'));
  9 + require __DIR__ . '/../' . $dir . strtr($name, '\\', DIRECTORY_SEPARATOR) . '.php';
  10 + }
  11 +});
... ...
vendor/pimple/pimple/.gitignore 0 → 100644
  1 +++ a/vendor/pimple/pimple/.gitignore
... ... @@ -0,0 +1,3 @@
  1 +phpunit.xml
  2 +composer.lock
  3 +/vendor/
... ...
vendor/pimple/pimple/.travis.yml 0 → 100644
  1 +++ a/vendor/pimple/pimple/.travis.yml
... ... @@ -0,0 +1,32 @@
  1 +language: php
  2 +
  3 +env:
  4 + matrix:
  5 + - PIMPLE_EXT=no
  6 + - PIMPLE_EXT=yes
  7 + global:
  8 + - REPORT_EXIT_STATUS=1
  9 +
  10 +php:
  11 + - 5.3
  12 + - 5.4
  13 + - 5.5
  14 + - 5.6
  15 + - hhvm
  16 +
  17 +before_script:
  18 + - composer self-update
  19 + - COMPOSER_ROOT_VERSION=dev-master composer dump-autoload
  20 + - if [ "$PIMPLE_EXT" == "yes" ]; then sh -c "cd ext/pimple && phpize && ./configure && make && sudo make install"; fi
  21 + - if [ "$PIMPLE_EXT" == "yes" ]; then echo "extension=pimple.so" >> `php --ini | grep "Loaded Configuration" | sed -e "s|.*:\s*||"`; fi
  22 +
  23 +script:
  24 + - cd ext/pimple
  25 + - if [ "$PIMPLE_EXT" == "yes" ]; then yes n | make test | tee output ; grep -E 'Tests failed +. +0' output; fi
  26 + - cd ../..
  27 + - phpunit
  28 +
  29 +matrix:
  30 + exclude:
  31 + - php: hhvm
  32 + env: PIMPLE_EXT=yes
... ...
vendor/pimple/pimple/CHANGELOG 0 → 100644
  1 +++ a/vendor/pimple/pimple/CHANGELOG
... ... @@ -0,0 +1,35 @@
  1 +* 3.0.2 (2015-09-11)
  2 +
  3 + * refactored the C extension
  4 + * minor non-significant changes
  5 +
  6 +* 3.0.1 (2015-07-30)
  7 +
  8 + * simplified some code
  9 + * fixed a segfault in the C extension
  10 +
  11 +* 3.0.0 (2014-07-24)
  12 +
  13 + * removed the Pimple class alias (use Pimple\Container instead)
  14 +
  15 +* 2.1.1 (2014-07-24)
  16 +
  17 + * fixed compiler warnings for the C extension
  18 + * fixed code when dealing with circular references
  19 +
  20 +* 2.1.0 (2014-06-24)
  21 +
  22 + * moved the Pimple to Pimple\Container (with a BC layer -- Pimple is now a
  23 + deprecated alias which will be removed in Pimple 3.0)
  24 + * added Pimple\ServiceProviderInterface (and Pimple::register())
  25 +
  26 +* 2.0.0 (2014-02-10)
  27 +
  28 + * changed extend to automatically re-assign the extended service and keep it as shared or factory
  29 + (to keep BC, extend still returns the extended service)
  30 + * changed services to be shared by default (use factory() for factory
  31 + services)
  32 +
  33 +* 1.0.0
  34 +
  35 + * initial version
... ...
vendor/pimple/pimple/LICENSE 0 → 100644
  1 +++ a/vendor/pimple/pimple/LICENSE
... ... @@ -0,0 +1,19 @@
  1 +Copyright (c) 2009-2015 Fabien Potencier
  2 +
  3 +Permission is hereby granted, free of charge, to any person obtaining a copy
  4 +of this software and associated documentation files (the "Software"), to deal
  5 +in the Software without restriction, including without limitation the rights
  6 +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  7 +copies of the Software, and to permit persons to whom the Software is furnished
  8 +to do so, subject to the following conditions:
  9 +
  10 +The above copyright notice and this permission notice shall be included in all
  11 +copies or substantial portions of the Software.
  12 +
  13 +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  14 +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  15 +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  16 +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  17 +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  18 +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  19 +THE SOFTWARE.
... ...
vendor/pimple/pimple/README.rst 0 → 100644
  1 +++ a/vendor/pimple/pimple/README.rst
... ... @@ -0,0 +1,201 @@
  1 +Pimple
  2 +======
  3 +
  4 +.. caution::
  5 +
  6 + This is the documentation for Pimple 3.x. If you are using Pimple 1.x, read
  7 + the `Pimple 1.x documentation`_. Reading the Pimple 1.x code is also a good
  8 + way to learn more about how to create a simple Dependency Injection
  9 + Container (recent versions of Pimple are more focused on performance).
  10 +
  11 +Pimple is a small Dependency Injection Container for PHP.
  12 +
  13 +Installation
  14 +------------
  15 +
  16 +Before using Pimple in your project, add it to your ``composer.json`` file:
  17 +
  18 +.. code-block:: bash
  19 +
  20 + $ ./composer.phar require pimple/pimple ~3.0
  21 +
  22 +Alternatively, Pimple is also available as a PHP C extension:
  23 +
  24 +.. code-block:: bash
  25 +
  26 + $ git clone https://github.com/silexphp/Pimple
  27 + $ cd Pimple/ext/pimple
  28 + $ phpize
  29 + $ ./configure
  30 + $ make
  31 + $ make install
  32 +
  33 +Usage
  34 +-----
  35 +
  36 +Creating a container is a matter of creating a ``Container`` instance:
  37 +
  38 +.. code-block:: php
  39 +
  40 + use Pimple\Container;
  41 +
  42 + $container = new Container();
  43 +
  44 +As many other dependency injection containers, Pimple manages two different
  45 +kind of data: **services** and **parameters**.
  46 +
  47 +Defining Services
  48 +~~~~~~~~~~~~~~~~~
  49 +
  50 +A service is an object that does something as part of a larger system. Examples
  51 +of services: a database connection, a templating engine, or a mailer. Almost
  52 +any **global** object can be a service.
  53 +
  54 +Services are defined by **anonymous functions** that return an instance of an
  55 +object:
  56 +
  57 +.. code-block:: php
  58 +
  59 + // define some services
  60 + $container['session_storage'] = function ($c) {
  61 + return new SessionStorage('SESSION_ID');
  62 + };
  63 +
  64 + $container['session'] = function ($c) {
  65 + return new Session($c['session_storage']);
  66 + };
  67 +
  68 +Notice that the anonymous function has access to the current container
  69 +instance, allowing references to other services or parameters.
  70 +
  71 +As objects are only created when you get them, the order of the definitions
  72 +does not matter.
  73 +
  74 +Using the defined services is also very easy:
  75 +
  76 +.. code-block:: php
  77 +
  78 + // get the session object
  79 + $session = $container['session'];
  80 +
  81 + // the above call is roughly equivalent to the following code:
  82 + // $storage = new SessionStorage('SESSION_ID');
  83 + // $session = new Session($storage);
  84 +
  85 +Defining Factory Services
  86 +~~~~~~~~~~~~~~~~~~~~~~~~~
  87 +
  88 +By default, each time you get a service, Pimple returns the **same instance**
  89 +of it. If you want a different instance to be returned for all calls, wrap your
  90 +anonymous function with the ``factory()`` method
  91 +
  92 +.. code-block:: php
  93 +
  94 + $container['session'] = $container->factory(function ($c) {
  95 + return new Session($c['session_storage']);
  96 + });
  97 +
  98 +Now, each call to ``$container['session']`` returns a new instance of the
  99 +session.
  100 +
  101 +Defining Parameters
  102 +~~~~~~~~~~~~~~~~~~~
  103 +
  104 +Defining a parameter allows to ease the configuration of your container from
  105 +the outside and to store global values:
  106 +
  107 +.. code-block:: php
  108 +
  109 + // define some parameters
  110 + $container['cookie_name'] = 'SESSION_ID';
  111 + $container['session_storage_class'] = 'SessionStorage';
  112 +
  113 +If you change the ``session_storage`` service definition like below:
  114 +
  115 +.. code-block:: php
  116 +
  117 + $container['session_storage'] = function ($c) {
  118 + return new $c['session_storage_class']($c['cookie_name']);
  119 + };
  120 +
  121 +You can now easily change the cookie name by overriding the
  122 +``session_storage_class`` parameter instead of redefining the service
  123 +definition.
  124 +
  125 +Protecting Parameters
  126 +~~~~~~~~~~~~~~~~~~~~~
  127 +
  128 +Because Pimple sees anonymous functions as service definitions, you need to
  129 +wrap anonymous functions with the ``protect()`` method to store them as
  130 +parameters:
  131 +
  132 +.. code-block:: php
  133 +
  134 + $container['random_func'] = $container->protect(function () {
  135 + return rand();
  136 + });
  137 +
  138 +Modifying Services after Definition
  139 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  140 +
  141 +In some cases you may want to modify a service definition after it has been
  142 +defined. You can use the ``extend()`` method to define additional code to be
  143 +run on your service just after it is created:
  144 +
  145 +.. code-block:: php
  146 +
  147 + $container['session_storage'] = function ($c) {
  148 + return new $c['session_storage_class']($c['cookie_name']);
  149 + };
  150 +
  151 + $container->extend('session_storage', function ($storage, $c) {
  152 + $storage->...();
  153 +
  154 + return $storage;
  155 + });
  156 +
  157 +The first argument is the name of the service to extend, the second a function
  158 +that gets access to the object instance and the container.
  159 +
  160 +Extending a Container
  161 +~~~~~~~~~~~~~~~~~~~~~
  162 +
  163 +If you use the same libraries over and over, you might want to reuse some
  164 +services from one project to the next one; package your services into a
  165 +**provider** by implementing ``Pimple\ServiceProviderInterface``:
  166 +
  167 +.. code-block:: php
  168 +
  169 + use Pimple\Container;
  170 +
  171 + class FooProvider implements Pimple\ServiceProviderInterface
  172 + {
  173 + public function register(Container $pimple)
  174 + {
  175 + // register some services and parameters
  176 + // on $pimple
  177 + }
  178 + }
  179 +
  180 +Then, register the provider on a Container:
  181 +
  182 +.. code-block:: php
  183 +
  184 + $pimple->register(new FooProvider());
  185 +
  186 +Fetching the Service Creation Function
  187 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  188 +
  189 +When you access an object, Pimple automatically calls the anonymous function
  190 +that you defined, which creates the service object for you. If you want to get
  191 +raw access to this function, you can use the ``raw()`` method:
  192 +
  193 +.. code-block:: php
  194 +
  195 + $container['session'] = function ($c) {
  196 + return new Session($c['session_storage']);
  197 + };
  198 +
  199 + $sessionFunction = $container->raw('session');
  200 +
  201 +.. _Pimple 1.x documentation: https://github.com/silexphp/Pimple/tree/1.1
... ...
vendor/pimple/pimple/composer.json 0 → 100644
  1 +++ a/vendor/pimple/pimple/composer.json
... ... @@ -0,0 +1,25 @@
  1 +{
  2 + "name": "pimple/pimple",
  3 + "type": "library",
  4 + "description": "Pimple, a simple Dependency Injection Container",
  5 + "keywords": ["dependency injection", "container"],
  6 + "homepage": "http://pimple.sensiolabs.org",
  7 + "license": "MIT",
  8 + "authors": [
  9 + {
  10 + "name": "Fabien Potencier",
  11 + "email": "fabien@symfony.com"
  12 + }
  13 + ],
  14 + "require": {
  15 + "php": ">=5.3.0"
  16 + },
  17 + "autoload": {
  18 + "psr-0": { "Pimple": "src/" }
  19 + },
  20 + "extra": {
  21 + "branch-alias": {
  22 + "dev-master": "3.0.x-dev"
  23 + }
  24 + }
  25 +}
... ...
vendor/pimple/pimple/ext/pimple/.gitignore 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/.gitignore
... ... @@ -0,0 +1,30 @@
  1 +*.sw*
  2 +.deps
  3 +Makefile
  4 +Makefile.fragments
  5 +Makefile.global
  6 +Makefile.objects
  7 +acinclude.m4
  8 +aclocal.m4
  9 +build/
  10 +config.cache
  11 +config.guess
  12 +config.h
  13 +config.h.in
  14 +config.log
  15 +config.nice
  16 +config.status
  17 +config.sub
  18 +configure
  19 +configure.in
  20 +install-sh
  21 +libtool
  22 +ltmain.sh
  23 +missing
  24 +mkinstalldirs
  25 +run-tests.php
  26 +*.loT
  27 +.libs/
  28 +modules/
  29 +*.la
  30 +*.lo
... ...
vendor/pimple/pimple/ext/pimple/README.md 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/README.md
... ... @@ -0,0 +1,12 @@
  1 +This is Pimple 2 implemented in C
  2 +
  3 +* PHP >= 5.3
  4 +* Not tested under Windows, might work
  5 +
  6 +Install
  7 +=======
  8 +
  9 + > phpize
  10 + > ./configure
  11 + > make
  12 + > make install
... ...
vendor/pimple/pimple/ext/pimple/config.m4 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/config.m4
... ... @@ -0,0 +1,63 @@
  1 +dnl $Id$
  2 +dnl config.m4 for extension pimple
  3 +
  4 +dnl Comments in this file start with the string 'dnl'.
  5 +dnl Remove where necessary. This file will not work
  6 +dnl without editing.
  7 +
  8 +dnl If your extension references something external, use with:
  9 +
  10 +dnl PHP_ARG_WITH(pimple, for pimple support,
  11 +dnl Make sure that the comment is aligned:
  12 +dnl [ --with-pimple Include pimple support])
  13 +
  14 +dnl Otherwise use enable:
  15 +
  16 +PHP_ARG_ENABLE(pimple, whether to enable pimple support,
  17 +dnl Make sure that the comment is aligned:
  18 +[ --enable-pimple Enable pimple support])
  19 +
  20 +if test "$PHP_PIMPLE" != "no"; then
  21 + dnl Write more examples of tests here...
  22 +
  23 + dnl # --with-pimple -> check with-path
  24 + dnl SEARCH_PATH="/usr/local /usr" # you might want to change this
  25 + dnl SEARCH_FOR="/include/pimple.h" # you most likely want to change this
  26 + dnl if test -r $PHP_PIMPLE/$SEARCH_FOR; then # path given as parameter
  27 + dnl PIMPLE_DIR=$PHP_PIMPLE
  28 + dnl else # search default path list
  29 + dnl AC_MSG_CHECKING([for pimple files in default path])
  30 + dnl for i in $SEARCH_PATH ; do
  31 + dnl if test -r $i/$SEARCH_FOR; then
  32 + dnl PIMPLE_DIR=$i
  33 + dnl AC_MSG_RESULT(found in $i)
  34 + dnl fi
  35 + dnl done
  36 + dnl fi
  37 + dnl
  38 + dnl if test -z "$PIMPLE_DIR"; then
  39 + dnl AC_MSG_RESULT([not found])
  40 + dnl AC_MSG_ERROR([Please reinstall the pimple distribution])
  41 + dnl fi
  42 +
  43 + dnl # --with-pimple -> add include path
  44 + dnl PHP_ADD_INCLUDE($PIMPLE_DIR/include)
  45 +
  46 + dnl # --with-pimple -> check for lib and symbol presence
  47 + dnl LIBNAME=pimple # you may want to change this
  48 + dnl LIBSYMBOL=pimple # you most likely want to change this
  49 +
  50 + dnl PHP_CHECK_LIBRARY($LIBNAME,$LIBSYMBOL,
  51 + dnl [
  52 + dnl PHP_ADD_LIBRARY_WITH_PATH($LIBNAME, $PIMPLE_DIR/lib, PIMPLE_SHARED_LIBADD)
  53 + dnl AC_DEFINE(HAVE_PIMPLELIB,1,[ ])
  54 + dnl ],[
  55 + dnl AC_MSG_ERROR([wrong pimple lib version or lib not found])
  56 + dnl ],[
  57 + dnl -L$PIMPLE_DIR/lib -lm
  58 + dnl ])
  59 + dnl
  60 + dnl PHP_SUBST(PIMPLE_SHARED_LIBADD)
  61 +
  62 + PHP_NEW_EXTENSION(pimple, pimple.c, $ext_shared)
  63 +fi
... ...
vendor/pimple/pimple/ext/pimple/config.w32 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/config.w32
... ... @@ -0,0 +1,13 @@
  1 +// $Id$
  2 +// vim:ft=javascript
  3 +
  4 +// If your extension references something external, use ARG_WITH
  5 +// ARG_WITH("pimple", "for pimple support", "no");
  6 +
  7 +// Otherwise, use ARG_ENABLE
  8 +// ARG_ENABLE("pimple", "enable pimple support", "no");
  9 +
  10 +if (PHP_PIMPLE != "no") {
  11 + EXTENSION("pimple", "pimple.c");
  12 +}
  13 +
... ...
vendor/pimple/pimple/ext/pimple/php_pimple.h 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/php_pimple.h
... ... @@ -0,0 +1,121 @@
  1 +
  2 +/*
  3 + * This file is part of Pimple.
  4 + *
  5 + * Copyright (c) 2014 Fabien Potencier
  6 + *
  7 + * Permission is hereby granted, free of charge, to any person obtaining a copy
  8 + * of this software and associated documentation files (the "Software"), to deal
  9 + * in the Software without restriction, including without limitation the rights
  10 + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  11 + * copies of the Software, and to permit persons to whom the Software is furnished
  12 + * to do so, subject to the following conditions:
  13 + *
  14 + * The above copyright notice and this permission notice shall be included in all
  15 + * copies or substantial portions of the Software.
  16 + *
  17 + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18 + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  19 + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  20 + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  21 + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  22 + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  23 + * THE SOFTWARE.
  24 + */
  25 +
  26 +#ifndef PHP_PIMPLE_H
  27 +#define PHP_PIMPLE_H
  28 +
  29 +extern zend_module_entry pimple_module_entry;
  30 +#define phpext_pimple_ptr &pimple_module_entry
  31 +
  32 +#ifdef PHP_WIN32
  33 +# define PHP_PIMPLE_API __declspec(dllexport)
  34 +#elif defined(__GNUC__) && __GNUC__ >= 4
  35 +# define PHP_PIMPLE_API __attribute__ ((visibility("default")))
  36 +#else
  37 +# define PHP_PIMPLE_API
  38 +#endif
  39 +
  40 +#ifdef ZTS
  41 +#include "TSRM.h"
  42 +#endif
  43 +
  44 +#define PIMPLE_VERSION "3.0.2"
  45 +#define PIMPLE_NS "Pimple"
  46 +
  47 +#define PIMPLE_DEFAULT_ZVAL_CACHE_NUM 5
  48 +#define PIMPLE_DEFAULT_ZVAL_VALUES_NUM 10
  49 +
  50 +zend_module_entry *get_module(void);
  51 +
  52 +PHP_MINIT_FUNCTION(pimple);
  53 +PHP_MINFO_FUNCTION(pimple);
  54 +
  55 +PHP_METHOD(Pimple, __construct);
  56 +PHP_METHOD(Pimple, factory);
  57 +PHP_METHOD(Pimple, protect);
  58 +PHP_METHOD(Pimple, raw);
  59 +PHP_METHOD(Pimple, extend);
  60 +PHP_METHOD(Pimple, keys);
  61 +PHP_METHOD(Pimple, register);
  62 +PHP_METHOD(Pimple, offsetSet);
  63 +PHP_METHOD(Pimple, offsetUnset);
  64 +PHP_METHOD(Pimple, offsetGet);
  65 +PHP_METHOD(Pimple, offsetExists);
  66 +
  67 +PHP_METHOD(PimpleClosure, invoker);
  68 +
  69 +typedef struct _pimple_bucket_value {
  70 + zval *value; /* Must be the first element */
  71 + zval *raw;
  72 + zend_object_handle handle_num;
  73 + enum {
  74 + PIMPLE_IS_PARAM = 0,
  75 + PIMPLE_IS_SERVICE = 2
  76 + } type;
  77 + zend_bool initialized;
  78 + zend_fcall_info_cache fcc;
  79 +} pimple_bucket_value;
  80 +
  81 +typedef struct _pimple_object {
  82 + zend_object zobj;
  83 + HashTable values;
  84 + HashTable factories;
  85 + HashTable protected;
  86 +} pimple_object;
  87 +
  88 +typedef struct _pimple_closure_object {
  89 + zend_object zobj;
  90 + zval *callable;
  91 + zval *factory;
  92 +} pimple_closure_object;
  93 +
  94 +static const char sensiolabs_logo[] = "<img src=\"\">";
  95 +
  96 +static int pimple_zval_to_pimpleval(zval *_zval, pimple_bucket_value *_pimple_bucket_value TSRMLS_DC);
  97 +static int pimple_zval_is_valid_callback(zval *_zval, pimple_bucket_value *_pimple_bucket_value TSRMLS_DC);
  98 +
  99 +static void pimple_bucket_dtor(pimple_bucket_value *bucket);
  100 +static void pimple_free_bucket(pimple_bucket_value *bucket);
  101 +
  102 +static zval *pimple_object_read_dimension(zval *object, zval *offset, int type TSRMLS_DC);
  103 +static void pimple_object_write_dimension(zval *object, zval *offset, zval *value TSRMLS_DC);
  104 +static int pimple_object_has_dimension(zval *object, zval *offset, int check_empty TSRMLS_DC);
  105 +static void pimple_object_unset_dimension(zval *object, zval *offset TSRMLS_DC);
  106 +static zend_object_value pimple_object_create(zend_class_entry *ce TSRMLS_DC);
  107 +static void pimple_free_object_storage(pimple_object *obj TSRMLS_DC);
  108 +
  109 +static void pimple_closure_free_object_storage(pimple_closure_object *obj TSRMLS_DC);
  110 +static zend_object_value pimple_closure_object_create(zend_class_entry *ce TSRMLS_DC);
  111 +static zend_function *pimple_closure_get_constructor(zval * TSRMLS_DC);
  112 +static int pimple_closure_get_closure(zval *obj, zend_class_entry **ce_ptr, union _zend_function **fptr_ptr, zval **zobj_ptr TSRMLS_DC);
  113 +
  114 +#ifdef ZTS
  115 +#define PIMPLE_G(v) TSRMG(pimple_globals_id, zend_pimple_globals *, v)
  116 +#else
  117 +#define PIMPLE_G(v) (pimple_globals.v)
  118 +#endif
  119 +
  120 +#endif /* PHP_PIMPLE_H */
  121 +
... ...
vendor/pimple/pimple/ext/pimple/pimple.c 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/pimple.c
... ... @@ -0,0 +1,922 @@
  1 +
  2 +/*
  3 + * This file is part of Pimple.
  4 + *
  5 + * Copyright (c) 2014 Fabien Potencier
  6 + *
  7 + * Permission is hereby granted, free of charge, to any person obtaining a copy
  8 + * of this software and associated documentation files (the "Software"), to deal
  9 + * in the Software without restriction, including without limitation the rights
  10 + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  11 + * copies of the Software, and to permit persons to whom the Software is furnished
  12 + * to do so, subject to the following conditions:
  13 + *
  14 + * The above copyright notice and this permission notice shall be included in all
  15 + * copies or substantial portions of the Software.
  16 + *
  17 + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18 + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  19 + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  20 + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  21 + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  22 + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  23 + * THE SOFTWARE.
  24 + */
  25 +
  26 +#ifdef HAVE_CONFIG_H
  27 +#include "config.h"
  28 +#endif
  29 +
  30 +#include "php.h"
  31 +#include "php_ini.h"
  32 +#include "ext/standard/info.h"
  33 +#include "php_pimple.h"
  34 +#include "pimple_compat.h"
  35 +#include "zend_interfaces.h"
  36 +#include "zend.h"
  37 +#include "Zend/zend_closures.h"
  38 +#include "ext/spl/spl_exceptions.h"
  39 +#include "Zend/zend_exceptions.h"
  40 +#include "main/php_output.h"
  41 +#include "SAPI.h"
  42 +
  43 +static zend_class_entry *pimple_ce;
  44 +static zend_object_handlers pimple_object_handlers;
  45 +static zend_class_entry *pimple_closure_ce;
  46 +static zend_class_entry *pimple_serviceprovider_ce;
  47 +static zend_object_handlers pimple_closure_object_handlers;
  48 +static zend_internal_function pimple_closure_invoker_function;
  49 +
  50 +#define FETCH_DIM_HANDLERS_VARS pimple_object *pimple_obj = NULL; \
  51 + ulong index; \
  52 + pimple_obj = (pimple_object *)zend_object_store_get_object(object TSRMLS_CC); \
  53 +
  54 +#define PIMPLE_OBJECT_HANDLE_INHERITANCE_OBJECT_HANDLERS do { \
  55 + if (ce != pimple_ce) { \
  56 + zend_hash_find(&ce->function_table, ZEND_STRS("offsetget"), (void **)&function); \
  57 + if (function->common.scope != ce) { /* if the function is not defined in this actual class */ \
  58 + pimple_object_handlers.read_dimension = pimple_object_read_dimension; /* then overwrite the handler to use custom one */ \
  59 + } \
  60 + zend_hash_find(&ce->function_table, ZEND_STRS("offsetset"), (void **)&function); \
  61 + if (function->common.scope != ce) { \
  62 + pimple_object_handlers.write_dimension = pimple_object_write_dimension; \
  63 + } \
  64 + zend_hash_find(&ce->function_table, ZEND_STRS("offsetexists"), (void **)&function); \
  65 + if (function->common.scope != ce) { \
  66 + pimple_object_handlers.has_dimension = pimple_object_has_dimension; \
  67 + } \
  68 + zend_hash_find(&ce->function_table, ZEND_STRS("offsetunset"), (void **)&function); \
  69 + if (function->common.scope != ce) { \
  70 + pimple_object_handlers.unset_dimension = pimple_object_unset_dimension; \
  71 + } \
  72 + } else { \
  73 + pimple_object_handlers.read_dimension = pimple_object_read_dimension; \
  74 + pimple_object_handlers.write_dimension = pimple_object_write_dimension; \
  75 + pimple_object_handlers.has_dimension = pimple_object_has_dimension; \
  76 + pimple_object_handlers.unset_dimension = pimple_object_unset_dimension; \
  77 + }\
  78 + } while(0);
  79 +
  80 +#define PIMPLE_CALL_CB do { \
  81 + zend_fcall_info_argn(&fci TSRMLS_CC, 1, &object); \
  82 + fci.size = sizeof(fci); \
  83 + fci.object_ptr = retval->fcc.object_ptr; \
  84 + fci.function_name = retval->value; \
  85 + fci.no_separation = 1; \
  86 + fci.retval_ptr_ptr = &retval_ptr_ptr; \
  87 +\
  88 + zend_call_function(&fci, &retval->fcc TSRMLS_CC); \
  89 + efree(fci.params); \
  90 + if (EG(exception)) { \
  91 + return EG(uninitialized_zval_ptr); \
  92 + } \
  93 + } while(0);
  94 +
  95 +ZEND_BEGIN_ARG_INFO_EX(arginfo___construct, 0, 0, 0)
  96 +ZEND_ARG_ARRAY_INFO(0, value, 0)
  97 +ZEND_END_ARG_INFO()
  98 +
  99 +ZEND_BEGIN_ARG_INFO_EX(arginfo_offsetset, 0, 0, 2)
  100 +ZEND_ARG_INFO(0, offset)
  101 +ZEND_ARG_INFO(0, value)
  102 +ZEND_END_ARG_INFO()
  103 +
  104 +ZEND_BEGIN_ARG_INFO_EX(arginfo_offsetget, 0, 0, 1)
  105 +ZEND_ARG_INFO(0, offset)
  106 +ZEND_END_ARG_INFO()
  107 +
  108 +ZEND_BEGIN_ARG_INFO_EX(arginfo_offsetexists, 0, 0, 1)
  109 +ZEND_ARG_INFO(0, offset)
  110 +ZEND_END_ARG_INFO()
  111 +
  112 +ZEND_BEGIN_ARG_INFO_EX(arginfo_offsetunset, 0, 0, 1)
  113 +ZEND_ARG_INFO(0, offset)
  114 +ZEND_END_ARG_INFO()
  115 +
  116 +ZEND_BEGIN_ARG_INFO_EX(arginfo_factory, 0, 0, 1)
  117 +ZEND_ARG_INFO(0, callable)
  118 +ZEND_END_ARG_INFO()
  119 +
  120 +ZEND_BEGIN_ARG_INFO_EX(arginfo_protect, 0, 0, 1)
  121 +ZEND_ARG_INFO(0, callable)
  122 +ZEND_END_ARG_INFO()
  123 +
  124 +ZEND_BEGIN_ARG_INFO_EX(arginfo_raw, 0, 0, 1)
  125 +ZEND_ARG_INFO(0, id)
  126 +ZEND_END_ARG_INFO()
  127 +
  128 +ZEND_BEGIN_ARG_INFO_EX(arginfo_extend, 0, 0, 2)
  129 +ZEND_ARG_INFO(0, id)
  130 +ZEND_ARG_INFO(0, callable)
  131 +ZEND_END_ARG_INFO()
  132 +
  133 +ZEND_BEGIN_ARG_INFO_EX(arginfo_keys, 0, 0, 0)
  134 +ZEND_END_ARG_INFO()
  135 +
  136 +ZEND_BEGIN_ARG_INFO_EX(arginfo_register, 0, 0, 1)
  137 +ZEND_ARG_OBJ_INFO(0, provider, Pimple\\ServiceProviderInterface, 0)
  138 +ZEND_ARG_ARRAY_INFO(0, values, 1)
  139 +ZEND_END_ARG_INFO()
  140 +
  141 +ZEND_BEGIN_ARG_INFO_EX(arginfo_serviceprovider_register, 0, 0, 1)
  142 +ZEND_ARG_OBJ_INFO(0, pimple, Pimple\\Container, 0)
  143 +ZEND_END_ARG_INFO()
  144 +
  145 +static const zend_function_entry pimple_ce_functions[] = {
  146 + PHP_ME(Pimple, __construct, arginfo___construct, ZEND_ACC_PUBLIC)
  147 + PHP_ME(Pimple, factory, arginfo_factory, ZEND_ACC_PUBLIC)
  148 + PHP_ME(Pimple, protect, arginfo_protect, ZEND_ACC_PUBLIC)
  149 + PHP_ME(Pimple, raw, arginfo_raw, ZEND_ACC_PUBLIC)
  150 + PHP_ME(Pimple, extend, arginfo_extend, ZEND_ACC_PUBLIC)
  151 + PHP_ME(Pimple, keys, arginfo_keys, ZEND_ACC_PUBLIC)
  152 + PHP_ME(Pimple, register, arginfo_register, ZEND_ACC_PUBLIC)
  153 +
  154 + PHP_ME(Pimple, offsetSet, arginfo_offsetset, ZEND_ACC_PUBLIC)
  155 + PHP_ME(Pimple, offsetGet, arginfo_offsetget, ZEND_ACC_PUBLIC)
  156 + PHP_ME(Pimple, offsetExists, arginfo_offsetexists, ZEND_ACC_PUBLIC)
  157 + PHP_ME(Pimple, offsetUnset, arginfo_offsetunset, ZEND_ACC_PUBLIC)
  158 + PHP_FE_END
  159 +};
  160 +
  161 +static const zend_function_entry pimple_serviceprovider_iface_ce_functions[] = {
  162 + PHP_ABSTRACT_ME(ServiceProviderInterface, register, arginfo_serviceprovider_register)
  163 + PHP_FE_END
  164 +};
  165 +
  166 +static void pimple_closure_free_object_storage(pimple_closure_object *obj TSRMLS_DC)
  167 +{
  168 + zend_object_std_dtor(&obj->zobj TSRMLS_CC);
  169 + if (obj->factory) {
  170 + zval_ptr_dtor(&obj->factory);
  171 + }
  172 + if (obj->callable) {
  173 + zval_ptr_dtor(&obj->callable);
  174 + }
  175 + efree(obj);
  176 +}
  177 +
  178 +static void pimple_free_object_storage(pimple_object *obj TSRMLS_DC)
  179 +{
  180 + zend_hash_destroy(&obj->factories);
  181 + zend_hash_destroy(&obj->protected);
  182 + zend_hash_destroy(&obj->values);
  183 + zend_object_std_dtor(&obj->zobj TSRMLS_CC);
  184 + efree(obj);
  185 +}
  186 +
  187 +static void pimple_free_bucket(pimple_bucket_value *bucket)
  188 +{
  189 + if (bucket->raw) {
  190 + zval_ptr_dtor(&bucket->raw);
  191 + }
  192 +}
  193 +
  194 +static zend_object_value pimple_closure_object_create(zend_class_entry *ce TSRMLS_DC)
  195 +{
  196 + zend_object_value retval;
  197 + pimple_closure_object *pimple_closure_obj = NULL;
  198 +
  199 + pimple_closure_obj = ecalloc(1, sizeof(pimple_closure_object));
  200 + ZEND_OBJ_INIT(&pimple_closure_obj->zobj, ce);
  201 +
  202 + pimple_closure_object_handlers.get_constructor = pimple_closure_get_constructor;
  203 + retval.handlers = &pimple_closure_object_handlers;
  204 + retval.handle = zend_objects_store_put(pimple_closure_obj, (zend_objects_store_dtor_t) zend_objects_destroy_object, (zend_objects_free_object_storage_t) pimple_closure_free_object_storage, NULL TSRMLS_CC);
  205 +
  206 + return retval;
  207 +}
  208 +
  209 +static zend_function *pimple_closure_get_constructor(zval *obj TSRMLS_DC)
  210 +{
  211 + zend_error(E_ERROR, "Pimple\\ContainerClosure is an internal class and cannot be instantiated");
  212 +
  213 + return NULL;
  214 +}
  215 +
  216 +static int pimple_closure_get_closure(zval *obj, zend_class_entry **ce_ptr, union _zend_function **fptr_ptr, zval **zobj_ptr TSRMLS_DC)
  217 +{
  218 + *zobj_ptr = obj;
  219 + *ce_ptr = Z_OBJCE_P(obj);
  220 + *fptr_ptr = (zend_function *)&pimple_closure_invoker_function;
  221 +
  222 + return SUCCESS;
  223 +}
  224 +
  225 +static zend_object_value pimple_object_create(zend_class_entry *ce TSRMLS_DC)
  226 +{
  227 + zend_object_value retval;
  228 + pimple_object *pimple_obj = NULL;
  229 + zend_function *function = NULL;
  230 +
  231 + pimple_obj = emalloc(sizeof(pimple_object));
  232 + ZEND_OBJ_INIT(&pimple_obj->zobj, ce);
  233 +
  234 + PIMPLE_OBJECT_HANDLE_INHERITANCE_OBJECT_HANDLERS
  235 +
  236 + retval.handlers = &pimple_object_handlers;
  237 + retval.handle = zend_objects_store_put(pimple_obj, (zend_objects_store_dtor_t) zend_objects_destroy_object, (zend_objects_free_object_storage_t) pimple_free_object_storage, NULL TSRMLS_CC);
  238 +
  239 + zend_hash_init(&pimple_obj->factories, PIMPLE_DEFAULT_ZVAL_CACHE_NUM, NULL, (dtor_func_t)pimple_bucket_dtor, 0);
  240 + zend_hash_init(&pimple_obj->protected, PIMPLE_DEFAULT_ZVAL_CACHE_NUM, NULL, (dtor_func_t)pimple_bucket_dtor, 0);
  241 + zend_hash_init(&pimple_obj->values, PIMPLE_DEFAULT_ZVAL_VALUES_NUM, NULL, (dtor_func_t)pimple_bucket_dtor, 0);
  242 +
  243 + return retval;
  244 +}
  245 +
  246 +static void pimple_object_write_dimension(zval *object, zval *offset, zval *value TSRMLS_DC)
  247 +{
  248 + FETCH_DIM_HANDLERS_VARS
  249 +
  250 + pimple_bucket_value pimple_value = {0}, *found_value = NULL;
  251 + ulong hash;
  252 +
  253 + pimple_zval_to_pimpleval(value, &pimple_value TSRMLS_CC);
  254 +
  255 + if (!offset) {/* $p[] = 'foo' when not overloaded */
  256 + zend_hash_next_index_insert(&pimple_obj->values, (void *)&pimple_value, sizeof(pimple_bucket_value), NULL);
  257 + Z_ADDREF_P(value);
  258 + return;
  259 + }
  260 +
  261 + switch (Z_TYPE_P(offset)) {
  262 + case IS_STRING:
  263 + hash = zend_hash_func(Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1);
  264 + zend_hash_quick_find(&pimple_obj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, hash, (void **)&found_value);
  265 + if (found_value && found_value->type == PIMPLE_IS_SERVICE && found_value->initialized == 1) {
  266 + pimple_free_bucket(&pimple_value);
  267 + zend_throw_exception_ex(spl_ce_RuntimeException, 0 TSRMLS_CC, "Cannot override frozen service \"%s\".", Z_STRVAL_P(offset));
  268 + return;
  269 + }
  270 + if (zend_hash_quick_update(&pimple_obj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, hash, (void *)&pimple_value, sizeof(pimple_bucket_value), NULL) == FAILURE) {
  271 + pimple_free_bucket(&pimple_value);
  272 + return;
  273 + }
  274 + Z_ADDREF_P(value);
  275 + break;
  276 + case IS_DOUBLE:
  277 + case IS_BOOL:
  278 + case IS_LONG:
  279 + if (Z_TYPE_P(offset) == IS_DOUBLE) {
  280 + index = (ulong)Z_DVAL_P(offset);
  281 + } else {
  282 + index = Z_LVAL_P(offset);
  283 + }
  284 + zend_hash_index_find(&pimple_obj->values, index, (void **)&found_value);
  285 + if (found_value && found_value->type == PIMPLE_IS_SERVICE && found_value->initialized == 1) {
  286 + pimple_free_bucket(&pimple_value);
  287 + zend_throw_exception_ex(spl_ce_RuntimeException, 0 TSRMLS_CC, "Cannot override frozen service \"%ld\".", index);
  288 + return;
  289 + }
  290 + if (zend_hash_index_update(&pimple_obj->values, index, (void *)&pimple_value, sizeof(pimple_bucket_value), NULL) == FAILURE) {
  291 + pimple_free_bucket(&pimple_value);
  292 + return;
  293 + }
  294 + Z_ADDREF_P(value);
  295 + break;
  296 + case IS_NULL: /* $p[] = 'foo' when overloaded */
  297 + zend_hash_next_index_insert(&pimple_obj->values, (void *)&pimple_value, sizeof(pimple_bucket_value), NULL);
  298 + Z_ADDREF_P(value);
  299 + break;
  300 + default:
  301 + pimple_free_bucket(&pimple_value);
  302 + zend_error(E_WARNING, "Unsupported offset type");
  303 + }
  304 +}
  305 +
  306 +static void pimple_object_unset_dimension(zval *object, zval *offset TSRMLS_DC)
  307 +{
  308 + FETCH_DIM_HANDLERS_VARS
  309 +
  310 + switch (Z_TYPE_P(offset)) {
  311 + case IS_STRING:
  312 + zend_symtable_del(&pimple_obj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1);
  313 + zend_symtable_del(&pimple_obj->factories, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1);
  314 + zend_symtable_del(&pimple_obj->protected, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1);
  315 + break;
  316 + case IS_DOUBLE:
  317 + case IS_BOOL:
  318 + case IS_LONG:
  319 + if (Z_TYPE_P(offset) == IS_DOUBLE) {
  320 + index = (ulong)Z_DVAL_P(offset);
  321 + } else {
  322 + index = Z_LVAL_P(offset);
  323 + }
  324 + zend_hash_index_del(&pimple_obj->values, index);
  325 + zend_hash_index_del(&pimple_obj->factories, index);
  326 + zend_hash_index_del(&pimple_obj->protected, index);
  327 + break;
  328 + default:
  329 + zend_error(E_WARNING, "Unsupported offset type");
  330 + }
  331 +}
  332 +
  333 +static int pimple_object_has_dimension(zval *object, zval *offset, int check_empty TSRMLS_DC)
  334 +{
  335 + FETCH_DIM_HANDLERS_VARS
  336 +
  337 + pimple_bucket_value *retval = NULL;
  338 +
  339 + switch (Z_TYPE_P(offset)) {
  340 + case IS_STRING:
  341 + if (zend_symtable_find(&pimple_obj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void **)&retval) == SUCCESS) {
  342 + switch (check_empty) {
  343 + case 0: /* isset */
  344 + return 1; /* Differs from PHP behavior (Z_TYPE_P(retval->value) != IS_NULL;) */
  345 + case 1: /* empty */
  346 + default:
  347 + return zend_is_true(retval->value);
  348 + }
  349 + }
  350 + return 0;
  351 + break;
  352 + case IS_DOUBLE:
  353 + case IS_BOOL:
  354 + case IS_LONG:
  355 + if (Z_TYPE_P(offset) == IS_DOUBLE) {
  356 + index = (ulong)Z_DVAL_P(offset);
  357 + } else {
  358 + index = Z_LVAL_P(offset);
  359 + }
  360 + if (zend_hash_index_find(&pimple_obj->values, index, (void **)&retval) == SUCCESS) {
  361 + switch (check_empty) {
  362 + case 0: /* isset */
  363 + return 1; /* Differs from PHP behavior (Z_TYPE_P(retval->value) != IS_NULL;)*/
  364 + case 1: /* empty */
  365 + default:
  366 + return zend_is_true(retval->value);
  367 + }
  368 + }
  369 + return 0;
  370 + break;
  371 + default:
  372 + zend_error(E_WARNING, "Unsupported offset type");
  373 + return 0;
  374 + }
  375 +}
  376 +
  377 +static zval *pimple_object_read_dimension(zval *object, zval *offset, int type TSRMLS_DC)
  378 +{
  379 + FETCH_DIM_HANDLERS_VARS
  380 +
  381 + pimple_bucket_value *retval = NULL;
  382 + zend_fcall_info fci = {0};
  383 + zval *retval_ptr_ptr = NULL;
  384 +
  385 + switch (Z_TYPE_P(offset)) {
  386 + case IS_STRING:
  387 + if (zend_symtable_find(&pimple_obj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void **)&retval) == FAILURE) {
  388 + zend_throw_exception_ex(spl_ce_InvalidArgumentException, 0 TSRMLS_CC, "Identifier \"%s\" is not defined.", Z_STRVAL_P(offset));
  389 + return EG(uninitialized_zval_ptr);
  390 + }
  391 + break;
  392 + case IS_DOUBLE:
  393 + case IS_BOOL:
  394 + case IS_LONG:
  395 + if (Z_TYPE_P(offset) == IS_DOUBLE) {
  396 + index = (ulong)Z_DVAL_P(offset);
  397 + } else {
  398 + index = Z_LVAL_P(offset);
  399 + }
  400 + if (zend_hash_index_find(&pimple_obj->values, index, (void **)&retval) == FAILURE) {
  401 + return EG(uninitialized_zval_ptr);
  402 + }
  403 + break;
  404 + case IS_NULL: /* $p[][3] = 'foo' first dim access */
  405 + return EG(uninitialized_zval_ptr);
  406 + break;
  407 + default:
  408 + zend_error(E_WARNING, "Unsupported offset type");
  409 + return EG(uninitialized_zval_ptr);
  410 + }
  411 +
  412 + if(retval->type == PIMPLE_IS_PARAM) {
  413 + return retval->value;
  414 + }
  415 +
  416 + if (zend_hash_index_exists(&pimple_obj->protected, retval->handle_num)) {
  417 + /* Service is protected, return the value every time */
  418 + return retval->value;
  419 + }
  420 +
  421 + if (zend_hash_index_exists(&pimple_obj->factories, retval->handle_num)) {
  422 + /* Service is a factory, call it everytime and never cache its result */
  423 + PIMPLE_CALL_CB
  424 + Z_DELREF_P(retval_ptr_ptr); /* fetch dim addr will increment refcount */
  425 + return retval_ptr_ptr;
  426 + }
  427 +
  428 + if (retval->initialized == 1) {
  429 + /* Service has already been called, return its cached value */
  430 + return retval->value;
  431 + }
  432 +
  433 + ALLOC_INIT_ZVAL(retval->raw);
  434 + MAKE_COPY_ZVAL(&retval->value, retval->raw);
  435 +
  436 + PIMPLE_CALL_CB
  437 +
  438 + retval->initialized = 1;
  439 + zval_ptr_dtor(&retval->value);
  440 + retval->value = retval_ptr_ptr;
  441 +
  442 + return retval->value;
  443 +}
  444 +
  445 +static int pimple_zval_is_valid_callback(zval *_zval, pimple_bucket_value *_pimple_bucket_value TSRMLS_DC)
  446 +{
  447 + if (Z_TYPE_P(_zval) != IS_OBJECT) {
  448 + return FAILURE;
  449 + }
  450 +
  451 + if (_pimple_bucket_value->fcc.called_scope) {
  452 + return SUCCESS;
  453 + }
  454 +
  455 + if (Z_OBJ_HANDLER_P(_zval, get_closure) && Z_OBJ_HANDLER_P(_zval, get_closure)(_zval, &_pimple_bucket_value->fcc.calling_scope, &_pimple_bucket_value->fcc.function_handler, &_pimple_bucket_value->fcc.object_ptr TSRMLS_CC) == SUCCESS) {
  456 + _pimple_bucket_value->fcc.called_scope = _pimple_bucket_value->fcc.calling_scope;
  457 + return SUCCESS;
  458 + } else {
  459 + return FAILURE;
  460 + }
  461 +}
  462 +
  463 +static int pimple_zval_to_pimpleval(zval *_zval, pimple_bucket_value *_pimple_bucket_value TSRMLS_DC)
  464 +{
  465 + _pimple_bucket_value->value = _zval;
  466 +
  467 + if (Z_TYPE_P(_zval) != IS_OBJECT) {
  468 + return PIMPLE_IS_PARAM;
  469 + }
  470 +
  471 + if (pimple_zval_is_valid_callback(_zval, _pimple_bucket_value TSRMLS_CC) == SUCCESS) {
  472 + _pimple_bucket_value->type = PIMPLE_IS_SERVICE;
  473 + _pimple_bucket_value->handle_num = Z_OBJ_HANDLE_P(_zval);
  474 + }
  475 +
  476 + return PIMPLE_IS_SERVICE;
  477 +}
  478 +
  479 +static void pimple_bucket_dtor(pimple_bucket_value *bucket)
  480 +{
  481 + zval_ptr_dtor(&bucket->value);
  482 + pimple_free_bucket(bucket);
  483 +}
  484 +
  485 +PHP_METHOD(Pimple, protect)
  486 +{
  487 + zval *protected = NULL;
  488 + pimple_object *pobj = NULL;
  489 + pimple_bucket_value bucket = {0};
  490 +
  491 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &protected) == FAILURE) {
  492 + return;
  493 + }
  494 +
  495 + if (pimple_zval_is_valid_callback(protected, &bucket TSRMLS_CC) == FAILURE) {
  496 + pimple_free_bucket(&bucket);
  497 + zend_throw_exception(spl_ce_InvalidArgumentException, "Callable is not a Closure or invokable object.", 0 TSRMLS_CC);
  498 + return;
  499 + }
  500 +
  501 + pimple_zval_to_pimpleval(protected, &bucket TSRMLS_CC);
  502 + pobj = (pimple_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
  503 +
  504 + if (zend_hash_index_update(&pobj->protected, bucket.handle_num, (void *)&bucket, sizeof(pimple_bucket_value), NULL) == SUCCESS) {
  505 + Z_ADDREF_P(protected);
  506 + RETURN_ZVAL(protected, 1 , 0);
  507 + } else {
  508 + pimple_free_bucket(&bucket);
  509 + }
  510 + RETURN_FALSE;
  511 +}
  512 +
  513 +PHP_METHOD(Pimple, raw)
  514 +{
  515 + zval *offset = NULL;
  516 + pimple_object *pobj = NULL;
  517 + pimple_bucket_value *value = NULL;
  518 + ulong index;
  519 +
  520 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &offset) == FAILURE) {
  521 + return;
  522 + }
  523 +
  524 + pobj = zend_object_store_get_object(getThis() TSRMLS_CC);
  525 +
  526 + switch (Z_TYPE_P(offset)) {
  527 + case IS_STRING:
  528 + if (zend_symtable_find(&pobj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void *)&value) == FAILURE) {
  529 + zend_throw_exception_ex(spl_ce_InvalidArgumentException, 0 TSRMLS_CC, "Identifier \"%s\" is not defined.", Z_STRVAL_P(offset));
  530 + RETURN_NULL();
  531 + }
  532 + break;
  533 + case IS_DOUBLE:
  534 + case IS_BOOL:
  535 + case IS_LONG:
  536 + if (Z_TYPE_P(offset) == IS_DOUBLE) {
  537 + index = (ulong)Z_DVAL_P(offset);
  538 + } else {
  539 + index = Z_LVAL_P(offset);
  540 + }
  541 + if (zend_hash_index_find(&pobj->values, index, (void *)&value) == FAILURE) {
  542 + RETURN_NULL();
  543 + }
  544 + break;
  545 + case IS_NULL:
  546 + default:
  547 + zend_error(E_WARNING, "Unsupported offset type");
  548 + }
  549 +
  550 + if (value->raw) {
  551 + RETVAL_ZVAL(value->raw, 1, 0);
  552 + } else {
  553 + RETVAL_ZVAL(value->value, 1, 0);
  554 + }
  555 +}
  556 +
  557 +PHP_METHOD(Pimple, extend)
  558 +{
  559 + zval *offset = NULL, *callable = NULL, *pimple_closure_obj = NULL;
  560 + pimple_bucket_value bucket = {0}, *value = NULL;
  561 + pimple_object *pobj = NULL;
  562 + pimple_closure_object *pcobj = NULL;
  563 + ulong index;
  564 +
  565 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz", &offset, &callable) == FAILURE) {
  566 + return;
  567 + }
  568 +
  569 + pobj = zend_object_store_get_object(getThis() TSRMLS_CC);
  570 +
  571 + switch (Z_TYPE_P(offset)) {
  572 + case IS_STRING:
  573 + if (zend_symtable_find(&pobj->values, Z_STRVAL_P(offset), Z_STRLEN_P(offset)+1, (void *)&value) == FAILURE) {
  574 + zend_throw_exception_ex(spl_ce_InvalidArgumentException, 0 TSRMLS_CC, "Identifier \"%s\" is not defined.", Z_STRVAL_P(offset));
  575 + RETURN_NULL();
  576 + }
  577 + if (value->type != PIMPLE_IS_SERVICE) {
  578 + zend_throw_exception_ex(spl_ce_InvalidArgumentException, 0 TSRMLS_CC, "Identifier \"%s\" does not contain an object definition.", Z_STRVAL_P(offset));
  579 + RETURN_NULL();
  580 + }
  581 + break;
  582 + case IS_DOUBLE:
  583 + case IS_BOOL:
  584 + case IS_LONG:
  585 + if (Z_TYPE_P(offset) == IS_DOUBLE) {
  586 + index = (ulong)Z_DVAL_P(offset);
  587 + } else {
  588 + index = Z_LVAL_P(offset);
  589 + }
  590 + if (zend_hash_index_find(&pobj->values, index, (void *)&value) == FAILURE) {
  591 + zend_throw_exception_ex(spl_ce_InvalidArgumentException, 0 TSRMLS_CC, "Identifier \"%ld\" is not defined.", index);
  592 + RETURN_NULL();
  593 + }
  594 + if (value->type != PIMPLE_IS_SERVICE) {
  595 + zend_throw_exception_ex(spl_ce_InvalidArgumentException, 0 TSRMLS_CC, "Identifier \"%ld\" does not contain an object definition.", index);
  596 + RETURN_NULL();
  597 + }
  598 + break;
  599 + case IS_NULL:
  600 + default:
  601 + zend_error(E_WARNING, "Unsupported offset type");
  602 + }
  603 +
  604 + if (pimple_zval_is_valid_callback(callable, &bucket TSRMLS_CC) == FAILURE) {
  605 + pimple_free_bucket(&bucket);
  606 + zend_throw_exception(spl_ce_InvalidArgumentException, "Extension service definition is not a Closure or invokable object.", 0 TSRMLS_CC);
  607 + RETURN_NULL();
  608 + }
  609 + pimple_free_bucket(&bucket);
  610 +
  611 + ALLOC_INIT_ZVAL(pimple_closure_obj);
  612 + object_init_ex(pimple_closure_obj, pimple_closure_ce);
  613 +
  614 + pcobj = zend_object_store_get_object(pimple_closure_obj TSRMLS_CC);
  615 + pcobj->callable = callable;
  616 + pcobj->factory = value->value;
  617 + Z_ADDREF_P(callable);
  618 + Z_ADDREF_P(value->value);
  619 +
  620 + if (zend_hash_index_exists(&pobj->factories, value->handle_num)) {
  621 + pimple_zval_to_pimpleval(pimple_closure_obj, &bucket TSRMLS_CC);
  622 + zend_hash_index_del(&pobj->factories, value->handle_num);
  623 + zend_hash_index_update(&pobj->factories, bucket.handle_num, (void *)&bucket, sizeof(pimple_bucket_value), NULL);
  624 + Z_ADDREF_P(pimple_closure_obj);
  625 + }
  626 +
  627 + pimple_object_write_dimension(getThis(), offset, pimple_closure_obj TSRMLS_CC);
  628 +
  629 + RETVAL_ZVAL(pimple_closure_obj, 1, 1);
  630 +}
  631 +
  632 +PHP_METHOD(Pimple, keys)
  633 +{
  634 + HashPosition pos;
  635 + pimple_object *pobj = NULL;
  636 + zval **value = NULL;
  637 + zval *endval = NULL;
  638 + char *str_index = NULL;
  639 + int str_len;
  640 + ulong num_index;
  641 +
  642 + if (zend_parse_parameters_none() == FAILURE) {
  643 + return;
  644 + }
  645 +
  646 + pobj = zend_object_store_get_object(getThis() TSRMLS_CC);
  647 + array_init_size(return_value, zend_hash_num_elements(&pobj->values));
  648 +
  649 + zend_hash_internal_pointer_reset_ex(&pobj->values, &pos);
  650 +
  651 + while(zend_hash_get_current_data_ex(&pobj->values, (void **)&value, &pos) == SUCCESS) {
  652 + MAKE_STD_ZVAL(endval);
  653 + switch (zend_hash_get_current_key_ex(&pobj->values, &str_index, (uint *)&str_len, &num_index, 0, &pos)) {
  654 + case HASH_KEY_IS_STRING:
  655 + ZVAL_STRINGL(endval, str_index, str_len - 1, 1);
  656 + zend_hash_next_index_insert(Z_ARRVAL_P(return_value), &endval, sizeof(zval *), NULL);
  657 + break;
  658 + case HASH_KEY_IS_LONG:
  659 + ZVAL_LONG(endval, num_index);
  660 + zend_hash_next_index_insert(Z_ARRVAL_P(return_value), &endval, sizeof(zval *), NULL);
  661 + break;
  662 + }
  663 + zend_hash_move_forward_ex(&pobj->values, &pos);
  664 + }
  665 +}
  666 +
  667 +PHP_METHOD(Pimple, factory)
  668 +{
  669 + zval *factory = NULL;
  670 + pimple_object *pobj = NULL;
  671 + pimple_bucket_value bucket = {0};
  672 +
  673 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &factory) == FAILURE) {
  674 + return;
  675 + }
  676 +
  677 + if (pimple_zval_is_valid_callback(factory, &bucket TSRMLS_CC) == FAILURE) {
  678 + pimple_free_bucket(&bucket);
  679 + zend_throw_exception(spl_ce_InvalidArgumentException, "Service definition is not a Closure or invokable object.", 0 TSRMLS_CC);
  680 + return;
  681 + }
  682 +
  683 + pimple_zval_to_pimpleval(factory, &bucket TSRMLS_CC);
  684 + pobj = (pimple_object *)zend_object_store_get_object(getThis() TSRMLS_CC);
  685 +
  686 + if (zend_hash_index_update(&pobj->factories, bucket.handle_num, (void *)&bucket, sizeof(pimple_bucket_value), NULL) == SUCCESS) {
  687 + Z_ADDREF_P(factory);
  688 + RETURN_ZVAL(factory, 1 , 0);
  689 + } else {
  690 + pimple_free_bucket(&bucket);
  691 + }
  692 +
  693 + RETURN_FALSE;
  694 +}
  695 +
  696 +PHP_METHOD(Pimple, offsetSet)
  697 +{
  698 + zval *offset = NULL, *value = NULL;
  699 +
  700 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz", &offset, &value) == FAILURE) {
  701 + return;
  702 + }
  703 +
  704 + pimple_object_write_dimension(getThis(), offset, value TSRMLS_CC);
  705 +}
  706 +
  707 +PHP_METHOD(Pimple, offsetGet)
  708 +{
  709 + zval *offset = NULL, *retval = NULL;
  710 +
  711 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &offset) == FAILURE) {
  712 + return;
  713 + }
  714 +
  715 + retval = pimple_object_read_dimension(getThis(), offset, 0 TSRMLS_CC);
  716 +
  717 + RETVAL_ZVAL(retval, 1, 0);
  718 +}
  719 +
  720 +PHP_METHOD(Pimple, offsetUnset)
  721 +{
  722 + zval *offset = NULL;
  723 +
  724 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &offset) == FAILURE) {
  725 + return;
  726 + }
  727 +
  728 + pimple_object_unset_dimension(getThis(), offset TSRMLS_CC);
  729 +}
  730 +
  731 +PHP_METHOD(Pimple, offsetExists)
  732 +{
  733 + zval *offset = NULL;
  734 +
  735 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &offset) == FAILURE) {
  736 + return;
  737 + }
  738 +
  739 + RETVAL_BOOL(pimple_object_has_dimension(getThis(), offset, 1 TSRMLS_CC));
  740 +}
  741 +
  742 +PHP_METHOD(Pimple, register)
  743 +{
  744 + zval *provider;
  745 + zval **data;
  746 + zval *retval = NULL;
  747 + zval key;
  748 +
  749 + HashTable *array = NULL;
  750 + HashPosition pos;
  751 +
  752 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "O|h", &provider, pimple_serviceprovider_ce, &array) == FAILURE) {
  753 + return;
  754 + }
  755 +
  756 + RETVAL_ZVAL(getThis(), 1, 0);
  757 +
  758 + zend_call_method_with_1_params(&provider, Z_OBJCE_P(provider), NULL, "register", &retval, getThis());
  759 +
  760 + if (retval) {
  761 + zval_ptr_dtor(&retval);
  762 + }
  763 +
  764 + if (!array) {
  765 + return;
  766 + }
  767 +
  768 + zend_hash_internal_pointer_reset_ex(array, &pos);
  769 +
  770 + while(zend_hash_get_current_data_ex(array, (void **)&data, &pos) == SUCCESS) {
  771 + zend_hash_get_current_key_zval_ex(array, &key, &pos);
  772 + pimple_object_write_dimension(getThis(), &key, *data TSRMLS_CC);
  773 + zend_hash_move_forward_ex(array, &pos);
  774 + }
  775 +}
  776 +
  777 +PHP_METHOD(Pimple, __construct)
  778 +{
  779 + zval *values = NULL, **pData = NULL, offset;
  780 + HashPosition pos;
  781 + char *str_index = NULL;
  782 + zend_uint str_length;
  783 + ulong num_index;
  784 +
  785 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|a!", &values) == FAILURE || !values) {
  786 + return;
  787 + }
  788 +
  789 + zend_hash_internal_pointer_reset_ex(Z_ARRVAL_P(values), &pos);
  790 + while (zend_hash_has_more_elements_ex(Z_ARRVAL_P(values), &pos) == SUCCESS) {
  791 + zend_hash_get_current_data_ex(Z_ARRVAL_P(values), (void **)&pData, &pos);
  792 + zend_hash_get_current_key_ex(Z_ARRVAL_P(values), &str_index, &str_length, &num_index, 0, &pos);
  793 + INIT_ZVAL(offset);
  794 + if (zend_hash_get_current_key_type_ex(Z_ARRVAL_P(values), &pos) == HASH_KEY_IS_LONG) {
  795 + ZVAL_LONG(&offset, num_index);
  796 + } else {
  797 + ZVAL_STRINGL(&offset, str_index, (str_length - 1), 0);
  798 + }
  799 + pimple_object_write_dimension(getThis(), &offset, *pData TSRMLS_CC);
  800 + zend_hash_move_forward_ex(Z_ARRVAL_P(values), &pos);
  801 + }
  802 +}
  803 +
  804 +/*
  805 + * This is PHP code snippet handling extend()s calls :
  806 +
  807 + $extended = function ($c) use ($callable, $factory) {
  808 + return $callable($factory($c), $c);
  809 + };
  810 +
  811 + */
  812 +PHP_METHOD(PimpleClosure, invoker)
  813 +{
  814 + pimple_closure_object *pcobj = NULL;
  815 + zval *arg = NULL, *retval = NULL, *newretval = NULL;
  816 + zend_fcall_info fci = {0};
  817 + zval **args[2];
  818 +
  819 + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &arg) == FAILURE) {
  820 + return;
  821 + }
  822 +
  823 + pcobj = zend_object_store_get_object(getThis() TSRMLS_CC);
  824 +
  825 + fci.function_name = pcobj->factory;
  826 + args[0] = &arg;
  827 + zend_fcall_info_argp(&fci TSRMLS_CC, 1, args);
  828 + fci.retval_ptr_ptr = &retval;
  829 + fci.size = sizeof(fci);
  830 +
  831 + if (zend_call_function(&fci, NULL TSRMLS_CC) == FAILURE || EG(exception)) {
  832 + efree(fci.params);
  833 + return; /* Should here return default zval */
  834 + }
  835 +
  836 + efree(fci.params);
  837 + memset(&fci, 0, sizeof(fci));
  838 + fci.size = sizeof(fci);
  839 +
  840 + fci.function_name = pcobj->callable;
  841 + args[0] = &retval;
  842 + args[1] = &arg;
  843 + zend_fcall_info_argp(&fci TSRMLS_CC, 2, args);
  844 + fci.retval_ptr_ptr = &newretval;
  845 +
  846 + if (zend_call_function(&fci, NULL TSRMLS_CC) == FAILURE || EG(exception)) {
  847 + efree(fci.params);
  848 + zval_ptr_dtor(&retval);
  849 + return;
  850 + }
  851 +
  852 + efree(fci.params);
  853 + zval_ptr_dtor(&retval);
  854 +
  855 + RETVAL_ZVAL(newretval, 1 ,1);
  856 +}
  857 +
  858 +PHP_MINIT_FUNCTION(pimple)
  859 +{
  860 + zend_class_entry tmp_pimple_ce, tmp_pimple_closure_ce, tmp_pimple_serviceprovider_iface_ce;
  861 + INIT_NS_CLASS_ENTRY(tmp_pimple_ce, PIMPLE_NS, "Container", pimple_ce_functions);
  862 + INIT_NS_CLASS_ENTRY(tmp_pimple_closure_ce, PIMPLE_NS, "ContainerClosure", NULL);
  863 + INIT_NS_CLASS_ENTRY(tmp_pimple_serviceprovider_iface_ce, PIMPLE_NS, "ServiceProviderInterface", pimple_serviceprovider_iface_ce_functions);
  864 +
  865 + tmp_pimple_ce.create_object = pimple_object_create;
  866 + tmp_pimple_closure_ce.create_object = pimple_closure_object_create;
  867 +
  868 + pimple_ce = zend_register_internal_class(&tmp_pimple_ce TSRMLS_CC);
  869 + zend_class_implements(pimple_ce TSRMLS_CC, 1, zend_ce_arrayaccess);
  870 +
  871 + pimple_closure_ce = zend_register_internal_class(&tmp_pimple_closure_ce TSRMLS_CC);
  872 + pimple_closure_ce->ce_flags |= ZEND_ACC_FINAL_CLASS;
  873 +
  874 + pimple_serviceprovider_ce = zend_register_internal_interface(&tmp_pimple_serviceprovider_iface_ce TSRMLS_CC);
  875 +
  876 + memcpy(&pimple_closure_object_handlers, zend_get_std_object_handlers(), sizeof(*zend_get_std_object_handlers()));
  877 + pimple_object_handlers = std_object_handlers;
  878 + pimple_closure_object_handlers.get_closure = pimple_closure_get_closure;
  879 +
  880 + pimple_closure_invoker_function.function_name = "Pimple closure internal invoker";
  881 + pimple_closure_invoker_function.fn_flags |= ZEND_ACC_CLOSURE;
  882 + pimple_closure_invoker_function.handler = ZEND_MN(PimpleClosure_invoker);
  883 + pimple_closure_invoker_function.num_args = 1;
  884 + pimple_closure_invoker_function.required_num_args = 1;
  885 + pimple_closure_invoker_function.scope = pimple_closure_ce;
  886 + pimple_closure_invoker_function.type = ZEND_INTERNAL_FUNCTION;
  887 + pimple_closure_invoker_function.module = &pimple_module_entry;
  888 +
  889 + return SUCCESS;
  890 +}
  891 +
  892 +PHP_MINFO_FUNCTION(pimple)
  893 +{
  894 + php_info_print_table_start();
  895 + php_info_print_table_header(2, "SensioLabs Pimple C support", "enabled");
  896 + php_info_print_table_row(2, "Pimple supported version", PIMPLE_VERSION);
  897 + php_info_print_table_end();
  898 +
  899 + php_info_print_box_start(0);
  900 + php_write((void *)ZEND_STRL("SensioLabs Pimple C support developed by Julien Pauli") TSRMLS_CC);
  901 + if (!sapi_module.phpinfo_as_text) {
  902 + php_write((void *)ZEND_STRL(sensiolabs_logo) TSRMLS_CC);
  903 + }
  904 + php_info_print_box_end();
  905 +}
  906 +
  907 +zend_module_entry pimple_module_entry = {
  908 + STANDARD_MODULE_HEADER,
  909 + "pimple",
  910 + NULL,
  911 + PHP_MINIT(pimple),
  912 + NULL,
  913 + NULL,
  914 + NULL,
  915 + PHP_MINFO(pimple),
  916 + PIMPLE_VERSION,
  917 + STANDARD_MODULE_PROPERTIES
  918 +};
  919 +
  920 +#ifdef COMPILE_DL_PIMPLE
  921 +ZEND_GET_MODULE(pimple)
  922 +#endif
... ...
vendor/pimple/pimple/ext/pimple/pimple_compat.h 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/pimple_compat.h
... ... @@ -0,0 +1,81 @@
  1 +
  2 +/*
  3 + * This file is part of Pimple.
  4 + *
  5 + * Copyright (c) 2014 Fabien Potencier
  6 + *
  7 + * Permission is hereby granted, free of charge, to any person obtaining a copy
  8 + * of this software and associated documentation files (the "Software"), to deal
  9 + * in the Software without restriction, including without limitation the rights
  10 + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  11 + * copies of the Software, and to permit persons to whom the Software is furnished
  12 + * to do so, subject to the following conditions:
  13 + *
  14 + * The above copyright notice and this permission notice shall be included in all
  15 + * copies or substantial portions of the Software.
  16 + *
  17 + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18 + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  19 + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  20 + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  21 + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  22 + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  23 + * THE SOFTWARE.
  24 + */
  25 +
  26 +#ifndef PIMPLE_COMPAT_H_
  27 +#define PIMPLE_COMPAT_H_
  28 +
  29 +#include "Zend/zend_extensions.h" /* for ZEND_EXTENSION_API_NO */
  30 +
  31 +#define PHP_5_0_X_API_NO 220040412
  32 +#define PHP_5_1_X_API_NO 220051025
  33 +#define PHP_5_2_X_API_NO 220060519
  34 +#define PHP_5_3_X_API_NO 220090626
  35 +#define PHP_5_4_X_API_NO 220100525
  36 +#define PHP_5_5_X_API_NO 220121212
  37 +#define PHP_5_6_X_API_NO 220131226
  38 +
  39 +#define IS_PHP_56 ZEND_EXTENSION_API_NO == PHP_5_6_X_API_NO
  40 +#define IS_AT_LEAST_PHP_56 ZEND_EXTENSION_API_NO >= PHP_5_6_X_API_NO
  41 +
  42 +#define IS_PHP_55 ZEND_EXTENSION_API_NO == PHP_5_5_X_API_NO
  43 +#define IS_AT_LEAST_PHP_55 ZEND_EXTENSION_API_NO >= PHP_5_5_X_API_NO
  44 +
  45 +#define IS_PHP_54 ZEND_EXTENSION_API_NO == PHP_5_4_X_API_NO
  46 +#define IS_AT_LEAST_PHP_54 ZEND_EXTENSION_API_NO >= PHP_5_4_X_API_NO
  47 +
  48 +#define IS_PHP_53 ZEND_EXTENSION_API_NO == PHP_5_3_X_API_NO
  49 +#define IS_AT_LEAST_PHP_53 ZEND_EXTENSION_API_NO >= PHP_5_3_X_API_NO
  50 +
  51 +#if IS_PHP_53
  52 +#define object_properties_init(obj, ce) do { \
  53 + zend_hash_copy(obj->properties, &ce->default_properties, zval_copy_property_ctor(ce), NULL, sizeof(zval *)); \
  54 + } while (0);
  55 +#endif
  56 +
  57 +#define ZEND_OBJ_INIT(obj, ce) do { \
  58 + zend_object_std_init(obj, ce TSRMLS_CC); \
  59 + object_properties_init((obj), (ce)); \
  60 + } while(0);
  61 +
  62 +#if IS_PHP_53 || IS_PHP_54
  63 +static void zend_hash_get_current_key_zval_ex(const HashTable *ht, zval *key, HashPosition *pos) {
  64 + Bucket *p;
  65 +
  66 + p = pos ? (*pos) : ht->pInternalPointer;
  67 +
  68 + if (!p) {
  69 + Z_TYPE_P(key) = IS_NULL;
  70 + } else if (p->nKeyLength) {
  71 + Z_TYPE_P(key) = IS_STRING;
  72 + Z_STRVAL_P(key) = estrndup(p->arKey, p->nKeyLength - 1);
  73 + Z_STRLEN_P(key) = p->nKeyLength - 1;
  74 + } else {
  75 + Z_TYPE_P(key) = IS_LONG;
  76 + Z_LVAL_P(key) = p->h;
  77 + }
  78 +}
  79 +#endif
  80 +
  81 +#endif /* PIMPLE_COMPAT_H_ */
... ...
vendor/pimple/pimple/ext/pimple/tests/001.phpt 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/tests/001.phpt
... ... @@ -0,0 +1,45 @@
  1 +--TEST--
  2 +Test for read_dim/write_dim handlers
  3 +--SKIPIF--
  4 +<?php if (!extension_loaded("pimple")) print "skip"; ?>
  5 +--FILE--
  6 +<?php
  7 +$p = new Pimple\Container();
  8 +$p[42] = 'foo';
  9 +$p['foo'] = 42;
  10 +
  11 +echo $p[42];
  12 +echo "\n";
  13 +echo $p['foo'];
  14 +echo "\n";
  15 +try {
  16 + var_dump($p['nonexistant']);
  17 + echo "Exception excpected";
  18 +} catch (InvalidArgumentException $e) { }
  19 +
  20 +$p[54.2] = 'foo2';
  21 +echo $p[54];
  22 +echo "\n";
  23 +$p[242.99] = 'foo99';
  24 +echo $p[242];
  25 +
  26 +echo "\n";
  27 +
  28 +$p[5] = 'bar';
  29 +$p[5] = 'baz';
  30 +echo $p[5];
  31 +
  32 +echo "\n";
  33 +
  34 +$p['str'] = 'str';
  35 +$p['str'] = 'strstr';
  36 +echo $p['str'];
  37 +?>
  38 +
  39 +--EXPECTF--
  40 +foo
  41 +42
  42 +foo2
  43 +foo99
  44 +baz
  45 +strstr
0 46 \ No newline at end of file
... ...
vendor/pimple/pimple/ext/pimple/tests/002.phpt 0 → 100644
  1 +++ a/vendor/pimple/pimple/ext/pimple/tests/002.phpt
... ... @@ -0,0 +1,15 @@
  1 +--TEST--
  2 +Test for constructor
  3 +--SKIPIF--
  4 +<?php if (!extension_loaded("pimple")) print "skip"; ?>
  5 +--FILE--
  6 +<?php
  7 +$p = new Pimple\Container();
  8 +var_dump($p[42]);
  9 +
  10 +$p = new Pimple\Container(array(42=>'foo'));
  11 +var_dump($p[42]);
  12 +?>
  13 +--EXPECT--
  14 +NULL
  15 +string(3) "foo"
... ...