Compare commits

...

22 Commits

Author SHA1 Message Date
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
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
Bastian de Byl
bfb6497d25 fixed UpdateOrder method 2023-02-26 02:38:14 -05:00
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
Bastian de Byl
41c58a497b added GetOder(token) function 2023-02-25 20:21:48 -05:00
Bastian de Byl
831ad7c029 added order: prefix to TokenPNGBase64 2023-02-25 16:57:10 -05:00
6 changed files with 184 additions and 25 deletions

View File

@@ -7,10 +7,6 @@ import (
"github.com/debyltech/go-snipcart/snipcart"
)
const (
configFile = "config.json"
)
func main() {
snipcartApiKey := flag.String("key", "", "Snipcart API Key")
flag.Parse()
@@ -19,9 +15,9 @@ func main() {
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 {
log.Fatal(err)
}

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

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

5
go.mod
View File

@@ -1,8 +1,9 @@
module github.com/debyltech/go-snipcart
go 1.20
go 1.19
require (
github.com/debyltech/go-helpers v0.0.0-20230224002154-eb55816c71ec
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
)

View File

@@ -6,7 +6,7 @@ import (
"errors"
"fmt"
helper "github.com/debyltech/go-helpers"
helper "github.com/debyltech/go-helpers/json"
"github.com/skip2/go-qrcode"
)
@@ -20,59 +20,102 @@ var (
orderUri = apiUri + ordersPath
)
type SnipcartProvider struct {
type Client struct {
SnipcartKey string
AuthBase64 string
Limit int
}
type SnipcartCustomField struct {
Name string `json:"name"`
Value string `json:"value"`
}
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"`
CustomFieldsJSON string `json:"customFieldsJson"`
UUID string `json:"uniqueId"`
ID string `json:"id"`
Name string `json:"name"`
Quantity int `json:"quantity"`
TotalWeight float64 `json:"totalWeight,omitempty"`
TotalPrice float64 `json:"totalPrice,omitempty"`
CustomFields []SnipcartCustomField `json:"customFields"`
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 {
Token string `json:"token"`
Invoice string `json:"invoiceNumber"`
Subtotal float64 `json:"subtotal,omitempty"`
Currency string `json:"currency,omitempty"`
Total float64 `json:"grandTotal,omitempty"`
Status string `json:"status"`
TotalWeight float64 `json:"totalWeight"`
Email string `json:"email"`
Name string `json:"shippingAddressName"`
Company string `json:"shippingAddressCompanyName"`
Address1 string `json:"shippingAddressAddress1"`
Address2 string `json:"shippingAddressAddress2"`
City string `json:"shippingAddressCity"`
Province string `json:"shippingAddressProvince"`
Country string `json:"shippingAddressCountry"`
PostalCode string `json:"shippingAddressPostalCode"`
Phone string `json:"shippingAddressPhone"`
Phone string `json:"shippingAddressPhone,omitempty"`
Email string `json:"email,omitempty"`
TrackingNumber string `json:"trackingNumber"`
TrackingUrl string `json:"trackingUrl"`
ShippingCost float64 `json:"shippingFees"`
Items []SnipcartItem `json:"items"`
}
type SnipcartOrderUpdate struct {
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
}
func NewSnipcartProvider(snipcartApiKey string) SnipcartProvider {
return SnipcartProvider{
func NewClient(snipcartApiKey string) Client {
return Client{
SnipcartKey: snipcartApiKey,
AuthBase64: base64.StdEncoding.EncodeToString([]byte(snipcartApiKey + ":")),
}
}
func (s *SnipcartProvider) GetOrders(queries map[string]string) (*SnipcartOrders, error) {
func (s *Client) GetOrder(token string) (*SnipcartOrder, error) {
response, err := helper.Get(orderUri+"/"+token, "Basic", s.AuthBase64, nil)
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 order SnipcartOrder
err = json.NewDecoder(response.Body).Decode(&order)
if err != nil {
return nil, err
}
return &order, nil
}
func (s *Client) GetOrders(queries map[string]string) (*SnipcartOrders, error) {
response, err := helper.Get(orderUri, "Basic", s.AuthBase64, queries)
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)
}
@@ -87,7 +130,7 @@ func (s *SnipcartProvider) GetOrders(queries map[string]string) (*SnipcartOrders
return &orders, nil
}
func (s *SnipcartProvider) GetOrdersByStatus(status OrderStatus) (*SnipcartOrders, error) {
func (s *Client) GetOrdersByStatus(status OrderStatus) (*SnipcartOrders, error) {
if status == "" {
return nil, errors.New("status is not set")
}
@@ -96,10 +139,31 @@ func (s *SnipcartProvider) GetOrdersByStatus(status OrderStatus) (*SnipcartOrder
}
func (o *SnipcartOrder) TokenPNGBase64() (string, error) {
img, err := qrcode.Encode(o.Token, qrcode.Medium, 128)
img, err := qrcode.Encode("order:"+o.Token, qrcode.Medium, 128)
if err != nil {
return "", err
}
return base64.StdEncoding.EncodeToString(img), nil
}
func (s *Client) UpdateOrder(token string, orderUpdate *SnipcartOrderUpdate) (*SnipcartOrder, error) {
response, err := helper.Put(orderUri+"/"+token, "Basic", s.AuthBase64, orderUpdate)
if err != nil {
return nil, err
}
if response.StatusCode < 200 && response.StatusCode >= 300 {
return nil, fmt.Errorf("unexpected response received: %s", response.Status)
}
fmt.Println(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
}

View File

@@ -0,0 +1,33 @@
package webhook
import (
"bytes"
"encoding/json"
"io/ioutil"
"github.com/debyltech/go-shippr/shippo"
)
type Config struct {
ShippoApiKey string `json:"shippo_api_key"`
WeightUnit string `json:"weight_unit"`
DimensionUnit string `json:"dimension_unit"`
ManufactureCountry string `json:"manufacture_country"`
SenderAddress shippo.Address `json:"sender_address"`
DefaultParcel shippo.Parcel `json:"default_parcel"`
}
func NewConfigFromFile(filePath string) (*Config, error) {
configBytes, err := ioutil.ReadFile(filePath)
if err != nil {
return nil, err
}
var config Config
err = json.NewDecoder(bytes.NewBuffer(configBytes)).Decode(&config)
if err != nil {
return nil, err
}
return &config, nil
}