-
Notifications
You must be signed in to change notification settings - Fork 21
WebServiceCreateJob
There are two ways of creating jobs. Both involve first creating an XML document to represent the job request:
<jobRequest xmlns='http://www.daisy.org/ns/pipeline/data'>
<script href='http://example.org/ws/scripts/dtbook-to-zedai'/>
<input name='source'>
...
</input>
<option name='opt-mods-filename'>the-mods-file.xml</option>
<option name='opt-css-filename'>the-css-file.css</option>
<option name='opt-zedai-filename'>the-zedai-file.xml</option>
<callback type='messages' href='http://example.org/ws/jobmessages' frequency='10'/>
<callback type='status' href='http://example.org/ws/jobstatus' frequency='10'/>
</jobRequest>
-
<script>
: gives the unique URI of the script that this job wishes to use -
<input>
: contains the input document(s) for the input port given by@name
-
<option>
: option value -
<callback>
: the [WebServicePush push notification] callback
The inputs and options for a script can be retrieved by requesting a description of that particular script. This data is then used when building the job request.
A job can be created using local file system references, inline XML or a multi-part upload.
This method is appropriate when the Pipeline server is running in
"local file system" mode (see
configuration). In this case the input
and
option
elements may reference absolute file URIs. An example:
<jobRequest xmlns='http://www.daisy.org/ns/pipeline/data'>
<script href='http://example.org/ws/scripts/dtbook-to-zedai'/>
<input name='source'>
<item value='file:///home/user/dtbook-basic.xml'/>
</input>
<option name='opt-mods-filename'>the-mods-file.xml</option>
<option name='opt-css-filename'>the-css-file.css</option>
<option name='opt-zedai-filename'>the-zedai-file.xml</option>
</jobRequest>
Another example to demonstrate absolute URIs in an option
:
<jobRequest xmlns='http://www.daisy.org/ns/pipeline/data'>
<script href='http://localhost:8181/ws/scripts/epub3-to-epub3'/>
<option name='source'>file:///home/user/accessible_epub_3.epub</option>
</jobRequest>
This method is appropriate if the only files involved are XML, and no external files (e.g. JPEGs) are required. The input XML document(s), in this case DTBook documents, are nested in the job request itself:
<jobRequest xmlns='http://www.daisy.org/ns/pipeline/data'>
<script href='http://example.org/ws/scripts/dtbook-to-zedai'/>
<input name='source'>
<docwrapper>
<dtbook xmlns='http://www.daisy.org/z3986/2005/dtbook/' version='2005-3' xml:lang='en-US'>
<head>
...
</head>
<book>
...
</book>
</dtbook>
</docwrapper>
</input>
</jobRequest>
If a sequence of documents is being passed to a port, then a series of
<docwrapper>
elements should be used:
<input name="source">
<docwrapper>
<dtbook>...</dtbook>
</docwrapper>
<docwrapper>
<dtbook>...</dtbook>
</docwrapper>
<docwrapper>
<dtbook>...</dtbook>
</docwrapper>
</input>
Sometimes the input file's context is required in order to perform the operation. An example is when the input file references images, and those images will be copied to the output directory. In cases like this, it is necessary to zip the input documents along with their data and submit the zip file as part of a multi-part upload.
The first part of the multi-part upload, identified as job-data
, is
a zip file containing input data.
The other part of the multi-part upload, identified as job-request
,
is an XML file describing the job request:
<jobRequest xmlns='http://www.daisy.org/ns/pipeline/data'>
<script href='http://example.org/ws/scripts/dtbook-to-zedai'/>
<input name='source'>
<item value='./dtbook-basic.xml'/>
</input>
<option name='opt-mods-filename'>the-mods-file.xml</option>
<option name='opt-css-filename'>the-css-file.css</option>
<option name='opt-zedai-filename'>the-zedai-file.xml</option>
</jobRequest>
Both parts are mandatory.
The <input>
element contains one or more <item>
element children,
each referring to a file in the attached zip by its relative path
(relative to the root of the zip file).
When creating the multi-part request, the following conventions must be observed:
- The field name for the zip data is "job-data"
- The field name for the job request XML is "job-request"
- The content type for the job request is "multipart/form-data"
- Home
- Download
-
Help
-
User Guide
- Installation
- Desktop Application
- Web Application
- Pipeline as a Service
- Command Line
-
Scripts
- DAISY 2.02 Validator
- DAISY 2.02 to EPUB 3
- DAISY 3 to DAISY 2.02
- DAISY 3 to EPUB 3
- DTBook Validator
- DTBook to DAISY 3
- DTBook to EPUB3
- DTBook to HTML
- DTBook to ODT
- DTBook to PEF
- DTBook to RTF
- DTBook to ZedAI
- EPUB 2 to EPUB 3
- EPUB 3 Enhancer
- EPUB 3 Validator
- EPUB 3 to DAISY 2.02
- EPUB 3 to DAISY 3
- EPUB 3 to PEF
- EPUB to DAISY
- HTML to DTBook
- HTML to EPUB3
- HTML to PEF
- NIMAS Fileset Validator
- ZedAI to EPUB 3
- ZedAI to HTML
- ZedAI to PEF
- API Documentation
- Issue Tracker
- Troubleshooting
- Forum
- [[Contact|mailto:[email protected]]]
-
User Guide
- Contribute
- DAISY Home