Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d182b35d56 | ||
|
|
1d5b44c7e9 | ||
|
|
84941b7acd | ||
|
|
28f77f63b9 |
@@ -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)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,9 +17,9 @@ func main() {
|
|||||||
log.Fatal("missing -key flag")
|
log.Fatal("missing -key flag")
|
||||||
}
|
}
|
||||||
|
|
||||||
snipcartProvider := snipcart.NewSnipcartProvider(*snipcartApiKey)
|
Client := snipcart.NewClient(*snipcartApiKey)
|
||||||
|
|
||||||
response, err := snipcartProvider.GetOrder("b35990df-c0ca-4014-94de-1caa7bd7bb51")
|
response, err := Client.GetOrder("b35990df-c0ca-4014-94de-1caa7bd7bb51")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,13 +15,13 @@ func main() {
|
|||||||
log.Fatal("missing -key flag")
|
log.Fatal("missing -key flag")
|
||||||
}
|
}
|
||||||
|
|
||||||
snipcartProvider := snipcart.NewSnipcartProvider(*snipcartApiKey)
|
Client := snipcart.NewClient(*snipcartApiKey)
|
||||||
|
|
||||||
updateOrder := snipcart.SnipcartOrderUpdate{
|
updateOrder := snipcart.SnipcartOrderUpdate{
|
||||||
Status: snipcart.Delivered,
|
Status: snipcart.Delivered,
|
||||||
}
|
}
|
||||||
|
|
||||||
response, err := snipcartProvider.UpdateOrder("b35990df-c0ca-4014-94de-1caa7bd7bb51", &updateOrder)
|
response, err := Client.UpdateOrder("b35990df-c0ca-4014-94de-1caa7bd7bb51", &updateOrder)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
2
go.mod
2
go.mod
@@ -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.5
|
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
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -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,7 +20,7 @@ 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
|
||||||
@@ -37,7 +37,7 @@ type SnipcartItem struct {
|
|||||||
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"`
|
||||||
TotalPrice string `json:"totalPrice,omitempty"`
|
TotalPrice float64 `json:"totalPrice,omitempty"`
|
||||||
CustomFields []SnipcartCustomField `json:"customFields"`
|
CustomFields []SnipcartCustomField `json:"customFields"`
|
||||||
Length float64 `json:"length,omitempty"`
|
Length float64 `json:"length,omitempty"`
|
||||||
Width float64 `json:"width,omitempty"`
|
Width float64 `json:"width,omitempty"`
|
||||||
@@ -49,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"`
|
||||||
@@ -79,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
|
||||||
@@ -106,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
|
||||||
@@ -126,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")
|
||||||
}
|
}
|
||||||
@@ -143,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
|
||||||
|
|||||||
Reference in New Issue
Block a user