The OpenKM Document Management System (DMS) plugin facilitates the seamless integration of OpenKM and Joget. This integration currently utilises two plugin types:
The plugin is created with the use of RESTful Guide - OpenKM Documentation to perform RESTful API calls on OpenKM.
The plugin source code is available in JogetOSS.
| Name | Description | 
|---|---|
| Username | OpenKM username. | 
| Password | OpenKM password. | 
| OpenKM URL | The URL that OpenKM is hosted at. Example: http://localhost:8180/OpenKM | 
| Root Folder UUID | The folder UUID retrieved from OpenKM folder. The UUID can be configured depending on desired folder level to start with. | 
More details on default configurations for file upload: File Upload - Knowledge Base for DX 8 - Joget | COMMUNITY
Below are configurations for section "OpenKM Configurations":
| Name | Description | 
|---|---|
| Credentials | Header field. | 
| Username | OpenKM username. | 
| Password | OpenKM password. | 
| OpenKM URL | The URL that OpenKM is hosted at. Example: http://localhost:8180/OpenKM | 
| Field Mappings | Header field. | 
| Form | The current form to bind the field with. | 
| OpenKM Path for File Upload | The current form field that contains the OpenKM File Path value. | 
| Automatically Create Folder by Form ID | Checkbox field. If true, file will be uploaded inside a newly created folder using submitted form ID in OpenKM. If false, file will be directly uploaded into the OpenKM File Path. | 
Setting up OpenKM DMS
Please refer to Download OpenKM to download the desired version for your system.
For this example, OpenKM is run on MacOS with Java 8.0.382-zulu and MySQL5.7.
When you see the following page, it shows that your openKM has been successfully hosted. Login with the default credentials "okmAdmin" with password "admin".

Figure 1: OpenKM Login Page
After logging in, you will see the homepage of OpenKM.

Figure 2: OpenKM Homepage
First, drag a select box and use the OpenKM DMS Form Options Binder to load the folder paths from OpenKM. Fill in the required credentials for the plugin to work as intended (Figure 3). The Root Folder UUID can be retrieved on the OpenKM folder that we intend to configure as root folder (Figure 4).

Figure 3: Joget Form Builder (Select Box with OpenKM DMS Form Options Binder)

Figure 4: Retrieve OpenKM Root Folder UUID
Then, the OpenKM DMS File Upload tool can be drag and drop to attach into the form as a form element. Fill in the OpenKM Configurations with necessary details. If the credentials of OpenKM is invalid, "Authentication ERROR" will be shown in the element (Figure 5).
We can now map the select box field in the Field Mappings section. Field mappings is an optional configuration, if no fields are mapped, the default file path will be "/okm:root".

Figure 5: Joget Form Builder (OpenKM DMS File Upload Element)
In the datalist builder, we can format the file upload column by using the OpenKM DMS Datalist Formatter. Similar configurations can be key in to enable users to download the file directly from datalist.

If we do not wish to type the credentials multiple times, the credentials can also be easily added into environment variables, and then use a hash variable to refer to the values in environmental variables. For more information, please refer to Environment Variable - Knowledge Base for DX 7 - Joget | COMMUNITY.
After all the configurations has been done, the user can retrieve the folder paths from OpenKM in the select box, then choose a file to upload.

Figure 6: OpenKM DMS UI (Form)
After uploading, we can view the latest file path that the file has been uploaded to, and also download the file retrieved from OpenKM.

Figure 7: OpenKM DMS UI (List)
At OpenKM DMS, we can view the file being uploaded. If we modify the file here, we can also get the modified newest file in Joget.

Figure 8: OpenKM DMS Homepage with Uploaded File
To upload multiple files and other file upload features, please visit File Upload - Knowledge Base for DX 8 - Joget | COMMUNITY for further information.