google-api-ruby-client/google-api-client/generated/google/apis/groupssettings_v1/classes.rb

719 lines
36 KiB
Ruby

# Copyright 2015 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
require 'date'
require 'google/apis/core/base_service'
require 'google/apis/core/json_representation'
require 'google/apis/core/hashable'
require 'google/apis/errors'
module Google
module Apis
module GroupssettingsV1
# JSON template for Group resource
class Groups
include Google::Apis::Core::Hashable
# Identifies whether members external to your organization can join the group.
# Possible values are:
# - true: G Suite users external to your organization can become members of this
# group.
# - false: Users not belonging to the organization are not allowed to become
# members of this group.
# Corresponds to the JSON property `allowExternalMembers`
# @return [String]
attr_accessor :allow_external_members
# Deprecated. Allows Google to contact administrator of the group.
# - true: Allow Google to contact managers of this group. Occasionally Google
# may send updates on the latest features, ask for input on new features, or ask
# for permission to highlight your group.
# - false: Google can not contact managers of this group.
# Corresponds to the JSON property `allowGoogleCommunication`
# @return [String]
attr_accessor :allow_google_communication
# Allows posting from web. Possible values are:
# - true: Allows any member to post to the group forum.
# - false: Members only use Gmail to communicate with the group.
# Corresponds to the JSON property `allowWebPosting`
# @return [String]
attr_accessor :allow_web_posting
# Allows the group to be archived only. Possible values are:
# - true: Group is archived and the group is inactive. New messages to this
# group are rejected. The older archived messages are browseable and searchable.
#
# - If true, the whoCanPostMessage property is set to NONE_CAN_POST.
# - If reverted from true to false, whoCanPostMessages is set to
# ALL_MANAGERS_CAN_POST.
# - false: The group is active and can receive messages.
# - When false, updating whoCanPostMessage to NONE_CAN_POST, results in an error.
# Corresponds to the JSON property `archiveOnly`
# @return [String]
attr_accessor :archive_only
# Set the content of custom footer text. The maximum number of characters is 1,
# 000.
# Corresponds to the JSON property `customFooterText`
# @return [String]
attr_accessor :custom_footer_text
# An email address used when replying to a message if the replyTo property is
# set to REPLY_TO_CUSTOM. This address is defined by an account administrator.
# - When the group's ReplyTo property is set to REPLY_TO_CUSTOM, the
# customReplyTo property holds a custom email address used when replying to a
# message.
# - If the group's ReplyTo property is set to REPLY_TO_CUSTOM, the customReplyTo
# property must have a text value or an error is returned.
# Corresponds to the JSON property `customReplyTo`
# @return [String]
attr_accessor :custom_reply_to
# Specifies whether the group has a custom role that's included in one of the
# settings being merged. This field is read-only and update/patch requests to it
# are ignored. Possible values are:
# - true
# - false
# Corresponds to the JSON property `customRolesEnabledForSettingsToBeMerged`
# @return [String]
attr_accessor :custom_roles_enabled_for_settings_to_be_merged
# When a message is rejected, this is text for the rejection notification sent
# to the message's author. By default, this property is empty and has no value
# in the API's response body. The maximum notification text size is 10,000
# characters. Note: Requires sendMessageDenyNotification property to be true.
# Corresponds to the JSON property `defaultMessageDenyNotificationText`
# @return [String]
attr_accessor :default_message_deny_notification_text
# Description of the group. This property value may be an empty string if no
# group description has been entered. If entered, the maximum group description
# is no more than 300 characters.
# Corresponds to the JSON property `description`
# @return [String]
attr_accessor :description
# The group's email address. This property can be updated using the Directory
# API. Note: Only a group owner can change a group's email address. A group
# manager can't do this.
# When you change your group's address using the Directory API or the control
# panel, you are changing the address your subscribers use to send email and the
# web address people use to access your group. People can't reach your group by
# visiting the old address.
# Corresponds to the JSON property `email`
# @return [String]
attr_accessor :email
# Specifies whether a collaborative inbox will remain turned on for the group.
# Possible values are:
# - true
# - false
# Corresponds to the JSON property `enableCollaborativeInbox`
# @return [String]
attr_accessor :enable_collaborative_inbox
# Indicates if favorite replies should be displayed above other replies.
# - true: Favorite replies will be displayed above other replies.
# - false: Favorite replies will not be displayed above other replies.
# Corresponds to the JSON property `favoriteRepliesOnTop`
# @return [String]
attr_accessor :favorite_replies_on_top
# Whether to include custom footer. Possible values are:
# - true
# - false
# Corresponds to the JSON property `includeCustomFooter`
# @return [String]
attr_accessor :include_custom_footer
# Enables the group to be included in the Global Address List. For more
# information, see the help center. Possible values are:
# - true: Group is included in the Global Address List.
# - false: Group is not included in the Global Address List.
# Corresponds to the JSON property `includeInGlobalAddressList`
# @return [String]
attr_accessor :include_in_global_address_list
# Allows the Group contents to be archived. Possible values are:
# - true: Archive messages sent to the group.
# - false: Do not keep an archive of messages sent to this group. If false,
# previously archived messages remain in the archive.
# Corresponds to the JSON property `isArchived`
# @return [String]
attr_accessor :is_archived
# The type of the resource. It is always groupsSettings#groups.
# Corresponds to the JSON property `kind`
# @return [String]
attr_accessor :kind
# Deprecated. The maximum size of a message is 25Mb.
# Corresponds to the JSON property `maxMessageBytes`
# @return [Fixnum]
attr_accessor :max_message_bytes
# Enables members to post messages as the group. Possible values are:
# - true: Group member can post messages using the group's email address instead
# of their own email address. Message appear to originate from the group itself.
# Note: When true, any message moderation settings on individual users or new
# members do not apply to posts made on behalf of the group.
# - false: Members can not post in behalf of the group's email address.
# Corresponds to the JSON property `membersCanPostAsTheGroup`
# @return [String]
attr_accessor :members_can_post_as_the_group
# Deprecated. The default message display font always has a value of "
# DEFAULT_FONT".
# Corresponds to the JSON property `messageDisplayFont`
# @return [String]
attr_accessor :message_display_font
# Moderation level of incoming messages. Possible values are:
# - MODERATE_ALL_MESSAGES: All messages are sent to the group owner's email
# address for approval. If approved, the message is sent to the group.
# - MODERATE_NON_MEMBERS: All messages from non group members are sent to the
# group owner's email address for approval. If approved, the message is sent to
# the group.
# - MODERATE_NEW_MEMBERS: All messages from new members are sent to the group
# owner's email address for approval. If approved, the message is sent to the
# group.
# - MODERATE_NONE: No moderator approval is required. Messages are delivered
# directly to the group. Note: When the whoCanPostMessage is set to
# ANYONE_CAN_POST, we recommend the messageModerationLevel be set to
# MODERATE_NON_MEMBERS to protect the group from possible spam.
# When memberCanPostAsTheGroup is true, any message moderation settings on
# individual users or new members will not apply to posts made on behalf of the
# group.
# Corresponds to the JSON property `messageModerationLevel`
# @return [String]
attr_accessor :message_moderation_level
# Name of the group, which has a maximum size of 75 characters.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# The primary language for group. For a group's primary language use the
# language tags from the G Suite languages found at G Suite Email Settings API
# Email Language Tags.
# Corresponds to the JSON property `primaryLanguage`
# @return [String]
attr_accessor :primary_language
# Specifies who receives the default reply. Possible values are:
# - REPLY_TO_CUSTOM: For replies to messages, use the group's custom email
# address.
# When the group's ReplyTo property is set to REPLY_TO_CUSTOM, the customReplyTo
# property holds the custom email address used when replying to a message. If
# the group's ReplyTo property is set to REPLY_TO_CUSTOM, the customReplyTo
# property must have a value. Otherwise an error is returned.
#
# - REPLY_TO_SENDER: The reply sent to author of message.
# - REPLY_TO_LIST: This reply message is sent to the group.
# - REPLY_TO_OWNER: The reply is sent to the owner(s) of the group. This does
# not include the group's managers.
# - REPLY_TO_IGNORE: Group users individually decide where the message reply is
# sent.
# - REPLY_TO_MANAGERS: This reply message is sent to the group's managers, which
# includes all managers and the group owner.
# Corresponds to the JSON property `replyTo`
# @return [String]
attr_accessor :reply_to
# Allows a member to be notified if the member's message to the group is denied
# by the group owner. Possible values are:
# - true: When a message is rejected, send the deny message notification to the
# message author.
# The defaultMessageDenyNotificationText property is dependent on the
# sendMessageDenyNotification property being true.
#
# - false: When a message is rejected, no notification is sent.
# Corresponds to the JSON property `sendMessageDenyNotification`
# @return [String]
attr_accessor :send_message_deny_notification
# Deprecated. This is merged into the new whoCanDiscoverGroup setting. Allows
# the group to be visible in the Groups Directory. Possible values are:
# - true: All groups in the account are listed in the Groups directory.
# - false: All groups in the account are not listed in the directory.
# Corresponds to the JSON property `showInGroupDirectory`
# @return [String]
attr_accessor :show_in_group_directory
# Specifies moderation levels for messages detected as spam. Possible values are:
#
# - ALLOW: Post the message to the group.
# - MODERATE: Send the message to the moderation queue. This is the default.
# - SILENTLY_MODERATE: Send the message to the moderation queue, but do not send
# notification to moderators.
# - REJECT: Immediately reject the message.
# Corresponds to the JSON property `spamModerationLevel`
# @return [String]
attr_accessor :spam_moderation_level
# Deprecated. This is merged into the new whoCanModerateMembers setting.
# Permissions to add members. Possible values are:
# - ALL_MEMBERS_CAN_ADD: Managers and members can directly add new members.
# - ALL_MANAGERS_CAN_ADD: Only managers can directly add new members. this
# includes the group's owner.
# - ALL_OWNERS_CAN_ADD: Only owners can directly add new members.
# - NONE_CAN_ADD: No one can directly add new members.
# Corresponds to the JSON property `whoCanAdd`
# @return [String]
attr_accessor :who_can_add
# Deprecated. This functionality is no longer supported in the Google Groups UI.
# The value is always "NONE".
# Corresponds to the JSON property `whoCanAddReferences`
# @return [String]
attr_accessor :who_can_add_references
# Specifies who can approve members who ask to join groups. This permission will
# be deprecated once it is merged into the new whoCanModerateMembers setting.
# Possible values are:
# - ALL_MEMBERS_CAN_APPROVE
# - ALL_MANAGERS_CAN_APPROVE
# - ALL_OWNERS_CAN_APPROVE
# - NONE_CAN_APPROVE
# Corresponds to the JSON property `whoCanApproveMembers`
# @return [String]
attr_accessor :who_can_approve_members
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can approve pending messages in the moderation queue. Possible
# values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanApproveMessages`
# @return [String]
attr_accessor :who_can_approve_messages
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to assign topics in a forum to another user. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanAssignTopics`
# @return [String]
attr_accessor :who_can_assign_topics
# Specifies who can moderate metadata. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanAssistContent`
# @return [String]
attr_accessor :who_can_assist_content
# Specifies who can deny membership to users. This permission will be deprecated
# once it is merged into the new whoCanModerateMembers setting. Possible values
# are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanBanUsers`
# @return [String]
attr_accessor :who_can_ban_users
# Permission to contact owner of the group via web UI. Possible values are:
# - ALL_IN_DOMAIN_CAN_CONTACT
# - ALL_MANAGERS_CAN_CONTACT
# - ALL_MEMBERS_CAN_CONTACT
# - ANYONE_CAN_CONTACT
# Corresponds to the JSON property `whoCanContactOwner`
# @return [String]
attr_accessor :who_can_contact_owner
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can delete replies to topics. (Authors can always delete their
# own posts). Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanDeleteAnyPost`
# @return [String]
attr_accessor :who_can_delete_any_post
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can delete topics. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanDeleteTopics`
# @return [String]
attr_accessor :who_can_delete_topics
# Specifies the set of users for whom this group is discoverable. Possible
# values are:
# - ANYONE_CAN_DISCOVER
# - ALL_IN_DOMAIN_CAN_DISCOVER
# - ALL_MEMBERS_CAN_DISCOVER
# Corresponds to the JSON property `whoCanDiscoverGroup`
# @return [String]
attr_accessor :who_can_discover_group
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to enter free form tags for topics in a forum. Possible values are:
#
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanEnterFreeFormTags`
# @return [String]
attr_accessor :who_can_enter_free_form_tags
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can hide posts by reporting them as abuse. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanHideAbuse`
# @return [String]
attr_accessor :who_can_hide_abuse
# Deprecated. This is merged into the new whoCanModerateMembers setting.
# Permissions to invite new members. Possible values are:
# - ALL_MEMBERS_CAN_INVITE: Managers and members can invite a new member
# candidate.
# - ALL_MANAGERS_CAN_INVITE: Only managers can invite a new member. This
# includes the group's owner.
# - ALL_OWNERS_CAN_INVITE: Only owners can invite a new member.
# - NONE_CAN_INVITE: No one can invite a new member candidate.
# Corresponds to the JSON property `whoCanInvite`
# @return [String]
attr_accessor :who_can_invite
# Permission to join group. Possible values are:
# - ANYONE_CAN_JOIN: Anyone in the account domain can join. This includes
# accounts with multiple domains.
# - ALL_IN_DOMAIN_CAN_JOIN: Any Internet user who is outside your domain can
# access your Google Groups service and view the list of groups in your Groups
# directory. Warning: Group owners can add external addresses, outside of the
# domain to their groups. They can also allow people outside your domain to join
# their groups. If you later disable this option, any external addresses already
# added to users' groups remain in those groups.
# - INVITED_CAN_JOIN: Candidates for membership can be invited to join.
# - CAN_REQUEST_TO_JOIN: Non members can request an invitation to join.
# Corresponds to the JSON property `whoCanJoin`
# @return [String]
attr_accessor :who_can_join
# Permission to leave the group. Possible values are:
# - ALL_MANAGERS_CAN_LEAVE
# - ALL_MEMBERS_CAN_LEAVE
# - NONE_CAN_LEAVE
# Corresponds to the JSON property `whoCanLeaveGroup`
# @return [String]
attr_accessor :who_can_leave_group
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can prevent users from posting replies to topics. Possible
# values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanLockTopics`
# @return [String]
attr_accessor :who_can_lock_topics
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can make topics appear at the top of the topic list. Possible
# values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMakeTopicsSticky`
# @return [String]
attr_accessor :who_can_make_topics_sticky
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to mark a topic as a duplicate of another topic. Possible values
# are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMarkDuplicate`
# @return [String]
attr_accessor :who_can_mark_duplicate
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to mark any other user's post as a favorite reply. Possible values
# are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMarkFavoriteReplyOnAnyTopic`
# @return [String]
attr_accessor :who_can_mark_favorite_reply_on_any_topic
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to mark a post for a topic they started as a favorite reply.
# Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMarkFavoriteReplyOnOwnTopic`
# @return [String]
attr_accessor :who_can_mark_favorite_reply_on_own_topic
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to mark a topic as not needing a response. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMarkNoResponseNeeded`
# @return [String]
attr_accessor :who_can_mark_no_response_needed
# Specifies who can moderate content. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanModerateContent`
# @return [String]
attr_accessor :who_can_moderate_content
# Specifies who can manage members. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanModerateMembers`
# @return [String]
attr_accessor :who_can_moderate_members
# Deprecated. This is merged into the new whoCanModerateMembers setting.
# Specifies who can change group members' roles. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanModifyMembers`
# @return [String]
attr_accessor :who_can_modify_members
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to change tags and categories. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanModifyTagsAndCategories`
# @return [String]
attr_accessor :who_can_modify_tags_and_categories
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can move topics into the group or forum. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMoveTopicsIn`
# @return [String]
attr_accessor :who_can_move_topics_in
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can move topics out of the group or forum. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanMoveTopicsOut`
# @return [String]
attr_accessor :who_can_move_topics_out
# Deprecated. This is merged into the new whoCanModerateContent setting.
# Specifies who can post announcements, a special topic type. Possible values
# are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanPostAnnouncements`
# @return [String]
attr_accessor :who_can_post_announcements
# Permissions to post messages. Possible values are:
# - NONE_CAN_POST: The group is disabled and archived. No one can post a message
# to this group.
# - When archiveOnly is false, updating whoCanPostMessage to NONE_CAN_POST,
# results in an error.
# - If archiveOnly is reverted from true to false, whoCanPostMessages is set to
# ALL_MANAGERS_CAN_POST.
# - ALL_MANAGERS_CAN_POST: Managers, including group owners, can post messages.
# - ALL_MEMBERS_CAN_POST: Any group member can post a message.
# - ALL_OWNERS_CAN_POST: Only group owners can post a message.
# - ALL_IN_DOMAIN_CAN_POST: Anyone in the account can post a message.
# - ANYONE_CAN_POST: Any Internet user who outside your account can access your
# Google Groups service and post a message. Note: When whoCanPostMessage is set
# to ANYONE_CAN_POST, we recommend the messageModerationLevel be set to
# MODERATE_NON_MEMBERS to protect the group from possible spam.
# Corresponds to the JSON property `whoCanPostMessage`
# @return [String]
attr_accessor :who_can_post_message
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to take topics in a forum. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanTakeTopics`
# @return [String]
attr_accessor :who_can_take_topics
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to unassign any topic in a forum. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanUnassignTopic`
# @return [String]
attr_accessor :who_can_unassign_topic
# Deprecated. This is merged into the new whoCanAssistContent setting.
# Permission to unmark any post from a favorite reply. Possible values are:
# - ALL_MEMBERS
# - OWNERS_AND_MANAGERS
# - MANAGERS_ONLY
# - OWNERS_ONLY
# - NONE
# Corresponds to the JSON property `whoCanUnmarkFavoriteReplyOnAnyTopic`
# @return [String]
attr_accessor :who_can_unmark_favorite_reply_on_any_topic
# Permissions to view group messages. Possible values are:
# - ANYONE_CAN_VIEW: Any Internet user can view the group's messages.
# - ALL_IN_DOMAIN_CAN_VIEW: Anyone in your account can view this group's
# messages.
# - ALL_MEMBERS_CAN_VIEW: All group members can view the group's messages.
# - ALL_MANAGERS_CAN_VIEW: Any group manager can view this group's messages.
# Corresponds to the JSON property `whoCanViewGroup`
# @return [String]
attr_accessor :who_can_view_group
# Permissions to view membership. Possible values are:
# - ALL_IN_DOMAIN_CAN_VIEW: Anyone in the account can view the group members
# list.
# If a group already has external members, those members can still send email to
# this group.
#
# - ALL_MEMBERS_CAN_VIEW: The group members can view the group members list.
# - ALL_MANAGERS_CAN_VIEW: The group managers can view group members list.
# Corresponds to the JSON property `whoCanViewMembership`
# @return [String]
attr_accessor :who_can_view_membership
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@allow_external_members = args[:allow_external_members] if args.key?(:allow_external_members)
@allow_google_communication = args[:allow_google_communication] if args.key?(:allow_google_communication)
@allow_web_posting = args[:allow_web_posting] if args.key?(:allow_web_posting)
@archive_only = args[:archive_only] if args.key?(:archive_only)
@custom_footer_text = args[:custom_footer_text] if args.key?(:custom_footer_text)
@custom_reply_to = args[:custom_reply_to] if args.key?(:custom_reply_to)
@custom_roles_enabled_for_settings_to_be_merged = args[:custom_roles_enabled_for_settings_to_be_merged] if args.key?(:custom_roles_enabled_for_settings_to_be_merged)
@default_message_deny_notification_text = args[:default_message_deny_notification_text] if args.key?(:default_message_deny_notification_text)
@description = args[:description] if args.key?(:description)
@email = args[:email] if args.key?(:email)
@enable_collaborative_inbox = args[:enable_collaborative_inbox] if args.key?(:enable_collaborative_inbox)
@favorite_replies_on_top = args[:favorite_replies_on_top] if args.key?(:favorite_replies_on_top)
@include_custom_footer = args[:include_custom_footer] if args.key?(:include_custom_footer)
@include_in_global_address_list = args[:include_in_global_address_list] if args.key?(:include_in_global_address_list)
@is_archived = args[:is_archived] if args.key?(:is_archived)
@kind = args[:kind] if args.key?(:kind)
@max_message_bytes = args[:max_message_bytes] if args.key?(:max_message_bytes)
@members_can_post_as_the_group = args[:members_can_post_as_the_group] if args.key?(:members_can_post_as_the_group)
@message_display_font = args[:message_display_font] if args.key?(:message_display_font)
@message_moderation_level = args[:message_moderation_level] if args.key?(:message_moderation_level)
@name = args[:name] if args.key?(:name)
@primary_language = args[:primary_language] if args.key?(:primary_language)
@reply_to = args[:reply_to] if args.key?(:reply_to)
@send_message_deny_notification = args[:send_message_deny_notification] if args.key?(:send_message_deny_notification)
@show_in_group_directory = args[:show_in_group_directory] if args.key?(:show_in_group_directory)
@spam_moderation_level = args[:spam_moderation_level] if args.key?(:spam_moderation_level)
@who_can_add = args[:who_can_add] if args.key?(:who_can_add)
@who_can_add_references = args[:who_can_add_references] if args.key?(:who_can_add_references)
@who_can_approve_members = args[:who_can_approve_members] if args.key?(:who_can_approve_members)
@who_can_approve_messages = args[:who_can_approve_messages] if args.key?(:who_can_approve_messages)
@who_can_assign_topics = args[:who_can_assign_topics] if args.key?(:who_can_assign_topics)
@who_can_assist_content = args[:who_can_assist_content] if args.key?(:who_can_assist_content)
@who_can_ban_users = args[:who_can_ban_users] if args.key?(:who_can_ban_users)
@who_can_contact_owner = args[:who_can_contact_owner] if args.key?(:who_can_contact_owner)
@who_can_delete_any_post = args[:who_can_delete_any_post] if args.key?(:who_can_delete_any_post)
@who_can_delete_topics = args[:who_can_delete_topics] if args.key?(:who_can_delete_topics)
@who_can_discover_group = args[:who_can_discover_group] if args.key?(:who_can_discover_group)
@who_can_enter_free_form_tags = args[:who_can_enter_free_form_tags] if args.key?(:who_can_enter_free_form_tags)
@who_can_hide_abuse = args[:who_can_hide_abuse] if args.key?(:who_can_hide_abuse)
@who_can_invite = args[:who_can_invite] if args.key?(:who_can_invite)
@who_can_join = args[:who_can_join] if args.key?(:who_can_join)
@who_can_leave_group = args[:who_can_leave_group] if args.key?(:who_can_leave_group)
@who_can_lock_topics = args[:who_can_lock_topics] if args.key?(:who_can_lock_topics)
@who_can_make_topics_sticky = args[:who_can_make_topics_sticky] if args.key?(:who_can_make_topics_sticky)
@who_can_mark_duplicate = args[:who_can_mark_duplicate] if args.key?(:who_can_mark_duplicate)
@who_can_mark_favorite_reply_on_any_topic = args[:who_can_mark_favorite_reply_on_any_topic] if args.key?(:who_can_mark_favorite_reply_on_any_topic)
@who_can_mark_favorite_reply_on_own_topic = args[:who_can_mark_favorite_reply_on_own_topic] if args.key?(:who_can_mark_favorite_reply_on_own_topic)
@who_can_mark_no_response_needed = args[:who_can_mark_no_response_needed] if args.key?(:who_can_mark_no_response_needed)
@who_can_moderate_content = args[:who_can_moderate_content] if args.key?(:who_can_moderate_content)
@who_can_moderate_members = args[:who_can_moderate_members] if args.key?(:who_can_moderate_members)
@who_can_modify_members = args[:who_can_modify_members] if args.key?(:who_can_modify_members)
@who_can_modify_tags_and_categories = args[:who_can_modify_tags_and_categories] if args.key?(:who_can_modify_tags_and_categories)
@who_can_move_topics_in = args[:who_can_move_topics_in] if args.key?(:who_can_move_topics_in)
@who_can_move_topics_out = args[:who_can_move_topics_out] if args.key?(:who_can_move_topics_out)
@who_can_post_announcements = args[:who_can_post_announcements] if args.key?(:who_can_post_announcements)
@who_can_post_message = args[:who_can_post_message] if args.key?(:who_can_post_message)
@who_can_take_topics = args[:who_can_take_topics] if args.key?(:who_can_take_topics)
@who_can_unassign_topic = args[:who_can_unassign_topic] if args.key?(:who_can_unassign_topic)
@who_can_unmark_favorite_reply_on_any_topic = args[:who_can_unmark_favorite_reply_on_any_topic] if args.key?(:who_can_unmark_favorite_reply_on_any_topic)
@who_can_view_group = args[:who_can_view_group] if args.key?(:who_can_view_group)
@who_can_view_membership = args[:who_can_view_membership] if args.key?(:who_can_view_membership)
end
end
end
end
end