Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/bold-commerce/go-shopify
Browse files Browse the repository at this point in the history
…into feature/upstream_access_scopes_and_metafield_support_sync

- Align impl of Metafield
- Add Access Scope
  • Loading branch information
ttyfky committed Jun 16, 2022
2 parents 525a208 + 49ba021 commit 66a2e98
Show file tree
Hide file tree
Showing 14 changed files with 117 additions and 21 deletions.
28 changes: 28 additions & 0 deletions access_scopes.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
package goshopify

type AccessScopesService interface {
List(interface{}) ([]AccessScope, error)
}

type AccessScope struct {
Handle string `json:"handle,omitempty"`
}

// AccessScopesResource represents the result from the oauth/access_scopes.json endpoint
type AccessScopesResource struct {
AccessScopes []AccessScope `json:"access_scopes,omitempty"`
}

// AccessScopesServiceOp handles communication with the Access Scopes
// related methods of the Shopify API
type AccessScopesServiceOp struct {
client *Client
}

// List gets access scopes based on used oauth token
func (s *AccessScopesServiceOp) List(options interface{}) ([]AccessScope, error) {
path := "oauth/access_scopes.json"
resource := new(AccessScopesResource)
err := s.client.Get(path, resource, options)
return resource.AccessScopes, err
}
37 changes: 37 additions & 0 deletions access_scopes_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
package goshopify

import (
"testing"
"fmt"
"reflect"

"github.com/jarcoal/httpmock"
)

func TestAccessScopesServiceOp_List(t *testing.T) {
setup()
defer teardown()

httpmock.RegisterResponder(
"GET",
fmt.Sprintf("https://fooshop.myshopify.com/%s/oauth/access_scopes.json", client.pathPrefix),
httpmock.NewBytesResponder(200, loadFixture("access_scopes.json")),
)

scopeResponse, err := client.AccessScopes.List(nil)
if err != nil {
t.Errorf("AccessScopes.List returned an error: %v", err)
}

expected := []AccessScope{
{
Handle: "scope_1",
},
{
Handle: "scope_2",
},
}
if !reflect.DeepEqual(scopeResponse, expected) {
t.Errorf("AccessScopes.List returned %+v, expected %+v", expected, expected)
}
}
6 changes: 4 additions & 2 deletions customcollection_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,8 @@ func TestCustomCollectionCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -260,7 +261,8 @@ func TestCustomCollectionUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down
6 changes: 4 additions & 2 deletions customer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -371,7 +371,8 @@ func TestCustomerCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -394,7 +395,8 @@ func TestCustomerUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down
10 changes: 10 additions & 0 deletions fixtures/access_scopes.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"access_scopes": [
{
"handle": "scope_1"
},
{
"handle": "scope_2"
}
]
}
3 changes: 2 additions & 1 deletion fixtures/metafield.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@
"namespace": "affiliates",
"key": "app_key",
"value": "app_value",
"type": "string",
"value_type": "string",
"type": "single_line_text_field",
"description": "some amaaazing app's value",
"owner_id": 1,
"created_at": "2016-01-01T00:00:00Z",
Expand Down
4 changes: 3 additions & 1 deletion goshopify.go
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,7 @@ type Client struct {
InventoryItem InventoryItemService
ShippingZone ShippingZoneService
ProductListing ProductListingService
AccessScopes AccessScopesService
}

// A general response error that follows a similar layout to Shopify's response
Expand Down Expand Up @@ -289,6 +290,7 @@ func NewClient(app App, shopName, token string, opts ...Option) *Client {
c.InventoryItem = &InventoryItemServiceOp{client: c}
c.ShippingZone = &ShippingZoneServiceOp{client: c}
c.ProductListing = &ProductListingServiceOp{client: c}
c.AccessScopes = &AccessScopesServiceOp{client: c}

// apply any options
for _, opt := range opts {
Expand Down Expand Up @@ -323,7 +325,7 @@ func (c *Client) doGetHeaders(req *http.Request, v interface{}) (http.Header, er
resp, err = c.Client.Do(req)
c.logResponse(resp)
if err != nil {
return nil, err //http client errors, not api responses
return nil, err // http client errors, not api responses
}

respErr := CheckResponseError(resp)
Expand Down
1 change: 1 addition & 0 deletions metafield.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ type Metafield struct {
ID int64 `json:"id,omitempty"`
Key string `json:"key,omitempty"`
Value interface{} `json:"value,omitempty"`
ValueType string `json:"value_type,omitempty"`
Type string `json:"type,omitempty"`
Namespace string `json:"namespace,omitempty"`
Description string `json:"description,omitempty"`
Expand Down
13 changes: 8 additions & 5 deletions metafield_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,8 @@ func TestMetafieldGet(t *testing.T) {
ID: 1,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
Description: "some amaaazing app's value",
OwnerId: 1,
Expand All @@ -114,7 +115,8 @@ func TestMetafieldCreate(t *testing.T) {
Namespace: "inventory",
Key: "warehouse",
Value: "25",
Type: "integer",
ValueType: "integer",
Type: "single_line_text_field",
}

returnedMetafield, err := client.Metafield.Create(metafield)
Expand All @@ -133,9 +135,10 @@ func TestMetafieldUpdate(t *testing.T) {
httpmock.NewBytesResponder(200, loadFixture("metafield.json")))

metafield := Metafield{
ID: 1,
Value: "something new",
Type: "string",
ID: 1,
Value: "something new",
ValueType: "string",
Type: "single_line_text_field",
}

returnedMetafield, err := client.Metafield.Update(metafield)
Expand Down
6 changes: 4 additions & 2 deletions order_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -548,7 +548,8 @@ func TestOrderCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -571,7 +572,8 @@ func TestOrderUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down
6 changes: 4 additions & 2 deletions page_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,8 @@ func TestPageCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -246,7 +247,8 @@ func TestPageUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down
6 changes: 4 additions & 2 deletions product_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -392,7 +392,8 @@ func TestProductCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -415,7 +416,8 @@ func TestProductUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down
6 changes: 4 additions & 2 deletions smartcollection_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,8 @@ func TestSmartCollectionCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -263,7 +264,8 @@ func TestSmartCollectionUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down
6 changes: 4 additions & 2 deletions variant_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -320,7 +320,8 @@ func TestVariantCreateMetafield(t *testing.T) {
metafield := Metafield{
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand All @@ -343,7 +344,8 @@ func TestVariantUpdateMetafield(t *testing.T) {
ID: 2,
Key: "app_key",
Value: "app_value",
Type: "string",
ValueType: "string",
Type: "single_line_text_field",
Namespace: "affiliates",
}

Expand Down

0 comments on commit 66a2e98

Please sign in to comment.