See also the SCUFL2 wiki
(c) 2009-2014 University of Manchester, UK
Licensed under the GNU Lesser General Public License (LGPL) 2.1. See LICENSE.txt for the full terms of LGPL 2.1.
This is the API, model and format of SCUFL2, which replaces Taverna's workflow format .t2flow. This API allows JVM applications to inspect, generate and modify Taverna workflow definitions without depending on the Taverna runtime.
A new format, called Scufl2 Workflow Bundle is defined alongside this API. This format can be inspected, generated and modified independently of this API.
Note that the ability for Scufl2 API to read a workflow bundle (using the scufl2-rdfxml
module) does not guarantee it is valid or structurally sound. The experimental modules scufl2-validation-*
will in the future be able to provide such verification.
For more information, see the SCUFL2 API pages, the Javadoc and the SCUFL2 examples.
mvn clean install
This will build each module and run their tests, producing JARs like scufl2-api/target/scufl2-api-0.14.0.jar
.
First time you build Scufl2 this might download dependencies needed for compliation. These have separate open source licenses, but should be compatible with LGPL. None of the dependencies are neccessary for using the compiled SCUFL2 API.
Some of the experimental modules are not built automatically, to build them separately, run the same command from within their folder.
Scufl2 is built as a Maven project, and the easiest way to use it is from other Maven projects.
Typical users of the Scufl2 API will depend on the three modules scufl2-api, scufl2-t2flow and scufl2-rdfxml. In your Maven project's POM file, add this to your <dependencies>
section:
<dependency> <groupId>uk.org.taverna.scufl2</groupId> <artifactId>scufl2-api</artifactId> <version>0.14.0</version> </dependency> <dependency> <groupId>uk.org.taverna.scufl2</groupId> <artifactId>scufl2-rdfxml</artifactId> <version>0.14.0</version> </dependency> <dependency> <groupId>uk.org.taverna.scufl2</groupId> <artifactId>scufl2-t2flow</artifactId> <version>0.14.0</version> </dependency>
All Scufl2 modules are also valid OSGi bundles, see the OSGi section below.
You can alternatively copy and add the JARs from these modules to your classpath:
See the SCUFL2 Javadoc for documentation of classes and methods of SCUFL2. The package uk.o.rg.taverna.scufl2.api is a good starting point.
See the scufl2-validation folder for examples of usage. The best classes to start exploring would be uk.org.taverna.scufl2.api.io.WorkflowBundleIO
and uk.org.taverna.scufl2.api.container.WorkflowBundle
.
Example of converting .t2flow to .wfbundle:
import uk.org.taverna.scufl2.api.container.WorkflowBundle; import uk.org.taverna.scufl2.api.io.ReaderException; import uk.org.taverna.scufl2.api.io.WorkflowBundleIO; import uk.org.taverna.scufl2.api.io.WriterException; // .. WorkflowBundleIO io = new WorkflowBundleIO(); File t2File = new File("workflow.t2flow"); File scufl2File = new File("workflow.wfbundle"); WorkflowBundle wfBundle = io.readBundle(t2File, "application/vnd.taverna.t2flow+xml"); io.writeBundle(wfBundle, scufl2File, "application/vnd.taverna.scufl2.workflow-bundle");
Check out the GitHub project scufl2-examples8 for examples of using Scufl2, including the above code.
Supported file formats with WorkflowBundleIO and their required modules:
To use SCUFL2 from OSGi, use the following OSGi Services. Example, from META-INF/spring/run-context.osgi.xml:
<?xml version="1.0" encoding="UTF-8"?> <beans:beans xmlns="http://www.springframework.org/schema/osgi" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:beans="http://www.springframework.org/schema/beans" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/osgi http://www.springframework.org/schema/osgi/spring-osgi.xsd"> <service ref="myService" interface="com.example.MyService"/> <reference id="workflowBundleIO" interface="uk.org.taverna.scufl2.api.io.WorkflowBundleIO" /> </beans:beans>
And in run-context.xml:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="myService" class="com.example.impl.MyServiceImpl" > <property name="workflowBundleIO" ref="workflowBundleIO"/> </bean> </beans>
This will provide a WorkflowBundleIO instance with its readers and writers loaded through OSGi, which when the bundles for scufl2-t2flow and scufl2-rdfxml are loaded, would include support for the Taverna 2 t2flow format and the Taverna 3 wfbundle format.
Note that you do not need to use OSGi services to instantiate Scufl2Tools or URITools, but may do so if you wish.
Official modules:
Experimental modules: