=begin
#Posts
#Use these endpoints for interacting with Blog Posts, Blog Authors, and Blog Tags
The version of the OpenAPI document: v3
Generated by: https://openapi-generator.tech
OpenAPI Generator version: 6.2.1
=end
require 'date'
require 'time'
module Hubspot
module Cms
module Blogs
module BlogPosts
# Model definition for a Blog Post.
class BlogPost
# The date (ISO8601 format) the blog post is to be published at.
attr_accessor :publish_date
# The explicitly defined ISO 639 language code of the Blog Post. If null, the Blog Post will default to the language of the ParentBlog.
attr_accessor :language
# Boolean to determine whether or not the styles from the template should be applied.
attr_accessor :enable_layout_stylesheets
# A description that goes in tag on the page.
attr_accessor :meta_description
# List of stylesheets to attach to this blog post. These stylesheets are attached to just this page. Order of precedence is bottom to top, just like in the HTML.
attr_accessor :attached_stylesheets
# Set this to create a password protected page. Entering the password will be required to view the page.
attr_accessor :password
# The html title of this Blog Post.
attr_accessor :html_title
# Set this to true if you want to be published immediately when the schedule publish endpoint is called, and to ignore the publish_date setting.
attr_accessor :publish_immediately
attr_accessor :translations
# The unique ID of the Blog Post.
attr_accessor :id
# An ENUM descibing the current state of this Blog Post.
attr_accessor :state
# The path of the this blog post. This field is appended to the domain to construct the url of this post.
attr_accessor :slug
# The ID of the user that created this Blog Post.
attr_accessor :created_by_id
# The contents of the RSS body for this Blog Post.
attr_accessor :rss_body
attr_accessor :currently_published
# If True, the post will not show up in your dashboard, although the post could still be live.
attr_accessor :archived_in_dashboard
attr_accessor :created
# An ENUM descibing the type of this object. Should always be BLOG_POST.
attr_accessor :content_type_category
#
attr_accessor :mab_experiment_id
# The ID of the user that updated this Blog Post.
attr_accessor :updated_by_id
# ID of the primary blog post this object was translated from.
attr_accessor :translated_from_id
#
attr_accessor :folder_id
# A data structure containing the data for all the modules inside the containers for this post. This will only be populated if the page has widget containers.
attr_accessor :widget_containers
#
attr_accessor :page_expiry_redirect_id
attr_accessor :dynamic_page_data_source_type
# The featuredImage of this Blog Post.
attr_accessor :featured_image
# The name of the user that updated this Blog Post.
attr_accessor :author_name
# The domain this Blog Post will resolve to. If null, the Blog Post will default to the domain of the ParentBlog.
attr_accessor :domain
# The internal name of the Blog Post.
attr_accessor :name
# The ID of the HubDB table this Blog Post references, if applicable
attr_accessor :dynamic_page_hub_db_table_id
# The GUID of the marketing campaign this Blog Post is a part of.
attr_accessor :campaign
attr_accessor :dynamic_page_data_source_id
# Boolean to determine whether or not the styles from the template should be applied.
attr_accessor :enable_domain_stylesheets
# Boolean to determine whether or not the Primary CSS Files should be applied.
attr_accessor :include_default_custom_css
#
attr_accessor :layout_sections
attr_accessor :updated
# Custom HTML for embed codes, javascript that should be placed before the
tag of the page.
attr_accessor :footer_html
# List of IDs for the tags associated with this Blog Post.
attr_accessor :tag_ids
# A data structure containing the data for all the modules for this page.
attr_accessor :widgets
# The summary of the blog post that will appear on the main listing page.
attr_accessor :post_summary
# Custom HTML for embed codes, javascript, etc. that goes in the
tag of the page.
attr_accessor :head_html
#
attr_accessor :page_expiry_redirect_url
#
attr_accessor :ab_status
# Boolean to determine if this post should use a featuredImage.
attr_accessor :use_featured_image
#
attr_accessor :ab_test_id
# Alt Text of the featuredImage.
attr_accessor :featured_image_alt_text
# The ID of the Blog Author associated with this Blog Post.
attr_accessor :blog_author_id
# The ID of the parent Blog this Blog Post is associated with.
attr_accessor :content_group_id
# The contents of the RSS summary for this Blog Post.
attr_accessor :rss_summary
#
attr_accessor :page_expiry_enabled
# A generated field representing the URL of this blog post.
attr_accessor :url
# Boolean to allow overriding the AMP settings for the blog.
attr_accessor :enable_google_amp_output_override
# Rules for require member registration to access private content.
attr_accessor :public_access_rules
# The timestamp (ISO8601 format) when this Blog Post was deleted.
attr_accessor :archived_at
# The HTML of the main post body.
attr_accessor :_post_body
#
attr_accessor :theme_settings_values
#
attr_accessor :page_expiry_date
# Boolean to determine whether or not to respect publicAccessRules.
attr_accessor :public_access_rules_enabled
# A generated ENUM descibing the current state of this Blog Post. Should always match state.
attr_accessor :current_state
# ID of the type of object this is.
attr_accessor :category_id
# Optional override to set the URL to be used in the rel=canonical link tag on the page.
attr_accessor :link_rel_canonical_url
class EnumAttributeValidator
attr_reader :datatype
attr_reader :allowable_values
def initialize(datatype, allowable_values)
@allowable_values = allowable_values.map do |value|
case datatype.to_s
when /Integer/i
value.to_i
when /Float/i
value.to_f
else
value
end
end
end
def valid?(value)
!value || allowable_values.include?(value)
end
end
# Attribute mapping from ruby-style variable name to JSON key.
def self.attribute_map
{
:'publish_date' => :'publishDate',
:'language' => :'language',
:'enable_layout_stylesheets' => :'enableLayoutStylesheets',
:'meta_description' => :'metaDescription',
:'attached_stylesheets' => :'attachedStylesheets',
:'password' => :'password',
:'html_title' => :'htmlTitle',
:'publish_immediately' => :'publishImmediately',
:'translations' => :'translations',
:'id' => :'id',
:'state' => :'state',
:'slug' => :'slug',
:'created_by_id' => :'createdById',
:'rss_body' => :'rssBody',
:'currently_published' => :'currentlyPublished',
:'archived_in_dashboard' => :'archivedInDashboard',
:'created' => :'created',
:'content_type_category' => :'contentTypeCategory',
:'mab_experiment_id' => :'mabExperimentId',
:'updated_by_id' => :'updatedById',
:'translated_from_id' => :'translatedFromId',
:'folder_id' => :'folderId',
:'widget_containers' => :'widgetContainers',
:'page_expiry_redirect_id' => :'pageExpiryRedirectId',
:'dynamic_page_data_source_type' => :'dynamicPageDataSourceType',
:'featured_image' => :'featuredImage',
:'author_name' => :'authorName',
:'domain' => :'domain',
:'name' => :'name',
:'dynamic_page_hub_db_table_id' => :'dynamicPageHubDbTableId',
:'campaign' => :'campaign',
:'dynamic_page_data_source_id' => :'dynamicPageDataSourceId',
:'enable_domain_stylesheets' => :'enableDomainStylesheets',
:'include_default_custom_css' => :'includeDefaultCustomCss',
:'layout_sections' => :'layoutSections',
:'updated' => :'updated',
:'footer_html' => :'footerHtml',
:'tag_ids' => :'tagIds',
:'widgets' => :'widgets',
:'post_summary' => :'postSummary',
:'head_html' => :'headHtml',
:'page_expiry_redirect_url' => :'pageExpiryRedirectUrl',
:'ab_status' => :'abStatus',
:'use_featured_image' => :'useFeaturedImage',
:'ab_test_id' => :'abTestId',
:'featured_image_alt_text' => :'featuredImageAltText',
:'blog_author_id' => :'blogAuthorId',
:'content_group_id' => :'contentGroupId',
:'rss_summary' => :'rssSummary',
:'page_expiry_enabled' => :'pageExpiryEnabled',
:'url' => :'url',
:'enable_google_amp_output_override' => :'enableGoogleAmpOutputOverride',
:'public_access_rules' => :'publicAccessRules',
:'archived_at' => :'archivedAt',
:'_post_body' => :'postBody',
:'theme_settings_values' => :'themeSettingsValues',
:'page_expiry_date' => :'pageExpiryDate',
:'public_access_rules_enabled' => :'publicAccessRulesEnabled',
:'current_state' => :'currentState',
:'category_id' => :'categoryId',
:'link_rel_canonical_url' => :'linkRelCanonicalUrl'
}
end
# Returns all the JSON keys this model knows about
def self.acceptable_attributes
attribute_map.values
end
# Attribute type mapping.
def self.openapi_types
{
:'publish_date' => :'Time',
:'language' => :'String',
:'enable_layout_stylesheets' => :'Boolean',
:'meta_description' => :'String',
:'attached_stylesheets' => :'Array>',
:'password' => :'String',
:'html_title' => :'String',
:'publish_immediately' => :'Boolean',
:'translations' => :'Hash',
:'id' => :'String',
:'state' => :'String',
:'slug' => :'String',
:'created_by_id' => :'String',
:'rss_body' => :'String',
:'currently_published' => :'Boolean',
:'archived_in_dashboard' => :'Boolean',
:'created' => :'Time',
:'content_type_category' => :'String',
:'mab_experiment_id' => :'String',
:'updated_by_id' => :'String',
:'translated_from_id' => :'String',
:'folder_id' => :'String',
:'widget_containers' => :'Hash',
:'page_expiry_redirect_id' => :'Integer',
:'dynamic_page_data_source_type' => :'Integer',
:'featured_image' => :'String',
:'author_name' => :'String',
:'domain' => :'String',
:'name' => :'String',
:'dynamic_page_hub_db_table_id' => :'String',
:'campaign' => :'String',
:'dynamic_page_data_source_id' => :'String',
:'enable_domain_stylesheets' => :'Boolean',
:'include_default_custom_css' => :'Boolean',
:'layout_sections' => :'Hash',
:'updated' => :'Time',
:'footer_html' => :'String',
:'tag_ids' => :'Array',
:'widgets' => :'Hash',
:'post_summary' => :'String',
:'head_html' => :'String',
:'page_expiry_redirect_url' => :'String',
:'ab_status' => :'String',
:'use_featured_image' => :'Boolean',
:'ab_test_id' => :'String',
:'featured_image_alt_text' => :'String',
:'blog_author_id' => :'String',
:'content_group_id' => :'String',
:'rss_summary' => :'String',
:'page_expiry_enabled' => :'Boolean',
:'url' => :'String',
:'enable_google_amp_output_override' => :'Boolean',
:'public_access_rules' => :'Array',
:'archived_at' => :'Integer',
:'_post_body' => :'String',
:'theme_settings_values' => :'Hash',
:'page_expiry_date' => :'Integer',
:'public_access_rules_enabled' => :'Boolean',
:'current_state' => :'String',
:'category_id' => :'Integer',
:'link_rel_canonical_url' => :'String'
}
end
# List of attributes with nullable: true
def self.openapi_nullable
Set.new([
])
end
# Initializes the object
# @param [Hash] attributes Model attributes in the form of hash
def initialize(attributes = {})
if (!attributes.is_a?(Hash))
fail ArgumentError, "The input argument (attributes) must be a hash in `Hubspot::Cms::Blogs::BlogPosts::BlogPost` initialize method"
end
# check to see if the attribute exists and convert string to symbol for hash key
attributes = attributes.each_with_object({}) { |(k, v), h|
if (!self.class.attribute_map.key?(k.to_sym))
fail ArgumentError, "`#{k}` is not a valid attribute in `Hubspot::Cms::Blogs::BlogPosts::BlogPost`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
end
h[k.to_sym] = v
}
if attributes.key?(:'publish_date')
self.publish_date = attributes[:'publish_date']
end
if attributes.key?(:'language')
self.language = attributes[:'language']
end
if attributes.key?(:'enable_layout_stylesheets')
self.enable_layout_stylesheets = attributes[:'enable_layout_stylesheets']
end
if attributes.key?(:'meta_description')
self.meta_description = attributes[:'meta_description']
end
if attributes.key?(:'attached_stylesheets')
if (value = attributes[:'attached_stylesheets']).is_a?(Array)
self.attached_stylesheets = value
end
end
if attributes.key?(:'password')
self.password = attributes[:'password']
end
if attributes.key?(:'html_title')
self.html_title = attributes[:'html_title']
end
if attributes.key?(:'publish_immediately')
self.publish_immediately = attributes[:'publish_immediately']
end
if attributes.key?(:'translations')
if (value = attributes[:'translations']).is_a?(Hash)
self.translations = value
end
end
if attributes.key?(:'id')
self.id = attributes[:'id']
end
if attributes.key?(:'state')
self.state = attributes[:'state']
end
if attributes.key?(:'slug')
self.slug = attributes[:'slug']
end
if attributes.key?(:'created_by_id')
self.created_by_id = attributes[:'created_by_id']
end
if attributes.key?(:'rss_body')
self.rss_body = attributes[:'rss_body']
end
if attributes.key?(:'currently_published')
self.currently_published = attributes[:'currently_published']
end
if attributes.key?(:'archived_in_dashboard')
self.archived_in_dashboard = attributes[:'archived_in_dashboard']
end
if attributes.key?(:'created')
self.created = attributes[:'created']
end
if attributes.key?(:'content_type_category')
self.content_type_category = attributes[:'content_type_category']
end
if attributes.key?(:'mab_experiment_id')
self.mab_experiment_id = attributes[:'mab_experiment_id']
end
if attributes.key?(:'updated_by_id')
self.updated_by_id = attributes[:'updated_by_id']
end
if attributes.key?(:'translated_from_id')
self.translated_from_id = attributes[:'translated_from_id']
end
if attributes.key?(:'folder_id')
self.folder_id = attributes[:'folder_id']
end
if attributes.key?(:'widget_containers')
if (value = attributes[:'widget_containers']).is_a?(Hash)
self.widget_containers = value
end
end
if attributes.key?(:'page_expiry_redirect_id')
self.page_expiry_redirect_id = attributes[:'page_expiry_redirect_id']
end
if attributes.key?(:'dynamic_page_data_source_type')
self.dynamic_page_data_source_type = attributes[:'dynamic_page_data_source_type']
end
if attributes.key?(:'featured_image')
self.featured_image = attributes[:'featured_image']
end
if attributes.key?(:'author_name')
self.author_name = attributes[:'author_name']
end
if attributes.key?(:'domain')
self.domain = attributes[:'domain']
end
if attributes.key?(:'name')
self.name = attributes[:'name']
end
if attributes.key?(:'dynamic_page_hub_db_table_id')
self.dynamic_page_hub_db_table_id = attributes[:'dynamic_page_hub_db_table_id']
end
if attributes.key?(:'campaign')
self.campaign = attributes[:'campaign']
end
if attributes.key?(:'dynamic_page_data_source_id')
self.dynamic_page_data_source_id = attributes[:'dynamic_page_data_source_id']
end
if attributes.key?(:'enable_domain_stylesheets')
self.enable_domain_stylesheets = attributes[:'enable_domain_stylesheets']
end
if attributes.key?(:'include_default_custom_css')
self.include_default_custom_css = attributes[:'include_default_custom_css']
end
if attributes.key?(:'layout_sections')
if (value = attributes[:'layout_sections']).is_a?(Hash)
self.layout_sections = value
end
end
if attributes.key?(:'updated')
self.updated = attributes[:'updated']
end
if attributes.key?(:'footer_html')
self.footer_html = attributes[:'footer_html']
end
if attributes.key?(:'tag_ids')
if (value = attributes[:'tag_ids']).is_a?(Array)
self.tag_ids = value
end
end
if attributes.key?(:'widgets')
if (value = attributes[:'widgets']).is_a?(Hash)
self.widgets = value
end
end
if attributes.key?(:'post_summary')
self.post_summary = attributes[:'post_summary']
end
if attributes.key?(:'head_html')
self.head_html = attributes[:'head_html']
end
if attributes.key?(:'page_expiry_redirect_url')
self.page_expiry_redirect_url = attributes[:'page_expiry_redirect_url']
end
if attributes.key?(:'ab_status')
self.ab_status = attributes[:'ab_status']
end
if attributes.key?(:'use_featured_image')
self.use_featured_image = attributes[:'use_featured_image']
end
if attributes.key?(:'ab_test_id')
self.ab_test_id = attributes[:'ab_test_id']
end
if attributes.key?(:'featured_image_alt_text')
self.featured_image_alt_text = attributes[:'featured_image_alt_text']
end
if attributes.key?(:'blog_author_id')
self.blog_author_id = attributes[:'blog_author_id']
end
if attributes.key?(:'content_group_id')
self.content_group_id = attributes[:'content_group_id']
end
if attributes.key?(:'rss_summary')
self.rss_summary = attributes[:'rss_summary']
end
if attributes.key?(:'page_expiry_enabled')
self.page_expiry_enabled = attributes[:'page_expiry_enabled']
end
if attributes.key?(:'url')
self.url = attributes[:'url']
end
if attributes.key?(:'enable_google_amp_output_override')
self.enable_google_amp_output_override = attributes[:'enable_google_amp_output_override']
end
if attributes.key?(:'public_access_rules')
if (value = attributes[:'public_access_rules']).is_a?(Array)
self.public_access_rules = value
end
end
if attributes.key?(:'archived_at')
self.archived_at = attributes[:'archived_at']
end
if attributes.key?(:'_post_body')
self._post_body = attributes[:'_post_body']
end
if attributes.key?(:'theme_settings_values')
if (value = attributes[:'theme_settings_values']).is_a?(Hash)
self.theme_settings_values = value
end
end
if attributes.key?(:'page_expiry_date')
self.page_expiry_date = attributes[:'page_expiry_date']
end
if attributes.key?(:'public_access_rules_enabled')
self.public_access_rules_enabled = attributes[:'public_access_rules_enabled']
end
if attributes.key?(:'current_state')
self.current_state = attributes[:'current_state']
end
if attributes.key?(:'category_id')
self.category_id = attributes[:'category_id']
end
if attributes.key?(:'link_rel_canonical_url')
self.link_rel_canonical_url = attributes[:'link_rel_canonical_url']
end
end
# Show invalid properties with the reasons. Usually used together with valid?
# @return Array for valid properties with the reasons
def list_invalid_properties
invalid_properties = Array.new
if @publish_date.nil?
invalid_properties.push('invalid value for "publish_date", publish_date cannot be nil.')
end
if @language.nil?
invalid_properties.push('invalid value for "language", language cannot be nil.')
end
if @enable_layout_stylesheets.nil?
invalid_properties.push('invalid value for "enable_layout_stylesheets", enable_layout_stylesheets cannot be nil.')
end
if @meta_description.nil?
invalid_properties.push('invalid value for "meta_description", meta_description cannot be nil.')
end
if @attached_stylesheets.nil?
invalid_properties.push('invalid value for "attached_stylesheets", attached_stylesheets cannot be nil.')
end
if @password.nil?
invalid_properties.push('invalid value for "password", password cannot be nil.')
end
if @html_title.nil?
invalid_properties.push('invalid value for "html_title", html_title cannot be nil.')
end
if @publish_immediately.nil?
invalid_properties.push('invalid value for "publish_immediately", publish_immediately cannot be nil.')
end
if @translations.nil?
invalid_properties.push('invalid value for "translations", translations cannot be nil.')
end
if @id.nil?
invalid_properties.push('invalid value for "id", id cannot be nil.')
end
if @state.nil?
invalid_properties.push('invalid value for "state", state cannot be nil.')
end
if @state.to_s.length > 25
invalid_properties.push('invalid value for "state", the character length must be smaller than or equal to 25.')
end
if @slug.nil?
invalid_properties.push('invalid value for "slug", slug cannot be nil.')
end
if @created_by_id.nil?
invalid_properties.push('invalid value for "created_by_id", created_by_id cannot be nil.')
end
if @rss_body.nil?
invalid_properties.push('invalid value for "rss_body", rss_body cannot be nil.')
end
if @currently_published.nil?
invalid_properties.push('invalid value for "currently_published", currently_published cannot be nil.')
end
if @archived_in_dashboard.nil?
invalid_properties.push('invalid value for "archived_in_dashboard", archived_in_dashboard cannot be nil.')
end
if @created.nil?
invalid_properties.push('invalid value for "created", created cannot be nil.')
end
if @content_type_category.nil?
invalid_properties.push('invalid value for "content_type_category", content_type_category cannot be nil.')
end
if @mab_experiment_id.nil?
invalid_properties.push('invalid value for "mab_experiment_id", mab_experiment_id cannot be nil.')
end
if @updated_by_id.nil?
invalid_properties.push('invalid value for "updated_by_id", updated_by_id cannot be nil.')
end
if @translated_from_id.nil?
invalid_properties.push('invalid value for "translated_from_id", translated_from_id cannot be nil.')
end
if @folder_id.nil?
invalid_properties.push('invalid value for "folder_id", folder_id cannot be nil.')
end
if @widget_containers.nil?
invalid_properties.push('invalid value for "widget_containers", widget_containers cannot be nil.')
end
if @page_expiry_redirect_id.nil?
invalid_properties.push('invalid value for "page_expiry_redirect_id", page_expiry_redirect_id cannot be nil.')
end
if @dynamic_page_data_source_type.nil?
invalid_properties.push('invalid value for "dynamic_page_data_source_type", dynamic_page_data_source_type cannot be nil.')
end
if @featured_image.nil?
invalid_properties.push('invalid value for "featured_image", featured_image cannot be nil.')
end
if @author_name.nil?
invalid_properties.push('invalid value for "author_name", author_name cannot be nil.')
end
if @domain.nil?
invalid_properties.push('invalid value for "domain", domain cannot be nil.')
end
if @name.nil?
invalid_properties.push('invalid value for "name", name cannot be nil.')
end
if @dynamic_page_hub_db_table_id.nil?
invalid_properties.push('invalid value for "dynamic_page_hub_db_table_id", dynamic_page_hub_db_table_id cannot be nil.')
end
if @campaign.nil?
invalid_properties.push('invalid value for "campaign", campaign cannot be nil.')
end
if @dynamic_page_data_source_id.nil?
invalid_properties.push('invalid value for "dynamic_page_data_source_id", dynamic_page_data_source_id cannot be nil.')
end
if @enable_domain_stylesheets.nil?
invalid_properties.push('invalid value for "enable_domain_stylesheets", enable_domain_stylesheets cannot be nil.')
end
if @include_default_custom_css.nil?
invalid_properties.push('invalid value for "include_default_custom_css", include_default_custom_css cannot be nil.')
end
if @layout_sections.nil?
invalid_properties.push('invalid value for "layout_sections", layout_sections cannot be nil.')
end
if @updated.nil?
invalid_properties.push('invalid value for "updated", updated cannot be nil.')
end
if @footer_html.nil?
invalid_properties.push('invalid value for "footer_html", footer_html cannot be nil.')
end
if @tag_ids.nil?
invalid_properties.push('invalid value for "tag_ids", tag_ids cannot be nil.')
end
if @widgets.nil?
invalid_properties.push('invalid value for "widgets", widgets cannot be nil.')
end
if @post_summary.nil?
invalid_properties.push('invalid value for "post_summary", post_summary cannot be nil.')
end
if @head_html.nil?
invalid_properties.push('invalid value for "head_html", head_html cannot be nil.')
end
if @page_expiry_redirect_url.nil?
invalid_properties.push('invalid value for "page_expiry_redirect_url", page_expiry_redirect_url cannot be nil.')
end
if @ab_status.nil?
invalid_properties.push('invalid value for "ab_status", ab_status cannot be nil.')
end
if @use_featured_image.nil?
invalid_properties.push('invalid value for "use_featured_image", use_featured_image cannot be nil.')
end
if @ab_test_id.nil?
invalid_properties.push('invalid value for "ab_test_id", ab_test_id cannot be nil.')
end
if @featured_image_alt_text.nil?
invalid_properties.push('invalid value for "featured_image_alt_text", featured_image_alt_text cannot be nil.')
end
if @blog_author_id.nil?
invalid_properties.push('invalid value for "blog_author_id", blog_author_id cannot be nil.')
end
if @content_group_id.nil?
invalid_properties.push('invalid value for "content_group_id", content_group_id cannot be nil.')
end
if @rss_summary.nil?
invalid_properties.push('invalid value for "rss_summary", rss_summary cannot be nil.')
end
if @page_expiry_enabled.nil?
invalid_properties.push('invalid value for "page_expiry_enabled", page_expiry_enabled cannot be nil.')
end
if @url.nil?
invalid_properties.push('invalid value for "url", url cannot be nil.')
end
if @enable_google_amp_output_override.nil?
invalid_properties.push('invalid value for "enable_google_amp_output_override", enable_google_amp_output_override cannot be nil.')
end
if @public_access_rules.nil?
invalid_properties.push('invalid value for "public_access_rules", public_access_rules cannot be nil.')
end
if @archived_at.nil?
invalid_properties.push('invalid value for "archived_at", archived_at cannot be nil.')
end
if @_post_body.nil?
invalid_properties.push('invalid value for "_post_body", _post_body cannot be nil.')
end
if @theme_settings_values.nil?
invalid_properties.push('invalid value for "theme_settings_values", theme_settings_values cannot be nil.')
end
if @page_expiry_date.nil?
invalid_properties.push('invalid value for "page_expiry_date", page_expiry_date cannot be nil.')
end
if @public_access_rules_enabled.nil?
invalid_properties.push('invalid value for "public_access_rules_enabled", public_access_rules_enabled cannot be nil.')
end
if @current_state.nil?
invalid_properties.push('invalid value for "current_state", current_state cannot be nil.')
end
if @category_id.nil?
invalid_properties.push('invalid value for "category_id", category_id cannot be nil.')
end
if @link_rel_canonical_url.nil?
invalid_properties.push('invalid value for "link_rel_canonical_url", link_rel_canonical_url cannot be nil.')
end
invalid_properties
end
# Check to see if the all the properties in the model are valid
# @return true if the model is valid
def valid?
return false if @publish_date.nil?
return false if @language.nil?
language_validator = EnumAttributeValidator.new('String', ["af", "af-na", "af-za", "agq", "agq-cm", "ak", "ak-gh", "am", "am-et", "ar", "ar-001", "ar-ae", "ar-bh", "ar-dj", "ar-dz", "ar-eg", "ar-eh", "ar-er", "ar-il", "ar-iq", "ar-jo", "ar-km", "ar-kw", "ar-lb", "ar-ly", "ar-ma", "ar-mr", "ar-om", "ar-ps", "ar-qa", "ar-sa", "ar-sd", "ar-so", "ar-ss", "ar-sy", "ar-td", "ar-tn", "ar-ye", "as", "as-in", "asa", "asa-tz", "ast", "ast-es", "az", "az-az", "bas", "bas-cm", "be", "be-by", "bem", "bem-zm", "bez", "bez-tz", "bg", "bg-bg", "bm", "bm-ml", "bn", "bn-bd", "bn-in", "bo", "bo-cn", "bo-in", "br", "br-fr", "brx", "brx-in", "bs", "bs-ba", "ca", "ca-ad", "ca-es", "ca-fr", "ca-it", "ccp", "ccp-bd", "ccp-in", "ce", "ce-ru", "ceb", "ceb-ph", "cgg", "cgg-ug", "chr", "chr-us", "ckb", "ckb-iq", "ckb-ir", "cs", "cs-cz", "cu", "cu-ru", "cy", "cy-gb", "da", "da-dk", "da-gl", "dav", "dav-ke", "de", "de-at", "de-be", "de-ch", "de-de", "de-gr", "de-it", "de-li", "de-lu", "dje", "dje-ne", "doi", "doi-in", "dsb", "dsb-de", "dua", "dua-cm", "dyo", "dyo-sn", "dz", "dz-bt", "ebu", "ebu-ke", "ee", "ee-gh", "ee-tg", "el", "el-cy", "el-gr", "en", "en-001", "en-150", "en-ae", "en-ag", "en-ai", "en-as", "en-at", "en-au", "en-bb", "en-be", "en-bi", "en-bm", "en-bs", "en-bw", "en-bz", "en-ca", "en-cc", "en-ch", "en-ck", "en-cm", "en-cn", "en-cx", "en-cy", "en-de", "en-dg", "en-dk", "en-dm", "en-ee", "en-er", "en-fr", "en-fi", "en-fj", "en-fk", "en-fm", "en-gb", "en-gd", "en-gg", "en-gh", "en-gi", "en-gm", "en-gu", "en-gy", "en-hk", "en-ie", "en-il", "en-im", "en-in", "en-io", "en-je", "en-jm", "en-ke", "en-ki", "en-kn", "en-ky", "en-lc", "en-lr", "en-ls", "en-lu", "en-mg", "en-mh", "en-mo", "en-mp", "en-ms", "en-mt", "en-mu", "en-mw", "en-mx", "en-my", "en-na", "en-nf", "en-ng", "en-nl", "en-nr", "en-nu", "en-nz", "en-pg", "en-ph", "en-pk", "en-pn", "en-pr", "en-pw", "en-rw", "en-sb", "en-sc", "en-sd", "en-se", "en-sg", "en-sh", "en-si", "en-sl", "en-ss", "en-sx", "en-sz", "en-tc", "en-tk", "en-to", "en-tt", "en-tv", "en-tz", "en-ug", "en-um", "en-us", "en-vc", "en-vg", "en-vi", "en-vu", "en-ws", "en-za", "en-zm", "en-zw", "eo", "eo-001", "es", "es-419", "es-ar", "es-bo", "es-br", "es-bz", "es-cl", "es-co", "es-cr", "es-cu", "es-do", "es-ea", "es-ec", "es-es", "es-gq", "es-gt", "es-hn", "es-ic", "es-mx", "es-ni", "es-pa", "es-pe", "es-ph", "es-pr", "es-py", "es-sv", "es-us", "es-uy", "es-ve", "et", "et-ee", "eu", "eu-es", "ewo", "ewo-cm", "fa", "fa-af", "fa-ir", "ff", "ff-bf", "ff-cm", "ff-gh", "ff-gm", "ff-gn", "ff-gw", "ff-lr", "ff-mr", "ff-ne", "ff-ng", "ff-sl", "ff-sn", "fi", "fi-fi", "fil", "fil-ph", "fo", "fo-dk", "fo-fo", "fr", "fr-be", "fr-bf", "fr-bi", "fr-bj", "fr-bl", "fr-ca", "fr-cd", "fr-cf", "fr-cg", "fr-ch", "fr-ci", "fr-cm", "fr-dj", "fr-dz", "fr-fr", "fr-ga", "fr-gf", "fr-gn", "fr-gp", "fr-gq", "fr-ht", "fr-km", "fr-lu", "fr-ma", "fr-mc", "fr-mf", "fr-mg", "fr-ml", "fr-mq", "fr-mr", "fr-mu", "fr-nc", "fr-ne", "fr-pf", "fr-pm", "fr-re", "fr-rw", "fr-sc", "fr-sn", "fr-sy", "fr-td", "fr-tg", "fr-tn", "fr-vu", "fr-wf", "fr-yt", "fur", "fur-it", "fy", "fy-nl", "ga", "ga-gb", "ga-ie", "gd", "gd-gb", "gl", "gl-es", "gsw", "gsw-ch", "gsw-fr", "gsw-li", "gu", "gu-in", "guz", "guz-ke", "gv", "gv-im", "ha", "ha-gh", "ha-ne", "ha-ng", "haw", "haw-us", "he", "hi", "hi-in", "hr", "hr-ba", "hr-hr", "hsb", "hsb-de", "hu", "hu-hu", "hy", "hy-am", "ia", "ia-001", "id", "ig", "ig-ng", "ii", "ii-cn", "id-id", "is", "is-is", "it", "it-ch", "it-it", "it-sm", "it-va", "he-il", "ja", "ja-jp", "jgo", "jgo-cm", "yi", "yi-001", "jmc", "jmc-tz", "jv", "jv-id", "ka", "ka-ge", "kab", "kab-dz", "kam", "kam-ke", "kde", "kde-tz", "kea", "kea-cv", "khq", "khq-ml", "ki", "ki-ke", "kk", "kk-kz", "kkj", "kkj-cm", "kl", "kl-gl", "kln", "kln-ke", "km", "km-kh", "kn", "kn-in", "ko", "ko-kp", "ko-kr", "kok", "kok-in", "ks", "ks-in", "ksb", "ksb-tz", "ksf", "ksf-cm", "ksh", "ksh-de", "kw", "kw-gb", "ku", "ku-tr", "ky", "ky-kg", "lag", "lag-tz", "lb", "lb-lu", "lg", "lg-ug", "lkt", "lkt-us", "ln", "ln-ao", "ln-cd", "ln-cf", "ln-cg", "lo", "lo-la", "lrc", "lrc-iq", "lrc-ir", "lt", "lt-lt", "lu", "lu-cd", "luo", "luo-ke", "luy", "luy-ke", "lv", "lv-lv", "mai", "mai-in", "mas", "mas-ke", "mas-tz", "mer", "mer-ke", "mfe", "mfe-mu", "mg", "mg-mg", "mgh", "mgh-mz", "mgo", "mgo-cm", "mi", "mi-nz", "mk", "mk-mk", "ml", "ml-in", "mn", "mn-mn", "mni", "mni-in", "mr", "mr-in", "ms", "ms-bn", "ms-id", "ms-my", "ms-sg", "mt", "mt-mt", "mua", "mua-cm", "my", "my-mm", "mzn", "mzn-ir", "naq", "naq-na", "nb", "nb-no", "nb-sj", "nd", "nd-zw", "nds", "nds-de", "nds-nl", "ne", "ne-in", "ne-np", "nl", "nl-aw", "nl-be", "nl-ch", "nl-bq", "nl-cw", "nl-lu", "nl-nl", "nl-sr", "nl-sx", "nmg", "nmg-cm", "nn", "nn-no", "nnh", "nnh-cm", "no", "no-no", "nus", "nus-ss", "nyn", "nyn-ug", "om", "om-et", "om-ke", "or", "or-in", "os", "os-ge", "os-ru", "pa", "pa-in", "pa-pk", "pcm", "pcm-ng", "pl", "pl-pl", "prg", "prg-001", "ps", "ps-af", "ps-pk", "pt", "pt-ao", "pt-br", "pt-ch", "pt-cv", "pt-gq", "pt-gw", "pt-lu", "pt-mo", "pt-mz", "pt-pt", "pt-st", "pt-tl", "qu", "qu-bo", "qu-ec", "qu-pe", "rm", "rm-ch", "rn", "rn-bi", "ro", "ro-md", "ro-ro", "rof", "rof-tz", "ru", "ru-by", "ru-kg", "ru-kz", "ru-md", "ru-ru", "ru-ua", "rw", "rw-rw", "rwk", "rwk-tz", "sa", "sa-in", "sah", "sah-ru", "saq", "saq-ke", "sat", "sat-in", "sbp", "sbp-tz", "sd", "sd-in", "sd-pk", "se", "se-fi", "se-no", "se-se", "seh", "seh-mz", "ses", "ses-ml", "sg", "sg-cf", "shi", "shi-ma", "si", "si-lk", "sk", "sk-sk", "sl", "sl-si", "smn", "smn-fi", "sn", "sn-zw", "so", "so-dj", "so-et", "so-ke", "so-so", "sq", "sq-al", "sq-mk", "sq-xk", "sr", "sr-ba", "sr-cs", "sr-me", "sr-rs", "sr-xk", "su", "su-id", "sv", "sv-ax", "sv-fi", "sv-se", "sw", "sw-cd", "sw-ke", "sw-tz", "sw-ug", "sy", "ta", "ta-in", "ta-lk", "ta-my", "ta-sg", "te", "te-in", "teo", "teo-ke", "teo-ug", "tg", "tg-tj", "th", "th-th", "ti", "ti-er", "ti-et", "tk", "tk-tm", "tl", "to", "to-to", "tr", "tr-cy", "tr-tr", "tt", "tt-ru", "twq", "twq-ne", "tzm", "tzm-ma", "ug", "ug-cn", "uk", "uk-ua", "ur", "ur-in", "ur-pk", "uz", "uz-af", "uz-uz", "vai", "vai-lr", "vi", "vi-vn", "vo", "vo-001", "vun", "vun-tz", "wae", "wae-ch", "wo", "wo-sn", "xh", "xh-za", "xog", "xog-ug", "yav", "yav-cm", "yo", "yo-bj", "yo-ng", "yue", "yue-cn", "yue-hk", "zgh", "zgh-ma", "zh", "zh-cn", "zh-hk", "zh-mo", "zh-sg", "zh-tw", "zh-hans", "zh-hant", "zu", "zu-za"])
return false unless language_validator.valid?(@language)
return false if @enable_layout_stylesheets.nil?
return false if @meta_description.nil?
return false if @attached_stylesheets.nil?
return false if @password.nil?
return false if @html_title.nil?
return false if @publish_immediately.nil?
return false if @translations.nil?
return false if @id.nil?
return false if @state.nil?
return false if @state.to_s.length > 25
return false if @slug.nil?
return false if @created_by_id.nil?
return false if @rss_body.nil?
return false if @currently_published.nil?
return false if @archived_in_dashboard.nil?
return false if @created.nil?
return false if @content_type_category.nil?
content_type_category_validator = EnumAttributeValidator.new('String', ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15"])
return false unless content_type_category_validator.valid?(@content_type_category)
return false if @mab_experiment_id.nil?
return false if @updated_by_id.nil?
return false if @translated_from_id.nil?
return false if @folder_id.nil?
return false if @widget_containers.nil?
return false if @page_expiry_redirect_id.nil?
return false if @dynamic_page_data_source_type.nil?
return false if @featured_image.nil?
return false if @author_name.nil?
return false if @domain.nil?
return false if @name.nil?
return false if @dynamic_page_hub_db_table_id.nil?
return false if @campaign.nil?
return false if @dynamic_page_data_source_id.nil?
return false if @enable_domain_stylesheets.nil?
return false if @include_default_custom_css.nil?
return false if @layout_sections.nil?
return false if @updated.nil?
return false if @footer_html.nil?
return false if @tag_ids.nil?
return false if @widgets.nil?
return false if @post_summary.nil?
return false if @head_html.nil?
return false if @page_expiry_redirect_url.nil?
return false if @ab_status.nil?
ab_status_validator = EnumAttributeValidator.new('String', ["master", "variant", "loser_variant", "mab_master", "mab_variant", "automated_master", "automated_variant", "automated_loser_variant"])
return false unless ab_status_validator.valid?(@ab_status)
return false if @use_featured_image.nil?
return false if @ab_test_id.nil?
return false if @featured_image_alt_text.nil?
return false if @blog_author_id.nil?
return false if @content_group_id.nil?
return false if @rss_summary.nil?
return false if @page_expiry_enabled.nil?
return false if @url.nil?
return false if @enable_google_amp_output_override.nil?
return false if @public_access_rules.nil?
return false if @archived_at.nil?
return false if @_post_body.nil?
return false if @theme_settings_values.nil?
return false if @page_expiry_date.nil?
return false if @public_access_rules_enabled.nil?
return false if @current_state.nil?
current_state_validator = EnumAttributeValidator.new('String', ["AUTOMATED", "AUTOMATED_DRAFT", "AUTOMATED_SENDING", "AUTOMATED_FOR_FORM", "AUTOMATED_FOR_FORM_BUFFER", "AUTOMATED_FOR_FORM_DRAFT", "AUTOMATED_FOR_FORM_LEGACY", "BLOG_EMAIL_DRAFT", "BLOG_EMAIL_PUBLISHED", "DRAFT", "DRAFT_AB", "DRAFT_AB_VARIANT", "ERROR", "LOSER_AB_VARIANT", "PAGE_STUB", "PRE_PROCESSING", "PROCESSING", "PUBLISHED", "PUBLISHED_AB", "PUBLISHED_AB_VARIANT", "PUBLISHED_OR_SCHEDULED", "RSS_TO_EMAIL_DRAFT", "RSS_TO_EMAIL_PUBLISHED", "SCHEDULED", "SCHEDULED_AB", "SCHEDULED_OR_PUBLISHED", "AUTOMATED_AB", "AUTOMATED_AB_VARIANT", "AUTOMATED_DRAFT_AB", "AUTOMATED_DRAFT_ABVARIANT", "AUTOMATED_LOSER_ABVARIANT"])
return false unless current_state_validator.valid?(@current_state)
return false if @category_id.nil?
return false if @link_rel_canonical_url.nil?
true
end
# Custom attribute writer method checking allowed values (enum).
# @param [Object] language Object to be assigned
def language=(language)
validator = EnumAttributeValidator.new('String', ["af", "af-na", "af-za", "agq", "agq-cm", "ak", "ak-gh", "am", "am-et", "ar", "ar-001", "ar-ae", "ar-bh", "ar-dj", "ar-dz", "ar-eg", "ar-eh", "ar-er", "ar-il", "ar-iq", "ar-jo", "ar-km", "ar-kw", "ar-lb", "ar-ly", "ar-ma", "ar-mr", "ar-om", "ar-ps", "ar-qa", "ar-sa", "ar-sd", "ar-so", "ar-ss", "ar-sy", "ar-td", "ar-tn", "ar-ye", "as", "as-in", "asa", "asa-tz", "ast", "ast-es", "az", "az-az", "bas", "bas-cm", "be", "be-by", "bem", "bem-zm", "bez", "bez-tz", "bg", "bg-bg", "bm", "bm-ml", "bn", "bn-bd", "bn-in", "bo", "bo-cn", "bo-in", "br", "br-fr", "brx", "brx-in", "bs", "bs-ba", "ca", "ca-ad", "ca-es", "ca-fr", "ca-it", "ccp", "ccp-bd", "ccp-in", "ce", "ce-ru", "ceb", "ceb-ph", "cgg", "cgg-ug", "chr", "chr-us", "ckb", "ckb-iq", "ckb-ir", "cs", "cs-cz", "cu", "cu-ru", "cy", "cy-gb", "da", "da-dk", "da-gl", "dav", "dav-ke", "de", "de-at", "de-be", "de-ch", "de-de", "de-gr", "de-it", "de-li", "de-lu", "dje", "dje-ne", "doi", "doi-in", "dsb", "dsb-de", "dua", "dua-cm", "dyo", "dyo-sn", "dz", "dz-bt", "ebu", "ebu-ke", "ee", "ee-gh", "ee-tg", "el", "el-cy", "el-gr", "en", "en-001", "en-150", "en-ae", "en-ag", "en-ai", "en-as", "en-at", "en-au", "en-bb", "en-be", "en-bi", "en-bm", "en-bs", "en-bw", "en-bz", "en-ca", "en-cc", "en-ch", "en-ck", "en-cm", "en-cn", "en-cx", "en-cy", "en-de", "en-dg", "en-dk", "en-dm", "en-ee", "en-er", "en-fr", "en-fi", "en-fj", "en-fk", "en-fm", "en-gb", "en-gd", "en-gg", "en-gh", "en-gi", "en-gm", "en-gu", "en-gy", "en-hk", "en-ie", "en-il", "en-im", "en-in", "en-io", "en-je", "en-jm", "en-ke", "en-ki", "en-kn", "en-ky", "en-lc", "en-lr", "en-ls", "en-lu", "en-mg", "en-mh", "en-mo", "en-mp", "en-ms", "en-mt", "en-mu", "en-mw", "en-mx", "en-my", "en-na", "en-nf", "en-ng", "en-nl", "en-nr", "en-nu", "en-nz", "en-pg", "en-ph", "en-pk", "en-pn", "en-pr", "en-pw", "en-rw", "en-sb", "en-sc", "en-sd", "en-se", "en-sg", "en-sh", "en-si", "en-sl", "en-ss", "en-sx", "en-sz", "en-tc", "en-tk", "en-to", "en-tt", "en-tv", "en-tz", "en-ug", "en-um", "en-us", "en-vc", "en-vg", "en-vi", "en-vu", "en-ws", "en-za", "en-zm", "en-zw", "eo", "eo-001", "es", "es-419", "es-ar", "es-bo", "es-br", "es-bz", "es-cl", "es-co", "es-cr", "es-cu", "es-do", "es-ea", "es-ec", "es-es", "es-gq", "es-gt", "es-hn", "es-ic", "es-mx", "es-ni", "es-pa", "es-pe", "es-ph", "es-pr", "es-py", "es-sv", "es-us", "es-uy", "es-ve", "et", "et-ee", "eu", "eu-es", "ewo", "ewo-cm", "fa", "fa-af", "fa-ir", "ff", "ff-bf", "ff-cm", "ff-gh", "ff-gm", "ff-gn", "ff-gw", "ff-lr", "ff-mr", "ff-ne", "ff-ng", "ff-sl", "ff-sn", "fi", "fi-fi", "fil", "fil-ph", "fo", "fo-dk", "fo-fo", "fr", "fr-be", "fr-bf", "fr-bi", "fr-bj", "fr-bl", "fr-ca", "fr-cd", "fr-cf", "fr-cg", "fr-ch", "fr-ci", "fr-cm", "fr-dj", "fr-dz", "fr-fr", "fr-ga", "fr-gf", "fr-gn", "fr-gp", "fr-gq", "fr-ht", "fr-km", "fr-lu", "fr-ma", "fr-mc", "fr-mf", "fr-mg", "fr-ml", "fr-mq", "fr-mr", "fr-mu", "fr-nc", "fr-ne", "fr-pf", "fr-pm", "fr-re", "fr-rw", "fr-sc", "fr-sn", "fr-sy", "fr-td", "fr-tg", "fr-tn", "fr-vu", "fr-wf", "fr-yt", "fur", "fur-it", "fy", "fy-nl", "ga", "ga-gb", "ga-ie", "gd", "gd-gb", "gl", "gl-es", "gsw", "gsw-ch", "gsw-fr", "gsw-li", "gu", "gu-in", "guz", "guz-ke", "gv", "gv-im", "ha", "ha-gh", "ha-ne", "ha-ng", "haw", "haw-us", "he", "hi", "hi-in", "hr", "hr-ba", "hr-hr", "hsb", "hsb-de", "hu", "hu-hu", "hy", "hy-am", "ia", "ia-001", "id", "ig", "ig-ng", "ii", "ii-cn", "id-id", "is", "is-is", "it", "it-ch", "it-it", "it-sm", "it-va", "he-il", "ja", "ja-jp", "jgo", "jgo-cm", "yi", "yi-001", "jmc", "jmc-tz", "jv", "jv-id", "ka", "ka-ge", "kab", "kab-dz", "kam", "kam-ke", "kde", "kde-tz", "kea", "kea-cv", "khq", "khq-ml", "ki", "ki-ke", "kk", "kk-kz", "kkj", "kkj-cm", "kl", "kl-gl", "kln", "kln-ke", "km", "km-kh", "kn", "kn-in", "ko", "ko-kp", "ko-kr", "kok", "kok-in", "ks", "ks-in", "ksb", "ksb-tz", "ksf", "ksf-cm", "ksh", "ksh-de", "kw", "kw-gb", "ku", "ku-tr", "ky", "ky-kg", "lag", "lag-tz", "lb", "lb-lu", "lg", "lg-ug", "lkt", "lkt-us", "ln", "ln-ao", "ln-cd", "ln-cf", "ln-cg", "lo", "lo-la", "lrc", "lrc-iq", "lrc-ir", "lt", "lt-lt", "lu", "lu-cd", "luo", "luo-ke", "luy", "luy-ke", "lv", "lv-lv", "mai", "mai-in", "mas", "mas-ke", "mas-tz", "mer", "mer-ke", "mfe", "mfe-mu", "mg", "mg-mg", "mgh", "mgh-mz", "mgo", "mgo-cm", "mi", "mi-nz", "mk", "mk-mk", "ml", "ml-in", "mn", "mn-mn", "mni", "mni-in", "mr", "mr-in", "ms", "ms-bn", "ms-id", "ms-my", "ms-sg", "mt", "mt-mt", "mua", "mua-cm", "my", "my-mm", "mzn", "mzn-ir", "naq", "naq-na", "nb", "nb-no", "nb-sj", "nd", "nd-zw", "nds", "nds-de", "nds-nl", "ne", "ne-in", "ne-np", "nl", "nl-aw", "nl-be", "nl-ch", "nl-bq", "nl-cw", "nl-lu", "nl-nl", "nl-sr", "nl-sx", "nmg", "nmg-cm", "nn", "nn-no", "nnh", "nnh-cm", "no", "no-no", "nus", "nus-ss", "nyn", "nyn-ug", "om", "om-et", "om-ke", "or", "or-in", "os", "os-ge", "os-ru", "pa", "pa-in", "pa-pk", "pcm", "pcm-ng", "pl", "pl-pl", "prg", "prg-001", "ps", "ps-af", "ps-pk", "pt", "pt-ao", "pt-br", "pt-ch", "pt-cv", "pt-gq", "pt-gw", "pt-lu", "pt-mo", "pt-mz", "pt-pt", "pt-st", "pt-tl", "qu", "qu-bo", "qu-ec", "qu-pe", "rm", "rm-ch", "rn", "rn-bi", "ro", "ro-md", "ro-ro", "rof", "rof-tz", "ru", "ru-by", "ru-kg", "ru-kz", "ru-md", "ru-ru", "ru-ua", "rw", "rw-rw", "rwk", "rwk-tz", "sa", "sa-in", "sah", "sah-ru", "saq", "saq-ke", "sat", "sat-in", "sbp", "sbp-tz", "sd", "sd-in", "sd-pk", "se", "se-fi", "se-no", "se-se", "seh", "seh-mz", "ses", "ses-ml", "sg", "sg-cf", "shi", "shi-ma", "si", "si-lk", "sk", "sk-sk", "sl", "sl-si", "smn", "smn-fi", "sn", "sn-zw", "so", "so-dj", "so-et", "so-ke", "so-so", "sq", "sq-al", "sq-mk", "sq-xk", "sr", "sr-ba", "sr-cs", "sr-me", "sr-rs", "sr-xk", "su", "su-id", "sv", "sv-ax", "sv-fi", "sv-se", "sw", "sw-cd", "sw-ke", "sw-tz", "sw-ug", "sy", "ta", "ta-in", "ta-lk", "ta-my", "ta-sg", "te", "te-in", "teo", "teo-ke", "teo-ug", "tg", "tg-tj", "th", "th-th", "ti", "ti-er", "ti-et", "tk", "tk-tm", "tl", "to", "to-to", "tr", "tr-cy", "tr-tr", "tt", "tt-ru", "twq", "twq-ne", "tzm", "tzm-ma", "ug", "ug-cn", "uk", "uk-ua", "ur", "ur-in", "ur-pk", "uz", "uz-af", "uz-uz", "vai", "vai-lr", "vi", "vi-vn", "vo", "vo-001", "vun", "vun-tz", "wae", "wae-ch", "wo", "wo-sn", "xh", "xh-za", "xog", "xog-ug", "yav", "yav-cm", "yo", "yo-bj", "yo-ng", "yue", "yue-cn", "yue-hk", "zgh", "zgh-ma", "zh", "zh-cn", "zh-hk", "zh-mo", "zh-sg", "zh-tw", "zh-hans", "zh-hant", "zu", "zu-za"])
unless validator.valid?(language)
fail ArgumentError, "invalid value for \"language\", must be one of #{validator.allowable_values}."
end
@language = language
end
# Custom attribute writer method with validation
# @param [Object] state Value to be assigned
def state=(state)
if state.nil?
fail ArgumentError, 'state cannot be nil'
end
if state.to_s.length > 25
fail ArgumentError, 'invalid value for "state", the character length must be smaller than or equal to 25.'
end
@state = state
end
# Custom attribute writer method checking allowed values (enum).
# @param [Object] content_type_category Object to be assigned
def content_type_category=(content_type_category)
validator = EnumAttributeValidator.new('String', ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15"])
unless validator.valid?(content_type_category)
fail ArgumentError, "invalid value for \"content_type_category\", must be one of #{validator.allowable_values}."
end
@content_type_category = content_type_category
end
# Custom attribute writer method checking allowed values (enum).
# @param [Object] ab_status Object to be assigned
def ab_status=(ab_status)
validator = EnumAttributeValidator.new('String', ["master", "variant", "loser_variant", "mab_master", "mab_variant", "automated_master", "automated_variant", "automated_loser_variant"])
unless validator.valid?(ab_status)
fail ArgumentError, "invalid value for \"ab_status\", must be one of #{validator.allowable_values}."
end
@ab_status = ab_status
end
# Custom attribute writer method checking allowed values (enum).
# @param [Object] current_state Object to be assigned
def current_state=(current_state)
validator = EnumAttributeValidator.new('String', ["AUTOMATED", "AUTOMATED_DRAFT", "AUTOMATED_SENDING", "AUTOMATED_FOR_FORM", "AUTOMATED_FOR_FORM_BUFFER", "AUTOMATED_FOR_FORM_DRAFT", "AUTOMATED_FOR_FORM_LEGACY", "BLOG_EMAIL_DRAFT", "BLOG_EMAIL_PUBLISHED", "DRAFT", "DRAFT_AB", "DRAFT_AB_VARIANT", "ERROR", "LOSER_AB_VARIANT", "PAGE_STUB", "PRE_PROCESSING", "PROCESSING", "PUBLISHED", "PUBLISHED_AB", "PUBLISHED_AB_VARIANT", "PUBLISHED_OR_SCHEDULED", "RSS_TO_EMAIL_DRAFT", "RSS_TO_EMAIL_PUBLISHED", "SCHEDULED", "SCHEDULED_AB", "SCHEDULED_OR_PUBLISHED", "AUTOMATED_AB", "AUTOMATED_AB_VARIANT", "AUTOMATED_DRAFT_AB", "AUTOMATED_DRAFT_ABVARIANT", "AUTOMATED_LOSER_ABVARIANT"])
unless validator.valid?(current_state)
fail ArgumentError, "invalid value for \"current_state\", must be one of #{validator.allowable_values}."
end
@current_state = current_state
end
# Checks equality by comparing each attribute.
# @param [Object] Object to be compared
def ==(o)
return true if self.equal?(o)
self.class == o.class &&
publish_date == o.publish_date &&
language == o.language &&
enable_layout_stylesheets == o.enable_layout_stylesheets &&
meta_description == o.meta_description &&
attached_stylesheets == o.attached_stylesheets &&
password == o.password &&
html_title == o.html_title &&
publish_immediately == o.publish_immediately &&
translations == o.translations &&
id == o.id &&
state == o.state &&
slug == o.slug &&
created_by_id == o.created_by_id &&
rss_body == o.rss_body &&
currently_published == o.currently_published &&
archived_in_dashboard == o.archived_in_dashboard &&
created == o.created &&
content_type_category == o.content_type_category &&
mab_experiment_id == o.mab_experiment_id &&
updated_by_id == o.updated_by_id &&
translated_from_id == o.translated_from_id &&
folder_id == o.folder_id &&
widget_containers == o.widget_containers &&
page_expiry_redirect_id == o.page_expiry_redirect_id &&
dynamic_page_data_source_type == o.dynamic_page_data_source_type &&
featured_image == o.featured_image &&
author_name == o.author_name &&
domain == o.domain &&
name == o.name &&
dynamic_page_hub_db_table_id == o.dynamic_page_hub_db_table_id &&
campaign == o.campaign &&
dynamic_page_data_source_id == o.dynamic_page_data_source_id &&
enable_domain_stylesheets == o.enable_domain_stylesheets &&
include_default_custom_css == o.include_default_custom_css &&
layout_sections == o.layout_sections &&
updated == o.updated &&
footer_html == o.footer_html &&
tag_ids == o.tag_ids &&
widgets == o.widgets &&
post_summary == o.post_summary &&
head_html == o.head_html &&
page_expiry_redirect_url == o.page_expiry_redirect_url &&
ab_status == o.ab_status &&
use_featured_image == o.use_featured_image &&
ab_test_id == o.ab_test_id &&
featured_image_alt_text == o.featured_image_alt_text &&
blog_author_id == o.blog_author_id &&
content_group_id == o.content_group_id &&
rss_summary == o.rss_summary &&
page_expiry_enabled == o.page_expiry_enabled &&
url == o.url &&
enable_google_amp_output_override == o.enable_google_amp_output_override &&
public_access_rules == o.public_access_rules &&
archived_at == o.archived_at &&
_post_body == o._post_body &&
theme_settings_values == o.theme_settings_values &&
page_expiry_date == o.page_expiry_date &&
public_access_rules_enabled == o.public_access_rules_enabled &&
current_state == o.current_state &&
category_id == o.category_id &&
link_rel_canonical_url == o.link_rel_canonical_url
end
# @see the `==` method
# @param [Object] Object to be compared
def eql?(o)
self == o
end
# Calculates hash code according to all attributes.
# @return [Integer] Hash code
def hash
[publish_date, language, enable_layout_stylesheets, meta_description, attached_stylesheets, password, html_title, publish_immediately, translations, id, state, slug, created_by_id, rss_body, currently_published, archived_in_dashboard, created, content_type_category, mab_experiment_id, updated_by_id, translated_from_id, folder_id, widget_containers, page_expiry_redirect_id, dynamic_page_data_source_type, featured_image, author_name, domain, name, dynamic_page_hub_db_table_id, campaign, dynamic_page_data_source_id, enable_domain_stylesheets, include_default_custom_css, layout_sections, updated, footer_html, tag_ids, widgets, post_summary, head_html, page_expiry_redirect_url, ab_status, use_featured_image, ab_test_id, featured_image_alt_text, blog_author_id, content_group_id, rss_summary, page_expiry_enabled, url, enable_google_amp_output_override, public_access_rules, archived_at, _post_body, theme_settings_values, page_expiry_date, public_access_rules_enabled, current_state, category_id, link_rel_canonical_url].hash
end
# Builds the object from hash
# @param [Hash] attributes Model attributes in the form of hash
# @return [Object] Returns the model itself
def self.build_from_hash(attributes)
new.build_from_hash(attributes)
end
# Builds the object from hash
# @param [Hash] attributes Model attributes in the form of hash
# @return [Object] Returns the model itself
def build_from_hash(attributes)
return nil unless attributes.is_a?(Hash)
attributes = attributes.transform_keys(&:to_sym)
self.class.openapi_types.each_pair do |key, type|
if attributes[self.class.attribute_map[key]].nil? && self.class.openapi_nullable.include?(key)
self.send("#{key}=", nil)
elsif type =~ /\AArray<(.*)>/i
# check to ensure the input is an array given that the attribute
# is documented as an array but the input is not
if attributes[self.class.attribute_map[key]].is_a?(Array)
self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
end
elsif !attributes[self.class.attribute_map[key]].nil?
self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
end
end
self
end
# Deserializes the data based on type
# @param string type Data type
# @param string value Value to be deserialized
# @return [Object] Deserialized data
def _deserialize(type, value)
case type.to_sym
when :Time
Time.parse(value)
when :Date
Date.parse(value)
when :String
value.to_s
when :Integer
value.to_i
when :Float
value.to_f
when :Boolean
if value.to_s =~ /\A(true|t|yes|y|1)\z/i
true
else
false
end
when :Object
# generic object (usually a Hash), return directly
value
when /\AArray<(?.+)>\z/
inner_type = Regexp.last_match[:inner_type]
value.map { |v| _deserialize(inner_type, v) }
when /\AHash<(?.+?), (?.+)>\z/
k_type = Regexp.last_match[:k_type]
v_type = Regexp.last_match[:v_type]
{}.tap do |hash|
value.each do |k, v|
hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
end
end
else # model
# models (e.g. Pet) or oneOf
klass = Hubspot::Cms::Blogs::BlogPosts.const_get(type)
klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
end
end
# Returns the string representation of the object
# @return [String] String presentation of the object
def to_s
to_hash.to_s
end
# to_body is an alias to to_hash (backward compatibility)
# @return [Hash] Returns the object in the form of hash
def to_body
to_hash
end
# Returns the object in the form of hash
# @return [Hash] Returns the object in the form of hash
def to_hash
hash = {}
self.class.attribute_map.each_pair do |attr, param|
value = self.send(attr)
if value.nil?
is_nullable = self.class.openapi_nullable.include?(attr)
next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
end
hash[param] = _to_hash(value)
end
hash
end
# Outputs non-array value in the form of hash
# For object, use to_hash. Otherwise, just return the value
# @param [Object] value Any valid value
# @return [Hash] Returns the value in the form of hash
def _to_hash(value)
if value.is_a?(Array)
value.compact.map { |v| _to_hash(v) }
elsif value.is_a?(Hash)
{}.tap do |hash|
value.each { |k, v| hash[k] = _to_hash(v) }
end
elsif value.respond_to? :to_hash
value.to_hash
else
value
end
end
end
end
end
end
end