Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
When registering a file handler, you specify a set of actions enabled by the file handler.
There are three built-in actions that a file handler can choose to support:
- newFile: File type appears in the New menu in OneDrive and SharePoint.
- open: Files can be opened by the file handler, which appears in the Open menu in OneDrive and SharePoint. Open actions are launched in a new browser tab.
- preview: Files can be previewed by the file handler. Preview occurs when the user left-clicks on a file in OneDrive and SharePoint. Preview actions are loaded in an- <IFRAME>element inside the OneDrive and SharePoint websites.
- custom: Files can use a file handler to create application defined actions. These additional actions appear in the toolbar in OneDrive and SharePoint, and can be added to any file extension.
Defining actions in the file handler manifest
Actions are defined in the file handler manifest within the actions key-value pair, which contains an array of actions supported by the file handler.
An example of the definition for the three built-in actions and a single custom action:
[
    {
        "type": "newFile",
        "url": "https://url/for/endpoint",
        "availableOn": {
            "file": { "extensions": [".bin"] },
            "web": { }
        }
    },
    {
        "type": "open",
        "url": "https://url/for/endpoint",
        "availableOn": {
            "file": { "extensions": [".bin"] },
            "web": { }
        }
    },
    {
        "type": "preview",
        "url": "https://url/for/endpoint",
        "availableOn": {
            "file": { "extensions": [".bin"] },
            "web": { }
        }
    },
    {
        "type": "custom",
        "url": "https://url/for/endpoint",
        "displayName": "Add Signature with Contoso",
        "shortDisplayName": "Add Signature",
        "icon": {
            "png1x": "https://url/for/icon.png"
        },
        "availableOn": {
            "file": { "extensions": ["*"] },
            "folder": { },
            "allowMultiSelect": true,
            "web": { }
        }
    }
]
Due to limitations in the Azure Active Directory addIn extensions, these actions are stored serialized into a string. It is recommended that you JSON minify the array before converting it to a string value to store in the manifest.
For example, the actions defined above would be stored in the file handler manifest like this:
{
    "type": "FileHandler",
    "properties": [
        {
            "key": "version",
            "value": "2"
        },
        {
            "key": "actions",
            "value": "[{\"type\":\"newFile\",\"url\":\"https://url/for/endpoint\",\"availableOn\":{\"file\":{\"extensions\":[\".bin\"]},\"web\":{}}},{\"type\":\"open\",\"url\":\"https://url/for/endpoint\",\"availableOn\":{\"file\":{\"extensions\":[\".bin\"]},\"web\":{}}},{\"type\":\"preview\",\"url\":\"https://url/for/endpoint\",\"availableOn\":{\"file\":{\"extensions\":[\".bin\"]},\"web\":{}}},{\"type\":\"custom\",\"url\":\"https://url/for/endpoint\",\"displayName\":\"Add Signature with Contoso\",\"shortDisplayName\":\"Add Signature\",\"icon\":{\"png1x\":\"https://url/for/icon.png\"},\"availableOn\":{\"file\":{\"extensions\":[\"*\"]},\"folder\":{},\"allowMultiSelect\":true,\"web\":{}}}]"
        }
    ]
}
Action parameters
Each action declared in the action parameter takes the following shape:
{
    "type": "newFile | open | preview | custom",
    "url": "url",
    "displayName": "string",
    "shortDisplayName": "string",
    "icon": { 
        "@odata.type": "microsoft.graph.displayIcon",
        "svg": "url",
        "png1x": "url",
        "png1_5x": "url",
        "png2x": "url"
    },
    "availableOn": {
        "@odata.type": "microsoft.graph.availableOn",
        "file": {
            "@odata.type": "microsoft.graph.availableOnFile",
            "extensions": [ ".pdf", ".png", ".psd" ]
        },
        "folder": {
            "@odata.type": "microsoft.graph.availableOnFolder"
        },
        "allowMultiSelect": false,
        "web": { "@odata.type": "microsoft.graph.availableOnWeb" }
    }
}
Properties
Not all properties are required, depending on the type of action specified.
| Parameter name | Type | Description | 
|---|---|---|
| type | string | A value of newFile,custom,open, orpreview. Required. | 
| url | URL | An https://URL for the endpoint that handles the file handler action. Required. | 
| displayName | string | A default locale string used to represent the action. Optional. Defaults to "Open in browser" for type: "open". | 
| shortDisplayName | string | A default locale string used to represent the action in the toolbar or collapsed action menu. Optional. | 
| availableOn | object | A collection of properties the define where this action is available. Required. | 
| icon | displayIcon | An object containing URLs to icon images for this file type. Optional. | 
AvailableOn Properties
By setting properties within the availableOn property, you can customize where the action is available:
| Parameter name | Type | Description | 
|---|---|---|
| file.extensions | array of strings | An array of the file extensions the action is available on. File extensions must start with a period (.). A wildcard character *can be used to indicate all file extensions for custom actions. | 
| folder | object | An object with no parameters indicates that the file handler is available when a folder is selected or when no files are selected. A null value or the property not being defined indicates the action is not available for folders. | 
| allowMultiSelect | boolean | If true, multiple files can be selected and the action will still be displayed. Iffalseor missing, the action is only displayed when a single item is selected. | 
| web | object | An object with no parameters indicates that the file handler is available when browsing the website. | 
- Only one file extension can be specified for actions of type newFile. This is the extension the newly created file will have. If multiple file extensions are listed, only the first file extension will be used.
- The folderandallowMultiSelectproperties are only applicable to actions of typecustom. These values are ignored for actions of any other type.