Recently I have successfully completed the recertification of AD5-E113 (AEM as a Cloud Service Architect Recertification Exam) which is basically an extension of 'AD0-E117 - Adobe Certified Master - Adobe Experience Manager Sites Architect (Adobe Experience Manager)'.
My first thoughts We assume re-certifications are easy to deal with. But it is not always the case.
To clear the 'AD0-E117' we will have to be thorough with AEM basics and advanced concepts, but AD5-E113 AEM as a Cloud Service Architect Recertification Exam, we need to be double strong with (AEMaaCS)'AEM As a cloud service concepts'. Let us analyze the certification details further.
The certification duration is 1.5 Hrs and recertification can be taken through 'examity' certification portal. The certification areas and credits are broken down as below.
Architecture and design - 9 questions
System maintenance - 2 questions
Discovery - 3 questions
Solution Design - 9 questions
Implementation - 4 questions
Configuration and deployment - 8 questions
Maintenance - 4 questions
When I took the certification in the month of June 2022, it had 39 questions overall.
Below given pointers will definitely help you while preparing for the re-certification.
AEM as a cloud service specific questions were around below topics
Licensing and credits of AEMaaCS, Various environment concepts
AEMaaCS - IMS configurations
AEMaaCS Indexing concepts
AEMaaCS Code quality concepts
AEM as a cloud service(AEMaaCS) pipeline concepts like various gates and thresholds
AEMaaCS Git, branching and merging concepts when we have multiple repositories
AEMaaCS deployment error analysis
AEM Dispatcher configurations in generic and AEMaaCS changes like filters etc.
AEMaaCS Access levels and various permissions w.r.t developer, admin, business owner
AEMaaCS dispatcher changes while moving to AEM as a cloud
AEMaaCS asset concepts, architectural decisions
AEMaaCS replication(reverse) concepts and how to deal with it
AEMaaCS maintenance activities - who owns what
AEMaaCS DAM update asset workflow and related changes
AEMaaCS Logs and analysis options
Site performance w.r.t. AEMaaCS
Generic questions were from below topics
AEM Sling jobs
Sling Content Distribution
Dynamic media concepts around smartcroping, smart imaging
Valid template counts for specific types of AEM pages.
Site performance analysis and decissions to be made as an architect w.r.t dispatcher configurations or in generic
Final Note: My recommendation is, even though you are working as an AEM architect, you must go through the documentation of AEMaaCS(Preferrably the conceptual articles rather than the videos) multiple times before attempting the certification exam.
Watch Below Youtube Shorst, this will definitely help you !
There are cases where we might need to manage content beyond the capability of a CMS Solution. Component Content Management System (CCMS) lets you manage content at a component level by providing capability of managing content at granular levels. Here content is created in the form of components.
What is a component in CCMS? A component is a piece of structured & self-contained content. It can contain a single word, a series of paragraphs, an image, table, or a video. The components are written in a modular manner without any style dependency. Component manages the relationships and associations and tracks all its usage and status.
Metadata is the one piece which makes a component more efficient. Components also enhances the way of content publishing to multi channels effortlessly.
What are some of the common use cases of a CCMS?
Some of the major usecases of a CCMS are given below,
Product/Technical documentation
Help & Support Content
Datasheets/Data booklet
Policies and procedures
Long-form marketing content
CMS Vs CCMS CMS usually store content as pages or documents. But CCMS manage content as individual paragraphs and words. CCMS helps distribution of granular content by enabling re-use of the content instead of re-writing or copy/paste. It helps multi-channel publish to any output or system while providing content analytics with a built in security. Translation capabilities are one of the major feature in any CCMS.
An example implementation could be a chatbot picking up exact content from a CCMS and providing relevant information to user based on his query.
What is DITA w.r.t CCMS? Majority of the CCMS uses a structured open standard known as DITA (Darwin Information Typing Architecture ). DITA is a set of specification about document types for authoring and organizing topic-oriented information, as well as a set of mechanisms for combining, extending, and constraining document types.
Other platforms and programs can be easily integrated with a DITA Component Content Management System via REST/API calls.
Adobe's role in CCMS world.
'Adobe Experience Manager Guides' A CCMS from Adobe, provides a structured content management for experience-driven documentation. Adobe Experience Manager Guides is an end-to-end solution which is scalable, agile and cloud-native with below capabilities.
Web-based content creation, review and collaboration - Creation & migration of any content to DITA with the out-of-the-box ingestion framework via seamless workflow process
Omnichannel content experiences - Seamlessly delivers content to AEM sites, Mobile Apps, CRM, IoT,Chatbots and other forms
AI-powered documentation - Smart tagging & smart cropping based on Adobe Sensei for faster content discovery and delivery
Native integration with Adobe products - Built in integration with Adobe Creative Cloud and Adobe Experience Cloud
Cloud Enabled - Leveraging the Adobe Experience Manager cloud native capability of always current, scalable, secure & global.
Evolution of AEM from on-prem/AMS to AEM As Cloud service has reduced the security concerns to a certain limit. But there are areas an AEM architect should be concerned about, when the code moves to production.
Role of Application Security Testing (AST) The application security is a major consideration when new design techniques are adopted and DevSecOps are in demand. Application Security Testing (AST) tools available as On-Premise,Cloud or as a SaaS offering. The current tech-market comprises of Application Security Testing (AST) tools offering core testing capabilities — which can be of type static, dynamic, interactive and various optional, specialized capabilities testing;
Below given a set of the AST techniques in brief
Static AST (SAST): SAST analyzes an application’s source, bytecode or binary code for security vulnerabilities - Mainly during development & testing phases.
Dynamic AST (DAST): DAST analyzes applications in their running/dynamic state during testing mainly during operational phases. DAST Simulates the attack on web-application(AEM) and APIs(within the boundary of AEM application)
Software composition analysis (SCA): SCA is used to identify other open-source and, less frequently, commercial components in use within an AEM application. From this, known security vulnerabilities, potential licensing concerns and operational risks can be identified.
Interactive AST (IAST): IAST checks a running application, For e.g In case of AEM via the Java Virtual Machine [JVM] and examines its operation to identify vulnerabilities.
Fuzzing: Fuzz testing relies on providing random, malformed or unexpected input to a program to identify potential security vulnerabilities — For e.g., a memory leaks or buffer overflows or application crashes.
Mobile AST (MAST): MAST generally use traditional testing approaches (e.g., SAST and DAST) that have been optimized to support languages and frameworks commonly used to develop mobile and/or Internet of things (IoT) applications. Since mobile & IoT is a related technology with AEM, we must consider such techniques.
Some of the market leaders in AST
There are many AST tools available in market, but below given a set of tools which we came across during our evaluation. Synopsis, Checkmarx, Veracode, Contrast security, Invicti, Data Theorem are some of the options which can be considered for Application security testing.
Please comment if you have come across any other tools suitable for AEM projetcs.
Conclusion An architectural thought should be around the selection of tools available in market, the time frame for testing, frequency and penetration level etc.
The consideration for tool selection must factor pricing vs a freemium model, low-code applications, notification/ alert strategies, language options, IDE & Dashboard supports, customer experience etc.
What is Adobe WorkFront? Workfront is a Work management application, which helps organizations to organize entire work in single location.
Workfront helps manage projects, assign tasks, manage resources, documents, allocate finance, generate various reports, analytics reports etc. The tool basically helps standardize process and establish governance within any organization.
Using this tool, a Project Manager can create projects and related tasks, assign tasks to team, set end dates etc. Project status section captures all status of a project (based on details which are manually updated within system by end users).
What are all the default capabilities of WorkFront? Workfront by default provides project templates, custom forms, approval workflows which are highly customizable.
Below given a list of all capabilities of Workfront,
Agile Storyboard Management,
Resource Management,
Project Management and Tasks Management,
Project planning and scheduling,
Time tracking,
Manage Budgeting, Projections and Spendings,
Status tracking,
Task management and progress tracking,
Milestone, Time and Expense tracking,
Alerts and notifications,
Custom Dashboards
Workfront integration with AEM
Workfront can be easily integrated with Adobe Experience Manager. Using WorkFront, we can create projects, tasks (For e.g. marketing promotion project and its subtasks like asset design) and once assets are ready it can be pushed to AEM. We can also enrich asset metadata between systems once connected while syncing (push & pull) AEM assets to WorkFront.
AEM specific Features within Workfront We can have project link folders - which help to organize folders and taxonomy between AEM and WorkFront. We can also create folder and subfolders, metadata and link or sync between AEM & Workfront.
Metadata sync capability
The feature helps sync metadata between AEM & Workfront. We can create AEM metadata schema(Workfront Asset details) and send them to Workfront. Once linked, on AEM Assets metadata tab we will have Workfront Asset details tab where all metadata gets synced.
Version controlled between AEM & Workfront We can have versions of assets and manages them well between AEM & Workfront.
Content Creation and Sync We can create a task for content creation and this content can be made available in AEM as Content fragment modal. Once done, using the same project id, (content fragment modal + same project id) specific assets can be authored on a page.
Automation We can have actions, trigger activity on both AEM & Workfront.
AEM Workflow engine can be used to update Workfront tasks, attach custom forms to any of the work types, automate publishing events based on predefined conditions etc. once connector is configured AEM Workflow can have steps to do specific actions on Workfront.
Which version of AEM supported with Workfront? Workfront works on AEM 6.4 to AEM as Cloud Service
Workfront License We will see how Workfront licenses and access levels are tied together here. There are 4 types of paid Workfront licenses which allow different levels of access to Workfront. Each access level is attached to one of these below licenses.
As a Workfront administrator, instead of assigning a license to a user, we can assign them the access level attached to that license.
License - Associated access level ------------ ------------------------ Plan - System Administrator - Planner Work - Worker Review - Reviewer External - External User [Note: Not a paid license. Designed mainly for sharing documents with collaborators who don't use Workfront.] How to add users to Workfront If the organization has been onboarded to the Adobe Business Platform, we can perform this action through the Adobe Admin Console. There are various operatios allowed within Workfront[ For e.g. Grant a user admin access, Add a user, deactivate, delete, edit bulk edit, import users]
What are all the access types available in Workfront? There are 6 built-in access levels are designed for a particular type of user:
System Administrator (attached to the Plan license)
Planner (attached to the Plan license) - users who create and manage work (plan and manage project, build & share reports, add users, edit project templates, create portfolios)
Worker (attached to the Work license) - a normal employee who work on task based on project task assigned by a manager
Reviewer (attached to the Review license)
Requestor (attached to the Request license)
External User (attached to the External Email license)
Various permission w.r.t users Edit - Users can create, edit, delete, and share the Workfront object View - Users can review and share the Workfront object No Access - Users cannot access the Workfront object
Custom Permissions In case if we need a custom Planner, Worker, Requester, or Reviewer access level, we can copy the built-in access level and determine the amount of access we want it to allow for the various Workfront object types.
For the users who are assigned to it, an access level defines what they can see and do with the following object types and areas in Workfront:
Projects
Tasks
Issues
Portfolios
Reports, Dashboards, and Calendars
Filters, Views, and Groupings
Documents
Other users
Templates
Financial Data
Resource Management
Scenario Planner
Workfront Goals
Read more here SSO and Active Directory integration with Workfront? Active Directory & LDAP Support
We can configure Adobe Workfront with SAML 2.0, SAML 1.1 using ADFS, We can also configure Adobe Workfront with Azure Active Directory. Adobe recommend SAML 2 Always.
Workfront provides a centrally managed single sign-on (SSO) configuration that easily integrates Workfront with existing corporate SSO solution. This configuration is easy to set up and manage, and is available for both OnDemand and OnPremise Enterprise customers.
In order to use the SSO functionality in Workfront, organization needs to setup an SSO application, such as LDAP or Active Directory. We can then configure Workfront so that it can communicate with organizations SSO solution.
If the organization has been onboarded to the Adobe Business Platform, the users use the Adobe Business Platform to access Adobe Workfront. User management is mainly done through the Adobe Admin Console. i.e. Single Sign-On (SSO) is handled through the Adobe Business Platform rather than through Workfront
If organization has been onboarded to the Adobe Business Platform, Single Sign-On (SSO) is automatically enabled as part of that integration. There is no separate configuration required for same.
User Onboarding by import If there is an existing system that is already populated with users associated with SSO credentials, we can import the users' IDs into Workfront by importing a comma-separated values (CSV) file into Workfront.
Third Party Integrations We can integrate Adobe Workfront with third-party applications. These integrations can extend the utility of Workfront.
Built-in integrations We can configure integrations directly from Workfront, or from another application by installing the Workfront add-in for that application.
Built-in integrations cover many of the most common apps used by businesses, such as Dropbox, Slack, Google Drive, or Adobe products such as the Adobe Creative Cloud or Adobe Experience Manager Assets.
Custom OAuth2 applications Workfront administrators can create OAuth2 applications for their instance of Workfront, which allow other applications to access Workfront. Admin users can then give permission to those other applications to access their Workfront data. In this way, we can integrate Workfront with applications of our choice, including own in-house applications.
Workfront API Workfront offers a public API that enables to extend and enhance the Workfront experience. The goal for the Workfront API is to simplify building own integrations with Workfront by introducing a REST-ful architecture that operates over HTTP.
Webhooks Adobe Workfront Document Webhooks defines a set of API endpoints through which Workfront makes authorized API calls to an External Document Provider. This allows anyone to create a connector plugin for any document storage provider. What is Workfront Fusion? Workfront Fusion helps to connect with other platform applications by allowing you to automate workflows across multiple apps and web services(scenarios where the apps work together to execute a task). It provides a visual user interface to configure workflows. Development knowledge is not mandatory to work with Workfront Fusion.
Conclusion Workfront improves operational efficiency & accuracy while reducing need for more resource by enabling more automation.
The integration between AEM and Workfront is mainly around the AEM assets capability at present.
There are cases where we need to generate reports for a
users last log-in in AEM.
I have seen many help blogs but none of them worked for me. Below given an approach which worked for me.
Approach
Utilising 'AuthenticationInfoPostProcessor' service
in combination with ACS commons, its going to be easy to generate such
reports. This is tested on AEM 6.5 version.
Step1: Deploy below Java code which will capture lastLogin information.
Java class which captures the users last login and update the user node
Note: Modify the conditions as per your project requirement.
/** * Users last logged in will be his last active time in AEM * Executed only when it is a logout operation to ensure the last active time is captured * Ensure to update the code with relevant condition */ if ((info != null && info.getAuthType() == null) || (request != null && request.getServletPath() != null && (*Your condition 1*))) { LOGGER.debug("AuthenticationInfo is null. " + "we can skip post processing this request."); return; }
In my case I had used below conditions. (*Your condition 1*) - !request.getServletPath().equals("/system/sling/logout.html") (*Your condition 2*) - !auth.getID().equals("anonymous")
Step 2: ACS Commons Report Now in ACS common reports create a new report with query of type JCRSQL2
SELECT * FROM [rep:User] as nodes WHERE ISDESCENDANTNODE("/home/users") AND nodes.[profile/lastLoggedIn] IS NOT NULL AND NOT ISDESCENDANTNODE([/home/users/community]) AND NOT ISDESCENDANTNODE([/home/users/mac]) AND NOT ISDESCENDANTNODE([/home/users/rep:policy]) AND NOT ISDESCENDANTNODE([/home/users/screens]) AND NOT ISDESCENDANTNODE([/home/users/system])
And configure the report column as below.
Now you will be able to Generate the final report as shown below.
By default, AEM supports Assets that are smaller than 2 GB because of a file size limit. However, you can overwrite this limit by going into CRXDE Lite and creating a node under the /apps directory detailed in URL.
Is there any limit to upload an asset? It can be configured to 30 GB also. AEM doesnt define a size limit. What we need to ensure while changing the default behavior?
When we make this changes, ensure you take care of the time out limit on OSGi and Dispatcher idle time so that AEM keep listening the asset upload.
Also major point; consider the AEM's default asset processing, and hardware configurations while making this changes.