2021-06-07 14:29:36 -05:00
// Copyright 2020 Prysmatic Labs.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
syntax = "proto3" ;
2021-08-13 12:55:24 +02:00
package ethereum . eth.service ;
2021-06-07 14:29:36 -05:00
import "google/api/annotations.proto" ;
import "google/protobuf/descriptor.proto" ;
2021-08-13 11:12:18 +02:00
import "proto/eth/v1/events.proto" ;
2021-06-07 14:29:36 -05:00
import "proto/gateway/event_source.proto" ;
2021-08-13 12:55:24 +02:00
option csharp_namespace = "Ethereum.Eth.Service" ;
2022-08-16 12:20:13 +00:00
option go_package = "github.com/prysmaticlabs/prysm/v3/proto/eth/service" ;
2021-06-07 14:29:36 -05:00
option java_multiple_files = true ;
2021-08-13 11:12:18 +02:00
option java_outer_classname = "EventsServiceProto" ;
2021-08-13 12:55:24 +02:00
option java_package = "org.ethereum.eth.service" ;
option php_namespace = "Ethereum\\Eth\\Service" ;
2021-06-07 14:29:36 -05:00
// Events API
//
2021-08-19 13:00:57 -05:00
// This service is defined in the upstream Ethereum consensus APIs repository (beacon-apis/apis/debug).
2021-06-07 14:29:36 -05:00
service Events {
2022-06-21 16:29:44 +02:00
// Provides endpoint to subscribe to beacon node Server-Sent-Events stream. Consumers should use eventsource implementation to listen on those events.
// Servers may send SSE comments beginning with : for any purpose, including to keep the event stream connection alive in the presence of proxy servers.
//
// Spec: https://ethereum.github.io/beacon-APIs/?urls.primaryName=v2.3.0#/Events/eventstream
2021-08-13 12:55:24 +02:00
rpc StreamEvents ( v1.StreamEventsRequest ) returns ( stream gateway.EventSource ) {
2021-06-09 11:49:03 -05:00
option ( google.api.http ) = {
2021-09-21 21:20:57 +02:00
get : "/internal/eth/v1/events"
2021-06-09 11:49:03 -05:00
} ;
}
2021-06-07 14:29:36 -05:00
}