<?php
# Generated by the protocol buffer compiler.  DO NOT EDIT!
# source: keyapis/multiapp/v1/keyapis_multiapp_app_v1.proto

namespace Keyapis\Multiapp\V1\GetAppCodeResponse;

use Google\Protobuf\Internal\GPBType;
use Google\Protobuf\Internal\RepeatedField;
use Google\Protobuf\Internal\GPBUtil;

/**
 * Ошибка запроса получения ссылки на приложение
 *
 * Generated from protobuf message <code>keyapis.multiapp.v1.GetAppCodeResponse.Error</code>
 */
class Error extends \Google\Protobuf\Internal\Message
{
    protected $reason;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type \Keyapis\Multiapp\V1\ValidationError $validation
     *           Ошибка валидации
     *     @type \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\PartnerKeyDoesNotExist $partner_key_does_not_exist
     *           Ошибка наличия публичного ключа у партнера
     *     @type \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\AppIsInactive $app_is_inactive
     *           Приложение не в статусе ACTIVE
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\Multiapp\V1\KeyapisMultiappAppV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Ошибка валидации
     *
     * Generated from protobuf field <code>.keyapis.multiapp.v1.ValidationError validation = 1;</code>
     * @return \Keyapis\Multiapp\V1\ValidationError|null
     */
    public function getValidation()
    {
        return $this->readOneof(1);
    }

    public function hasValidation()
    {
        return $this->hasOneof(1);
    }

    /**
     * Ошибка валидации
     *
     * Generated from protobuf field <code>.keyapis.multiapp.v1.ValidationError validation = 1;</code>
     * @param \Keyapis\Multiapp\V1\ValidationError $var
     * @return $this
     */
    public function setValidation($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\Multiapp\V1\ValidationError::class);
        $this->writeOneof(1, $var);

        return $this;
    }

    /**
     * Ошибка наличия публичного ключа у партнера
     *
     * Generated from protobuf field <code>.keyapis.multiapp.v1.GetAppCodeResponse.Error.PartnerKeyDoesNotExist partner_key_does_not_exist = 2;</code>
     * @return \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\PartnerKeyDoesNotExist|null
     */
    public function getPartnerKeyDoesNotExist()
    {
        return $this->readOneof(2);
    }

    public function hasPartnerKeyDoesNotExist()
    {
        return $this->hasOneof(2);
    }

    /**
     * Ошибка наличия публичного ключа у партнера
     *
     * Generated from protobuf field <code>.keyapis.multiapp.v1.GetAppCodeResponse.Error.PartnerKeyDoesNotExist partner_key_does_not_exist = 2;</code>
     * @param \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\PartnerKeyDoesNotExist $var
     * @return $this
     */
    public function setPartnerKeyDoesNotExist($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\PartnerKeyDoesNotExist::class);
        $this->writeOneof(2, $var);

        return $this;
    }

    /**
     * Приложение не в статусе ACTIVE
     *
     * Generated from protobuf field <code>.keyapis.multiapp.v1.GetAppCodeResponse.Error.AppIsInactive app_is_inactive = 3;</code>
     * @return \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\AppIsInactive|null
     */
    public function getAppIsInactive()
    {
        return $this->readOneof(3);
    }

    public function hasAppIsInactive()
    {
        return $this->hasOneof(3);
    }

    /**
     * Приложение не в статусе ACTIVE
     *
     * Generated from protobuf field <code>.keyapis.multiapp.v1.GetAppCodeResponse.Error.AppIsInactive app_is_inactive = 3;</code>
     * @param \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\AppIsInactive $var
     * @return $this
     */
    public function setAppIsInactive($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\Multiapp\V1\GetAppCodeResponse\Error\AppIsInactive::class);
        $this->writeOneof(3, $var);

        return $this;
    }

    /**
     * @return string
     */
    public function getReason()
    {
        return $this->whichOneof("reason");
    }

}

// Adding a class alias for backwards compatibility with the previous class name.
class_alias(Error::class, \Keyapis\Multiapp\V1\GetAppCodeResponse_Error::class);

