Skip to content

InternalCalculateOfferPricingRequest

Properties

  • customerId (string)Customer ID for pricing calculation.
  • offers (array)List of offers to calculate pricing for.

    • Items (object)Cannot contain additional properties.

      • offerId (string, required)Offer ID to price.
      • pageCount (['integer', 'null'], format: int32)Page count (used if tiers and page count tiers exist).
      • productIds (['array', 'null'])Product IDs.

        • Items (string)
      • quantity (integer, format: int32, required)Quantity to price.

  • priceClasses (['array', 'null'])Preferred price classes (priority order).

    • Items (string)

Quicktype Command

quicktype \
    --framework SystemTextJson  \
    --lang cs  \
    --number-type double  \
    --src-lang schema  \
    --no-check-required  \
    --density dense  \
    --features complete  \
    --namespace OtpSchema.Api.OfferBroker.InternalCalculateOfferPricingRequest  \
    --src .working/build/internal/json-schema-for-cs/InternalCalculateOfferPricingRequest.json -o .working/build/internal/csharp/OtpSchema/Api/OfferBroker/InternalCalculateOfferPricingRequest.cs
InternalCalculateOfferPricingRequest
// <auto-generated />
//
// To parse this JSON data, add NuGet 'System.Text.Json' then do:
//
//    using OtpSchema.Api.OfferBroker.InternalCalculateOfferPricingRequest;
//
//    var internalCalculateOfferPricingRequest = InternalCalculateOfferPricingRequest.FromJson(jsonString);
#nullable enable
#pragma warning disable CS8618
#pragma warning disable CS8601
#pragma warning disable CS8603

namespace OtpSchema.Api.OfferBroker.InternalCalculateOfferPricingRequest
{
    using System;
    using System.Collections.Generic;

    using System.Text.Json;
    using System.Text.Json.Serialization;
    using System.Globalization;
    using J = System.Text.Json.Serialization.JsonPropertyNameAttribute;
    using N = System.Text.Json.Serialization.JsonIgnoreCondition;

    public partial class InternalCalculateOfferPricingRequest
    {
        [J("customerId")]   public string CustomerId { get; set; }     // Customer ID for pricing calculation.
        [J("offers")]       public Offer[]? Offers { get; set; }        // List of offers to calculate pricing for.
        [J("priceClasses")] public string[]? PriceClasses { get; set; } // Preferred price classes (priority order).
    }

    public partial class Offer
    {
        [J("offerId")]    public string OfferId { get; set; }      // Offer ID to price.
        [J("pageCount")]  public long? PageCount { get; set; }     // Page count (used if tiers and page count tiers exist).
        [J("productIds")] public string[]? ProductIds { get; set; } // Product IDs.
        [J("quantity")]   public long Quantity { get; set; }       // Quantity to price.
    }

    public partial class InternalCalculateOfferPricingRequest
    {
        public static InternalCalculateOfferPricingRequest FromJson(string json) => JsonSerializer.Deserialize<InternalCalculateOfferPricingRequest>(json, OtpSchema.Api.OfferBroker.InternalCalculateOfferPricingRequest.Converter.Settings);
    }

    public static class Serialize
    {
        public static string ToJson(this InternalCalculateOfferPricingRequest self) => JsonSerializer.Serialize(self, OtpSchema.Api.OfferBroker.InternalCalculateOfferPricingRequest.Converter.Settings);
    }

    internal static class Converter
    {
        public static readonly JsonSerializerOptions Settings = new(JsonSerializerDefaults.General)
        {
            Converters =
            {
                new DateOnlyConverter(),
                new TimeOnlyConverter(),
                IsoDateTimeOffsetConverter.Singleton
            },
        };
    }

    public class DateOnlyConverter : JsonConverter<DateOnly>
    {
        private readonly string serializationFormat;
        public DateOnlyConverter() : this(null) { }

        public DateOnlyConverter(string? serializationFormat)
        {
                this.serializationFormat = serializationFormat ?? "yyyy-MM-dd";
        }

        public override DateOnly Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
        {
                var value = reader.GetString();
                return DateOnly.Parse(value!);
        }

        public override void Write(Utf8JsonWriter writer, DateOnly value, JsonSerializerOptions options)
                => writer.WriteStringValue(value.ToString(serializationFormat));
    }

    public class TimeOnlyConverter : JsonConverter<TimeOnly>
    {
        private readonly string serializationFormat;

        public TimeOnlyConverter() : this(null) { }

        public TimeOnlyConverter(string? serializationFormat)
        {
                this.serializationFormat = serializationFormat ?? "HH:mm:ss.fff";
        }

        public override TimeOnly Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
        {
                var value = reader.GetString();
                return TimeOnly.Parse(value!);
        }

        public override void Write(Utf8JsonWriter writer, TimeOnly value, JsonSerializerOptions options)
                => writer.WriteStringValue(value.ToString(serializationFormat));
    }

    internal class IsoDateTimeOffsetConverter : JsonConverter<DateTimeOffset>
    {
        public override bool CanConvert(Type t) => t == typeof(DateTimeOffset);

        private const string DefaultDateTimeFormat = "yyyy'-'MM'-'dd'T'HH':'mm':'ss.FFFFFFFK";

        private DateTimeStyles _dateTimeStyles = DateTimeStyles.RoundtripKind;
        private string? _dateTimeFormat;
        private CultureInfo? _culture;

        public DateTimeStyles DateTimeStyles
        {
                get => _dateTimeStyles;
                set => _dateTimeStyles = value;
        }

        public string? DateTimeFormat
        {
                get => _dateTimeFormat ?? string.Empty;
                set => _dateTimeFormat = (string.IsNullOrEmpty(value)) ? null : value;
        }

        public CultureInfo Culture
        {
                get => _culture ?? CultureInfo.CurrentCulture;
                set => _culture = value;
        }

        public override void Write(Utf8JsonWriter writer, DateTimeOffset value, JsonSerializerOptions options)
        {
                string text;


                if ((_dateTimeStyles & DateTimeStyles.AdjustToUniversal) == DateTimeStyles.AdjustToUniversal
                        || (_dateTimeStyles & DateTimeStyles.AssumeUniversal) == DateTimeStyles.AssumeUniversal)
                {
                        value = value.ToUniversalTime();
                }

                text = value.ToString(_dateTimeFormat ?? DefaultDateTimeFormat, Culture);

                writer.WriteStringValue(text);
        }

        public override DateTimeOffset Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
        {
                string? dateText = reader.GetString();

                if (string.IsNullOrEmpty(dateText) == false)
                {
                        if (!string.IsNullOrEmpty(_dateTimeFormat))
                        {
                                return DateTimeOffset.ParseExact(dateText, _dateTimeFormat, Culture, _dateTimeStyles);
                        }
                        else
                        {
                                return DateTimeOffset.Parse(dateText, Culture, _dateTimeStyles);
                        }
                }
                else
                {
                        return default(DateTimeOffset);
                }
        }


        public static readonly IsoDateTimeOffsetConverter Singleton = new IsoDateTimeOffsetConverter();
    }
}
#pragma warning restore CS8618
#pragma warning restore CS8601
#pragma warning restore CS8603

InternalCalculateOfferPricingRequest
{
  "$schema": "http://json-schema.org/draft-07/schema#", 
  "$id": "InternalCalculateOfferPricingRequest.json", 
  "type": "object", 
  "additionalProperties": false, 
  "properties": {
    "customerId": {"description": "Customer ID for pricing calculation.", "type": "string"}, 
    "offers": {
      "description": "List of offers to calculate pricing for.", 
      "type": "array", 
      "items": {
        "type": "object", 
        "additionalProperties": false, 
        "properties": {
          "offerId": {"description": "Offer ID to price.", "type": "string"}, 
          "pageCount": {
            "description": "Page count (used if tiers and page count tiers exist).", 
            "type": ["integer", "null"], 
            "format": "int32"
          }, 
          "productIds": {
            "description": "Product IDs.", 
            "type": ["array", "null"], 
            "items": {"type": "string"}
          }, 
          "quantity": {"description": "Quantity to price.", "type": "integer", "format": "int32"}
        }, 
        "required": ["offerId", "quantity"]
      }
    }, 
    "priceClasses": {
      "description": "Preferred price classes (priority order).", 
      "type": ["array", "null"], 
      "items": {"type": "string"}
    }
  }, 
  "required": ["customerId", "offers"]
}