This commit is contained in:
邹宗楠
2025-09-12 16:23:59 +08:00
parent 641329db6d
commit c4f6462945
11 changed files with 189 additions and 16 deletions

View File

@@ -22,8 +22,10 @@ const (
CmdShopUnbindMsg = "shop.unbind.msg"
//IM消息回调通知
CmdImMessageSendEvent = "im.message.send.event" //用户/骑手消息通知
CmdImMessageReadEvent = "im.message.read.event" //用户/骑手已读通知
CmdImMessageSendEvent = "im.message.send.event" // 用户/骑手消息通知
CmdImMessageReadEvent = "im.message.read.event" // 用户/骑手已读通知
CmdImInvoicApply = "invoice.apply.push" // 用户发送发票申请
CmdImInvoicEmail = "invoice.email.push" // 发票用户重发邮件
)

View File

@@ -0,0 +1,114 @@
package ebaiapi
import (
"fmt"
"git.rosy.net.cn/baseapi/utils"
)
// UploadInvoice 上传发票回复
func (a *API) UploadInvoice(baiduShopId, applicationNo, fileUrl string) (*UploadInvoiceResult, error) {
param := &UpdateInvoice{
BaiduShopId: baiduShopId,
ShopId: "",
RequestList: nil,
}
requestList := make([]ApplicationList, 0, 0)
requestList = append(requestList, ApplicationList{
ApplicationNo: applicationNo,
Status: "",
InvoiceList: nil,
FileUrl: fileUrl,
InvoiceClass: "",
InvoiceCode: "",
InvoiceDate: "",
InvoiceMaterial: "",
InvoiceNo: "",
Memo: "",
LineList: nil,
MachineCode: "",
SellerInfo: SellerInfo{},
TaxAmount: "",
ValidationCode: "",
})
param.RequestList = requestList
data, err := a.AccessAPI("invoice.apply.batchUpdate", utils.Struct2Map(param, "", false))
if err != nil {
return nil, err
}
if data.ErrNo != 0 {
return nil, fmt.Errorf(data.Error)
}
result := &UploadInvoiceResult{}
if err = utils.UnmarshalUseNumber(utils.MustMarshal(data.Data), result); err != nil {
return nil, err
}
return result, nil
}
type UploadInvoiceResult struct {
SuccessfulApplicationNoList []string `json:"successful_application_no_list"`
FailedApplicationNoList []string `json:"failed_application_no_list"`
}
// UpdateInvoice 申请
type UpdateInvoice struct {
BaiduShopId string `json:"baidu_shop_id"`
ShopId string `json:"shop_id"`
RequestList []ApplicationList `json:"request_list"`
}
type ApplicationList struct {
ApplicationNo string `json:"application_no"`
Status string `json:"status"`
InvoiceList []InvoiceList `json:"buyer_title"`
FileUrl string `json:"file_url"`
InvoiceClass string `json:"invoice_class"`
InvoiceCode string `json:"invoice_code"`
InvoiceDate string `json:"invoice_date"`
InvoiceMaterial string `json:"invoice_material"`
InvoiceNo string `json:"invoice_no"`
Memo string `json:"memo"`
LineList []LineList `json:"line_list"`
MachineCode string `json:"machine_code"`
SellerInfo SellerInfo `json:"seller_info"`
TaxAmount string `json:"tax_amount"`
ValidationCode string `json:"validation_code"`
}
type InvoiceList struct {
AmountWithTax float64 `json:"amount_with_tax"`
AmountWithoutTax float64 `json:"amount_without_tax"`
BuyerTitle struct {
BankAccount string `json:"bank_account"`
BankName string `json:"bank_name"`
RegisterAddress string `json:"register_address"`
RegisterPhone string `json:"register_phone"`
TaxPayerNum string `json:"tax_payer_num"`
TitleName string `json:"title_name"`
TitleType string `json:"title_type"`
}
}
type LineList struct {
AmountWithoutTax float64 `json:"amount_without_tax"`
CargoName string `json:"cargo_name"`
CargoNo string `json:"cargo_no"`
Quantity int `json:"quantity"`
Specification string `json:"specification"`
TaxAmount int `json:"tax_amount"`
TaxRate float64 `json:"tax_rate"`
Unit string `json:"unit"`
UnitPrice float64 `json:"unit_price"`
}
type SellerInfo struct {
BankAccount string `json:"bank_account"`
BankName string `json:"bank_name"`
Checker string `json:"checker"`
Clerk string `json:"clerk"`
Name string `json:"name"`
Payee string `json:"payee"`
RegisterAddress string `json:"register_address"`
RegisterPhone string `json:"register_phone"`
TaxPayerNum string `json:"tax_payer_num"`
}

View File

@@ -2,6 +2,7 @@ package ebaiapi
import (
"fmt"
"git.rosy.net.cn/jx-callback/globals"
"regexp"
"strings"
@@ -327,6 +328,7 @@ func (a *API) SkuCreate(trackInfo, shopID string, customSkuID int64, params map[
KeyShopID: shopID,
KeyCustomSkuID: customSkuID,
}
globals.SugarLogger.Debugf("----SkuCreate,params1 -- : %s", utils.Format4Output(params, false))
if params["upc"] == nil {
defParams["upc"] = "upc-" + utils.Int2Str(int(customSkuID))
}
@@ -337,6 +339,7 @@ func (a *API) SkuCreate(trackInfo, shopID string, customSkuID int64, params map[
defParams["brand_name"] = "无" // 很狗血的是,你还必须填个无才行。。。
}*/
params = utils.MergeMaps(params, defParams)
globals.SugarLogger.Debugf("----SkuCreate,params2 -- : %s", utils.Format4Output(params, false))
result, err := a.AccessAPI2("sku.create", params, trackInfo)
if err == nil && result.Data != nil {
return utils.Interface2Int64WithDefault(result.Data.(map[string]interface{})[KeySkuID], 0), nil

View File

@@ -328,7 +328,7 @@ func TestDeleteStoreSku(t *testing.T) {
}
func TestDeleteSku(t *testing.T) {
shopId := "669283"
shopId := "667410"
param1 := &SkuListParams{
Page: 1,
PageSize: 100,

View File

@@ -1,6 +1,7 @@
package mtwmapi
import (
"git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/jx-callback/globals"
"testing"
"time"
@@ -8,7 +9,7 @@ import (
func TestBillList(t *testing.T) {
now := time.Now()
from := time.Date(now.Year(), now.Month(), now.Day()-2, 0, 0, 0, 0, time.Local)
from := time.Date(now.Year(), now.Month(), now.Day()-5, 0, 0, 0, 0, time.Local)
to := time.Date(now.Year(), now.Month(), now.Day()-2, 23, 59, 59, 59, time.Local)
param := &Bill{
AppPoiCode: "4418003",
@@ -19,13 +20,13 @@ func TestBillList(t *testing.T) {
AccessToken: api.token,
}
_, _, _, err := api.GetStoreBillList(param)
_, fine, _, err := api.GetStoreBillList(param)
if err != nil {
globals.SugarLogger.Debugf("err := %v", err)
return
}
//globals.SugarLogger.Debugf("settleId := %d", settleId)
globals.SugarLogger.Debugf("settleId := %s", utils.Format4Output(fine, false))
//for _, v := range data {
// globals.SugarLogger.Debugf("OrderId : %s , TimingFee : %d , DeliveryFee : %d , PlatformSettlement : %d ", v.OrderId, v.TimingFee, v.DeliveryFee, v.PlatformSettlement)
//}

View File

@@ -77,14 +77,14 @@ func TestRdbSet(t *testing.T) {
func TestSendMsg(t *testing.T) {
data := PushContentReq{
AppID: 589,
AppPoiCode: "7290541",
MsgID: 1729566539763500,
MsgContent: "cqH27xu/6vS+eqmykE39nA==",
AppPoiCode: "29066882",
MsgID: 175758059520401,
MsgContent: "v+JsErdWUcxwSLVPfXgw7+0chcSyHbInTQOgcOGGLaGnb92NO9Iut8rgpGDQbvYYjjPzX7XCcEud/ECwcZskl+HoQF6Qa+La1++qGurBov0=",
MsgSource: 1,
MsgType: 1,
MsgType: 2,
Cts: int(time.Now().Unix()),
OrderID: 3801305470340611516,
OpenUserID: 9548822498,
OrderID: 0,
OpenUserID: 9020915181,
}
dataMar, err := json.Marshal(data)
fmt.Println(string(dataMar))

View File

@@ -48,7 +48,6 @@ func (a *API) UploadInvoice(orderId, invoiceUrl, invoiceId, taskId string) (err
for _, v := range resp.(map[string]interface{})["error_list"].([]interface{}) {
errMsg = append(errMsg, v.(map[string]interface{})["msg"].(string))
}
}
return fmt.Errorf("%s", strings.Join(errMsg, ","))
}

View File

@@ -5,6 +5,7 @@ import (
"crypto/md5"
"fmt"
"git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/jx-callback/globals"
"mime/multipart"
"net/http"
"net/url"
@@ -149,7 +150,7 @@ func (a *API) AccessAPI2(cmd string, isGet bool, bizParams map[string]interface{
}
signURL := a.genURL(cmd) + "?"
params[signKey] = a.signParams(signURL, params)
//globals.SugarLogger.Debugf("test mtCancelAct cmd=%s sig=%s", cmd, utils.Format4Output(params, false))
globals.SugarLogger.Debugf("-----sing := %s", params[signKey].(string))
err = platformapi.AccessPlatformAPIWithRetry(a.client,
func() *http.Request {
var request *http.Request

View File

@@ -20,10 +20,10 @@ func init() {
baseapi.Init(sugarLogger)
// 菜市
//api = New("589", "a81eb3df418d83d6a1a4b7c572156d2f", "", "")
api = New("589", "a81eb3df418d83d6a1a4b7c572156d2f", "", "")
// 果园
api = New("4123", "df2c88338b85f830cebce2a9eab56628", "", "")
//api = New("4123", "df2c88338b85f830cebce2a9eab56628", "", "")
//商超
//api = New("5873", "41c479790a76f86326f89e8048964739", "", "token_nld07Y5m8rEQZJMMrvZGmA")

View File

@@ -1,6 +1,7 @@
package mtwmapi
import (
"encoding/json"
"git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/jx-callback/globals"
"regexp"
@@ -471,6 +472,52 @@ type CategoryAttrValueListResult struct {
Value string `json:"value"`
}
// RetailProductRules 根据末级美团分类ID获取图片发布规则
func (a *API) RetailProductRules(tagID int64) (*ProductRulesObj, error) {
result, err := a.AccessAPI2("retail/product/rules", true, map[string]interface{}{
"tag_id": tagID,
}, "success_map", "")
if err != nil {
return nil, err
}
rules := &ProductRulesObj{}
if result != nil {
resultByte, _ := json.Marshal(result)
err = utils.UnmarshalUseNumber(resultByte, rules)
if err != nil {
return nil, err
}
}
return rules, err
}
type ProductRulesObj struct {
StructRules []struct {
RuleId int `json:"rule_id"`
RuleName string `json:"rule_name"`
ValueList []struct {
IsByDefault bool `json:"is_by_default"`
ValueId int `json:"value_id"`
ValueName string `json:"value_name"`
} `json:"value_list"`
} `json:"struct_rules"`
UnstructRules struct {
QualificationPicturesRule struct {
IsQualificationPicturesNeed int `json:"is_qualification_pictures_need"`
} `json:"qualification_pictures_rule"`
SpecialPicturesRules []struct {
IsDisplayed int `json:"is_displayed"`
IsRequired int `json:"is_required"`
NumLimit int `json:"num_limit"`
SpecialPictureDescription string `json:"special_picture_description"`
SpecialPictureExample string `json:"special_picture_example"`
SpecialPictureTitle string `json:"special_picture_title"`
SpecialPictureType int `json:"special_picture_type"`
} `json:"special_pictures_rules"`
} `json:"unstruct_rules"`
}
//category/attr/value/list 查询特殊属性的属性值列表
//https://open-shangou.meituan.com/home/docDetail/387
func (a *API) CategoryAttrValueList(attr_id int64, keyword string) (categoryAttrValueListResult []*CategoryAttrValueListResult, err error) {

View File

@@ -462,3 +462,9 @@ func TestDeleteCat(t *testing.T) {
}
}
func TestRetailProductRules(t *testing.T) {
result, err := api.RetailProductRules(200002538)
t.Log(utils.Format4Output(result, false))
t.Log(err)
}