This plugin enables users to edit office documents from Alfresco Share using ONLYOFFICE Docs packaged as Document Server - Community or Enterprise Edition.
Tested with Alfresco 6.*
- Create and edit text documents, spreadsheets, and presentations.
- Share documents with other users.
- Co-edit documents in real-time: use two co-editing modes (Fast and Strict), Track Changes, comments, and built-in chat.
Supported formats:
- For viewing and editing: DOCX, XLSX, PPTX.
- For converting to Office Open XML: ODT, ODP, ODS, DOC, XLS, PPT.
To convert a specific file, select Convert using ONLYOFFICE
action. Resulting file will be placed in the same folder. You can also configure rules for a folder, that will automatically convert files on upload or on change. Details here.
You will need an instance of ONLYOFFICE Docs (Document Server) that is resolvable and connectable both from Alfresco and any end clients (version 3.0 and later are supported for use with the plugin). ONLYOFFICE Document Server must also be able to POST to Alfresco directly.
You can install free Community version of ONLYOFFICE Docs or scalable Enterprise Edition with pro features.
To install free Community version, use Docker (recommended) or follow these instructions for Debian, Ubuntu, or derivatives.
To install Enterprise Edition, follow instructions here.
Community Edition vs Enterprise Edition comparison can be found here.
To start using ONLYOFFICE Document Server with Alfresco, the following steps must be performed for Ubuntu 14.04:
The latest compiled package files are available here.
-
Upload the compiled *.jar packages to directories accordingly for your Alfresco installation:
- from
onlyoffice-alfresco/repo/target/
to the/webapps/alfresco/WEB-INF/lib/
for Alfresco repository, - from
onlyoffice-alfresco/share/target/
to/webapps/share/WEB-INF/lib/
for Share.
- from
-
Make sure that Document Server will be able to POST to Alfresco.
You may need to change these lines in
alfresco-global.properties
or you can set it using configuration pagealfresco.host=<hostname> alfresco.port=443 alfresco.protocol=https share.host=<hostname> share.port=443 share.protocol=https
Probably located here
/usr/local/tomcat/shared/classes/alfresco-global.properties
-
Restart Alfresco:
sudo ./alfresco.sh stop sudo ./alfresco.sh start
The module can be checked in administrator tools at share/page/console/admin-console/module-package
in Alfresco.
Module configuration can be found inside Alfresco Administration Console
or by simply navigating to http://<alfrescohost>/alfresco/s/onlyoffice/onlyoffice-config
You can also add
onlyoffice.url
inalfresco-global.properties
. Configuration made via settings page will overridealfresco-global.properties
.
JWT can be configured via configuration page or by adding onlyoffice.jwtsecret
in alfresco-global.properties
.
The JWT configuration on the Document Server side can be found here.
If you plan to compile the ONLYOFFICE Alfresco module package yourself (e.g. edit the source code and compile it afterwards), follow these steps.
-
The latest stable Oracle Java version is necessary for the successful build. If you do not have it installed, use the following commands to install Oracle Java 8:
sudo apt-get update sudo apt-get install openjdk-8-jdk
-
Install latest Maven: Installation process is described here
-
Download the ONLYOFFICE Alfresco module package source code:
git clone https://github.com/onlyoffice/onlyoffice-alfresco.git
-
Compile packages in the
repo
andshare
directories:cd onlyoffice-alfresco/ mvn clean install
Another way to build ONLYOFFICE Alfresco module package is using docker-compose file.
Use this command from project directory:
docker-compose up
The ONLYOFFICE integration follows the API documented here:
- User navigates to a document within Alfresco Share and selects the
Edit in ONLYOFFICE
action. - Alfresco Share makes a request to the repo end (URL of the form:
/parashift/onlyoffice/prepare?nodeRef={nodeRef}
). - Alfresco Repo end prepares a JSON object for the Share with the following properties:
- url: the URL that ONLYOFFICE Document Server uses to download the document (includes the
alf_ticket
of the current user), - callbackUrl: the URL that ONLYOFFICE Document Server informs about status of the document editing;
- onlyofficeUrl: the URL that the client needs to reply to ONLYOFFICE Document Server (provided by the onlyoffice.url property);
- key: the UUID+Modified Timestamp to instruct ONLYOFFICE Document Server whether to download the document again or not;
- title: the document Title (name).
- url: the URL that ONLYOFFICE Document Server uses to download the document (includes the
- Alfresco Share takes this object and constructs a page from a freemarker 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 Alfresco and the user begins editing.
- ONLYOFFICE Document Server sends a POST request to the
callback
URL to inform Alfresco that a user is editing the document. - Alfresco locks the document, but still allows other users with write access the ability to collaborate in real time with ONLYOFFICE Document Server by leaving the Action present.
- When all users and client browsers are done with editing, they close the editing window.
- After 10 seconds of inactivity, ONLYOFFICE Document Server sends a POST to the
callback
URL letting Alfresco know that the clients have finished editing the document and closed it. - Alfresco downloads the new version of the document, replacing the old one.
ONLYOFFICE offers different versions of its online document editors that can be deployed on your own servers.
- Community Edition (onlyoffice-documentserver package)
- Enterprise Edition (onlyoffice-documentserver-ee package)
The table below will help you make the right choice.
Pricing and licensing | Community Edition | Enterprise Edition |
---|---|---|
Get it now | Start Free Trial | |
Cost | FREE | Go to the pricing page |
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 | Enterprise Edition |
Documentation | Help Center | Help Center |
Standard support | GitHub or paid | One year support included |
Premium support | Buy Now | Buy Now |
Services | Community Edition | Enterprise Edition |
Conversion Service | + | + |
Document Builder Service | + | + |
Interface | Community Edition | Enterprise Edition |
Tabbed interface | + | + |
White Label | - | - |
Integrated test example (node.js) | - | + |
Mobile web editors | - | + |
Plugins & Macros | Community Edition | Enterprise Edition |
Plugins | + | + |
Macros | + | + |
Collaborative capabilities | Community Edition | Enterprise 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 | Enterprise Edition |
Font and paragraph formatting | + | + |
Object insertion | + | + |
Adding Content control | - | + |
Editing Content control | + | + |
Layout tools | + | + |
Table of contents | + | + |
Navigation panel | + | + |
Comparing Documents | - | +* |
Comparing Documents | - | + |
Spreadsheet Editor features | Community Edition | Enterprise Edition |
Font and paragraph formatting | + | + |
Object insertion | + | + |
Functions, formulas, equations | + | + |
Table templates | + | + |
Pivot tables | + | + |
Conditional formatting for viewing | +** | +** |
Presentation Editor features | Community Edition | Enterprise Edition |
Font and paragraph formatting | + | + |
Object insertion | + | + |
Animations | + | + |
Presenter mode | + | + |
Notes | + | + |
Get it now | Start Free Trial |
* It's possible to add documents for comparison from your local drive and from URL. Adding files for comparison from storage is not available yet.
** Support for all conditions and gradient. Adding/Editing capabilities are coming soon