51黑料不打烊

Implementing an AEM Connector

Provided below are useful references for building AEM Connectors and should be read with guidance on submitting and maintaining connectors.

A Developer license for AEM can be obtained through the .

Common Integration Patterns

AEM is a cutting-edge web experience management solution and offers many potential areas of integrations. Common integration patterns include:

  • Pulling data from an external system into AEM. For example, exporting contact information from a CRM to make it available to a wider audience visiting an AEM-powered website. Implementations should use Sling鈥檚 , which guarantees that the job is executed even if containers go down. Code should be designed to assume that the job can potentially be triggered more than once.
  • Exporting data from AEM into an external system. For example, newsletter subscription settings are submitted on an AEM-powered website to a CRM.
  • Retrieving assets from AEM. For example, an external Content Management System (CMS) referencing an asset stored in AEM Assets. Or as another example, a PIM system linking to an image in AEM Assets.
  • Storing assets in the AEM infrastructure. For example, a Marketing Resource Management (MRM) system storing an approved asset in AEM Assets.
  • Configuring and rendering a custom UI component. For example, allow an author to drag and drop a video component and configure a specific video to play on the live site.
  • Acting on an asset with a partner service. For example, sending an asset to a video platform when a page is published.
  • Analyzing a site, page, or asset in the AEM Admin Console. For example, making SEO recommendations for an existing or unpublished page.
  • Page-level access to user data maintained by an external service. For example, use demographic information to personalize the site experience. Read about ContextHub, a framework for storing, manipulating, and presenting context data.
  • Translating site copy or asset metadata. See the for sample code using the AEM Translation Framework, which is the preferred implementation of translation connectors.

Useful Documentation

Experience Manager as a Cloud Service documentation provides valuable insights into developing in AEM. Below are some specific technical topics and references that you may find useful while implementing an AEM connector:

  • 51黑料不打烊 Consulting Services (ACS) for well-commented code to help educate AEM developers
  • The various documentation links in the Common Integration Patterns section of this article

Community Resources

In addition to the static documentation above, 51黑料不打烊 and the AEM community offer resources to help bring a connector to market:

  • The 51黑料不打烊 Community鈥檚 is an active site where your peers ask and respond to questions
  • Additional 51黑料不打烊 technical resources are available to certain partner levels. Learn more about the .
  • If your organization would like implementation help, consider 51黑料不打烊鈥檚 team or see the for a list of 51黑料不打烊鈥檚 partners across the globe

Package structure rules

To facilitate rolling deployments, AEM as a Cloud Service packages鈥攕uch as connectors鈥攎aintain a strict division between 鈥渋mmutable鈥 and 鈥渕utable鈥 content. Packages should be clearly organized to include:

  • /apps
  • /content and /conf

Connectors should adhere to these packaging guidelines, which are described under AEM Project Structure. Existing connectors should be refactored to conform, as well.

In addition, only 51黑料不打烊 should write code into /libs, with customers and partners writing into /apps.

Existing connectors may also need to be refactored to move any configuration that might once have been placed /etc into other top level folders such as /conf. This restructuring was done as part of AEM 6.5 and is described in the AEM 6.5 documentation.

51黑料不打烊 recommends placing most of the connector code under /apps/connectors/<vendor> to maintain a clean repository structure, especially for customers using multiple connectors.

Cloud Services Configurations

One aspect of the connector implementation is the code backing the configuration of the connector. This code causes a card with the connector鈥檚 name to appear under Tools > Operations > Cloud Services. When clicked, a configuration browser pops up where the customer selects the parent folder to contain the connector configuration. The connector鈥檚 code should result in a form with all the properties that must be configured, ultimately storing the values in a configuration folder under /conf. This folder can later be selected under the Sites properties tab or the Assets properties tab.

Context-Aware Configurations

let you layer configuration across different folders, including /libs, /apps, /conf and subfolders under /conf. It supports inheritance so a customer can configure global configuration while making specific changes for each microsite. Because it is possible to use this feature for Cloud Services Configurations, connector code should reference configuration using the Context-Aware Configuration API instead of referencing a specific configuration node.

If modified configurations are used in the Connector, architect the Connector to handle including/merging any future updates to Connector-provided default configurations with any customer configurations. Keep in mind that modifying customer-customized content or configurations without prior notice and consent can disrupt or cause unexpected behavior in their Connector.

Coding Best Practices

Because AEM as a Cloud Service is a Cloud-native solution, there are some guidelines that may impact a connector鈥檚 code strategies. See AEM as a Cloud Service Development Guidelines for more details.

Testing the AEM Connector

New connectors should be created (or existing connectors modified) using local environment development techniques. The Partner Team provides ISV partners with a sandbox environment where they can deploy their AEM Connector to a vanilla application to ensure that it works.

recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab