using System;
using System.Xml.Serialization;
using System.Collections.Generic;
using Top.Api.Util;
using Top.Api;
using Top.Api.DingTalk;
namespace DingTalk.Api.Request
{
    /// 
    /// TOP API: dingtalk.oapi.impaas.group.create
    /// 
    public class OapiImpaasGroupCreateRequest : BaseDingTalkRequest
    {
        /// 
        /// 创建群请求对象
        /// 
        public string Request { get; set; }
        public CreateGroupRequestDomain Request_ { set { this.Request = TopUtils.ObjectToJson(value); } } 
        #region IDingTalkRequest Members
        public override string GetApiName()
        {
            return "dingtalk.oapi.impaas.group.create";
        }
        public override string GetApiCallType()
        {
            return DingTalkConstants.CALL_TYPE_OAPI;
        }
        public override IDictionary GetParameters()
        {
            TopDictionary parameters = new TopDictionary();
            parameters.Add("request", this.Request);
            if (this.otherParams != null)
            {
                parameters.AddAll(this.otherParams);
            }
            return parameters;
        }
        public override void Validate()
        {
            RequestValidator.ValidateRequired("request", this.Request);
        }
	/// 
/// BaseGroupMemberInfoDomain Data Structure.
/// 
[Serializable]
public class BaseGroupMemberInfoDomain : TopObject
{
	        /// 
	        /// 创建者账号ID,类型由type字段决定
	        /// 
	        [XmlElement("id")]
	        public string Id { get; set; }
	
	        /// 
	        /// 账号ID类型,当type=staff时,id填写staffid,当type=channelUser时,id字段填写channelUserId
	        /// 
	        [XmlElement("type")]
	        public string Type { get; set; }
}
	/// 
/// CreateGroupRequestDomain Data Structure.
/// 
[Serializable]
public class CreateGroupRequestDomain : TopObject
{
	        /// 
	        /// 接入方channel信息,该值由接入方接入IMPaaS平台时,向IMPaaS平台申请,例如“hema”“eleme”等。
	        /// 
	        [XmlElement("channel")]
	        public string Channel { get; set; }
	
	        /// 
	        /// 创建者
	        /// 
	        [XmlElement("creater")]
	        public BaseGroupMemberInfoDomain Creater { get; set; }
	
	        /// 
	        /// 二级会话入口ID
	        /// 
	        [XmlElement("entrance_id")]
	        public Nullable EntranceId { get; set; }
	
	        /// 
	        /// 扩展数据,业务可以自定义,目前最大支持256B
	        /// 
	        [XmlElement("extension")]
	        public string Extension { get; set; }
	
	        /// 
	        /// 群成员列表
	        /// 
	        [XmlArray("member_list")]
	        [XmlArrayItem("base_group_member_info")]
	        public List MemberList { get; set; }
	
	        /// 
	        /// 群名称
	        /// 
	        [XmlElement("name")]
	        public string Name { get; set; }
	
	        /// 
	        /// 新人进群是否能查看最近100条记录。0:不能;1:可以查看最近100条记录;不填默认为0
	        /// 
	        [XmlElement("show_history_type")]
	        public Nullable ShowHistoryType { get; set; }
	
	        /// 
	        /// 群类型,目前没有使用,填0即可
	        /// 
	        [XmlElement("type")]
	        public Nullable Type { get; set; }
	
	        /// 
	        /// uuid, 用于防止弱网情况下超时导致重复创建, 一分钟内传递相同的uuid会返回同一个群,传空则不去重
	        /// 
	        [XmlElement("uuid")]
	        public string Uuid { get; set; }
}
        #endregion
    }
}