Compare commits

..

19 Commits

Author SHA1 Message Date
Bastian de Byl
131af89f4f moved enums to enums.go, added SendNotification, Notification structs & enums 2023-04-12 16:56:01 -04:00
Bastian de Byl
b93afeec2f added Created and Modified times to SnipcartOrder 2023-04-09 18:31:53 -04:00
Bastian de Byl
bc56b4d16a 8677r5eju added initial .drone.yml 2023-04-06 23:34:18 -04:00
Bastian de Byl
b08b64f5b2 added SnipcartTax and SnipcartWebhookTaxResponse 2023-04-06 17:59:48 -04:00
Bastian de Byl
ad93704f41 renamed Order.ShippingRate to Order.ShippingRateId 2023-04-03 21:20:22 -04:00
Bastian de Byl
b97ee3132b consolidated webhook order to just order 2023-03-29 13:24:09 -04:00
Bastian de Byl
cfdde462f4 added more order struct details 2023-03-29 13:14:30 -04:00
Bastian de Byl
e039b583e2 fixed Curreny to Currency typo 2023-03-13 00:26:11 -04:00
Bastian de Byl
26571a41fa changed ShippingAddress State to Province 2023-03-13 00:16:22 -04:00
Bastian de Byl
559a100e90 added more missing OrderEventContent fields 2023-03-13 00:14:47 -04:00
Bastian de Byl
6ff851823e added missing OrderEventContent fields 2023-03-13 00:12:11 -04:00
Bastian de Byl
db6e320b7f added webhook specific structs 2023-03-13 00:07:50 -04:00
Bastian de Byl
563e6baeda main added Metadata field to SnipcartOrder struct 2023-03-02 17:19:50 -05:00
Bastian de Byl
e1f7e99027 moved webhook to go-snipcart-webhook repo 2023-02-26 21:23:37 -05:00
Bastian de Byl
36ca8d6f83 added initial webhook main function 2023-02-26 20:36:12 -05:00
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
7 changed files with 116 additions and 35 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)
} }

View File

@@ -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)
} }

View File

@@ -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)
} }

5
go.mod
View File

@@ -1,8 +1,9 @@
module github.com/debyltech/go-snipcart module github.com/debyltech/go-snipcart
go 1.20 go 1.19
require ( require (
github.com/debyltech/go-helpers v1.0.5 github.com/debyltech/go-helpers v1.1.0
github.com/debyltech/go-shippr v0.1.0
github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e
) )

View File

@@ -1,6 +1,7 @@
package snipcart package snipcart
type OrderStatus string type OrderStatus string
type NotificationType string
const ( const (
Processed OrderStatus = "Processed" Processed OrderStatus = "Processed"
@@ -10,4 +11,10 @@ const (
Pending = "Pending" Pending = "Pending"
Cancelled = "Cancelled" Cancelled = "Cancelled"
Dispatched = "Dispatched" Dispatched = "Dispatched"
Comment NotificationType = "Comment"
OrderStatusChanged = "OrderStatusChanged"
OrderShipped = "OrderShipped"
TrackingNumber = "TrackingNumber"
Invoice = "Invice"
) )

View File

@@ -5,8 +5,9 @@ import (
"encoding/json" "encoding/json"
"errors" "errors"
"fmt" "fmt"
"time"
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 +21,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 +38,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"`
@@ -47,23 +48,34 @@ type SnipcartItem struct {
} }
type SnipcartOrder struct { type SnipcartOrder struct {
Token string `json:"token"` Token string `json:"token"`
Invoice string `json:"invoiceNumber"` Created time.Time `json:"creationDate"`
Status string `json:"status"` Modified time.Time `json:"modificationDate"`
TotalWeight float64 `json:"totalWeight"` Invoice string `json:"invoiceNumber"`
Email string `json:"email"` Subtotal float64 `json:"subtotal,omitempty"`
Name string `json:"shippingAddressName"` Currency string `json:"currency,omitempty"`
Address1 string `json:"shippingAddressAddress1"` Total float64 `json:"grandTotal,omitempty"`
Address2 string `json:"shippingAddressAddress2"` Status string `json:"status"`
City string `json:"shippingAddressCity"` TotalWeight float64 `json:"totalWeight"`
Province string `json:"shippingAddressProvince"` ShippingAddress SnipcartShippingAddress `json:"shippingAddress,omitempty"`
Country string `json:"shippingAddressCountry"` Name string `json:"shippingAddressName,omitempty"`
PostalCode string `json:"shippingAddressPostalCode"` Company string `json:"shippingAddressCompanyName,omitempty"`
Phone string `json:"shippingAddressPhone"` Address1 string `json:"shippingAddressAddress1,omitempty"`
TrackingNumber string `json:"trackingNumber"` Address2 string `json:"shippingAddressAddress2,omitempty"`
TrackingUrl string `json:"trackingUrl"` City string `json:"shippingAddressCity,omitempty"`
ShippingCost float64 `json:"shippingFees"` Province string `json:"shippingAddressProvince,omitempty"`
Items []SnipcartItem `json:"items"` Country string `json:"shippingAddressCountry,omitempty"`
PostalCode string `json:"shippingAddressPostalCode,omitempty"`
Phone string `json:"shippingAddressPhone,omitempty"`
Email string `json:"email,omitempty"`
TrackingNumber string `json:"trackingNumber"`
TrackingUrl string `json:"trackingUrl"`
ShippingCost float64 `json:"shippingFees"`
ShippingProvider string `json:"shippingProvider,omitempty"`
ShippingMethod string `json:"shippingMethod,omitempty"`
ShippingRateId string `json:"shippingRateUserDefinedId,omitempty"`
Items []SnipcartItem `json:"items"`
Metadata any `json:"metadata"`
} }
type SnipcartOrderUpdate struct { type SnipcartOrderUpdate struct {
@@ -79,14 +91,38 @@ type SnipcartOrders struct {
Items []SnipcartOrder Items []SnipcartOrder
} }
func NewSnipcartProvider(snipcartApiKey string) SnipcartProvider { type SnipcartTax struct {
return SnipcartProvider{ Name string `json:"name"`
Amount float64 `json:"amount"`
NumberForInvoice string `json:"numberForInvoice"`
Rate float64 `json:"rate"`
}
type SnipcartNotification struct {
Type NotificationType `json:"type"`
DeliveryMethod string `json:"deliveryMethod"`
Message string `json:"message,omitempty"`
}
type SnipcartNotificationResponse struct {
Id string `json:"id"`
Created time.Time `json:"creationDate"`
Type NotificationType `json:"type"`
DeliveryMethod string `json:"deliveryMethod"`
Body string `json:"body"`
Message string `json:"message"`
Subject string `json:"subject"`
SentOn time.Time `json:"sentOn"`
}
func NewClient(snipcartApiKey string) Client {
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 +142,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 +162,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 +179,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
@@ -151,7 +187,6 @@ func (s *SnipcartProvider) UpdateOrder(token string, orderUpdate *SnipcartOrderU
if response.StatusCode < 200 && response.StatusCode >= 300 { if response.StatusCode < 200 && response.StatusCode >= 300 {
return nil, fmt.Errorf("unexpected response received: %s", response.Status) return nil, fmt.Errorf("unexpected response received: %s", response.Status)
} }
fmt.Println(response.Status)
defer response.Body.Close() defer response.Body.Close()
@@ -163,3 +198,20 @@ func (s *SnipcartProvider) UpdateOrder(token string, orderUpdate *SnipcartOrderU
return &responseOrder, nil return &responseOrder, nil
} }
func (s *Client) SendNotification(token string, notification *SnipcartNotification) (*SnipcartNotificationResponse, error) {
response, err := helper.Post(orderUri+"/"+token+"/notifications", "Basic", s.AuthBase64, notification)
if err != nil {
return nil, err
}
defer response.Body.Close()
var responseNotification SnipcartNotificationResponse
err = json.NewDecoder(response.Body).Decode(&responseNotification)
if err != nil {
return nil, err
}
return &responseNotification, nil
}

21
snipcart/webhook.go Normal file
View File

@@ -0,0 +1,21 @@
package snipcart
type SnipcartShippingAddress struct {
FullName string `json:"fullName"`
FirstName string `json:"firstName"`
Name string `json:"name"`
Company string `json:"company"`
Address1 string `json:"address1"`
Address2 string `json:"address2"`
FullAddress string `json:"fullAddress"`
City string `json:"city"`
Country string `json:"country"`
PostalCode string `json:"postalCode"`
Province string `json:"province"`
Phone string `json:"phone"`
VatNumber string `json:"vatNumber,omitempty"`
}
type SnipcartWebhookTaxResponse struct {
Taxes []SnipcartTax `json:"taxes"`
}