dlt_gateway.proto 3.67 KB
Newer Older
// Copyright 2021-2023 H2020 TeraFlow (https://www.teraflow-h2020.eu/)
//
// 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.

Ricard Vilalta's avatar
Ricard Vilalta committed
syntax = "proto3";
package dlt;

import "context.proto";

Ricard Vilalta's avatar
Ricard Vilalta committed
service DltGatewayService {
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
  rpc RecordToDlt   (DltRecord                 ) returns (       DltRecordStatus  ) {}
  rpc GetFromDlt    (DltRecordId               ) returns (       DltRecord        ) {}
  rpc SubscribeToDlt(DltRecordSubscription     ) returns (stream DltRecordEvent   ) {}
  rpc GetDltStatus  (context.TeraFlowController) returns (       DltPeerStatus    ) {}  // NEC is checking if it is possible
  rpc GetDltPeers   (context.Empty             ) returns (       DltPeerStatusList) {}  // NEC is checking if it is possible
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
enum DltRecordTypeEnum {
  DLTRECORDTYPE_UNDEFINED = 0;
  DLTRECORDTYPE_CONTEXT   = 1;
  DLTRECORDTYPE_TOPOLOGY  = 2;
  DLTRECORDTYPE_DEVICE    = 3;
  DLTRECORDTYPE_LINK      = 4;
  DLTRECORDTYPE_SERVICE   = 5;
  DLTRECORDTYPE_SLICE     = 6;
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
enum DltRecordOperationEnum {
  DLTRECORDOPERATION_UNDEFINED = 0;
  DLTRECORDOPERATION_ADD       = 1;
  DLTRECORDOPERATION_UPDATE    = 2;
  DLTRECORDOPERATION_DELETE    = 3;
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
enum DltRecordStatusEnum {
  DLTRECORDSTATUS_UNDEFINED = 0;
  DLTRECORDSTATUS_SUCCEEDED = 1;
  DLTRECORDSTATUS_FAILED    = 2;
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
enum DltStatusEnum {
  DLTSTATUS_UNDEFINED    = 0;
  DLTSTATUS_NOTAVAILABLE = 1;
  DLTSTATUS_INITIALIZED  = 2;
  DLTSTATUS_AVAILABLE    = 3;
  DLTSTATUS_DEINIT       = 4;
Ricard Vilalta's avatar
Ricard Vilalta committed
}

message DltRecordId {
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
  context.Uuid      domain_uuid = 1;          // unique identifier of domain owning the record
  DltRecordTypeEnum type        = 2;          // type of record
  context.Uuid      record_uuid = 3;          // unique identifier of the record within the domain context_uuid/topology_uuid
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
message DltRecord {
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
  DltRecordId            record_id = 1;       // record identifier
  DltRecordOperationEnum operation = 2;       // operation to be performed over the record
  string                 data_json = 3;       // record content: JSON-encoded record content
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
message DltRecordSubscription {
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
  // retrieved events have to match ALL conditions.
  //   i.e., type in types requested, AND operation in operations requested
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
  // TODO: consider adding a more sophisticated filtering
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
  repeated DltRecordTypeEnum      type      = 1;  // selected event types, empty=all
  repeated DltRecordOperationEnum operation = 2;  // selected event operations, empty=all
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
message DltRecordEvent {
  context.Event event     = 1;                // common event data (timestamp & event_type)
  DltRecordId   record_id = 2;                // record identifier associated with this event
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
message DltRecordStatus {
  DltRecordId         record_id     = 1;      // identifier of the associated record
  DltRecordStatusEnum status        = 2;      // status of the record
  string              error_message = 3;      // error message in case of failure, empty otherwise
Ricard Vilalta's avatar
Ricard Vilalta committed
}

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
message DltPeerStatus {
  context.TeraFlowController controller = 1;  // Identifier of the TeraFlow controller instance
  DltStatusEnum              status     = 2;  // Status of the TeraFlow controller instance
}
Ricard Vilalta's avatar
Ricard Vilalta committed

Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
message DltPeerStatusList {
  repeated DltPeerStatus peers = 1;           // List of peers and their status
}