duodealer_api 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (322) hide show
  1. checksums.yaml +7 -0
  2. data/.document +5 -0
  3. data/.gitignore +13 -0
  4. data/.rubocop.yml +8 -0
  5. data/.travis.yml +23 -0
  6. data/Gemfile +5 -0
  7. data/Gemfile_ar41 +5 -0
  8. data/Gemfile_ar50 +5 -0
  9. data/Gemfile_ar51 +5 -0
  10. data/Gemfile_ar_master +5 -0
  11. data/RELEASING +13 -0
  12. data/Rakefile +44 -0
  13. data/docker-compose.yml +13 -0
  14. data/docs/graphql.md +191 -0
  15. data/duodealer_api.gemspec +38 -0
  16. data/lib/active_resource/connection_ext.rb +10 -0
  17. data/lib/active_resource/detailed_log_subscriber.rb +52 -0
  18. data/lib/active_resource/json_errors.rb +31 -0
  19. data/lib/duodealer_api.rb +33 -0
  20. data/lib/duodealer_api/api_version.rb +205 -0
  21. data/lib/duodealer_api/connection.rb +35 -0
  22. data/lib/duodealer_api/countable.rb +14 -0
  23. data/lib/duodealer_api/disable_prefix_check.rb +31 -0
  24. data/lib/duodealer_api/events.rb +7 -0
  25. data/lib/duodealer_api/graphql.rb +79 -0
  26. data/lib/duodealer_api/graphql/http_client.rb +22 -0
  27. data/lib/duodealer_api/graphql/railtie.rb +17 -0
  28. data/lib/duodealer_api/graphql/task.rake +97 -0
  29. data/lib/duodealer_api/limits.rb +76 -0
  30. data/lib/duodealer_api/message_enricher.rb +23 -0
  31. data/lib/duodealer_api/meta.rb +15 -0
  32. data/lib/duodealer_api/metafields.rb +20 -0
  33. data/lib/duodealer_api/paginated_collection.rb +69 -0
  34. data/lib/duodealer_api/pagination_link_headers.rb +33 -0
  35. data/lib/duodealer_api/resources.rb +3 -0
  36. data/lib/duodealer_api/resources/abandoned_checkout.rb +7 -0
  37. data/lib/duodealer_api/resources/access_scope.rb +10 -0
  38. data/lib/duodealer_api/resources/access_token.rb +8 -0
  39. data/lib/duodealer_api/resources/address.rb +4 -0
  40. data/lib/duodealer_api/resources/announcement.rb +4 -0
  41. data/lib/duodealer_api/resources/api_permission.rb +9 -0
  42. data/lib/duodealer_api/resources/application_charge.rb +15 -0
  43. data/lib/duodealer_api/resources/application_credit.rb +4 -0
  44. data/lib/duodealer_api/resources/array_base.rb +13 -0
  45. data/lib/duodealer_api/resources/article.rb +21 -0
  46. data/lib/duodealer_api/resources/asset.rb +100 -0
  47. data/lib/duodealer_api/resources/assigned_fulfillment_order.rb +16 -0
  48. data/lib/duodealer_api/resources/base.rb +162 -0
  49. data/lib/duodealer_api/resources/billing_address.rb +4 -0
  50. data/lib/duodealer_api/resources/blog.rb +10 -0
  51. data/lib/duodealer_api/resources/carrier_service.rb +4 -0
  52. data/lib/duodealer_api/resources/cart.rb +4 -0
  53. data/lib/duodealer_api/resources/checkout.rb +30 -0
  54. data/lib/duodealer_api/resources/collect.rb +6 -0
  55. data/lib/duodealer_api/resources/collection.rb +14 -0
  56. data/lib/duodealer_api/resources/collection_listing.rb +18 -0
  57. data/lib/duodealer_api/resources/collection_publication.rb +10 -0
  58. data/lib/duodealer_api/resources/comment.rb +9 -0
  59. data/lib/duodealer_api/resources/country.rb +4 -0
  60. data/lib/duodealer_api/resources/currency.rb +6 -0
  61. data/lib/duodealer_api/resources/custom_collection.rb +19 -0
  62. data/lib/duodealer_api/resources/customer.rb +29 -0
  63. data/lib/duodealer_api/resources/customer_group.rb +5 -0
  64. data/lib/duodealer_api/resources/customer_invite.rb +4 -0
  65. data/lib/duodealer_api/resources/customer_saved_search.rb +11 -0
  66. data/lib/duodealer_api/resources/discount_code.rb +9 -0
  67. data/lib/duodealer_api/resources/draft_order.rb +14 -0
  68. data/lib/duodealer_api/resources/draft_order_invoice.rb +4 -0
  69. data/lib/duodealer_api/resources/event.rb +8 -0
  70. data/lib/duodealer_api/resources/fulfillment.rb +47 -0
  71. data/lib/duodealer_api/resources/fulfillment_event.rb +15 -0
  72. data/lib/duodealer_api/resources/fulfillment_order.rb +137 -0
  73. data/lib/duodealer_api/resources/fulfillment_order_locations_for_move.rb +4 -0
  74. data/lib/duodealer_api/resources/fulfillment_request.rb +15 -0
  75. data/lib/duodealer_api/resources/fulfillment_service.rb +4 -0
  76. data/lib/duodealer_api/resources/fulfillment_v2.rb +20 -0
  77. data/lib/duodealer_api/resources/gift_card.rb +7 -0
  78. data/lib/duodealer_api/resources/image.rb +16 -0
  79. data/lib/duodealer_api/resources/inventory_item.rb +6 -0
  80. data/lib/duodealer_api/resources/inventory_level.rb +55 -0
  81. data/lib/duodealer_api/resources/line_item.rb +14 -0
  82. data/lib/duodealer_api/resources/location.rb +8 -0
  83. data/lib/duodealer_api/resources/marketing_event.rb +10 -0
  84. data/lib/duodealer_api/resources/metafield.rb +13 -0
  85. data/lib/duodealer_api/resources/note_attribute.rb +4 -0
  86. data/lib/duodealer_api/resources/option.rb +4 -0
  87. data/lib/duodealer_api/resources/order.rb +43 -0
  88. data/lib/duodealer_api/resources/order_risk.rb +8 -0
  89. data/lib/duodealer_api/resources/page.rb +6 -0
  90. data/lib/duodealer_api/resources/payment.rb +7 -0
  91. data/lib/duodealer_api/resources/payment_details.rb +4 -0
  92. data/lib/duodealer_api/resources/ping.rb +3 -0
  93. data/lib/duodealer_api/resources/policy.rb +7 -0
  94. data/lib/duodealer_api/resources/price_rule.rb +8 -0
  95. data/lib/duodealer_api/resources/product.rb +35 -0
  96. data/lib/duodealer_api/resources/product_listing.rb +16 -0
  97. data/lib/duodealer_api/resources/product_publication.rb +10 -0
  98. data/lib/duodealer_api/resources/province.rb +5 -0
  99. data/lib/duodealer_api/resources/publication.rb +5 -0
  100. data/lib/duodealer_api/resources/receipt.rb +4 -0
  101. data/lib/duodealer_api/resources/recurring_application_charge.rb +31 -0
  102. data/lib/duodealer_api/resources/redirect.rb +4 -0
  103. data/lib/duodealer_api/resources/refund.rb +14 -0
  104. data/lib/duodealer_api/resources/report.rb +4 -0
  105. data/lib/duodealer_api/resources/resource_feedback.rb +19 -0
  106. data/lib/duodealer_api/resources/rule.rb +4 -0
  107. data/lib/duodealer_api/resources/script_tag.rb +4 -0
  108. data/lib/duodealer_api/resources/shipping_address.rb +4 -0
  109. data/lib/duodealer_api/resources/shipping_line.rb +4 -0
  110. data/lib/duodealer_api/resources/shipping_rate.rb +7 -0
  111. data/lib/duodealer_api/resources/shipping_zone.rb +4 -0
  112. data/lib/duodealer_api/resources/shop.rb +25 -0
  113. data/lib/duodealer_api/resources/smart_collection.rb +19 -0
  114. data/lib/duodealer_api/resources/storefront_access_token.rb +4 -0
  115. data/lib/duodealer_api/resources/tax_line.rb +4 -0
  116. data/lib/duodealer_api/resources/tax_service.rb +4 -0
  117. data/lib/duodealer_api/resources/tender_transaction.rb +6 -0
  118. data/lib/duodealer_api/resources/theme.rb +4 -0
  119. data/lib/duodealer_api/resources/transaction.rb +5 -0
  120. data/lib/duodealer_api/resources/usage_charge.rb +5 -0
  121. data/lib/duodealer_api/resources/user.rb +4 -0
  122. data/lib/duodealer_api/resources/variant.rb +8 -0
  123. data/lib/duodealer_api/resources/webhook.rb +4 -0
  124. data/lib/duodealer_api/session.rb +171 -0
  125. data/lib/duodealer_api/version.rb +3 -0
  126. data/shipit.rubygems.yml +1 -0
  127. data/test/abandoned_checkouts_test.rb +29 -0
  128. data/test/access_scope_test.rb +23 -0
  129. data/test/access_token_test.rb +19 -0
  130. data/test/active_resource/json_errors_test.rb +19 -0
  131. data/test/api_permission_test.rb +9 -0
  132. data/test/api_version_test.rb +157 -0
  133. data/test/application_charge_test.rb +79 -0
  134. data/test/application_credit_test.rb +35 -0
  135. data/test/article_test.rb +73 -0
  136. data/test/asset_test.rb +18 -0
  137. data/test/assigned_fulfillment_order_test.rb +77 -0
  138. data/test/base_test.rb +198 -0
  139. data/test/blog_test.rb +8 -0
  140. data/test/carrier_service_test.rb +17 -0
  141. data/test/cart_test.rb +13 -0
  142. data/test/checkouts_test.rb +77 -0
  143. data/test/collect_test.rb +9 -0
  144. data/test/collection_listing_test.rb +79 -0
  145. data/test/collection_publication_test.rb +40 -0
  146. data/test/collection_test.rb +49 -0
  147. data/test/countable_test.rb +13 -0
  148. data/test/currency_test.rb +21 -0
  149. data/test/custom_collection_test.rb +9 -0
  150. data/test/customer_saved_search_test.rb +27 -0
  151. data/test/customer_test.rb +50 -0
  152. data/test/detailed_log_subscriber_test.rb +139 -0
  153. data/test/discount_code_test.rb +53 -0
  154. data/test/draft_order_test.rb +151 -0
  155. data/test/fixtures/abandoned_checkout.json +184 -0
  156. data/test/fixtures/abandoned_checkouts.json +186 -0
  157. data/test/fixtures/access_scopes.json +10 -0
  158. data/test/fixtures/access_token_delegate.json +4 -0
  159. data/test/fixtures/api_versions.json +38 -0
  160. data/test/fixtures/apis.json +42 -0
  161. data/test/fixtures/application_charge.json +16 -0
  162. data/test/fixtures/application_charges.json +57 -0
  163. data/test/fixtures/application_credit.json +12 -0
  164. data/test/fixtures/application_credits.json +24 -0
  165. data/test/fixtures/article.json +15 -0
  166. data/test/fixtures/articles.json +39 -0
  167. data/test/fixtures/asset.json +9 -0
  168. data/test/fixtures/assets.json +136 -0
  169. data/test/fixtures/assigned_fulfillment_orders.json +78 -0
  170. data/test/fixtures/authors.json +1 -0
  171. data/test/fixtures/blog.json +13 -0
  172. data/test/fixtures/blogs.json +13 -0
  173. data/test/fixtures/carrier_service.json +9 -0
  174. data/test/fixtures/carts.json +43 -0
  175. data/test/fixtures/checkout.json +160 -0
  176. data/test/fixtures/checkouts.json +162 -0
  177. data/test/fixtures/collect.json +12 -0
  178. data/test/fixtures/collection.json +17 -0
  179. data/test/fixtures/collection_listing.json +11 -0
  180. data/test/fixtures/collection_listing_product_ids.json +1 -0
  181. data/test/fixtures/collection_listing_product_ids2.json +1 -0
  182. data/test/fixtures/collection_listings.json +13 -0
  183. data/test/fixtures/collection_products.json +47 -0
  184. data/test/fixtures/collection_publication.json +11 -0
  185. data/test/fixtures/collection_publications.json +13 -0
  186. data/test/fixtures/currencies.json +25 -0
  187. data/test/fixtures/custom_collection.json +17 -0
  188. data/test/fixtures/customer_invite.json +9 -0
  189. data/test/fixtures/customer_saved_search.json +9 -0
  190. data/test/fixtures/customer_saved_search_customers.json +60 -0
  191. data/test/fixtures/customers.json +59 -0
  192. data/test/fixtures/customers_account_activation_url.json +3 -0
  193. data/test/fixtures/customers_search.json +60 -0
  194. data/test/fixtures/discount_code.json +10 -0
  195. data/test/fixtures/discount_codes.json +12 -0
  196. data/test/fixtures/draft_order.json +159 -0
  197. data/test/fixtures/draft_order_completed.json +159 -0
  198. data/test/fixtures/draft_order_invoice.json +9 -0
  199. data/test/fixtures/draft_orders.json +161 -0
  200. data/test/fixtures/engagement.json +15 -0
  201. data/test/fixtures/events.json +31 -0
  202. data/test/fixtures/fulfillment.json +49 -0
  203. data/test/fixtures/fulfillment_event.json +12 -0
  204. data/test/fixtures/fulfillment_order.json +38 -0
  205. data/test/fixtures/fulfillment_order_locations_for_move.json +18 -0
  206. data/test/fixtures/fulfillment_orders.json +78 -0
  207. data/test/fixtures/fulfillment_request.json +28 -0
  208. data/test/fixtures/fulfillment_service.json +10 -0
  209. data/test/fixtures/fulfillments.json +53 -0
  210. data/test/fixtures/gift_card.json +20 -0
  211. data/test/fixtures/gift_card_disabled.json +20 -0
  212. data/test/fixtures/graphql/2019-10.json +1083 -0
  213. data/test/fixtures/graphql/dummy_schema.rb +16 -0
  214. data/test/fixtures/graphql/unstable.json +1083 -0
  215. data/test/fixtures/image.json +10 -0
  216. data/test/fixtures/images.json +20 -0
  217. data/test/fixtures/inventory_level.json +7 -0
  218. data/test/fixtures/inventory_levels.json +24 -0
  219. data/test/fixtures/marketing_event.json +28 -0
  220. data/test/fixtures/marketing_events.json +54 -0
  221. data/test/fixtures/metafield.json +12 -0
  222. data/test/fixtures/metafields.json +34 -0
  223. data/test/fixtures/order.json +297 -0
  224. data/test/fixtures/order_risk.json +14 -0
  225. data/test/fixtures/order_risks.json +28 -0
  226. data/test/fixtures/order_with_properties.json +373 -0
  227. data/test/fixtures/orders.json +299 -0
  228. data/test/fixtures/payment.json +7 -0
  229. data/test/fixtures/payments.json +9 -0
  230. data/test/fixtures/ping/conversation.json +1 -0
  231. data/test/fixtures/ping/failed_delivery_confirmation.json +1 -0
  232. data/test/fixtures/ping/message.json +1 -0
  233. data/test/fixtures/ping/successful_delivery_confirmation.json +1 -0
  234. data/test/fixtures/policies.json +8 -0
  235. data/test/fixtures/price_rule.json +27 -0
  236. data/test/fixtures/price_rules.json +28 -0
  237. data/test/fixtures/product.json +116 -0
  238. data/test/fixtures/product_listing.json +86 -0
  239. data/test/fixtures/product_listing_product_ids.json +1 -0
  240. data/test/fixtures/product_listing_product_ids2.json +1 -0
  241. data/test/fixtures/product_listings.json +174 -0
  242. data/test/fixtures/product_publication.json +11 -0
  243. data/test/fixtures/product_publications.json +13 -0
  244. data/test/fixtures/publications.json +9 -0
  245. data/test/fixtures/recurring_application_charge.json +22 -0
  246. data/test/fixtures/recurring_application_charge_adjustment.json +5 -0
  247. data/test/fixtures/recurring_application_charges.json +106 -0
  248. data/test/fixtures/redirect.json +7 -0
  249. data/test/fixtures/refund.json +112 -0
  250. data/test/fixtures/report.json +9 -0
  251. data/test/fixtures/reports.json +11 -0
  252. data/test/fixtures/script_tag.json +10 -0
  253. data/test/fixtures/script_tags.json +18 -0
  254. data/test/fixtures/shipping_rates.json +12 -0
  255. data/test/fixtures/shipping_zones.json +315 -0
  256. data/test/fixtures/shop.json +26 -0
  257. data/test/fixtures/smart_collection.json +21 -0
  258. data/test/fixtures/smart_collection_products.json +155 -0
  259. data/test/fixtures/storefront_access_token.json +9 -0
  260. data/test/fixtures/storefront_access_tokens.json +18 -0
  261. data/test/fixtures/tags.json +1 -0
  262. data/test/fixtures/tax_service.json +9 -0
  263. data/test/fixtures/tender_transactions.json +52 -0
  264. data/test/fixtures/transaction.json +29 -0
  265. data/test/fixtures/usage_charge.json +11 -0
  266. data/test/fixtures/usage_charges.json +23 -0
  267. data/test/fixtures/user.json +21 -0
  268. data/test/fixtures/users.json +42 -0
  269. data/test/fixtures/variant.json +23 -0
  270. data/test/fixtures/variants.json +88 -0
  271. data/test/fixtures/webhook.json +10 -0
  272. data/test/fixtures/webhooks.json +18 -0
  273. data/test/fulfillment_event_test.rb +69 -0
  274. data/test/fulfillment_order_test.rb +462 -0
  275. data/test/fulfillment_order_test_helper.rb +7 -0
  276. data/test/fulfillment_request_test.rb +33 -0
  277. data/test/fulfillment_service_test.rb +17 -0
  278. data/test/fulfillment_test.rb +224 -0
  279. data/test/fulfillment_v2_test.rb +62 -0
  280. data/test/gift_card_test.rb +22 -0
  281. data/test/graphql/http_client_test.rb +26 -0
  282. data/test/graphql_test.rb +147 -0
  283. data/test/image_test.rb +39 -0
  284. data/test/inventory_level_test.rb +59 -0
  285. data/test/lib/webmock_extensions/last_request.rb +16 -0
  286. data/test/limits_test.rb +38 -0
  287. data/test/location_test.rb +14 -0
  288. data/test/marketing_event_test.rb +68 -0
  289. data/test/message_enricher_test.rb +45 -0
  290. data/test/meta_test.rb +49 -0
  291. data/test/metafield_test.rb +46 -0
  292. data/test/order_risk_test.rb +46 -0
  293. data/test/order_test.rb +125 -0
  294. data/test/pagination_test.rb +257 -0
  295. data/test/payment_test.rb +19 -0
  296. data/test/policy_test.rb +19 -0
  297. data/test/price_rule_test.rb +65 -0
  298. data/test/product_listing_test.rb +97 -0
  299. data/test/product_publication_test.rb +40 -0
  300. data/test/product_test.rb +60 -0
  301. data/test/publication_test.rb +12 -0
  302. data/test/recurring_application_charge_test.rb +142 -0
  303. data/test/redirect_test.rb +9 -0
  304. data/test/refund_test.rb +32 -0
  305. data/test/report_test.rb +35 -0
  306. data/test/resource_feedback_test.rb +42 -0
  307. data/test/script_tag_test.rb +30 -0
  308. data/test/session_test.rb +366 -0
  309. data/test/shipping_rate_test.rb +17 -0
  310. data/test/shipping_zone_test.rb +10 -0
  311. data/test/shop_test.rb +68 -0
  312. data/test/smart_collection_test.rb +35 -0
  313. data/test/storefront_access_token_test.rb +32 -0
  314. data/test/tax_service_test.rb +9 -0
  315. data/test/tender_transaction_test.rb +18 -0
  316. data/test/test_helper.rb +124 -0
  317. data/test/transaction_test.rb +17 -0
  318. data/test/usage_charge_test.rb +21 -0
  319. data/test/user_test.rb +17 -0
  320. data/test/variant_test.rb +46 -0
  321. data/test/webhook_test.rb +21 -0
  322. metadata +541 -0
@@ -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
@@ -0,0 +1,5 @@
1
+ README.rdoc
2
+ lib/**/*.rb
3
+ bin/*
4
+ features/**/*.feature
5
+ LICENSE
@@ -0,0 +1,13 @@
1
+ *.sw?
2
+ .DS_Store
3
+ coverage
4
+ rdoc
5
+ doc
6
+ pkg
7
+ .ruby-version
8
+ *.lock
9
+ *.gem
10
+ .idea
11
+ .dev/
12
+ .bundle/
13
+ vendor/
@@ -0,0 +1,8 @@
1
+ inherit_from:
2
+ - https://duodealer.github.io/ruby-style-guide/rubocop.yml
3
+
4
+ AllCops:
5
+ TargetRubyVersion: 2.4
6
+
7
+ Rails:
8
+ Enabled: false
@@ -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
@@ -0,0 +1,5 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem "activeresource", "~> 5.1"
@@ -0,0 +1,5 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem "activeresource", "4.1.0"
@@ -0,0 +1,5 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem "activeresource", "5.0.0"
@@ -0,0 +1,5 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem "activeresource", "5.1.0"
@@ -0,0 +1,5 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem 'activeresource', git: 'git://github.com/rails/activeresource'
@@ -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
@@ -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
@@ -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:
@@ -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,10 @@
1
+ require 'duodealer_api/connection'
2
+
3
+ module ActiveResource
4
+ class Connection
5
+ attr_reader :response
6
+
7
+ prepend DuodealerAPI::Connection::ResponseCapture
8
+ prepend DuodealerAPI::Connection::RequestNotification
9
+ end
10
+ 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