1
This commit is contained in:
@@ -1 +1,283 @@
|
||||
package xpyunapi
|
||||
|
||||
const (
|
||||
//http返回成功状态码
|
||||
HttpStatusSuccessCode = 200
|
||||
//响应状态码
|
||||
REQUEST_HEADER_ERROR = -1 // 请求头错误
|
||||
REQUEST_PARAM_INVALID = -2 //参数不合法
|
||||
REQUEST_SIGN_FAILED = -3 //参数签名失败
|
||||
REQUEST_USER_NOT_REGISTER = -4 //用户未注册
|
||||
|
||||
SN_USER_NOT_MATCH = 1001 //打印机编号和用户不匹配
|
||||
PRINTER_NOT_REGISTER = 1002 //打印机未注册
|
||||
PRINTER_OFFLINE = 1003 //打印机不在线
|
||||
ADD_ORDER_FAILED = 1004 //添加订单失败
|
||||
ORDER_NOT_FOUND = 1005 //未找到订单信息
|
||||
ORDER_DATE_INVALID = 1006 //订单日期格式或大小不正确
|
||||
PRINT_CONTENT_MORE_THAN_12K_BYTES = 1007 //打印内容不能超过12K
|
||||
PRINTER_RECORD_LOCK_FAIL = 1008 //用户修改打印机记录失败
|
||||
SN_OR_NAME_EMPTY = 1009 // 用户添加打印机时,打印机编号或名称不能为空
|
||||
PRINTER_NUMBER_INVALID = 1010 //打印机设备编号无效
|
||||
PRINTER_EXIST = 1011 //打印机已存在,若当前开放平台无法查询到打印机信息,请联系售后技术支持人员核实
|
||||
PRINTER_EXCEPTION = 1012 //添加打印设备失败,请稍后再试或联系售后技术支持人员
|
||||
ORDER_IDEMPOTENT = 1013 //打印订单时触发幂等性
|
||||
ORDER_IDEMPOTENT_LIMITLEN = 1014 //幂等因子过长
|
||||
LOGO_FORMAT_ERROR = 1016 //LOGO文件格式错误
|
||||
LOGO_SIZE_LARGE = 1017 //LOGO文件超出规定范围
|
||||
LOGO_UPLOAD_TIMES = 1018 //LOGO上传次数超限制
|
||||
LOGO_DELETE_NO_EXIST = 1020 // LOGO删除失败
|
||||
LABEL_MODE_ERROR = 1021 //LOGO上传模式错误
|
||||
)
|
||||
|
||||
var XpuErrMsg2 = map[string]string{
|
||||
"REQUEST_HEADER_ERROR": "请求头错误",
|
||||
"REQUEST_PARAM_INVALID": "参数不合法",
|
||||
"REQUEST_SIGN_FAILED": "参数签名失败",
|
||||
"REQUEST_USER_NOT_REGISTER": "用户未注册",
|
||||
"SN_USER_NOT_MATCH": "打印机编号和用户不匹配",
|
||||
"PRINTER_NOT_REGISTER": "打印机未注册",
|
||||
"PRINTER_OFFLINE": "打印机不在线",
|
||||
"ADD_ORDER_FAILED": "添加订单失败",
|
||||
"ORDER_NOT_FOUND": "未找到订单信息",
|
||||
"ORDER_DATE_INVALID": "订单日期格式或大小不正确",
|
||||
"PRINT_CONTENT_MORE_THAN_12K_BYTES": "打印内容不能超过12K",
|
||||
"PRINTER_RECORD_LOCK_FAIL": "用户修改打印机记录失败",
|
||||
"SN_OR_NAME_EMPTY": "用户添加打印机时,打印机编号或名称不能为空",
|
||||
"PRINTER_NUMBER_INVALID": "打印机设备编号无效",
|
||||
"PRINTER_EXIST": "打印机已存在",
|
||||
"PRINTER_EXCEPTION": "添加打印设备失败",
|
||||
"ORDER_IDEMPOTENT": "打印订单时触发幂等性",
|
||||
"ORDER_IDEMPOTENT_LIMITLEN": "幂等因子过长",
|
||||
"LOGO_FORMAT_ERROR": "LOGO文件格式错误",
|
||||
"LOGO_SIZE_LARGE": "LOGO文件超出规定范围",
|
||||
"LOGO_UPLOAD_TIMES": "LOGO上传次数超限制",
|
||||
"LOGO_DELETE_NO_EXIST": "LOGO删除失败",
|
||||
"LABEL_MODE_ERROR": "LOGO上传模式错误",
|
||||
}
|
||||
var XpuErrMsg = map[string]string{
|
||||
"1001": "打印机编号和用户不匹配",
|
||||
"1002": "打印机未注册,尚未添加至云平台",
|
||||
"1003": "打印机不在线",
|
||||
"1004": "添加订单失败",
|
||||
"1005": "未找到订单信息",
|
||||
"1006": "订单日期格式或大小不正确",
|
||||
"1007": "打印内容不能超过12K",
|
||||
"1008": "用户修改打印机记录失败",
|
||||
"1009": "用户添加打印机时,打印机编号或名称不能为空",
|
||||
"1010": "打印机设备编号无效",
|
||||
"1011": "打印机已存在",
|
||||
"1012": "添加打印设备失败",
|
||||
"1013": "打印订单时触发幂等性",
|
||||
"1014": "幂等因子过长",
|
||||
"1016": "LOGO文件格式错误",
|
||||
"1017": "LOGO文件超出规定范围",
|
||||
"1018": "LOGO上传次数超限制",
|
||||
"1020": "LOGO删除失败",
|
||||
"1021": "LOGO上传模式错误",
|
||||
}
|
||||
|
||||
const (
|
||||
//声音类型 v10版本
|
||||
VoiceTypeV10PersonBig = 0 //真人语音 大
|
||||
VoiceTypeV10PersonMedium = 1 //真人语音 中
|
||||
VoiceTypeV10PersonSmall = 2 //真人语音 小
|
||||
VoiceTypeV10DiDi = 3 //滴滴声
|
||||
VoiceTypeV10Mute = 4 //静音
|
||||
|
||||
//声音类型 其他固件版本
|
||||
VoiceTypeOtherPerson = 0 //真人语音
|
||||
VoiceTypeOtherDiDi = 3 //滴滴声
|
||||
VoiceTypeOtherMute = 4 //静音
|
||||
|
||||
//声音大小,打印机固件版本为非V10.xx的机器支持此参数
|
||||
VolumeLevelBig = 0 //大
|
||||
VolumeLevelMedium = 1 //中
|
||||
VolumeLevelSmall = 2 //小
|
||||
VolumeLevelClose = 3 //关闭
|
||||
|
||||
//切刀控制开关,默认为0,仅用于支持切刀的芯烨云打印机
|
||||
CutterOpen = 0 //开启云端默认设置控制切刀
|
||||
CutterClose = 1 //关闭云端切刀
|
||||
|
||||
//声音播放模式:0-取消订单模式,1-静音模式,2-来单播放模式(默认),3-播报退单语音,4-播报美团来单语音,5-播报饿了么来单语音
|
||||
VoiceCancelOrder = 0 //取消订单模式
|
||||
VoiceMute = 1 //静音模式
|
||||
VoicePlayOrder = 2 //来单播放模式
|
||||
VoiceUserChargeback = 3 //用户申请退单模式
|
||||
VoiceMT = 4 //播报美团来单语音
|
||||
VoiceELM = 5 //播报饿了么来单语音
|
||||
|
||||
//打印模式 默认0
|
||||
ModeCheckYes = 1 //不检查打印机是否在线,直接生成打印订单,并返回打印订单号。如果打印机不在线,订单将缓存在打印队列中,打印机正常在线时会自动打印
|
||||
ModeCheckNo = 0 //或不指定则会检查打印机是否在线,如果不在线 则不生成打印订单,直接返回设备不在线状态码;如果在线则生成打印订单,并返回打印订单号
|
||||
//默认订单过期时间
|
||||
ExpiresInDefault = 86399 //秒
|
||||
//支付方式41-55
|
||||
PayTypeZFB = 41 //支付宝
|
||||
PayTypeWX = 42 //微信
|
||||
PayTypeYunZF = 43 //云支付
|
||||
PayTypeYLCard = 44 //银联刷卡
|
||||
PayTypeYLPay = 45 //银联支付
|
||||
PayTypeMemberCardPay = 46 //会员卡消费
|
||||
PayTypeMemberCardCharge = 47 //会员卡充值
|
||||
PayTypeYiZF = 48 //翼支付
|
||||
PayTypePaymentSuccess = 49 //成功收款
|
||||
PayTypeJLZF = 50 //嘉联支付
|
||||
PayTypeYQB = 51 //壹钱包
|
||||
PayTypeJDZF = 52 //京东支付
|
||||
PayTypeKQZF = 53 //快钱支付
|
||||
PayTypeWZF = 54 //威支付
|
||||
PayTypeXQZF = 55 //享钱支付
|
||||
|
||||
//支付与否
|
||||
PayModeDrawback = 59 //退款
|
||||
PayModeReceipt = 60 //到账
|
||||
PayModeConsume = 61 //消费
|
||||
|
||||
//打印机状态
|
||||
PrinterStateOffline = 0 //离线
|
||||
PrinterStateOnlineNormal = 1 //在线正常
|
||||
PrinterStateOnlineUnusual = 2 //在线异常
|
||||
PrinterStateError = -1 //获取状态出错
|
||||
|
||||
)
|
||||
|
||||
var (
|
||||
//打印机状态说明
|
||||
PrinterStatus = map[float64]string{
|
||||
PrinterStateOffline: "离线",
|
||||
PrinterStateOnlineNormal: "在线正常",
|
||||
PrinterStateOnlineUnusual: "在线异常",
|
||||
PrinterStateError: "获取状态出错",
|
||||
}
|
||||
)
|
||||
|
||||
//请求参数
|
||||
type RestRequest struct {
|
||||
User string `json:"user"` //开发者ID(芯烨云后台登录账号)
|
||||
UserKey string `json:"-"` //芯烨云后台开发者密钥
|
||||
Timestamp int64 `json:"timestamp"` //当前UNIX时间戳,10位,精确到秒
|
||||
Sign string `json:"sign"` //对参数 user + UKEY + timestamp 拼接后(+号表示连接符)进行SHA1加密得到签名,值为40位小写字符串
|
||||
Debug int `json:"debug"` //debug=1返回非json格式的数据。仅测试时候使用
|
||||
}
|
||||
|
||||
//响应参数
|
||||
type XPYunResp struct {
|
||||
HttpStatusCode int `json:"httpStatusCode"`
|
||||
Content *XPYunRespContent `json:"content"`
|
||||
}
|
||||
type XPYunRespContent struct {
|
||||
Code int `json:"code"`
|
||||
Msg string `json:"msg"`
|
||||
Data interface{} `json:"data,omitempty"`
|
||||
ServerExecutedTime int `json:"serverExecutedTime"`
|
||||
}
|
||||
|
||||
type AddPrinterRequestItem struct {
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
Name string `json:"name,omitempty"` //打印机名称
|
||||
}
|
||||
|
||||
// 添加打印机到开发者账户(可批量)
|
||||
type AddPrinterRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Items []*AddPrinterRequestItem `json:"items"`
|
||||
}
|
||||
|
||||
//设置打印机语音类型
|
||||
type SetVoiceTypeRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
VoiceType int `json:"voiceType"` //声音类型:打印机固件版本为V10.xx的机器取值: 0真人语音(大) 1真人语音(中) 2真人语音(小) 3 嘀嘀声 4 静音;其它固件版本的机器取值:0真人语音 3 嘀嘀声 4 静音
|
||||
VolumeLevel int `json:"volumeLevel"` //声音大小:0大 1中 2小 3关闭,说明:打印机固件版本为非V10.xx的机器支持此参数
|
||||
}
|
||||
|
||||
//打印小票订单
|
||||
type PrintRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
Content string `json:"content"` //打印内容,不能超过12k字节
|
||||
//非必填
|
||||
Copies int `json:"copies,omitempty"` //打印份数,默认为1,取值[1-65535]
|
||||
Cutter int `json:"cutter,omitempty"` //是否支持切刀自定义控制 0采用默认切刀 1采用自定义控制切刀
|
||||
Voice int `json:"voice,omitempty"` //声音播放模式,0-取消订单模式,1-静音模式,2-来单播放模式(默认),3-播报退单语音,4-播报美团来单语音,5-播报饿了么来单语音
|
||||
Mode int `json:"mode,omitempty"` //打印模式,默认为0
|
||||
ExpiresIn int `json:"expiresIn,omitempty"` //订单有效期 单位:秒 取值范围为:0<订单失效时间<24*60*60,使用该参数时,需要将参数mode 设置为1
|
||||
BackurlFlag int `json:"backurlFlag,omitempty"` //回调地址对应标识,必须先在管理后台设置,否则无效
|
||||
PayType int `json:"payType,omitempty"` //41~55: 支付宝 41、微信 42、云支付 43、银联刷卡 44、银联支付 45、会员卡消费 46、会员卡充值 47、翼支付 48、成功收款 49、嘉联支付 50、壹钱包 51、京东支付 52、快钱支付 53、威支付 54、享钱支付 55
|
||||
PayMode int `json:"payMode,omitempty"` //59~61: 退款 59 到账 60 消费 61
|
||||
Money float64 `json:"money,omitempty"` //支付金额 允许保留2位小数
|
||||
}
|
||||
|
||||
//打印标签订单
|
||||
type PrintLabelRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
Content string `json:"content"` //打印内容,不能超过12k字节
|
||||
//非必填
|
||||
Copies int `json:"copies,omitempty"` //打印份数,默认为1,取值[1-65535]
|
||||
Voice int `json:"voice,omitempty"` //声音播放模式,0-取消订单模式,1-静音模式,2-来单播放模式(默认),3-播报退单语音,4-播报美团来单语音,5-播报饿了么来单语音
|
||||
Mode int `json:"mode,omitempty"` //打印模式,默认为0
|
||||
ExpiresIn int `json:"expiresIn,omitempty"` //订单有效期 单位:秒 取值范围为:0<订单失效时间<24*60*60,使用该参数时,需要将参数mode 设置为1
|
||||
BackurlFlag int `json:"backurlFlag,omitempty"` //回调地址对应标识,必须先在管理后台设置,否则无效
|
||||
PayType int `json:"payType,omitempty"` //41~55: 支付宝 41、微信 42、云支付 43、银联刷卡 44、银联支付 45、会员卡消费 46、会员卡充值 47、翼支付 48、成功收款 49、嘉联支付 50、壹钱包 51、京东支付 52、快钱支付 53、威支付 54、享钱支付 55
|
||||
PayMode int `json:"payMode,omitempty"` //59~61: 退款 59 到账 60 消费 61
|
||||
Money float64 `json:"money,omitempty"` //支付金额 允许保留2位小数
|
||||
}
|
||||
|
||||
//删除打印机
|
||||
type DelPrinterRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
SnList []string `json:"snlist"` //打印机编号集合
|
||||
}
|
||||
|
||||
//修改打印机信息
|
||||
type UpdPrinterRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
Name string `json:"name,omitempty"` //打印机名称
|
||||
//非必填
|
||||
CardNo string `json:"cardno"` //打印机流量卡号码
|
||||
}
|
||||
|
||||
//清空待打印队列
|
||||
type EmpPrinterQueueRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
}
|
||||
|
||||
// 查询订单状态
|
||||
type QueryOrderStateRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
OrderId string `json:"orderId"` //订单编号,由“打印订单”接口返回
|
||||
}
|
||||
|
||||
//查询指定打印机某天的订单统计数
|
||||
type QueryOrderStatisRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
Date string `json:"date"` //查询日期,格式YY-MM-DD,如:2016-09-20
|
||||
}
|
||||
|
||||
//获取指定打印机状态
|
||||
type QueryPrinterStatusRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
}
|
||||
|
||||
//批量查询打印机状态
|
||||
type QueryPrintersStatusRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
SnList []string `json:"snlist"` //打印机编号集合,一次最多20台
|
||||
}
|
||||
|
||||
//金额播报 仅用于支持金额播报的芯烨云打印机
|
||||
type PlayVoiceRequest struct {
|
||||
RestRequest `json:",inline"`
|
||||
Sn string `json:"sn"` //打印机编号
|
||||
//非必填
|
||||
PayType int `json:"payType"` //支付方式41~55
|
||||
PayMode int `json:"payMode"` //支付与否59~61:退款 59 到账 60 消费 61
|
||||
Money float64 `json:"money"` //支付金额,允许保留2位小数
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user