Architecture Overview
At this point we want to give a short overview of the architecture of Pimcore.
As usual, a picture is worth a thousand words:
This chart shows the architecture of a typical Pimcore application. Everything in blue is shipped directly with Pimcore, is an integral part of it, or is an extension of its Core that can be installed depending on the project's needs. The other components are printed in different colors.
Pimcore itself consists of the Pimcore Core and the MVC component. The Pimcore Core is the main application, which provides all the basic functionalities and can be started within the MVC component or in a headless way, for example via CLI scripts. The Pimcore Core is also responsible for accessing the persistence layer with Database, Filesystem and Cache-System.
Built upon the Pimcore Core, the MVC component provides all the necessary functionalities for interacting with Pimcore via the Browser or any other HTTP API client (REST, SOAP, ...).
The Core extensions can be installed via Composer, extending the Core functionalities with additional functions. Some of them are only provided by the Enterprise Edition.
Plugins and other custom modules/bundles can also be added via Composer and use the Pimcore Core functionalities via its API, or be used by the MVC component.
When implementing solutions with Pimcore, your custom parts should be in one of the following locations within the architecture:
- Apps/Website within the MVC component: Here are all the solution specific implementations like models, views and controllers for your website.
- Plugins/Bundles, custom modules: Here are all implementations and modules you might want to reuse in other projects. Like in other solutions out there, it's not mandatory to make a plugin out of every piece of code.