Skip to content

Latest commit

 

History

History
241 lines (181 loc) · 11.2 KB

README.md

File metadata and controls

241 lines (181 loc) · 11.2 KB

Description

A plugin that provides an integration between Vntana and the Nuxeo Platform.

How to build

git clone https://github.com/nuxeo-sandbox/nuxeo-vntana-connector
cd nuxeo-vntana-connector
mvn clean install -DskipTests

In order to run the integration tests, several parameters must be passed:

mvn clean install -DvntanaApiKey=<API_KEY> -DvntanaOrganizationUUID=<ORGANIZATION_UUID> -DvntanaClientUUID=<CLIENT_UUID> -DvntanaProductUUID=<PRODUCT_UUID>

Configuration

Several configuration settings are available.

nuxeo.conf

Property name description
vntana.enabled A boolean proprerty to enable/disable the plugin
vntana.api.key The API key to use when calling Vntana's REST API
vntana.api.default.organization The default vnatana organization UUID where models get published
vntana.api.default.client The default vntana client (folder) UUID where models get published
vntana.webhook.secret The secret to use to verify event callback from vntana

Supported Documents

Whether a Document can be published or not to Vntana is controled by a Nuxeo Filter extension. The default contribution can be overridden in a configuration template, plugin or Nuxeo Studio.

  <extension point="filters" target="org.nuxeo.ecm.platform.actions.ActionService">
    <filter id="vntanaDocumentFilter">
      <rule grant="true">
        <type>MyType</type>
      </rule>
    </filter>
  </extension>

Plugin Features

A Java client for the Vntana REST API

This projects contains a Java client for the Vnatana REST API which is autogenerated from the swagger definition using the OpenAPI Generator Maven Plugin

Data Model

The plugin includes a vnatana schema that contains the model information in Vntana once published. The schema is typically added to a Document in Nuxeo using the Vntana Facet.

Service

The VntanaService provides the glue between the Java Client and the Nuxeo Java APIs

An Automation API to publish, update and un-publish models

Several Automation operations are made available by this plugin.

Publish Model

curl 'http://localhost:8080/nuxeo/api/v1/automation/Vntana.PublishModel' \
  -H 'Content-Type: application/json' \
  -H 'properties: *' \
  --data-raw '{"params":{"save":true},"context":{},"input":"<DOC_UUID>"}' \
  --compressed

Parameters:

Name Description Type Required Default value
organizationUUID The Vntana destination organization string false
clientUUID The client destination within the organization string false
save Save the document boolean false false

Fetch Model status from Vntana

curl 'http://localhost:8080/nuxeo/api/v1/automation/Vntana.UpdateModelRemoteProcessingStatus' \
  -H 'Content-Type: application/json' \
  -H 'properties: *' \
  --data-raw '{"params":{"save":true},"context":{},"input":"<DOC_UUID>"}'

Parameters:

Name Description Type Required Default value
save Save the document boolean false false

Update Model

Update the Vntana related product binary file with the document current file.

curl 'http://localhost:8080/nuxeo/api/v1/automation/Vntana.UpdateModel' \
  -H 'Accept: application/json' \
  -H 'Content-Type: application/json' \
  -H 'properties: *' \
  --data-raw '{"params":{"save":true},"context":{},"input":"<DOC_UUID>"}'

Parameters:

Name Description Type Required Default value
save Save the document boolean false false

Unpublish Model

curl 'http://localhost:8080/nuxeo/api/v1/automation/Vntana.UnpublishModel' \
  -H 'Content-Type: application/json' \
  -H 'properties: *' \
  --data-raw '{"params":{"save":true},"context":{},"input":"<DOC_UUID>"}' \
  --compressed

Parameters:

Name Description Type Required Default value
save Save the document boolean false false

Download Model Conversion

curl 'http://localhost:8080/nuxeo/api/v1/automation/Vntana.DownloadModel' \
  -H 'Content-Type: application/json' \
  -H 'properties: *' \
  --data-raw '{"params":{"format":"GLB"},"context":{},"input":"<DOC_UUID>"}' 

Parameters:

Name Description Type Required Default value
format The file format to download from Vntana: GLB or USDZ string true "GLB"

Webui Resources

Configuration

The plugin automatically contributes a webui configuration corresponding to the vntana.enabled nuxeo.conf property

console.log(Nuxeo.UI.config.vntana)
{enabled: 'true'}

API Document Enricher

An API document enricher is available to easily determine if a document can be published to Vntana

curl 'http://localhost:8080/nuxeo/api/v1/path/<PATH>' \
  -H 'Accept-Language: en-US,en;q=0.9,fr;q=0.8' \
  -H 'Content-Type: application/json' \
  -H 'enrichers-document: vntana' 
{
   "entity-type":"document",
   "contextParameters": {
     "vntana": {
       "isSupported": true
     }
   }
}

Actions

UI actions corresponding to the Automation operations are included into the plugin. The actions are automatically displayed depending on whether the publin is enabled and the document is supported.

UI Publish Model Action Screenshot

UI Published Model Actions Screenshot

Vnatana Viewer

Vntana provides a reusable 3D viewer JS component that can be used to preview GLB files stored in Nuxeo. This viewer relies on the open source google viewer and adds a layer of optimization. However, the JS component cannot be used directly into a webui components because of conflicting dependencies. So instead this plugin includes a simple web page that loads the viewer and can be embedded as an iframe into a webcomponent.

Below is an example of how to use the iframe with a document that holds a GLB file

<iframe src="[[_getFrameUrl(document)]]" allowfullscreen mozallowfullscreen="true" webkitallowfullscreen="true" onmousewheel=""></iframe>

_getSource: function(document) {
    return document ? document.properties['file:content'].data : null;
},

_getThumbnail: function(document) {
    if (document && document.properties['thumb:thumbnail'] && document.properties['thumb:thumbnail'].data) {
        return document.properties['thumb:thumbnail'].data;
    } else {
        return undefined;
    }
},

_getFrameUrl: function(document) {
    return `/nuxeo/ui/nuxeo-vntana/frame/nuxeo-vntana-viewer-frame.html?blobUrl=${encodeURIComponent(this._getSource(document))}&thumbnailUrl=${this._getThumbnail(document)}`;
}

Webhooks

This plugin implements an endpoint to receive events from Vntana. The callback URL is https://myserver/nuxeo/site/vntana/event. The endpoint will generate a vntanaEvent event in Nuxeo that can be catched with event listeners in java or event handlers in Nuxeo Studio. Below is a sample automation script triggered by event handler:

UI Published Model Actions Screenshot

function run(input, params) {
  Auth.LoginAs(input, {});
  //get Vntana Event
  var event = ctx.Event.getContext().getProperty("vntanaEvent");
  Console.log('Received Event from Vntana: '+ event);

  var eventName = event.event;
  var productUuid = event.product.uuid; 
  
  //do things
}

Support

These features are not part of the Nuxeo Production platform.

These solutions are provided for inspiration and we encourage customers to use them as code samples and learning resources.

This is a moving project (no API maintenance, no deprecation process, etc.) If any of these solutions are found to be useful for the Nuxeo Platform in general, they will be integrated directly into platform, not maintained here.

Nuxeo Marketplace

This plugin is published on the marketplace

License

Apache License, Version 2.0

About Nuxeo

Nuxeo Platform is an open source Content Services platform, written in Java. Data can be stored in both SQL & NoSQL databases.

The development of the Nuxeo Platform is mostly done by Nuxeo employees with an open development model.

The source code, documentation, roadmap, issue tracker, testing, benchmarks are all public.

Typically, Nuxeo users build different types of information management solutions for document management, case management, and digital asset management, use cases. It uses schema-flexible metadata & content models that allows content to be repurposed to fulfill future use cases.

More information is available at www.nuxeo.com.