Skip to content

gRPC

This page provides a description of the Fathom gRPC API. This should only ever be interacted with via a Fathom client SDK, but is here for completion.


fathom/api/v2/common.proto

Messages

Metadata

Metadata for requests made to the API.

Field Type Description
project_id string In some cases you may require Fathom API queries to be billed as part of an internal project. The project ID is stored in Fathom's usage database and will be used to itemise usage for billing purposes.

fathom/api/v2/fathom.proto

FathomService

FathomService defines the externally facing API for querying Fathom data.

GetPolygonData

rpc GetPolygonData(GetPolygonDataRequest) GetPolygonDataResponse

Returns data in tiff format for the given polygon from supplied layers.

GetPointsData

rpc GetPointsData(GetPointsDataRequest) GetPointsDataResponse

Returns data for given points (locations) from supplied layers.

GetGeoJSONPointsData

rpc GetGeoJSONPointsData(GetGeoJSONPointsDataRequest) GetPointsDataResponse

Returns data for the supplied layers using points parsed from the given GeoJSON. Returns an error if any geometries in the request are not Point or MultiPoint.

GetGeoJSONPolygonData

rpc GetGeoJSONPolygonData(GetGeoJSONPolygonDataRequest) GetPolygonDataResponse

Returns data for the supplied layers using a polygon parsed from the given GeoJSON. Returns an error if there is not exactly one polygon geometry in the request.

GetGeoJSONPolygonStats

rpc GetGeoJSONPolygonStats(GetGeoJSONPolygonStatsRequest) GetPolygonStatsResponse

Returns stats for the supplied layers using a polygon parsed from the given GeoJSON. Returns an error if there is not exactly one polygon geometry in the request.

GetPolygonStats

rpc GetPolygonStats(GetPolygonStatsRequest) GetPolygonStatsResponse

Returns statistics data retrieved from making geo-query to given polygon and from the layers.

GetShapePolygonStats

rpc GetShapePolygonStats(GetShapePolygonStatsRequest) GetShapePolygonStatsResponse

Returns statistics for the supplied layers using the primitive polygon shape described in the request.

GetWKTPolygonStats

rpc GetWKTPolygonStats(GetWKTPolygonStatsRequest) GetWKTPolygonStatsResponse

Returns statistics for the supplied layers using the wkt polygon described in the request.

CreateAccessToken

rpc CreateAccessToken(CreateAccessTokenRequest) CreateAccessTokenResponse

Returns a token used to access the API.

QuotePoints

rpc QuotePoints(QuotePointsRequest) QuotePointsResponse

Quote the cost to get points data

QuotePolygon

rpc QuotePolygon(QuotePolygonRequest) QuotePolygonResponse

Quote the cost to get polygon data

GetLargePolygonData

rpc GetLargePolygonData(GetLargePolygonDataRequest) GetLargePolygonDataResponse

Returns data as a link to a compressed archive of 1 tif per layer for the given polygon from supplied layers. Can only accept a maximum of 40 layers.

Messages

CreateAccessTokenRequest

Field Type Description
client_id string Client ID to identify the user. Required.
client_secret string Client Secret used with the provided Client ID. Required.

CreateAccessTokenResponse

Field Type Description
access_token string JWT to access the API.
expire_secs uint64 Seconds until this token expires

GetGeoJSONPointsDataRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
points_geojson map GetGeoJSONPointsDataRequest.PointsGeojsonEntry none

GetGeoJSONPointsDataRequest.PointsGeojsonEntry

Field Type Description
key string none
value google.protobuf.Value none

GetGeoJSONPolygonDataRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
polygon_geojson map GetGeoJSONPolygonDataRequest.PolygonGeojsonEntry none

GetGeoJSONPolygonDataRequest.PolygonGeojsonEntry

Field Type Description
key string none
value google.protobuf.Value none

GetGeoJSONPolygonStatsRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
polygon_geojson map GetGeoJSONPolygonStatsRequest.PolygonGeojsonEntry none

GetGeoJSONPolygonStatsRequest.PolygonGeojsonEntry

Field Type Description
key string none
value google.protobuf.Value none

GetLargePolygonDataRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
polygon Polygon none

GetLargePolygonDataResponse

Field Type Description
download_url string URL to download results of the request query.
result_codes map GetLargePolygonDataResponse.ResultCodesEntry Mapping of layer ID to result code for the polygon. If the code was OUT_OF_BOUNDS, that polygon will not be in the zip file returned in download_url.

GetLargePolygonDataResponse.ResultCodesEntry

Field Type Description
key string none
value PolygonResultCode none

GetPointsDataRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
points repeated Point none

GetPointsDataResponse

Field Type Description
results map GetPointsDataResponse.ResultsEntry Map of layer ID to the points result for that layer

GetPointsDataResponse.ResultsEntry

Field Type Description
key string none
value PointResult none

GetPolygonDataRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
polygon Polygon none

GetPolygonDataResponse

Field Type Description
results map GetPolygonDataResponse.ResultsEntry Map of layer ID to the polygon result for that layer

GetPolygonDataResponse.ResultsEntry

Field Type Description
key string none
value PolygonResult none

GetPolygonStatsRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
polygon Polygon none

GetPolygonStatsResponse

Field Type Description
results map GetPolygonStatsResponse.ResultsEntry Map of layer ID to the polygon stats for that layer

GetPolygonStatsResponse.ResultsEntry

Field Type Description
key string none
value PolygonStats none

GetShapePolygonStatsRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
shape Shape none
size uint32 If the shape is SQUARE, it is taken as the half side-length. If the shape is CIRCLE, size is taken as the radius.

size in meters. | | center | Point | none |

GetShapePolygonStatsResponse

Field Type Description
results map GetShapePolygonStatsResponse.ResultsEntry Map of layer ID to the polygon stats for that layer

GetShapePolygonStatsResponse.ResultsEntry

Field Type Description
key string none
value PolygonStats none

GetWKTPolygonStatsRequest

Field Type Description
layer_ids repeated string none
oneof _metadata.metadata optional Metadata none
wkt string none

GetWKTPolygonStatsResponse

Field Type Description
results map GetWKTPolygonStatsResponse.ResultsEntry Map of layer ID to the polygon stats for that layer

GetWKTPolygonStatsResponse.ResultsEntry

Field Type Description
key string none
value PolygonStats none

Point

A Point represents a WGS84 latitude-longitude pair.

Latitudes MUST be in the range +/-90 degrees and longitude MUST be in the range +/-180 degrees.

Field Type Description
longitude double none
latitude double none

PointResult

Resolution and the result for each point

Field Type Description
values repeated PointResultValue none

PointResultValue

The result value for a point in a query.

Field Type Description
query_point Point The point from the original request.
oneof _val.val optional int32 The actual result value.

Polygon

A Polygon represents a GeoJSON polygon with just one loop (LineString). It MUST be closed (i.e. the first and last Points are the same), with four or more Points. The inside of a polygon loop is the left-hand side of an observer walking the edges in vertex order (i.e. vertices MUST be counter-clockwise if viewed from above).

Reference: https://datatracker.ietf.org/doc/html/rfc7946#section-3.1.6. This does not support Polygon with holes, just boundary polygon.

Field Type Description
points repeated Point none

PolygonResult

The raw tiff data and resolution for the result of a polygon calculation

Field Type Description
oneof result.geo_tiff bytes A GeoTIFF file
oneof result.code PolygonResultCode A code indicating the reason why a result could not be calculated for the given polygon

PolygonStats

Field Type Description
oneof _mean.mean optional int32 The fields are optional to make the field presence explicit because the value can be 0. See: https://protobuf.dev/programming-guides/field_presence/
oneof _min.min optional int32 none
oneof _max.max optional int32 none
oneof _std_dev.std_dev optional int32 none
oneof _share_above_zero.share_above_zero optional double Share (on a scale of 0 to 1) of the pixels in the provided polygon that have a value above zero.

QuotePointsRequest

Field Type Description
layer_ids repeated string none
points repeated Point none

QuotePointsResponse

Field Type Description
total double none
currency string none

QuotePolygonRequest

Field Type Description
layer_ids repeated string none
polygon Polygon none

QuotePolygonResponse

Field Type Description
total double none
currency string none

Enums

PolygonResultCode

PolygonResultCode is an code corresponding to why polygon data may not have been returned.

Name Number Description
POLYGON_RESULT_CODE_UNSPECIFIED 0 none
POLYGON_RESULT_CODE_OUT_OF_BOUNDS 1 Returned when the given polygon covered an area not covered by the requested dataset.
POLYGON_RESULT_CODE_OK 2 Returned when the given polygon was computed successfully. Should only be returned by the large polygon endpoint.

Resolution

Name Number Description
RESOLUTION_UNSPECIFIED 0 none
RESOLUTION_1_ARC_SEC 1 1 arc-sec.
RESOLUTION_THIRD_ARC_SEC 2 1/3 arc-sec.
RESOLUTION_3_ARC_SEC 3 3 arc-sec

Shape

Name Number Description
SHAPE_UNSPECIFIED 0 none
SHAPE_CIRCLE 1 none
SHAPE_SQUARE 2 none

fathom/api/v2/portfolio.proto

PortfolioService

CreatePortfolioTask

rpc CreatePortfolioTask(CreatePortfolioTaskRequest) CreatePortfolioTaskResponse

CreatePortfolioTask creates a Portfolio Task and returns a task ID and signed URL. The task ID is used to check on the status of the task. The signed URL is the location to upload the Portfolio csv.

GetPortfolioTaskStatus

rpc GetPortfolioTaskStatus(GetPortfolioTaskStatusRequest) GetPortfolioTaskStatusResponse

Fetch information about the status of a portfolio task

GetPortfolioQuotaInfo

rpc GetPortfolioQuotaInfo(.google.protobuf.Empty) GetPortfolioQuotaInfoResponse

GetPortfolioQuotaInfo gets information about portfolios

Messages

CreatePortfolioTaskRequest

Creates a new portfolio request.

Field Type Description
layer_ids repeated string Layer IDs to be requested.
metadata Metadata none

CreatePortfolioTaskResponse

Returned on the creation of a new portfolio task

Field Type Description
task_id string Task UUID.
upload_url string Document upload URL, it will be in form a signedURL.

GetPortfolioQuotaInfoResponse

Field Type Description
used int64 Total number of portfolios 'units' used this month
remaining int64 Number remaining for this month. Note this may be negative, in which case that's how far over the quota it's gone.

GetPortfolioTaskStatusRequest

Query the status of an existing portfolio task.

Field Type Description
task_id string Task UUID from CreatePortfolioTaskResponse

GetPortfolioTaskStatusResponse

The status of an existing large portfolio task.

Field Type Description
task_status TaskStatus Status of the task.
download_url string URL to download results from if the status was COMPLETE.
errors repeated string Any errors that occurred during processing.

Enums

TaskStatus

The state of a Portfolio task.

Name Number Description
TASK_STATUS_UNSPECIFIED 0 none
TASK_STATUS_PENDING 1 none
TASK_STATUS_COMPLETE 2 none
TASK_STATUS_ERROR 3 none
TASK_STATUS_IN_PROGRESS 4 none
TASK_STATUS_EXPIRED 5 none
TASK_STATUS_QUEUED 6 none

proto/data/data.proto

Extra data specifications for requests

Enums

Resolution

Name Number Description
RESOLUTION_UNSPECIFIED 0 none
RESOLUTION_1_ARC_SEC 1 1 arc-sec.
RESOLUTION_THIRD_ARC_SEC 2 1/3 arc-sec. TODO: change to RESOLUTION_1_3_ARC_SEC
RESOLUTION_3_ARC_SEC 3 3 arc-sec

proto/fathom/fathom.proto

The core specification for the Fathom API

FathomService

FathomService defines the externally facing API for querying Fathom data.

GetData

rpc GetData(GetDataRequest) GetDataResponse

GetData returns data from a specified geometry, associated with one or more layers. The HTTP/JSON<->gRPC Transcoding uses a custom method just because it'll be easier to transcode the whole request body using POST method and avoid using query parameters with GET.

GetPolygonStats

rpc GetPolygonStats(GetPolygonStatsRequest) GetPolygonStatsResponse

GetPolygonStats calculates some commonly used statistics for a polygonal area with the given layer IDs.

CreateAccessToken

rpc CreateAccessToken(CreateAccessTokenRequest) CreateAccessTokenResponse

CreateAccessToken returns a JWT used to access the API.

Messages

CreateAccessTokenRequest

Field Type Description
client_id string Client ID to identify the user. Required.
client_secret string Client Secret used with the provided Client ID. Required.

CreateAccessTokenResponse

Field Type Description
access_token string JWT to access the API.
expire_secs uint64 Seconds until this token expires

Data

Data represents a subset of data from a single layer.

Field Type Description
resolution data.Resolution none
values repeated Data.Value none
oneof payload.polygons Polygons none
oneof payload.code Code none

Data.Value

Field Type Description
sw_corner geo.Point none
query_point geo.Point none
oneof payload.val uint32 none
oneof payload.code Code none

GetDataRequest

Field Type Description
oneof coordinates.polygon geo.Polygon none
oneof coordinates.points geo.MultiPoint none
oneof coordinates.shp_file bytes A shp_file is the contents of a .shp shapefile only, not the entire zip archive.

Shape file headers are at least 68 bytes | | layers | Layers | Layer IDs for the request | | metadata | map GetDataRequest.MetadataEntry | Extra metadata for the request |

GetDataRequest.MetadataEntry

Field Type Description
key string none
value string none

GetDataResponse

Field Type Description
results map GetDataResponse.ResultsEntry Mapping from layer_id to the data result.

GetDataResponse.ResultsEntry

Field Type Description
key string none
value Data none

GetPolygonStatsRequest

Field Type Description
polygon geo.Polygon The polygon to fetch data for
layers Layers Layer IDs for the request
metadata map GetPolygonStatsRequest.MetadataEntry Extra metadata for the request

GetPolygonStatsRequest.MetadataEntry

Field Type Description
key string none
value string none

GetPolygonStatsResponse

Field Type Description
stats map GetPolygonStatsResponse.StatsEntry Mapping from layer_id to the stats result.

GetPolygonStatsResponse.StatsEntry

Field Type Description
key string none
value PolygonStats none

Layers

Field Type Description
oneof ids.layer_ids Layers.Identifiers none

Layers.Identifiers

Field Type Description
ids repeated string none

PolygonStats

Field Type Description
oneof _mean.mean optional int32 The fields are optional to make the field presence explicit because the value can be 0. See: https://protobuf.dev/programming-guides/field_presence/
oneof _min.min optional int32 none
oneof _max.max optional int32 none
oneof _stddev.stddev optional int32 none

Polygons

Field Type Description
geo_tiffs repeated bytes none

Enums

Code

This is used to explain why a value has not been returned for a point or polygon. Usually NO_DATA means that the requested layer does not have data for the requested area.

Name Number Description
UNSPECIFIED 0 none
NO_DATA 1 none
PERMANENT_WATER 2 none

proto/geo/geo.proto

Data specifications for requests

Messages

LineString

A LineString is an array of two or more Points.

Field Type Description
points repeated Point none

MultiPoint

Field Type Description
points repeated Point none

Point

A Point represents a WGS84 latitude-longitude pair.

Latitudes MUST be in the range +/-90 degrees and longitude MUST be in the range +/-180 degrees.

Field Type Description
longitude double none
latitude double none

Polygon

A Polygon represents a GeoJSON polygon. Each LineString MUST be closed (i.e. the first and last Points are the same), with four or more Points. The inside of a polygon loop is the left-hand side of an observer walking the edges in vertex order (i.e. vertices MUST be counter-clockwise if viewed from above).

Reference: https://datatracker.ietf.org/doc/html/rfc7946#section-3.1.6

Field Type Description
lines repeated LineString none