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

namespace Keyapis\Multiapp\V1;

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

/**
 * Шаблон уведомления.
 * # Описание модели
 *
 * Generated from protobuf message <code>keyapis.multiapp.v1.NotificationTemplate</code>
 */
class NotificationTemplate extends \Google\Protobuf\Internal\Message
{
    /**
     * Идентификатор.
     * Если не передан создаётся сервером.
     * # Тип: Guid
     *
     * Generated from protobuf field <code>string id = 1;</code>
     */
    protected $id = '';
    /**
     * Заголовок шаблона.
     * Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     * Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     * Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     * Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     * # Диапазон: 3..128
     *
     * Generated from protobuf field <code>string template_header = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $template_header = '';
    /**
     * Тело шаблона.
     * Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     * Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     * Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     * Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     * # Диапазон: 3..512
     *
     * Generated from protobuf field <code>string template_text = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $template_text = '';
    /**
     * Дата создания.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp created_at = 4 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     */
    protected $created_at = null;
    /**
     * Дата последнего изменения.
     * Заполняется и обновляется сервером.
     * При изменении должен совпадать со значением из БД.
     * Является версией объекта.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp changed_at = 5;</code>
     */
    protected $changed_at = null;
    /**
     * Дата удаления.
     * # Тип: DateTime?
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp deleted_at = 6 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     */
    protected $deleted_at = null;
    /**
     * Системное наименование.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string title = 7 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $title = '';

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type string $id
     *           Идентификатор.
     *           Если не передан создаётся сервером.
     *           # Тип: Guid
     *     @type string $template_header
     *           Заголовок шаблона.
     *           Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     *           Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     *           Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     *           Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     *           # Диапазон: 3..128
     *     @type string $template_text
     *           Тело шаблона.
     *           Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     *           Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     *           Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     *           Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     *           # Диапазон: 3..512
     *     @type \Google\Protobuf\Timestamp $created_at
     *           Дата создания.
     *           # Тип: DateTime
     *     @type \Google\Protobuf\Timestamp $changed_at
     *           Дата последнего изменения.
     *           Заполняется и обновляется сервером.
     *           При изменении должен совпадать со значением из БД.
     *           Является версией объекта.
     *           # Тип: DateTime
     *     @type \Google\Protobuf\Timestamp $deleted_at
     *           Дата удаления.
     *           # Тип: DateTime?
     *     @type string $title
     *           Системное наименование.
     *           # Диапазон: 3..256
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\Multiapp\V1\KeyapisMultiappNotificationTemplateV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Идентификатор.
     * Если не передан создаётся сервером.
     * # Тип: Guid
     *
     * Generated from protobuf field <code>string id = 1;</code>
     * @return string
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Идентификатор.
     * Если не передан создаётся сервером.
     * # Тип: Guid
     *
     * Generated from protobuf field <code>string id = 1;</code>
     * @param string $var
     * @return $this
     */
    public function setId($var)
    {
        GPBUtil::checkString($var, True);
        $this->id = $var;

        return $this;
    }

    /**
     * Заголовок шаблона.
     * Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     * Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     * Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     * Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     * # Диапазон: 3..128
     *
     * Generated from protobuf field <code>string template_header = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getTemplateHeader()
    {
        return $this->template_header;
    }

    /**
     * Заголовок шаблона.
     * Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     * Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     * Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     * Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     * # Диапазон: 3..128
     *
     * Generated from protobuf field <code>string template_header = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setTemplateHeader($var)
    {
        GPBUtil::checkString($var, True);
        $this->template_header = $var;

        return $this;
    }

    /**
     * Тело шаблона.
     * Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     * Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     * Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     * Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     * # Диапазон: 3..512
     *
     * Generated from protobuf field <code>string template_text = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getTemplateText()
    {
        return $this->template_text;
    }

    /**
     * Тело шаблона.
     * Поддерживает mustache теги в формате: {{название переменной|тип данных}}.
     * Название переменной в теге может содержать латинские буквы (в верхнем или нижнем регистре), цифры и символ "_".
     * Тип данных может быть указан в верхнем или нижнем регистре, пробелы не допускаются, допустимые типы данных указаны в таблице.
     * Символы "{" и "}" являются служебными и могут использоваться только для формирования Mustache тегов.
     * # Диапазон: 3..512
     *
     * Generated from protobuf field <code>string template_text = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setTemplateText($var)
    {
        GPBUtil::checkString($var, True);
        $this->template_text = $var;

        return $this;
    }

    /**
     * Дата создания.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp created_at = 4 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getCreatedAt()
    {
        return $this->created_at;
    }

    public function hasCreatedAt()
    {
        return isset($this->created_at);
    }

    public function clearCreatedAt()
    {
        unset($this->created_at);
    }

    /**
     * Дата создания.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp created_at = 4 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setCreatedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->created_at = $var;

        return $this;
    }

    /**
     * Дата последнего изменения.
     * Заполняется и обновляется сервером.
     * При изменении должен совпадать со значением из БД.
     * Является версией объекта.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp changed_at = 5;</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getChangedAt()
    {
        return $this->changed_at;
    }

    public function hasChangedAt()
    {
        return isset($this->changed_at);
    }

    public function clearChangedAt()
    {
        unset($this->changed_at);
    }

    /**
     * Дата последнего изменения.
     * Заполняется и обновляется сервером.
     * При изменении должен совпадать со значением из БД.
     * Является версией объекта.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp changed_at = 5;</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setChangedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->changed_at = $var;

        return $this;
    }

    /**
     * Дата удаления.
     * # Тип: DateTime?
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp deleted_at = 6 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getDeletedAt()
    {
        return $this->deleted_at;
    }

    public function hasDeletedAt()
    {
        return isset($this->deleted_at);
    }

    public function clearDeletedAt()
    {
        unset($this->deleted_at);
    }

    /**
     * Дата удаления.
     * # Тип: DateTime?
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp deleted_at = 6 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setDeletedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->deleted_at = $var;

        return $this;
    }

    /**
     * Системное наименование.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string title = 7 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getTitle()
    {
        return $this->title;
    }

    /**
     * Системное наименование.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string title = 7 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setTitle($var)
    {
        GPBUtil::checkString($var, True);
        $this->title = $var;

        return $this;
    }

}

