Java-based API for creating and activating packages id175UB30E05Z
The following Java-based API allows you to create and activate CRX packages. This API is available in the form of a bundle. You must include this bundle in your code to use this APIs.
Bundle details:
-
Group ID: com.adobe.fmdita
-
Artifact ID: api
-
Version: 3.3
-
Package: com.adobe.fmdita.api.crxactivate
-
Class details:
code language-java public class CRXActivator
The
CRXActivator
class contains a method for creating CRX packages and replicating it on the publish instance.
Create and activate packages
The activate
method creates a CRX package on the author instance and replicates it on the publish instance, if required. It is assumed that the AEM replication parameters have already been setup on the author instance. This method creates the CRX package based on a list of rules provided as input parameters in a JSON string.
outputstream
.Example with two parameters
Syntax:
public static void activate
(
String json,
OutputStream outputstream,
Session session
)
throws GuidesApiException
Example with third optional parameter
public static void activate
(
String json,
OutputStream outputstream,
String activationTarget,
Session session
)
throws GuidesApiException
Parameters:
json
-
activate
: Is of type Boolean (true
/false
). Determines whether the CRX package created in the author instance is replicated to the publish instance.-
rules
: Is of type JSON Array. An array of JSON rules, which are processed sequentially to build the CRX package.-
rootPath
: Is of type String. The base path upon which the node/property queries are executed. If no node/property queries are present, the root path and all nodes present under the root path are included in the CRX package.-
nodeQueries
: Is of type Regex Array. An array of regular expressions used to include specific files under the root path.-
propertyQueries
: Is of type JSON Array. An array of JSON Objects with each JSON Object consisting of an XPath query to be executed on the root path and the name of a property present in each JCR node after the query is executed. The value of the property in each JCR node should be a path or an array of paths. The paths present in this property are added to the CRX package.outputstream
outputstream
. This is useful for debugging.session
activationTarget
preview
or publish
for Cloud Service and publish
for On-premise Software- For Cloud Service, if the parameter contains an invalid value, then the package activation fails.
- For On-Premise Software, if the parameter contains an invalid value, the error is logged, and publishing is done using the default value,
publish
.Exception:
Throws java.io.IOException
and java.io.IllegalArgumentException
If you do not define the optional parameter, activationTarget
, it activates using the default publish agent for both Cloud Service and On-premise Software.
Example:
The following example shows how to build a JSON query:
{
"activate": true,
"rules": [
{
"rootPath": "/content/dam/nested",
"nodeQueries": [
".*\\.jpg",
".*\\.png",
".*\\.gif"
]
},
{
"rootPath": "/content/output/sites/hierarchy_ditamap"
},
{
"rootPath": "/content/output/sites/hierarchy_ditamap",
"propertyQueries": [
{
"query": "//*[@fileReference]",
"property": "fileReference"
}
]
}
]
}
The example JSON query consists of the following rules:
- Only the .png, .jpg, and .gif images under /content/dam/nested path are included in the package.
- All node under /content/output/sites/hierarchy_ditamap are included in the package.
- The paths present in the
fileReference
property of nodes under /content/output/sites/hierarchy_ditamap are included in the package.