// Common Protocol Buffers for Saturnin services and microservices
// Copyright 2019 Firebird Project. All rights reserved.
// https://www.firebirdsql.org/
// https://saturnin.rtfd.io
//
// License: The MIT License
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom
// the Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
syntax = "proto3";
package saturnin.core.protobuf;
import "google/protobuf/struct.proto";
// Enums
// Service type
enum ServiceTypeEnum {
SVC_TYPE_UNKNOWN = 0 ; // Not a valid option, defined only to handle undefined values
SVC_TYPE_DATA_PROVIDER = 1 ; // Data Pipe Service that collects and pass on data.
SVC_TYPE_DATA_FILTER = 2 ; // Data Pipe Service that process data from input and sends results to output
SVC_TYPE_DATA_CONSUMER = 3 ; // Data Pipe Servuce that consumes input data
SVC_TYPE_PROCESSING = 4 ; // Service for REQEST/REPLY data processing
SVC_TYPE_EXECUTOR = 5 ; // Service that does things on request
SVC_TYPE_CONTROL = 6 ; // Service that manages other services
SVC_TYPE_OTHER = 100 ; // Other service type
}
// Message severity level
enum SeverityLevel {
SEVERITY_UNKNOWN = 0 ;
SEVERITY_INFO = 1 ;
SEVERITY_WARNING = 2 ;
SEVERITY_ERROR = 3 ;
SEVERITY_CRITICAL = 4 ;
}
// Generic data record
message GenericDataRecord {
uint64 sequence = 1 ; // Record sequence number (zero when sequence is not used)
google.protobuf.Struct data = 2 ; // Data payload
}
// Generic Data package
message GenericDataPackage {
repeated GenericDataRecord records = 1 ;
}