All Downloads are FREE. Search and download functionalities are using the official Maven repository.

me.chanjar.weixin.cp.bean.external.WxCpContactWayInfo Maven / Gradle / Ivy

package me.chanjar.weixin.cp.bean.external;

import com.google.gson.annotations.JsonAdapter;
import com.google.gson.annotations.SerializedName;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import me.chanjar.weixin.cp.util.json.WxCpConclusionAdapter;
import me.chanjar.weixin.cp.util.json.WxCpGsonBuilder;

import java.io.Serializable;
import java.util.List;

/**
 * 「联系我」方式 对象
 *
 * @author element
 */
@Data
@NoArgsConstructor
public class WxCpContactWayInfo implements Serializable {
  private static final long serialVersionUID = -8697184659526210472L;

  @SerializedName("contact_way")
  private ContactWay contactWay;

  /**
   * The type Contact way.
   */
  @Getter
  @Setter
  public static class ContactWay implements Serializable {
    private static final long serialVersionUID = -8697184659526210472L;

    /**
     * 联系方式的配置id
     */
    @SerializedName("config_id")
    private String configId;

    /**
     * 
     * 必填
     * 联系方式类型,1-单人, 2-多人
     * 
*/ private TYPE type; /** *
     * 必填
     * 场景,1-在小程序中联系,2-通过二维码联系
     * 
*/ private SCENE scene; /** *
     * 非必填
     * 在小程序中联系时使用的控件样式
     * 单人样式(type=1)时可选1,2,3
     * 多人样式(type=2)时可选1,2
     * 
*/ private Integer style; /** *
     * 非必填
     * 联系方式的备注信息,用于助记,不超过30个字符
     * 
*/ private String remark; /** *
     * 非必填
     * 外部客户添加时是否无需验证,默认为true
     * 
*/ @SerializedName("skip_verify") private Boolean skipVerify = Boolean.TRUE; /** *
     * 非必填
     * 企业自定义的state参数,用于区分不同的添加渠道,在调用“获取外部联系人详情(WxCpExternalContactService.getContactDetail)”  时会返回该参数值,不超过30个字符
     * 
*/ private String state; /** *
     * 联系二维码的URL,仅在scene为2时返回
     * 
*/ @SerializedName("qr_code") private String qrCode; /** *
     * 使用该联系方式的用户userID列表,在type为1时为必填,且只能有一个
     * 
*/ @SerializedName("user") private List users; /** *
     * 非必填
     * 使用该联系方式的部门id列表,只在type为2时有效
     * 
*/ @SerializedName("party") private List parties; /** *
     * 非必填
     * 是否临时会话模式,true表示使用临时会话模式,默认为false
     * 
*/ @SerializedName("is_temp") private Boolean isTemp = Boolean.FALSE; /** *
     * 非必填
     * 临时会话二维码有效期,以秒为单位。该参数仅在is_temp为true时有效,默认7天
     * 
*/ @SerializedName("expires_in") private Integer expiresIn; /** *
     * 非必填
     * 临时会话有效期,以秒为单位。该参数仅在is_temp为true时有效,默认为添加好友后24小时
     * 
*/ @SerializedName("chat_expires_in") private Integer chatExpiresIn; /** *
     * 非必填
     * 可进行临时会话的客户unionid,该参数仅在is_temp为true时有效,如不指定则不进行限制
     * 
*/ @SerializedName("unionid") private String unionId; /** *
     * 非必填
     * 结束语,会话结束时自动发送给客户,可参考“结束语定义”,仅在is_temp为true时有效
     * 
*/ private Conclusion conclusions; /** * From json wx cp contact way info . contact way. * * @param json the json * @return the wx cp contact way info . contact way */ public static WxCpContactWayInfo.ContactWay fromJson(String json) { return WxCpGsonBuilder.create().fromJson(json, WxCpContactWayInfo.ContactWay.class); } /** * To json string. * * @return the string */ public String toJson() { return WxCpGsonBuilder.create().toJson(this); } /** * 结束语定义 */ @Data @JsonAdapter(WxCpConclusionAdapter.class) public static class Conclusion implements Serializable { private static final long serialVersionUID = -8697184659526210472L; private String textContent; private String imgMediaId; private String imgPicUrl; private String linkTitle; private String linkPicUrl; private String linkDesc; private String linkUrl; private String miniProgramTitle; private String miniProgramPicMediaId; private String miniProgramAppId; private String miniProgramPage; } } /** * From json wx cp contact way info. * * @param json the json * @return the wx cp contact way info */ public static WxCpContactWayInfo fromJson(String json) { return WxCpGsonBuilder.create().fromJson(json, WxCpContactWayInfo.class); } /** * To json string. * * @return the string */ public String toJson() { return WxCpGsonBuilder.create().toJson(this); } /** * The enum Type. */ public enum TYPE { /** * 单人 */ @SerializedName("1") SINGLE, /** * 多人 */ @SerializedName("2") MULTI } /** * The enum Scene. */ public enum SCENE { /** * 在小程序中联系 */ @SerializedName("1") MINIPROGRAM, /** * 通过二维码联系 */ @SerializedName("2") QRCODE } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy