Compare commits
76 Commits
fix-holida
...
master
Author | SHA1 | Date |
---|---|---|
Minh Nguyen | 9c48edf1e3 | |
Nguyen Minh | 78194a2d43 | |
sinhluu | 0f40121bf7 | |
Minh Nguyen | de84fdc2bf | |
Minh Nguyen | 72d45ed239 | |
Nguyen Minh | a4a6f31ec6 | |
Nguyen Minh | 7ab8f1f3a5 | |
Nguyen Minh | ff223e2b46 | |
Sinh | 2b0d33efc2 | |
Sinh | dfdccfa86a | |
sinhluu | 1384cae433 | |
sinhluu | c82bf48503 | |
Minh Nguyen | 2e5a5b5f0f | |
Nguyen Minh | 2d04611fee | |
Sinh | 1d0b13285a | |
Minh Nguyen | 2b9092ecbe | |
Sinh | fd41b1eadf | |
Sinh | 9004771704 | |
Sinh | 524db8391f | |
sinhluu | 546c45aad4 | |
Sinh | 3a5046f65d | |
Sinh | c6284f3200 | |
Nguyen Minh | 02b699f144 | |
Sinh | a409c0d17c | |
sinhluu | 5edec97ee3 | |
Sinh | 430e07b7d0 | |
Sinh | 7302b78f25 | |
Sinh | e84157281b | |
Sinh | 28178e0c31 | |
Sinh | b3bde5cd09 | |
kingphon | 2ba590a0a0 | |
kingphon | a62eeb60d2 | |
kingphon | 31a13546bb | |
kingphon | b240d7a9d1 | |
kingphon | f58dfd4291 | |
kingphon | ba8af50460 | |
kingphon | 8dd914ca4e | |
trunglam | 10aec9f710 | |
trunglt251292 | 1c7e947344 | |
sinhluu | 898ee7822f | |
sinhluu | 1ca2e5720e | |
Sinh | 202dca2c28 | |
Sinh | 1579e563ac | |
Sinh | a432e7fd44 | |
Sinh | 041dd43616 | |
Minh Nguyen | aaf8de9830 | |
Nguyen Minh | 9c2f55e434 | |
Nguyen Minh | 8ed19af4ea | |
Nguyen Minh | 985a86dbd7 | |
Nguyen Minh | afd6b215d6 | |
Minh Nguyen | d6f50295c7 | |
sinhluu | 983731715b | |
Sinh | d03758a32d | |
Nguyen Minh | 71d674b74c | |
Nguyen Minh | 41b79b4ae8 | |
sinhluu | 53b2215309 | |
Nguyen Minh | ffe9418671 | |
Nguyen Minh | 7b01640583 | |
Sinh | 2e069b94e7 | |
Sinh | aee7b01b40 | |
tuannt20 | 2f64f1fa37 | |
tuannt20 | a1d6840fd9 | |
Nguyen Minh | 0401a57930 | |
Nguyen Minh | 79ad5c401c | |
trunglam | e64ba040b0 | |
quang | dba7cf4691 | |
sinhluu | 0269010ce8 | |
Sinh | 4c328c0858 | |
trunglam | 6626bc8588 | |
Sinh | df1fbbcf57 | |
Sinh | 1edc683dd5 | |
Sinh | e7888e2c4c | |
Sinh | 252c82f1e4 | |
Sinh | e66596baf6 | |
Sinh | b19fea04c8 | |
Sinh | 46539db236 |
|
@ -38,6 +38,27 @@ func (l Location) GetLocationByCode(payload model.LocationRequestPayload) (*mode
|
|||
return r.Data, nil
|
||||
}
|
||||
|
||||
// GetLocationByWardCode ...
|
||||
func (l Location) GetLocationByWardCode(payload model.RequestCondition) (*model.ResponseLocationAddress, error) {
|
||||
msg, err := natsio.GetServer().Request(subject.Location.GetLocationByWardCode, toBytes(payload))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var r struct {
|
||||
Data *model.ResponseLocationAddress `json:"data"`
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if r.Error != "" {
|
||||
return nil, errors.New(r.Error)
|
||||
}
|
||||
return r.Data, nil
|
||||
}
|
||||
|
||||
// GetProvincesByCodes ...
|
||||
func (l Location) GetProvincesByCodes(p model.ProvinceRequestPayload) (*model.LocationProvinceResponse, error) {
|
||||
msg, err := natsio.GetServer().Request(subject.Location.GetProvincesByCodesFromLocationService, toBytes(p))
|
||||
|
|
|
@ -119,3 +119,22 @@ func (o Order) GetSupplierOrders(p model.OrderSupplierQuery) (*model.SupplierOrd
|
|||
}
|
||||
return &r.Data, nil
|
||||
}
|
||||
|
||||
// GetUserTotalWarningOrder ...
|
||||
func (o Order) GetUserTotalWarningOrder(p model.OrderGetTotalWarningPayload) (*model.OrderGetTotalWarningRes, error) {
|
||||
msg, err := natsio.GetServer().Request(subject.Order.GetUserTotalWarningOrders, toBytes(p))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
var r struct {
|
||||
Data model.OrderGetTotalWarningRes `json:"data"`
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return nil, errors.New(r.Error)
|
||||
}
|
||||
return &r.Data, nil
|
||||
}
|
||||
|
|
|
@ -0,0 +1,86 @@
|
|||
package client
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
|
||||
"git.selly.red/Selly-Modules/natsio"
|
||||
"git.selly.red/Selly-Modules/natsio/model"
|
||||
"git.selly.red/Selly-Modules/natsio/subject"
|
||||
)
|
||||
|
||||
// Product ...
|
||||
type Product struct{}
|
||||
|
||||
// GetProduct ...
|
||||
func GetProduct() Product {
|
||||
return Product{}
|
||||
}
|
||||
|
||||
func (c Product) ApplyRequest(p model.ProductApplyRequestPayload) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Product.ApplyRequest, toBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c Product) CreateRequestSteps(p model.ProductCreateStepsPayload) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Product.CreateRequestStep, toBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c Product) ProcessApplyRequest(p model.ProductApplyRequestPayload) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Product.ProcessApplyRequest, toBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c Product) RequestChangeStatus(p model.ProductRequestChangeStatus) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Product.RequestChangeStatus, toBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
|
@ -0,0 +1,35 @@
|
|||
package client
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
|
||||
"git.selly.red/Selly-Modules/natsio"
|
||||
"git.selly.red/Selly-Modules/natsio/model"
|
||||
"git.selly.red/Selly-Modules/natsio/subject"
|
||||
)
|
||||
|
||||
// Queue ...
|
||||
type Queue struct{}
|
||||
|
||||
// GetQueue ...
|
||||
func GetQueue() Queue {
|
||||
return Queue{}
|
||||
}
|
||||
|
||||
func (c Queue) ScheduleTask(p model.QueueScheduleTaskRequest) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Queue.ScheduleTask, toBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
|
@ -0,0 +1,27 @@
|
|||
package client
|
||||
|
||||
import (
|
||||
"git.selly.red/Selly-Modules/natsio"
|
||||
"git.selly.red/Selly-Modules/natsio/model"
|
||||
"git.selly.red/Selly-Modules/natsio/subject"
|
||||
)
|
||||
|
||||
// Socket ...
|
||||
type Socket struct{}
|
||||
|
||||
// GetSocket ...
|
||||
func GetSocket() Socket {
|
||||
return Socket{}
|
||||
}
|
||||
|
||||
// EmitSocketEventDataReward ...
|
||||
func (s Socket) EmitSocketEventDataReward(p model.PayloadEmitSocketEvent) error {
|
||||
_, err := natsio.GetServer().Request(subject.Socket.EmitEventReward, toBytes(p))
|
||||
return err
|
||||
}
|
||||
|
||||
// EmitEventToUser ...
|
||||
func (s Socket) EmitEventToUser(p model.PayloadEmitSocketEvent) error {
|
||||
_, err := natsio.GetServer().Request(subject.Socket.EmitEventToUser, toBytes(p))
|
||||
return err
|
||||
}
|
|
@ -146,6 +146,25 @@ func (w Warehouse) GetConfigByWarehouseID(warehouseID string) (*model.WarehouseC
|
|||
return r.Data, nil
|
||||
}
|
||||
|
||||
// GetListConfig ...
|
||||
func (w Warehouse) GetListConfig(req model.GetListWarehouseConfigReq) ([]*model.WarehouseConfiguration, error) {
|
||||
msg, err := natsio.GetServer().Request(subject.Warehouse.GetListWarehouseConfig, toBytes(req))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
var r struct {
|
||||
Data []*model.WarehouseConfiguration `json:"data"`
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return nil, errors.New(r.Error)
|
||||
}
|
||||
return r.Data, nil
|
||||
}
|
||||
|
||||
// GetWarehouses ...
|
||||
func (w Warehouse) GetWarehouses(p model.GetWarehousesRequest) (*model.GetWarehousesResponse, error) {
|
||||
msg, err := natsio.GetServer().Request(subject.Warehouse.GetWarehouses, toBytes(p))
|
||||
|
@ -202,3 +221,23 @@ func (w Warehouse) UpdateStatusWarehousePendingInactive(p model.UpdateStatusWare
|
|||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// UpdateIsSellyMall ...
|
||||
func (w Warehouse) UpdateIsSellyMall(p model.UpdateIsSellyMallRequest) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Warehouse.UpdateIsSellyMall, toBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return fmt.Errorf("nats: update_is_selly_mall %v", err)
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
|
@ -3,6 +3,7 @@ package client
|
|||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
|
||||
"git.selly.red/Selly-Modules/natsio"
|
||||
"git.selly.red/Selly-Modules/natsio/model"
|
||||
"git.selly.red/Selly-Modules/natsio/subject"
|
||||
|
@ -83,3 +84,39 @@ func (w Warehouse) FindByCondition(p model.FindWithCondition) ([]*model.Warehous
|
|||
}
|
||||
return r.Data, nil
|
||||
}
|
||||
|
||||
// UpdateWarehouseConfig ...
|
||||
func (w Warehouse) UpdateWarehouseConfig(p model.UpdatePayload) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Warehouse.UpdateWarehouseConfig, bsonToBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// BulkWriteWarehouseConfig ...
|
||||
func (w Warehouse) BulkWriteWarehouseConfig(p model.UpdatePayload) error {
|
||||
msg, err := natsio.GetServer().Request(subject.Warehouse.BulkWriteWarehouseConfig, bsonToBytes(p))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var r struct {
|
||||
Error string `json:"error"`
|
||||
}
|
||||
if err = json.Unmarshal(msg.Data, &r); err != nil {
|
||||
return err
|
||||
}
|
||||
if r.Error != "" {
|
||||
return errors.New(r.Error)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
|
@ -2,11 +2,17 @@ package jsconsumer
|
|||
|
||||
// Selly ...
|
||||
var Selly = struct {
|
||||
PushNotification string
|
||||
UpdateSellerAffiliateStatistic string
|
||||
CheckAnDInsertCashflowBySeller string
|
||||
PushNotification string
|
||||
UpdateSellerAffiliateStatistic string
|
||||
CheckAnDInsertCashflowBySeller string
|
||||
SubscriberTopic string
|
||||
UpdateSellerSavingCampaignStatistic string
|
||||
GenerateVoucherPromotion string
|
||||
}{
|
||||
PushNotification: "PULL_PUSH_NOTIFICATION",
|
||||
UpdateSellerAffiliateStatistic: "PULL_UPDATE_SELLER_AFFILIATE_STATISTIC",
|
||||
CheckAnDInsertCashflowBySeller: "PULL_CHECK_AND_INSERT_CASHFLOW_BY_SELLER",
|
||||
PushNotification: "PULL_PUSH_NOTIFICATION",
|
||||
UpdateSellerAffiliateStatistic: "PULL_UPDATE_SELLER_AFFILIATE_STATISTIC",
|
||||
CheckAnDInsertCashflowBySeller: "PULL_CHECK_AND_INSERT_CASHFLOW_BY_SELLER",
|
||||
SubscriberTopic: "PULL_SUBSCRIBER_TOPIC",
|
||||
UpdateSellerSavingCampaignStatistic: "PULL_UPDATE_SELLER_SAVING_CAMPAIGN_STATISTIC",
|
||||
GenerateVoucherPromotion: "PULL_GENERATE_VOUCHER_PROMOTION",
|
||||
}
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
package jsmodel
|
||||
|
||||
import "go.mongodb.org/mongo-driver/bson/primitive"
|
||||
|
||||
// PushNotification ...
|
||||
type PushNotification struct {
|
||||
User string `json:"user"`
|
||||
|
@ -12,9 +14,11 @@ type PushNotification struct {
|
|||
|
||||
// NotificationOptions ...
|
||||
type NotificationOptions struct {
|
||||
Title string `json:"title"`
|
||||
Content string `json:"content"`
|
||||
CampaignID string `json:"campaignId,omitempty"`
|
||||
Title string `json:"title"`
|
||||
Content string `json:"content"`
|
||||
CampaignID string `json:"campaignId,omitempty"`
|
||||
SellerSavingCampaignID string `json:"sellerSavingCampaignId,omitempty"`
|
||||
SellerSavingCampaignStatus string `json:"sellerSavingCampaignStatus,omitempty"`
|
||||
}
|
||||
|
||||
// PayloadUpdateSellerAffiliateStatistic ...
|
||||
|
@ -62,4 +66,45 @@ type CashFlowOptions struct {
|
|||
// Campaign
|
||||
CampaignID string `json:"campaignId,omitempty"`
|
||||
CampaignName string `json:"campaignName,omitempty"`
|
||||
|
||||
// SavingCampaign
|
||||
SavingCampaignID string `json:"savingCampaignId,omitempty"`
|
||||
SavingCampaignName string `json:"savingCampaignName,omitempty"`
|
||||
|
||||
SavingCampaignItemID string `json:"savingCampaignItemId,omitempty"`
|
||||
SavingCampaignItemName string `json:"savingCampaignItemName,omitempty"`
|
||||
}
|
||||
|
||||
// PayloadUpdateSellerSavingCampaignStatistic ...
|
||||
type PayloadUpdateSellerSavingCampaignStatistic struct {
|
||||
SellerID string `json:"sellerId"`
|
||||
Statistic SellerSavingCampaignStatistic `json:"statistic"`
|
||||
}
|
||||
|
||||
// SellerSavingCampaignStatistic ...
|
||||
type SellerSavingCampaignStatistic struct {
|
||||
SavingCampaignCashPending float64 `json:"savingCampaignCashPending"`
|
||||
SavingCampaignCashCompleted float64 `json:"savingCampaignCashCompleted"`
|
||||
}
|
||||
|
||||
// GenerateVoucherPromotion ...
|
||||
type GenerateVoucherPromotion struct {
|
||||
Cash float64 `json:"cash"`
|
||||
TargetID primitive.ObjectID `json:"targetId"`
|
||||
TargetType string `json:"targetType"`
|
||||
Options GenerateVoucherPromotionOptions `json:"options"`
|
||||
Seller primitive.ObjectID `json:"seller"`
|
||||
}
|
||||
|
||||
// GenerateVoucherPromotionOptions ...
|
||||
type GenerateVoucherPromotionOptions struct {
|
||||
Title string `json:"title"`
|
||||
}
|
||||
|
||||
// SubscriberNotificationTopic ...
|
||||
type SubscriberNotificationTopic struct {
|
||||
User string `json:"user"`
|
||||
Topic string `json:"topic"`
|
||||
DeviceId string `json:"deviceId"`
|
||||
FCMToken string `json:"fcmToken"`
|
||||
}
|
||||
|
|
|
@ -11,11 +11,17 @@ func getSellyValue(val string) string {
|
|||
|
||||
// Selly ...
|
||||
var Selly = struct {
|
||||
PushNotification string
|
||||
UpdateSellerAffiliateStatistic string
|
||||
CheckAnDInsertCashflowBySeller string
|
||||
PushNotification string
|
||||
UpdateSellerAffiliateStatistic string
|
||||
CheckAnDInsertCashflowBySeller string
|
||||
SubscriberTopic string
|
||||
UpdateSellerSavingCampaignStatistic string
|
||||
GenerateVoucherPromotion string
|
||||
}{
|
||||
PushNotification: getSellyValue("push_notifications"),
|
||||
UpdateSellerAffiliateStatistic: getSellyValue("update_seller_affiliate_statistic"),
|
||||
CheckAnDInsertCashflowBySeller: getSellyValue("check_and_insert_cashflow_statistic"),
|
||||
PushNotification: getSellyValue("push_notifications"),
|
||||
UpdateSellerAffiliateStatistic: getSellyValue("update_seller_affiliate_statistic"),
|
||||
CheckAnDInsertCashflowBySeller: getSellyValue("check_and_insert_cashflow_statistic"),
|
||||
SubscriberTopic: getSellyValue("subscriber_topic"),
|
||||
UpdateSellerSavingCampaignStatistic: getSellyValue("update_seller_saving_campaign_statistic"),
|
||||
GenerateVoucherPromotion: getSellyValue("generate_voucher_promotion"),
|
||||
}
|
||||
|
|
|
@ -43,3 +43,14 @@ type RequestCondition struct {
|
|||
Page int64 `json:"page"`
|
||||
Limit int64 `json:"limit"`
|
||||
}
|
||||
|
||||
type UpdatePayload struct {
|
||||
Conditions interface{} `json:"conditions"`
|
||||
Payload interface{} `json:"payload"`
|
||||
Opts []*options.UpdateOptions `json:"opts"`
|
||||
}
|
||||
|
||||
type WebhookPayloadV2 struct {
|
||||
Path string `json:"path"` // request URL path from external
|
||||
Data string `json:"data"` // request body
|
||||
}
|
||||
|
|
|
@ -5,6 +5,9 @@ type CommunicationRequestHttp struct {
|
|||
ResponseImmediately bool `json:"responseImmediately"`
|
||||
Authentication string `json:"authentication"`
|
||||
Payload HttpRequest `json:"payload"`
|
||||
|
||||
// collection to store log data, will be prepended with log-, default it stored in logs collections
|
||||
LogTarget string `json:"logTarget"`
|
||||
}
|
||||
|
||||
// HttpRequest ...
|
||||
|
|
|
@ -28,10 +28,17 @@ type (
|
|||
|
||||
// LocationWard ...
|
||||
LocationWard struct {
|
||||
ID string `json:"id"`
|
||||
Name string `json:"name"`
|
||||
Code int `json:"code"`
|
||||
Slug string `json:"slug"`
|
||||
ID string `json:"id"`
|
||||
Name string `json:"name"`
|
||||
Code int `json:"code"`
|
||||
Slug string `json:"slug"`
|
||||
Location *GEOLocation `json:"location"`
|
||||
}
|
||||
|
||||
// GEOLocation ...
|
||||
GEOLocation struct {
|
||||
Type string `bson:"type" json:"type"`
|
||||
Coordinates []float64 `bson:"coordinates" json:"coordinates"`
|
||||
}
|
||||
|
||||
// LocationProvinceResponse ...
|
||||
|
@ -76,12 +83,13 @@ type (
|
|||
|
||||
// LocationWardDetailResponse ...
|
||||
LocationWardDetailResponse struct {
|
||||
ID string `json:"_id"`
|
||||
Name string `json:"name"`
|
||||
OldSlugs []string `json:"oldSlugs"`
|
||||
Slug string `json:"slug"`
|
||||
Code int `json:"code"`
|
||||
DistrictCode int `json:"districtCode"`
|
||||
ProvinceCode int `json:"provinceCode"`
|
||||
ID string `json:"_id"`
|
||||
Name string `json:"name"`
|
||||
OldSlugs []string `json:"oldSlugs"`
|
||||
Slug string `json:"slug"`
|
||||
Code int `json:"code"`
|
||||
DistrictCode int `json:"districtCode"`
|
||||
ProvinceCode int `json:"provinceCode"`
|
||||
Location *GEOLocation `json:"location"`
|
||||
}
|
||||
)
|
||||
|
|
|
@ -49,3 +49,7 @@ type OrderSupplierQuery struct {
|
|||
SupplierID string `json:"supplierId"`
|
||||
WarehouseIDs []string `json:"warehouseIDs"`
|
||||
}
|
||||
|
||||
type OrderGetTotalWarningPayload struct {
|
||||
UserID string `json:"userId"`
|
||||
}
|
||||
|
|
|
@ -33,3 +33,10 @@ type SupplierOrderDelivery struct {
|
|||
Status string `json:"status" enums:"waiting_to_confirm,waiting_to_pick,picking,picked,delay_pickup,pickup_failed,delivering,delay_delivery,delivered,cancelled,delivery_failed,waiting_to_return,returning,delay_return,compensation,returned"`
|
||||
TPLCode string `json:"tplCode" enums:"SLY,GHTK,GHN,SSC,SPY,VTP,SE,NTL,BEST"`
|
||||
}
|
||||
|
||||
// OrderGetTotalWarningRes ...
|
||||
type OrderGetTotalWarningRes struct {
|
||||
UserID string `json:"userId"`
|
||||
TotalWarningOrder int64 `json:"totalWarningOrder"`
|
||||
Action ActionType `json:"action"`
|
||||
}
|
||||
|
|
|
@ -0,0 +1,14 @@
|
|||
package model
|
||||
|
||||
type ProductApplyRequestPayload struct {
|
||||
RequestID string `json:"requestId"`
|
||||
}
|
||||
|
||||
type ProductCreateStepsPayload struct {
|
||||
RequestID string `json:"requestId"`
|
||||
}
|
||||
|
||||
type ProductRequestChangeStatus struct {
|
||||
RequestID string `json:"requestId"`
|
||||
Status string `json:"status"`
|
||||
}
|
|
@ -0,0 +1,8 @@
|
|||
package model
|
||||
|
||||
type QueueScheduleTaskRequest struct {
|
||||
ID string `json:"id"`
|
||||
NatsSubject string `json:"natsSubject"`
|
||||
Data string `json:"data"`
|
||||
StartAt int64 `json:"startAt"` // unix
|
||||
}
|
|
@ -4,9 +4,11 @@ import "time"
|
|||
|
||||
// ResponseSellerInfo ...
|
||||
type ResponseSellerInfo struct {
|
||||
ID string `json:"_id"`
|
||||
Name string `json:"name"`
|
||||
Code string `json:"code"`
|
||||
ID string `json:"_id"`
|
||||
Name string `json:"name"`
|
||||
Code string `json:"code"`
|
||||
IsAccountPro bool `json:"isAccountPro"`
|
||||
CashRemaining float64 `json:"cashRemaining"`
|
||||
}
|
||||
|
||||
// ResponseListSellerInfo ...
|
||||
|
|
|
@ -0,0 +1,19 @@
|
|||
package model
|
||||
|
||||
// PayloadEmitSocketEvent ...
|
||||
type PayloadEmitSocketEvent struct {
|
||||
User string `json:"user"`
|
||||
Message string `json:"message"`
|
||||
Data string `json:"data"`
|
||||
IsNotRemove bool `json:"isNotRemove"`
|
||||
}
|
||||
|
||||
// PayloadEventSocketReward ...
|
||||
type PayloadEventSocketReward struct {
|
||||
Type string `json:"type"`
|
||||
Title string `json:"title"`
|
||||
Cash float64 `json:"cash"`
|
||||
Message string `json:"message"`
|
||||
Photo interface{} `json:"photo"`
|
||||
Action *ActionType `json:"action"`
|
||||
}
|
|
@ -5,6 +5,7 @@ type ResponseSupplierInfo struct {
|
|||
ID string `json:"id"`
|
||||
Name string `json:"name"`
|
||||
BusinessType string `json:"businessType"`
|
||||
IsSellyMall bool `json:"isSellyMall"`
|
||||
}
|
||||
|
||||
// ResponseSupplierContract ...
|
||||
|
|
|
@ -37,11 +37,12 @@ type InsuranceOpts struct {
|
|||
|
||||
// OutboundRequestItem ...
|
||||
type OutboundRequestItem struct {
|
||||
SupplierSKU string `json:"supplierSKU"`
|
||||
Quantity int64 `json:"quantity"`
|
||||
UnitCode string `json:"unitCode"`
|
||||
Price float64 `json:"price"`
|
||||
Name string `json:"name"`
|
||||
SupplierSKU string `json:"supplierSKU"`
|
||||
Quantity int64 `json:"quantity"`
|
||||
UnitCode string `json:"unitCode"`
|
||||
Price float64 `json:"price"`
|
||||
Name string `json:"name"`
|
||||
PartnerProductCode string `json:"partnerProductCode"`
|
||||
}
|
||||
|
||||
// CustomerInfo ...
|
||||
|
@ -63,11 +64,12 @@ type AddressDetail struct {
|
|||
|
||||
// UpdateOutboundRequestLogisticInfoPayload ...
|
||||
type UpdateOutboundRequestLogisticInfoPayload struct {
|
||||
ShippingLabel string `json:"shippingLabel"`
|
||||
TrackingCode string `json:"trackingCode"`
|
||||
ORCode string `json:"orCode"`
|
||||
TPLCode string `json:"tplCode"`
|
||||
OrderID string `json:"orderId"`
|
||||
ShippingLabel string `json:"shippingLabel,omitempty"`
|
||||
TrackingCode string `json:"trackingCode,omitempty"`
|
||||
ORCode string `json:"orCode,omitempty"`
|
||||
TPLCode string `json:"tplCode,omitempty"`
|
||||
OrderID string `json:"orderId"`
|
||||
DeliveryStatus string `json:"deliveryStatus,omitempty"`
|
||||
}
|
||||
|
||||
// CancelOutboundRequest ...
|
||||
|
@ -97,10 +99,11 @@ type SupplierIsClosed struct {
|
|||
|
||||
// GetWarehousesRequest ...
|
||||
type GetWarehousesRequest struct {
|
||||
Keyword string `json:"keyword"`
|
||||
Status string `json:"status"`
|
||||
Supplier string `json:"supplier"`
|
||||
BusinessType string `json:"businessType"`
|
||||
Keyword string `json:"keyword"`
|
||||
Status string `json:"status"`
|
||||
Supplier string `json:"supplier"`
|
||||
BusinessType string `json:"businessType"`
|
||||
IDs []string `json:"ids"`
|
||||
|
||||
Page int64 `json:"page"`
|
||||
Limit int64 `json:"limit"`
|
||||
|
@ -119,8 +122,18 @@ type UpdateStatusWarehousePendingInactiveRequest struct {
|
|||
Warehouses []UpdateStatusWarehousePendingInactive `json:"warehouses"`
|
||||
}
|
||||
|
||||
// UpdateIsSellyMallRequest ...
|
||||
type UpdateIsSellyMallRequest struct {
|
||||
SupplierID string `json:"supplier"`
|
||||
}
|
||||
|
||||
// UpdateStatusWarehousePendingInactive ...
|
||||
type UpdateStatusWarehousePendingInactive struct {
|
||||
WarehouseID string `json:"warehouse"`
|
||||
PendingInactive bool `json:"pendingInactive"`
|
||||
}
|
||||
|
||||
type GetListWarehouseConfigReq struct {
|
||||
PartnerCode string `json:"partnerCode"`
|
||||
PartnerIdentityCode string `json:"partnerIdentityCode"`
|
||||
}
|
||||
|
|
|
@ -61,16 +61,28 @@ type WarehouseSupplier struct {
|
|||
|
||||
// WarehouseOrder ...
|
||||
type WarehouseOrder struct {
|
||||
MinimumValue float64 `json:"minimumValue"`
|
||||
PaymentMethod WarehousePaymentMethod `json:"paymentMethod"`
|
||||
IsLimitNumberOfPurchases bool `json:"isLimitNumberOfPurchases"`
|
||||
LimitNumberOfPurchases int64 `json:"limitNumberOfPurchases"`
|
||||
MinimumValue float64 `json:"minimumValue"`
|
||||
PaymentMethod WarehousePaymentMethod `json:"paymentMethod"`
|
||||
IsLimitNumberOfPurchases bool `json:"isLimitNumberOfPurchases"`
|
||||
LimitNumberOfPurchases int64 `json:"limitNumberOfPurchases"`
|
||||
NotifyOnNewOrder WarehouseConfigNotifyOnNewOrder `json:"notifyOnNewOrder"`
|
||||
LabelSize string `json:"labelSize"`
|
||||
MaximumOrderValue float64 `json:"maximumOrderValue"`
|
||||
MaximumNumberPerBuyerEachMonth int64 `json:"maximumNumberPerBuyerEachMonth"`
|
||||
}
|
||||
|
||||
// WarehouseConfigNotifyOnNewOrder ...
|
||||
type WarehouseConfigNotifyOnNewOrder struct {
|
||||
Enable bool `bson:"enable" json:"enable"`
|
||||
Channel string `bson:"channel" json:"channel"`
|
||||
RoomID string `bson:"roomId" json:"roomId"`
|
||||
}
|
||||
|
||||
// WarehousePaymentMethod ...
|
||||
type WarehousePaymentMethod struct {
|
||||
Cod bool `json:"cod"`
|
||||
BankTransfer bool `json:"bankTransfer"`
|
||||
Fundiin bool `json:"fundiin"`
|
||||
}
|
||||
|
||||
// WarehouseDelivery ...
|
||||
|
@ -144,6 +156,8 @@ type WarehouseNatsResponse struct {
|
|||
UpdatedAt time.Time `json:"updatedAt"`
|
||||
ReasonPendingInactive string `json:"reasonPendingInactive"`
|
||||
IsPendingInactive bool `json:"isPendingInactive"`
|
||||
IsFromInternational bool `json:"isFromInternational"`
|
||||
StoreCode string `json:"storeCode"`
|
||||
}
|
||||
|
||||
// WarehouseInfo ...
|
||||
|
@ -172,3 +186,9 @@ type GetWarehousesResponse struct {
|
|||
Limit int64 `json:"limit"`
|
||||
List []WarehouseInfo `json:"list"`
|
||||
}
|
||||
|
||||
type GetListWarehouseConfigRes struct {
|
||||
Total int64 `json:"total"`
|
||||
Limit int64 `json:"limit"`
|
||||
List []WarehouseConfiguration `json:"list"`
|
||||
}
|
||||
|
|
|
@ -14,8 +14,11 @@ var prefixes = struct {
|
|||
SocialPost string
|
||||
Staff string
|
||||
Segment string
|
||||
Product string
|
||||
Queue string
|
||||
Campaign string
|
||||
Affiliate string
|
||||
Socket string
|
||||
}{
|
||||
Communication: "communication",
|
||||
Order: "order",
|
||||
|
@ -30,6 +33,9 @@ var prefixes = struct {
|
|||
SocialPost: "social_post",
|
||||
Staff: "staff",
|
||||
Segment: "segment",
|
||||
Product: "product",
|
||||
Queue: "queue",
|
||||
Campaign: "campaign",
|
||||
Affiliate: "affiliate",
|
||||
Socket: "socket",
|
||||
}
|
||||
|
|
|
@ -9,6 +9,7 @@ func getLocationValue(val string) string {
|
|||
var Location = struct {
|
||||
GetLocationByCode string
|
||||
GetLocationByCodeFromLocationService string
|
||||
GetLocationByWardCode string
|
||||
GetProvincesByCodes string
|
||||
GetProvincesByCodesFromLocationService string
|
||||
GetDistrictsByCodes string
|
||||
|
@ -28,6 +29,7 @@ var Location = struct {
|
|||
}{
|
||||
GetLocationByCode: getLocationValue("get_location_warehouse"),
|
||||
GetLocationByCodeFromLocationService: getLocationValue("get_location_warehouse_from_location_service"),
|
||||
GetLocationByWardCode: getLocationValue("get_location_by_ward_code"),
|
||||
GetProvincesByCodes: getLocationValue("get_provinces_by_codes"),
|
||||
GetProvincesByCodesFromLocationService: getLocationValue("get_provinces_by_codes_from_location_service"),
|
||||
GetDistrictsByCodes: getLocationValue("get_districts_by_codes"),
|
||||
|
|
|
@ -7,17 +7,19 @@ func getOrderValue(val string) string {
|
|||
}
|
||||
|
||||
var Order = struct {
|
||||
UpdateORStatus string
|
||||
CancelDelivery string
|
||||
ChangeDeliveryStatus string
|
||||
UpdateLogisticInfoFailed string
|
||||
ORNotUpdateStatus string
|
||||
GetSupplierOrders string
|
||||
UpdateORStatus string
|
||||
GetUserTotalWarningOrders string
|
||||
CancelDelivery string
|
||||
ChangeDeliveryStatus string
|
||||
UpdateLogisticInfoFailed string
|
||||
ORNotUpdateStatus string
|
||||
GetSupplierOrders string
|
||||
}{
|
||||
UpdateORStatus: getOrderValue("update_outbound_request_status"),
|
||||
CancelDelivery: getOrderValue("cancel_delivery"),
|
||||
ChangeDeliveryStatus: getOrderValue("change_delivery_status"),
|
||||
UpdateLogisticInfoFailed: getOrderValue("update_logistic_info_failed"),
|
||||
ORNotUpdateStatus: getOrderValue("outbound_request_not_update_status"),
|
||||
GetSupplierOrders: getOrderValue("get_supplier_orders"),
|
||||
UpdateORStatus: getOrderValue("update_outbound_request_status"),
|
||||
GetUserTotalWarningOrders: getOrderValue("get_user_total_warning_orders"),
|
||||
CancelDelivery: getOrderValue("cancel_delivery"),
|
||||
ChangeDeliveryStatus: getOrderValue("change_delivery_status"),
|
||||
UpdateLogisticInfoFailed: getOrderValue("update_logistic_info_failed"),
|
||||
ORNotUpdateStatus: getOrderValue("outbound_request_not_update_status"),
|
||||
GetSupplierOrders: getOrderValue("get_supplier_orders"),
|
||||
}
|
||||
|
|
|
@ -0,0 +1,26 @@
|
|||
package subject
|
||||
|
||||
import "fmt"
|
||||
|
||||
// getSegmentValue ...
|
||||
func getProductValue(val string) string {
|
||||
return fmt.Sprintf("%s.%s", prefixes.Product, val)
|
||||
}
|
||||
|
||||
var Product = struct {
|
||||
ApplyRequest string
|
||||
CreateRequestStep string
|
||||
ProcessApplyRequest string
|
||||
RequestChangeStatus string
|
||||
WebhookStockUpdate string // WebhookStockUpdate Kiotviet queue
|
||||
OPWebhookStockUpdate string // OPWebhookStockUpdate Onpoint queue
|
||||
OrderPaymentBankTransferWebhookCheckAndUpdateStatus string
|
||||
}{
|
||||
ApplyRequest: getProductValue("apply_request"),
|
||||
CreateRequestStep: getProductValue("create_request_step"),
|
||||
ProcessApplyRequest: getProductValue("process_apply_request"),
|
||||
RequestChangeStatus: getProductValue("request_change_status"),
|
||||
WebhookStockUpdate: getProductValue("webhook_stock_update"),
|
||||
OPWebhookStockUpdate: getProductValue("op_webhook_stock_update"),
|
||||
OrderPaymentBankTransferWebhookCheckAndUpdateStatus: getProductValue("order_payment_bank_transfer_webhook_check_and_update_status"),
|
||||
}
|
|
@ -0,0 +1,13 @@
|
|||
package subject
|
||||
|
||||
import "fmt"
|
||||
|
||||
func getQueueValue(val string) string {
|
||||
return fmt.Sprintf("%s.%s", prefixes.Queue, val)
|
||||
}
|
||||
|
||||
var Queue = struct {
|
||||
ScheduleTask string
|
||||
}{
|
||||
ScheduleTask: getQueueValue("schedule_task"),
|
||||
}
|
|
@ -0,0 +1,16 @@
|
|||
package subject
|
||||
|
||||
import "fmt"
|
||||
|
||||
func getSocketValue(val string) string {
|
||||
return fmt.Sprintf("%s.%s", prefixes.Socket, val)
|
||||
}
|
||||
|
||||
// Socket ...
|
||||
var Socket = struct {
|
||||
EmitEventReward string
|
||||
EmitEventToUser string
|
||||
}{
|
||||
EmitEventReward: getSocketValue("emit_event_reward"),
|
||||
EmitEventToUser: "send_message_to_socket",
|
||||
}
|
|
@ -19,6 +19,7 @@ var Warehouse = struct {
|
|||
WebhookTNC string
|
||||
WebhookGlobalCare string
|
||||
WebhookOnPoint string
|
||||
WebhookViettelFFM string
|
||||
FindOne string
|
||||
FindByCondition string
|
||||
Distinct string
|
||||
|
@ -29,6 +30,10 @@ var Warehouse = struct {
|
|||
GetWarehouses string
|
||||
UpdateORDeliveryStatus string
|
||||
UpdateStatusWarehousePendingInactive string
|
||||
UpdateIsSellyMall string
|
||||
UpdateWarehouseConfig string
|
||||
BulkWriteWarehouseConfig string
|
||||
GetListWarehouseConfig string
|
||||
}{
|
||||
CreateWarehouseIntoServiceSupplier: getWarehouseValue("create_warehouse_into_service_supplier"),
|
||||
UpdateWarehouseIntoServiceSupplier: getWarehouseValue("update_warehouse_into_service_supplier"),
|
||||
|
@ -42,6 +47,7 @@ var Warehouse = struct {
|
|||
WebhookTNC: getWarehouseValue("webhook_tnc"),
|
||||
WebhookGlobalCare: getWarehouseValue("webhook_global_care"),
|
||||
WebhookOnPoint: getWarehouseValue("webhook_on_point"),
|
||||
WebhookViettelFFM: getWarehouseValue("webhook_viettel_ffm"),
|
||||
FindOne: getWarehouseValue("find_one"),
|
||||
FindByCondition: getWarehouseValue("find_all_by_condition"),
|
||||
Distinct: getWarehouseValue("distinct"),
|
||||
|
@ -50,4 +56,8 @@ var Warehouse = struct {
|
|||
GetWarehouses: getWarehouseValue("get_warehouses"),
|
||||
UpdateORDeliveryStatus: getWarehouseValue("update_or_delivery_status"),
|
||||
UpdateStatusWarehousePendingInactive: getWarehouseValue("update_status_warehouse_pending_inactive"),
|
||||
UpdateIsSellyMall: getWarehouseValue("update_is_selly_mall"),
|
||||
UpdateWarehouseConfig: getWarehouseValue("update_warehouse_config"),
|
||||
BulkWriteWarehouseConfig: getWarehouseValue("bulk_write_warehouse_config"),
|
||||
GetListWarehouseConfig: getWarehouseValue("get_list_warehouse_config"),
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue