/*
Сервис управления настройками Syslog-сервера
*/
syntax = "proto3";
package deviceapis.device.v1;
import "deviceapis/device/v1/deviceapis_device_common_v1.proto";
import "google/api/annotations.proto";
import "google/api/field_behavior.proto";
import "google/protobuf/field_mask.proto";
import "protoc-gen-openapiv2/options/annotations.proto";
option cc_enable_arenas = true;
option csharp_namespace = "Deviceapis.Device.V1";
option go_package = "/deviceapis_device_v1";
option java_multiple_files = false;
option java_outer_classname = "DeviceapisDeviceV1Proto";
option java_package = "ru.deviceapis.device.v1";
option java_string_check_utf8 = true;
option objc_class_prefix = "DEVICEAPISDEVICEV1";
option optimize_for = LITE_RUNTIME;
option php_namespace = "Deviceapis\\Device\\V1";
option ruby_package = "Deviceapis::Device::V1";
// Сервис управления настройками Syslog-сервера
service SyslogSettingsService {
    // Метод редактирования настроек Syslog-сервера
    rpc EditSyslogSettings ( EditSyslogSettingsRequest ) returns ( EditSyslogSettingsResponse ) {
        option (google.api.http) = { patch: "/device/api/v1/syslog/settings", body: "data" };
    }
    // Метод получения настроек Syslog-сервера
    rpc GetSyslogSettings ( GetSyslogSettingsRequest ) returns ( GetSyslogSettingsResponse ) {
        option (google.api.http) = { get: "/device/api/v1/syslog/settings" };
    }
}
// Запрос редактирования настроек Syslog-сервера
message EditSyslogSettingsRequest {
    // Настройки Syslog-сервера
    SyslogSettings data = 1 [(google.api.field_behavior) = REQUIRED];
    // Маска полей обновления
    google.protobuf.FieldMask update_mask = 2;
}
// Ответ на запрос редактирования настроек Syslog-сервера
message EditSyslogSettingsResponse {
    // Ошибка запроса
    message Error {
        // Причина ошибки
        oneof reason {
            // Ошибка валидации
            ValidationError validation = 1;
        }
    }
    // Тип ответа
    oneof type {
        // Настройки Syslog-сервера
        SyslogSettings data = 1;
        // Ошибка
        Error error = 2;
    }
}
// Запрос получения настроек Syslog-сервера
message GetSyslogSettingsRequest {
}
// Ответ на запрос получения настроек Syslog-сервера
message GetSyslogSettingsResponse {
    // Тип ответа
    oneof type {
        // Настройки Syslog-сервера
        SyslogSettings data = 1;
    }
}
// Настройки Syslog-сервера
message SyslogSettings {
    // Уровень логирования
    enum LogLevelType {
        // Значение не указано
        LOG_LEVEL_TYPE_UNKNOWN = 0;
        // Система не пригодна для использования
        EMERGENCY = 1;
        // Требуются немедленные меры
        ALERT = 2;
        // Сообщение о критическом состоянии
        CRIT = 3;
        // Сообщение об ошибочном состоянии
        ERROR = 4;
        // Предупреждение
        WARN = 5;
        // Сообщение о значительном нормальном событии
        NOTE = 6;
        // Информационное сообщение
        INFO = 7;
        // Сообщение отладочного уровня
        DEBUG = 8;
    }
    // Тип протокола
    enum ProtocolType {
        // Значение не указано
        PROTOCOL_TYPE_UNKNOWN = 0;
        // Протокол UDP
        UDP = 1;
        // Протокол TCP
        TCP = 2;
    }
    // Тип протокола
    ProtocolType protocol_type = 1 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"UDP\"" }
    ];
    // Адрес Syslog-сервера.
    // Сетевой адрес и порт.
    // Пример: 192.168.0.1:514, syslog.acme.io:6514
    string address = 2 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"syslog.acme.io:514\"", min_length: 5 }
    ];
    // Уровень логирования
    LogLevelType log_level_type = 3 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"ERROR\"" }
    ];
}
