/*
  Сервис предоставляет возможность авторизации
*/
syntax = "proto3";

import "google/api/annotations.proto";
import "google/api/field_behavior.proto";

package keyapis.identity.v1;

option java_package = "ru.keyapis.identity.v1";
option java_outer_classname = "KeyapisIdentityV1Proto";
option java_multiple_files = false;
option java_string_check_utf8 = true;
option go_package = "/keyapis_identity_v1";
option cc_enable_arenas = true;
option csharp_namespace = "Keyapis.Identity.V1";
option objc_class_prefix = "KEYAPISIDENTITYV1";
option php_namespace = "Keyapis\\Identity\\V1";
option ruby_package = "Keyapis::Identity::V1";
option optimize_for = LITE_RUNTIME;

// Сервис токенов пользователей
service TokenService {
  // Метод получения токена по идентификатору пользователя.
  // Метод доступен для: service
  rpc PostTokenUser(PostTokenUserRequest) returns (PostTokenUserResponse) {
    option (google.api.http) = {
      post: "/identity/internal/api/v1/token/user/{user_id}"
    };
  }
}

// Информация о токене доступа пользователя
message Token {
  // Токен
  string access_token = 1 [(google.api.field_behavior) = REQUIRED];
  // Время (в секундах), через которое истечет срок действия Access Token
  int32 expires_in = 2 [(google.api.field_behavior) = REQUIRED];
}

// Запрос на получение токена по идентификатору пользователя
message PostTokenUserRequest {
  // Идентификатор пользователя
  int32 user_id = 1 [(google.api.field_behavior) = REQUIRED];
}

// Ответ на запрос на получение токена по идентификатору пользователя
message PostTokenUserResponse {
  // Ошибка запроса на получение токена по идентификатору пользователя
  message Error {
    // Ошибка получения токена.
    // Причины:
    // - Ошибка в сервисе Household
    message TokenError {}
    // Причина ошибки
    oneof reason {
      // Ошибка получения токена
      TokenError token = 1;
    }
  }

  // Тип результата
  oneof type {
    // Токен пользователя
    Token data = 1;
    // Ошибка
    Error error = 2;
  }
}
