=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