Skip to content

Protocol Documentation

Table of Contents

Top

grpc.proto

RdfStreamReceived

Acknowledgement of receiving a stream sent by the server to the client.

RdfStreamSubscribe

Subscribe command sent by the client to the server.

Field Type Label Description
topic string The topic to which the client wants to subscribe (UTF-8 encoded).
requested_options RdfStreamOptions Optional: the stream options requested by the client. The server should respond with a stream that matches these options. In case that is not possible, the server must respond with the INVALID_ARGUMENT error.

RdfStreamService

Pub/Sub service for RDF streams, to be implemented by the server.

Method Name Request Type Response Type Description
SubscribeRdf RdfStreamSubscribe RdfStreamFrame stream Subscribe to an RDF stream.
PublishRdf RdfStreamFrame stream RdfStreamReceived Publish an RDF stream. In case the server cannot process the stream, it must respond with the INVALID_ARGUMENT error.

Top

rdf.proto

RdfDatatypeEntry

Entry in the datatype lookup table

Field Type Label Description
id uint32 1-based identifier If id=0, it should be interpreted as previous_id + 1. If id=0 appears in the first RdfDatatypeEntry of the stream, it should be interpreted as 1.
value string Value of the datatype (UTF-8 encoded)

RdfDefaultGraph

Empty message indicating the default RDF graph.

RdfGraphEnd

End of a graph in a GRAPHS stream

RdfGraphStart

Start of a graph in a GRAPHS stream

In contrast to RdfQuad, setting the graph oneof to some value is always required. No repeated terms are allowed.

Field Type Label Description
g_iri RdfIri IRI
g_bnode string Blank node
g_default_graph RdfDefaultGraph Default graph
g_literal RdfLiteral Literal – only valid for generalized RDF streams

RdfIri

RDF IRIs The IRIs are reconstructed by the consumer using the prefix and name lookup tables.

Field Type Label Description
prefix_id uint32 1-based, refers to an entry in the prefix lookup. 0 signifies "use the same prefix_id as in the previous IRI". For this to work, IRIs must be processed strictly in order: firstly by stream row, then by term (subject, predicate, object, graph). This also applies recursively to RDF-star quoted triples. If 0 appears in the first IRI of the stream (and in any subsequent IRI), this should be interpreted as an empty ("") prefix. This is for example used when the prefix lookup table is disabled.
name_id uint32 1-based, refers to an entry in the name lookup. 0 signifies "use the previous name_id + 1". This requires the same order guarantees as prefixes. If 0 appears in the first IRI of the stream, it should be interpreted as name_id = 1.

RdfLiteral

RDF literals

Field Type Label Description
lex string The lexical form of the literal (required).
langtag string Language-tagged string.
datatype uint32 Typed literal. The datatype is a reference to an entry in the datatype lookup. This value is 1-based and the value of 0 is invalid (in contrast to prefix_id and name_id in RdfIri).

RdfNameEntry

Entry in the name lookup table

Field Type Label Description
id uint32 1-based identifier If id=0, it should be interpreted as previous_id + 1. If id=0 appears in the first RdfNameEntry of the stream, it should be interpreted as 1.
value string Value of the name (UTF-8 encoded)

RdfNamespaceDeclaration

Explicit namespace declaration

This does not correspond to any construct in the RDF Abstract Syntax. Rather, it is a hint to the consumer that the given IRI prefix (namespace) may be associated with a shorter name, like in Turtle syntax: PREFIX ex: <http://example.org/>

These short names (here "ex:") are NOT used in the RDF statement encoding. This is a purely cosmetic feature useful in cases where you want to preserve the namespace declarations from the original RDF document. These declarations have nothing in common with the prefix lookup table.

Field Type Label Description
name string Short name of the namespace (e.g., "ex") Do NOT include the colon.
value RdfIri IRI of the namespace (e.g., "http://example.org/"))

RdfPrefixEntry

Entry in the prefix lookup table

Note: the prefixes in the lookup table can be arbitrary strings, and are NOT meant to be user-facing. They are only used for IRI compression. To transmit user-facing namespace declarations for cosmetic purposes, use RdfNamespaceDeclaration.

Field Type Label Description
id uint32 1-based identifier If id=0, it should be interpreted as previous_id + 1. If id=0 appears in the first RdfPrefixEntry of the stream, it should be interpreted as 1.
value string Value of the prefix (UTF-8 encoded)

RdfQuad

RDF quad

Fields 1–12 are repeated from RdfTriple for performance reasons.

Similarly to RdfTriple, this message allows for representing generalized RDF quads (for example, with literals as predicates). Whether this is used in the stream is determined by the stream options (see RdfStreamOptions).

If no field in a given oneof is set, the term is interpreted as a repeated term – the same as the term in the same position in the previous quad. In the first quad of the stream, all terms must be set.

Field Type Label Description
s_iri RdfIri IRI
s_bnode string Blank node
s_literal RdfLiteral Literal Only valid in a generalized RDF stream.
s_triple_term RdfTriple RDF-star quoted triple
p_iri RdfIri IRI
p_bnode string Blank node Only valid in a generalized RDF stream.
p_literal RdfLiteral Literal Only valid in a generalized RDF stream.
p_triple_term RdfTriple RDF-star quoted triple
o_iri RdfIri IRI
o_bnode string Blank node
o_literal RdfLiteral Literal
o_triple_term RdfTriple RDF-star quoted triple
g_iri RdfIri IRI
g_bnode string Blank node
g_default_graph RdfDefaultGraph Default graph
g_literal RdfLiteral Literal – only valid for generalized RDF streams

RdfStreamFrame

RDF stream frame – base message for RDF streams.

Field Type Label Description
rows RdfStreamRow repeated Stream rows

RdfStreamOptions

RDF stream options

Field Type Label Description
stream_name string Name of the stream (completely optional). This may be used for, e.g., topic names in a pub/sub system.
physical_type PhysicalStreamType Type of the stream (required)
generalized_statements bool Whether the stream may contain generalized triples, quads, or datasets
rdf_star bool Whether the stream may contain RDF-star statements
max_name_table_size uint32 Maximum size of the name lookup table
max_prefix_table_size uint32 Maximum size of the prefix lookup table
max_datatype_table_size uint32 Maximum size of the datatype lookup table
logical_type LogicalStreamType Logical (RDF-STaX-based) stream type In contrast to the physical type, this field is entirely optional.
version uint32 Protocol version (required) For Jelly 1.0.x value must be 1. For Jelly 1.1.x value must be 2. For custom extensions, the value must be 10000 or higher.

RdfStreamRow

RDF stream row

Field Type Label Description
options RdfStreamOptions Stream options. Must occur at the start of the stream.
triple RdfTriple RDF triple statement. Valid in streams of physical type TRIPLES or GRAPHS.
quad RdfQuad RDF quad statement. Only valid in streams of physical type QUADS.
graph_start RdfGraphStart Graph boundary: ends the currently transmitted graph and starts a new one Only valid in streams of physical type GRAPHS.
graph_end RdfGraphEnd Explicit end of a graph. Signals the consumer that the transmitted graph is complete. Only valid in streams of physical type GRAPHS.
namespace RdfNamespaceDeclaration Explicit namespace declaration.
name RdfNameEntry Entry in the name lookup table.
prefix RdfPrefixEntry Entry in the prefix lookup table.
datatype RdfDatatypeEntry Entry in the datatype lookup table.

RdfTriple

RDF triple

For each term (subject, predicate, object), the fields are repeated for performance reasons. This is to avoid the need for boxing each term in a separate message.

Note: this message allows for representing generalized RDF triples (for example, with literals as predicates). Whether this is used in the stream is determined by the stream options (see RdfStreamOptions).

If no field in a given oneof is set, the term is interpreted as a repeated term – the same as the term in the same position in the previous triple. In the first triple of the stream, all terms must be set. All terms must also be set in quoted triples (RDF-star).

Field Type Label Description
s_iri RdfIri IRI
s_bnode string Blank node
s_literal RdfLiteral Literal Only valid in a generalized RDF stream.
s_triple_term RdfTriple RDF-star quoted triple
p_iri RdfIri IRI
p_bnode string Blank node Only valid in a generalized RDF stream.
p_literal RdfLiteral Literal Only valid in a generalized RDF stream.
p_triple_term RdfTriple RDF-star quoted triple
o_iri RdfIri IRI
o_bnode string Blank node
o_literal RdfLiteral Literal
o_triple_term RdfTriple RDF-star quoted triple

LogicalStreamType

Logical stream type, according to the RDF Stream Taxonomy (RDF-STaX). Type 0 is reserved for the unspecified stream type. The rest of the type numbers follow the taxonomical structure of RDF-STaX. For example: 1 is a subtype of 0, 13 and 23 are subtypes of 3, 114 is a subtype of 14, etc.

Types 1–4 correspond to the four base concrete stream types. Their subtypes can be in most cases simply processed in the same way as the base types. Therefore, implementations can take the modulo 10 of the stream type to determine the base type of the stream and use this information to select the appropriate processing logic.

RDF-STaX version: 1.1.2 https://w3id.org/stax/1.1.2

^ The above URL is used to automatically determine the version of RDF-STaX in the Jelly protocol specification. Please keep it up-to-date and in the same format.

Name Number Description
LOGICAL_STREAM_TYPE_UNSPECIFIED 0 Unspecified stream type – invalid
LOGICAL_STREAM_TYPE_FLAT_TRIPLES 1 Flat RDF triple stream https://w3id.org/stax/ontology#flatTripleStream
LOGICAL_STREAM_TYPE_FLAT_QUADS 2 Flat RDF quad stream https://w3id.org/stax/ontology#flatQuadStream
LOGICAL_STREAM_TYPE_GRAPHS 3 RDF graph stream https://w3id.org/stax/ontology#graphStream
LOGICAL_STREAM_TYPE_DATASETS 4 RDF dataset stream https://w3id.org/stax/ontology#datasetStream
LOGICAL_STREAM_TYPE_SUBJECT_GRAPHS 13 RDF subject graph stream (subtype of RDF graph stream) https://w3id.org/stax/ontology#subjectGraphStream
LOGICAL_STREAM_TYPE_NAMED_GRAPHS 14 RDF named graph stream (subtype of RDF dataset stream) https://w3id.org/stax/ontology#namedGraphStream
LOGICAL_STREAM_TYPE_TIMESTAMPED_NAMED_GRAPHS 114 RDF timestamped named graph stream (subtype of RDF dataset stream) https://w3id.org/stax/ontology#timestampedNamedGraphStream

PhysicalStreamType

Physical stream type This determines how the data is encoded in the stream, not the logical structure of the data. See LogicalStreamType for the latter.

Name Number Description
PHYSICAL_STREAM_TYPE_UNSPECIFIED 0 Unspecified stream type – invalid
PHYSICAL_STREAM_TYPE_TRIPLES 1 RDF triples
PHYSICAL_STREAM_TYPE_QUADS 2 RDF quads
PHYSICAL_STREAM_TYPE_GRAPHS 3 RDF triples grouped in graphs

Scalar Value Types

.proto Type Notes C++ Java Python Go C# PHP Ruby
double double double float float64 double float Float
float float float float float32 float float Float
int32 Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint32 instead. int32 int int int32 int integer Bignum or Fixnum (as required)
int64 Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint64 instead. int64 long int/long int64 long integer/string Bignum
uint32 Uses variable-length encoding. uint32 int int/long uint32 uint integer Bignum or Fixnum (as required)
uint64 Uses variable-length encoding. uint64 long int/long uint64 ulong integer/string Bignum or Fixnum (as required)
sint32 Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int32s. int32 int int int32 int integer Bignum or Fixnum (as required)
sint64 Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int64s. int64 long int/long int64 long integer/string Bignum
fixed32 Always four bytes. More efficient than uint32 if values are often greater than 2^28. uint32 int int uint32 uint integer Bignum or Fixnum (as required)
fixed64 Always eight bytes. More efficient than uint64 if values are often greater than 2^56. uint64 long int/long uint64 ulong integer/string Bignum
sfixed32 Always four bytes. int32 int int int32 int integer Bignum or Fixnum (as required)
sfixed64 Always eight bytes. int64 long int/long int64 long integer/string Bignum
bool bool boolean boolean bool bool boolean TrueClass/FalseClass
string A string must always contain UTF-8 encoded or 7-bit ASCII text. string String str/unicode string string string String (UTF-8)
bytes May contain any arbitrary sequence of bytes. string ByteString str []byte ByteString string String (ASCII-8BIT)