Correspondência automática personalizada

Se a estratégia de correspondência automática padrão (correspondência automática OOTB) não estiver alinhada aos seus requisitos de negócios específicos, selecione a opção de correspondência personalizada. Esta opção oferece suporte ao uso do Adobe Developer App Builder para desenvolver um aplicativo de correspondência personalizado que lida com lógica de correspondência complexa ou com ativos provenientes de um sistema de terceiros que não pode preencher metadados no AEM Assets.

Configurar correspondência automática personalizada

  1. No Administrador do Commerce, navegue até Store > Configuração > ADOBE SERVICES > AEM Assets Integration.

  2. Selecione Custom Matcher como regra de correspondência.

  3. Ao selecionar esta regra de correspondência, o Administrador exibe campos adicionais para configurar os pontos de extremidade e os parâmetros de autenticação necessários para a lógica de correspondência personalizada.

workspace.json

O campo Adobe I/O Workspace Configuration fornece uma maneira simplificada de configurar a correspondência personalizada importando seu arquivo de configuração do App Builder workspace.json.

Você pode baixar o arquivo workspace.json da Adobe Developer Console. O arquivo contém todas as credenciais e detalhes de configuração do espaço de trabalho do App Builder.

Exemplo workspace.json
code language-json
{
  "project": {
    "id": "project_id",
    "name": "project_name",
    "title": "title_name",
    "org": {
      "id": "id",
      "name": "Organization_name",
      "ims_org_id": "ims_id"
    },
    "workspace": {
      "id": "workspace_id",
      "name": "workspace_name_id",
      "title": "workspace_title_id",
      "action_url": "https://action_url.net",
      "app_url": "https://app_url.net",
      "details": {
        "credentials": [
          {
            "id": "credential_id",
            "name": "credential_name_id",
            "integration_type": "oauth_server_to_server",
            "oauth_server_to_server": {
              "client_id": "client_id",
              "client_secrets": ["secret"],
              "technical_account_email": "xx@technical_account_email.com",
              "technical_account_id": "technical_account_id",
              "scopes": [
                "AdobeID",
                "openid",
                "read_organizations",
                "additional_info.projectedProductContext",
                "additional_info.roles",
                "adobeio_api",
                "read_client_secret",
                "manage_client_secrets"
              ]
            }
          }
        ],
        "services": [
          {
            "code": "AdobeIOManagementAPISDK",
            "name": "I/O Management API"
          }
        ],
        "runtime": {
          "namespaces": [
            {
              "name": "namespace_name",
              "auth": "example_auth"
            }
          ]
        },
        "events": {
          "registrations": []
        },
        "mesh": {}
      }
    }
  }
}
  1. Arraste e solte seu arquivo workspace.json do seu projeto do App Builder no campo Adobe I/O Workspace Configuration. Como alternativa, você pode clicar em para procurar e selecionar o arquivo.

Configuração do Workspace {width="600" modal="regular"}

  1. O sistema automaticamente:

    • Valida a estrutura JSON
    • Extrai e preenche credenciais do OAuth
    • Busca as ações de tempo de execução disponíveis para o espaço de trabalho
    • Preenche as opções suspensas para os campos Product to Asset URL e Asset to Product URL
  2. Selecione as ações de tempo de execução apropriadas nos menus suspensos para cada fluxo.

  3. Clique em Save Config.

Pontos de extremidade da API do correspondedor personalizado

Ao criar um aplicativo de correspondência personalizado usando o App Builder, o aplicativo deve expor os seguintes pontos de extremidade:

  • Ponto de extremidade Ativo App Builder para URL do produto
  • Ponto de extremidade Produto App Builder para URL do ativo

Ativo App Builder para endpoint do URL do produto

Esse endpoint recupera a lista de SKUs associadas a um determinado ativo:

Exemplo de uso

const { Core } = require('@adobe/aio-sdk')

async function main(params) {

    // Build your own matching logic here to return the products that map to the assetId
    // var productMatches = [];
    // params.assetId
    // params.eventData.assetMetadata['commerce:isCommerce']
    // params.eventData.assetMetadata['commerce:skus'][i]
    // params.eventData.assetMetadata['commerce:roles']
    // params.eventData.assetMetadata['commerce:positions'][i]
    // ...
    // End of your matching logic

    // Set skip to true if the mapping hasn't changed
    const skipSync = false;

    return {
        statusCode: 200,
        body: {
            asset_id: params.assetId,
            product_matches: [
                {
                    product_sku: "<YOUR-SKU-HERE>",
                    asset_roles: ["thumbnail", "image", "swatch_image", "small_image"],
                    asset_position: 1
                }
            ],
            skip: skipSync
        }
    };
}

exports.main = main;

Solicitação

POST https://your-app-builder-url/api/v1/web/app-builder-external-rule/asset-to-product
Parâmetro
Tipo de dados
Descrição
assetId
String
Representa a ID de ativo atualizada.
eventData
String
Retorna a carga de dados associada à ID do ativo.

Resposta

{
  "asset_id": "{ASSET_ID}",
  "product_matches": [
    {
      "product_sku": "{PRODUCT_SKU_1}",
      "asset_roles": ["thumbnail", "image"]
    },
    {
      "product_sku": "{PRODUCT_SKU_2}",
      "asset_roles": ["thumbnail"]
    }
  ],
  "skip": false
}
Parâmetro
Tipo de dados
Descrição
asset_id
String
A ID do ativo que está sendo correspondida.
product_matches
Matriz
Lista de produtos associados ao ativo.
skip
Booleano
(Opcional) Quando true, o mecanismo de regra ignora a sincronização para este ativo (nenhuma atualização de mapeamento de produto). Quando false ou for omitido, o processamento normal será executado. Consulte Ignorar processamento de sincronização.

Produto App Builder para endpoint do URL do ativo

Esse endpoint recupera a lista de ativos associados a determinada SKU:

Exemplo de uso

const { Core } = require('@adobe/aio-sdk')

async function main(params) {
    // return asset matches for a product
    // Build your own matching logic here to return the assets that map to the productSku
    // var assetMatches = [];
    // params.productSku
    // ...
    // End of your matching logic

    // Set skip to true if the mapping hasn't changed
    const skipSync = false;

    return {
        statusCode: 200,
        body: {
            product_sku: params.productSku,
            asset_matches: [
                {
                    asset_id: "<YOUR-ASSET-ID-HERE>", // urn:aaid:aem:1aa1d5i2-17h8-40a7-a228-e3ur588deee1
                    asset_roles: ["thumbnail", "image", "swatch_image", "small_image"],
                    asset_format: "image", // can be "image" or "video"
                    asset_position: 1
                }
            ],
            skip: skipSync
        }
    };
}

exports.main = main;

Solicitação

POST https://your-app-builder-url/api/v1/web/app-builder-external-rule/product-to-asset
Parâmetro
Tipo de dados
Descrição
productSKU
String
Representa o SKU do produto atualizado.
eventData
String
Retorna a carga de dados associada ao SKU do produto.

Resposta

{
  "product_sku": "{PRODUCT_SKU}",
  "asset_matches": [
    {
      "asset_id": "{ASSET_ID_1}",
      "asset_roles": ["thumbnail", "image"],
      "asset_position": 1,
      "asset_format": "image"
    },
    {
      "asset_id": "{ASSET_ID_2}",
      "asset_roles": ["thumbnail"],
      "asset_position": 2,
      "asset_format": "image"
    }
  ],
  "skip": false
}
Parâmetro
Tipo de dados
Descrição
product_sku
String
O SKU do produto que está sendo correspondido.
asset_matches
Matriz
Lista de ativos associados ao produto.
skip
Booleano
(Opcional) Quando true, o mecanismo de regra ignora a sincronização para este produto (nenhuma atualização de mapeamento de ativos). Quando false ou for omitido, o processamento normal será executado. Consulte Ignorar processamento de sincronização.

O parâmetro asset_matches contém os seguintes atributos:

Atributo
Tipo de dados
Descrição
asset_id
String
A ID do ativo.
asset_roles
Matriz
Funções do ativo. Usa funções de ativos do Commerce com suporte, como thumbnail, image, small_image e swatch_image.
asset_format
String
O formato do ativo. Os valores possíveis são image e video.
asset_position
Número
A posição do ativo na galeria de produtos.

Ignorar processamento de sincronização

O parâmetro skip permite que a correspondência personalizada ignore o processamento de sincronização de ativos ou produtos específicos.

Quando o aplicativo do App Builder retorna "skip": true na resposta, o mecanismo de regras não envia solicitações de atualização ou remoção de API para o Commerce desse ativo ou produto. Essa otimização reduz chamadas desnecessárias de API e melhora o desempenho.

recommendation-more-help
ca3e43e7-8fc7-412c-9d52-80a723c40cea