You can setup multi store views in Magneto and connect with AEM sites. Follow CIF-Add-On and create factory configurations for GraphQL. So let's start.
1) Create OSGI Configs for multi stores. for eg : you have 2 stores default and mystore then create 2 OSGI configs as per run-modes
In ui.config package , create json configs like below
com.adobe.cq.commerce.graphql.client.impl.GraphqlClientImpl~default.cfg.json
{
"url": "https://localhost.magento2brand1.com/graphql",
"identifier" : "default",
"httpMethod": "POST",
"allowHttpProtocol": "true",
"connectionTimeout": 1000000,
"requestPoolTimeout": 500000,
"socketTimeout": 1000000
}
com.adobe.cq.commerce.graphql.client.impl.GraphqlClientImpl~mystore.cfg.json
{
"url": "https://localhost.magento2brand2.com/graphql",
"identifier" : "mystore",
"httpMethod": "POST",
"allowHttpProtocol": "true",
"connectionTimeout": 1000000,
"requestPoolTimeout": 500000,
"socketTimeout": 1000000
}
Follow below steps to do CIF Cloud configurations.
Step-1:
If you already have created config folder under /conf folder from codebase then its fine. Otherwise follow below steps to create folder inside /conf
- Open author instance http://localhost:4502/aem/start.html
- Tools > General > Configuration Browser
data:image/s3,"s3://crabby-images/90471/904718bfa3e01734110ed3289ffff9a78542b0c8" alt="Configuration Browser-AEM Configuration Browser-AEM" |
Configuration Browser-AEM |
Click Create and below pop-up opens
data:image/s3,"s3://crabby-images/def84/def84e18ae597e3ec8bc4c39d302d1e2710409c1" alt="Create Configuration-AEM Create Configuration-AEM" |
Create Configuration-AEM |
Enter title of the project for site-1 and Check Cloud Configurations(mandate for cloud configs) and other options for editable templates enablement check editable templates and so on..
data:image/s3,"s3://crabby-images/05cf6/05cf6806711f9da5068eed68f091d6a742b23d46" alt="Project Configuration Project Configuration" |
Project Configuration |
Repeat step-1 for site-2
Step-2: Go to Tools>Cloud Services>CIF Configuration
data:image/s3,"s3://crabby-images/f139f/f139f899ad2b351d3d7d141ee6c9498684069b3b" alt="CIF Configuration-AEM CIF Configuration-AEM" |
CIF Configuration-AEM |
Select your project created in Step-1
data:image/s3,"s3://crabby-images/d1546/d15462322baf5fc37f3bd239abf7809d517c708a" alt="Configure Commerce Config Configure Commerce Config" |
Configure Commerce Config |
Click Create and select Commerce Configuration. It will create project specific commerce configuration.
Now Select/check commerce config created under <MyProject> and open properties. It will open below config window
data:image/s3,"s3://crabby-images/17582/17582411655c3a313edc332fd33962efd00c60f0" alt="GraphQL Store Configuration GraphQL Store Configuration" |
GraphQL Store Configuration |
Title- Same name of the
configuration created for commerce(default). You can change this title.
GraphQL Client * - Select store as
identifier from drop down. You have 2 OSGI configs. One is "default"
and second is "mystore". Select store view as per your requirement
for one of the site.
Store View- You can enter same
name as in identifier or skip as it is optional.
Catalog Root identifier- default
value
Language- Add language of the
store view. In my case it is for “en” so selected English(India)
Click Save and close.
Repeat step-2 for site-2
Step-3
Now open your site hierarchy. Go to http://localhost:4502/aem/start.html
- Select Sites. Select your first website
- Open properties
- Click Advance Tab
- Select cloud configuration from Cloud Configuration section(saved in step-2). It should be under /conf
data:image/s3,"s3://crabby-images/0031c/0031c3a30959f6b5140e85eda094ffc824cb35a9" alt="Configuration at page properties Configuration at page properties" |
Configuration at page properties |
data:image/s3,"s3://crabby-images/389de/389de5f6e77eef832401ac3ca67faa6d1b24cb37" alt="" |
Cloud config path under /conf |
Do same configuration for site-2
Now open your Product Listing Page(PLP) or detail page (PDP) to check your realtime data coming from magento store views.
Happy Coding!