Greetings! I'm Aneesh Sreedharan, CEO of 2Hats Logic Solutions. At 2Hats Logic Solutions, we are dedicated to providing technical expertise and resolving your concerns in the world of technology. Our blog page serves as a resource where we share insights and experiences, offering valuable perspectives on your queries.
Shopware has emerged as the popular integrated tool for creating online stores and apps. The simplicity of Shopware makes it accessible to users without a technical background, allowing them to easily use and master the platform, further enhancing its list of benefits. In this post, we’ll look at how to use Symfony and the Shopware App Bundle to build a simple Shopware app and set up an app server. We’ll go over the procedures for developing a Shopware app.
You can create and integrate your own app with Shopware by following these steps:
Step 1: Creating a Basic Shopware App
Create a Shopware App Directory: Let us begin with creating a new directory for your app inside the custom/apps directory of your Shopware installation. Choose a suitable name for your app, such as “MyExampleApp”.
Example directory structure:
└── custom
└── apps
└── MyExampleApp
└── manifest.xml
Define the manifest.xml File: The manifest.xml file serves as the core of your app, defining the interface between your app and the Shopware instance. It contains important information about your app. Open the manifest.xml file and add the following code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <?xml version="1.0" encoding="UTF-8"?> <manifest xmlns_xsi="http://www.w3.org/2001/XMLSchema-instance" xsi_noNamespaceSchemaLocation="https://raw.githubusercontent.com/shopware/platform/trunk/src/Core/Framework/App/Manifest/Schema/manifest-2.0.xsd"> <meta> <name>MyExampleApp</name> <label>Label</label> <label lang="de-DE">Name</label> <description>A description</description> <description lang="de-DE">Eine Beschreibung</description> <author>Your Company Ltd.</author> <copyright>(c) by Your Company Ltd.</copyright> <version>1.0.0</version> <icon>Resources/config/plugin.png</icon> <license>MIT</license> </meta> </manifest> |
Add Your App Logo: Create a new folder named Resources/config inside the MyExampleApp folder. Copy your app logo file (e.g., plugin.png) into the Resources/config folder.
Install and Activate the App: Utilize the Shopware CLI to install and activate your app. From the root directory of your Shopware installation, run the following command.
bin/console app:install –activate MyExampleApp
Step 2: Creating an App Server using Symfony and the Shopware App Bundle
Create a New Symfony Project: Start by creating a new Symfony project using the following command:
1 | composer create-project symfony/skeleton:"6.2.*" my-app |
Install the App Bundle: Navigate to the project directory and install the Shopware App Bundle using Composer:
cd my-app
composer require shopware/app-bundle
- Update the Database Details: Open the .env file in your Symfony project and update the DATABASE_URL parameter with your actual database connection details.
- Generate Migration Files: Install the necessary packages to generate migration files:
1 2 3 | composer require symfony/maker-bundle --dev composer require migrations |
1 2 3 | php bin/console make: migration php bin/console doctrine:migrations: migrate |
- Run the App Server: You can start the Symfony app server using the following command:
symfony server:start
This will run your app server at http://127.0.0.1:8000 by default.
Step 3: Connecting Shopware and the App Server
Open the Shopware manifest.xml file: Locate the manifest.xml file in your Shopware app project and add the following code inside the <setup> section:
1 2 3 4 5 6 7 | <setup> <registrationUrl>http://127.0.0.1:8000/app/lifecycle/register</registrationUrl> <secret>TestSecretCode</secret> </setup> |
Update the App Server Environment File: Open the environment file (usually .env) of your app server (Symfony project). Update the following lines:
###> shopware/app-bundle ###
SHOPWARE_APP_NAME=MyExampleApp
SHOPWARE_APP_SECRET=TestSecretCode
###< shopware/app-bundle ###
- Reinstall the Shopware App or Clear Cache: After making the changes, reinstall your Shopware app or clear the cache to apply the updates.
- Check the Shop Table in the App Server Database: After reinstalling the app, you can verify that the Shopware app’s details are inserted into the shop table of your app server’s database
By following these steps, you will have successfully set up the app server and connected Shopware with your app server. You can now start developing and integrating your app with Shopware.
Step 4: Creating a Custom Page in App Server (Symfony) and Connecting it to Shopware
Create a Controller: Generate a new controller file by running the following command in your terminal:
symfony console make:controller HomeController
Define a Custom Function in the Controller: Open the HomeController file and add a custom function. For example, let’s add a function named home:
- 1234567891011121314151617181920212223242526272829<?phpnamespace AppController;use SymfonyBundleFrameworkBundleControllerAbstractController;use SymfonyComponentHttpFoundationResponse;use SymfonyComponentRoutingAnnotationRoute;class HomeController extends AbstractController{#[Route('/home', name: 'home_app')]public function home(): Response{$data = 'Hello, this is my custom page!';return new Response($data);}}<span id="mce_marker" data-mce-type="bookmark" data-mce-fragment="1"></span>
Creating a Twig File: Install the Twig bundle by running the following command
composer require symfony/twig-bundle
This will install the necessary dependencies and configure Twig for your Symfony project.
Create the Twig template: Inside the templates folder (located in the src directory), create a new Twig template file named index.twig.html. Customize the content of the template according to your requirements. For example:
1 2 3 4 5 6 7 8 9 10 11 | <!DOCTYPE html> <html> <body> <h3>My new page</h3> </body> </html> |
Update your HomeController: Open the HomeController file and update the home function to render the Twig template we created earlier. Here’s an example:
1 2 3 4 5 6 7 | public function home(): Response { return $this->render('index.html.twig'); } |
Step 5: Connect the Interface to Shopware
Open the manifest.xml file of your Shopware app (MyExampleApp).
Inside the <admin> section, add the following code:
1 2 3 4 5 6 7 8 9 10 11 | <admin> <module name="MyExampleApp" source="http://127.0.0.1:8000/home" parent="sw-marketing" position="50"> <label>New Menu</label> <label lang="de-DE">Neues Menü</label> </module> </admin> |
- Clear the Cache or Reinstall Your App: To ensure that the changes in the manifest.xml file take effect, clear the cache or reinstall your app.
- Verify the Interface Integration: After clearing the cache or reinstalling your app, a new menu item should appear in the admin sidebar under the specified parent menu. It should be labeled as “New Menu” (or the corresponding label in the specified language.
If the iframe template does not load, make sure the following script tag is present in your app server’s index file (usually src/templates/index.html.twig):
1 | <img src="" data-wp-preserve="%3Cscript%3E%0A%20%20%20%20window.onload%20%3D%20()%20%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20window.parent.postMessage(%22sw-app-loaded%22%2C%20%22*%22)%3B%0A%20%20%20%20%7D%0A%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" /> |
Now you can create a custom page in your app server (Symfony) and easily connect it to your Shopware, enabling integration and functionality within the Shopware administration interface.
FAQ
What is AppServer in the context of Shopware app development?
AppServer is a powerful development tool provided by Shopware that allows developers to create custom applications, plugins, or extensions for the Shopware e-commerce platform. It serves as the backbone for app development, enabling seamless integration with Shopware's architecture and functionalities.
What programming languages can I use to create a Shopware app with AppServer?
AppServer primarily supports PHP for backend development and JavaScript (including frameworks like Vue.js) for frontend development. Developers can utilize PHP to create backend logic and process data, while JavaScript is used for building interactive user interfaces and enhancing the app's frontend experience.
Can I integrate custom databases or external APIs into my Shopware app using AppServer?
Yes, AppServer allows seamless integration of custom databases and external APIs into your Shopware app. You can connect your app to external data sources, fetch data, and use it within your application to offer enhanced functionalities to users.
Is it necessary to have prior experience with Shopware development to create an app using AppServer?
While prior experience with Shopware development can be beneficial, it is not a strict requirement. Basic knowledge of PHP, JavaScript, and web development concepts is recommended, as it will help you grasp the Shopware app development process more effectively. The Shopware documentation and community resources can also be valuable learning tools for beginners.