JSON API
Overview
The OMERO JSON API described here provides create, read, update and delete
access to an underlying OMERO server. It is implemented as a Django app
named api
in the OMERO.web framework.
Omero-marshal and Projection-based APIs
The majority of the API URLs use omero-marshal
to generate JSON dictionaries from OMERO model objects.
All these URLs are under the m
prefix:
<server>/api/v0/m/
The webclient currently uses a small number of URLs to perform customized
queries for browsing Project, Dataset and Image hierarchies.
These queries use projections and typically load a subset of fields for
OMERO objects in order to improve performance for large data counts.
These will be made available under the p
prefix in future releases
but are not yet supported.
<server>/api/v0/p/
Versioning
The JSON API uses major and minor version numbers to reflect breaking and non-breaking changes respectively. Non-breaking changes include simple addition of attributes to JSON data or addition of new URLs. The API version is not tied to the version of OMERO.server.
The major version is included in the URL such as /v0/
whereas the full
version number can be found in the header:
X-OMERO-ApiVersion : 0.2
JSON format
The JSON objects generated by omero-marshal
are defined by the OME-Model. The OMERO model closely follows the
OME schema but is not identical. In the cases where OMERO-specific fields are included, these
will be prefixed by omero:
. For example, omero:details
specifies the owner, group and
permissions of each object in OMERO.
JSON objects also include an @id
of the object in the OMERO database and a @type
that specifies
the OME Schema used to generate it such as http://www.openmicroscopy.org/Schemas/OME/2016-06#Project
.
All the fields of the OMERO model object will be included in the JSON except those that are null
,
which will be omitted.
Where supported, modifying the JSON object and saving this back to OMERO will update the object accordingly.
URLs in JSON
URLs are included in JSON objects using keys with the url:
prefix. URLs are added for
related objects to facilitate exploration of the API in a browser. You may find that a
JSON formatting plugin for your browser improves both the presentation and
navigation of JSON data.
Pagination
Requests that return a list of items will be paginated, showing
a limit
of the first 200 objects by default.
Pagination can be specified using the limit
and offset
query
parameters:
# List the first 100 Projects (offset=0 by default)
<server>/api/v0/m/projects/?limit=100
# List the next 100 Projects
<server>/api/v0/m/projects/?limit=100&offset=100
Pagination details will be returned in a meta
JSON object, including
the totalCount
of objects for that query, the current offset
and
limit
as well as the maxLimit
that you can use.
"meta": {
"totalCount": 13240,
"maxLimit": 500,
"limit": 200,
"offset": 0
},
Sysadmins can configure the default limit
and maxLimit
settings
for their server, for example:
$ omero config set omero.web.api.limit 100
$ omero config set omero.web.api.max_limit 300
The maxLimit
setting prevents API consumers from requesting very
large amounts of data by limiting the number of top-level objects that
are loaded.
Loading of linked objects
In most cases the API loads only the requested objects along with
their omero:details
. For example, /api/v0/m/projects/
loads
Projects but does not also load their child Datasets.
However, it is sometimes useful to load a number of closely related objects.
For example, loading Images also loads their Pixels data (but not Channels)
and loading Wells also loads WellSamples (fields) and Images (but not Pixels).
The number of objects loaded when listing Images or Wells is kept to
a minimum to avoid requesting too much data. This restriction is relaxed when
a single Image or Well is loaded. For example, loading a single Image will also
load Channels.
Normalizing Experimenters and Groups
When returning a list of JSON objects that each contain omero:details
with
owner
and group
data, these will typically be nested many times
within the list. In order to avoid this duplication, we can remove objects from
within each omero:details
and place them under top-level experimenters
and experimenterGroups
lists.
You can specify this with the ?normalize=true
query parameter.
N.B.: Currently this normalizing will only apply to the top-level objects
being listed, such as Projects, Datasets and Images. Where child objects
are also loaded (for example Pixels within an Image), the omero:details
of these objects will not be affected by the ?normalize=true
parameter.
Child counts
For container objects such as Projects, Datasets and Screens it is
often useful to know the number of children within them. This can be
specified with ?childCount=true
parameter.
This will add an omero:childCount
value to the JSON data.
Filtering by Owner and Group
Most data in OMERO has an Owner
and is assigned to a permissions
Group
. By default, queries will return data from all owners
across all groups that are accessible to the current user.
Use the query strings to filter by owner and/or group:
/api/v0/m/projects/?owner=3&group=5
When you are retrieving data using an object ID you will not need to
filter by group
since all the data will be in the same group.
For example, Datasets in a specified Project will all be in the
same group as the Project.
Error handling
Errors will result in responses with an appropriate status and may include
JSON content with a message
to provide more information:
404 Not Found: Caused by an invalid URL or when a specified object cannot be found in OMERO.
400 Bad Request: May be caused by invalid query parameters or submitting invalid JSON content. For example,
?limit=foo
will give a response of:{"message": "invalid literal for int() with base 10: 'foo'"}405 Method Not Allowed: Returned if you try to use the wrong http method for a url, such as
POST
to/api/v0/m/projects/
. It can also be caused by trying to create or update an unsupported object, such as an Image.500 Internal Server Error: Generated from any unhandled exceptions. See the
message
returned and check whether astacktrace
is also included.
Getting started
You may find this
example python script useful.
It uses the python requests
library to connect to the JSON api, login, query data, create and delete Projects.
These steps are covered in more detail below.
For an example how to use the API with Java,
see JSONClient.java
.
See the following link for a JSON client example https://github.com/ome/openmicroscopy/blob/develop/examples/Training/javascript/index.html.
List supported versions
You need to find which versions of the API are supported by your server, as described above. These are provided by the base URL:
GET /api/
Response
{
"data": [
{
"version": "0",
"url:base": "http://<server>/api/v0/"
}
]
}
List starting URLs
The base URL for the chosen version will list a number of URLs for logging on and getting started.
GET /api/v0/
Response
{
"url:login": "http://<server>/api/v0/login/",
"url:save": "http://<server>/api/v0/m/save/",
"url:projects": "http://<server>/api/v0/m/projects/",
"url:plates": "http://<server>/api/v0/m/plates/",
"url:datasets": "http://<server>/api/v0/m/datasets/",
"url:token": "http://<server>/api/v0/token/",
"url:schema": "http://www.openmicroscopy.org/Schemas/OME/2016-06",
"url:screens": "http://<server>/api/v0/m/screens/",
"url:servers": "http://<server>/api/v0/servers/",
"url:images": "http://<server>/api/v0/m/images/"
}
List available OMERO servers
Your API may allow you to connect to several different OMERO servers.
GET /api/v0/servers/
Response
{
"data": [
{
"host": "<server>",
"server": "omero",
"id": 1,
"port": 4064
}
]
}
Get CSRF token
In order to prevent CSRF attacks, CSRF tokens are required for any
POST, PUT and DELETE requests. You will need to obtain a CSRF token
for your session and use it for all subsequent requests in that session.
You can obtain this from the csrftoken
cookie of any request or from the following URL:
GET /api/v0/token/
Response
{
"data": "eNoVq528bOqlhQqbCzKuviODTRX3PUO2"
}
If you are using the API over HTTPS, you will also need to set the Referer
key in
request headers when supplying the CSRF token to other endpoints. The referer URI
needs to be an address on the same domain as the server for the token to be accepted.
Login
You can login to create an OMERO session. You must also include the CSRF token,
either in the POST parameters as csrfmiddlewaretoken
or in the session
header as X-CSRFToken
.
The EventContext for this session will be returned to you.
POST /api/v0/login/
Parameters
Name Type Description
------------------------------------------------------------------
server Number ID of the server
username String User's username
password String User's password
csrfmiddlewaretoken String CSRF token (can be provided in header)
Response
{
"eventContext": {
"userName": "ben",
"eventId": -1,
"sessionUuid": "0b30ee4a-c0b2-4b0f-9c61-f48b31bcad8c",
"eventType": "User",
"userId": 3,
"sessionId": 171319,
"groupName": "Nevis Lab",
"isAdmin": False,
"memberOfGroups": [5, 1, 4],
"leaderOfGroups": [],
"groupId": 5
},
"success": true
}
Projects, Datasets and Images
OMERO organizes Images in two types of many-to-many hierarchy:
screen/plate/[run]/well/image
for HCS data and project/dataset/image
for other data. Plates, Datasets and Images can also be Orphaned
if not
contained within any parent container.
Parameters
These query parameters are used by many queries below:
Name Type Description
------------------------------------------------------------------
offset Number Pagination offset. The default is 0
limit Number The size of each page. The default is 200
normalize Boolean Place Experimenters and Groups into top-level lists instead
of nesting within objects
childCount Boolean Use ?childCount=true to include an omero:childCount attribute
for container objects
owner Number Filter by Experimenter ID
group Number Filter by Group ID
List Projects
Parameters
Name Type Description
------------------------------------------------------------------
dataset Number Filter Projects by child Dataset ID
These query parameters are also supported (see above):
offset, limit, owner, group, childCount, normalize
GET /api/v0/m/projects/
Response
{
"data": [
{
"Name": "New data",
"Description": "Example Project",
"url:project": "https://server.openmicroscopy.org/api/v0/m/projects/11601/",
"url:datasets": "https://server.openmicroscopy.org/api/v0/m/projects/11601/datasets/",
"@id": 11601,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
"owner": {
"UserName": "ben",
"FirstName": "Ben",
"MiddleName": "",
"omero:details": {
"@type": "TBD#Details",
"permissions": {
"isUserWrite": false,
"isWorldWrite": false,
"canDelete": false,
"isWorldRead": false,
"perm": "------",
"canEdit": false,
"canAnnotate": false,
"isGroupAnnotate": false,
"isGroupWrite": false,
"canLink": false,
"isUserRead": false,
"@type": "TBD#Permissions",
"isGroupRead": false
}
},
"Email": "",
"LastName": "Nevis",
"@id": 0,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Experimenter"
},
"group": {
"omero:details": {
"@type": "TBD#Details",
"permissions": {
"isUserWrite": true,
"isWorldWrite": false,
"canDelete": false,
"isWorldRead": false,
"perm": "rwra--",
"canEdit": false,
"canAnnotate": false,
"isGroupAnnotate": true,
"isGroupWrite": false,
"canLink": false,
"isUserRead": true,
"@type": "TBD#Permissions",
"isGroupRead": true
}
},
"@id": 5,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#ExperimenterGroup",
"Name": "read-ann"
},
"@type": "TBD#Details",
"permissions": {
"isUserWrite": true,
"isWorldWrite": false,
"canDelete": false,
"isWorldRead": false,
"perm": "rwra--",
"canEdit": false,
"canAnnotate": true,
"isGroupAnnotate": true,
"isGroupWrite": false,
"canLink": false,
"isUserRead": true,
"@type": "TBD#Permissions",
"isGroupRead": true
}
}
}
]
}
Get a single Project
GET /api/v0/m/projects/{project_id}/
Response
{
"data": {
"@id": 3872,
"Name": "RNAi experiments",
"Description": "Knockout assays",
"url:datasets": "https://server.openmicroscopy.org/api/v0/m/projects/3872/datasets/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
# omitted for brevity
}
}
}
List Datasets
Parameters
Name Type Description
------------------------------------------------------------------
project Number Filter Datasets by parent Project ID
image Number Filter Datasets by child Image ID
orphaned Boolean Find Datasets that are not in any Project
These query parameters are also supported (see above):
offset, limit, owner, group, childCount, normalize
GET /api/v0/m/datasets/
Response
{
"data": [
{
"Name": "Test data",
"Description": "This is the Dataset description",
"url:dataset": "https://server.openmicroscopy.org/api/v0/m/dataset/112/",
"url:images": "https://server.openmicroscopy.org/api/v0/m/datasets/112/images/",
"url:projects": "https://server.openmicroscopy.org/api/v0/m/datasets/112/projects/",
"@id": 112,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
# omitted for brevity
}
}
]
}
Datasets in a Project
Datasets can be filtered by parent Project using the ?project=id
query string but
you can also show Datasets in a Project using this URL:
GET /api/v0/m/projects/{project_id}/datasets/
Get a single Dataset
GET /api/v0/m/datasets/{dataset_id}/
Response
{
"data": {
"@id": 9702,
"Name": "My data",
"Description": "An example set",
"url:images": "https://server.openmicroscopy.org/api/v0/m/datasets/9702/images/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Dataset",
"omero:details": {
# omitted for brevity
}
}
}
List Images
When Images are listed, their Pixels
object is also loaded, which
includes dimensions and pixel sizes of the Image.
When a single Image is retrieved, the Channels
data is additionally
loaded.
Parameters
Name Type Description
------------------------------------------------------------------
dataset Number Filter Images by parent Dataset ID
orphaned Boolean Find Images that are not in any Dataset or Well
These query parameters are also supported (see above):
offset, limit, owner, group, normalize
GET /api/v0/m/images/
Response
{
"data": [
{
"@id": 16783,
"Name": "CFP_AurB_R3D.dv",
"AcquisitionDate": 1235730332000,
"omero:details": {
# omitted for brevity
},
"url:image": "https://server.openmicroscopy.org/api/v0/m/images/16783/",
"Pixels": {
"@id": 12801,
"SizeX": 512,
"SizeY": 512,
"SizeZ": 29,
"SizeC": 2,
"SizeT": 1,
"PhysicalSizeX": {
"Symbol": "µm",
"Value": 0.12698,
"@type": "TBD#LengthI",
"Unit": "MICROMETER"
},
"PhysicalSizeY": {
"Symbol": "µm",
"Value": 0.12698,
"@type": "TBD#LengthI",
"Unit": "MICROMETER"
},
"PhysicalSizeZ": {
"Symbol": "µm",
"Value": 0.2,
"@type": "TBD#LengthI",
"Unit": "MICROMETER"
},
"Type": {
"omero:details": {
# omitted for brevity
},
"@id": 6,
"@type": "TBD#PixelsType",
"value": "uint16"
},
"omero:sha1": "eae01c54191fd9cf4b09e3651e1899d677375b7d",
"omero:details": {
# omitted for brevity
},
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Pixels",
"SignificantBits": 16
},
"omero:series": 0,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Image"
}
]
}
Images in a Dataset
Images can be filtered by parent Dataset using the ?dataset=id
query string but
you can also show Images in a Dataset using this URL:
GET /api/v0/m/datasets/{dataset_id}/images/
Get a single Image
GET /api/v0/m/images/{image_id}/
Response
The response for a single Image is the same as for listing Images
above with the addition of Channels
data.
{
"data": [
{
"@id": 16783,
"Name": "CFP_AurB_R3D.dv",
"AcquisitionDate": 1235730332000,
"omero:details": {
# omitted for brevity
},
"Pixels": {
"@id": 12801,
"Channels": [
{
"omero:photometricInterpretation": {
"omero:details": {},
"@id": 5,
"@type": "TBD#PhotometricInterpretation",
"value": "Monochrome"
},
"Name": "CFP_JP4",
"Color": 65535,
"omero:details": {},
"ExcitationWavelength": {
"Symbol": "nm",
"Value": 436,
"@type": "TBD#LengthI",
"Unit": "NANOMETER"
},
"SamplesPerPixel": 1,
"NDFilter": 1,
"EmissionWavelength": {
"Symbol": "nm",
"Value": 470,
"@type": "TBD#LengthI",
"Unit": "NANOMETER"
},
"omero:LogicalChannelId": 12301,
"@id": 14451,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Channel"
},
{
"omero:photometricInterpretation": {
"omero:details": {},
"@id": 5,
"@type": "TBD#PhotometricInterpretation",
"value": "Monochrome"
},
"Name": "RD_TR-PE",
"Color": -16776961,
"omero:details": {},
"ExcitationWavelength": {
"Symbol": "nm",
"Value": 555,
"@type": "TBD#LengthI",
"Unit": "NANOMETER"
},
"SamplesPerPixel": 1,
"NDFilter": 0,
"EmissionWavelength": {
"Symbol": "nm",
"Value": 617,
"@type": "TBD#LengthI",
"Unit": "NANOMETER"
},
"omero:LogicalChannelId": 12303,
"@id": 14453,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Channel"
}
],
"SizeX": 512,
"SizeY": 512,
"SizeZ": 29,
"SizeC": 2,
"SizeT": 1,
"PhysicalSizeX": {
"Symbol": "µm",
"Value": 0.12698,
"@type": "TBD#LengthI",
"Unit": "MICROMETER"
},
"PhysicalSizeY": {
"Symbol": "µm",
"Value": 0.12698,
"@type": "TBD#LengthI",
"Unit": "MICROMETER"
},
"PhysicalSizeZ": {
"Symbol": "µm",
"Value": 0.2,
"@type": "TBD#LengthI",
"Unit": "MICROMETER"
},
"Type": {
"omero:details": {
# omitted for brevity
},
"@id": 6,
"@type": "TBD#PixelsType",
"value": "uint16"
},
"omero:sha1": "eae01c54191fd9cf4b09e3651e1899d677375b7d",
"omero:details": {
# omitted for brevity
},
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Pixels",
"SignificantBits": 16
},
"omero:series": 0,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Image"
}
]
}
Screens, Plates and Wells
For more information on the Screen, Plate, Well data model, please see the documentation page.
List Screens
Parameters
Name Type Description
------------------------------------------------------------------
plate Number Filter Datasets by child Plate ID
These query parameters are also supported (see above):
offset, limit, owner, group, childCount, normalize
GET /api/v0/m/screens/
Response
{
"data": [
{
"@id": 582,
"Name": "Test data",
"Description": "This is the Screen description",
"url:screen": "https://server.openmicroscopy.org/api/v0/m/screen/582/",
"url:plates": "https://server.openmicroscopy.org/api/v0/m/screen/582/plates/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Screen",
"omero:details": {
# omitted for brevity
}
}
]
}
Get a single Screen
GET /api/v0/m/screens/{screen_id}/
Response
{
"data": {
"@id": 582,
"Name": "Test data",
"Description": "This is the Screen description",
"url:plates": "https://server.openmicroscopy.org/api/v0/m/screen/582/plates/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Screen",
"omero:details": {
# omitted for brevity
}
}
}
List Plates
Parameters
Name Type Description
------------------------------------------------------------------
screen Number Filter Plates by parent Screen ID
well Number Filter Plates by child Well ID
orphaned Boolean Find Plates that are not in any Screen
These query parameters are also supported (see above):
offset, limit, owner, group, childCount, normalize
GET /api/v0/m/plates/
Response
{
"data": [
{
"@id": 5067,
"Name": "Plate name",
"Rows": 8,
"Columns": 12,
"RowNamingConvention": "letter",
"ColumnNamingConvention": "number",
"ExternalIdentifier": "003857",
"url:plate": "https://server.openmicroscopy.org/api/v0/m/plates/5067/",
"url:plateacquisitions": "https://server.openmicroscopy.org/api/v0/m/plates/5067/plateacquisitions/",
"url:wells": "https://server.openmicroscopy.org/api/v0/m/plates/5067/wells/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Plate",
"omero:details": {
# omitted for brevity
}
},
]
}
Plates in a Screen
Plates can be filtered by parent Screen using the ?screen=id
query string but
you can also show Plates in a Screen using this URL:
GET /api/v0/m/screens/{screen_id}/plates/
Get a single Plate
GET /api/v0/m/plates/{plate_id}/
Response
The response for a single Plate includes information on the WellSamples (fields) for each Well such as the min/max WellSampleIndex for the Plate.
{
"data": {
"@id": 5067,
"Name": "Plate name",
"Rows": 8,
"Columns": 12,
"RowNamingConvention": "letter",
"ColumnNamingConvention": "number",
"ExternalIdentifier": "003857",
"url:plate": "https://server.openmicroscopy.org/api/v0/m/plates/5067/",
"url:plateacquisitions": "https://server.openmicroscopy.org/api/v0/m/plates/5067/plateacquisitions/",
"url:wells": "https://server.openmicroscopy.org/api/v0/m/plates/5067/wells/",
"url:wellsampleindex_wells": [
"https://server.openmicroscopy.org/api/v0/m/plates/5068/wellsampleindex/0/wells/",
"https://server.openmicroscopy.org/api/v0/m/plates/5068/wellsampleindex/1/wells/",
"https://server.openmicroscopy.org/api/v0/m/plates/5068/wellsampleindex/2/wells/",
"https://server.openmicroscopy.org/api/v0/m/plates/5068/wellsampleindex/3/wells/"
],
"omero:wellsampleIndex": [
0,
3
],
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Plate",
"omero:details": {
# omitted for brevity
}
}
}
List Plate Acquisitions
A Plate Acquisition (run) is a collection of WellSamples, grouped by an acquisition time. A Plate may contain zero, one or more Plate Acquisitions.
GET /api/v0/m/plates/{plate_id}/plateacquisitions/
Response
{
"data": [
{
"@id": 4217,
"url:wellsampleindex_wells": [
"https://server.openmicroscopy.org/api/v0/m/plateacquisitions/4217/wellsampleindex/0/wells/"
"https://server.openmicroscopy.org/api/v0/m/plateacquisitions/4217/wellsampleindex/1/wells/"
"https://server.openmicroscopy.org/api/v0/m/plateacquisitions/4217/wellsampleindex/2/wells/"
],
"omero:details": {
# omitted for brevity
},
"MaximumFieldCount": 3,
"url:plateacquisition": "https://server.openmicroscopy.org/api/v0/m/plateacquisitions/4217/",
"omero:wellsampleIndex": [
0,
2
],
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#PlateAcquisition"
}
]
}
List Wells in a Plate
Each Well in a Plate may contain zero, one or many WellSamples (fields). By default, when listing Wells in a Plate, all of the WellSamples and Images will be loaded for each Well. Wells are ordered by Column and Row.
Parameters
The following query parameters can be used (as described above)
offset, limit, owner, normalize
GET /api/v0/m/plates/{plate_id}/wells/
Note
If there are a large number of WellSamples per Well, this has the
potential to load a large amount of data. This can be reduced by using
a smaller limit
on the number of Wells loaded or only loading a single
WellSample per Well, as described below.
Response
{
"data": [
{
"@id": 139,
"Column": 0,
"Row": 0,
"omero:details": {
# omitted for brevity
},
"url:well": "https://server.openmicroscopy.org/api/v0/m/wells/139/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Well",
"WellSamples": [
{
"PositionX": {
"Symbol": "reference frame",
"Value": 21864.47,
"@type": "TBD#LengthI",
"Unit": "REFERENCEFRAME"
},
"PositionY": {
"Symbol": "reference frame",
"Value": 36711.98,
"@type": "TBD#LengthI",
"Unit": "REFERENCEFRAME"
},
"omero:details": {
# omitted for brevity
},
"Image": {
"Name": "plate1.HTD [Well E02 Field #1]",
"AcquisitionDate": 1252939626000,
"omero:details": {
# omitted for brevity
},
"url:image": "https://server.openmicroscopy.org/api/v0/m/images/2942/",
"omero:series": 120,
"@id": 2942,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Image",
"Description": "Scan Time: Mon Sep 14 11:36:58 2009"
},
"PlateAcquisition": {
"omero:details": {
# omitted for brevity
},
"MaximumFieldCount": 4,
"StartTime": 1252938959000,
"EndTime": 1252939813000,
"@id": 102,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#PlateAcquisition"
},
"@id": 203,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#WellSample"
}
]
}
]
}
It is also possible to list all Wells without filtering by Plate, using the top-level
URL /api/v0/m/wells/
optionally filtering by the plate
query parameter.
List Wells by WellSample Index
To list Wells in a Plate, loading only a single WellSample and Image per Well, you can filter by WellSample Index. This list of Wells will not include empty Wells (Wells that have no WellSamples and Images).
GET /api/v0/m/plates/{plate_id}/wellsampleindex/{index}/wells/
It is also possible to use the Plate Acquisition ID instead of Plate ID, when the WellSample (field) at the specified index was acquired as part of that Plate Acquisition:
GET /api/v0/m/plateacquisitions/{plateacquisition_id}/wellsampleindex/{index}/wells/
Get a single Well
When a single Well is loaded, this will include all the WellSamples and Images with Pixels loaded.
GET /api/v0/m/wells/{well_id}/
ROIs and Shapes
Support for listing ROIs was added in API version 0.1. ROIs are linked to Images and contain one or more Shapes. Types of shape are Ellipse, Label, Line, Mask, Point, Polygon, Polyline and Rectangle.
List ROIs
When ROIs are listed, their child Shapes will also be loaded.
Parameters
Name Type Description
------------------------------------------------------------------
image Number Filter ROIs by Image ID
These query parameters are also supported (see above):
offset, limit, owner, group, normalize
GET /api/v0/m/rois/
Response
{
"data": [
{
"@id": 454,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#ROI",
"shapes": [
{
"FontStyle": "Normal",
"Locked": false,
"Width": 98,
"omero:details": {
# omitted for brevity
},
"Height": 135,
"FontFamily": "sans-serif",
"StrokeWidth": {},
"FontSize": {
"Symbol": "pt",
"Value": 12,
"@type": "TBD#LengthI",
"Unit": "POINT"
},
"FillColor": 1073741824,
"Y": 192,
"X": 189,
"StrokeColor": -993737532,
"TheT": 23,
"@id": 713,
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Rectangle",
"TheZ": 1
}
],
"omero:details": {
# omitted for brevity
},
},
]
}
ROIs on an Image
ROIs can be filtered by Image using the ?image=id
query string but
you can also show ROIs on an Image using this URL:
GET /api/v0/m/images/{image_id}/rois/
Experimenters and Groups
Support for listing Experimenters and Groups was added in API version 0.2. Experimenters are users of OMERO and can belong to one or more Groups. Groups are defined as ExperimenterGroups in the OME model.
Listing Experimenters
OMERO will only allow you to access details of Experimenters who are members of a non-private group that you are also a member of.
Parameters
Name Type Description
------------------------------------------------------------------
experimentergroup Number Filter Experimenters by Group
These query parameters are also supported (see above):
offset, limit
GET /api/v0/m/experimenters/
Response
{
"data": [
{
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Experimenter",
"@id": 10,
"omero:details": {
"@type": "TBD#Details",
"permissions": {
"@type": "TBD#Permissions",
"perm": "------",
"canAnnotate": true,
"canDelete": false,
"canEdit": false,
"canLink": true,
"isWorldWrite": false,
"isWorldRead": false,
"isGroupWrite": false,
"isGroupRead": false,
"isGroupAnnotate": false,
"isUserWrite": false,
"isUserRead": false
}
},
"FirstName": "Ben",
"LastName": "Nevis",
"UserName": "ben",
"url:experimenter": "https://server.openmicroscopy.org/web/api/v0/m/experimenters/10/",
"url:experimentergroups": "https://server.openmicroscopy.org/web/api/v0/m/experimenters/10/experimentergroups/"
},
]
}
Get a single Experimenter
Load an Experimenter with:
GET /api/v0/m/experimenters/{experimenter_id}/
Experimenters in a Group
Experimenters can be filtered by Group using the ?experimentergroup=id
query string but
you can also show Members of a Group using this URL:
GET /api/v0/m/experimentergroups/{group_id}/experimenters/
Listing Groups
Parameters
Name Type Description
------------------------------------------------------------------
experimenter Number Filter Groups by Experimenter
These query parameters are also supported (see above):
offset, limit
GET /api/v0/m/experimentergroups/
Response
{
"data": [
{
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#ExperimenterGroup",
"@id": 10,
"omero:details": {
"@type": "TBD#Details",
"permissions": {
"@type": "TBD#Permissions",
"perm": "------",
"canAnnotate": true,
"canDelete": false,
"canEdit": false,
"canLink": true,
"isWorldWrite": false,
"isWorldRead": false,
"isGroupWrite": false,
"isGroupRead": false,
"isGroupAnnotate": false,
"isUserWrite": false,
"isUserRead": false
}
},
"Name": "Swedlow Lab",
"url:experimentergroup": "https://server.openmicroscopy.org/web/api/v0/m/experimentergroups/10/",
"url:experimenters": "https://server.openmicroscopy.org/web/api/v0/m/experimentergroups/10/experimenters/"
},
]
}
Get a single Group
Load a Group with:
GET /api/v0/m/experimentergroups/{group_id}/
Groups for an Experimenter
Groups can be filtered by Experimenter using the ?experimenter=id
query string but
you can also show ExperimenterGroups that an Experimenter belongs to using this URL:
GET /api/v0/m/experimenters/{experimenter_id}/experimentergroups
Creating and saving objects
The JSON API currently supports creating and saving of a limited number of object types, namely Projects, Datasets and Screens. It is not yet possible to save objects with unloaded objects, such as an Image without Pixels or Channels loaded. We will be working to resolve these issues in future releases.
Creating and saving of JSON objects are handled by a single save
URL
and objects are identified by their @type
and @id
attributes.
Object types
The object @type
must be based on the currently supported Schema URL
which can be retrieved with:
GET /api/v0/
Response
{
"url:schema": "http://www.openmicroscopy.org/Schemas/OME/2016-06",
# other urls not shown
}
This can then be used to create a @type
by appending #
and the
object name, such as:
http://www.openmicroscopy.org/Schemas/OME/2016-06#Project
Creating objects
To create an object, POST the JSON for that object, including the ID of the OMERO group that the object should be saved in. Currently only creation of Projects, Datasets and Screens is supported.
POST /api/v0/m/save/?group={group_id}
Content
{
"Name": "My new Project",
"Description": "Created via the JSON API",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project"
}
Response
{
"data": {
"@id": 567,
"Name": "My new Project",
"Description": "Created via the JSON API",
"url:datasets": "https://server.openmicroscopy.org/api/v0/m/projects/3872/datasets/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
# omitted for brevity
}
}
}
Updating objects
The API supports PUT to replace existing objects with the submitted data. As mentioned above, the only objects that you can currently update are Projects, Datasets and Screens. The submitted JSON data can be constructed from scratch, but it will generally be more convenient and safer to GET the object, update it and save the edited JSON.
For example, to edit the Name of the Project in the previous example:
PUT /api/v0/m/save/
Content
{
"@id": 567,
"Name": "Edited Project Name",
"Description": "Created via the JSON API",
"url:datasets": "https://server.openmicroscopy.org/api/v0/m/projects/3872/datasets/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
# omitted for brevity
}
}
Response
{
"data": {
"@id": 567,
"Name": "Edited Project Name",
"Description": "Created via the JSON API",
"url:datasets": "https://server.openmicroscopy.org/api/v0/m/projects/3872/datasets/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
# omitted for brevity
}
}
}
Deleting objects
To delete a Project, Dataset or Screen, simply DELETE using the URL to that object. The deleted object will be returned. For example, to delete a Project:
DELETE /api/v0/m/projects/{project_id}/
Response
{
"data": {
"@id": 567,
"Name": "Edited Project Name",
"Description": "Created via the JSON API",
"url:datasets": "https://server.openmicroscopy.org/api/v0/m/projects/3872/datasets/",
"@type": "http://www.openmicroscopy.org/Schemas/OME/2016-06#Project",
"omero:details": {
# omitted for brevity
}
}
}