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

me.chanjar.weixin.mp.api.WxMpKefuService Maven / Gradle / Ivy

package me.chanjar.weixin.mp.api;

import java.io.File;
import java.util.Date;

import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.mp.bean.kefu.WxMpKefuMessage;
import me.chanjar.weixin.mp.bean.kefu.request.WxMpKfAccountRequest;
import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfList;
import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfMsgList;
import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfOnlineList;
import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionGetResult;
import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionList;
import me.chanjar.weixin.mp.bean.kefu.result.WxMpKfSessionWaitCaseList;

/**
 * 
 * 客服接口.
 * 注意:命名采用kefu拼音的原因是:其英文CustomerService如果再加上Service后缀显得有点啰嗦,如果不加又显得表意不完整。
 * 
* * @author Binary Wang */ public interface WxMpKefuService { /** *
   * 发送客服消息
   * 详情请见: 发送客服消息
   * 接口url格式:https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=ACCESS_TOKEN
   * 
* * @param message the message * @return the boolean * @throws WxErrorException 异常 */ boolean sendKefuMessage(WxMpKefuMessage message) throws WxErrorException; /** *
   * 发送客服消息
   * 详情请见: 发送客服消息
   * 接口url格式:https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=ACCESS_TOKEN
   * 
* * @param message the message * @return the response * @throws WxErrorException 异常 */ String sendKefuMessageWithResponse(WxMpKefuMessage message) throws WxErrorException; //*******************客服管理接口***********************// /** *
   * 获取客服基本信息
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/cgi-bin/customservice/getkflist?access_token=ACCESS_TOKEN
   * 
* * @return the wx mp kf list * @throws WxErrorException 异常 */ WxMpKfList kfList() throws WxErrorException; /** *
   * 获取在线客服接待信息
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/cgi-bin/customservice/getonlinekflist?access_token=ACCESS_TOKEN
   * 
* * @return the wx mp kf online list * @throws WxErrorException 异常 */ WxMpKfOnlineList kfOnlineList() throws WxErrorException; /** *
   * 添加客服账号
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/customservice/kfaccount/add?access_token=ACCESS_TOKEN
   * 
* * @param request the request * @return the boolean * @throws WxErrorException 异常 */ boolean kfAccountAdd(WxMpKfAccountRequest request) throws WxErrorException; /** *
   * 设置客服信息(即更新客服信息)
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/customservice/kfaccount/update?access_token=ACCESS_TOKEN
   * 
* * @param request the request * @return the boolean * @throws WxErrorException the wx error exception */ boolean kfAccountUpdate(WxMpKfAccountRequest request) throws WxErrorException; /** *
   * 设置客服信息(即更新客服信息)
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/customservice/kfaccount/inviteworker?access_token=ACCESS_TOKEN
   * 
* * @param request the request * @return the boolean * @throws WxErrorException 异常 */ boolean kfAccountInviteWorker(WxMpKfAccountRequest request) throws WxErrorException; /** *
   * 上传客服头像
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/customservice/kfaccount/uploadheadimg?access_token=ACCESS_TOKEN&kf_account=KFACCOUNT
   * 
* * @param kfAccount the kf account * @param imgFile the img file * @return the boolean * @throws WxErrorException 异常 */ boolean kfAccountUploadHeadImg(String kfAccount, File imgFile) throws WxErrorException; /** *
   * 删除客服账号
   * 详情请见:客服管理
   * 接口url格式:https://api.weixin.qq.com/customservice/kfaccount/del?access_token=ACCESS_TOKEN&kf_account=KFACCOUNT
   * 
* * @param kfAccount the kf account * @return the boolean * @throws WxErrorException 异常 */ boolean kfAccountDel(String kfAccount) throws WxErrorException; //*******************客服会话控制接口***********************// /** *
   * 创建会话
   * 此接口在客服和用户之间创建一个会话,如果该客服和用户会话已存在,则直接返回0。指定的客服帐号必须已经绑定微信号且在线。
   * 详情请见:客服会话控制接口
   * 接口url格式: https://api.weixin.qq.com/customservice/kfsession/create?access_token=ACCESS_TOKEN
   * 
* * @param openid the openid * @param kfAccount the kf account * @return the boolean * @throws WxErrorException 异常 */ boolean kfSessionCreate(String openid, String kfAccount) throws WxErrorException; /** *
   * 关闭会话
   * 开发者可以使用本接口,关闭一个会话。
   * 详情请见:客服会话控制接口
   * 接口url格式: https://api.weixin.qq.com/customservice/kfsession/close?access_token=ACCESS_TOKEN
   * 
* * @param openid the openid * @param kfAccount the kf account * @return the boolean * @throws WxErrorException 异常 */ boolean kfSessionClose(String openid, String kfAccount) throws WxErrorException; /** *
   * 获取客户的会话状态
   * 此接口获取一个客户的会话,如果不存在,则kf_account为空。
   * 详情请见:客服会话控制接口
   * 接口url格式: https://api.weixin.qq.com/customservice/kfsession/getsession?access_token=ACCESS_TOKEN&openid=OPENID
   * 
* * @param openid the openid * @return the wx mp kf session get result * @throws WxErrorException 异常 */ WxMpKfSessionGetResult kfSessionGet(String openid) throws WxErrorException; /** *
   * 获取客服的会话列表
   * 开发者可以通过本接口获取某个客服正在接待的会话列表。
   * 详情请见:客服会话控制
   * 接口url格式: https://api.weixin.qq.com/customservice/kfsession/getsessionlist?access_token=ACCESS_TOKEN&kf_account=KFACCOUNT
   * 
* * @param kfAccount the kf account * @return the wx mp kf session list * @throws WxErrorException 异常 */ WxMpKfSessionList kfSessionList(String kfAccount) throws WxErrorException; /** *
   * 获取未接入会话列表
   * 开发者可以通过本接口获取当前正在等待队列中的会话列表,此接口最多返回最早进入队列的100个未接入会话。
   * 详情请见:客服会话控制
   * 接口url格式: https://api.weixin.qq.com/customservice/kfsession/getwaitcase?access_token=ACCESS_TOKEN
   * 
* * @return the wx mp kf session wait case list * @throws WxErrorException 异常 */ WxMpKfSessionWaitCaseList kfSessionGetWaitCase() throws WxErrorException; //*******************获取聊天记录的接口***********************// /** *
   * 获取聊天记录(原始接口)
   * 此接口返回的聊天记录中,对于图片、语音、视频,分别展示成文本格式的[image]、[voice]、[video]
   * 详情请见:获取聊天记录
   * 接口url格式: https://api.weixin.qq.com/customservice/msgrecord/getmsglist?access_token=ACCESS_TOKEN
   * 
* * @param startTime 起始时间 * @param endTime 结束时间 * @param msgId 消息id顺序从小到大,从1开始 * @param number 每次获取条数,最多10000条 * @return 聊天记录对象 wx mp kf msg list * @throws WxErrorException 异常 */ WxMpKfMsgList kfMsgList(Date startTime, Date endTime, Long msgId, Integer number) throws WxErrorException; /** *
   * 获取聊天记录(优化接口,返回指定时间段内所有的聊天记录)
   * 此接口返回的聊天记录中,对于图片、语音、视频,分别展示成文本格式的[image]、[voice]、[video]
   * 详情请见:获取聊天记录
   * 接口url格式: https://api.weixin.qq.com/customservice/msgrecord/getmsglist?access_token=ACCESS_TOKEN
   * 
* * @param startTime 起始时间 * @param endTime 结束时间 * @return 聊天记录对象 wx mp kf msg list * @throws WxErrorException 异常 */ WxMpKfMsgList kfMsgList(Date startTime, Date endTime) throws WxErrorException; /** *
   * 客服输入状态
   * 开发者可通过调用“客服输入状态”接口,返回客服当前输入状态给用户。
   * 此接口需要客服消息接口权限。
   * 如果不满足发送客服消息的触发条件,则无法下发输入状态。
   * 下发输入状态,需要客服之前30秒内跟用户有过消息交互。
   * 在输入状态中(持续15s),不可重复下发输入态。
   * 在输入状态中,如果向用户下发消息,会同时取消输入状态。
   *
   * 详情请见:客服输入状态
   * 接口url格式:https://api.weixin.qq.com/cgi-bin/message/custom/typing?access_token=ACCESS_TOKEN
   * 
* * @param openid 用户id * @param command "Typing":对用户下发“正在输入"状态 "CancelTyping":取消对用户的”正在输入"状态 * @return the boolean * @throws WxErrorException 异常 */ boolean sendKfTypingState(String openid, String command) throws WxErrorException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy