The development environment contains one processor example as a template how local test, packaging and upload to a processing centre can be performed. You can copy this example into your home directory of the VM with
/urbantep/software/urbantep-dev/bin/setup-example.sh
The result is a directory called example with the following content:
fmask-and-merge.sh is the processor that shall be applied to Landsat-8 inputs. It is shown here mainly for illustration. Your own processors may look different. The processor will be called with the path to the Landsat-8 input file as command line argument. The processor finally uses a tagged line in stdout (OUTPUT_PRODUCT) to inform about the filename of the result.
urbanuser@urbandev:~ $ cat /urbantep/software/urbantep-dev/example/fmask-3.2/fmask-and-merge.sh
#!/bin/bash
set -e
input=$(basename $1)
id=${input%.tar.gz}
id=${id%.tgz}
metadatafile=${id}_MTL.txt
mask=${id}_MTLFmask.hdr
output=${id}-fmask.nc
wd=$(pwd)
SNAP_DIR=/urbantep/software/snap-3.0.1
MCR_DIR=/urbantep/software/mcr_root-v81
FMASK_DIR=$(cd $(dirname $0); pwd)
if [ ! -e $wd/$metadatafile ]; then
    echo 'unpacking tgz input ...'
    tar xf $1
fi
if [ ! -e $wd/$mask ]; then
    echo 'masking with Fmask ...'
    export MCR_CACHE_ROOT=${wd}/mcrcache
    mkdir -p ${MCR_CACHE_ROOT}
    $FMASK_DIR/run_Fmask.sh $MCR_DIR
fi
if [ ! -e $wd/$output ]; then
    echo 'merging mask into product ...'
    ${SNAP_DIR}/bin/gpt -c 4G $FMASK_DIR/merge-graph.xml -PmasterProduct=$wd/$metadatafile $wd/$mask -f NetCDF4-BEAM -t $wd/$output
fi
echo OUTPUT_PRODUCT $output
Processors are usually packaged with Docker to allow for a constant environment of the processor even in different processing centres. The Dockerfile
urbanuser@urbandev:~ $ cat /urbantep/software/urbantep-dev/example/Dockerfile
FROM centos:7
RUN yum install -y libXext.x86_64 libXt.x86_64 libXmu.x86_64
The descriptor XML is a declaration that is independent of the target processing centre. It declares names and versions, the processor script to be started to run the processor, formal parameters, and dependencies.
urbanuser@urbandev:~ $ cat /urbantep/software/urbantep-dev/example/descriptor.xml
<?xml version="1.0" encoding="utf-8"?>
<utep:descriptor xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                 xmlns:utep="http://urban-tep.eo.esa.int/schema/urban-tep-schema.xsd"
                 xsi:schemaLocation="http://urban-tep.eo.esa.int/schema/urban-tep-schema.xsd urban-tep-schema.xsd">
  <utep:processor>
    <utep:name>Fmask8</utep:name>
    <utep:executable>fmask-and-merge.sh</utep:executable>
    <utep:title>Urban TEP Fmask for Landsat 8</utep:title>
    <utep:description><p>Performs cloud detection for Landsat 8 L1 products.</p></utep:description>
    <utep:inputTypes>Landsat8</utep:inputTypes>
    <utep:parameters>
      <utep:parameter>
        <utep:name>threshold</utep:name>
        <utep:type>string</utep:type>
        <utep:description>cloud probability threshold</utep:description>
        <utep:default>0.2</utep:default>
      </utep:parameter>
    </utep:parameters>
    <utep:packaging>
      <utep:name>fmask</utep:name>
      <utep:version>3.2</utep:version>
      <utep:type>Docker</utep:type>
      <utep:dependencies>
        <utep:dependency>
          <utep:name>snap</utep:name>
        </utep:dependency>
        <utep:dependency>
          <utep:name>mcr_root</utep:name>
          <utep:version>v81</utep:version>
        </utep:dependency>
      </utep:dependencies>
      <utep:resources>
        <utep:resource>
          <utep:name>memory</utep:name>
          <utep:value>7000</utep:value>
        </utep:resource>
        <utep:resource>
          <utep:name>timelimit</utep:name>
          <utep:value>3600</utep:value>
        </utep:resource>
      </utep:resources>
    </utep:packaging>
  </utep:processor>
</utep:descriptor>
The elements of this descriptor.xml file content are: