12 KiB
title, date, weight, geekdocRepo, geekdocEditPath, geekdocFilePath
| title | date | weight | geekdocRepo | geekdocEditPath | geekdocFilePath |
|---|---|---|---|---|---|
| Apps | 2018-05-02T00:00:00+00:00 | 10 | https://github.com/owncloud/ocis | edit/master/docs/extensions/storage | apps.md |
oCIS is all about files. But most of the time you want to do something with files that is beyond the basic upload, download and share behavior. Therefore, oCIS has a concept for apps, that can handle specific file types, so called mime types.
App provider capability
The capabilities endpoint (e.g. https://localhost:9200/ocs/v1.php/cloud/capabilities?format=json) gives you following capabilities which are relevant for the app provider:
{
"ocs": {
"data": {
"capabilities": {
"files": {
"app_providers": [
{
"enabled": true,
"version": "1.0.0",
"apps_url": "/app/list",
"open_url": "/app/open",
"new_url": "/app/new"
}
]
}
}
}
}
}
{{< hint info >}} Please note that there might be two or more app providers with different versions. This is not be expected to happen on a regular basis. It was designed for a possible migration period for clients when the app provider needs a breaking change. {{< /hint >}}
App registry
The app registry is the single point where all apps register themselves and their respective supported mime types.
Mime type configuration / creation allow list
The apps will register their supported mime types automatically, so that users can open supported files with them.
Administrators can set default applications on a per mime type basis and also allow the creation of new files for certain mime types. This per mime type configuration also features a description, file extension option and an icon.
In order to modify the mime type config you need to set STORAGE_APP_REGISTRY_MIMETYPES_JSON=.../mimetypes.json to a valid JSON file with content like this:
[
{
"mime_type": "application/vnd.oasis.opendocument.text",
"extension": "odt",
"name": "OpenDocument",
"description": "OpenDocument text document",
"icon": "https://some-website.test/opendocument-text-icon.png",
"default_app": "Collabora",
"allow_creation": true
},
{
"mime_type": "application/vnd.oasis.opendocument.spreadsheet",
"extension": "ods",
"name": "OpenSpreadsheet",
"description": "OpenDocument spreadsheet document",
"icon": "",
"default_app": "Collabora",
"allow_creation": false
}
]
Fields:
mime_typeis the mime type you want to configureextensionis the file extension to be used for new filesnameis the name of the file / mime typedescriptionis a human readable description of the file / mime typeiconURL to an icon which should be used for that mime typedefault_appname of the default app which opens this mime type when the user doesn't specify oneallow_creationis whether a user should be able to create new file from that mime type (trueorfalse)
Listing available apps / mime types
Clients, for example ownCloud Web, need to offer users the available apps to open files and mime types for new file creation. This information can be obtained from this endpoint.
Endpoint: specified in the capabilities in apps_url, currently /app/list
Method: HTTP GET
Authentication: None
Request example:
curl 'https://ocis.test/app/list'
Response example:
HTTP status code: 200
{
"mime-types": [
{
"mime_type": "application/pdf",
"ext": "pdf",
"app_providers": [
{
"name": "OnlyOffice",
"icon": "https://www.pikpng.com/pngl/m/343-3435764_onlyoffice-desktop-editors-onlyoffice-logo-clipart.png"
}
],
"name": "PDF",
"description": "PDF document"
},
{
"mime_type": "application/vnd.oasis.opendocument.text",
"ext": "odt",
"app_providers": [
{
"name": "Collabora",
"icon": "https://www.collaboraoffice.com/wp-content/uploads/2019/01/CP-icon.png"
},
{
"name": "OnlyOffice",
"icon": "https://www.pikpng.com/pngl/m/343-3435764_onlyoffice-desktop-editors-onlyoffice-logo-clipart.png"
}
],
"name": "OpenDocument",
"icon": "https://some-website.test/opendocument-text-icon.png",
"description": "OpenDocument text document",
"allow_creation": true,
"default_application": "Collabora"
},
{
"mime_type": "text/markdown",
"ext": "md",
"app_providers": [
{
"name": "CodiMD",
"icon": "https://avatars.githubusercontent.com/u/67865462?v=4"
}
],
"name": "Markdown file",
"description": "Markdown file",
"allow_creation": true,
"default_application": "CodiMD"
},
{
"mime_type": "application/vnd.ms-word.document.macroenabled.12",
"app_providers": [
{
"name": "Collabora",
"icon": "https://www.collaboraoffice.com/wp-content/uploads/2019/01/CP-icon.png"
},
{
"name": "OnlyOffice",
"icon": "https://www.pikpng.com/pngl/m/343-3435764_onlyoffice-desktop-editors-onlyoffice-logo-clipart.png"
}
]
},
{
"mime_type": "application/vnd.ms-powerpoint.template.macroenabled.12",
"app_providers": [
{
"name": "Collabora",
"icon": "https://www.collaboraoffice.com/wp-content/uploads/2019/01/CP-icon.png"
}
]
}
]
}
Open a file with the app provider
Endpoint: specified in the capabilities in open_url, currently /app/open
Method: HTTP POST
Authentication (one of them):
Authorizationheader with OIDC Bearer token for authenticated users or basic auth credentials (if enabled in oCIS)Public-Tokenheader with public link token for public linksX-Access-Tokenheader with a REVA token for authenticated users
Query parameters:
file_id(mandatory): id of the file to be openedapp_name(optional)- default (not given): default app for mime type
- possible values depend on the app providers for a mimetype from the
/app/openendpoint
view_mode(optional)- default (not given): highest possible view mode, depending on the file permissions
- possible values:
write: user can edit and download in the opening appread: user can view and download from the opening appview: user can view in the opening app (download is not possible)
Request examples:
curl -X POST 'https://ocis.test/app/open?file_id=ZmlsZTppZAo='
curl -X POST 'https://ocis.test/app/open?file_id=ZmlsZTppZAo=&app_name=Collabora'
curl -X POST 'https://ocis.test/app/open?file_id=ZmlsZTppZAo=&view_mode=read'
curl -X POST 'https://ocis.test/app/open?file_id=ZmlsZTppZAo=&app_name=Collabora&view_mode=write'
Response examples:
All apps are expected to be opened in an iframe and the response will give some parameters for that action.
There are apps, which need to be opened in the iframe with a form post. The form post must include all form parameters included in the response. For these apps the response will look like this:
HTTP status code: 200
{
"app_url": "https://.....",
"method": "POST",
"form_parameters": {
"access_token": "eyJ0...",
"access_token_ttl": "1634300912000",
"arbitrary_param": "lorem-ipsum"
}
}
There are apps, which need to be opened in the iframe with a GET request. The GET request must have set all headers included in the response. For these apps the response will look like this:
HTTP status code: 200
{
"app_url": "https://...",
"method": "GET",
"headers": {
"access_token": "eyJ0e...",
"access_token_ttl": "1634300912000",
"arbitrary_header": "lorem-ipsum"
}
}
Example responses (error case):
-
missing
file_idHTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "missing file ID" } -
wrong
view_modeHTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "invalid view mode" } -
unknown
app_nameHTTP status code: 404
{ "code": "RESOURCE_NOT_FOUND", "message": "error: not found: app 'Collabor' not found" } -
wrong / invalid file id
HTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "invalid file ID" } -
file id does not point to a file
HTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "the given file id does not point to a file" } -
file does not exist / unauthorized to open the file
HTTP status code: 404
{ "code": "RESOURCE_NOT_FOUND", "message": "file does not exist" }
Creating a file with the app provider
Endpoint: specified in the capabilities in new_file_url, currently /app/new
Method: HTTP POST
Authentication (one of them):
Authorizationheader with OIDC Bearer token for authenticated users or basic auth credentials (if enabled in oCIS)Public-Tokenheader with public link token for public linksX-Access-Tokenheader with a REVA token for authenticated users
Query parameters:
parent_container_id(mandatory): ID of the folder in which the file will be createdfilename(mandatory): name of the new filetemplate(optional): not yet implemented
Request examples:
curl -X POST 'https://ocis.test/app/new?parent_container_id=c2lkOmNpZAo=&filename=test.odt'
Response example:
You will receive a file id of the freshly created file, which you can use to open the file in an editor.
{
"file_id": "ZmlsZTppZAo="
}
Example responses (error case):
-
missing
parent_container_idHTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "missing parent container ID" } -
missing
filenameHTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "missing filename" } -
parent container not found
HTTP status code: 404
{ "code": "RESOURCE_NOT_FOUND", "message": "the parent container is not accessible or does not exist" } -
parent_container_iddoes not point to a containerHTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "the parent container id does not point to a container" } -
filenameis invalid (e.g. includes a path segment)HTTP status code: 400
{ "code": "INVALID_PARAMETER", "message": "the filename must not contain a path segment" } -
file already exists
HTTP status code: 403
{ "code": "RESOURCE_ALREADY_EXISTS", "message": "the file already exists" }
App drivers
App drivers represent apps, if the app is not able to register itself. Currently there is only the CS3org WOPI server app driver.
CS3org WOPI server app driver
The CS3org WOPI server app driver is included in oCIS by default. It needs at least one WOPI compliant app (e.g. Collabora, OnlyOffice or Microsoft Online Online Server) or a CS3org WOPI bridge supported app (CodiMD or Etherpad) and the CS3org WOPI server.
Here is a closer look at the configuration of the actual app provider in a docker-compose example (see also full example):
services:
ocis:
image: owncloud/ocis:latest
...
environment:
...
STORAGE_GATEWAY_GRPC_ADDR: 0.0.0.0:9142 # make the REVA gateway accessible to the app drivers
ocis-appdriver-collabora:
image: owncloud/ocis:latest
command: storage-app-provider server # start only the app driver
environment:
STORAGE_GATEWAY_ENDPOINT: ocis:9142 # oCIS gateway endpoint
APP_PROVIDER_GRPC_ADDR: 0.0.0.0:9164
APP_PROVIDER_EXTERNAL_ADDR: ocis-appdriver-collabora:9164 # how oCIS can reach this app driver
OCIS_JWT_SECRET: ocis-jwt-secret
APP_PROVIDER_DRIVER: wopi
APP_PROVIDER_WOPI_DRIVER_APP_NAME: Collabora # will be used as name for this app
APP_PROVIDER_WOPI_DRIVER_APP_ICON_URI: https://www.collaboraoffice.com/wp-content/uploads/2019/01/CP-icon.png # will be used as icon for this app
APP_PROVIDER_WOPI_DRIVER_APP_URL: https://collabora.owncloud.test # endpoint of collabora
APP_PROVIDER_WOPI_DRIVER_INSECURE: false
APP_PROVIDER_WOPI_DRIVER_IOP_SECRET: wopi-iop-secret
APP_PROVIDER_WOPI_DRIVER_WOPI_URL: https://wopiserver.owncloud.test # endpoint of the CS3org WOPI server