shopify_api 9.0.4 → 12.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (847) hide show
  1. checksums.yaml +4 -4
  2. data/.github/CODEOWNERS +1 -1
  3. data/.github/ISSUE_TEMPLATE/BUG_REPORT.md +40 -0
  4. data/.github/ISSUE_TEMPLATE/ENHANCEMENT.md +9 -0
  5. data/.github/ISSUE_TEMPLATE/FEATURE_REQUEST.md +9 -0
  6. data/.github/dependabot.yml +20 -0
  7. data/.github/pull_request_template.md +20 -0
  8. data/.github/workflows/build.yml +39 -0
  9. data/.github/workflows/cla.yml +22 -0
  10. data/.github/workflows/close-waiting-for-response-issues.yml +20 -0
  11. data/.github/workflows/remove-labels-on-activity.yml +16 -0
  12. data/.github/workflows/stale.yml +33 -0
  13. data/.rubocop.yml +56 -5
  14. data/BREAKING_CHANGES_FOR_OLDER_VERSIONS.md +110 -0
  15. data/CHANGELOG.md +325 -198
  16. data/CONTRIBUTING.md +4 -3
  17. data/Gemfile +9 -1
  18. data/Gemfile.lock +159 -0
  19. data/LICENSE +2 -2
  20. data/README.md +82 -581
  21. data/RELEASING.md +19 -0
  22. data/Rakefile +15 -36
  23. data/SECURITY.md +59 -0
  24. data/bin/tapioca +29 -0
  25. data/dev.yml +32 -0
  26. data/docs/README.md +13 -0
  27. data/docs/getting_started.md +53 -0
  28. data/docs/issues.md +39 -0
  29. data/docs/usage/graphql.md +115 -0
  30. data/docs/usage/graphql_storefront.md +42 -0
  31. data/docs/usage/oauth.md +104 -0
  32. data/docs/usage/rest.md +137 -0
  33. data/docs/usage/session_storage.md +46 -0
  34. data/docs/usage/webhooks.md +98 -0
  35. data/lib/shopify_api/admin_versions.rb +20 -0
  36. data/lib/shopify_api/auth/associated_user.rb +36 -0
  37. data/lib/shopify_api/auth/auth_scopes.rb +75 -0
  38. data/lib/shopify_api/auth/file_session_storage.rb +72 -0
  39. data/lib/shopify_api/auth/jwt_payload.rb +83 -0
  40. data/lib/shopify_api/auth/oauth/auth_query.rb +47 -0
  41. data/lib/shopify_api/auth/oauth/session_cookie.rb +28 -0
  42. data/lib/shopify_api/auth/oauth.rb +135 -0
  43. data/lib/shopify_api/auth/session.rb +119 -0
  44. data/lib/shopify_api/auth/session_storage.rb +30 -0
  45. data/lib/shopify_api/auth.rb +26 -0
  46. data/lib/shopify_api/clients/graphql/admin.rb +15 -0
  47. data/lib/shopify_api/clients/graphql/client.rb +40 -0
  48. data/lib/shopify_api/clients/graphql/storefront.rb +35 -0
  49. data/lib/shopify_api/clients/http_client.rb +100 -0
  50. data/lib/shopify_api/clients/http_request.rb +35 -0
  51. data/lib/shopify_api/clients/http_response.rb +66 -0
  52. data/lib/shopify_api/clients/rest/admin.rb +118 -0
  53. data/lib/shopify_api/context.rb +196 -0
  54. data/lib/shopify_api/errors/context_not_setup_error.rb +9 -0
  55. data/lib/shopify_api/errors/cookie_not_found_error.rb +9 -0
  56. data/lib/shopify_api/errors/feature_deprecated_error.rb +9 -0
  57. data/lib/shopify_api/errors/http_response_error.rb +23 -0
  58. data/lib/shopify_api/errors/invalid_graphql_request_error.rb +9 -0
  59. data/lib/shopify_api/errors/invalid_http_request_error.rb +9 -0
  60. data/lib/shopify_api/errors/invalid_jwt_token_error.rb +9 -0
  61. data/lib/shopify_api/errors/invalid_oauth_error.rb +9 -0
  62. data/lib/shopify_api/errors/invalid_webhook_error.rb +9 -0
  63. data/lib/shopify_api/errors/invalid_webhook_registration_error.rb +9 -0
  64. data/lib/shopify_api/errors/log_level_not_found_error.rb +9 -0
  65. data/lib/shopify_api/errors/max_http_retries_exceeded_error.rb +9 -0
  66. data/lib/shopify_api/errors/missing_jwt_token_error.rb +9 -0
  67. data/lib/shopify_api/errors/missing_required_argument_error.rb +9 -0
  68. data/lib/shopify_api/errors/no_active_session_error.rb +9 -0
  69. data/lib/shopify_api/errors/no_session_cookie_error.rb +9 -0
  70. data/lib/shopify_api/errors/no_webhook_handler.rb +9 -0
  71. data/lib/shopify_api/errors/private_app_error.rb +9 -0
  72. data/lib/shopify_api/errors/request_access_token_error.rb +9 -0
  73. data/lib/shopify_api/errors/session_not_found_error.rb +9 -0
  74. data/lib/shopify_api/errors/session_storage_error.rb +9 -0
  75. data/lib/shopify_api/errors/unsupported_oauth_error.rb +9 -0
  76. data/lib/shopify_api/errors/unsupported_version_error.rb +9 -0
  77. data/lib/shopify_api/errors/webhook_registration_error.rb +9 -0
  78. data/lib/shopify_api/inflector.rb +17 -0
  79. data/lib/shopify_api/logger.rb +82 -0
  80. data/lib/shopify_api/rest/base.rb +394 -0
  81. data/lib/shopify_api/rest/base_errors.rb +32 -0
  82. data/lib/shopify_api/rest/resources/2022_01/abandoned_checkout.rb +190 -0
  83. data/lib/shopify_api/rest/resources/2022_01/access_scope.rb +58 -0
  84. data/lib/shopify_api/rest/resources/2022_01/android_pay_key.rb +77 -0
  85. data/lib/shopify_api/rest/resources/2022_01/apple_pay_certificate.rb +105 -0
  86. data/lib/shopify_api/rest/resources/2022_01/application_charge.rb +104 -0
  87. data/lib/shopify_api/rest/resources/2022_01/application_credit.rb +87 -0
  88. data/lib/shopify_api/rest/resources/2022_01/article.rb +265 -0
  89. data/lib/shopify_api/rest/resources/2022_01/asset.rb +118 -0
  90. data/lib/shopify_api/rest/resources/2022_01/assigned_fulfillment_order.rb +86 -0
  91. data/lib/shopify_api/rest/resources/2022_01/balance.rb +50 -0
  92. data/lib/shopify_api/rest/resources/2022_01/blog.rb +162 -0
  93. data/lib/shopify_api/rest/resources/2022_01/cancellation_request.rb +83 -0
  94. data/lib/shopify_api/rest/resources/2022_01/carrier_service.rb +116 -0
  95. data/lib/shopify_api/rest/resources/2022_01/checkout.rb +209 -0
  96. data/lib/shopify_api/rest/resources/2022_01/collect.rb +142 -0
  97. data/lib/shopify_api/rest/resources/2022_01/collection.rb +110 -0
  98. data/lib/shopify_api/rest/resources/2022_01/collection_listing.rb +155 -0
  99. data/lib/shopify_api/rest/resources/2022_01/comment.rb +283 -0
  100. data/lib/shopify_api/rest/resources/2022_01/country.rb +137 -0
  101. data/lib/shopify_api/rest/resources/2022_01/currency.rb +57 -0
  102. data/lib/shopify_api/rest/resources/2022_01/custom_collection.rb +187 -0
  103. data/lib/shopify_api/rest/resources/2022_01/customer.rb +326 -0
  104. data/lib/shopify_api/rest/resources/2022_01/customer_address.rb +201 -0
  105. data/lib/shopify_api/rest/resources/2022_01/customer_saved_search.rb +169 -0
  106. data/lib/shopify_api/rest/resources/2022_01/deprecated_api_call.rb +57 -0
  107. data/lib/shopify_api/rest/resources/2022_01/discount_code.rb +219 -0
  108. data/lib/shopify_api/rest/resources/2022_01/dispute.rb +111 -0
  109. data/lib/shopify_api/rest/resources/2022_01/draft_order.rb +275 -0
  110. data/lib/shopify_api/rest/resources/2022_01/event.rb +148 -0
  111. data/lib/shopify_api/rest/resources/2022_01/fulfillment.rb +272 -0
  112. data/lib/shopify_api/rest/resources/2022_01/fulfillment_event.rb +166 -0
  113. data/lib/shopify_api/rest/resources/2022_01/fulfillment_order.rb +281 -0
  114. data/lib/shopify_api/rest/resources/2022_01/fulfillment_request.rb +87 -0
  115. data/lib/shopify_api/rest/resources/2022_01/fulfillment_service.rb +130 -0
  116. data/lib/shopify_api/rest/resources/2022_01/gift_card.rb +215 -0
  117. data/lib/shopify_api/rest/resources/2022_01/gift_card_adjustment.rb +118 -0
  118. data/lib/shopify_api/rest/resources/2022_01/image.rb +157 -0
  119. data/lib/shopify_api/rest/resources/2022_01/inventory_item.rb +108 -0
  120. data/lib/shopify_api/rest/resources/2022_01/inventory_level.rb +179 -0
  121. data/lib/shopify_api/rest/resources/2022_01/location.rb +167 -0
  122. data/lib/shopify_api/rest/resources/2022_01/locations_for_move.rb +56 -0
  123. data/lib/shopify_api/rest/resources/2022_01/marketing_event.rb +209 -0
  124. data/lib/shopify_api/rest/resources/2022_01/metafield.rb +349 -0
  125. data/lib/shopify_api/rest/resources/2022_01/mobile_platform_application.rb +110 -0
  126. data/lib/shopify_api/rest/resources/2022_01/order.rb +473 -0
  127. data/lib/shopify_api/rest/resources/2022_01/order_risk.rb +135 -0
  128. data/lib/shopify_api/rest/resources/2022_01/page.rb +194 -0
  129. data/lib/shopify_api/rest/resources/2022_01/payment.rb +140 -0
  130. data/lib/shopify_api/rest/resources/2022_01/payment_gateway.rb +143 -0
  131. data/lib/shopify_api/rest/resources/2022_01/payment_transaction.rb +107 -0
  132. data/lib/shopify_api/rest/resources/2022_01/payout.rb +97 -0
  133. data/lib/shopify_api/rest/resources/2022_01/policy.rb +69 -0
  134. data/lib/shopify_api/rest/resources/2022_01/price_rule.rb +223 -0
  135. data/lib/shopify_api/rest/resources/2022_01/product.rb +223 -0
  136. data/lib/shopify_api/rest/resources/2022_01/product_listing.rb +196 -0
  137. data/lib/shopify_api/rest/resources/2022_01/product_resource_feedback.rb +88 -0
  138. data/lib/shopify_api/rest/resources/2022_01/province.rb +132 -0
  139. data/lib/shopify_api/rest/resources/2022_01/recurring_application_charge.rb +167 -0
  140. data/lib/shopify_api/rest/resources/2022_01/redirect.rb +139 -0
  141. data/lib/shopify_api/rest/resources/2022_01/refund.rb +151 -0
  142. data/lib/shopify_api/rest/resources/2022_01/report.rb +121 -0
  143. data/lib/shopify_api/rest/resources/2022_01/resource_feedback.rb +73 -0
  144. data/lib/shopify_api/rest/resources/2022_01/script_tag.rb +155 -0
  145. data/lib/shopify_api/rest/resources/2022_01/shipping_zone.rb +83 -0
  146. data/lib/shopify_api/rest/resources/2022_01/shop.rb +218 -0
  147. data/lib/shopify_api/rest/resources/2022_01/smart_collection.rb +216 -0
  148. data/lib/shopify_api/rest/resources/2022_01/storefront_access_token.rb +87 -0
  149. data/lib/shopify_api/rest/resources/2022_01/tender_transaction.rb +93 -0
  150. data/lib/shopify_api/rest/resources/2022_01/theme.rb +120 -0
  151. data/lib/shopify_api/rest/resources/2022_01/transaction.rb +181 -0
  152. data/lib/shopify_api/rest/resources/2022_01/usage_charge.rb +97 -0
  153. data/lib/shopify_api/rest/resources/2022_01/user.rb +138 -0
  154. data/lib/shopify_api/rest/resources/2022_01/variant.rb +212 -0
  155. data/lib/shopify_api/rest/resources/2022_01/webhook.rb +168 -0
  156. data/lib/shopify_api/rest/resources/2022_04/abandoned_checkout.rb +190 -0
  157. data/lib/shopify_api/rest/resources/2022_04/access_scope.rb +58 -0
  158. data/lib/shopify_api/rest/resources/2022_04/android_pay_key.rb +77 -0
  159. data/lib/shopify_api/rest/resources/2022_04/apple_pay_certificate.rb +105 -0
  160. data/lib/shopify_api/rest/resources/2022_04/application_charge.rb +104 -0
  161. data/lib/shopify_api/rest/resources/2022_04/application_credit.rb +87 -0
  162. data/lib/shopify_api/rest/resources/2022_04/article.rb +265 -0
  163. data/lib/shopify_api/rest/resources/2022_04/asset.rb +118 -0
  164. data/lib/shopify_api/rest/resources/2022_04/assigned_fulfillment_order.rb +86 -0
  165. data/lib/shopify_api/rest/resources/2022_04/balance.rb +50 -0
  166. data/lib/shopify_api/rest/resources/2022_04/blog.rb +162 -0
  167. data/lib/shopify_api/rest/resources/2022_04/cancellation_request.rb +83 -0
  168. data/lib/shopify_api/rest/resources/2022_04/carrier_service.rb +116 -0
  169. data/lib/shopify_api/rest/resources/2022_04/checkout.rb +209 -0
  170. data/lib/shopify_api/rest/resources/2022_04/collect.rb +142 -0
  171. data/lib/shopify_api/rest/resources/2022_04/collection.rb +110 -0
  172. data/lib/shopify_api/rest/resources/2022_04/collection_listing.rb +155 -0
  173. data/lib/shopify_api/rest/resources/2022_04/comment.rb +283 -0
  174. data/lib/shopify_api/rest/resources/2022_04/country.rb +137 -0
  175. data/lib/shopify_api/rest/resources/2022_04/currency.rb +57 -0
  176. data/lib/shopify_api/rest/resources/2022_04/custom_collection.rb +187 -0
  177. data/lib/shopify_api/rest/resources/2022_04/customer.rb +329 -0
  178. data/lib/shopify_api/rest/resources/2022_04/customer_address.rb +201 -0
  179. data/lib/shopify_api/rest/resources/2022_04/customer_saved_search.rb +169 -0
  180. data/lib/shopify_api/rest/resources/2022_04/deprecated_api_call.rb +57 -0
  181. data/lib/shopify_api/rest/resources/2022_04/discount_code.rb +219 -0
  182. data/lib/shopify_api/rest/resources/2022_04/dispute.rb +111 -0
  183. data/lib/shopify_api/rest/resources/2022_04/draft_order.rb +275 -0
  184. data/lib/shopify_api/rest/resources/2022_04/event.rb +148 -0
  185. data/lib/shopify_api/rest/resources/2022_04/fulfillment.rb +272 -0
  186. data/lib/shopify_api/rest/resources/2022_04/fulfillment_event.rb +166 -0
  187. data/lib/shopify_api/rest/resources/2022_04/fulfillment_order.rb +284 -0
  188. data/lib/shopify_api/rest/resources/2022_04/fulfillment_request.rb +87 -0
  189. data/lib/shopify_api/rest/resources/2022_04/fulfillment_service.rb +130 -0
  190. data/lib/shopify_api/rest/resources/2022_04/gift_card.rb +215 -0
  191. data/lib/shopify_api/rest/resources/2022_04/gift_card_adjustment.rb +118 -0
  192. data/lib/shopify_api/rest/resources/2022_04/image.rb +157 -0
  193. data/lib/shopify_api/rest/resources/2022_04/inventory_item.rb +108 -0
  194. data/lib/shopify_api/rest/resources/2022_04/inventory_level.rb +179 -0
  195. data/lib/shopify_api/rest/resources/2022_04/location.rb +167 -0
  196. data/lib/shopify_api/rest/resources/2022_04/locations_for_move.rb +56 -0
  197. data/lib/shopify_api/rest/resources/2022_04/marketing_event.rb +209 -0
  198. data/lib/shopify_api/rest/resources/2022_04/metafield.rb +344 -0
  199. data/lib/shopify_api/rest/resources/2022_04/mobile_platform_application.rb +110 -0
  200. data/lib/shopify_api/rest/resources/2022_04/order.rb +473 -0
  201. data/lib/shopify_api/rest/resources/2022_04/order_risk.rb +135 -0
  202. data/lib/shopify_api/rest/resources/2022_04/page.rb +194 -0
  203. data/lib/shopify_api/rest/resources/2022_04/payment.rb +140 -0
  204. data/lib/shopify_api/rest/resources/2022_04/payment_gateway.rb +143 -0
  205. data/lib/shopify_api/rest/resources/2022_04/payment_transaction.rb +107 -0
  206. data/lib/shopify_api/rest/resources/2022_04/payout.rb +97 -0
  207. data/lib/shopify_api/rest/resources/2022_04/policy.rb +69 -0
  208. data/lib/shopify_api/rest/resources/2022_04/price_rule.rb +223 -0
  209. data/lib/shopify_api/rest/resources/2022_04/product.rb +223 -0
  210. data/lib/shopify_api/rest/resources/2022_04/product_listing.rb +196 -0
  211. data/lib/shopify_api/rest/resources/2022_04/product_resource_feedback.rb +88 -0
  212. data/lib/shopify_api/rest/resources/2022_04/province.rb +132 -0
  213. data/lib/shopify_api/rest/resources/2022_04/recurring_application_charge.rb +167 -0
  214. data/lib/shopify_api/rest/resources/2022_04/redirect.rb +139 -0
  215. data/lib/shopify_api/rest/resources/2022_04/refund.rb +151 -0
  216. data/lib/shopify_api/rest/resources/2022_04/report.rb +121 -0
  217. data/lib/shopify_api/rest/resources/2022_04/resource_feedback.rb +73 -0
  218. data/lib/shopify_api/rest/resources/2022_04/script_tag.rb +155 -0
  219. data/lib/shopify_api/rest/resources/2022_04/shipping_zone.rb +83 -0
  220. data/lib/shopify_api/rest/resources/2022_04/shop.rb +218 -0
  221. data/lib/shopify_api/rest/resources/2022_04/smart_collection.rb +216 -0
  222. data/lib/shopify_api/rest/resources/2022_04/storefront_access_token.rb +87 -0
  223. data/lib/shopify_api/rest/resources/2022_04/tender_transaction.rb +93 -0
  224. data/lib/shopify_api/rest/resources/2022_04/theme.rb +120 -0
  225. data/lib/shopify_api/rest/resources/2022_04/transaction.rb +181 -0
  226. data/lib/shopify_api/rest/resources/2022_04/usage_charge.rb +97 -0
  227. data/lib/shopify_api/rest/resources/2022_04/user.rb +138 -0
  228. data/lib/shopify_api/rest/resources/2022_04/variant.rb +212 -0
  229. data/lib/shopify_api/rest/resources/2022_04/webhook.rb +168 -0
  230. data/lib/shopify_api/rest/resources/2022_07/abandoned_checkout.rb +190 -0
  231. data/lib/shopify_api/rest/resources/2022_07/access_scope.rb +58 -0
  232. data/lib/shopify_api/rest/resources/2022_07/android_pay_key.rb +77 -0
  233. data/lib/shopify_api/rest/resources/2022_07/apple_pay_certificate.rb +105 -0
  234. data/lib/shopify_api/rest/resources/2022_07/application_charge.rb +104 -0
  235. data/lib/shopify_api/rest/resources/2022_07/application_credit.rb +87 -0
  236. data/lib/shopify_api/rest/resources/2022_07/article.rb +265 -0
  237. data/lib/shopify_api/rest/resources/2022_07/asset.rb +118 -0
  238. data/lib/shopify_api/rest/resources/2022_07/assigned_fulfillment_order.rb +86 -0
  239. data/lib/shopify_api/rest/resources/2022_07/balance.rb +50 -0
  240. data/lib/shopify_api/rest/resources/2022_07/blog.rb +162 -0
  241. data/lib/shopify_api/rest/resources/2022_07/cancellation_request.rb +83 -0
  242. data/lib/shopify_api/rest/resources/2022_07/carrier_service.rb +113 -0
  243. data/lib/shopify_api/rest/resources/2022_07/checkout.rb +209 -0
  244. data/lib/shopify_api/rest/resources/2022_07/collect.rb +142 -0
  245. data/lib/shopify_api/rest/resources/2022_07/collection.rb +110 -0
  246. data/lib/shopify_api/rest/resources/2022_07/collection_listing.rb +155 -0
  247. data/lib/shopify_api/rest/resources/2022_07/comment.rb +283 -0
  248. data/lib/shopify_api/rest/resources/2022_07/country.rb +137 -0
  249. data/lib/shopify_api/rest/resources/2022_07/currency.rb +57 -0
  250. data/lib/shopify_api/rest/resources/2022_07/custom_collection.rb +187 -0
  251. data/lib/shopify_api/rest/resources/2022_07/customer.rb +329 -0
  252. data/lib/shopify_api/rest/resources/2022_07/customer_address.rb +201 -0
  253. data/lib/shopify_api/rest/resources/2022_07/customer_saved_search.rb +169 -0
  254. data/lib/shopify_api/rest/resources/2022_07/deprecated_api_call.rb +57 -0
  255. data/lib/shopify_api/rest/resources/2022_07/discount_code.rb +219 -0
  256. data/lib/shopify_api/rest/resources/2022_07/dispute.rb +111 -0
  257. data/lib/shopify_api/rest/resources/2022_07/dispute_evidence.rb +117 -0
  258. data/lib/shopify_api/rest/resources/2022_07/dispute_file_upload.rb +81 -0
  259. data/lib/shopify_api/rest/resources/2022_07/draft_order.rb +275 -0
  260. data/lib/shopify_api/rest/resources/2022_07/event.rb +148 -0
  261. data/lib/shopify_api/rest/resources/2022_07/fulfillment.rb +225 -0
  262. data/lib/shopify_api/rest/resources/2022_07/fulfillment_event.rb +166 -0
  263. data/lib/shopify_api/rest/resources/2022_07/fulfillment_order.rb +310 -0
  264. data/lib/shopify_api/rest/resources/2022_07/fulfillment_request.rb +87 -0
  265. data/lib/shopify_api/rest/resources/2022_07/fulfillment_service.rb +130 -0
  266. data/lib/shopify_api/rest/resources/2022_07/gift_card.rb +215 -0
  267. data/lib/shopify_api/rest/resources/2022_07/gift_card_adjustment.rb +118 -0
  268. data/lib/shopify_api/rest/resources/2022_07/image.rb +157 -0
  269. data/lib/shopify_api/rest/resources/2022_07/inventory_item.rb +108 -0
  270. data/lib/shopify_api/rest/resources/2022_07/inventory_level.rb +179 -0
  271. data/lib/shopify_api/rest/resources/2022_07/location.rb +167 -0
  272. data/lib/shopify_api/rest/resources/2022_07/locations_for_move.rb +56 -0
  273. data/lib/shopify_api/rest/resources/2022_07/marketing_event.rb +209 -0
  274. data/lib/shopify_api/rest/resources/2022_07/metafield.rb +344 -0
  275. data/lib/shopify_api/rest/resources/2022_07/mobile_platform_application.rb +110 -0
  276. data/lib/shopify_api/rest/resources/2022_07/order.rb +473 -0
  277. data/lib/shopify_api/rest/resources/2022_07/order_risk.rb +135 -0
  278. data/lib/shopify_api/rest/resources/2022_07/page.rb +194 -0
  279. data/lib/shopify_api/rest/resources/2022_07/payment.rb +140 -0
  280. data/lib/shopify_api/rest/resources/2022_07/payment_gateway.rb +143 -0
  281. data/lib/shopify_api/rest/resources/2022_07/payment_transaction.rb +107 -0
  282. data/lib/shopify_api/rest/resources/2022_07/payout.rb +97 -0
  283. data/lib/shopify_api/rest/resources/2022_07/policy.rb +69 -0
  284. data/lib/shopify_api/rest/resources/2022_07/price_rule.rb +223 -0
  285. data/lib/shopify_api/rest/resources/2022_07/product.rb +223 -0
  286. data/lib/shopify_api/rest/resources/2022_07/product_listing.rb +196 -0
  287. data/lib/shopify_api/rest/resources/2022_07/product_resource_feedback.rb +88 -0
  288. data/lib/shopify_api/rest/resources/2022_07/province.rb +132 -0
  289. data/lib/shopify_api/rest/resources/2022_07/recurring_application_charge.rb +167 -0
  290. data/lib/shopify_api/rest/resources/2022_07/redirect.rb +139 -0
  291. data/lib/shopify_api/rest/resources/2022_07/refund.rb +151 -0
  292. data/lib/shopify_api/rest/resources/2022_07/report.rb +121 -0
  293. data/lib/shopify_api/rest/resources/2022_07/resource_feedback.rb +73 -0
  294. data/lib/shopify_api/rest/resources/2022_07/script_tag.rb +155 -0
  295. data/lib/shopify_api/rest/resources/2022_07/shipping_zone.rb +83 -0
  296. data/lib/shopify_api/rest/resources/2022_07/shop.rb +218 -0
  297. data/lib/shopify_api/rest/resources/2022_07/smart_collection.rb +216 -0
  298. data/lib/shopify_api/rest/resources/2022_07/storefront_access_token.rb +87 -0
  299. data/lib/shopify_api/rest/resources/2022_07/tender_transaction.rb +93 -0
  300. data/lib/shopify_api/rest/resources/2022_07/theme.rb +120 -0
  301. data/lib/shopify_api/rest/resources/2022_07/transaction.rb +181 -0
  302. data/lib/shopify_api/rest/resources/2022_07/usage_charge.rb +97 -0
  303. data/lib/shopify_api/rest/resources/2022_07/user.rb +138 -0
  304. data/lib/shopify_api/rest/resources/2022_07/variant.rb +212 -0
  305. data/lib/shopify_api/rest/resources/2022_07/webhook.rb +168 -0
  306. data/lib/shopify_api/rest/resources/2022_10/abandoned_checkout.rb +190 -0
  307. data/lib/shopify_api/rest/resources/2022_10/access_scope.rb +58 -0
  308. data/lib/shopify_api/rest/resources/2022_10/android_pay_key.rb +77 -0
  309. data/lib/shopify_api/rest/resources/2022_10/apple_pay_certificate.rb +105 -0
  310. data/lib/shopify_api/rest/resources/2022_10/application_charge.rb +104 -0
  311. data/lib/shopify_api/rest/resources/2022_10/application_credit.rb +87 -0
  312. data/lib/shopify_api/rest/resources/2022_10/article.rb +265 -0
  313. data/lib/shopify_api/rest/resources/2022_10/asset.rb +118 -0
  314. data/lib/shopify_api/rest/resources/2022_10/assigned_fulfillment_order.rb +86 -0
  315. data/lib/shopify_api/rest/resources/2022_10/balance.rb +50 -0
  316. data/lib/shopify_api/rest/resources/2022_10/blog.rb +162 -0
  317. data/lib/shopify_api/rest/resources/2022_10/cancellation_request.rb +83 -0
  318. data/lib/shopify_api/rest/resources/2022_10/carrier_service.rb +113 -0
  319. data/lib/shopify_api/rest/resources/2022_10/checkout.rb +209 -0
  320. data/lib/shopify_api/rest/resources/2022_10/collect.rb +142 -0
  321. data/lib/shopify_api/rest/resources/2022_10/collection.rb +110 -0
  322. data/lib/shopify_api/rest/resources/2022_10/collection_listing.rb +155 -0
  323. data/lib/shopify_api/rest/resources/2022_10/comment.rb +283 -0
  324. data/lib/shopify_api/rest/resources/2022_10/country.rb +137 -0
  325. data/lib/shopify_api/rest/resources/2022_10/currency.rb +57 -0
  326. data/lib/shopify_api/rest/resources/2022_10/custom_collection.rb +187 -0
  327. data/lib/shopify_api/rest/resources/2022_10/customer.rb +329 -0
  328. data/lib/shopify_api/rest/resources/2022_10/customer_address.rb +201 -0
  329. data/lib/shopify_api/rest/resources/2022_10/customer_saved_search.rb +169 -0
  330. data/lib/shopify_api/rest/resources/2022_10/deprecated_api_call.rb +57 -0
  331. data/lib/shopify_api/rest/resources/2022_10/discount_code.rb +219 -0
  332. data/lib/shopify_api/rest/resources/2022_10/dispute.rb +111 -0
  333. data/lib/shopify_api/rest/resources/2022_10/dispute_evidence.rb +117 -0
  334. data/lib/shopify_api/rest/resources/2022_10/dispute_file_upload.rb +81 -0
  335. data/lib/shopify_api/rest/resources/2022_10/draft_order.rb +275 -0
  336. data/lib/shopify_api/rest/resources/2022_10/event.rb +148 -0
  337. data/lib/shopify_api/rest/resources/2022_10/fulfillment.rb +225 -0
  338. data/lib/shopify_api/rest/resources/2022_10/fulfillment_event.rb +166 -0
  339. data/lib/shopify_api/rest/resources/2022_10/fulfillment_order.rb +310 -0
  340. data/lib/shopify_api/rest/resources/2022_10/fulfillment_request.rb +87 -0
  341. data/lib/shopify_api/rest/resources/2022_10/fulfillment_service.rb +130 -0
  342. data/lib/shopify_api/rest/resources/2022_10/gift_card.rb +215 -0
  343. data/lib/shopify_api/rest/resources/2022_10/gift_card_adjustment.rb +118 -0
  344. data/lib/shopify_api/rest/resources/2022_10/image.rb +157 -0
  345. data/lib/shopify_api/rest/resources/2022_10/inventory_item.rb +108 -0
  346. data/lib/shopify_api/rest/resources/2022_10/inventory_level.rb +179 -0
  347. data/lib/shopify_api/rest/resources/2022_10/location.rb +167 -0
  348. data/lib/shopify_api/rest/resources/2022_10/locations_for_move.rb +56 -0
  349. data/lib/shopify_api/rest/resources/2022_10/marketing_event.rb +209 -0
  350. data/lib/shopify_api/rest/resources/2022_10/metafield.rb +344 -0
  351. data/lib/shopify_api/rest/resources/2022_10/mobile_platform_application.rb +110 -0
  352. data/lib/shopify_api/rest/resources/2022_10/order.rb +476 -0
  353. data/lib/shopify_api/rest/resources/2022_10/order_risk.rb +135 -0
  354. data/lib/shopify_api/rest/resources/2022_10/page.rb +194 -0
  355. data/lib/shopify_api/rest/resources/2022_10/payment.rb +140 -0
  356. data/lib/shopify_api/rest/resources/2022_10/payment_gateway.rb +143 -0
  357. data/lib/shopify_api/rest/resources/2022_10/payment_transaction.rb +107 -0
  358. data/lib/shopify_api/rest/resources/2022_10/payout.rb +97 -0
  359. data/lib/shopify_api/rest/resources/2022_10/policy.rb +69 -0
  360. data/lib/shopify_api/rest/resources/2022_10/price_rule.rb +223 -0
  361. data/lib/shopify_api/rest/resources/2022_10/product.rb +223 -0
  362. data/lib/shopify_api/rest/resources/2022_10/product_listing.rb +196 -0
  363. data/lib/shopify_api/rest/resources/2022_10/product_resource_feedback.rb +88 -0
  364. data/lib/shopify_api/rest/resources/2022_10/province.rb +132 -0
  365. data/lib/shopify_api/rest/resources/2022_10/recurring_application_charge.rb +167 -0
  366. data/lib/shopify_api/rest/resources/2022_10/redirect.rb +139 -0
  367. data/lib/shopify_api/rest/resources/2022_10/refund.rb +151 -0
  368. data/lib/shopify_api/rest/resources/2022_10/report.rb +121 -0
  369. data/lib/shopify_api/rest/resources/2022_10/resource_feedback.rb +73 -0
  370. data/lib/shopify_api/rest/resources/2022_10/script_tag.rb +155 -0
  371. data/lib/shopify_api/rest/resources/2022_10/shipping_zone.rb +83 -0
  372. data/lib/shopify_api/rest/resources/2022_10/shop.rb +221 -0
  373. data/lib/shopify_api/rest/resources/2022_10/smart_collection.rb +216 -0
  374. data/lib/shopify_api/rest/resources/2022_10/storefront_access_token.rb +87 -0
  375. data/lib/shopify_api/rest/resources/2022_10/tender_transaction.rb +93 -0
  376. data/lib/shopify_api/rest/resources/2022_10/theme.rb +120 -0
  377. data/lib/shopify_api/rest/resources/2022_10/transaction.rb +181 -0
  378. data/lib/shopify_api/rest/resources/2022_10/usage_charge.rb +97 -0
  379. data/lib/shopify_api/rest/resources/2022_10/user.rb +138 -0
  380. data/lib/shopify_api/rest/resources/2022_10/variant.rb +212 -0
  381. data/lib/shopify_api/rest/resources/2022_10/webhook.rb +168 -0
  382. data/lib/shopify_api/rest/resources/2023_01/abandoned_checkout.rb +190 -0
  383. data/lib/shopify_api/rest/resources/2023_01/access_scope.rb +58 -0
  384. data/lib/shopify_api/rest/resources/2023_01/apple_pay_certificate.rb +105 -0
  385. data/lib/shopify_api/rest/resources/2023_01/application_charge.rb +104 -0
  386. data/lib/shopify_api/rest/resources/2023_01/application_credit.rb +87 -0
  387. data/lib/shopify_api/rest/resources/2023_01/article.rb +265 -0
  388. data/lib/shopify_api/rest/resources/2023_01/asset.rb +118 -0
  389. data/lib/shopify_api/rest/resources/2023_01/assigned_fulfillment_order.rb +86 -0
  390. data/lib/shopify_api/rest/resources/2023_01/balance.rb +50 -0
  391. data/lib/shopify_api/rest/resources/2023_01/blog.rb +162 -0
  392. data/lib/shopify_api/rest/resources/2023_01/cancellation_request.rb +83 -0
  393. data/lib/shopify_api/rest/resources/2023_01/carrier_service.rb +113 -0
  394. data/lib/shopify_api/rest/resources/2023_01/checkout.rb +209 -0
  395. data/lib/shopify_api/rest/resources/2023_01/collect.rb +142 -0
  396. data/lib/shopify_api/rest/resources/2023_01/collection.rb +110 -0
  397. data/lib/shopify_api/rest/resources/2023_01/collection_listing.rb +155 -0
  398. data/lib/shopify_api/rest/resources/2023_01/comment.rb +283 -0
  399. data/lib/shopify_api/rest/resources/2023_01/country.rb +137 -0
  400. data/lib/shopify_api/rest/resources/2023_01/currency.rb +57 -0
  401. data/lib/shopify_api/rest/resources/2023_01/custom_collection.rb +187 -0
  402. data/lib/shopify_api/rest/resources/2023_01/customer.rb +329 -0
  403. data/lib/shopify_api/rest/resources/2023_01/customer_address.rb +201 -0
  404. data/lib/shopify_api/rest/resources/2023_01/customer_saved_search.rb +169 -0
  405. data/lib/shopify_api/rest/resources/2023_01/deprecated_api_call.rb +57 -0
  406. data/lib/shopify_api/rest/resources/2023_01/discount_code.rb +219 -0
  407. data/lib/shopify_api/rest/resources/2023_01/dispute.rb +111 -0
  408. data/lib/shopify_api/rest/resources/2023_01/draft_order.rb +275 -0
  409. data/lib/shopify_api/rest/resources/2023_01/event.rb +148 -0
  410. data/lib/shopify_api/rest/resources/2023_01/fulfillment.rb +225 -0
  411. data/lib/shopify_api/rest/resources/2023_01/fulfillment_event.rb +166 -0
  412. data/lib/shopify_api/rest/resources/2023_01/fulfillment_order.rb +316 -0
  413. data/lib/shopify_api/rest/resources/2023_01/fulfillment_request.rb +87 -0
  414. data/lib/shopify_api/rest/resources/2023_01/fulfillment_service.rb +130 -0
  415. data/lib/shopify_api/rest/resources/2023_01/gift_card.rb +215 -0
  416. data/lib/shopify_api/rest/resources/2023_01/gift_card_adjustment.rb +118 -0
  417. data/lib/shopify_api/rest/resources/2023_01/image.rb +157 -0
  418. data/lib/shopify_api/rest/resources/2023_01/inventory_item.rb +108 -0
  419. data/lib/shopify_api/rest/resources/2023_01/inventory_level.rb +179 -0
  420. data/lib/shopify_api/rest/resources/2023_01/location.rb +167 -0
  421. data/lib/shopify_api/rest/resources/2023_01/locations_for_move.rb +56 -0
  422. data/lib/shopify_api/rest/resources/2023_01/marketing_event.rb +209 -0
  423. data/lib/shopify_api/rest/resources/2023_01/metafield.rb +344 -0
  424. data/lib/shopify_api/rest/resources/2023_01/mobile_platform_application.rb +110 -0
  425. data/lib/shopify_api/rest/resources/2023_01/order.rb +479 -0
  426. data/lib/shopify_api/rest/resources/2023_01/order_risk.rb +135 -0
  427. data/lib/shopify_api/rest/resources/2023_01/page.rb +194 -0
  428. data/lib/shopify_api/rest/resources/2023_01/payment.rb +140 -0
  429. data/lib/shopify_api/rest/resources/2023_01/payment_gateway.rb +143 -0
  430. data/lib/shopify_api/rest/resources/2023_01/payment_transaction.rb +107 -0
  431. data/lib/shopify_api/rest/resources/2023_01/payout.rb +97 -0
  432. data/lib/shopify_api/rest/resources/2023_01/policy.rb +69 -0
  433. data/lib/shopify_api/rest/resources/2023_01/price_rule.rb +223 -0
  434. data/lib/shopify_api/rest/resources/2023_01/product.rb +223 -0
  435. data/lib/shopify_api/rest/resources/2023_01/product_listing.rb +196 -0
  436. data/lib/shopify_api/rest/resources/2023_01/product_resource_feedback.rb +88 -0
  437. data/lib/shopify_api/rest/resources/2023_01/province.rb +132 -0
  438. data/lib/shopify_api/rest/resources/2023_01/recurring_application_charge.rb +167 -0
  439. data/lib/shopify_api/rest/resources/2023_01/redirect.rb +139 -0
  440. data/lib/shopify_api/rest/resources/2023_01/refund.rb +151 -0
  441. data/lib/shopify_api/rest/resources/2023_01/report.rb +121 -0
  442. data/lib/shopify_api/rest/resources/2023_01/resource_feedback.rb +73 -0
  443. data/lib/shopify_api/rest/resources/2023_01/script_tag.rb +155 -0
  444. data/lib/shopify_api/rest/resources/2023_01/shipping_zone.rb +83 -0
  445. data/lib/shopify_api/rest/resources/2023_01/shop.rb +221 -0
  446. data/lib/shopify_api/rest/resources/2023_01/smart_collection.rb +216 -0
  447. data/lib/shopify_api/rest/resources/2023_01/storefront_access_token.rb +87 -0
  448. data/lib/shopify_api/rest/resources/2023_01/tender_transaction.rb +93 -0
  449. data/lib/shopify_api/rest/resources/2023_01/theme.rb +120 -0
  450. data/lib/shopify_api/rest/resources/2023_01/transaction.rb +181 -0
  451. data/lib/shopify_api/rest/resources/2023_01/usage_charge.rb +97 -0
  452. data/lib/shopify_api/rest/resources/2023_01/user.rb +138 -0
  453. data/lib/shopify_api/rest/resources/2023_01/variant.rb +212 -0
  454. data/lib/shopify_api/rest/resources/2023_01/webhook.rb +168 -0
  455. data/lib/shopify_api/utils/graphql_proxy.rb +52 -0
  456. data/lib/shopify_api/utils/hmac_validator.rb +44 -0
  457. data/lib/shopify_api/utils/http_utils.rb +17 -0
  458. data/lib/shopify_api/utils/session_utils.rb +152 -0
  459. data/lib/shopify_api/utils/verifiable_query.rb +18 -0
  460. data/lib/shopify_api/version.rb +4 -1
  461. data/lib/shopify_api/webhooks/handler.rb +15 -0
  462. data/lib/shopify_api/webhooks/register_result.rb +14 -0
  463. data/lib/shopify_api/webhooks/registration.rb +73 -0
  464. data/lib/shopify_api/webhooks/registrations/event_bridge.rb +61 -0
  465. data/lib/shopify_api/webhooks/registrations/http.rb +72 -0
  466. data/lib/shopify_api/webhooks/registrations/pub_sub.rb +65 -0
  467. data/lib/shopify_api/webhooks/registry.rb +215 -0
  468. data/lib/shopify_api/webhooks/request.rb +56 -0
  469. data/lib/shopify_api.rb +20 -30
  470. data/service.yml +0 -7
  471. data/shipit.rubygems.yml +1 -1
  472. data/shopify_api.gemspec +34 -22
  473. data/sorbet/config +3 -0
  474. data/sorbet/rbi/gems/activesupport@7.0.1.rbi +654 -0
  475. data/sorbet/rbi/gems/addressable@2.8.0.rbi +290 -0
  476. data/sorbet/rbi/gems/ast@2.4.2.rbi +54 -0
  477. data/sorbet/rbi/gems/coderay@1.1.3.rbi +8 -0
  478. data/sorbet/rbi/gems/concurrent-ruby@1.1.9.rbi +2401 -0
  479. data/sorbet/rbi/gems/crack@0.4.5.rbi +57 -0
  480. data/sorbet/rbi/gems/diff-lcs@1.5.0.rbi +185 -0
  481. data/sorbet/rbi/gems/fakefs@1.4.1.rbi +571 -0
  482. data/sorbet/rbi/gems/hash_diff@1.0.0.rbi +47 -0
  483. data/sorbet/rbi/gems/hashdiff@1.0.1.rbi +82 -0
  484. data/sorbet/rbi/gems/httparty@0.20.0.rbi +573 -0
  485. data/sorbet/rbi/gems/i18n@1.8.11.rbi +25 -0
  486. data/sorbet/rbi/gems/jwt@2.3.0.rbi +437 -0
  487. data/sorbet/rbi/gems/method_source@1.0.0.rbi +8 -0
  488. data/sorbet/rbi/gems/mime-types-data@3.2022.0105.rbi +73 -0
  489. data/sorbet/rbi/gems/mime-types@3.4.1.rbi +295 -0
  490. data/sorbet/rbi/gems/minitest@5.15.0.rbi +541 -0
  491. data/sorbet/rbi/gems/mocha@1.13.0.rbi +986 -0
  492. data/sorbet/rbi/gems/multi_xml@0.6.0.rbi +36 -0
  493. data/sorbet/rbi/gems/oj@3.13.11.rbi +274 -0
  494. data/sorbet/rbi/gems/openssl@3.0.0.rbi +581 -0
  495. data/sorbet/rbi/gems/parallel@1.21.0.rbi +113 -0
  496. data/sorbet/rbi/gems/parser@3.1.0.0.rbi +1741 -0
  497. data/sorbet/rbi/gems/pry@0.14.1.rbi +8 -0
  498. data/sorbet/rbi/gems/public_suffix@4.0.6.rbi +145 -0
  499. data/sorbet/rbi/gems/rainbow@3.1.1.rbi +157 -0
  500. data/sorbet/rbi/gems/rake@13.0.6.rbi +814 -0
  501. data/sorbet/rbi/gems/rbi@0.0.11.rbi +1646 -0
  502. data/sorbet/rbi/gems/regexp_parser@2.2.0.rbi +1130 -0
  503. data/sorbet/rbi/gems/rexml@3.2.5.rbi +709 -0
  504. data/sorbet/rbi/gems/rubocop-ast@1.15.1.rbi +1921 -0
  505. data/sorbet/rbi/gems/rubocop-shopify@2.4.0.rbi +8 -0
  506. data/sorbet/rbi/gems/rubocop-sorbet@0.6.5.rbi +295 -0
  507. data/sorbet/rbi/gems/rubocop@1.25.1.rbi +13507 -0
  508. data/sorbet/rbi/gems/ruby-progressbar@1.11.0.rbi +405 -0
  509. data/sorbet/rbi/gems/securerandom@0.1.1.rbi +10 -0
  510. data/sorbet/rbi/gems/spoom@1.1.8.rbi +1252 -0
  511. data/sorbet/rbi/gems/tapioca@0.6.3.rbi +1238 -0
  512. data/sorbet/rbi/gems/thor@1.2.1.rbi +844 -0
  513. data/sorbet/rbi/gems/tzinfo@2.0.4.rbi +858 -0
  514. data/sorbet/rbi/gems/unicode-display_width@2.1.0.rbi +26 -0
  515. data/sorbet/rbi/gems/unparser@0.6.3.rbi +1816 -0
  516. data/sorbet/rbi/gems/webmock@3.14.0.rbi +683 -0
  517. data/sorbet/rbi/gems/webrick@1.7.0.rbi +601 -0
  518. data/sorbet/rbi/gems/yard-sorbet@0.6.1.rbi +199 -0
  519. data/sorbet/rbi/gems/yard@0.9.27.rbi +4145 -0
  520. data/sorbet/rbi/gems/zeitwerk@2.5.4.rbi +200 -0
  521. data/sorbet/rbi/shims/fakefs.rbi +1 -0
  522. data/sorbet/rbi/shims/openssl.rb +3 -0
  523. data/sorbet/rbi/todo.rbi +8 -0
  524. data/sorbet/tapioca/config.yml +4 -0
  525. data/sorbet/tapioca/require.rb +20 -0
  526. metadata +641 -356
  527. data/.document +0 -5
  528. data/.github/probots.yml +0 -2
  529. data/.gitignore +0 -13
  530. data/.rubocop-https---shopify-github-io-ruby-style-guide-rubocop-yml +0 -1027
  531. data/.travis.yml +0 -23
  532. data/CONTRIBUTORS +0 -3
  533. data/Gemfile_ar41 +0 -5
  534. data/Gemfile_ar50 +0 -5
  535. data/Gemfile_ar51 +0 -5
  536. data/Gemfile_ar_master +0 -5
  537. data/RELEASING +0 -13
  538. data/bin/shopify +0 -3
  539. data/docker-compose.yml +0 -13
  540. data/docs/graphql.md +0 -196
  541. data/lib/active_resource/connection_ext.rb +0 -10
  542. data/lib/active_resource/detailed_log_subscriber.rb +0 -52
  543. data/lib/active_resource/json_errors.rb +0 -31
  544. data/lib/shopify_api/api_version.rb +0 -205
  545. data/lib/shopify_api/connection.rb +0 -35
  546. data/lib/shopify_api/countable.rb +0 -14
  547. data/lib/shopify_api/disable_prefix_check.rb +0 -31
  548. data/lib/shopify_api/events.rb +0 -7
  549. data/lib/shopify_api/graphql/http_client.rb +0 -22
  550. data/lib/shopify_api/graphql/railtie.rb +0 -17
  551. data/lib/shopify_api/graphql/task.rake +0 -100
  552. data/lib/shopify_api/graphql.rb +0 -83
  553. data/lib/shopify_api/limits.rb +0 -76
  554. data/lib/shopify_api/message_enricher.rb +0 -23
  555. data/lib/shopify_api/meta.rb +0 -15
  556. data/lib/shopify_api/metafields.rb +0 -20
  557. data/lib/shopify_api/paginated_collection.rb +0 -69
  558. data/lib/shopify_api/pagination_link_headers.rb +0 -33
  559. data/lib/shopify_api/resources/abandoned_checkout.rb +0 -7
  560. data/lib/shopify_api/resources/access_scope.rb +0 -10
  561. data/lib/shopify_api/resources/access_token.rb +0 -8
  562. data/lib/shopify_api/resources/address.rb +0 -4
  563. data/lib/shopify_api/resources/announcement.rb +0 -4
  564. data/lib/shopify_api/resources/api_permission.rb +0 -9
  565. data/lib/shopify_api/resources/application_charge.rb +0 -15
  566. data/lib/shopify_api/resources/application_credit.rb +0 -4
  567. data/lib/shopify_api/resources/array_base.rb +0 -13
  568. data/lib/shopify_api/resources/article.rb +0 -21
  569. data/lib/shopify_api/resources/asset.rb +0 -100
  570. data/lib/shopify_api/resources/assigned_fulfillment_order.rb +0 -16
  571. data/lib/shopify_api/resources/base.rb +0 -162
  572. data/lib/shopify_api/resources/billing_address.rb +0 -4
  573. data/lib/shopify_api/resources/blog.rb +0 -10
  574. data/lib/shopify_api/resources/carrier_service.rb +0 -4
  575. data/lib/shopify_api/resources/cart.rb +0 -4
  576. data/lib/shopify_api/resources/checkout.rb +0 -30
  577. data/lib/shopify_api/resources/collect.rb +0 -6
  578. data/lib/shopify_api/resources/collection.rb +0 -14
  579. data/lib/shopify_api/resources/collection_listing.rb +0 -18
  580. data/lib/shopify_api/resources/collection_publication.rb +0 -10
  581. data/lib/shopify_api/resources/comment.rb +0 -9
  582. data/lib/shopify_api/resources/country.rb +0 -4
  583. data/lib/shopify_api/resources/currency.rb +0 -6
  584. data/lib/shopify_api/resources/custom_collection.rb +0 -19
  585. data/lib/shopify_api/resources/customer.rb +0 -29
  586. data/lib/shopify_api/resources/customer_group.rb +0 -5
  587. data/lib/shopify_api/resources/customer_invite.rb +0 -4
  588. data/lib/shopify_api/resources/customer_saved_search.rb +0 -11
  589. data/lib/shopify_api/resources/discount_code.rb +0 -9
  590. data/lib/shopify_api/resources/discount_code_batch.rb +0 -32
  591. data/lib/shopify_api/resources/draft_order.rb +0 -14
  592. data/lib/shopify_api/resources/draft_order_invoice.rb +0 -4
  593. data/lib/shopify_api/resources/event.rb +0 -8
  594. data/lib/shopify_api/resources/fulfillment.rb +0 -47
  595. data/lib/shopify_api/resources/fulfillment_event.rb +0 -15
  596. data/lib/shopify_api/resources/fulfillment_order.rb +0 -137
  597. data/lib/shopify_api/resources/fulfillment_order_locations_for_move.rb +0 -4
  598. data/lib/shopify_api/resources/fulfillment_request.rb +0 -15
  599. data/lib/shopify_api/resources/fulfillment_service.rb +0 -4
  600. data/lib/shopify_api/resources/fulfillment_v2.rb +0 -20
  601. data/lib/shopify_api/resources/gift_card.rb +0 -7
  602. data/lib/shopify_api/resources/image.rb +0 -16
  603. data/lib/shopify_api/resources/inventory_item.rb +0 -6
  604. data/lib/shopify_api/resources/inventory_level.rb +0 -55
  605. data/lib/shopify_api/resources/line_item.rb +0 -14
  606. data/lib/shopify_api/resources/location.rb +0 -8
  607. data/lib/shopify_api/resources/marketing_event.rb +0 -10
  608. data/lib/shopify_api/resources/metafield.rb +0 -13
  609. data/lib/shopify_api/resources/note_attribute.rb +0 -4
  610. data/lib/shopify_api/resources/option.rb +0 -4
  611. data/lib/shopify_api/resources/order.rb +0 -43
  612. data/lib/shopify_api/resources/order_risk.rb +0 -8
  613. data/lib/shopify_api/resources/page.rb +0 -6
  614. data/lib/shopify_api/resources/payment.rb +0 -7
  615. data/lib/shopify_api/resources/payment_details.rb +0 -4
  616. data/lib/shopify_api/resources/ping.rb +0 -3
  617. data/lib/shopify_api/resources/policy.rb +0 -7
  618. data/lib/shopify_api/resources/price_rule.rb +0 -8
  619. data/lib/shopify_api/resources/product.rb +0 -35
  620. data/lib/shopify_api/resources/product_listing.rb +0 -16
  621. data/lib/shopify_api/resources/product_publication.rb +0 -10
  622. data/lib/shopify_api/resources/province.rb +0 -5
  623. data/lib/shopify_api/resources/publication.rb +0 -5
  624. data/lib/shopify_api/resources/receipt.rb +0 -4
  625. data/lib/shopify_api/resources/recurring_application_charge.rb +0 -31
  626. data/lib/shopify_api/resources/redirect.rb +0 -4
  627. data/lib/shopify_api/resources/refund.rb +0 -14
  628. data/lib/shopify_api/resources/report.rb +0 -4
  629. data/lib/shopify_api/resources/resource_feedback.rb +0 -19
  630. data/lib/shopify_api/resources/rule.rb +0 -4
  631. data/lib/shopify_api/resources/script_tag.rb +0 -4
  632. data/lib/shopify_api/resources/shipping_address.rb +0 -4
  633. data/lib/shopify_api/resources/shipping_line.rb +0 -4
  634. data/lib/shopify_api/resources/shipping_rate.rb +0 -7
  635. data/lib/shopify_api/resources/shipping_zone.rb +0 -4
  636. data/lib/shopify_api/resources/shop.rb +0 -25
  637. data/lib/shopify_api/resources/smart_collection.rb +0 -19
  638. data/lib/shopify_api/resources/storefront_access_token.rb +0 -4
  639. data/lib/shopify_api/resources/tax_line.rb +0 -4
  640. data/lib/shopify_api/resources/tax_service.rb +0 -4
  641. data/lib/shopify_api/resources/tender_transaction.rb +0 -6
  642. data/lib/shopify_api/resources/theme.rb +0 -4
  643. data/lib/shopify_api/resources/transaction.rb +0 -5
  644. data/lib/shopify_api/resources/usage_charge.rb +0 -5
  645. data/lib/shopify_api/resources/user.rb +0 -4
  646. data/lib/shopify_api/resources/variant.rb +0 -8
  647. data/lib/shopify_api/resources/webhook.rb +0 -4
  648. data/lib/shopify_api/resources.rb +0 -3
  649. data/lib/shopify_api/session.rb +0 -172
  650. data/test/abandoned_checkouts_test.rb +0 -29
  651. data/test/access_scope_test.rb +0 -23
  652. data/test/access_token_test.rb +0 -19
  653. data/test/active_resource/json_errors_test.rb +0 -19
  654. data/test/api_permission_test.rb +0 -9
  655. data/test/api_version_test.rb +0 -157
  656. data/test/application_charge_test.rb +0 -79
  657. data/test/application_credit_test.rb +0 -35
  658. data/test/article_test.rb +0 -73
  659. data/test/asset_test.rb +0 -18
  660. data/test/assigned_fulfillment_order_test.rb +0 -77
  661. data/test/base_test.rb +0 -198
  662. data/test/blog_test.rb +0 -8
  663. data/test/carrier_service_test.rb +0 -17
  664. data/test/cart_test.rb +0 -13
  665. data/test/checkouts_test.rb +0 -77
  666. data/test/collect_test.rb +0 -9
  667. data/test/collection_listing_test.rb +0 -79
  668. data/test/collection_publication_test.rb +0 -40
  669. data/test/collection_test.rb +0 -49
  670. data/test/countable_test.rb +0 -13
  671. data/test/currency_test.rb +0 -21
  672. data/test/custom_collection_test.rb +0 -9
  673. data/test/customer_saved_search_test.rb +0 -27
  674. data/test/customer_test.rb +0 -50
  675. data/test/detailed_log_subscriber_test.rb +0 -139
  676. data/test/discount_code_batch_test.rb +0 -40
  677. data/test/discount_code_test.rb +0 -53
  678. data/test/draft_order_test.rb +0 -151
  679. data/test/fixtures/abandoned_checkout.json +0 -184
  680. data/test/fixtures/abandoned_checkouts.json +0 -186
  681. data/test/fixtures/access_scopes.json +0 -10
  682. data/test/fixtures/access_token_delegate.json +0 -4
  683. data/test/fixtures/api_versions.json +0 -38
  684. data/test/fixtures/apis.json +0 -42
  685. data/test/fixtures/application_charge.json +0 -16
  686. data/test/fixtures/application_charges.json +0 -57
  687. data/test/fixtures/application_credit.json +0 -12
  688. data/test/fixtures/application_credits.json +0 -24
  689. data/test/fixtures/article.json +0 -15
  690. data/test/fixtures/articles.json +0 -39
  691. data/test/fixtures/asset.json +0 -9
  692. data/test/fixtures/assets.json +0 -136
  693. data/test/fixtures/assigned_fulfillment_orders.json +0 -78
  694. data/test/fixtures/authors.json +0 -1
  695. data/test/fixtures/blog.json +0 -13
  696. data/test/fixtures/blogs.json +0 -13
  697. data/test/fixtures/carrier_service.json +0 -9
  698. data/test/fixtures/carts.json +0 -43
  699. data/test/fixtures/checkout.json +0 -160
  700. data/test/fixtures/checkouts.json +0 -162
  701. data/test/fixtures/collect.json +0 -12
  702. data/test/fixtures/collection.json +0 -17
  703. data/test/fixtures/collection_listing.json +0 -11
  704. data/test/fixtures/collection_listing_product_ids.json +0 -1
  705. data/test/fixtures/collection_listing_product_ids2.json +0 -1
  706. data/test/fixtures/collection_listings.json +0 -13
  707. data/test/fixtures/collection_products.json +0 -47
  708. data/test/fixtures/collection_publication.json +0 -11
  709. data/test/fixtures/collection_publications.json +0 -13
  710. data/test/fixtures/currencies.json +0 -25
  711. data/test/fixtures/custom_collection.json +0 -17
  712. data/test/fixtures/customer_invite.json +0 -9
  713. data/test/fixtures/customer_saved_search.json +0 -9
  714. data/test/fixtures/customer_saved_search_customers.json +0 -60
  715. data/test/fixtures/customers.json +0 -59
  716. data/test/fixtures/customers_account_activation_url.json +0 -3
  717. data/test/fixtures/customers_search.json +0 -60
  718. data/test/fixtures/discount_code.json +0 -10
  719. data/test/fixtures/discount_code_batch.json +0 -14
  720. data/test/fixtures/discount_code_batch_discount_codes.json +0 -21
  721. data/test/fixtures/discount_codes.json +0 -12
  722. data/test/fixtures/draft_order.json +0 -159
  723. data/test/fixtures/draft_order_completed.json +0 -159
  724. data/test/fixtures/draft_order_invoice.json +0 -9
  725. data/test/fixtures/draft_orders.json +0 -161
  726. data/test/fixtures/engagement.json +0 -15
  727. data/test/fixtures/events.json +0 -31
  728. data/test/fixtures/fulfillment.json +0 -49
  729. data/test/fixtures/fulfillment_event.json +0 -12
  730. data/test/fixtures/fulfillment_order.json +0 -38
  731. data/test/fixtures/fulfillment_order_locations_for_move.json +0 -18
  732. data/test/fixtures/fulfillment_orders.json +0 -78
  733. data/test/fixtures/fulfillment_request.json +0 -28
  734. data/test/fixtures/fulfillment_service.json +0 -10
  735. data/test/fixtures/fulfillments.json +0 -53
  736. data/test/fixtures/gift_card.json +0 -20
  737. data/test/fixtures/gift_card_disabled.json +0 -20
  738. data/test/fixtures/graphql/2019-10.json +0 -1083
  739. data/test/fixtures/graphql/dummy_schema.rb +0 -16
  740. data/test/fixtures/graphql/unstable.json +0 -1083
  741. data/test/fixtures/image.json +0 -10
  742. data/test/fixtures/images.json +0 -20
  743. data/test/fixtures/inventory_level.json +0 -7
  744. data/test/fixtures/inventory_levels.json +0 -24
  745. data/test/fixtures/marketing_event.json +0 -28
  746. data/test/fixtures/marketing_events.json +0 -54
  747. data/test/fixtures/metafield.json +0 -12
  748. data/test/fixtures/metafields.json +0 -34
  749. data/test/fixtures/order.json +0 -297
  750. data/test/fixtures/order_risk.json +0 -14
  751. data/test/fixtures/order_risks.json +0 -28
  752. data/test/fixtures/order_with_properties.json +0 -373
  753. data/test/fixtures/orders.json +0 -299
  754. data/test/fixtures/payment.json +0 -7
  755. data/test/fixtures/payments.json +0 -9
  756. data/test/fixtures/ping/conversation.json +0 -1
  757. data/test/fixtures/ping/failed_delivery_confirmation.json +0 -1
  758. data/test/fixtures/ping/message.json +0 -1
  759. data/test/fixtures/ping/successful_delivery_confirmation.json +0 -1
  760. data/test/fixtures/policies.json +0 -8
  761. data/test/fixtures/price_rule.json +0 -27
  762. data/test/fixtures/price_rules.json +0 -28
  763. data/test/fixtures/product.json +0 -116
  764. data/test/fixtures/product_listing.json +0 -86
  765. data/test/fixtures/product_listing_product_ids.json +0 -1
  766. data/test/fixtures/product_listing_product_ids2.json +0 -1
  767. data/test/fixtures/product_listings.json +0 -174
  768. data/test/fixtures/product_publication.json +0 -11
  769. data/test/fixtures/product_publications.json +0 -13
  770. data/test/fixtures/publications.json +0 -9
  771. data/test/fixtures/recurring_application_charge.json +0 -22
  772. data/test/fixtures/recurring_application_charge_adjustment.json +0 -5
  773. data/test/fixtures/recurring_application_charges.json +0 -106
  774. data/test/fixtures/redirect.json +0 -7
  775. data/test/fixtures/refund.json +0 -112
  776. data/test/fixtures/report.json +0 -9
  777. data/test/fixtures/reports.json +0 -11
  778. data/test/fixtures/script_tag.json +0 -10
  779. data/test/fixtures/script_tags.json +0 -18
  780. data/test/fixtures/shipping_rates.json +0 -12
  781. data/test/fixtures/shipping_zones.json +0 -315
  782. data/test/fixtures/shop.json +0 -26
  783. data/test/fixtures/smart_collection.json +0 -21
  784. data/test/fixtures/smart_collection_products.json +0 -155
  785. data/test/fixtures/storefront_access_token.json +0 -9
  786. data/test/fixtures/storefront_access_tokens.json +0 -18
  787. data/test/fixtures/tags.json +0 -1
  788. data/test/fixtures/tax_service.json +0 -9
  789. data/test/fixtures/tender_transactions.json +0 -52
  790. data/test/fixtures/transaction.json +0 -29
  791. data/test/fixtures/usage_charge.json +0 -11
  792. data/test/fixtures/usage_charges.json +0 -23
  793. data/test/fixtures/user.json +0 -21
  794. data/test/fixtures/users.json +0 -42
  795. data/test/fixtures/variant.json +0 -23
  796. data/test/fixtures/variants.json +0 -88
  797. data/test/fixtures/webhook.json +0 -10
  798. data/test/fixtures/webhooks.json +0 -18
  799. data/test/fulfillment_event_test.rb +0 -69
  800. data/test/fulfillment_order_test.rb +0 -462
  801. data/test/fulfillment_order_test_helper.rb +0 -7
  802. data/test/fulfillment_request_test.rb +0 -33
  803. data/test/fulfillment_service_test.rb +0 -17
  804. data/test/fulfillment_test.rb +0 -224
  805. data/test/fulfillment_v2_test.rb +0 -62
  806. data/test/gift_card_test.rb +0 -22
  807. data/test/graphql/http_client_test.rb +0 -26
  808. data/test/graphql_test.rb +0 -158
  809. data/test/image_test.rb +0 -39
  810. data/test/inventory_level_test.rb +0 -59
  811. data/test/lib/webmock_extensions/last_request.rb +0 -16
  812. data/test/limits_test.rb +0 -38
  813. data/test/location_test.rb +0 -14
  814. data/test/marketing_event_test.rb +0 -68
  815. data/test/message_enricher_test.rb +0 -45
  816. data/test/meta_test.rb +0 -49
  817. data/test/metafield_test.rb +0 -46
  818. data/test/order_risk_test.rb +0 -46
  819. data/test/order_test.rb +0 -125
  820. data/test/pagination_test.rb +0 -257
  821. data/test/payment_test.rb +0 -19
  822. data/test/policy_test.rb +0 -19
  823. data/test/price_rule_test.rb +0 -65
  824. data/test/product_listing_test.rb +0 -97
  825. data/test/product_publication_test.rb +0 -40
  826. data/test/product_test.rb +0 -60
  827. data/test/publication_test.rb +0 -12
  828. data/test/recurring_application_charge_test.rb +0 -142
  829. data/test/redirect_test.rb +0 -9
  830. data/test/refund_test.rb +0 -32
  831. data/test/report_test.rb +0 -35
  832. data/test/resource_feedback_test.rb +0 -42
  833. data/test/script_tag_test.rb +0 -30
  834. data/test/session_test.rb +0 -366
  835. data/test/shipping_rate_test.rb +0 -17
  836. data/test/shipping_zone_test.rb +0 -10
  837. data/test/shop_test.rb +0 -68
  838. data/test/smart_collection_test.rb +0 -35
  839. data/test/storefront_access_token_test.rb +0 -32
  840. data/test/tax_service_test.rb +0 -9
  841. data/test/tender_transaction_test.rb +0 -18
  842. data/test/test_helper.rb +0 -124
  843. data/test/transaction_test.rb +0 -17
  844. data/test/usage_charge_test.rb +0 -21
  845. data/test/user_test.rb +0 -17
  846. data/test/variant_test.rb +0 -46
  847. data/test/webhook_test.rb +0 -21
data/RELEASING.md ADDED
@@ -0,0 +1,19 @@
1
+ # Releasing ShopifyAPI
2
+
3
+ 1. Before releasing, make sure `sorbet` and related gems are up to date:
4
+ `bundle update sorbet sorbet-runtime sorbet-static tapioca --conservative`
5
+ 1. Check the Semantic Versioning page for info on how to version the new release: http://semver.org
6
+ 1. Update the version of ShopifyAPI in lib/shopify_api/version.rb
7
+ 1. Run `bundle`
8
+ 1. Add a CHANGELOG entry for the new release
9
+ 1. Commit the changes with a commit message like "Packaging for release X.Y.Z"
10
+ 1. Tag the release with the version (Leave REV blank for HEAD or provide a SHA)
11
+ $ git tag vX.Y.Z REV
12
+ 1. Push out the changes
13
+ $ git push
14
+ 1. Push out the tags
15
+ $ git push --tags
16
+ 1. Publish the gem using Shipit
17
+ 1. Consider if the dependency in Shopify/shopify needs updated. It's used only by the tests so is a low risk change.
18
+ Also consider Shopify/shopify_app whose gemspec depends on this.
19
+ We don't need to do this for every release, but we should try to keep them relatively up to date.
data/Rakefile CHANGED
@@ -1,44 +1,23 @@
1
- require 'rake'
2
- require "bundler/gem_tasks"
1
+ # typed: false
2
+ # frozen_string_literal: true
3
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
4
+ require "rake/testtask"
5
+ require "bundler/gem_tasks"
10
6
 
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"
7
+ namespace :test do
8
+ Rake::TestTask.new(:library) do |t|
9
+ t.test_files = FileList["test/**/*_test.rb"].exclude("test/rest/**/*.rb")
21
10
  end
22
- end
23
11
 
24
- task :default => :test
12
+ Rake::TestTask.new(:rest_wrappers) do |t|
13
+ pattern = if ENV.key?("API_VERSION")
14
+ "test/rest/**/#{ENV.fetch("API_VERSION")}/*.rb"
15
+ else
16
+ "test/rest/**/*.rb"
17
+ end
25
18
 
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 = ""
19
+ t.pattern = pattern
33
20
  end
34
-
35
- rdoc.rdoc_dir = 'rdoc'
36
- rdoc.title = "shopify_api #{version}"
37
- rdoc.rdoc_files.include('README*')
38
- rdoc.rdoc_files.include('lib/**/*.rb')
39
21
  end
40
22
 
41
- task :docker do
42
- cmd = "docker-compose up -d && docker exec -i -t shopify_api bash"
43
- exec(cmd, err: File::NULL)
44
- end
23
+ task test: ["test:library"]
data/SECURITY.md ADDED
@@ -0,0 +1,59 @@
1
+ # Security Policy
2
+
3
+ ## Supported versions
4
+
5
+ ### New features
6
+
7
+ New features will only be added to the main branch and will not be made available in point releases.
8
+
9
+ ### Bug fixes
10
+
11
+ Only the latest release series will receive bug fixes. When enough bugs are fixed and its deemed worthy to release a new gem, this is the branch it happens from.
12
+
13
+ ### Security issues
14
+
15
+ Only the latest release series will receive patches and new versions in case of a security issue.
16
+
17
+ ### Severe security issues
18
+
19
+ For severe security issues we will provide new versions as above, and also the last major release series will receive patches and new versions. The classification of the security issue is judged by the core team.
20
+
21
+ ### Unsupported Release Series
22
+
23
+ When a release series is no longer supported, it's your own responsibility to deal with bugs and security issues. If you are not comfortable maintaining your own versions, you should upgrade to a supported version.
24
+
25
+ ## Reporting a bug
26
+
27
+ All security bugs in shopify repositories should be reported to [our hackerone program](https://hackerone.com/shopify)
28
+ Shopify's whitehat program is our way to reward security researchers for finding serious security vulnerabilities in the In Scope properties listed at the bottom of this page, including our core application (all functionality associated with a Shopify store, particularly your-store.myshopify.com/admin) and certain ancillary applications.
29
+
30
+ ## Disclosure Policy
31
+
32
+ We look forward to working with all security researchers and strive to be respectful, always assume the best and treat others as peers. We expect the same in return from all participants. To achieve this, our team strives to:
33
+
34
+ - Reply to all reports within one business day and triage within two business days (if applicable)
35
+ - Be as transparent as possible, answering all inquires about our report decisions and adding hackers to duplicate HackerOne reports
36
+ - Award bounties within a week of resolution (excluding extenuating circumstances)
37
+ - Only close reports as N/A when the issue reported is included in Known Issues, Ineligible Vulnerabilities Types or lacks evidence of a vulnerability
38
+
39
+ **The following rules must be followed in order for any rewards to be paid:**
40
+
41
+ - You may only test against shops you have created which include your HackerOne YOURHANDLE @ wearehackerone.com registered email address.
42
+ - You must not attempt to gain access to, or interact with, any shops other than those created by you.
43
+ - The use of commercial scanners is prohibited (e.g., Nessus).
44
+ - Rules for reporting must be followed.
45
+ - Do not disclose any issues publicly before they have been resolved.
46
+ - Shopify reserves the right to modify the rules for this program or deem any submissions invalid at any time. Shopify may cancel the whitehat program without notice at any time.
47
+ - Contacting Shopify Support over chat, email or phone about your HackerOne report is not allowed. We may disqualify you from receiving a reward, or from participating in the program altogether.
48
+ - You are not an employee of Shopify; employees should report bugs to the internal bug bounty program.
49
+ - You hereby represent, warrant and covenant that any content you submit to Shopify is an original work of authorship and that you are legally entitled to grant the rights and privileges conveyed by these terms. You further represent, warrant and covenant that the consent of no other person or entity is or will be necessary for Shopify to use the submitted content.
50
+ - By submitting content to Shopify, you irrevocably waive all moral rights which you may have in the content.
51
+ - All content submitted by you to Shopify under this program is licensed under the MIT License.
52
+ - You must report any discovered vulnerability to Shopify as soon as you have validated the vulnerability.
53
+ - Failure to follow any of the foregoing rules will disqualify you from participating in this program.
54
+
55
+ ** Please see our [Hackerone Profile](https://hackerone.com/shopify) for full details
56
+
57
+ ## Receiving Security Updates
58
+
59
+ To recieve all general updates to vulnerabilities, please subscribe to our hackerone [Hacktivity](https://hackerone.com/shopify/hacktivity)
data/bin/tapioca ADDED
@@ -0,0 +1,29 @@
1
+ #!/usr/bin/env ruby
2
+ # frozen_string_literal: true
3
+
4
+ #
5
+ # This file was generated by Bundler.
6
+ #
7
+ # The application 'tapioca' is installed as part of a gem, and
8
+ # this file is here to facilitate running it.
9
+ #
10
+
11
+ require "pathname"
12
+ ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../Gemfile",
13
+ Pathname.new(__FILE__).realpath)
14
+
15
+ bundle_binstub = File.expand_path("../bundle", __FILE__)
16
+
17
+ if File.file?(bundle_binstub)
18
+ if File.read(bundle_binstub, 300) =~ /This file was generated by Bundler/
19
+ load(bundle_binstub)
20
+ else
21
+ abort("Your `bin/bundle` was not generated by Bundler, so this binstub cannot run.
22
+ Replace `bin/bundle` by running `bundle binstubs bundler --force`, then run this command again.")
23
+ end
24
+ end
25
+
26
+ require "rubygems"
27
+ require "bundler/setup"
28
+
29
+ load Gem.bin_path("tapioca", "tapioca")
data/dev.yml ADDED
@@ -0,0 +1,32 @@
1
+ name: shopify-api
2
+
3
+ type: ruby
4
+
5
+ up:
6
+ - ruby: 3.0.3
7
+ - bundler
8
+
9
+ commands:
10
+ console:
11
+ desc: 'start a ruby shell with ShopifyAPI already loaded'
12
+ aliases: ['c']
13
+ run: bundle exec irb -Ilib -rshopify_api
14
+ style:
15
+ desc: 'run rubocop'
16
+ run: bundle exec rubocop
17
+ typecheck:
18
+ desc: 'run Sorbet typechecking'
19
+ aliases: ['tc']
20
+ run: bundle exec srb tc
21
+ test:
22
+ run: bundle exec rake test
23
+ sanity:
24
+ desc: 'run all static checks against the codebase'
25
+ run: bundle exec rubocop && bundle exec srb tc && bundle exec rake test
26
+ subcommands:
27
+ all:
28
+ desc: 'run all checks regardless of the success states of previous checks'
29
+ run: bundle exec rubocop; bundle exec srb tc; bundle exec rake test
30
+ rbi:
31
+ desc: 'generate .rbi files for specified gem to the project'
32
+ run: bin/tapioca gem
data/docs/README.md ADDED
@@ -0,0 +1,13 @@
1
+ <!-- Make sure this file is in sync with the Getting started section in README -->
2
+
3
+ # Getting started
4
+
5
+ You can follow our getting started guide to learn how to use this library.
6
+
7
+ - [Getting started](getting_started.md)
8
+ - [Performing OAuth](usage/oauth.md)
9
+ - [REST Admin API](usage/rest.md)
10
+ - [Make a GraphQL API call](usage/graphql.md)
11
+ - [Make a Storefront API call](usage/graphql_storefront.md)
12
+ - [Webhooks](usage/webhooks.md)
13
+ - [Known issues and caveats](issues.md)
@@ -0,0 +1,53 @@
1
+ # Getting started
2
+
3
+ This page will outline everything you need to know and the steps you need to follow in order to start using the Shopify Ruby API gem in your app.
4
+
5
+ ## Requirements
6
+
7
+ - A working knowledge of ruby and a web framework such as Rails or Sinatra
8
+ - A custom app already set up in your test store or partner account
9
+ - We recommend `ngrok` to tunnel traffic to your localhost for testing
10
+
11
+ ## Installation
12
+
13
+ Add the following to your Gemfile:
14
+
15
+ `gem "shopify_api"`
16
+
17
+ ## Steps to use the Gem
18
+
19
+ ### Setup Shopify Context
20
+
21
+ Start by initializing the `ShopifyAPI::Context` with the parameters of your app by calling `ShopifyAPI::Context.setup` (example below) when your app starts (e.g `application.rb` in a Rails app).
22
+
23
+ ```ruby
24
+ ShopifyAPI::Context.setup(
25
+ api_key: "<api-key>",
26
+ api_secret_key: "<api-secret-key>",
27
+ host_name: "<application-host-name>",
28
+ scope: "read_orders,read_products,etc",
29
+ session_storage: ShopifyAPI::Auth::FileSessionStorage.new, # This is only to be used for testing, more information in session docs
30
+ is_embedded: true, # Set to true if you are building an embedded app
31
+ is_private: false, # Set to true if you are building a private app
32
+ api_version: "2021-01" # The vesion of the API you would like to use
33
+ )
34
+ ```
35
+
36
+ ### Setup a Session Store
37
+
38
+ In order for the Shopify API gem to properly store sessions it needs an implementation of `ShopifyAPI::Auth::SessionStorage`. There is one provided in the gem, `ShopifyAPI::Auth::FileSessionStorage`, this is suitable for testing, however it is not intended for production apps. See the [Session Storage doc](usage/session_storage.md) for instructions on how to create a custom session store for a production application.
39
+
40
+ Normally session information would be stored in cookies on the browser. However, due to restrictions with modern browsers we highly discourage using cookies for embedded apps. For this reason, an app needs to define a storage implementation that can be used to store and retrieve a session given an ID. In a non embedded app this ID will come from a cookie however, in an embedded app this ID will come from [App Bridge](https://shopify.dev/apps/tools/app-bridge)
41
+
42
+ ### Performing OAuth
43
+
44
+ Next, unless you are making a private app, you need to go through OAuth as described [here](https://shopify.dev/apps/auth/oauth) to create sessions for shops using your app.
45
+ The Shopify API gem tries to make this easy by providing functions to begin and complete the OAuth process. See the [Oauth doc](usage/oauth.md) for instructions on how to use these.
46
+
47
+ ### Register Webhooks and a Webhook Handler
48
+
49
+ If you intend to use webhooks in your application follow the steps in the [Webhooks doc](usage/webhooks.md) for instructions on registering and handling webhooks.
50
+
51
+ ### Start Making Authenticated Shopify Requests
52
+
53
+ You can now start making authenticated Shopify API calls using the Admin [REST](usage/rest.md) or [GraphQL](usage/graphql.md) Clients or the [Storefront GraphQL Client](usage/graphql_storefront.md).
data/docs/issues.md ADDED
@@ -0,0 +1,39 @@
1
+ # Known issues and caveats
2
+
3
+ By following this guide, you will have a fully functional Shopify app. However, there are some things you should be aware of before using your new app in a production environment.
4
+
5
+ ## Notes on session handling
6
+
7
+ Before you start writing your application, please note that the Shopify library needs to store some information for OAuth in sessions. Since each application may choose a different strategy to store information, the library cannot dictate any specific storage strategy. When calling `ShopifyAPI::Context.setup`, you'll need to provide an instance of a class that implements the `ShopifyAPI::Auth::SessionStorage` interface.
8
+
9
+ This library provides a very simple implementation of that interface which stores sessions in files, `ShopifyAPI::Auth::FileSessionStorage` ([source code](../lib/shopify_api/auth/file_session_storage.rb)). This class is meant to speed up development with this library, but it is not suitable for production use, because it will lead to disk build-up as old sessions are not cleaned up.
10
+
11
+ Before you deploy your app to production, it should use your selected storage method for sessions. You can do that by creating a class that implements the `SessionStorage` interface and pass that in your `Context.setup` call. Your class will need to implement the methods below.
12
+
13
+ **Note**: After you create your implementation of `SessionStorage`, you should make sure to clean up old sessions periodically in your data storage. The library will delete some sessions when they are no longer useful, but it cannot guarantee that expired sessions are deleted automatically.
14
+
15
+ #### `SessionStorage.storeSession`
16
+
17
+ Creates **or updates** a `Session` object in your storage. This function should return a `bool` indicating whether the operation was successful.
18
+
19
+ | Param | Type | Notes |
20
+ | --------- | --------- | --------------------------- |
21
+ | `session` | `Session` | The session object to store |
22
+
23
+ #### `SessionStorage.loadSession`
24
+
25
+ Fetches a `Session` object from your storage. This function should return a `Session` object, or `null` if it was not found.
26
+
27
+ | Param | Type | Notes |
28
+ | ----------- | -------- | ----------------------------- |
29
+ | `sessionId` | `string` | The id of the session to load |
30
+
31
+ #### `SessionStorage.deleteSession`
32
+
33
+ Deletes a session from your storage. This function should return a `bool` indicating whether the operation was successful.
34
+
35
+ | Param | Type | Notes |
36
+ | ----------- | -------- | ------------------------------- |
37
+ | `sessionId` | `string` | The id of the session to delete |
38
+
39
+ [Back to guide index](README.md)
@@ -0,0 +1,115 @@
1
+ # Make a GraphQL API call
2
+
3
+ Once you have a [session](oauth.md#fetching-sessions) after completing oauth, you can make GraphQL queries to the Admin API with `ShopifyAPI::Clients::Graphql::Admin`
4
+
5
+ Below is an example
6
+
7
+ ```ruby
8
+ # load the current session with SessionUtils.load_current_session
9
+ session = ShopifyAPI::Utils::SessionUtils.load_current_session(auth_header: <auth-header>, cookies: <cookies>, is_online: <true|false>)
10
+
11
+ # initalize the client
12
+ client = ShopifyAPI::Clients::Graphql::Admin.new(session: session)
13
+
14
+ # make the GraphQL query string
15
+ query =<<~QUERY
16
+ {
17
+ products(first: 10) {
18
+ edges {
19
+ cursor
20
+ node {
21
+ id
22
+ title
23
+ onlineStoreUrl
24
+ }
25
+ }
26
+ }
27
+ }
28
+ QUERY
29
+
30
+ response = client.query(query: query)
31
+ # do something with the response data
32
+ ```
33
+
34
+ You can also make GraphQL calls that take in variables
35
+
36
+ ```ruby
37
+ client = ShopifyAPI::Clients::Graphql::Admin.new(session: session)
38
+
39
+ query = <<~QUERY
40
+ query testQueryWithVariables($first: Int!){
41
+ products(first: $first) {
42
+ edges {
43
+ cursor
44
+ node {
45
+ id
46
+ title
47
+ onlineStoreUrl
48
+ }
49
+ }
50
+ }
51
+ }
52
+ QUERY
53
+ variables = {
54
+ first: 3
55
+ }
56
+
57
+ response = client.query(query: query, variables: variables)
58
+
59
+ ```
60
+
61
+ Here is an example of how you might use fragments as part of the client
62
+
63
+ ```ruby
64
+ client = ShopifyAPI::Clients::Graphql::Admin.new(session: session)
65
+ # define the fragment as part of the query
66
+ query = <<~QUERY
67
+ fragment ProductStuff on Product {
68
+ id
69
+ title
70
+ description
71
+ onlineStoreUrl
72
+ }
73
+ query testQueryWithVariables($first: Int){
74
+ products(first: $first) {
75
+ edges {
76
+ cursor
77
+ node {
78
+ ...ProductStuff
79
+ }
80
+ }
81
+ }
82
+ }
83
+ QUERY
84
+ variables = {
85
+ first: 3
86
+ }
87
+ response = client.query(query: query, variables: variables)
88
+ # do something with the reponse
89
+ ```
90
+
91
+ Want to make calls to the Storefront API? Click [here](graphql_storefront.md)
92
+
93
+ # Proxy a GraphQL Query
94
+
95
+ If you would like to give your front end the ability to make authenticated graphql queries to the Shopify Admin API, the `shopify_api` gem makes proxying a graphql request easy! The gem provides a utility function which will accept the raw request body (a GraphQL query), the headers, and the cookies (optional). It will add authentication to the request, proxy it to the Shopify Admin API, and return a `ShopifyAPI::Clients::HttpResponse`. An example utilization of this in Rails is shown below:
96
+
97
+ ```ruby
98
+ def proxy
99
+ begin
100
+ response = ShopifyAPI::Utils::GraphqlProxy.proxy_query(
101
+ headers: request.headers.to_h,
102
+ body: request.raw_post,
103
+ cookies: request.cookies.to_h
104
+ )
105
+
106
+ render json: response.body, status: response.code
107
+ rescue ShopifyAPI::Errors::InvalidGraphqlRequestError
108
+ # Handle bad request
109
+ rescue ShopifyAPI::Errors::SessionNotFoundError
110
+ # Handle no session found
111
+ end
112
+ end
113
+ ```
114
+
115
+ **Note:** GraphQL proxying is only supported for online sessions for non-private apps, the utility will raise a `ShopifyAPI::Errors::SessionNotFoundError` if there are no existing online tokens for the provided credentials, and a `ShopifyAPI::Errors::PrivateAppError` if called from a private app.
@@ -0,0 +1,42 @@
1
+ # Make a Storefront API call
2
+
3
+ The library also allows you to send GraphQL requests to the [Shopify Storefront API](https://shopify.dev/docs/storefront-api). To do that, you can use `ShopifyAPI::Clients::Graphql::Storefront` with the current session and a `storefrontAccessToken`.
4
+
5
+ You can obtain Storefront API access tokens for both private apps and sales channels. Please read [our documentation](https://shopify.dev/docs/storefront-api/getting-started) to learn more about Storefront Access Tokens.
6
+
7
+ Below is an example of how you may query the Storefront API:
8
+
9
+ ```ruby
10
+ # Load the access token as per instructions above
11
+ storefront_access_token = ''
12
+ # your shop domain
13
+ shop_url = 'shop.myshopify.com'
14
+
15
+ # initialize the client with session and storefront access token
16
+ client = ShopifyAPI::Clients::Graphql::Storefront.new(shop_url, storefront_access_token)
17
+
18
+ query = <<~QUERY
19
+ {
20
+ collections(first: 2) {
21
+ edges {
22
+ node {
23
+ id
24
+ products(first: 5) {
25
+ edges {
26
+ node {
27
+ id
28
+ title
29
+ }
30
+ }
31
+ }
32
+ }
33
+ }
34
+ }
35
+ }
36
+ QUERY
37
+
38
+ response = client.query(query: query)
39
+ # do something with the returned data
40
+ ```
41
+
42
+ Want to make calls to the Admin API? Click [here](graphql.md)
@@ -0,0 +1,104 @@
1
+ # Performing OAuth
2
+
3
+ Once the library is set up for your project, you'll be able to use it to start adding functionality to your app. The first thing your app will need to do is to obtain an access token to the Admin API by performing the OAuth process.
4
+
5
+ To do this, you can follow the steps below.
6
+ For more information on authenticating a Shopify app please see the [Types of Authentication](https://shopify.dev/apps/auth#types-of-authentication) page.
7
+
8
+ ## Add a route to start OAuth
9
+
10
+ The route for starting the OAuth process (in this case `/login`) will use the library's `begin_auth` method. The method will return an `auth_route` URI that will be used for redirecting the user to the Shopify Authentication screen and a session cookie to store on the user's browser. These return values will be a hash in the form of {`auth_route`: `String`, `cookie`: `ShopifyAPI::Auth::Oauth::SessionCookie`}
11
+
12
+ | Parameter | Type | Required? | Default Value | Notes |
13
+ | -------------- | ---------------------- | :-------: | :-----------: | ----------------------------------------------------------------------------------------------------------- |
14
+ | `shop` | `String` | Yes | - | A Shopify domain name in the form `{exampleshop}.myshopify.com`. |
15
+ | `redirect_path` | `String` | Yes | - | The redirect path used for callback with a leading `/`. The route should be allowed under the app settings. |
16
+ | `is_online` | `Boolean` | No | `true` | `true` if the session is online and `false` otherwise. |
17
+
18
+ Your app should take the returned values from the `begin_auth` function and redirect the user to url defined by `auth_route` and set the cookie in the user's browser. We strongly recommend that you use secure, httpOnly cookies for this to help prevent session hijacking.
19
+
20
+ An example is shown below in a Rails app but these steps could be applied in any framework:
21
+
22
+ ```ruby
23
+ class ShopifyAuthController < ApplicationController
24
+ def login
25
+ shop = request.headers["Shop"]
26
+
27
+ auth_response = ShopifyAPI::Auth::Oauth.begin_auth(shop: domain, redirect_path: "/auth/callback")
28
+
29
+ cookies[auth_response[:cookie].name] = {
30
+ expires: auth_response[:cookie].expires,
31
+ secure: true,
32
+ http_only: true,
33
+ value: auth_response[:cookie].value
34
+ }
35
+
36
+ head 307
37
+ response.set_header("Location", auth_response[:auth_route])
38
+ end
39
+ end
40
+ ```
41
+
42
+ ## Add your OAuth callback route
43
+
44
+ After the app is authenticated with Shopify, the Shopify platform will send a request back to your app using this route (which you provided as a parameter to `begin_auth`, above). Your app will now use the provided `validate_auth_callback` method to finalize the OAuth process. This method returns a hash containing the new session and a cookie to be set in the browser in form of {`session`: `ShopifyAPI::Auth::Session`, `cookie`: `ShopifyAPI::Auth::Oauth::SessionCookie`}.
45
+
46
+ An example is shown below in a Rails app but these steps could be applied in any framework:
47
+
48
+ ```ruby
49
+ def callback
50
+ begin
51
+ auth_result = ShopifyAPI::Auth::Oauth.validate_auth_callback(
52
+ cookies: cookies.to_h,
53
+ auth_query: ShopifyAPI::Auth::Oauth::AuthQuery.new(request.parameters.symbolize_keys.except(:controller, :action))
54
+ )
55
+
56
+ cookies[auth_result[:cookie].name] = {
57
+ expires: auth_result[:cookie].expires,
58
+ secure: true,
59
+ http_only: true,
60
+ value: auth_result[:cookie].value
61
+ }
62
+
63
+ puts("OAuth complete! New access token: #{auth_result[:session].access_token}")
64
+
65
+ head 307
66
+ response.set_header("Location", "<some-redirect-url>")
67
+ rescue => e
68
+ puts(e.message)
69
+ head 500
70
+ end
71
+ end
72
+ ```
73
+ ## Fetching sessions
74
+
75
+ You can use the OAuth methods to create both offline and online sessions. Once the process is completed, the session will be stored as per your `Context.session_storage`, and can be retrieved with `SessionUtils` class methods.
76
+
77
+ - To load current session, you can use the following method:
78
+
79
+ ```ruby
80
+ ShopifyAPI::Utils::SessionUtils.load_current_session(auth_header: <auth-header>, cookies: <cookies>, is_online: <true|false>)
81
+ ```
82
+
83
+ Accepted arguments:
84
+ | Parameter | Type | Notes |
85
+ | ----------- | ------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
86
+ | `auth_header` | `String` | JWT token will be extracted from `auth_header` to load session for embedded apps. If JWT token is not provided this methods will try with `cookies`. Only required if trying to load, an embedded session. |
87
+ | `cookies` | `Hash(String, String)` | The cookies from the HTTP request. A session cookie named `shopify_app_session` is used to load session for non-embedded apps. Can be omitted if loading and embedded session without falling back on cookies |
88
+ | `is_online` | `Boolean` | Whether to load online or offline sessions. Defaults to `false` |
89
+
90
+ This method will return a `ShopifyAPI::Auth::Session` if a session exists. Either a proper token or a proper cookie must be present.
91
+
92
+ - To load offline session, you can use the following method:
93
+
94
+ ```ruby
95
+ ShopifyAPI::Utils::SessionUtils.load_offline_session(shop)
96
+ ```
97
+
98
+ Accepted arguments:
99
+ | Parameter | Type | Notes |
100
+ | ------------------- | --------- | --------------------------------------------- |
101
+ | `shop` | `String` | The shop url to find the offline session for. |
102
+ | `include_expired` | `Boolean` | Include expired sessions or not. |
103
+
104
+ This method will return a `ShopifyAPI::Auth::Session` if a session exists and `nil` otherwise. This method **does not** perform any validation on the shop domain, so it **must not** rely on user input for the domain. This method is typically meant to be used in background tasks like webhooks, where the data is expected to have been validated when the task was enqueued.