# owncloud-onlyoffice **Repository Path**: vianjun/owncloud-onlyoffice ## Basic Information - **Project Name**: owncloud-onlyoffice - **Description**: owncloud-onlyoffice - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-10-13 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # ![onlyoffice icon](screenshots/icon.png) ownCloud ONLYOFFICE integration app This app allows users to edit office documents from [ownCloud](https://owncloud.com) using ONLYOFFICE Document Server - [Community or Integration Edition](#onlyoffice-document-server-editions). ## Features The app allows to: * Create and edit text documents, spreadsheets, and presentations. * Share files with different permission types - viewing/editing, commenting, reviewing, filling forms. It's also possible to restrict downloading (in all editors) and modifying filters (in spreadshhets). Sharing via public link is also available. * Co-edit documents in real-time: use two co-editing modes (Fast and Strict), Track Changes, comments, and built-in chat. Co-editing is also available several federated ownCloud instances connected to one Document Server. Supported formats: * For viewing and editing: DOCX, XLSX, PPTX, CSV, TXT. * For viewing only: PDF. * For converting to Office Open XML formats: DOC, DOCM, DOT, DOTX, EPUB, HTM, HTML, ODP, ODT, POT, POTM, POTX, PPS, PPSM, PPSX, PPT, PPTM, RTF, XLS, XLSM, XLT, XLTM, XLTX. ODT, ODS, and ODP is also available for instant conversion. After you enable the corresponding option in the admin settings, ODF-formatted documents are immediately converted in the editor and opened after you click on it. ## Installing ONLYOFFICE Document Server You will need an instance of ONLYOFFICE Document Server that is resolvable and connectable both from ownCloud and any end clients (version 4.2.7 and later are supported for use with the app). ONLYOFFICE Document Server must also be able to POST to ownCloud directly. ONLYOFFICE Document Server and ownCloud can be installed either on different computers, or on the same machine. If you use one machine, set up a custom port for Document Server as by default both ONLYOFFICE Document Server and ownCloud work on port 80. You can install free Community version of ONLYOFFICE Document Server or scalable enterprise-level Integration Edition. To install free Community version, use [Docker](https://github.com/onlyoffice/Docker-DocumentServer) (recommended) or follow [these instructions](https://helpcenter.onlyoffice.com/server/linux/document/linux-installation.aspx) for Debian, Ubuntu, or derivatives. To install Integration Edition, follow instructions [here](https://helpcenter.onlyoffice.com/server/integration-edition/index.aspx). Community Edition vs Integration Edition comparison can be found [here](#onlyoffice-document-server-editions). To use ONLYOFFICE behind a proxy, please refer to [this article](https://helpcenter.onlyoffice.com/server/document/document-server-proxy.aspx). You can also use our **[Docker installation](https://github.com/ONLYOFFICE/docker-onlyoffice-owncloud)** to install pre-configured Document Server (free version) and ownCloud with a couple of commands. ## Installing ownCloud ONLYOFFICE integration app The ownCloud administrator can install the integration app from the in-built application market. For that click the upper-left hamburger menu and select **Market**. After that find **ONLYOFFICE** in the list of available applications and install it. If the server with the ownCloud installed does not have an Internet access, or if you need it for some other reason, the administrator can install the application manually: 1. Go to the ownCloud server _apps/_ directory (or some other directory [used](https://doc.owncloud.org/server/admin_manual/installation/apps_management_installation.html#using-custom-app-directories)): ```bash cd apps/ ``` 2. Get the ownCloud ONLYOFFICE integration app. There are several ways to do that: a. Download the latest signed version from the official store for [ownCloud](https://marketplace.owncloud.com/apps/onlyoffice). b. Or you can download the latest signed version from the application [release page](https://github.com/ONLYOFFICE/onlyoffice-owncloud/releases) on GitHub. c. Or you can clone the application source code and compile it yourself: ```bash git clone https://github.com/ONLYOFFICE/onlyoffice-owncloud.git onlyoffice ``` > ownCloud does not work with unsigned applications giving an alert, so you will need to use either option **a** or **b** to get the application. 3. Change the owner to update the application right from ownCloud web interface: ```bash chown -R www-data:www-data onlyoffice ``` 4. In ownCloud open the `~/settings/admin?sectionid=apps&category=disabled` page with _Not enabled_ apps by administrator and click _Enable_ for the **ONLYOFFICE** application. ## Configuring ownCloud ONLYOFFICE integration app In ownCloud open the `~/settings/admin?sectionid=additional#onlyoffice` page with administrative settings for **ONLYOFFICE** section. Enter the following address to connect ONLYOFFICE Document Server: ```bash https:/// ``` Where the **documentserver** is the name of the server with the ONLYOFFICE Document Server installed. The address must be accessible for the user browser and from the ownCloud server. The ownCloud server address must also be accessible from ONLYOFFICE Document Server for correct work. Sometimes your network configuration might not allow the requests between installed ownCloud and ONLYOFFICE Document Server using the public addresses. The _Advanced server settings_ allows to set the ONLYOFFICE Document Server address for internal requests from ownCloud server and the returning ownCloud address for the internal requests from ONLYOFFICE Document Server. You need to enter them in the appropriate fields. To restrict the access to ONLYOFFICE Document Server and for security reasons and data integrity the encrypted signature is used. Specify the _Secret key_ in the ownCloud administrative configuration. In the ONLYOFFICE Document Server [config file](https://api.onlyoffice.com/editors/signature/) specify the same secret key and enable the validation. Enable or disable the _Open file in the same tab_ setting. The **Open in ONLYOFFICE** action will be added to the file context menu. You can specify this action as default and it will be used when the file name is clicked for the selected file types. ## How it works The ONLYOFFICE integration follows the API documented [here](https://api.onlyoffice.com/editors/basic): * When creating a new file, the user navigates to a document folder within ownCloud and clicks the **Document**, **Spreadsheet** or **Presentation** item in the _new_ (+) menu. * The browser invokes the `create` method in the `/lib/Controller/EditorController.php` controller. This method adds the copy of the file from the assets folder to the folder the user is currently in. * Or, when opening an existing file, the user navigates to it within ownCloud and selects the **Open in ONLYOFFICE** menu option. * A new browser tab is opened and the `index` method of the `/lib/Controller/EditorController.php` controller is invoked. * The app prepares a JSON object with the following properties: * **url** - the URL that ONLYOFFICE Document Server uses to download the document; * **callbackUrl** - the URL that ONLYOFFICE Document Server informs about status of the document editing; * **documentServerUrl** - the URL that the client needs to respond to ONLYOFFICE Document Server (can be set at the administrative settings page); * **key** - the etag to instruct ONLYOFFICE Document Server whether to download the document again or not; * ownCloud takes this object and constructs a page from `templates/editor.php` template, filling in all of those values so that the client browser can load up the editor. * The client browser makes a request for the javascript library from ONLYOFFICE Document Server and sends ONLYOFFICE Document Server the DocEditor configuration with the above properties. * Then ONLYOFFICE Document Server downloads the document from ownCloud and the user begins editing. * ONLYOFFICE Document Server sends a POST request to the _callbackUrl_ to inform ownCloud that a user is editing the document. * When all users and client browsers are done with editing, they close the editing window. * After [10 seconds](https://api.onlyoffice.com/editors/save#savedelay) of inactivity, ONLYOFFICE Document Server sends a POST to the _callbackUrl_ letting ownCloud know that the clients have finished editing the document and closed it. * ownCloud downloads the new version of the document, replacing the old one. ## Known issues * Adding the storage using the **External storages** app has issues with the co-editing in some cases. If the connection is made using the same authorization keys (the _Username and password_ or _Global credentials_ authentication type is selected), then the co-editing is available for the users. If different authorization keys are used (_Log-in credentials, save in database_ or _User entered, store in database_ authentication options), the co-editing is not available. When the _Log-in credentials, save in session_ authentication type is used, the files cannot be opened in the editor. * ownCloud provides an option to encrypt the file storage. But if the encryption with the _per-user encryption keys_ (used by default in ownCloud **Default encryption module** app) is enabled, ONLYOFFICE Document Server cannot open the encrypted files for editing and save them after the editing. The ONLYOFFICE section of the administrative settings page will display a notification about it. However if you set the encryption with the _master key_, ONLYOFFICE application will work as intended. The instruction on enabling _master key_ based encryption is available in the official documentation on [ownCloud](https://doc.owncloud.org/server/administration_manual/configuration/files/encryption_configuration.html#enabling-encryption-from-the-command-line) websites. * If you are using a self-signed certificate for your **Document Server**, ownCloud will not validate such a certificate and will not allow connection to/from **Document Server**. This issue can be solved the following way: locate the ownCloud config file (_/owncloud/config/config.php_) and open it. Insert the following section to it: ```php 'onlyoffice' => array ( 'verify_peer_off' => true ) ``` This will disable the certificate verification and allow ownCloud to establish connection with **Document Server**, but you must remember that this is a temporary insecure solution and we strongly recommend that you replace the certificate with the one issued by some CA. Once you do that, do not forget to remove the above section from ownCloud config file. ## ONLYOFFICE Document Server editions ONLYOFFICE offers different versions of its online document editors that can be deployed on your own servers. ONLYOFFICE Document Server: * Community Edition (`onlyoffice-documentserver` package) * Integration Edition (`onlyoffice-documentserver-ie` package) The table below will help you to make the right choice. | Pricing and licensing | Community Edition | Integration Edition | | ------------- | ------------- | ------------- | | | [Get it now](https://www.onlyoffice.com/download.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | [Start Free Trial](https://www.onlyoffice.com/connectors-request.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | | Cost | FREE | [Go to the pricing page](https://www.onlyoffice.com/integration-edition-prices.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | | Simultaneous connections | up to 20 maximum | As in chosen pricing plan | | Number of users | up to 20 recommended | As in chosen pricing plan | | License | GNU AGPL v.3 | Proprietary | | **Support** | **Community Edition** | **Integration Edition** | | Documentation | [Help Center](https://helpcenter.onlyoffice.com/server/docker/opensource/index.aspx) | [Help Center](https://helpcenter.onlyoffice.com/server/integration-edition/index.aspx) | | Standard support | [GitHub](https://github.com/ONLYOFFICE/DocumentServer/issues) or paid | One year support included | | Premium support | [Buy Now](https://www.onlyoffice.com/support.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | [Buy Now](https://www.onlyoffice.com/support.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | | **Services** | **Community Edition** | **Integration Edition** | | Conversion Service | + | + | | Document Builder Service | + | + | | **Interface** | **Community Edition** | **Integration Edition** | | Tabbed interface | + | + | | White Label | - | - | | Integrated test example (node.js)* | - | + | | Mobile web editors | - | + | | **Plugins & Macros** | **Community Edition** | **Integration Edition** | | Plugins | + | + | | Macros | + | + | | **Collaborative capabilities** | **Community Edition** | **Integration Edition** | | Two co-editing modes | + | + | | Comments | + | + | | Built-in chat | + | + | | Review and tracking changes | + | + | | Display modes of tracking changes | + | + | | Version history | + | + | | **Document Editor features** | **Community Edition** | **Integration Edition** | | Font and paragraph formatting | + | + | | Object insertion | + | + | | Adding Content control | - | + | | Editing Content control | + | + | | Layout tools | + | + | | Table of contents | + | + | | Navigation panel | + | + | | Mail Merge | + | + | | Comparing Documents | - | +* | | **Spreadsheet Editor features** | **Community Edition** | **Integration Edition** | | Font and paragraph formatting | + | + | | Object insertion | + | + | | Functions, formulas, equations | + | + | | Table templates | + | + | | Pivot tables | +** | +** | | **Presentation Editor features** | **Community Edition** | **Integration Edition** | | Font and paragraph formatting | + | + | | Object insertion | + | + | | Animations | + | + | | Presenter mode | + | + | | Notes | + | + | | | [Get it now](https://www.onlyoffice.com/download.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | [Start Free Trial](https://www.onlyoffice.com/connectors-request.aspx?utm_source=github&utm_medium=cpc&utm_campaign=GitHubOwncloud) | \* It's possible to add documents for comparison from your local drive, from URL and from ownCloud storage. \** Changing style and deleting (Full support coming soon)