Class

TrackerEndpointHttp

Description [src]

final class Tracker.EndpointHttp : Tracker.Endpoint {
  /* No available fields */
}

TrackerEndpointHttp makes the RDF data in a TrackerSparqlConnection accessible to other hosts via HTTP.

This object is a TrackerEndpoint subclass that exports a TrackerSparqlConnection so its RDF data is accessible via HTTP requests on the given port. This endpoint implementation is compliant with the SPARQL protocol specifications and may interoperate with other implementations.

// This host has "example.local" hostname
endpoint = tracker_endpoint_http_new (sparql_connection,
                                      8080,
                                      tls_certificate,
                                      NULL,
                                      &error);

// From another host
connection = tracker_sparql_connection_remote_new ("http://example.local:8080/sparql");

Access to HTTP endpoints may be managed via the TrackerEndpointHttp::block-remote-address signal, the boolean return value expressing whether the connection is blocked or not. Inspection of the requester address is left up to the user. The default value allows all requests independently of their provenance, users are encouraged to add a handler.

If the provided GTlsCertificate is NULL, the endpoint will allow plain HTTP connections. Users are encouraged to provide a certificate in order to use HTTPS.

As a security measure, and in compliance specifications, the HTTP endpoint does not handle database updates or modifications in any way. The database content is considered to be entirely managed by the process that creates the HTTP endpoint and owns the TrackerSparqlConnection.

A TrackerEndpointHttp may be created on a different thread/main context from the one that created TrackerSparqlConnection.

Available since:3.1

Ancestors

Implements

  • GInitable

Constructors

tracker_endpoint_http_new

Sets up a Tracker endpoint to listen via HTTP, in the given port. If certificate is not NULL, HTTPS may be used to connect to the endpoint.

Available since: 3.1

Properties

Tracker.EndpointHttp:http-certificate

GTlsCertificate to encrypt the communication.

Tracker.EndpointHttp:http-port

HTTP port used to listen requests.

Properties inherited from TrackerEndpoint (4)
Tracker.Endpoint:allowed-graphs

RDF graphs that are allowed to be accessed through queries to this endpoint. See tracker_endpoint_set_allowed_graphs().

Available since: 3.7

Tracker.Endpoint:allowed-services

External SPARQL endpoints that are allowed to be accessed through queries to this endpint. See tracker_endpoint_set_allowed_services().

Available since: 3.7

Tracker.Endpoint:readonly

Whether the endpoint allows SPARQL updates or not. See tracker_endpoint_set_readonly().

Available since: 3.7

Tracker.Endpoint:sparql-connection

The TrackerSparqlConnection being proxied by this endpoint.

Signals

Tracker.EndpointHttp::block-remote-address

Allows control over the connections stablished. The given address is that of the requesting peer.