<?php
// GENERATED CODE -- DO NOT EDIT!

// Original file comments:
//
// Сервис реализует функционал управления измерениями
namespace Keyapis\TelemetryMetric\V1;

/**
 * Сервис измерений
 */
class MeasurementServiceClient extends \Grpc\BaseStub {

    /**
     * @param string $hostname hostname
     * @param array $opts channel options
     * @param \Grpc\Channel $channel (optional) re-use channel object
     */
    public function __construct($hostname, $opts, $channel = null) {
        parent::__construct($hostname, $opts, $channel);
    }

    /**
     * Метод сохранения измерений.
     * Метод доступен для: service, application(telemetry:edit)
     * @param \Keyapis\TelemetryMetric\V1\PostMeasurementRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function PostMeasurement(\Keyapis\TelemetryMetric\V1\PostMeasurementRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.telemetry_metric.v1.MeasurementService/PostMeasurement',
        $argument,
        ['\Keyapis\TelemetryMetric\V1\PostMeasurementResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Полудуплексный метод сохранения потока измерений.
     * Метод доступен для: service, application(telemetry:edit)
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\ClientStreamingCall
     */
    public function PostMeasurementHalfDuplex($metadata = [], $options = []) {
        return $this->_clientStreamRequest('/keyapis.telemetry_metric.v1.MeasurementService/PostMeasurementHalfDuplex',
        ['\Keyapis\TelemetryMetric\V1\PostMeasurementHalfDuplexResponse','decode'],
        $metadata, $options);
    }

    /**
     * Метод получения списка измерений.
     * Метод доступен для: service, application(telemetry:read или telemetry:edit)
     * @param \Keyapis\TelemetryMetric\V1\GetMeasurementListRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\ServerStreamingCall
     */
    public function GetMeasurementList(\Keyapis\TelemetryMetric\V1\GetMeasurementListRequest $argument,
      $metadata = [], $options = []) {
        return $this->_serverStreamRequest('/keyapis.telemetry_metric.v1.MeasurementService/GetMeasurementList',
        $argument,
        ['\Keyapis\TelemetryMetric\V1\GetMeasurementListResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод получения количества измерений.
     * Метод доступен для: service, application(telemetry:read или telemetry:edit)
     * @param \Keyapis\TelemetryMetric\V1\GetMeasurementCountRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function GetMeasurementCount(\Keyapis\TelemetryMetric\V1\GetMeasurementCountRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.telemetry_metric.v1.MeasurementService/GetMeasurementCount',
        $argument,
        ['\Keyapis\TelemetryMetric\V1\GetMeasurementCountResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод получения списка преобразованных измерений.
     * Метод доступен для: service, application(telemetry:read или telemetry:edit)
     * @param \Keyapis\TelemetryMetric\V1\GetMeasurementConvertedListRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\ServerStreamingCall
     */
    public function GetMeasurementConvertedList(\Keyapis\TelemetryMetric\V1\GetMeasurementConvertedListRequest $argument,
      $metadata = [], $options = []) {
        return $this->_serverStreamRequest('/keyapis.telemetry_metric.v1.MeasurementService/GetMeasurementConvertedList',
        $argument,
        ['\Keyapis\TelemetryMetric\V1\GetMeasurementConvertedListResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод получения количества преобразованных измерений.
     * Метод доступен для: service, application(telemetry:read или telemetry:edit)
     * @param \Keyapis\TelemetryMetric\V1\GetMeasurementConvertedCountRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function GetMeasurementConvertedCount(\Keyapis\TelemetryMetric\V1\GetMeasurementConvertedCountRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.telemetry_metric.v1.MeasurementService/GetMeasurementConvertedCount',
        $argument,
        ['\Keyapis\TelemetryMetric\V1\GetMeasurementConvertedCountResponse', 'decode'],
        $metadata, $options);
    }

}
