Compare commits

...

7 Commits

Author SHA1 Message Date
Bastian de Byl
d182b35d56 updated helper module 2023-02-26 15:26:59 -05:00
Bastian de Byl
1d5b44c7e9 renamed SnipcartProvider to Client 2023-02-26 14:41:04 -05:00
Bastian de Byl
84941b7acd corrected Price related field types 2023-02-26 14:17:31 -05:00
Bastian de Byl
28f77f63b9 added Total and Subtotal to SnipcartOrder 2023-02-26 14:16:26 -05:00
Bastian de Byl
2a97bca474 added TotalPrice to SnipcartItem 2023-02-26 14:14:52 -05:00
Bastian de Byl
2d91d1d122 corrected SnipcartItem 2023-02-26 14:11:55 -05:00
Bastian de Byl
13f482e50a fixed UpdateOrder method from downstream helper 2023-02-26 02:47:32 -05:00
5 changed files with 95 additions and 22 deletions

View File

@@ -15,9 +15,9 @@ func main() {
log.Fatal("missing -key flag") log.Fatal("missing -key flag")
} }
snipcartProvider := snipcart.NewSnipcartProvider(*snipcartApiKey) Client := snipcart.NewClient(*snipcartApiKey)
response, err := snipcartProvider.GetOrdersByStatus(snipcart.Processed) response, err := Client.GetOrdersByStatus(snipcart.Processed)
if err != nil { if err != nil {
log.Fatal(err) log.Fatal(err)
} }

33
example_get_order.go Normal file
View File

@@ -0,0 +1,33 @@
package main
import (
"encoding/json"
"flag"
"fmt"
"log"
"github.com/debyltech/go-snipcart/snipcart"
)
func main() {
snipcartApiKey := flag.String("key", "", "Snipcart API Key")
flag.Parse()
if *snipcartApiKey == "" {
log.Fatal("missing -key flag")
}
Client := snipcart.NewClient(*snipcartApiKey)
response, err := Client.GetOrder("b35990df-c0ca-4014-94de-1caa7bd7bb51")
if err != nil {
log.Fatal(err)
}
byteResponse, err := json.Marshal(response)
if err != nil {
log.Fatal(err)
}
fmt.Println(string(byteResponse))
}

32
example_update_order.go Normal file
View File

@@ -0,0 +1,32 @@
package main
import (
"flag"
"log"
"github.com/debyltech/go-snipcart/snipcart"
)
func main() {
snipcartApiKey := flag.String("key", "", "Snipcart API Key")
flag.Parse()
if *snipcartApiKey == "" {
log.Fatal("missing -key flag")
}
Client := snipcart.NewClient(*snipcartApiKey)
updateOrder := snipcart.SnipcartOrderUpdate{
Status: snipcart.Delivered,
}
response, err := Client.UpdateOrder("b35990df-c0ca-4014-94de-1caa7bd7bb51", &updateOrder)
if err != nil {
log.Fatal(err)
}
for k, v := range response.Items {
log.Printf("%v: %v\n", k, v)
}
}

2
go.mod
View File

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

View File

@@ -6,7 +6,7 @@ import (
"errors" "errors"
"fmt" "fmt"
helper "github.com/debyltech/go-helpers" helper "github.com/debyltech/go-helpers/json"
"github.com/skip2/go-qrcode" "github.com/skip2/go-qrcode"
) )
@@ -20,19 +20,25 @@ var (
orderUri = apiUri + ordersPath orderUri = apiUri + ordersPath
) )
type SnipcartProvider struct { type Client struct {
SnipcartKey string SnipcartKey string
AuthBase64 string AuthBase64 string
Limit int Limit int
} }
type SnipcartCustomField struct {
Name string `json:"name"`
Value string `json:"value"`
}
type SnipcartItem struct { type SnipcartItem struct {
UUID string `json:"uniqueId"` UUID string `json:"uniqueId"`
ID string `json:"id"` ID string `json:"id"`
Name string `json:"name"` Name string `json:"name"`
Quantity int `json:"quantity"` Quantity int `json:"quantity"`
TotalWeight float64 `json:"totalWeight,omitempty"` TotalWeight float64 `json:"totalWeight,omitempty"`
CustomFieldsJSON string `json:"customFieldsJson"` TotalPrice float64 `json:"totalPrice,omitempty"`
CustomFields []SnipcartCustomField `json:"customFields"`
Length float64 `json:"length,omitempty"` Length float64 `json:"length,omitempty"`
Width float64 `json:"width,omitempty"` Width float64 `json:"width,omitempty"`
Height float64 `json:"height,omitempty"` Height float64 `json:"height,omitempty"`
@@ -43,6 +49,8 @@ type SnipcartItem struct {
type SnipcartOrder struct { type SnipcartOrder struct {
Token string `json:"token"` Token string `json:"token"`
Invoice string `json:"invoiceNumber"` Invoice string `json:"invoiceNumber"`
Subtotal float64 `json:"subtotal,omitempty"`
Total float64 `json:"grandTotal,omitempty"`
Status string `json:"status"` Status string `json:"status"`
TotalWeight float64 `json:"totalWeight"` TotalWeight float64 `json:"totalWeight"`
Email string `json:"email"` Email string `json:"email"`
@@ -73,14 +81,14 @@ type SnipcartOrders struct {
Items []SnipcartOrder Items []SnipcartOrder
} }
func NewSnipcartProvider(snipcartApiKey string) SnipcartProvider { func NewClient(snipcartApiKey string) Client {
return SnipcartProvider{ return Client{
SnipcartKey: snipcartApiKey, SnipcartKey: snipcartApiKey,
AuthBase64: base64.StdEncoding.EncodeToString([]byte(snipcartApiKey + ":")), AuthBase64: base64.StdEncoding.EncodeToString([]byte(snipcartApiKey + ":")),
} }
} }
func (s *SnipcartProvider) GetOrder(token string) (*SnipcartOrder, error) { func (s *Client) GetOrder(token string) (*SnipcartOrder, error) {
response, err := helper.Get(orderUri+"/"+token, "Basic", s.AuthBase64, nil) response, err := helper.Get(orderUri+"/"+token, "Basic", s.AuthBase64, nil)
if err != nil { if err != nil {
return nil, err return nil, err
@@ -100,7 +108,7 @@ func (s *SnipcartProvider) GetOrder(token string) (*SnipcartOrder, error) {
return &order, nil return &order, nil
} }
func (s *SnipcartProvider) GetOrders(queries map[string]string) (*SnipcartOrders, error) { func (s *Client) GetOrders(queries map[string]string) (*SnipcartOrders, error) {
response, err := helper.Get(orderUri, "Basic", s.AuthBase64, queries) response, err := helper.Get(orderUri, "Basic", s.AuthBase64, queries)
if err != nil { if err != nil {
return nil, err return nil, err
@@ -120,7 +128,7 @@ func (s *SnipcartProvider) GetOrders(queries map[string]string) (*SnipcartOrders
return &orders, nil return &orders, nil
} }
func (s *SnipcartProvider) GetOrdersByStatus(status OrderStatus) (*SnipcartOrders, error) { func (s *Client) GetOrdersByStatus(status OrderStatus) (*SnipcartOrders, error) {
if status == "" { if status == "" {
return nil, errors.New("status is not set") return nil, errors.New("status is not set")
} }
@@ -137,7 +145,7 @@ func (o *SnipcartOrder) TokenPNGBase64() (string, error) {
return base64.StdEncoding.EncodeToString(img), nil return base64.StdEncoding.EncodeToString(img), nil
} }
func (s *SnipcartProvider) UpdateOrder(token string, orderUpdate *SnipcartOrderUpdate) (*SnipcartOrder, error) { func (s *Client) UpdateOrder(token string, orderUpdate *SnipcartOrderUpdate) (*SnipcartOrder, error) {
response, err := helper.Put(orderUri+"/"+token, "Basic", s.AuthBase64, orderUpdate) response, err := helper.Put(orderUri+"/"+token, "Basic", s.AuthBase64, orderUpdate)
if err != nil { if err != nil {
return nil, err return nil, err