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

import "google/protobuf/timestamp.proto";
import "google/api/annotations.proto";
import "google/api/field_behavior.proto";
import "google/protobuf/wrappers.proto";

package keyapis.iot_connect.v1;

option java_package = "ru.keyapis.iot_connect.v1";
option java_outer_classname = "KeyapisIotConnectV1Proto";
option java_multiple_files = false;
option java_string_check_utf8 = true;
option go_package = "/keyapis_iot_connect_v1";
option cc_enable_arenas = true;
option csharp_namespace = "Keyapis.IotConnect.V1";
option objc_class_prefix = "KEYAPISIOTCONNECTV1";
option php_namespace = "Keyapis\\IotConnect\\V1";
option ruby_package = "Keyapis::IotConnect::V1";
option optimize_for = LITE_RUNTIME;

// Сервис для взаимодействия с внешними партнёрами Iot
service IotConnectCallbackService{
  // Метод получения пользователя.
  // Метод доступен для: TokenACF: Scope: iot
  rpc GetCallbackUser(GetCallbackUserRequest) returns (GetCallbackUserResponse)
  {
    option (google.api.http) = {
      get: "/iot_connect/api/v1/callback/user"
    };
  }
  // Метод получения устройств, доступных пользователю.
  // Метод доступен для: TokenACF: Scope: iot
  rpc GetCallbackDevices(GetCallbackDevicesRequest) returns (GetCallbackDevicesResponse)
  {
    option (google.api.http) = {
      get: "/iot_connect/api/v1/callback/devices"
    };
  }
  // Метод получения внешним партнёром состояния устройства.
  // Метод доступен для: TokenACF: Scope: iot
  rpc PostCallbackStatus(PostCallbackStatusRequest) returns (PostCallbackStatusResponse)
  {
    option (google.api.http) = {
      post: "/iot_connect/api/v1/callback/status"
    };
  }
  // Метод запроса внешнего IoT партнёра на изменение состояния устройства.
  // Поддерживается только открытие домофона.
  // Метод доступен для: TokenACF: Scope: iot
  rpc PostCallbackCommand(PostCallbackCommandRequest) returns (PostCallbackCommandResponse)
  {
    option (google.api.http) = {
      post: "/iot_connect/api/v1/callback/command"
    };
  }
  // Метод сообщения от внешнего IoT партнёра о разъединении аккаунтов.
  // Метод доступен для: TokenACF: Scope: iot
  rpc PostCallbackUnlink(PostCallbackUnlinkRequest) returns (PostCallbackUnlinkResponse)
  {
    option (google.api.http) = {
      post: "/iot_connect/api/v1/callback/unlink"
    };
  }
}


// Сообщение ошибки на запрос
message CommonError {
  // Коммент 1
  int32 code = 1;
  // Коммент 1
  string message = 2;
  // Коммент 1
  string details = 3;
}

// Объект устройства
message Device {
  // Идентификатор пользователя
  int32 user_id = 1;
  // Коммент 1
  string id = 2;
  // Коммент 1
  string parent_id = 3;
  // Коммент 1
  string name = 4;
  // Коммент 1
  string default_name = 5;
  // Коммент 1
  string home = 6;
  // Коммент 1
  string room = 7;
  // Коммент 1
  repeated string groups = 8;
  // Коммент 1
  string model_id = 9;
  // Коммент 1
  string hw_version = 10;
  // Коммент 1
  string sw_version = 11;
}

// Запрос списка домофонов пользователя в виде связки квартира-домофон, к которым имеет доступ пользователь
message GetCallbackDevicesRequest {
}

// Ответ на запрос списка домофонов пользователя в виде связки квартира-домофон, к которым имеет доступ пользователь
message GetCallbackDevicesResponse {
  // Массив домофонов пользователя
  repeated Device data = 1;
}

// Запрос статуса домофонов пользователя
message PostCallbackStatusRequest {
  // Массив домофонов пользователя
  repeated string data = 1;
}

// Ответ на запрос статуса домофонов пользователя
message PostCallbackStatusResponse {
  // Коммент 1
  message Status {
    // Идентификатор пользователя
    int32 user_id = 1;
    // Коммент 1
    string id = 2;
    // Коммент 1
    string parent_id = 3;
    // Коммент 1
    string name = 4;
    // Коммент 1
    string default_name = 5;
    // Коммент 1
    string home = 6;
    // Коммент 1
    string room = 7;
    // Коммент 1
    repeated string groups = 8;
    // Коммент 1
    string model_id = 9;
    // Коммент 1
    string hw_version = 10;
    // Коммент 1
    string sw_version = 11;
  }
  // Коммент
  Status data = 1;
}

// Запрос на изменение статуса домофона
message PostCallbackCommandRequest{
}

// Ответ на запрос на изменение статуса домофона
message PostCallbackCommandResponse{
}

// Запрос-информирование о разъединении аккаунтов
message PostCallbackUnlinkRequest {
}

// Ответ на запрос-информирование о разъединении аккаунтов
message PostCallbackUnlinkResponse {
}
// Запрос идентификатора пользователя Ключ
message GetCallbackUserRequest {
}

// Ответ на запрос идентификатора пользователя Ключ
message GetCallbackUserResponse {
  // Идентификатор пользователя
  int32 data = 1;
}



//{
//"id": "ABCD_004",
//  "name": "Мой домофон",
//  "default_name": "Умный домофон",
//  "home": "Мой дом",
//  "room": "Подъезд",
//"groups": ["Гости", "Места общего пользования"],
//  "model_id": "QWERTY124",
//  "hw_version": "3.1",
//  "sw_version": "5.6",
//"partner_meta": {
//"internal-id": 1234,
//  "specificity": "microchip 2A"
//  },
//  }
