the zend framework provides a powerful module system. the module system has three components. they are as follows −
- module autoloader − a module autoloader is responsible for locating and loading of modules from variety of sources. it can load modules packaged as phar archives as well. the implementation of the module autoloader is located at myapp/vendor/zendframework/zend-loader/src/moduleautoloader.php. 
- module manager − once the module autoloader locates the modules, the module manager fires a sequence of events for each module. the implementation of the module manager is located at myapp/vendor/zendframework/zendmodulemanager/src/modulemanager.php. 
- module manager listeners − they can be attached to the events fired by the module manager. by attaching to the events of module manager, they can do everything from resolving and loading modules to performing complex work for each modules. 
mvc web module system
the mvc web application in the zend framework is usually written as modules. a single website can contain one or more modules grouped by functionality. the recommended structure for mvc-oriented module is as follows −
module_root/ 
   module.php 
   autoload_classmap.php 
   autoload_function.php 
   autoload_register.php 
   config/ 
      module.config.php 
   public/ 
      images/ 
      css/ 
      js/ 
   src/ 
      <module_namespace>/ 
      <code files> 
   test/ 
      phpunit.xml
      bootstrap.php 
      <module_namespace>/ 
         <test code files> 
   view/ 
      <dir-named-after-module-namespace>/ 
         <dir-named-after-a-controller>/ 
            <.phtml files>
the structure is same as discussed in the previous chapter, but here it is generic. the autoload_ files can be used as a default mechanism for autoloading the classes available in the module without using the advanced module manager available in the zend-modulemanager.
- autoload_classmap.php − returns an array of class name and its corresponding filename. 
- autoload_function.php − returns a php callback. this can utilize classes returned by autoload_classmap.php. 
- autoload_register.php − registers the php callback that is returned by the autoload_function.php. 
these autoload files are not required but recommended. in the skeleton application, we have not used the autoload_ files.
module class
the module class should be named module and the namespace of the module class should be module name. this will help the zend framework to resolve and load the module easily. the application module code in the skeleton(myapp) application,myapp/module/application/src/module.php is as follows −
namespace application; 
class module { 
   const version = '3.0.2dev'; 
   public function getconfig() { 
      return include __dir__ . '/../config/module.config.php'; 
   } 
}
the zend framework module manager will call the getconfig() function automatically and will do the necessary steps.
