This document scopes the extension of the OMERO Command Line Interface to have a better support for trees and graphs.
We already introduced the CLI obj plugin to manipulate individual objects. The generic syntax of this plugin is of the form:
bin/omero obj subcommand Object:id field1=value1 field2=value2 ...
We are facing more use cases where we need to manipulate graphs and sets of objects. A first implementation of such a plugin has been provided in the context of IDR with the CLI children plugin.
The current consensus is to preserve the obj
plugin for the manipulation of
individual objects and design a new plugin for graph/set tasks. For now, we will use the term tree
to refer to this new plugin.
This plugin could include a set of subcommands. Each subcommand could either
be a read operation applied to a graph specified by the graph-spec
argument:
bin/omero tree read-operation graph-spec
or a write operations applied to a graph-spec
argument with an optional
object-spec
target:
bin/omero tree write-operation graph-spec [obj-spec]
There are 2 proposed formats that could be supported when specifying the input
graph-spec
:
- either stay close to the current
obj-spec
format, i.e.Object:id
- or move towards xpath-like formats e.g.
//Image/*
,Image[name=xxx]
,Screen:id/*/Roi:*
If sticking to the first option, the proposed representation of orphaned
objects would be Image:orphan
.
Below is a list of proposed subcommands with use cases.
Move orphaned images into a dataset:
omero tree link Image:orphan Dataset:1
omero tree link //Image:* Dataset:1
Link images, annotations, and everything in between datasets:
omero tree link Dataset:1/Image:* Dataset:2
omero tree link Dataset:1/Annotation:* Dataset:2
omero tree link Dataset:1/* Dataset:2
Link a subset of images in between datasets:
omero tree link Dataset:1/Image[tag=good]:* Dataset:2
- This format requires children to be specified explicitly to avoid ambiguity
Unlink objects from one dataset and link into another:
omero tree move Dataset:1/Image:* Dataset:2
- If an Image is in multiple datasets those other links won't be unaffected
Link all Regions of interest to a folder
omero tree link Image:1/Roi:* Folder:1
omero tree link Screen:1/Roi:* Folder:2
omero tree link Screen:1/*/Roi:* Folder:2
Orphan all images in a dataset
omero tree unlink Dataset:1
Link all images in one dataset into another
omero tree copy Dataset:1 Dataset:2
omero tree copy Dataset:1/* Dataset:2
List containers/folders content
omero tree ls Dataset:1
omero tree ls Folder:1
omero tree ls Fileset:1 # Show all entries, images, etc.
omero tree ls ExperimenterGroup:* # Show groups with users
omero tree ls Experimenter:* # Show users with groups
omero tree ls TagAnnotation:* # See existing plugin
List orphaned objects
omero tree ls --orphan
omero tree ls Image:orphan
List objects with filter
omero tree ls Screen:1 --filter FileAnnotation[ns='bulk-annotation']
omero tree ls Screen:1/*/FileAnnotation[ns='bulk-annotation']
Return the object identifiers only
omero tree ls Dataset:1 --ids
Format the returned objects in a coice of styles, for example obj-spec, YAML, JSON.
This part of the specification may also be used in other CLI plugins which output information about omero objects such as hql
, import
, etc.
omero tree ls Dataset:1 --output=yml
Provide commands to list the parents and children of an object.
This may be partly covered by ls
though that is only in the children direction.
This might support some level of recursion for viewing more complex family trees.
See parents and children subcommands