Edit in GitHubLog an issue

Create a mesh

This page provides the basic steps for creating your first mesh.

Requirements

Before creating a mesh, create a project or a templated project and workspace for the mesh. For other requirements see Prerequisites.

Create a project

When you create a mesh, you must assign the mesh to a specific project. To create a new project, log in to the Adobe Developer Console and create a project.

Add a workspace to your project

If you are creating a templated project, you can add workspaces. Workspaces allow you to create separate environments. You can also create workspaces for each developer on your team.

Workspaces that already have an API mesh will have "API Mesh" displayed on their workspace card in the developer console. To learn more about viewing, deleting, or selecting projects and workspaces, see Projects and workspaces.

workspace card

Create a mesh

  1. Create and save a JSON configuration file that defines the properties of your mesh. Your mesh is defined by a combination of handlers and transforms. In this example, the file name is mesh.json.

    The following mesh file can be used with minimal setup to access the endpoint of the Venia demo store.

    Copied to your clipboard
    {
    "meshConfig": {
    "sources": [
    {
    "name": "Commerce",
    "handler": {
    "graphql": {
    "endpoint": "https://venia.magento.com/graphql/"
    }
    }
    }
    ]
    }
    }
  2. Run the login command and provide your credentials in the browser window.

    Copied to your clipboard
    aio auth:login
  3. Run the following command to create a mesh. In this example, the file name is mesh.json.

    Copied to your clipboard
    aio api-mesh:create mesh.json
  4. If you have not already selected a project and workspace manually, choose the organization, project, and workspace that you want to create the mesh in. If you do not have a project, see Create a project.

    You must also indicate if you want to automatically select the specified organization and workspace in the future. If you answer Yes to either of these prompts and you want to select an organization or workspace other than the cached organization and workspace. You can use the -i or -ignoreCache flag to clear the cache, allowing you to select another organization and workspace. You can also manually modify the selected project or workspace.

    Note: Each workspace within a project can only have one mesh associated with it at a time.

  5. When you are prompted to confirm that you want to create a mesh, select Yes. If you want to automatically confirm the creation, add the -c or --autoConfirmAction flag to your create command.

    The aio api-mesh:create response assigns you a meshId. Use the aio api-mesh:status command to see the status of your mesh creation. You can run the aio api-mesh:describe command to get your apiKey and a GraphQL endpoint that you can use to query your mesh.

Access the gateway

The aio api-mesh:create response automatically assigns you an API key and subscribes that API key to the mesh service. You can also retrieve the API key by viewing the project in the Adobe Developer Console.

After you create a mesh, you can access the GraphQL endpoint in any GraphQL browser by modifying the following URL: https://graph.adobe.io/api/<meshId>/graphql?api_key=<your_apiKey>

Create a mesh from a source

The aio api-mesh:source commands provide several prebuilt mesh sources that you can use to create your mesh file, for example mesh.json. Each source contains a mesh configuration file designed for a specific first or third-party source. Third parties can submit their sources as a pull request to the api-mesh-sources repo. Once approved, these sources will be available for selection in the CLI.

Currently, this feature serves as a way for you to quickly copy an example mesh.

  1. To choose a prebuilt source from a list, run the following command:

    Copied to your clipboard
    aio api-mesh:source:discover

    Note: Alternatively, you can use the aio api-mesh:source:install command if you know the source you want to install.

  2. Use the arrow keys to select which source you want to copy and press Enter. You can use the Spacebar to select multiple sources.

  3. Confirm that you want to print the configuration in the console. The mesh configuration prints in your terminal and is automatically copied to your clipboard depending on your selections.

  4. Review the mesh configuration. When you are ready to install the mesh configuration, run the aio api-mesh:source:install command followed by the "<source_name>" you want to install, for example:

Copied to your clipboard
aio api-mesh:source:install "AEM Assets API"

You can repeat this process multiple times to add sources to your mesh.

Refer to the Command reference flags to learn how to replace variables in the source mesh configuration.

Create a mesh from a template

You can also create a mesh automatically when bootstrapping a new app through the CLI:

  1. Navigate to the location you want to initialize your project and enter the following command:

    Copied to your clipboard
    aio app init
  2. Select the desired organization, project, and workspace by using the arrow keys, or start typing to search.

  3. Select the generator-app-api-mesh standalone application.

  4. Indicate if you want this app to be a single-page application accessible through the Experience Cloud UI.

  5. Indicate if you want to create a sample mesh.

  6. After the process completes, you are provided a link to your API mesh endpoint.

  7. When you are ready, you can deploy your app by running the following command:

    Copied to your clipboard
    aio app deploy
  8. After the process completes, you are provided a link to your app at experience.adobe.com.

Mesh example

The following example adds both an Adobe Commerce instance (with Live Search enabled) and an Adobe Experience Manager instance to the mesh. The GraphQL endpoints for Commerce and Live Search are different, therefore you must configure them separately.

Copied to your clipboard
{
"meshConfig": {
"sources": [
{
"name": "Commerce",
"handler": {
"graphql": {
"endpoint": "https://<your_commerce_site>/graphql/"
}
}
},
{
"name": "AEM",
"handler": {
"graphql": {
"endpoint": "https://<your_AEM_site>/endpoint.json"
}
}
},
{
"name": "LiveSearch",
"handler": {
"graphql": {
"endpoint": "https://<your_commerce_site>/search/graphql",
"operationHeaders": {
"x-api-key": "search_gql",
"Magento-Environment-Id": "<your_environment_id>",
"Magento-Website-Code": "base",
"Content-Type": "application/json",
"Magento-Store-Code": "main_website_store",
"Magento-Store-View-Code": "default"
},
"schemaHeaders": {
"x-api-key": "search_gql",
"Magento-Environment-Id": "<your_environment_id>",
"Magento-Website-Code": "base",
"Content-Type": "application/json",
"Magento-Store-Code": "main_website_store",
"Magento-Store-View-Code": "default"
}
}
}
}
]
}
}

Update an existing mesh

If you make any changes to your mesh file, such as adding transforms, you must publish them before the changes will be reflected in your gateway. Additionally, if a source schema is modified, you must update your mesh to allow API Mesh to cache any changes.

The following command updates the mesh in the selected workspace with the settings specified in the update-mesh.json file.

Copied to your clipboard
aio api-mesh:update update-mesh.json
Copied to your clipboard
{
"meshConfig": {
"sources": [
{
"name": "Commerce",
"handler": {
"graphql": {
"endpoint": "https://<your_commerce_site>/graphql/"
}
}
},
{
"name": "AEM",
"handler": {
"graphql": {
"endpoint": "https://<your_AEM_site>/endpoint.json"
}
}
},
{
"name": "LiveSearch",
"handler": {
"graphql": {
"endpoint": "https://<your_commerce_site>/search/graphql",
"operationHeaders": {
"x-api-key": "search_gql",
"Magento-Environment-Id": "<your_environment_id>",
"Magento-Website-Code": "base",
"Content-Type": "application/json",
"Magento-Store-Code": "main_website_store",
"Magento-Store-View-Code": "default"
},
"schemaHeaders": {
"x-api-key": "search_gql",
"Magento-Environment-Id": "<your_environment_id>",
"Magento-Website-Code": "base",
"Content-Type": "application/json",
"Magento-Store-Code": "main_website_store",
"Magento-Store-View-Code": "default"
}
}
}
}
]
}
}

View your mesh in the Adobe Developer Console

As an alternative to running the aio api-mesh:get command, you can view your mesh details by selecting the API Mesh section in the desired workspace in the Adobe Developer Console.

On the API Mesh Details screen, you can use the tabs to view different segments of your mesh.

api mesh details

To download a copy of your mesh file, click the Download Mesh Schema button at the top of the API Mesh Details screen.

download mesh

Manually create an API Key (optional)

To access the gateway and perform GraphQL queries, you need to provide an API Key to authorize access to your mesh. To create your API Key:

  1. In Adobe Developer Console, select the desired organization from the dropdown in the top-right corner.

    create a project

  2. Select an existing project or create a new one.

  3. Inside the project, click Add API.

    add an api

  4. Select API Mesh for Adobe Developer App Builder and click Next.

    add an api mesh

  5. The Allowed Domain field is not currently enforced. Enter any valid test domain to proceed.

    add an allowed domain

  6. Click Save configured API. Copy your API Key from the Project Overview page.

    api key

You can return to the Project Overview page whenever you need to retrieve your API Key.

Next steps

  • Privacy
  • Terms of Use
  • Do not sell or share my personal information
  • AdChoices
Copyright © 2023 Adobe. All rights reserved.