duodealer_api 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.document +5 -0
- data/.gitignore +13 -0
- data/.rubocop.yml +8 -0
- data/.travis.yml +23 -0
- data/Gemfile +5 -0
- data/Gemfile_ar41 +5 -0
- data/Gemfile_ar50 +5 -0
- data/Gemfile_ar51 +5 -0
- data/Gemfile_ar_master +5 -0
- data/RELEASING +13 -0
- data/Rakefile +44 -0
- data/docker-compose.yml +13 -0
- data/docs/graphql.md +191 -0
- data/duodealer_api.gemspec +38 -0
- data/lib/active_resource/connection_ext.rb +10 -0
- data/lib/active_resource/detailed_log_subscriber.rb +52 -0
- data/lib/active_resource/json_errors.rb +31 -0
- data/lib/duodealer_api.rb +33 -0
- data/lib/duodealer_api/api_version.rb +205 -0
- data/lib/duodealer_api/connection.rb +35 -0
- data/lib/duodealer_api/countable.rb +14 -0
- data/lib/duodealer_api/disable_prefix_check.rb +31 -0
- data/lib/duodealer_api/events.rb +7 -0
- data/lib/duodealer_api/graphql.rb +79 -0
- data/lib/duodealer_api/graphql/http_client.rb +22 -0
- data/lib/duodealer_api/graphql/railtie.rb +17 -0
- data/lib/duodealer_api/graphql/task.rake +97 -0
- data/lib/duodealer_api/limits.rb +76 -0
- data/lib/duodealer_api/message_enricher.rb +23 -0
- data/lib/duodealer_api/meta.rb +15 -0
- data/lib/duodealer_api/metafields.rb +20 -0
- data/lib/duodealer_api/paginated_collection.rb +69 -0
- data/lib/duodealer_api/pagination_link_headers.rb +33 -0
- data/lib/duodealer_api/resources.rb +3 -0
- data/lib/duodealer_api/resources/abandoned_checkout.rb +7 -0
- data/lib/duodealer_api/resources/access_scope.rb +10 -0
- data/lib/duodealer_api/resources/access_token.rb +8 -0
- data/lib/duodealer_api/resources/address.rb +4 -0
- data/lib/duodealer_api/resources/announcement.rb +4 -0
- data/lib/duodealer_api/resources/api_permission.rb +9 -0
- data/lib/duodealer_api/resources/application_charge.rb +15 -0
- data/lib/duodealer_api/resources/application_credit.rb +4 -0
- data/lib/duodealer_api/resources/array_base.rb +13 -0
- data/lib/duodealer_api/resources/article.rb +21 -0
- data/lib/duodealer_api/resources/asset.rb +100 -0
- data/lib/duodealer_api/resources/assigned_fulfillment_order.rb +16 -0
- data/lib/duodealer_api/resources/base.rb +162 -0
- data/lib/duodealer_api/resources/billing_address.rb +4 -0
- data/lib/duodealer_api/resources/blog.rb +10 -0
- data/lib/duodealer_api/resources/carrier_service.rb +4 -0
- data/lib/duodealer_api/resources/cart.rb +4 -0
- data/lib/duodealer_api/resources/checkout.rb +30 -0
- data/lib/duodealer_api/resources/collect.rb +6 -0
- data/lib/duodealer_api/resources/collection.rb +14 -0
- data/lib/duodealer_api/resources/collection_listing.rb +18 -0
- data/lib/duodealer_api/resources/collection_publication.rb +10 -0
- data/lib/duodealer_api/resources/comment.rb +9 -0
- data/lib/duodealer_api/resources/country.rb +4 -0
- data/lib/duodealer_api/resources/currency.rb +6 -0
- data/lib/duodealer_api/resources/custom_collection.rb +19 -0
- data/lib/duodealer_api/resources/customer.rb +29 -0
- data/lib/duodealer_api/resources/customer_group.rb +5 -0
- data/lib/duodealer_api/resources/customer_invite.rb +4 -0
- data/lib/duodealer_api/resources/customer_saved_search.rb +11 -0
- data/lib/duodealer_api/resources/discount_code.rb +9 -0
- data/lib/duodealer_api/resources/draft_order.rb +14 -0
- data/lib/duodealer_api/resources/draft_order_invoice.rb +4 -0
- data/lib/duodealer_api/resources/event.rb +8 -0
- data/lib/duodealer_api/resources/fulfillment.rb +47 -0
- data/lib/duodealer_api/resources/fulfillment_event.rb +15 -0
- data/lib/duodealer_api/resources/fulfillment_order.rb +137 -0
- data/lib/duodealer_api/resources/fulfillment_order_locations_for_move.rb +4 -0
- data/lib/duodealer_api/resources/fulfillment_request.rb +15 -0
- data/lib/duodealer_api/resources/fulfillment_service.rb +4 -0
- data/lib/duodealer_api/resources/fulfillment_v2.rb +20 -0
- data/lib/duodealer_api/resources/gift_card.rb +7 -0
- data/lib/duodealer_api/resources/image.rb +16 -0
- data/lib/duodealer_api/resources/inventory_item.rb +6 -0
- data/lib/duodealer_api/resources/inventory_level.rb +55 -0
- data/lib/duodealer_api/resources/line_item.rb +14 -0
- data/lib/duodealer_api/resources/location.rb +8 -0
- data/lib/duodealer_api/resources/marketing_event.rb +10 -0
- data/lib/duodealer_api/resources/metafield.rb +13 -0
- data/lib/duodealer_api/resources/note_attribute.rb +4 -0
- data/lib/duodealer_api/resources/option.rb +4 -0
- data/lib/duodealer_api/resources/order.rb +43 -0
- data/lib/duodealer_api/resources/order_risk.rb +8 -0
- data/lib/duodealer_api/resources/page.rb +6 -0
- data/lib/duodealer_api/resources/payment.rb +7 -0
- data/lib/duodealer_api/resources/payment_details.rb +4 -0
- data/lib/duodealer_api/resources/ping.rb +3 -0
- data/lib/duodealer_api/resources/policy.rb +7 -0
- data/lib/duodealer_api/resources/price_rule.rb +8 -0
- data/lib/duodealer_api/resources/product.rb +35 -0
- data/lib/duodealer_api/resources/product_listing.rb +16 -0
- data/lib/duodealer_api/resources/product_publication.rb +10 -0
- data/lib/duodealer_api/resources/province.rb +5 -0
- data/lib/duodealer_api/resources/publication.rb +5 -0
- data/lib/duodealer_api/resources/receipt.rb +4 -0
- data/lib/duodealer_api/resources/recurring_application_charge.rb +31 -0
- data/lib/duodealer_api/resources/redirect.rb +4 -0
- data/lib/duodealer_api/resources/refund.rb +14 -0
- data/lib/duodealer_api/resources/report.rb +4 -0
- data/lib/duodealer_api/resources/resource_feedback.rb +19 -0
- data/lib/duodealer_api/resources/rule.rb +4 -0
- data/lib/duodealer_api/resources/script_tag.rb +4 -0
- data/lib/duodealer_api/resources/shipping_address.rb +4 -0
- data/lib/duodealer_api/resources/shipping_line.rb +4 -0
- data/lib/duodealer_api/resources/shipping_rate.rb +7 -0
- data/lib/duodealer_api/resources/shipping_zone.rb +4 -0
- data/lib/duodealer_api/resources/shop.rb +25 -0
- data/lib/duodealer_api/resources/smart_collection.rb +19 -0
- data/lib/duodealer_api/resources/storefront_access_token.rb +4 -0
- data/lib/duodealer_api/resources/tax_line.rb +4 -0
- data/lib/duodealer_api/resources/tax_service.rb +4 -0
- data/lib/duodealer_api/resources/tender_transaction.rb +6 -0
- data/lib/duodealer_api/resources/theme.rb +4 -0
- data/lib/duodealer_api/resources/transaction.rb +5 -0
- data/lib/duodealer_api/resources/usage_charge.rb +5 -0
- data/lib/duodealer_api/resources/user.rb +4 -0
- data/lib/duodealer_api/resources/variant.rb +8 -0
- data/lib/duodealer_api/resources/webhook.rb +4 -0
- data/lib/duodealer_api/session.rb +171 -0
- data/lib/duodealer_api/version.rb +3 -0
- data/shipit.rubygems.yml +1 -0
- data/test/abandoned_checkouts_test.rb +29 -0
- data/test/access_scope_test.rb +23 -0
- data/test/access_token_test.rb +19 -0
- data/test/active_resource/json_errors_test.rb +19 -0
- data/test/api_permission_test.rb +9 -0
- data/test/api_version_test.rb +157 -0
- data/test/application_charge_test.rb +79 -0
- data/test/application_credit_test.rb +35 -0
- data/test/article_test.rb +73 -0
- data/test/asset_test.rb +18 -0
- data/test/assigned_fulfillment_order_test.rb +77 -0
- data/test/base_test.rb +198 -0
- data/test/blog_test.rb +8 -0
- data/test/carrier_service_test.rb +17 -0
- data/test/cart_test.rb +13 -0
- data/test/checkouts_test.rb +77 -0
- data/test/collect_test.rb +9 -0
- data/test/collection_listing_test.rb +79 -0
- data/test/collection_publication_test.rb +40 -0
- data/test/collection_test.rb +49 -0
- data/test/countable_test.rb +13 -0
- data/test/currency_test.rb +21 -0
- data/test/custom_collection_test.rb +9 -0
- data/test/customer_saved_search_test.rb +27 -0
- data/test/customer_test.rb +50 -0
- data/test/detailed_log_subscriber_test.rb +139 -0
- data/test/discount_code_test.rb +53 -0
- data/test/draft_order_test.rb +151 -0
- data/test/fixtures/abandoned_checkout.json +184 -0
- data/test/fixtures/abandoned_checkouts.json +186 -0
- data/test/fixtures/access_scopes.json +10 -0
- data/test/fixtures/access_token_delegate.json +4 -0
- data/test/fixtures/api_versions.json +38 -0
- data/test/fixtures/apis.json +42 -0
- data/test/fixtures/application_charge.json +16 -0
- data/test/fixtures/application_charges.json +57 -0
- data/test/fixtures/application_credit.json +12 -0
- data/test/fixtures/application_credits.json +24 -0
- data/test/fixtures/article.json +15 -0
- data/test/fixtures/articles.json +39 -0
- data/test/fixtures/asset.json +9 -0
- data/test/fixtures/assets.json +136 -0
- data/test/fixtures/assigned_fulfillment_orders.json +78 -0
- data/test/fixtures/authors.json +1 -0
- data/test/fixtures/blog.json +13 -0
- data/test/fixtures/blogs.json +13 -0
- data/test/fixtures/carrier_service.json +9 -0
- data/test/fixtures/carts.json +43 -0
- data/test/fixtures/checkout.json +160 -0
- data/test/fixtures/checkouts.json +162 -0
- data/test/fixtures/collect.json +12 -0
- data/test/fixtures/collection.json +17 -0
- data/test/fixtures/collection_listing.json +11 -0
- data/test/fixtures/collection_listing_product_ids.json +1 -0
- data/test/fixtures/collection_listing_product_ids2.json +1 -0
- data/test/fixtures/collection_listings.json +13 -0
- data/test/fixtures/collection_products.json +47 -0
- data/test/fixtures/collection_publication.json +11 -0
- data/test/fixtures/collection_publications.json +13 -0
- data/test/fixtures/currencies.json +25 -0
- data/test/fixtures/custom_collection.json +17 -0
- data/test/fixtures/customer_invite.json +9 -0
- data/test/fixtures/customer_saved_search.json +9 -0
- data/test/fixtures/customer_saved_search_customers.json +60 -0
- data/test/fixtures/customers.json +59 -0
- data/test/fixtures/customers_account_activation_url.json +3 -0
- data/test/fixtures/customers_search.json +60 -0
- data/test/fixtures/discount_code.json +10 -0
- data/test/fixtures/discount_codes.json +12 -0
- data/test/fixtures/draft_order.json +159 -0
- data/test/fixtures/draft_order_completed.json +159 -0
- data/test/fixtures/draft_order_invoice.json +9 -0
- data/test/fixtures/draft_orders.json +161 -0
- data/test/fixtures/engagement.json +15 -0
- data/test/fixtures/events.json +31 -0
- data/test/fixtures/fulfillment.json +49 -0
- data/test/fixtures/fulfillment_event.json +12 -0
- data/test/fixtures/fulfillment_order.json +38 -0
- data/test/fixtures/fulfillment_order_locations_for_move.json +18 -0
- data/test/fixtures/fulfillment_orders.json +78 -0
- data/test/fixtures/fulfillment_request.json +28 -0
- data/test/fixtures/fulfillment_service.json +10 -0
- data/test/fixtures/fulfillments.json +53 -0
- data/test/fixtures/gift_card.json +20 -0
- data/test/fixtures/gift_card_disabled.json +20 -0
- data/test/fixtures/graphql/2019-10.json +1083 -0
- data/test/fixtures/graphql/dummy_schema.rb +16 -0
- data/test/fixtures/graphql/unstable.json +1083 -0
- data/test/fixtures/image.json +10 -0
- data/test/fixtures/images.json +20 -0
- data/test/fixtures/inventory_level.json +7 -0
- data/test/fixtures/inventory_levels.json +24 -0
- data/test/fixtures/marketing_event.json +28 -0
- data/test/fixtures/marketing_events.json +54 -0
- data/test/fixtures/metafield.json +12 -0
- data/test/fixtures/metafields.json +34 -0
- data/test/fixtures/order.json +297 -0
- data/test/fixtures/order_risk.json +14 -0
- data/test/fixtures/order_risks.json +28 -0
- data/test/fixtures/order_with_properties.json +373 -0
- data/test/fixtures/orders.json +299 -0
- data/test/fixtures/payment.json +7 -0
- data/test/fixtures/payments.json +9 -0
- data/test/fixtures/ping/conversation.json +1 -0
- data/test/fixtures/ping/failed_delivery_confirmation.json +1 -0
- data/test/fixtures/ping/message.json +1 -0
- data/test/fixtures/ping/successful_delivery_confirmation.json +1 -0
- data/test/fixtures/policies.json +8 -0
- data/test/fixtures/price_rule.json +27 -0
- data/test/fixtures/price_rules.json +28 -0
- data/test/fixtures/product.json +116 -0
- data/test/fixtures/product_listing.json +86 -0
- data/test/fixtures/product_listing_product_ids.json +1 -0
- data/test/fixtures/product_listing_product_ids2.json +1 -0
- data/test/fixtures/product_listings.json +174 -0
- data/test/fixtures/product_publication.json +11 -0
- data/test/fixtures/product_publications.json +13 -0
- data/test/fixtures/publications.json +9 -0
- data/test/fixtures/recurring_application_charge.json +22 -0
- data/test/fixtures/recurring_application_charge_adjustment.json +5 -0
- data/test/fixtures/recurring_application_charges.json +106 -0
- data/test/fixtures/redirect.json +7 -0
- data/test/fixtures/refund.json +112 -0
- data/test/fixtures/report.json +9 -0
- data/test/fixtures/reports.json +11 -0
- data/test/fixtures/script_tag.json +10 -0
- data/test/fixtures/script_tags.json +18 -0
- data/test/fixtures/shipping_rates.json +12 -0
- data/test/fixtures/shipping_zones.json +315 -0
- data/test/fixtures/shop.json +26 -0
- data/test/fixtures/smart_collection.json +21 -0
- data/test/fixtures/smart_collection_products.json +155 -0
- data/test/fixtures/storefront_access_token.json +9 -0
- data/test/fixtures/storefront_access_tokens.json +18 -0
- data/test/fixtures/tags.json +1 -0
- data/test/fixtures/tax_service.json +9 -0
- data/test/fixtures/tender_transactions.json +52 -0
- data/test/fixtures/transaction.json +29 -0
- data/test/fixtures/usage_charge.json +11 -0
- data/test/fixtures/usage_charges.json +23 -0
- data/test/fixtures/user.json +21 -0
- data/test/fixtures/users.json +42 -0
- data/test/fixtures/variant.json +23 -0
- data/test/fixtures/variants.json +88 -0
- data/test/fixtures/webhook.json +10 -0
- data/test/fixtures/webhooks.json +18 -0
- data/test/fulfillment_event_test.rb +69 -0
- data/test/fulfillment_order_test.rb +462 -0
- data/test/fulfillment_order_test_helper.rb +7 -0
- data/test/fulfillment_request_test.rb +33 -0
- data/test/fulfillment_service_test.rb +17 -0
- data/test/fulfillment_test.rb +224 -0
- data/test/fulfillment_v2_test.rb +62 -0
- data/test/gift_card_test.rb +22 -0
- data/test/graphql/http_client_test.rb +26 -0
- data/test/graphql_test.rb +147 -0
- data/test/image_test.rb +39 -0
- data/test/inventory_level_test.rb +59 -0
- data/test/lib/webmock_extensions/last_request.rb +16 -0
- data/test/limits_test.rb +38 -0
- data/test/location_test.rb +14 -0
- data/test/marketing_event_test.rb +68 -0
- data/test/message_enricher_test.rb +45 -0
- data/test/meta_test.rb +49 -0
- data/test/metafield_test.rb +46 -0
- data/test/order_risk_test.rb +46 -0
- data/test/order_test.rb +125 -0
- data/test/pagination_test.rb +257 -0
- data/test/payment_test.rb +19 -0
- data/test/policy_test.rb +19 -0
- data/test/price_rule_test.rb +65 -0
- data/test/product_listing_test.rb +97 -0
- data/test/product_publication_test.rb +40 -0
- data/test/product_test.rb +60 -0
- data/test/publication_test.rb +12 -0
- data/test/recurring_application_charge_test.rb +142 -0
- data/test/redirect_test.rb +9 -0
- data/test/refund_test.rb +32 -0
- data/test/report_test.rb +35 -0
- data/test/resource_feedback_test.rb +42 -0
- data/test/script_tag_test.rb +30 -0
- data/test/session_test.rb +366 -0
- data/test/shipping_rate_test.rb +17 -0
- data/test/shipping_zone_test.rb +10 -0
- data/test/shop_test.rb +68 -0
- data/test/smart_collection_test.rb +35 -0
- data/test/storefront_access_token_test.rb +32 -0
- data/test/tax_service_test.rb +9 -0
- data/test/tender_transaction_test.rb +18 -0
- data/test/test_helper.rb +124 -0
- data/test/transaction_test.rb +17 -0
- data/test/usage_charge_test.rb +21 -0
- data/test/user_test.rb +17 -0
- data/test/variant_test.rb +46 -0
- data/test/webhook_test.rb +21 -0
- metadata +541 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: b4265e6139d66455a7dbd091d56cd085f2e7ec337721256678771c408486f657
|
4
|
+
data.tar.gz: f145162ae13aeb3f5faf148252b49e5e8f0e3605d95fa96880ba396b4847075d
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 92f7734605809972f78d8845dc209a424e86327488d05edaf716dca9873f1e6786d1f2cea700a1cbb9e735acffec5871d4ae7e043ad68c7fd5f9128c75a836b4
|
7
|
+
data.tar.gz: af7dbc96a95bc64d76ab7aeb72cc977b82a44aabb6f96e8a38fc999cc38ba642142fb7cedbff51dc9f43368ef0cee847898e41c5e154ac33560f16f5866d8d7a
|
data/.document
ADDED
data/.gitignore
ADDED
data/.rubocop.yml
ADDED
data/.travis.yml
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
language: ruby
|
2
|
+
sudo: false
|
3
|
+
|
4
|
+
rvm:
|
5
|
+
- 2.4.6
|
6
|
+
- 2.5.5
|
7
|
+
- 2.6.2
|
8
|
+
|
9
|
+
gemfile:
|
10
|
+
- Gemfile_ar41
|
11
|
+
- Gemfile_ar50
|
12
|
+
- Gemfile_ar51
|
13
|
+
- Gemfile_ar_master
|
14
|
+
|
15
|
+
matrix:
|
16
|
+
fast_finish: true
|
17
|
+
allow_failures:
|
18
|
+
- rvm: 2.4.6
|
19
|
+
gemfile: Gemfile_ar_master
|
20
|
+
- rvm: 2.5.5
|
21
|
+
gemfile: Gemfile_ar_master
|
22
|
+
- rvm: 2.6.2
|
23
|
+
gemfile: Gemfile_ar_master
|
data/Gemfile
ADDED
data/Gemfile_ar41
ADDED
data/Gemfile_ar50
ADDED
data/Gemfile_ar51
ADDED
data/Gemfile_ar_master
ADDED
data/RELEASING
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
Releasing DuodealerAPI
|
2
|
+
|
3
|
+
1. Check the Semantic Versioning page for info on how to version the new release: http://semver.org
|
4
|
+
2. Update the version of DuodealerAPI in lib/duodealer_api/version.rb
|
5
|
+
3. Add a CHANGELOG entry for the new release
|
6
|
+
4. Commit the changes with a commit message like "Packaging for release X.Y.Z"
|
7
|
+
5. Tag the release with the version (Leave REV blank for HEAD or provide a SHA)
|
8
|
+
$ git tag vX.Y.Z REV
|
9
|
+
6. Push out the changes
|
10
|
+
$ git push
|
11
|
+
7. Push out the tags
|
12
|
+
$ git push --tags
|
13
|
+
8. Publish the gem using Shipit
|
data/Rakefile
ADDED
@@ -0,0 +1,44 @@
|
|
1
|
+
require 'rake'
|
2
|
+
require "bundler/gem_tasks"
|
3
|
+
|
4
|
+
require 'rake/testtask'
|
5
|
+
Rake::TestTask.new(:test) do |test|
|
6
|
+
test.libs << 'lib' << 'test'
|
7
|
+
test.pattern = 'test/**/*_test.rb'
|
8
|
+
test.warning = false
|
9
|
+
end
|
10
|
+
|
11
|
+
begin
|
12
|
+
require 'rcov/rcovtask'
|
13
|
+
Rcov::RcovTask.new do |test|
|
14
|
+
test.libs << 'test'
|
15
|
+
test.pattern = 'test/**/*_test.rb'
|
16
|
+
test.verbose = true
|
17
|
+
end
|
18
|
+
rescue LoadError
|
19
|
+
task :rcov do
|
20
|
+
abort "RCov is not available. In order to run rcov, you must: sudo gem install spicycode-rcov"
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
task :default => :test
|
25
|
+
|
26
|
+
require 'rdoc/task'
|
27
|
+
Rake::RDocTask.new do |rdoc|
|
28
|
+
if File.exist?('VERSION.yml')
|
29
|
+
config = YAML.load(File.read('VERSION.yml'))
|
30
|
+
version = "#{config[:major]}.#{config[:minor]}.#{config[:patch]}"
|
31
|
+
else
|
32
|
+
version = ""
|
33
|
+
end
|
34
|
+
|
35
|
+
rdoc.rdoc_dir = 'rdoc'
|
36
|
+
rdoc.title = "duodealer_api #{version}"
|
37
|
+
rdoc.rdoc_files.include('README*')
|
38
|
+
rdoc.rdoc_files.include('lib/**/*.rb')
|
39
|
+
end
|
40
|
+
|
41
|
+
task :docker do
|
42
|
+
cmd = "docker-compose up -d && docker exec -i -t duodealer_api bash"
|
43
|
+
exec(cmd, err: File::NULL)
|
44
|
+
end
|
data/docker-compose.yml
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
version: '3.5'
|
2
|
+
services:
|
3
|
+
api:
|
4
|
+
container_name: duodealer_api
|
5
|
+
image: ruby:2.6
|
6
|
+
working_dir: /duodealer_api
|
7
|
+
volumes:
|
8
|
+
- .:/duodealer_api
|
9
|
+
- bundle:/usr/local/bundle
|
10
|
+
command: bash -c "bundle install && tail -f /dev/null"
|
11
|
+
|
12
|
+
volumes:
|
13
|
+
bundle:
|
data/docs/graphql.md
ADDED
@@ -0,0 +1,191 @@
|
|
1
|
+
# GraphQL client
|
2
|
+
|
3
|
+
The `duodealer_api` gem includes a full featured GraphQL client to interact with
|
4
|
+
DuoDealer's [GraphQL Admin API](https://help.duodealer.com/en/api/graphql-admin-api).
|
5
|
+
GitHub's [graphql-client](https://github.com/github/graphql-client) is used as
|
6
|
+
the underlying client and this library integrates it with our existing
|
7
|
+
session, authentication, and API versioning features.
|
8
|
+
|
9
|
+
## Example
|
10
|
+
|
11
|
+
```ruby
|
12
|
+
client = DuodealerAPI::GraphQL.client
|
13
|
+
|
14
|
+
SHOP_NAME_QUERY = client.parse <<-'GRAPHQL'
|
15
|
+
{
|
16
|
+
shop {
|
17
|
+
name
|
18
|
+
}
|
19
|
+
}
|
20
|
+
GRAPHQL
|
21
|
+
|
22
|
+
result = client.query(SHOP_NAME_QUERY)
|
23
|
+
result.data.shop.name
|
24
|
+
```
|
25
|
+
|
26
|
+
* [Getting started](#getting-started)
|
27
|
+
* [Rails integration](#rails-integration)
|
28
|
+
* [API versioning](#api-versioning)
|
29
|
+
* [Initialization process](#initialization-process)
|
30
|
+
* [Migration guide](#migration-guide)
|
31
|
+
|
32
|
+
## Getting started
|
33
|
+
|
34
|
+
1. [Dump the schema](#dump-the-schema)
|
35
|
+
2. [Configure session/authencation](#sessions-and-authentication)
|
36
|
+
3. [Make queries](#make-queries)
|
37
|
+
|
38
|
+
### Dump the schema
|
39
|
+
One of the main benefits of GraphQL is its [schema and type system](https://graphql.org/learn/schema/)
|
40
|
+
which enables tools like graphql-client to ensure your queries are valid in development.
|
41
|
+
|
42
|
+
So the first step in making GraphQL queries is having a local JSON file of DuoDealer's Admin schema.
|
43
|
+
This gem provides a `duodealer_api:graphql:dump` Rake task to make it as easy as possible:
|
44
|
+
|
45
|
+
```bash
|
46
|
+
$ rake duodealer_api:graphql:dump SHOP_URL="https://API_KEY:PASSWORD@SHOP_NAME.duodealer.com" API_VERSION=2020-01
|
47
|
+
```
|
48
|
+
|
49
|
+
If successful `db/duodealer_graphql_schemas/2020-01.json` will be created.
|
50
|
+
|
51
|
+
You can either use private app authentication or an OAuth access token. Run `rake duodealer_api:graphql:dump`
|
52
|
+
to see full usage details.
|
53
|
+
|
54
|
+
If you're using duodealer_api in a Rails app, the default location for schema files is `db/duodealer_graphql_schemas`.
|
55
|
+
For non-Rails applications, the default is `duodealer_graphql_schemas` in your project root.
|
56
|
+
|
57
|
+
The schema path location can be changed via `DuodealerAPI::GraphQL.schema_location`:
|
58
|
+
|
59
|
+
```ruby
|
60
|
+
DuodealerAPI::GraphQL.schema_location = 'assets/schemas'
|
61
|
+
```
|
62
|
+
|
63
|
+
#### Updating schemas
|
64
|
+
Each time you want to use a new API version, or update an existing one
|
65
|
+
(such as the `unstable` version), simply run the Rake task again to overwrite the file.
|
66
|
+
|
67
|
+
### Sessions and authentication
|
68
|
+
The GraphQL client is designed to be integrated with the rest of duodealer_api so
|
69
|
+
all its features such as sessions, authentication, and API versioning work the
|
70
|
+
exact same.
|
71
|
+
|
72
|
+
If you've already been using the duodealer_api gem in your application to make
|
73
|
+
REST API calls then no other configuration is necessary.
|
74
|
+
|
75
|
+
Steps 1-5 of our main [Getting started](https://gitlab.com/duodealer/duodealer_api#getting-started)
|
76
|
+
section still apply for the GraphQL client as well.
|
77
|
+
|
78
|
+
### Make queries
|
79
|
+
Now that you've dumped a schema file and configured an authenticated session, you can make GraphQL API requests.
|
80
|
+
graphql-client encourages all queries to be defined statically as constants:
|
81
|
+
|
82
|
+
```ruby
|
83
|
+
SHOP_NAME_QUERY = DuodealerAPI::GraphQL.client.parse <<-'GRAPHQL'
|
84
|
+
{
|
85
|
+
shop {
|
86
|
+
name
|
87
|
+
}
|
88
|
+
}
|
89
|
+
GRAPHQL
|
90
|
+
|
91
|
+
result = DuodealerAPI::GraphQL.client.query(SHOP_NAME_QUERY)
|
92
|
+
result.data.shop.name
|
93
|
+
```
|
94
|
+
|
95
|
+
But we've also enabled its `allow_dynamic_queries` option if you prefer:
|
96
|
+
|
97
|
+
```ruby
|
98
|
+
query = DuodealerAPI::GraphQL.client.parse <<-'GRAPHQL'
|
99
|
+
{
|
100
|
+
shop {
|
101
|
+
name
|
102
|
+
}
|
103
|
+
}
|
104
|
+
GRAPHQL
|
105
|
+
|
106
|
+
result = DuodealerAPI::GraphQL.client.query(query)
|
107
|
+
result.data.shop.name
|
108
|
+
```
|
109
|
+
|
110
|
+
See the [graphql-client documentation](https://github.com/github/graphql-client#defining-queries)
|
111
|
+
for more details on defining and executing queries.
|
112
|
+
|
113
|
+
## Rails integration
|
114
|
+
`DuodealerAPI::GraphQL` integrates with Rails to automatically do the following:
|
115
|
+
|
116
|
+
* load the `duodealer_api:graphql:dump` Rake task
|
117
|
+
* set the `schema_location` to be in the `db` directory in your Rails root
|
118
|
+
* initialize clients in the Rails app initializer phase
|
119
|
+
|
120
|
+
## API versioning
|
121
|
+
`DuodealerAPI::GraphQL` is version aware and lets you easily make queries to multiple
|
122
|
+
API versions through version specific clients if need be.
|
123
|
+
|
124
|
+
If you have multiple clients and need to be explicit you can specify the version parameter:
|
125
|
+
|
126
|
+
```ruby
|
127
|
+
DuodealerAPI::GraphQL.client # defaults to the client using DuodealerAPI::Base.api_version
|
128
|
+
DuodealerAPI::GraphQL.client('unstable')
|
129
|
+
```
|
130
|
+
|
131
|
+
## Initialization process
|
132
|
+
`DuodealerAPI::GraphQL` is a thin integration layer which initializes `GraphQL::Client`s
|
133
|
+
from local schema files.
|
134
|
+
|
135
|
+
`DuodealerAPI::GraphQL.initialize_clients` scans `DuodealerAPI::GraphQL.schema_location`
|
136
|
+
and creates a client for each version specific schema file found.
|
137
|
+
|
138
|
+
This happens automatically in a Rails application due to our [integration](#rails-integration).
|
139
|
+
For non-Rails applications, ensure you call `DuodealerAPI::GraphQL.initialize_clients`
|
140
|
+
during your boot process.
|
141
|
+
|
142
|
+
The goal is to have all clients created at boot so there's no schema loading,
|
143
|
+
parsing, or client instantiation done during runtime when your app serves a request.
|
144
|
+
|
145
|
+
## Migration guide
|
146
|
+
Prior to duodealer_api v9.0 the GraphQL client implementation was limited and almost
|
147
|
+
unusable due to the client making dynamic introspection queries to Duo Dealer's API.
|
148
|
+
This was not only very slow but also led to unbounded memory growth.
|
149
|
+
|
150
|
+
There are two steps to migrate to the new client:
|
151
|
+
1. [Dump a local schema file](#dump-the-schema)
|
152
|
+
2. [Migrate `client` usage](#migrate-usage)
|
153
|
+
|
154
|
+
### Migrate usage
|
155
|
+
|
156
|
+
Previously a client was initialized with `DuodealerAPI::GraphQL.new`:
|
157
|
+
```ruby
|
158
|
+
client = DuodealerAPI::GraphQL.new
|
159
|
+
|
160
|
+
SHOP_NAME_QUERY = client.parse <<-'GRAPHQL'
|
161
|
+
{
|
162
|
+
shop {
|
163
|
+
name
|
164
|
+
}
|
165
|
+
}
|
166
|
+
GRAPHQL
|
167
|
+
|
168
|
+
result = client.query(SHOP_NAME_QUERY)
|
169
|
+
result.data.shop.name
|
170
|
+
```
|
171
|
+
|
172
|
+
Now there's no need to initialize a client so all references to
|
173
|
+
`DuodealerAPI::GraphQL.new` should be removed and instead the client is called
|
174
|
+
via `DuodealerAPI::GraphQL.client`:
|
175
|
+
|
176
|
+
```ruby
|
177
|
+
client = DuodealerAPI::GraphQL.client
|
178
|
+
|
179
|
+
SHOP_NAME_QUERY = client.parse <<-'GRAPHQL'
|
180
|
+
{
|
181
|
+
shop {
|
182
|
+
name
|
183
|
+
}
|
184
|
+
}
|
185
|
+
GRAPHQL
|
186
|
+
|
187
|
+
result = client.query(SHOP_NAME_QUERY)
|
188
|
+
result.data.shop.name
|
189
|
+
```
|
190
|
+
|
191
|
+
See [making queries](#making-queries) for more usage details.
|
@@ -0,0 +1,38 @@
|
|
1
|
+
$:.push File.expand_path("../lib", __FILE__)
|
2
|
+
require "duodealer_api/version"
|
3
|
+
|
4
|
+
Gem::Specification.new do |s|
|
5
|
+
s.name = %q{duodealer_api}
|
6
|
+
s.version = DuodealerAPI::VERSION
|
7
|
+
s.author = "Eric Raio"
|
8
|
+
|
9
|
+
s.summary = %q{The Duo Dealer API gem is a lightweight gem for accessing the Duo Dealer admin GraphQL web services}
|
10
|
+
s.description = %q{The Duo Dealer API gem allows Ruby developers to programmatically access the admin section of Duo Dealer stores. The API is implemented as JSON or XML over HTTP using all four verbs (GET/POST/PUT/DELETE). Each resource, like Order, Product, or Collection, has its own URL and is manipulated in isolation.}
|
11
|
+
s.email = %q{careers@duodealer.com}
|
12
|
+
s.homepage = %q{http://www.duodealer.com/partners/apps}
|
13
|
+
|
14
|
+
s.extra_rdoc_files = []
|
15
|
+
s.files = `git ls-files`.split("\n")
|
16
|
+
s.test_files = `git ls-files -- {test}/*`.split("\n")
|
17
|
+
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
18
|
+
|
19
|
+
s.rdoc_options = ["--charset=UTF-8"]
|
20
|
+
s.summary = %q{DuodealerAPI is a lightweight gem for accessing the Duo Dealer admin GraphQL web services}
|
21
|
+
s.license = "MIT"
|
22
|
+
|
23
|
+
s.required_ruby_version = ">= 2.4"
|
24
|
+
|
25
|
+
s.add_runtime_dependency("railties", "~> 6.0.2.1")
|
26
|
+
s.add_runtime_dependency("activeresource", ">= 4.1.0", "< 6.0.0")
|
27
|
+
s.add_runtime_dependency("rack")
|
28
|
+
s.add_runtime_dependency("graphql-client")
|
29
|
+
|
30
|
+
s.add_development_dependency("mocha", ">= 0.9.8")
|
31
|
+
s.add_development_dependency("webmock")
|
32
|
+
s.add_development_dependency("minitest", ">= 4.0")
|
33
|
+
s.add_development_dependency("rake")
|
34
|
+
s.add_development_dependency("timecop")
|
35
|
+
s.add_development_dependency("rubocop")
|
36
|
+
s.add_development_dependency("pry")
|
37
|
+
s.add_development_dependency("pry-byebug")
|
38
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
module ActiveResource
|
2
|
+
class DetailedLogSubscriber < ActiveSupport::LogSubscriber
|
3
|
+
VERSION_EOL_WARNING_HEADER = 'x-duodealer-api-version-warning'
|
4
|
+
VERSION_DEPRECATION_HEADER = 'x-duodealer-api-deprecated-reason'
|
5
|
+
def request(event)
|
6
|
+
log_request_response_details(event)
|
7
|
+
warn_on_deprecated_header_or_version_eol_header(event)
|
8
|
+
end
|
9
|
+
|
10
|
+
def logger
|
11
|
+
ActiveResource::Base.logger
|
12
|
+
end
|
13
|
+
|
14
|
+
private
|
15
|
+
|
16
|
+
def log_request_response_details(event)
|
17
|
+
data = event.payload[:data]
|
18
|
+
headers = data.extract_options!
|
19
|
+
request_body = data.first
|
20
|
+
|
21
|
+
info "Request:\n#{request_body}" if request_body
|
22
|
+
info "Headers: #{headers.inspect}"
|
23
|
+
info "Response:\n#{event.payload[:response].body}"
|
24
|
+
end
|
25
|
+
|
26
|
+
def warn_on_deprecated_header_or_version_eol_header(event)
|
27
|
+
payload = event.payload
|
28
|
+
|
29
|
+
payload[:response].each do |header_name, header_value|
|
30
|
+
case header_name.downcase
|
31
|
+
when VERSION_DEPRECATION_HEADER
|
32
|
+
warning_message = <<-MSG
|
33
|
+
[DEPRECATED] DuodealerAPI made a call to #{payload[:method].upcase} #{payload[:path]}, and this call made
|
34
|
+
use of a deprecated endpoint, behaviour, or parameter. See #{header_value} for more details.
|
35
|
+
MSG
|
36
|
+
|
37
|
+
warn warning_message
|
38
|
+
|
39
|
+
when VERSION_EOL_WARNING_HEADER
|
40
|
+
warning_message = <<-MSG
|
41
|
+
[API Version Warning] DuodealerAPI made a call to #{payload[:method].upcase} #{payload[:path]}, and this call used
|
42
|
+
an API version that is unsupported or will become unsupported within 30 days. See #{header_value} for more details.
|
43
|
+
MSG
|
44
|
+
|
45
|
+
warn warning_message
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
ActiveResource::DetailedLogSubscriber.attach_to :active_resource_detailed
|