Compare commits

..

10 Commits

Author SHA1 Message Date
Bastian de Byl
82b88cbaf5 fixed data Put in UpdateOrder again with bytes buffer 2023-02-26 02:14:57 -05:00
Bastian de Byl
994cabc20e fixed data Put in UpdateOrder 2023-02-26 02:13:20 -05:00
Bastian de Byl
bde3d07c28 added unique struct for UpdateOrder 2023-02-26 02:08:36 -05:00
Bastian de Byl
0bf0abd435 fixed order pointer in UpdateOrder 2023-02-26 02:04:24 -05:00
Bastian de Byl
82106ee4e0 added UpdateOrder function, fixed response statuscode handling 2023-02-26 02:01:02 -05:00
Bastian de Byl
c1091f12b0 changed ShippingCost type to float64 in SnipcartOrder 2023-02-26 01:32:24 -05:00
Bastian de Byl
f80f35f5d5 changed dimension types in SnipcartItem struct 2023-02-26 01:31:28 -05:00
Bastian de Byl
13bef02dcb changed weight strinbg to float64 2023-02-26 01:30:13 -05:00
Bastian de Byl
e6ffe724af added more fields to SnipcartItem struct 2023-02-26 01:28:02 -05:00
Bastian de Byl
8fee81d8a4 added ShippingCost to SnipcartOrder 2023-02-26 00:07:03 -05:00
2 changed files with 45 additions and 6 deletions

2
go.mod
View File

@@ -3,6 +3,6 @@ module github.com/debyltech/go-snipcart
go 1.20
require (
github.com/debyltech/go-helpers v0.0.0-20230224002154-eb55816c71ec
github.com/debyltech/go-helpers v1.0.1
github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e
)

View File

@@ -1,6 +1,7 @@
package snipcart
import (
"bytes"
"encoding/base64"
"encoding/json"
"errors"
@@ -30,10 +31,14 @@ type SnipcartItem struct {
UUID string `json:"uniqueId"`
ID string `json:"id"`
Name string `json:"name"`
Quantity float64 `json:"quantity"`
Weight string `json:"weight"`
TotalWeight float64 `json:"totalWeight"`
Quantity int `json:"quantity"`
TotalWeight float64 `json:"totalWeight,omitempty"`
CustomFieldsJSON string `json:"customFieldsJson"`
Length float64 `json:"length,omitempty"`
Width float64 `json:"width,omitempty"`
Height float64 `json:"height,omitempty"`
Weight float64 `json:"weight,omitempty"`
Shippable bool `json:"shippable,omitempty"`
}
type SnipcartOrder struct {
@@ -52,9 +57,19 @@ type SnipcartOrder struct {
Phone string `json:"shippingAddressPhone"`
TrackingNumber string `json:"trackingNumber"`
TrackingUrl string `json:"trackingUrl"`
ShippingCost float64 `json:"shippingFees"`
Items []SnipcartItem `json:"items"`
}
type SnipcartOrderUpdate struct {
Token string `json:"token"`
Status OrderStatus `json:"status"`
PaymentStatus string `json:"paymentStatus,omitempty"`
TrackingNumber string `json:"trackingNumber,omitempty"`
TrackingUrl string `json:"trackingUrl,omitempty"`
Metadata any `json:"metadata,omitempty"`
}
type SnipcartOrders struct {
TotalItems int
Items []SnipcartOrder
@@ -72,7 +87,7 @@ func (s *SnipcartProvider) GetOrder(token string) (*SnipcartOrder, error) {
if err != nil {
return nil, err
}
if response.Status != "200 OK" {
if response.StatusCode < 200 && response.StatusCode >= 300 {
return nil, fmt.Errorf("unexpected response received: %s", response.Status)
}
@@ -92,7 +107,7 @@ func (s *SnipcartProvider) GetOrders(queries map[string]string) (*SnipcartOrders
if err != nil {
return nil, err
}
if response.Status != "200 OK" {
if response.StatusCode < 200 && response.StatusCode >= 300 {
return nil, fmt.Errorf("unexpected response received: %s", response.Status)
}
@@ -123,3 +138,27 @@ func (o *SnipcartOrder) TokenPNGBase64() (string, error) {
return base64.StdEncoding.EncodeToString(img), nil
}
func (s *SnipcartProvider) UpdateOrder(orderUpdate *SnipcartOrderUpdate) (*SnipcartOrder, error) {
updateJson, err := json.Marshal(orderUpdate)
if err != nil {
return nil, err
}
response, err := helper.Put(orderUri+"/"+orderUpdate.Token, "Basic", s.AuthBase64, bytes.NewBuffer(updateJson))
if err != nil {
return nil, err
}
if response.StatusCode < 200 && response.StatusCode >= 300 {
return nil, fmt.Errorf("unexpected response received: %s", response.Status)
}
defer response.Body.Close()
var responseOrder SnipcartOrder
err = json.NewDecoder(response.Body).Decode(&responseOrder)
if err != nil {
return nil, err
}
return &responseOrder, nil
}