/*
Спецификация АПИ управления сущностью SafeCityOsd
*/
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";
// Сервис управления настройками OSD
service SafeCityOsdService {
    // Метод редактирования настроек OSD
    rpc EditSafeCityOsd ( EditSafeCityOsdRequest ) returns ( EditSafeCityOsdResponse ) {
        option (google.api.http) = { patch: "/device/api/v1/safe_city/osd", body: "data" };
    }
    // Метод получения настроек OSD
    rpc GetSafeCityOsd ( GetSafeCityOsdRequest ) returns ( GetSafeCityOsdResponse ) {
        option (google.api.http) = { get: "/device/api/v1/safe_city/osd" };
    }
}
// Запрос редактирования настроек OSD
message EditSafeCityOsdRequest {
    // Настройки OSD
    SafeCityOsd data = 1 [(google.api.field_behavior) = REQUIRED];
    // Маска полей обновления
    google.protobuf.FieldMask update_mask = 2;
}
// Ответ на запрос редактирования настроек OSD
message EditSafeCityOsdResponse {
    // Ошибка запроса
    message Error {
        // Причина ошибки
        oneof reason {
            // Ошибка валидации
            ValidationError validation = 1;
        }
    }
    // Тип ответа
    oneof type {
        // Настройки OSD
        SafeCityOsd data = 1;
        // Ошибка
        Error error = 2;
    }
}
// Запрос получения настроек OSD
message GetSafeCityOsdRequest {
}
// Ответ на запрос получения настроек OSD
message GetSafeCityOsdResponse {
    // Тип ответа
    oneof type {
        // Настройки OSD
        SafeCityOsd data = 1;
    }
}
// Настройки OSD
message SafeCityOsd {
    // Тип размещения текста
    enum PlacementType {
        // Значение не указано
        PLACEMENT_TYPE_UNKNOWN = 0;
        // Сверху слева
        TOP_LEFT = 1;
        // Сверху справа
        TOP_RIGHT = 2;
        // Снизу слева
        BOTTOM_LEFT = 3;
        // Снизу справа
        BOTTOM_RIGHT = 4;
    }
    // Тип добавления формата даты
    enum ShowDatetimeType {
        // Значение не указано
        SHOW_DATETIME_TYPE_UNKNOWN = 0;
        // Формат отсутствует
        ABSENT = 1;
        // День и время yyyy-mm-dd HH:MM:SS
        DAY_TIME = 2;
        // Время HH:MM:SS
        TIME = 3;
    }
    // Флаг включения OSD
    bool is_osd_enabled = 1 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"true\"" }
    ];
    // Текст
    string textline = 2 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"Lorem ipsum dolor sit amet consectetur adipiscing elit\"" }
    ];
    // Размер текста, пикселей
    int32 textsize = 3 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "100" }
    ];
    // Размещение текста
    PlacementType placement_type = 4 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"TOP_LEFT\"" }
    ];
    // Вариант добавления даты
    ShowDatetimeType show_datetime_type = 5 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"ABSENT\"" }
    ];
    // Флаг отображения количества кадров в секунду
    bool is_show_fps = 6 [
        (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = { example: "\"true\"" }
    ];
    // Флаг отображения битрейта
    bool is_show_bitrate = 7;
    // Флаг отображения количества потоков
    bool is_show_count_of_streams = 8;
    // Флаг отображения имени устройства
    bool is_show_name_of_device = 9;
}
