keywords | title | description | contributors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Manifest Version 2 |
This is the manifest version 2 page |
Each add-on bundle contains a manifest.json
file at the root level which defines the metadata for your add-on and how it should behave. This guide outlines the latest manifest version available, which is version 2.
{
"testId": "addon-sample",
"name": "Add-on Sample",
"version": "1.0.0",
"manifestVersion": 2,
"requirements": {
"apps": [
{
"name": "Express",
"apiVersion": 1
}
],
"supportsTouch": false,
},
"entryPoints": [
{
"type": "panel",
"id": "panel1",
"main": "index.html",
"documentSandbox": "code.js",
"permissions": {
"sandbox": ["allow-popups", "allow-presentation", "allow-downloads"],
"oauth": ["www.dropbox.com"]
}
}
]
}
Note: The ? denotes the key is optional.
Key | Type | Description |
---|---|---|
testId? |
string |
Used to uniquely identify an add-on among other add-ons during a development workflows only. This is auto-generated and inserted into the manifest by the CLI when an add-on is created. This is mandatory in the development workflow and ignored in add-ons submitted to the marketplace. |
name? |
string |
Add-on name for development workflow only. The name provided in the UI during submission is used in all other workflows. |
version |
string |
Add-on version in "major.minor.patch" format (e.g. "1.2.0") |
manifestVersion |
number |
Version of the manifest schema (e.g. 2). |
requirements |
object |
Specify the apps the add-on is applicable for. |
entryPoints |
object [] |
An entry point for your add-on. At least one is required. |
Key | Type | Description |
---|---|---|
apps |
object [] |
Add-on authors can specify the apps that the add-on is intended for. |
experimentalApis? |
boolean |
Add-ons can opt to use experimental apis by specifying this flag. This flag is only allowed during development and needs to be removed during submission. |
supportsTouch? |
boolean |
Whether the add-on supports touch-only devices. If not specified, the default value assumed is false . |
renditionPreview? |
boolean |
Ensure premium content preview is properly handled for free users when add-ons create renditions. |
Example:
"requirements": {
"apps": [
{
"name": "Express",
"apiVersion": 1,
"supportedDeviceClass": ["desktop"]
},
{…}],
"experimentalApis": true,
"supportsTouch": false,
"renditionPreview": true
}
Key | Type | Description |
---|---|---|
name |
string |
Currently supported values: "Express" |
apiVersion |
number |
API version that the add-on uses. Currently supported values: 1 |
supportedDeviceClass? |
string [] |
Supported platforms by the add-on. If not specified, the default value assumed is: ["desktop"] . |
Example:
"apps": [
{
"name": "Express",
"apiVersion": 1,
"supportedDeviceClass": ["desktop"]
}
],
The following platform value is currently supported in the supportedDeviceClass
key.
Platform | Description |
---|---|
desktop |
Browser on desktop. |
Key | Type | Description |
---|---|---|
type |
string |
The type of the entry point. Currently supported values: "panel" . |
id |
string |
Identifier for the entry point. Must be unique within the add-on. |
main |
string |
Main file for this entry point when launched. |
documentSandbox |
string |
File containing the JavaScript code to use with the document sandbox SDK and Adobe Express Document APIs. |
permissions |
object |
The permissions defined for this entry point. |
Example:
"entryPoints": [
{
"type": "panel",
"id": "panel1",
"main": "index.html",
"permissions": {
"sandbox": ["allow-popups", "allow-popups-to-escape-sandbox", "allow-presentation", "allow-downloads"],
"oauth": ["www.dropbox.com"]
}
}
]
Key | Type | Description |
---|---|---|
sandbox? |
string [] |
List of iframe sandbox permissions. |
oauth? |
string [] |
List of 3rd party auth server domains for which OAuth workflow may be requested. |
clipboard? |
string [] |
The allowed values for the list of clipboard permissions. Currently, clipboard-write is supported and allows an add-on to write arbitrary data to the clipboard. |
microphone? |
string |
The allowlists value used in iframe ‘allow’ attribute. Enables the add-on to access the user's microphone for audio input. |
camera? |
string |
The allowlists value used in iframe ‘allow’ attribute. Enables the add-on to access the user's camera for video input. |
Example:
"permissions" : {
"sandbox": [" allow-popups ", "allow-downloads"],
"oauth" : ["...", "..."],
"clipboard": ["clipboard-write"],
"microphone": "*",
"camera" : "*"
}
The following permission values are currently supported in the sandbox
key.
Permission | Description |
---|---|
allow-popups |
Allows popups (such as window.open() , target="_blank" , or showModalDialog() ). Note: If this permission is not set and you're using popups, the popup will silently fail to open. |
allow-popups-to-escape-sandbox |
Allows a sandboxed document to open new windows without forcing the sandboxing flags upon them |
allow-presentation |
Lets the add-on start a presentation session. |
allow-downloads |
Allows downloading files through an <a> or <area> element with the download attribute, as well as through the navigation that leads to a download of a file. |
Example:
"permissions" : {
"sandbox": ["allow-popups ", "allow-downloads"],
}
IMPORTANT: When implementing the premium content flows where you present a dialog or option to allow the user to upgrade, you must be sure to also include the following permissions in the sandbox
attribute of your manifest.json
. This will allow the Adobe Express pricing page to properly load:
"entryPoints": [
{
/*... other fields ...*/
"permissions": {
"sandbox": ["allow-popups-to-escape-sandbox", "allow-popups", "allow-downloads"]
}
}
]