2021-10-27 15:49:06 +03:00
|
|
|
package retailcrm
|
2018-02-27 11:37:15 +03:00
|
|
|
|
2021-11-17 16:57:35 +03:00
|
|
|
import (
|
|
|
|
"crypto/hmac"
|
|
|
|
"crypto/sha256"
|
|
|
|
"encoding/hex"
|
|
|
|
)
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CustomerRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type CustomerRequest struct {
|
|
|
|
By string `url:"by,omitempty"`
|
|
|
|
Site string `url:"site,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CustomersRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type CustomersRequest struct {
|
|
|
|
Filter CustomersFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CorporateCustomersRequest type.
|
2019-10-16 16:32:31 +03:00
|
|
|
type CorporateCustomersRequest struct {
|
|
|
|
Filter CorporateCustomersFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CorporateCustomersNotesRequest type.
|
2019-10-16 16:32:31 +03:00
|
|
|
type CorporateCustomersNotesRequest struct {
|
|
|
|
Filter CorporateCustomersNotesFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CorporateCustomerAddressesRequest type.
|
2019-10-16 16:32:31 +03:00
|
|
|
type CorporateCustomerAddressesRequest struct {
|
|
|
|
Filter CorporateCustomerAddressesFilter `url:"filter,omitempty"`
|
|
|
|
By string `url:"by,omitempty"`
|
|
|
|
Site string `url:"site,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// IdentifiersPairRequest type.
|
2019-10-16 16:32:31 +03:00
|
|
|
type IdentifiersPairRequest struct {
|
|
|
|
Filter IdentifiersPairFilter `url:"filter,omitempty"`
|
|
|
|
By string `url:"by,omitempty"`
|
|
|
|
Site string `url:"site,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CustomersUploadRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type CustomersUploadRequest struct {
|
|
|
|
Customers []Customer `url:"customers,omitempty,brackets"`
|
|
|
|
Site string `url:"site,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CustomersHistoryRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type CustomersHistoryRequest struct {
|
|
|
|
Filter CustomersHistoryFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CorporateCustomersHistoryRequest type.
|
2019-11-25 10:55:06 +03:00
|
|
|
type CorporateCustomersHistoryRequest struct {
|
|
|
|
Filter CorporateCustomersHistoryFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// OrderRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type OrderRequest struct {
|
|
|
|
By string `url:"by,omitempty"`
|
|
|
|
Site string `url:"site,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// OrdersRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type OrdersRequest struct {
|
|
|
|
Filter OrdersFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// OrdersStatusesRequest type.
|
2020-06-29 16:26:10 +03:00
|
|
|
type OrdersStatusesRequest struct {
|
|
|
|
IDs []int `url:"ids,omitempty,brackets"`
|
|
|
|
ExternalIDs []string `url:"externalIds,omitempty,brackets"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// OrdersUploadRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type OrdersUploadRequest struct {
|
|
|
|
Orders []Order `url:"orders,omitempty,brackets"`
|
|
|
|
Site string `url:"site,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// OrdersHistoryRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type OrdersHistoryRequest struct {
|
|
|
|
Filter OrdersHistoryFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// PacksRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type PacksRequest struct {
|
|
|
|
Filter PacksFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// PacksHistoryRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type PacksHistoryRequest struct {
|
|
|
|
Filter OrdersHistoryFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// UsersRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type UsersRequest struct {
|
|
|
|
Filter UsersFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// UserGroupsRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type UserGroupsRequest struct {
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// TasksRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type TasksRequest struct {
|
|
|
|
Filter TasksFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// NotesRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type NotesRequest struct {
|
2018-04-12 16:43:53 +03:00
|
|
|
Filter NotesFilter `url:"filter,omitempty"`
|
2018-02-27 11:37:15 +03:00
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// SegmentsRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type SegmentsRequest struct {
|
|
|
|
Filter SegmentsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// InventoriesRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type InventoriesRequest struct {
|
|
|
|
Filter InventoriesFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// ProductsGroupsRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type ProductsGroupsRequest struct {
|
|
|
|
Filter ProductsGroupsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// ProductsRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type ProductsRequest struct {
|
|
|
|
Filter ProductsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// ProductsPropertiesRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type ProductsPropertiesRequest struct {
|
|
|
|
Filter ProductsPropertiesFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// DeliveryTrackingRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type DeliveryTrackingRequest struct {
|
2021-01-29 14:29:44 +03:00
|
|
|
DeliveryID string `json:"deliveryId,omitempty"`
|
|
|
|
TrackNumber string `json:"trackNumber,omitempty"`
|
2021-10-27 15:49:06 +03:00
|
|
|
History []DeliveryHistoryRecord `json:"history,omitempty"`
|
|
|
|
ExtraData map[string]string `json:"extraData,omitempty"`
|
2018-02-27 11:37:15 +03:00
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// DeliveryShipmentsRequest type.
|
2018-02-27 11:37:15 +03:00
|
|
|
type DeliveryShipmentsRequest struct {
|
|
|
|
Filter ShipmentFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
2018-04-11 13:39:43 +03:00
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CostsRequest type.
|
2018-04-11 13:39:43 +03:00
|
|
|
type CostsRequest struct {
|
|
|
|
Filter CostsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// FilesRequest type.
|
2019-09-04 11:38:21 +03:00
|
|
|
type FilesRequest struct {
|
|
|
|
Filter FilesFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CustomFieldsRequest type.
|
2018-04-11 13:39:43 +03:00
|
|
|
type CustomFieldsRequest struct {
|
|
|
|
Filter CustomFieldsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-04-26 12:09:21 +03:00
|
|
|
// CustomDictionariesRequest type.
|
2018-04-11 13:39:43 +03:00
|
|
|
type CustomDictionariesRequest struct {
|
|
|
|
Filter CustomDictionariesFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
2021-11-17 16:57:35 +03:00
|
|
|
|
|
|
|
// ConnectRequest contains information about the system connection that is requested to be created.
|
|
|
|
type ConnectRequest struct {
|
|
|
|
// Token is used to verify the request. Do not use directly; use Verify instead.
|
|
|
|
Token string `json:"token"`
|
|
|
|
// APIKey that was generated for the module.
|
|
|
|
APIKey string `json:"apiKey"`
|
|
|
|
// URL of the system. Do not use directly; use SystemURL instead.
|
|
|
|
URL string `json:"systemUrl"`
|
|
|
|
}
|
|
|
|
|
2022-08-09 13:45:11 +03:00
|
|
|
// BonusOperationsRequest type.
|
|
|
|
type BonusOperationsRequest struct {
|
|
|
|
Filter BonusOperationsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Cursor string `url:"cursor,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// AccountBonusOperationsRequest type.
|
|
|
|
type AccountBonusOperationsRequest struct {
|
|
|
|
Filter AccountBonusOperationsFilter `url:"filter,omitempty"`
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
|
|
|
}
|
|
|
|
|
2022-11-24 13:37:21 +03:00
|
|
|
type LoyaltyBonusCreditRequest struct {
|
|
|
|
Amount float64 `url:"amount"`
|
|
|
|
ActivationDate string `url:"activationDate,omitempty"`
|
|
|
|
ExpiredDate string `url:"expiredDate,omitempty"`
|
|
|
|
Comment string `url:"comment,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type LoyaltyBonusStatusDetailsRequest struct {
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
2022-12-08 16:24:52 +03:00
|
|
|
Filter LoyaltyBonusAPIFilterType `url:"filter,omitempty"`
|
2022-11-24 13:37:21 +03:00
|
|
|
}
|
|
|
|
|
2022-12-07 17:40:52 +03:00
|
|
|
type LoyaltyAccountsRequest struct {
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"limit,omitempty"`
|
2022-12-08 16:24:52 +03:00
|
|
|
Filter LoyaltyAccountAPIFilter `url:"filter,omitempty"`
|
2022-12-07 17:40:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
type LoyaltyCalculateRequest struct {
|
2022-12-08 13:32:54 +03:00
|
|
|
Site string
|
|
|
|
Order Order
|
|
|
|
Bonuses float32
|
|
|
|
}
|
|
|
|
|
|
|
|
type LoyaltiesRequest struct {
|
|
|
|
Limit int `url:"limit,omitempty"`
|
|
|
|
Page int `url:"page,omitempty"`
|
2022-12-08 16:24:52 +03:00
|
|
|
Filter LoyaltyAPIFilter `url:"filter,omitempty"`
|
2022-12-07 17:40:52 +03:00
|
|
|
}
|
|
|
|
|
2022-12-29 16:17:29 +03:00
|
|
|
type NotificationsSendRequest struct {
|
|
|
|
UserGroups []UserGroupType `json:"userGroups,omitempty"`
|
|
|
|
Type NotificationType `json:"type"`
|
|
|
|
Message string `json:"message"`
|
|
|
|
UserIDs []string `json:"userIds,omitempty"`
|
|
|
|
}
|
|
|
|
|
2023-05-17 17:17:34 +03:00
|
|
|
type EditMGChannelTemplateRequest struct {
|
|
|
|
Templates []MGChannelTemplate `json:"templates"`
|
|
|
|
Removed []int `json:"removed"`
|
|
|
|
}
|
|
|
|
|
2021-11-17 16:57:35 +03:00
|
|
|
// SystemURL returns system URL from the connection request without trailing slash.
|
|
|
|
func (r ConnectRequest) SystemURL() string {
|
|
|
|
if r.URL == "" {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
if r.URL[len(r.URL)-1:] == "/" {
|
|
|
|
return r.URL[:len(r.URL)-1]
|
|
|
|
}
|
|
|
|
|
|
|
|
return r.URL
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify returns true if connection request is legitimate. Application secret should be provided to this method.
|
|
|
|
func (r ConnectRequest) Verify(secret string) bool {
|
|
|
|
mac := hmac.New(sha256.New, []byte(secret))
|
|
|
|
if _, err := mac.Write([]byte(r.APIKey)); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
return hmac.Equal([]byte(r.Token), []byte(hex.EncodeToString(mac.Sum(nil))))
|
|
|
|
}
|