It 's all about namespacing. As long as your config file does not use namespaces the mysqlAdapter::class statement must be used as a use statement in your Module.php or with a forwarding backslash.
<?php
declare(strict_types=1);
namespace Application;
use mysqlAdapter;
class Module
{
public function getServiceConfig()
{
return [
'factories' => [
$dbAdapter = $container->get(mysqlAdapter::class);
// or as \mysqlAdapter::class without the use statement above
$resultSetPrototype = new ResultSet();
$resultSetPrototype->setArrayObjectPrototype(new Model\Member());
return new TableGateway('member', $dbAdapter, null, $resultSetPrototype);
]
];
}
}
Lambda functions still do not pose a problem. Looking at the current laminas/laminas-servicemanager package the class ServiceManager recognizes callables when getting factories. In line 534ff at ServiceManager.php factories are first, it is checked whether the specified factory is a string and the named class exists. This case covers factories as classes. Immediately afterwards, it is checked whether the specified factory is a callable. Since every factory class should implement the PSR __invoke() method, it is a callable, too. So the service manager handles classes and lambdas as well.
I myself prefer to write factories as classes, as this seems much clearer to me. The code is encapsulated and is exactly where it should be. However, callables are still a tried and tested means.
namespace Service\Factory;
use Psr\Container\ContainerInterface;
use Laminas\Db\Adapter\Adapter;
use Laminas\ServiceManager\Factory\FactoryInterface;
class ModelAdapterFactory implements FactoryInterface
{
public function __invoke(ContainerInterface $container, $requestedName, array $options = null)
{
$adapter = new Adapter($container->get('model-adapter-config'));
return $adapter;
}
}
I’ve to agree to disagree here with your approach. When a much easier and more understandable approach is defined here. Why should I go with your solution which is a sacrilege? Sacrilege is just used here in a humble sense. Don’t take it as an offence. Thanks!
Thanks for understanding. Agreed on coding is an art. But, when joining a community I have this dumb idea some configuration should resemble exactly what is shown by the people who have created this community. Then we bring everyone to some common way of writing. But that is just my dumb opinion. In the end thanks for understanding.