Preflight Checklist
Version
v.0.9.1
PHP version
7.4
Go version
No response
Expected Behavior
When the path prefix is changed, the library continues to work.
Actual Behavior
When changing the path prefix, the library does not work.
Steps To Reproduce
- Add to the
.proto file package apis.inter.services;
- Register a handler
$this->router->registerHandler(
MyServer::PATH_PREFIX,
new MyServer($this->service)
);
- After generating the MyServer class in the PATH_PREFIX constant:
final class MyServer implements RequestHandlerInterface
{
const PATH_PREFIX = '/twirp/apis.inter.services.My/';
//...
- But below the code (MyServer) we have a switch:
switch ($req->getUri()->getPath()) {
case '/twirp/apis.inter.services.My/Create': // <-- full path?
return $this->handleCreate($ctx, $req);
default:
return $this->writeError($ctx, $this->noRouteError($req));
}
This switch does not use path prefix from constructor in ANY way, which we specify when registering the handler. Looks like a serious mistake. Why pass a prefix if it's always the same?
Additional Information
No response
Preflight Checklist
Version
v.0.9.1
PHP version
7.4
Go version
No response
Expected Behavior
When the path prefix is changed, the library continues to work.
Actual Behavior
When changing the path prefix, the library does not work.
Steps To Reproduce
.protofilepackage apis.inter.services;This switch does not use path prefix from constructor in ANY way, which we specify when registering the handler. Looks like a serious mistake. Why pass a prefix if it's always the same?
Additional Information
No response