TaxFeeInfo

Запросы

Синтаксис

Сообщение TaxFeeInfo использует следующий синтаксис:

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="timestamp"
            id="message_ID"
            partner="partner_key">
  <Property action="[overlay]">
    <ID>HotelID</ID>
    <Taxes>
      <Tax>
        <RoomTypes>
          <RoomType id="RoomID_1"/>
          <RoomType id="RoomID_2"/>
        </RoomTypes>
        <RatePlans>
          <RatePlan id="PackageID_1"/>
          <RatePlan id="PackageID_2"/>
        </RatePlans>
        <BookingDates>
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </BookingDates>
        <CheckinDates>
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </CheckinDates>
        <CheckoutDates>
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </CheckoutDates>
        <StayDates application="[all|any|overlap]">
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </StayDates>
        <Type>[percent|amount|cumulative_percent]</Type>
        <Basis>[room|person]</Basis>
        <Period>[stay|night]</Period>
        <Currency>currency_code</Currency>
        <Amount>tax_amount</Amount>
        <ApplicableNights max="integer" excluded="integer"/>
        <LengthOfStay min="integer" max="integer"/>
        <!-- Use either <Amount> or <Brackets> -->
        <Brackets base_amount="tax_amount"/>
          <Bracket starts_at="nightly_rate" amount="tax_amount"/>
        </Brackets>
        <AgeBrackets>
          <AdultCharge amount="tax_amount"/>
          <ChildAgeBrackets>
            <ChildAgeBracket max_age="max_age" amount="tax_amount"/>
          </ChildAgeBrackets>
        </AgeBrackets>
        <UserCountries type="[include|exclude]">
          <Country code="country_code1"/>
          <Country code="country_code2"/>
        </UserCountries>
        <!--"exclusive" parameter is optional -->
        <Rank exclusive="[true|false]">integer</Rank>
      </Tax>
    </Taxes>
    <Fees>
      <Fee>
        <RoomTypes>
          <RoomType id="RoomID_1"/>
          <RoomType id="RoomID_2"/>
        </RoomTypes>
        <RatePlans>
          <RatePlan id="PackageID_1"/>
          <RatePlan id="PackageID_2"/>
        </RatePlans>
        <BookingDates>
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </BookingDates>
        <CheckinDates>
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </CheckinDates>
        <CheckoutDates>
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </CheckoutDates>
        <StayDates application="[all|any|overlap]">
          <DateRange start="YYYY-MM-DD" end="YYYY-MM-DD" days_of_week="MTWHFSU_or_subset"/>
        </StayDates>
        <Type>[percent|amount|cumulative_percent]</Type>
        <Basis>[room|person]</Basis>
        <Period>[stay|night]</Period>
        <Currency>currency_code</Currency>
        <Amount>fee_amount</Amount>
        <ApplicableNights max="integer" excluded="integer"/>
        <LengthOfStay min="integer" max="integer"/>
        <!-- Use either <Amount> or <Brackets> -->
        <Brackets base_amount="tax_amount"/>
          <Bracket starts_at="nightly_rate" amount="tax_amount"/>
        </Brackets>
        <AgeBrackets>
          <AdultCharge amount="tax_amount"/>
          <ChildAgeBrackets>
            <ChildAgeBracket max_age="max_age" amount="tax_amount"/>
          </ChildAgeBrackets>
        </AgeBrackets>
        <UserCountries type="[include|exclude]">
          <Country code="country_code1"/>
          <Country code="country_code2"/>
        </UserCountries>
        <!--"exclusive" parameter is optional -->
        <Rank exclusive="[true|false]">integer</Rank>
      </Fee>
    </Fees>
  </Property>
</TaxFeeInfo>

Элементы и атрибуты

Сообщение TaxFeeInfo имеет следующие элементы и атрибуты:

Элемент / @Атрибут Происшествия Тип Описание
TaxFeeInfo 1 Complex element Корневой элемент сообщения, определяющего налоги и сборы для отдельного объекта недвижимости.
TaxFeeInfo / @timestamp 1 DateTime Дата и время создания данного сообщения.
TaxFeeInfo / @id 1 string Уникальный идентификатор запроса. Это значение возвращается в ответном сообщении. Допустимые символы: az , AZ , 0-9 , _ (подчёркивание) и - (тире).
TaxFeeInfo / @partner 1 string Учётная запись партнёра для этого сообщения. Это строковое значение — значение «Ключа партнёра», указанное на странице настроек учётной записи в Hotel Center.

Примечание: если у вас есть бэкэнд, который предоставляет каналы для нескольких учетных записей, это значение должно совпадать со значением атрибута ID , указанным в элементе <RequestorID> ваших сообщений <OTA_HotelRateAmountNotifRQ> и <OTA_HotelAvailNotifRQ> для той же учетной записи.

TaxFeeInfo / Property 1..n Property Контейнер для определения налогов и сборов для отдельного объекта недвижимости.
TaxFeeInfo / Property / @action 0..1 string Указывает, как будет применяться обновление. Поддерживается только overlay , значение по умолчанию — overlay . Все предыдущие Taxes и Fees для этого объекта будут удалены перед применением обновления.
TaxFeeInfo / Property / ID 1 string Уникальный идентификатор объекта. Это значение должно соответствовать идентификатору отеля, указанному с помощью <id> в элементе <listing> в ленте списка отелей. Идентификатор отеля также указан в Hotel Center .
TaxFeeInfo / Property / Taxes 0..1 Taxes Контейнер для одного или нескольких элементов <Tax> .
TaxFeeInfo / Property / Taxes / Tax 1..n Tax Индивидуальный налог, применяемый к имуществу.
TaxFeeInfo / Property / Taxes / Tax / RoomTypes 0..1 RoomTypes Контейнер для списка типов номеров, к которым применяется налог. Налог применяется к каждому указанному <RoomType> . Если <RoomTypes> не указан, налог применяется ко всем номерам.
TaxFeeInfo / Property / Taxes / Tax / RoomTypes / RoomType 1..n RoomType Указывает тип номера. Тип номера определяется в элементе <RoomData> сообщения «Транзакция (данные объекта)» и идентифицируется с помощью его идентификатора RoomID. (На его значение <RoomID> также ссылается атрибут InvTypeCode в сообщениях OTA_HotelRateAmountNotifRQ .)
TaxFeeInfo / Property / Taxes / Tax / RoomTypes / RoomType / @id 1 string Уникальный идентификатор инвентаря (типа помещения). Это значение соответствует <RoomID> в сообщении «Транзакция (данные объекта)» . Максимальное количество символов — 50.
TaxFeeInfo / Property / Taxes / Tax / RatePlans 0..1 RatePlans Контейнер для списка тарифных планов, к которым применяется налог. Если <RatePlans> не указан, налог применяется ко всем тарифным планам.
TaxFeeInfo / Property / Taxes / Tax / RatePlans / RatePlan 1..n RatePlan Указывает тарифный план. Тарифный план определяется комбинацией пакета, тарифов и доступности, как указано в сообщениях «Транзакция» (данные объекта), OTA_HotelRateAmountNotifRQ и OTA_HotelAvailNotifRQ, а также как указано в PackageID.
TaxFeeInfo / Property / Taxes / Tax / RatePlans / RatePlan / @id 1 string Уникальный идентификатор тарифного плана. Это значение соответствует значению PackageID в поле <PackageData> сообщения « Транзакция (данные объекта)» и значению RatePlanCode , заданному в атрибуте <StatusApplicationControl> в сообщениях <OTA_HotelRateAmountNotifRQ> и <OTA_HotelAvailNotifRQ> . Максимальное количество символов — 50.
TaxFeeInfo / Property / Taxes / Tax / BookingDates 0..1 BookingDates Контейнер для одного или нескольких диапазонов дат, определяющих, когда должно быть осуществлено бронирование, чтобы был применен налог.
TaxFeeInfo / Property / Taxes / Tax / BookingDates / DateRange 1..99 DateRange Диапазон дат, указывающий, когда должно быть совершено бронирование, чтобы налог был применен.
TaxFeeInfo / Property / Taxes / Tax / BookingDates / DateRange / @start 0..1 Date Начальная дата (в зависимости от часового пояса объекта) диапазона дат (включительно). Эта дата должна быть раньше даты end или совпадать с ней. Если start не указана, диапазон дат фактически не ограничен датой начала.
TaxFeeInfo / Property / Taxes / Tax / BookingDates / DateRange / @end 0..1 Date Дата окончания (в зависимости от часового пояса объекта размещения) диапазона дат включительно. Эта дата должна совпадать с датой start или быть позже неё. Если end не указана, диапазон дат фактически не ограничен датой окончания.
TaxFeeInfo / Property / Taxes / Tax / BookingDates / DateRange / @days_of_week 0..1 string

Дни недели, которые разрешены в диапазоне дат. Если не указано иное, разрешены все дни в диапазоне дат. Каждый символ в строке обозначает день. Например, «MTWHF» указывает, что в диапазоне дат разрешены будние дни.

Допустимые символы:

  • M — понедельник
  • T — вторник
  • W для среды
  • H для четверга
  • F для пятницы
  • S для субботы
  • U для воскресенья

Допустима любая комбинация символов.

TaxFeeInfo / Property / Taxes / Tax / CheckinDates 0..1 CheckinDates Контейнер для одного или нескольких диапазонов дат, определяющих, когда должна быть произведена регистрация для применения налога.
TaxFeeInfo / Property / Taxes / Tax / CheckinDates / DateRange 1..20 DateRange Диапазон дат, указывающий, когда должна быть произведена регистрация для применения налога.
TaxFeeInfo / Property / Taxes / Tax / CheckinDates / DateRange / @start 0..1 Date Начальная дата (в зависимости от часового пояса объекта) диапазона дат (включительно). Эта дата должна быть раньше даты end или совпадать с ней. Если start не указана, диапазон дат фактически не ограничен датой начала.
TaxFeeInfo / Property / Taxes / Tax / CheckinDates / DateRange / @end 0..1 Date Дата окончания (в зависимости от часового пояса объекта размещения) диапазона дат включительно. Эта дата должна совпадать с датой start или быть позже неё. Если end не указана, диапазон дат фактически не ограничен датой окончания.
TaxFeeInfo / Property / Taxes / Tax / CheckinDates / DateRange / @days_of_week 0..1 string

Дни недели, которые разрешены в диапазоне дат. Если не указано иное, разрешены все дни в диапазоне дат. Каждый символ в строке обозначает день. Например, «MTWHF» указывает, что в диапазоне дат разрешены будние дни.

Допустимые символы:

  • M — понедельник
  • T — вторник
  • W для среды
  • H для четверга
  • F для пятницы
  • S для субботы
  • U для воскресенья

Допустима любая комбинация символов.

TaxFeeInfo / Property / Taxes / Tax / CheckoutDates 0..1 CheckoutDates Контейнер для одного или нескольких диапазонов дат, определяющих, когда должна быть произведена выписка, чтобы был применен налог.
TaxFeeInfo / Property / Taxes / Tax / CheckoutDates / DateRange 1..20 DateRange Диапазон дат, указывающий, когда должен произойти выезд, чтобы налог был применен.
TaxFeeInfo / Property / Taxes / Tax / CheckoutDates / DateRange / @start 0..1 Date Начальная дата (в зависимости от часового пояса объекта) диапазона дат (включительно). Эта дата должна быть раньше даты end или совпадать с ней. Если start не указана, диапазон дат фактически не ограничен датой начала.
TaxFeeInfo / Property / Taxes / Tax / CheckoutDates / DateRange / @end 0..1 Date Дата окончания (в зависимости от часового пояса объекта размещения) диапазона дат включительно. Эта дата должна совпадать с датой start или быть позже неё. Если end не указана, диапазон дат фактически не ограничен датой окончания.
TaxFeeInfo / Property / Taxes / Tax / CheckoutDates / DateRange / @days_of_week 0..1 string

Дни недели, которые разрешены в диапазоне дат. Если не указано иное, разрешены все дни в диапазоне дат. Каждый символ в строке обозначает день. Например, «MTWHF» указывает, что в диапазоне дат разрешены будние дни.

Допустимые символы:

  • M — понедельник
  • T — вторник
  • W для среды
  • H для четверга
  • F для пятницы
  • S для субботы
  • U для воскресенья

Допустима любая комбинация символов.

TaxFeeInfo / Property / Taxes / Tax / StayDates 0..1 StayDates

Контейнер для одного или нескольких диапазонов дат, определяющих, применяется ли налог, например, для учета сезонных скидок.

TaxFeeInfo / Property / Taxes / Tax / StayDates / @application 1 enum

Описывает, как следует применять налог.

Допустимые значения:

  • all : Применяет налог к каждой ночи в маршруте, если все даты в маршруте совпадают с датами пребывания.
  • any : Применяет налог ко всем ночам в маршруте, если какая-либо дата в маршруте совпадает с датой в диапазоне дат пребывания.
  • overlap : налог применяется только к тем ночам в маршруте, которые перекрываются с датой в диапазоне дат пребывания.

    Примечание : overlap допустимо только в том случае, если для параметра <Period> установлено значение night .

Этот атрибут всегда должен быть указан.

TaxFeeInfo / Property / Taxes / Tax / StayDates / DateRange 1..99 DateRange Диапазон дат, указывающий даты, когда должен применяться налог.
TaxFeeInfo / Property / Taxes / Tax / StayDates / DateRange / @start 0..1 Date Начальная дата (в зависимости от часового пояса объекта) диапазона дат (включительно). Эта дата должна быть раньше даты end или совпадать с ней. Если start не указана, диапазон дат фактически не ограничен датой начала.
TaxFeeInfo / Property / Taxes / Tax / StayDates / DateRange / @end 0..1 Date Дата окончания (в зависимости от часового пояса объекта размещения) диапазона дат включительно. Эта дата должна совпадать с датой start или быть позже неё. Если end не указана, диапазон дат фактически не ограничен датой окончания.
TaxFeeInfo / Property / Taxes / Tax / StayDates / DateRange / @days_of_week 0..1 string

Дни недели, которые разрешены в диапазоне дат. Если не указано иное, разрешены все дни в диапазоне дат. Каждый символ в строке обозначает день. Например, «MTWHF» указывает, что в диапазоне дат разрешены будние дни.

Допустимые символы:

  • M — понедельник
  • T — вторник
  • W для среды
  • H для четверга
  • F для пятницы
  • S для субботы
  • U для воскресенья

Допустима любая комбинация символов.

TaxFeeInfo / Property / Taxes / Tax / Type 1 enum

Допустимые значения:

  • percent: процент от общей ставки
  • amount: фиксированная сумма, добавляемая к окончательной ставке
  • cumulative_percent: процент от общей ставки, налогов и сборов, накопленный до расчета данного налога или сбора. Если это значение указано, необходимо также указать <Rank> .
  • <Brackets> и <AgeBrackets> нельзя указывать с типом cumulative_percent .

TaxFeeInfo / Property / Taxes / Tax / Basis 1 enum

Допустимые значения:

  • room: <Amount> применяется к комнате.
  • person: <Amount> применяется к каждому человеку. Это значение применяется только в том случае, если <Type> задано значение «Сумма».
TaxFeeInfo / Property / Taxes / Tax / Period 1 enum

Допустимые значения:

  • stay: <Amount> добавляется к общей стоимости проживания.
  • night: <Amount> добавляется за каждую ночь проживания.
TaxFeeInfo / Property / Taxes / Tax / Currency 0..1 string Трехбуквенный код валюты налога (например: USD).

Примечание: Если <Currency> не указана, но указано <Amount> , то значение <Currency> по умолчанию соответствует валюте базовой ставки.

TaxFeeInfo / Property / Taxes / Tax / Amount 0..1 float Величина процента или суммы налога.
TaxFeeInfo / Property / Taxes / Tax / ApplicableNights 0..1 ApplicableNights Это значение применяется только в том случае, если <Type> установлен на сумму , а <Period> установлен на ночь .

Ограничивает количество ночей, за которые может взиматься налог.

Укажите либо max , либо excluded , но не оба одновременно.

TaxFeeInfo / Property / Taxes / Tax / ApplicableNights / @max 0..1 integer <ApplicableNights max="N"> указывает, что ночи после первых N ночей следует исключить.
TaxFeeInfo / Property / Taxes / Tax / ApplicableNights / @excluded 0..1 integer <ApplicableNights excluded="N"> указывает, что первые N ночей следует исключить.
TaxFeeInfo / Property / Taxes / Tax / LengthOfStay 0..1 LengthOfStay Определяет предельную продолжительность пребывания, в пределах которой может применяться данный налог. Налог не взимается, если продолжительность пребывания выходит за пределы минимального и максимального лимитов.
TaxFeeInfo / Property / Taxes / Tax / LengthOfStay / @min 0..1 integer Минимальное количество ночей проживания, для которого применяется налог. Если это не указано, минимального количества нет.
TaxFeeInfo / Property / Taxes / Tax / LengthOfStay / @max 0..1 integer Максимальное количество ночей проживания, для которого применяется налог. Если это не указано, максимума нет.
TaxFeeInfo / Property / Taxes / Tax / Brackets 0..1 Brackets Контейнер для одного или нескольких элементов <Bracket> . Определяет набор смежных и непересекающихся налоговых категорий. Например: индийские налоги GST (налоговые блоки).

Этот элемент действителен только в том случае, если <Period> установлен на night и <Amount> не указан.

TaxFeeInfo / Property / Taxes / Tax / Brackets / @base_amount 0..1 float Значение процента или суммы налога, применяемого к ночным тарифам ниже значения starts_at первой группы.
TaxFeeInfo / Property / Taxes / Tax / Brackets / Bracket 1..n Bracket Определяет налоговую категорию на основе ночных ставок.
TaxFeeInfo / Property / Taxes / Tax / Brackets / Bracket / @starts_at 1 float

Определяет нижнюю границу налоговой категории. Верхняя граница указывается в поле starts_at следующей категории. Для последней категории верхняя граница отсутствует.

Налоговая категория активна, когда ежедневная ставка больше или равна значению starts_at данной категории и строго меньше значения starts_at последующей категории.

Это значение должно быть строго больше 0.

TaxFeeInfo / Property / Taxes / Tax / Brackets / Bracket / @amount 1 float Значение процента или суммы налога, применяемого к данной налоговой категории.
TaxFeeInfo / Property / Taxes / Tax / AgeBrackets 0..1 AgeBrackets Позволяет указать набор налогов в зависимости от возраста проживающих.

Этот элемент действителен только в том случае, если не указаны <Brackets> и <Amount> , <Basis> имеет значение person , а <Type>amount .

TaxFeeInfo / Property / Taxes / Tax / AgeBrackets / AdultCharge 0..1 AdultCharge Контейнер для указания налогов для взрослых.
TaxFeeInfo / Property / Taxes / Tax / AgeBrackets / AdultCharge / @amount 1 float Фиксированная сумма налога, применяемая к взрослым.
TaxFeeInfo / Property / Taxes / Tax / AgeBrackets / ChildAgeBrackets 0..1 ChildAgeBrackets Контейнер для хранения одного или нескольких элементов <ChildAgeBracket> .
TaxFeeInfo / Property / Taxes / Tax / AgeBrackets / ChildAgeBrackets / ChildAgeBracket 1..n ChildAgeBracket Определяет возрастной диапазон детей и соответствующую сумму налога.
TaxFeeInfo / Property / Taxes / Tax / AgeBrackets / ChildAgeBrackets / ChildAgeBracket / @max_age 1 integer

Определяет верхнюю границу возраста ребёнка. Нижняя граница указана в поле max_age предыдущей скобки + 1. Верхняя и нижняя границы являются включительными. Нижняя граница для первой скобки равна 0.

max_age должен быть в диапазоне от 0 до 17 (включительно).

TaxFeeInfo / Property / Taxes / Tax / AgeBrackets / ChildAgeBrackets / ChildAgeBracket / @amount 1 float Фиксированная ставка налога, применяемая к детям этого возраста.
TaxFeeInfo / Property / Taxes / Tax / UserCountries 0..1 UserCountries Контейнер для списка стран пользователей, для которых налог включен или исключен. Если он присутствует, налог будет включен или исключен только для пользователей из указанных стран.
TaxFeeInfo / Property / Taxes / Tax / UserCountries / @type 0..1 enum Тип спецификации UserCountries.

Допустимые значения: include и exclude .

Если type UserCountries установлен как include , налог будет применяться только к пользователям из перечисленных стран.

Тогда как если type UserCountries — exclude , налог будет применяться только к пользователям за пределами перечисленных стран.

Если type UserCountries не задан, мы будем рассматривать его как include и налог будет применяться только к пользователям из перечисленных стран.

TaxFeeInfo / Property / Taxes / Tax / UserCountries / Country 1..n Country Определяет одну страну в списке UserCountries.
TaxFeeInfo / Property / Taxes / Tax / UserCountries / Country / @code 1 string Код страны CLDR , например, DE или FR . Обратите внимание, что для некоторых стран код страны CLDR не совпадает с двухбуквенным кодом страны ISO. Кроме того, коды регионов CLDR не поддерживаются.
TaxFeeInfo / Property / Taxes / Tax / Rank 1 integer

Ранг, определяющий порядок применения налога или сбора. Например, значение 2 означает, что налог применяется вторым. Этот элемент всегда должен быть указан, если <Type> задано значение cumulative_percent . Как правило, этот порядок применяется как к налогам, так и к сборам.

<Rank>2</Rank>

Среди налогов и сборов допускаются повторяющиеся значения ранга, но это может привести к неопределенному поведению, когда налоги и сборы применяются произвольным и кумулятивным образом.

В качестве альтернативы используйте параметр "exclusive" в теге <Rank> , чтобы указать, что к ставке применяются все налоги и сборы одинакового ранга. Значение по умолчанию — false , и все налоги и сборы одинакового ранга применяются к ставке произвольным образом. Параметр "exclusive" необязателен.

Если параметр exclusive установлен на true , то к ставке применяется только первый налог, указанный в <Tax> , или первая комиссия, указанная в <Fee> .

<Rank exclusive="true">1</Rank>

Налоги применяются в первую очередь, а не в первую; поэтому, если налог и сбор имеют одинаковый ранг, а для сбора установлено значение "exclusive" true ), налог всё равно применяется первым. Рекомендуется перечислять налоги и сборы в порядке их применения.

Чтобы включить все налоги и сборы одного ранга, избегайте установки exclusive true .

Налоги и сборы без рангов применяются до подачи всех рейтинговых заявок.

<Rank> должен быть в диапазоне от 1 до 99 (включительно).

TaxFeeInfo / Property / Fees 0..1 Fees Контейнер для одного или нескольких элементов <Fee> .
TaxFeeInfo / Property / Fees / Fee 1..n Fee

Индивидуальная плата, которая применяется к объекту недвижимости.

Все дочерние элементы <Tax> также поддерживаются для <Fee> с тем же синтаксисом.

Примеры

Для одного объекта недвижимости установлено ограничение в 300 налогов и сборов. Чтобы удалить налоги и сборы для объекта недвижимости, см. пример «Удаление налогов».

Основное сообщение

Базовое сообщение TaxFeeInfo :

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="2024-05-18T16:20:00-04:00"
            id="12345678"
            partner="partner_key">
  <Property>
    <ID>Property_1</ID>
    <Taxes>
      <Tax>
        <Type>percent</Type>
        <Basis>room</Basis>
        <Period>stay</Period>
        <Amount>10.00</Amount>
      </Tax>
    </Taxes>
    <Fees>
      <Fee>
        <Type>amount</Type>
        <Basis>person</Basis>
        <Period>night</Period>
        <Currency>USD</Currency>
        <Amount>5.00</Amount>
      </Fee>
    </Fees>
  </Property>
</TaxFeeInfo>

Удалить налоги

Удалить все налоги и сборы на уровне объекта недвижимости для указанного отеля:

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="2024-06-16T16:20:00-04:00"
            id="12345678"
            partner="partner_key">
  <Property action="overlay"/>
    <ID>Property_1</ID>
  </Property>
</TaxFeeInfo>

налог на плиты

Налог на товары и услуги (GST) в Индии, применяемый на основе ночных тарифов. Налоговые категории:

  • Налог не взимается, если стоимость проживания за ночь меньше или равна 1000.
  • Налог 12%, если стоимость проживания за ночь больше 1000 и меньше или равна 7500.
  • Налог 18%, если стоимость проживания за ночь превышает 7500.
<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="2024-05-18T16:20:00-04:00"
            id="12345678"
            partner="partner_key">
  <Property>
    <ID>Property_1</ID>
    <Taxes>
      <Tax>
        <Type>percent</Type>
        <Basis>room</Basis>
        <Period>night</Period>
        <Brackets base_amount="0">
          <Bracket starts_at="1000.01" amount="12"/>
          <Bracket starts_at="7500.01" amount="18"/>
        </Brackets>
      </Tax>
    </Taxes>
  </Property>
</TaxFeeInfo>

Налоги по возрасту

Налоги взимаются в зависимости от возраста жильцов:

  • Налог для взрослых жильцов составляет 20 долларов.
  • Налог в размере 10 долларов для детей в возрасте от 11 до 17 лет.
  • Налог в размере 5 долларов США для детей в возрасте от 0 до 10 лет.
<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="2024-05-18T16:20:00-04:00"
            id="12345678"
            partner="partner_key">
  <Property>
    <ID>Property_1</ID>
    <Taxes>
      <Tax>
        <Type>amount</Type>
        <Basis>person</Basis>
        <Period>night</Period>
        <AgeBrackets>
          <AdultCharge amount="20"/>
          <ChildAgeBrackets>
            <ChildAgeBracket max_age="10" amount="5"/>
            <ChildAgeBracket max_age="17" amount="10"/>
          </ChildAgeBrackets>
        </AgeBrackets>
      </Tax>
    </Taxes>
  </Property>
</TaxFeeInfo>

Перекрывающиеся диапазоны дат пребывания

Если задано несколько перекрывающихся диапазонов дат пребывания, то заданная дата пребывания должна соответствовать только одному из этих диапазонов, а не всем. Диапазоны дат пребывания должны быть указаны в одном диапазоне начального и конечного значений.

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="2025-03-12T10:59:49+01:00"
            id="12345678"
            partner="partner_key">
  <Property action="overlay">
    <ID>987654</ID>
      <Taxes>
        <Tax>
          <Type>amount</Type>
          <Basis>person</Basis>
          <Period>night</Period>
          <RoomTypes>
            <RoomType id="RoomID_1"/>
            <RoomType id="RoomID_2"/>
          </RoomTypes>
          <StayDates application="any">
            <DateRange start="2025-06-16"/>
          </StayDates>
          <Currency>USD</Currency>
          <Amount>50</Amount>
        </Tax>
      </Taxes>
      <Fees>
        <Fee>
          <Type>amount</Type>
          <Basis>room</Basis>
          <Period>stay</Period>
          <StayDates application="any">
            <DateRange start="2025-03-12" end="2025-03-18"/>
          </StayDates>
          <Currency>USD</Currency>
          <Amount>200</Amount>
        </Fee>
        <Fee>
          <Type>amount</Type>
          <Basis>room</Basis>
          <Period>stay</Period>
          <StayDates application="any">
            <DateRange start="2025-03-19"/>
          </StayDates>
          <Currency>USD</Currency>
          <Amount>300</Amount>
      </Fee>
    </Fees>
  </Property>
</TaxFeeInfo>

Множество налогов и сборов с эксклюзивным рейтингом

Ниже приведён пример с несколькими налогами и сборами с exclusive="true" и разными рангами. Рассмотрим следующие налоги и сборы, которые следует применить к ставке:

  • Налог на проживание в размере 5% с рангом 1 exclusive="true" .
  • Налог на обслуживание номеров в размере 10 долларов США с рангом 1.
  • Плата за уборку в размере 50 долларов США с рангом 2 exclusive="true" .
  • Плата за удобства в размере 2% при ранге 3.

Хронологический порядок применения налогов и сборов в зависимости от <Rank> Ранга>:

  1. Налог на размещение с exclusive="true" и рангом 1 применяется в первую очередь.
  2. Налог на обслуживание номеров с рангом 1 применяться не будет, поскольку предыдущий налог на размещение является исключительным.
  3. Далее применяется плата за уборку с exclusive="true" и рангом 2.
  4. Плата за удобства с рангом 3 применяется после платы за уборку с рангом 2.

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfo timestamp="2024-02-29T12:00:00Z"
            id="tax-fee-id"
            partner="partner_key">
  <Property action="overlay">
    <ID>765432</ID>
    <Taxes>
      <Tax>
        <Type>percent</Type>
        <Amount>5</Amount>
        <Period>stay</Period>
        <Basis>room</Basis>
        <Rank exclusive="true">1</Rank>
      </Tax>
      <Tax>
        <Type>amount</Type>
        <Amount>10</Amount>
        <Period>night</Period>
        <Basis>room</Basis>
        <Currency>USD</Currency>
        <Rank>1</Rank>
      </Tax>
    </Taxes>
    <Fees>
      <Fee>
        <Type>amount</Type>
        <Amount>50</Amount>
        <Period>night</Period>
        <Basis>room</Basis>
        <Currency>USD</Currency>
        <Rank exclusive="true">2</Rank>
      </Fee>
      <Fee>
        <Type>percent</Type>
        <Amount>2</Amount>
        <Period>stay</Period>
        <Basis>room</Basis>
        <Rank>3</Rank>
      </Fee>
    </Fees>
  </Property>
</TaxFeeInfo>

Ответы

Синтаксис

Сообщение TaxFeeInfoResponse использует следующий синтаксис:

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfoResponse timestamp="timestamp"
                    id="message_ID"
                    partner="partner_key">
  <!-- Either Success or Issues will be populated. -->
  <Success/>
  <Issues>
    <Issue code="issue_code" status="issue_type">issue_description</Issue>
  </Issues>
</TaxFeeInfoResponse>

Элементы и атрибуты

Сообщение TaxFeeInfoResponse имеет следующие элементы и атрибуты:

Элемент / @Атрибут Происшествия Тип Описание
TaxFeeInfoResponse 1 Complex element Корневой элемент, указывающий на успешность или наличие проблем при получении сообщения-запроса TaxFeeInfo.
TaxFeeInfoResponse / @timestamp 1 DateTime Дата и время создания данного сообщения.
TaxFeeInfoResponse / @id 1 string Уникальный идентификатор из связанного сообщения TaxFeeInfo.
TaxFeeInfoResponse / @partner 1 string Партнерский аккаунт для этого сообщения.
TaxFeeInfoResponse / Success 0..1 Success Указывает, что сообщение TaxFeeInfo было обработано успешно без предупреждений, ошибок или сбоев.

В каждом сообщении присутствует либо <Success> , либо <Issues> .

TaxFeeInfoResponse / Issues 0..1 Issues Контейнер для одной или нескольких проблем, возникших при обработке сообщения TaxFeeInfo .

В каждом сообщении присутствует либо <Success> , либо <Issues> .

TaxFeeInfoResponse / Issues / Issue 1..n Issue Описание предупреждения, ошибки или сбоя, возникшего при обработке сообщения TaxFeeInfo. Подробную информацию об этих проблемах можно найти в разделе «Сообщения об ошибках статуса фида» .
TaxFeeInfoResponse / Issues / Issue / @code 1 integer Идентификатор проблемы.
TaxFeeInfoResponse / Issues / Issue / @status 1 enum

Тип обнаруженной проблемы.

Допустимые значения: warning , error и failure .

Примеры

Успех

Ниже приведен ответ на успешно обработанное сообщение TaxFeeInfo .

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfoResponse timestamp="2024-05-18T16:20:00-04:00"
                    id="12345678"
                    partner="partner_key">
  <Success/>
</TaxFeeInfoResponse>

Проблемы

Ниже приведен ответ на сообщение TaxFeeInfo , которое не было обработано из-за ошибок.

<?xml version="1.0" encoding="UTF-8"?>
<TaxFeeInfoResponse timestamp="2024-05-18T16:20:00-04:00"
                    id="12345678"
                    partner="partner_key">
  <Issues>
    <Issue code="1001" status="error">Example</Issue>
  </Issues>
</TaxFeeInfoResponse>