/*
  Сервис реализует функционал управления операциями с устройствами
*/
syntax = "proto3";

import "google/api/annotations.proto";
import "google/api/field_behavior.proto";
import "keyapis/device/v1/keyapis_device_device_v1.proto";


package keyapis.device.v1;

option java_package = "ru.keyapis.device.v1";
option java_outer_classname = "KeyapisDeviceV1Proto";
option java_multiple_files = false;
option java_string_check_utf8 = true;
option go_package = "/keyapis_device_v1";
option cc_enable_arenas = true;
option csharp_namespace = "Keyapis.Device.V1";
option objc_class_prefix = "KEYAPISDEVICEV1";
option php_namespace = "Keyapis\\Device\\V1";
option ruby_package = "Keyapis::Device::V1";
option optimize_for = LITE_RUNTIME;

// Сервис устройств
service CommandDeviceService {
  // Метод отправки задания на открытие устройства.
  // Метод доступен для: admin, service
  rpc PostCommandDeviceOpen(PostCommandDeviceOpenRequest) returns (PostCommandDeviceOpenResponse) {
    option (google.api.http) = {
      post: "/device/api/v1/command/device/{device_id}/open"
      body: "*"
    };
  }

}

// Запрос на отправку задания на открытие устройства
message PostCommandDeviceOpenRequest {
  // Идентификатор устройства
  int32 device_id = 1 [(google.api.field_behavior) = REQUIRED];
}

// Ответ на запрос на отправку задания на открытие устройства
message PostCommandDeviceOpenResponse {
  // Ошибка запроса
  message Error {
    // Причина ошибки
    oneof reason {
      // Ошибка валидации
      ValidationError validation = 1;
    }
  }
  // Тип ответа
  oneof type {
    // Ошибка
    Error error = 1;
  }
}

