terminal-shop 2.1.3 → 3.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.ignore +2 -0
- data/CHANGELOG.md +674 -0
- data/README.md +86 -26
- data/SECURITY.md +27 -0
- data/lib/{terminal-shop → terminal_shop}/client.rb +19 -24
- data/lib/terminal_shop/errors.rb +192 -0
- data/lib/terminal_shop/file_part.rb +55 -0
- data/lib/terminal_shop/internal/transport/base_client.rb +486 -0
- data/lib/terminal_shop/internal/transport/pooled_net_requester.rb +193 -0
- data/lib/terminal_shop/internal/type/array_of.rb +154 -0
- data/lib/terminal_shop/internal/type/base_model.rb +443 -0
- data/lib/terminal_shop/internal/type/base_page.rb +55 -0
- data/lib/terminal_shop/internal/type/boolean.rb +64 -0
- data/lib/terminal_shop/internal/type/converter.rb +274 -0
- data/lib/terminal_shop/internal/type/enum.rb +133 -0
- data/lib/terminal_shop/internal/type/file_input.rb +96 -0
- data/lib/terminal_shop/internal/type/hash_of.rb +174 -0
- data/lib/terminal_shop/internal/type/request_parameters.rb +48 -0
- data/lib/terminal_shop/internal/type/union.rb +220 -0
- data/lib/terminal_shop/internal/type/unknown.rb +68 -0
- data/lib/terminal_shop/internal/util.rb +790 -0
- data/lib/terminal_shop/internal.rb +11 -0
- data/lib/terminal_shop/models/address.rb +93 -0
- data/lib/terminal_shop/models/address_create_params.rb +78 -0
- data/lib/terminal_shop/models/address_create_response.rb +17 -0
- data/lib/terminal_shop/models/address_delete_params.rb +14 -0
- data/lib/terminal_shop/models/address_delete_response.rb +16 -0
- data/lib/terminal_shop/models/address_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/address_get_response.rb +4 -7
- data/lib/terminal_shop/models/address_list_params.rb +14 -0
- data/lib/terminal_shop/models/address_list_response.rb +17 -0
- data/lib/{terminal-shop → terminal_shop}/models/app.rb +14 -12
- data/lib/terminal_shop/models/app_create_params.rb +26 -0
- data/lib/{terminal-shop → terminal_shop}/models/app_create_response.rb +10 -15
- data/lib/terminal_shop/models/app_delete_params.rb +14 -0
- data/lib/terminal_shop/models/app_delete_response.rb +16 -0
- data/lib/terminal_shop/models/app_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/app_get_response.rb +4 -7
- data/lib/terminal_shop/models/app_list_params.rb +14 -0
- data/lib/terminal_shop/models/app_list_response.rb +17 -0
- data/lib/terminal_shop/models/card.rb +75 -0
- data/lib/terminal_shop/models/card_collect_params.rb +14 -0
- data/lib/terminal_shop/models/card_collect_response.rb +36 -0
- data/lib/terminal_shop/models/card_create_params.rb +27 -0
- data/lib/terminal_shop/models/card_create_response.rb +17 -0
- data/lib/terminal_shop/models/card_delete_params.rb +14 -0
- data/lib/terminal_shop/models/card_delete_response.rb +16 -0
- data/lib/terminal_shop/models/card_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/card_get_response.rb +4 -7
- data/lib/terminal_shop/models/card_list_params.rb +14 -0
- data/lib/terminal_shop/models/card_list_response.rb +17 -0
- data/lib/terminal_shop/models/cart.rb +150 -0
- data/lib/terminal_shop/models/cart_clear_params.rb +14 -0
- data/lib/terminal_shop/models/cart_clear_response.rb +16 -0
- data/lib/terminal_shop/models/cart_convert_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/cart_convert_response.rb +4 -7
- data/lib/terminal_shop/models/cart_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/cart_get_response.rb +4 -7
- data/lib/terminal_shop/models/cart_set_address_params.rb +22 -0
- data/lib/terminal_shop/models/cart_set_address_response.rb +16 -0
- data/lib/terminal_shop/models/cart_set_card_params.rb +22 -0
- data/lib/terminal_shop/models/cart_set_card_response.rb +16 -0
- data/lib/terminal_shop/models/cart_set_item_params.rb +30 -0
- data/lib/{terminal-shop → terminal_shop}/models/cart_set_item_response.rb +4 -7
- data/lib/terminal_shop/models/email_create_params.rb +22 -0
- data/lib/terminal_shop/models/email_create_response.rb +16 -0
- data/lib/terminal_shop/models/order.rb +278 -0
- data/lib/terminal_shop/models/order_create_params.rb +38 -0
- data/lib/terminal_shop/models/order_create_response.rb +17 -0
- data/lib/terminal_shop/models/order_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/order_get_response.rb +4 -7
- data/lib/terminal_shop/models/order_list_params.rb +14 -0
- data/lib/terminal_shop/models/order_list_response.rb +17 -0
- data/lib/terminal_shop/models/product.rb +125 -0
- data/lib/terminal_shop/models/product_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/product_get_response.rb +4 -7
- data/lib/terminal_shop/models/product_list_params.rb +14 -0
- data/lib/terminal_shop/models/product_list_response.rb +17 -0
- data/lib/terminal_shop/models/product_variant.rb +84 -0
- data/lib/{terminal-shop → terminal_shop}/models/profile.rb +22 -22
- data/lib/terminal_shop/models/profile_me_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/profile_me_response.rb +4 -7
- data/lib/terminal_shop/models/profile_update_params.rb +26 -0
- data/lib/{terminal-shop → terminal_shop}/models/profile_update_response.rb +4 -7
- data/lib/{terminal-shop → terminal_shop}/models/region.rb +4 -6
- data/lib/terminal_shop/models/subscription.rb +125 -0
- data/lib/terminal_shop/models/subscription_create_params.rb +14 -0
- data/lib/terminal_shop/models/subscription_create_response.rb +16 -0
- data/lib/terminal_shop/models/subscription_delete_params.rb +14 -0
- data/lib/terminal_shop/models/subscription_delete_response.rb +16 -0
- data/lib/terminal_shop/models/subscription_get_params.rb +14 -0
- data/lib/{terminal-shop → terminal_shop}/models/subscription_get_response.rb +4 -7
- data/lib/terminal_shop/models/subscription_list_params.rb +14 -0
- data/lib/terminal_shop/models/subscription_list_response.rb +17 -0
- data/lib/terminal_shop/models/subscription_update_params.rb +76 -0
- data/lib/terminal_shop/models/subscription_update_response.rb +17 -0
- data/lib/terminal_shop/models/token.rb +38 -0
- data/lib/terminal_shop/models/token_create_params.rb +14 -0
- data/lib/terminal_shop/models/token_create_response.rb +41 -0
- data/lib/terminal_shop/models/token_delete_params.rb +14 -0
- data/lib/terminal_shop/models/token_delete_response.rb +16 -0
- data/lib/terminal_shop/models/token_get_params.rb +14 -0
- data/lib/terminal_shop/models/token_get_response.rb +22 -0
- data/lib/terminal_shop/models/token_list_params.rb +14 -0
- data/lib/terminal_shop/models/token_list_response.rb +17 -0
- data/lib/terminal_shop/models/view_init_params.rb +14 -0
- data/lib/terminal_shop/models/view_init_response.rb +97 -0
- data/lib/{terminal-shop → terminal_shop}/request_options.rb +14 -15
- data/lib/{terminal-shop → terminal_shop}/resources/address.rb +28 -18
- data/lib/{terminal-shop → terminal_shop}/resources/app.rb +22 -14
- data/lib/{terminal-shop → terminal_shop}/resources/card.rb +30 -15
- data/lib/{terminal-shop → terminal_shop}/resources/cart.rb +30 -16
- data/lib/{terminal-shop → terminal_shop}/resources/email.rb +7 -3
- data/lib/{terminal-shop → terminal_shop}/resources/order.rb +18 -10
- data/lib/{terminal-shop → terminal_shop}/resources/product.rb +11 -5
- data/lib/{terminal-shop → terminal_shop}/resources/profile.rb +12 -8
- data/lib/terminal_shop/resources/subscription.rb +141 -0
- data/lib/{terminal-shop → terminal_shop}/resources/token.rb +20 -10
- data/lib/{terminal-shop → terminal_shop}/resources/view.rb +7 -3
- data/lib/{terminal-shop → terminal_shop}/version.rb +1 -1
- data/lib/terminal_shop.rb +144 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/client.rbi +18 -19
- data/rbi/lib/terminal_shop/errors.rbi +143 -0
- data/rbi/lib/terminal_shop/file_part.rbi +34 -0
- data/rbi/lib/terminal_shop/internal/transport/base_client.rbi +213 -0
- data/rbi/lib/terminal_shop/internal/transport/pooled_net_requester.rbi +60 -0
- data/rbi/lib/terminal_shop/internal/type/array_of.rbi +88 -0
- data/rbi/lib/terminal_shop/internal/type/base_model.rbi +220 -0
- data/rbi/lib/terminal_shop/internal/type/base_page.rbi +38 -0
- data/rbi/lib/terminal_shop/internal/type/boolean.rbi +48 -0
- data/rbi/lib/terminal_shop/internal/type/converter.rbi +120 -0
- data/rbi/lib/terminal_shop/internal/type/enum.rbi +66 -0
- data/rbi/lib/terminal_shop/internal/type/file_input.rbi +50 -0
- data/rbi/lib/terminal_shop/internal/type/hash_of.rbi +88 -0
- data/rbi/lib/terminal_shop/internal/type/request_parameters.rbi +21 -0
- data/rbi/lib/terminal_shop/internal/type/union.rbi +80 -0
- data/rbi/lib/terminal_shop/internal/type/unknown.rbi +40 -0
- data/rbi/lib/terminal_shop/internal/util.rbi +302 -0
- data/rbi/lib/terminal_shop/internal.rbi +11 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/address.rbi +30 -6
- data/rbi/lib/{terminal-shop → terminal_shop}/models/address_create_params.rbi +14 -9
- data/rbi/lib/{terminal-shop → terminal_shop}/models/address_create_response.rbi +6 -6
- data/rbi/lib/terminal_shop/models/address_delete_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/address_delete_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/address_get_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/address_get_response.rbi +8 -8
- data/rbi/lib/terminal_shop/models/address_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/address_list_response.rbi +7 -7
- data/rbi/lib/{terminal-shop → terminal_shop}/models/app.rbi +12 -6
- data/rbi/lib/{terminal-shop → terminal_shop}/models/app_create_params.rbi +6 -8
- data/rbi/lib/{terminal-shop → terminal_shop}/models/app_create_response.rbi +13 -13
- data/rbi/lib/terminal_shop/models/app_delete_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/app_delete_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/app_get_params.rbi +19 -0
- data/rbi/lib/terminal_shop/models/app_get_response.rbi +25 -0
- data/rbi/lib/terminal_shop/models/app_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/app_list_response.rbi +7 -7
- data/rbi/lib/{terminal-shop → terminal_shop}/models/card.rbi +32 -15
- data/rbi/lib/terminal_shop/models/card_collect_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/card_collect_response.rbi +16 -15
- data/rbi/lib/terminal_shop/models/card_create_params.rbi +31 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/card_create_response.rbi +6 -6
- data/rbi/lib/terminal_shop/models/card_delete_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/card_delete_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/card_get_params.rbi +19 -0
- data/rbi/lib/terminal_shop/models/card_get_response.rbi +25 -0
- data/rbi/lib/terminal_shop/models/card_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/card_list_response.rbi +7 -7
- data/rbi/lib/{terminal-shop → terminal_shop}/models/cart.rbi +51 -29
- data/rbi/lib/terminal_shop/models/cart_clear_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/cart_clear_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/cart_convert_params.rbi +19 -0
- data/rbi/lib/terminal_shop/models/cart_convert_response.rbi +25 -0
- data/rbi/lib/terminal_shop/models/cart_get_params.rbi +19 -0
- data/rbi/lib/terminal_shop/models/cart_get_response.rbi +25 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/cart_set_address_params.rbi +10 -9
- data/rbi/lib/{terminal-shop → terminal_shop}/models/cart_set_address_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/cart_set_card_params.rbi +29 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/cart_set_card_response.rbi +3 -5
- data/rbi/lib/{terminal-shop → terminal_shop}/models/cart_set_item_params.rbi +12 -9
- data/rbi/lib/terminal_shop/models/cart_set_item_response.rbi +25 -0
- data/rbi/lib/terminal_shop/models/email_create_params.rbi +29 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/email_create_response.rbi +3 -5
- data/rbi/lib/{terminal-shop → terminal_shop}/models/order.rbi +149 -36
- data/rbi/lib/{terminal-shop → terminal_shop}/models/order_create_params.rbi +14 -9
- data/rbi/lib/{terminal-shop → terminal_shop}/models/order_create_response.rbi +6 -6
- data/rbi/lib/terminal_shop/models/order_get_params.rbi +19 -0
- data/rbi/lib/terminal_shop/models/order_get_response.rbi +25 -0
- data/rbi/lib/terminal_shop/models/order_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/order_list_response.rbi +7 -7
- data/rbi/lib/{terminal-shop → terminal_shop}/models/product.rbi +44 -24
- data/rbi/lib/terminal_shop/models/product_get_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/product_get_response.rbi +8 -8
- data/rbi/lib/terminal_shop/models/product_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/product_list_response.rbi +7 -7
- data/rbi/lib/terminal_shop/models/product_variant.rbi +109 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/profile.rbi +22 -14
- data/rbi/lib/terminal_shop/models/profile_me_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/profile_me_response.rbi +8 -8
- data/rbi/lib/{terminal-shop → terminal_shop}/models/profile_update_params.rbi +6 -8
- data/rbi/lib/{terminal-shop → terminal_shop}/models/profile_update_response.rbi +8 -8
- data/rbi/lib/{terminal-shop → terminal_shop}/models/region.rbi +4 -4
- data/rbi/lib/{terminal-shop → terminal_shop}/models/subscription.rbi +44 -21
- data/rbi/lib/{terminal-shop → terminal_shop}/models/subscription_create_params.rbi +5 -7
- data/rbi/lib/{terminal-shop → terminal_shop}/models/subscription_create_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/subscription_delete_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/subscription_delete_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/subscription_get_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/subscription_get_response.rbi +8 -8
- data/rbi/lib/terminal_shop/models/subscription_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/subscription_list_response.rbi +7 -7
- data/rbi/lib/terminal_shop/models/subscription_update_params.rbi +125 -0
- data/rbi/lib/terminal_shop/models/subscription_update_response.rbi +25 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/token.rbi +11 -7
- data/rbi/lib/terminal_shop/models/token_create_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/token_create_response.rbi +15 -14
- data/rbi/lib/terminal_shop/models/token_delete_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/token_delete_response.rbi +3 -5
- data/rbi/lib/terminal_shop/models/token_get_params.rbi +19 -0
- data/rbi/lib/terminal_shop/models/token_get_response.rbi +27 -0
- data/rbi/lib/terminal_shop/models/token_list_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/token_list_response.rbi +7 -7
- data/rbi/lib/terminal_shop/models/view_init_params.rbi +19 -0
- data/rbi/lib/{terminal-shop → terminal_shop}/models/view_init_response.rbi +25 -25
- data/rbi/lib/{terminal-shop → terminal_shop}/request_options.rbi +11 -13
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/address.rbi +17 -17
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/app.rbi +17 -16
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/card.rbi +28 -22
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/cart.rbi +35 -23
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/email.rbi +4 -6
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/order.rbi +15 -13
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/product.rbi +13 -9
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/profile.rbi +13 -8
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/subscription.rbi +49 -17
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/token.rbi +24 -16
- data/rbi/lib/{terminal-shop → terminal_shop}/resources/view.rbi +12 -6
- data/rbi/lib/{terminal-shop → terminal_shop}/version.rbi +1 -1
- data/sig/{terminal-shop → terminal_shop}/client.rbs +3 -3
- data/sig/terminal_shop/errors.rbs +101 -0
- data/sig/terminal_shop/file_part.rbs +21 -0
- data/sig/terminal_shop/internal/transport/base_client.rbs +116 -0
- data/sig/terminal_shop/internal/transport/pooled_net_requester.rbs +41 -0
- data/sig/terminal_shop/internal/type/array_of.rbs +45 -0
- data/sig/terminal_shop/internal/type/base_model.rbs +96 -0
- data/sig/terminal_shop/internal/type/base_page.rbs +24 -0
- data/sig/terminal_shop/internal/type/boolean.rbs +23 -0
- data/sig/terminal_shop/internal/type/converter.rbs +54 -0
- data/sig/terminal_shop/internal/type/enum.rbs +29 -0
- data/sig/terminal_shop/internal/type/file_input.rbs +23 -0
- data/sig/terminal_shop/internal/type/hash_of.rbs +45 -0
- data/sig/terminal_shop/internal/type/request_parameters.rbs +15 -0
- data/sig/terminal_shop/internal/type/union.rbs +49 -0
- data/sig/terminal_shop/internal/type/unknown.rbs +23 -0
- data/sig/terminal_shop/internal/util.rbs +158 -0
- data/sig/terminal_shop/internal.rbs +5 -0
- data/sig/{terminal-shop → terminal_shop}/models/address.rbs +5 -1
- data/sig/{terminal-shop → terminal_shop}/models/address_create_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/address_create_response.rbs +1 -1
- data/sig/terminal_shop/models/address_delete_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/address_delete_response.rbs +1 -1
- data/sig/terminal_shop/models/address_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/address_get_response.rbs +1 -1
- data/sig/terminal_shop/models/address_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/address_list_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/app.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/app_create_params.rbs +5 -4
- data/sig/{terminal-shop → terminal_shop}/models/app_create_response.rbs +2 -2
- data/sig/terminal_shop/models/app_delete_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/app_delete_response.rbs +1 -1
- data/sig/terminal_shop/models/app_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/app_get_response.rbs +1 -1
- data/sig/terminal_shop/models/app_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/app_list_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/card.rbs +6 -2
- data/sig/terminal_shop/models/card_collect_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/card_collect_response.rbs +2 -2
- data/sig/{terminal-shop → terminal_shop}/models/card_create_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/card_create_response.rbs +1 -1
- data/sig/terminal_shop/models/card_delete_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/card_delete_response.rbs +1 -1
- data/sig/terminal_shop/models/card_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/card_get_response.rbs +1 -1
- data/sig/terminal_shop/models/card_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/card_list_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/cart.rbs +4 -4
- data/sig/terminal_shop/models/cart_clear_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/cart_clear_response.rbs +1 -1
- data/sig/terminal_shop/models/cart_convert_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/cart_convert_response.rbs +1 -1
- data/sig/terminal_shop/models/cart_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/cart_get_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/cart_set_address_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/cart_set_address_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/cart_set_card_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/cart_set_card_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/cart_set_item_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/cart_set_item_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/email_create_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/email_create_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/order.rbs +51 -6
- data/sig/{terminal-shop → terminal_shop}/models/order_create_params.rbs +4 -4
- data/sig/{terminal-shop → terminal_shop}/models/order_create_response.rbs +1 -1
- data/sig/terminal_shop/models/order_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/order_get_response.rbs +1 -1
- data/sig/terminal_shop/models/order_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/order_list_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/product.rbs +9 -3
- data/sig/terminal_shop/models/product_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/product_get_response.rbs +1 -1
- data/sig/terminal_shop/models/product_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/product_list_response.rbs +1 -1
- data/sig/terminal_shop/models/product_variant.rbs +70 -0
- data/sig/{terminal-shop → terminal_shop}/models/profile.rbs +2 -2
- data/sig/terminal_shop/models/profile_me_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/profile_me_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/profile_update_params.rbs +5 -4
- data/sig/{terminal-shop → terminal_shop}/models/profile_update_response.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/models/region.rbs +3 -2
- data/sig/{terminal-shop → terminal_shop}/models/subscription.rbs +12 -4
- data/sig/{terminal-shop → terminal_shop}/models/subscription_create_params.rbs +4 -3
- data/sig/{terminal-shop → terminal_shop}/models/subscription_create_response.rbs +1 -1
- data/sig/terminal_shop/models/subscription_delete_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/subscription_delete_response.rbs +1 -1
- data/sig/terminal_shop/models/subscription_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/subscription_get_response.rbs +1 -1
- data/sig/terminal_shop/models/subscription_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/subscription_list_response.rbs +1 -1
- data/sig/terminal_shop/models/subscription_update_params.rbs +71 -0
- data/sig/terminal_shop/models/subscription_update_response.rbs +14 -0
- data/sig/{terminal-shop → terminal_shop}/models/token.rbs +1 -1
- data/sig/terminal_shop/models/token_create_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/token_create_response.rbs +2 -2
- data/sig/terminal_shop/models/token_delete_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/token_delete_response.rbs +1 -1
- data/sig/terminal_shop/models/token_get_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/token_get_response.rbs +1 -1
- data/sig/terminal_shop/models/token_list_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/token_list_response.rbs +1 -1
- data/sig/terminal_shop/models/view_init_params.rbs +15 -0
- data/sig/{terminal-shop → terminal_shop}/models/view_init_response.rbs +2 -2
- data/sig/{terminal-shop → terminal_shop}/request_options.rbs +1 -1
- data/sig/{terminal-shop → terminal_shop}/resources/subscription.rbs +10 -0
- data/sig/{terminal-shop → terminal_shop}/version.rbs +1 -1
- metadata +354 -339
- data/lib/terminal-shop/errors.rb +0 -183
- data/lib/terminal-shop/models/address.rb +0 -90
- data/lib/terminal-shop/models/address_create_params.rb +0 -86
- data/lib/terminal-shop/models/address_create_response.rb +0 -20
- data/lib/terminal-shop/models/address_delete_params.rb +0 -18
- data/lib/terminal-shop/models/address_delete_response.rb +0 -19
- data/lib/terminal-shop/models/address_get_params.rb +0 -18
- data/lib/terminal-shop/models/address_list_params.rb +0 -18
- data/lib/terminal-shop/models/address_list_response.rb +0 -20
- data/lib/terminal-shop/models/app_create_params.rb +0 -30
- data/lib/terminal-shop/models/app_delete_params.rb +0 -18
- data/lib/terminal-shop/models/app_delete_response.rb +0 -19
- data/lib/terminal-shop/models/app_get_params.rb +0 -18
- data/lib/terminal-shop/models/app_list_params.rb +0 -18
- data/lib/terminal-shop/models/app_list_response.rb +0 -20
- data/lib/terminal-shop/models/card.rb +0 -67
- data/lib/terminal-shop/models/card_collect_params.rb +0 -18
- data/lib/terminal-shop/models/card_collect_response.rb +0 -38
- data/lib/terminal-shop/models/card_create_params.rb +0 -26
- data/lib/terminal-shop/models/card_create_response.rb +0 -20
- data/lib/terminal-shop/models/card_delete_params.rb +0 -18
- data/lib/terminal-shop/models/card_delete_response.rb +0 -19
- data/lib/terminal-shop/models/card_get_params.rb +0 -18
- data/lib/terminal-shop/models/card_list_params.rb +0 -18
- data/lib/terminal-shop/models/card_list_response.rb +0 -20
- data/lib/terminal-shop/models/cart.rb +0 -178
- data/lib/terminal-shop/models/cart_clear_params.rb +0 -18
- data/lib/terminal-shop/models/cart_clear_response.rb +0 -19
- data/lib/terminal-shop/models/cart_convert_params.rb +0 -18
- data/lib/terminal-shop/models/cart_get_params.rb +0 -18
- data/lib/terminal-shop/models/cart_set_address_params.rb +0 -25
- data/lib/terminal-shop/models/cart_set_address_response.rb +0 -19
- data/lib/terminal-shop/models/cart_set_card_params.rb +0 -25
- data/lib/terminal-shop/models/cart_set_card_response.rb +0 -19
- data/lib/terminal-shop/models/cart_set_item_params.rb +0 -32
- data/lib/terminal-shop/models/email_create_params.rb +0 -25
- data/lib/terminal-shop/models/email_create_response.rb +0 -19
- data/lib/terminal-shop/models/order.rb +0 -257
- data/lib/terminal-shop/models/order_create_params.rb +0 -39
- data/lib/terminal-shop/models/order_create_response.rb +0 -20
- data/lib/terminal-shop/models/order_get_params.rb +0 -18
- data/lib/terminal-shop/models/order_list_params.rb +0 -18
- data/lib/terminal-shop/models/order_list_response.rb +0 -20
- data/lib/terminal-shop/models/product.rb +0 -150
- data/lib/terminal-shop/models/product_get_params.rb +0 -18
- data/lib/terminal-shop/models/product_list_params.rb +0 -18
- data/lib/terminal-shop/models/product_list_response.rb +0 -20
- data/lib/terminal-shop/models/product_variant.rb +0 -36
- data/lib/terminal-shop/models/profile_me_params.rb +0 -18
- data/lib/terminal-shop/models/profile_update_params.rb +0 -30
- data/lib/terminal-shop/models/subscription.rb +0 -119
- data/lib/terminal-shop/models/subscription_create_params.rb +0 -18
- data/lib/terminal-shop/models/subscription_create_response.rb +0 -19
- data/lib/terminal-shop/models/subscription_delete_params.rb +0 -18
- data/lib/terminal-shop/models/subscription_delete_response.rb +0 -19
- data/lib/terminal-shop/models/subscription_get_params.rb +0 -18
- data/lib/terminal-shop/models/subscription_list_params.rb +0 -18
- data/lib/terminal-shop/models/subscription_list_response.rb +0 -20
- data/lib/terminal-shop/models/token.rb +0 -37
- data/lib/terminal-shop/models/token_create_params.rb +0 -18
- data/lib/terminal-shop/models/token_create_response.rb +0 -42
- data/lib/terminal-shop/models/token_delete_params.rb +0 -18
- data/lib/terminal-shop/models/token_delete_response.rb +0 -19
- data/lib/terminal-shop/models/token_get_params.rb +0 -18
- data/lib/terminal-shop/models/token_get_response.rb +0 -21
- data/lib/terminal-shop/models/token_list_params.rb +0 -18
- data/lib/terminal-shop/models/token_list_response.rb +0 -20
- data/lib/terminal-shop/models/view_init_params.rb +0 -18
- data/lib/terminal-shop/models/view_init_response.rb +0 -93
- data/lib/terminal-shop/resources/subscription.rb +0 -96
- data/lib/terminal-shop/transport/base_client.rb +0 -459
- data/lib/terminal-shop/transport/pooled_net_requester.rb +0 -182
- data/lib/terminal-shop/type/array_of.rb +0 -112
- data/lib/terminal-shop/type/base_model.rb +0 -364
- data/lib/terminal-shop/type/base_page.rb +0 -61
- data/lib/terminal-shop/type/boolean_model.rb +0 -52
- data/lib/terminal-shop/type/converter.rb +0 -217
- data/lib/terminal-shop/type/enum.rb +0 -101
- data/lib/terminal-shop/type/hash_of.rb +0 -138
- data/lib/terminal-shop/type/request_parameters.rb +0 -38
- data/lib/terminal-shop/type/union.rb +0 -185
- data/lib/terminal-shop/type/unknown.rb +0 -56
- data/lib/terminal-shop/type.rb +0 -23
- data/lib/terminal-shop/util.rb +0 -726
- data/lib/terminal-shop.rb +0 -149
- data/rbi/lib/terminal-shop/errors.rbi +0 -144
- data/rbi/lib/terminal-shop/models/address_delete_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/address_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/address_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/app_delete_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/app_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/app_get_response.rbi +0 -22
- data/rbi/lib/terminal-shop/models/app_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/card_collect_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/card_create_params.rbi +0 -32
- data/rbi/lib/terminal-shop/models/card_delete_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/card_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/card_get_response.rbi +0 -22
- data/rbi/lib/terminal-shop/models/card_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/cart_clear_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/cart_convert_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/cart_convert_response.rbi +0 -22
- data/rbi/lib/terminal-shop/models/cart_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/cart_get_response.rbi +0 -22
- data/rbi/lib/terminal-shop/models/cart_set_card_params.rbi +0 -31
- data/rbi/lib/terminal-shop/models/cart_set_item_response.rbi +0 -22
- data/rbi/lib/terminal-shop/models/email_create_params.rbi +0 -31
- data/rbi/lib/terminal-shop/models/order_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/order_get_response.rbi +0 -22
- data/rbi/lib/terminal-shop/models/order_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/product_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/product_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/product_variant.rbi +0 -28
- data/rbi/lib/terminal-shop/models/profile_me_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/subscription_delete_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/subscription_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/subscription_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/token_create_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/token_delete_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/token_get_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/token_get_response.rbi +0 -23
- data/rbi/lib/terminal-shop/models/token_list_params.rbi +0 -21
- data/rbi/lib/terminal-shop/models/view_init_params.rbi +0 -21
- data/rbi/lib/terminal-shop/transport/base_client.rbi +0 -208
- data/rbi/lib/terminal-shop/transport/pooled_net_requester.rbi +0 -64
- data/rbi/lib/terminal-shop/type/array_of.rbi +0 -82
- data/rbi/lib/terminal-shop/type/base_model.rbi +0 -194
- data/rbi/lib/terminal-shop/type/base_page.rbi +0 -38
- data/rbi/lib/terminal-shop/type/boolean_model.rbi +0 -41
- data/rbi/lib/terminal-shop/type/converter.rbi +0 -101
- data/rbi/lib/terminal-shop/type/enum.rbi +0 -58
- data/rbi/lib/terminal-shop/type/hash_of.rbi +0 -85
- data/rbi/lib/terminal-shop/type/request_parameters.rbi +0 -20
- data/rbi/lib/terminal-shop/type/union.rbi +0 -68
- data/rbi/lib/terminal-shop/type/unknown.rbi +0 -37
- data/rbi/lib/terminal-shop/type.rbi +0 -23
- data/rbi/lib/terminal-shop/util.rbi +0 -281
- data/sig/terminal-shop/errors.rbs +0 -99
- data/sig/terminal-shop/models/address_delete_params.rbs +0 -14
- data/sig/terminal-shop/models/address_get_params.rbs +0 -14
- data/sig/terminal-shop/models/address_list_params.rbs +0 -14
- data/sig/terminal-shop/models/app_delete_params.rbs +0 -14
- data/sig/terminal-shop/models/app_get_params.rbs +0 -14
- data/sig/terminal-shop/models/app_list_params.rbs +0 -14
- data/sig/terminal-shop/models/card_collect_params.rbs +0 -14
- data/sig/terminal-shop/models/card_delete_params.rbs +0 -14
- data/sig/terminal-shop/models/card_get_params.rbs +0 -14
- data/sig/terminal-shop/models/card_list_params.rbs +0 -14
- data/sig/terminal-shop/models/cart_clear_params.rbs +0 -14
- data/sig/terminal-shop/models/cart_convert_params.rbs +0 -14
- data/sig/terminal-shop/models/cart_get_params.rbs +0 -14
- data/sig/terminal-shop/models/order_get_params.rbs +0 -14
- data/sig/terminal-shop/models/order_list_params.rbs +0 -14
- data/sig/terminal-shop/models/product_get_params.rbs +0 -14
- data/sig/terminal-shop/models/product_list_params.rbs +0 -14
- data/sig/terminal-shop/models/product_variant.rbs +0 -17
- data/sig/terminal-shop/models/profile_me_params.rbs +0 -14
- data/sig/terminal-shop/models/subscription_delete_params.rbs +0 -14
- data/sig/terminal-shop/models/subscription_get_params.rbs +0 -14
- data/sig/terminal-shop/models/subscription_list_params.rbs +0 -14
- data/sig/terminal-shop/models/token_create_params.rbs +0 -14
- data/sig/terminal-shop/models/token_delete_params.rbs +0 -14
- data/sig/terminal-shop/models/token_get_params.rbs +0 -14
- data/sig/terminal-shop/models/token_list_params.rbs +0 -14
- data/sig/terminal-shop/models/view_init_params.rbs +0 -14
- data/sig/terminal-shop/transport/base_client.rbs +0 -110
- data/sig/terminal-shop/transport/pooled_net_requester.rbs +0 -39
- data/sig/terminal-shop/type/array_of.rbs +0 -36
- data/sig/terminal-shop/type/base_model.rbs +0 -73
- data/sig/terminal-shop/type/base_page.rbs +0 -22
- data/sig/terminal-shop/type/boolean_model.rbs +0 -18
- data/sig/terminal-shop/type/converter.rbs +0 -42
- data/sig/terminal-shop/type/enum.rbs +0 -22
- data/sig/terminal-shop/type/hash_of.rbs +0 -36
- data/sig/terminal-shop/type/request_parameters.rbs +0 -13
- data/sig/terminal-shop/type/union.rbs +0 -40
- data/sig/terminal-shop/type/unknown.rbs +0 -18
- data/sig/terminal-shop/type.rbs +0 -22
- data/sig/terminal-shop/util.rbs +0 -136
- /data/sig/{terminal-shop → terminal_shop}/resources/address.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/app.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/card.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/cart.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/email.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/order.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/product.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/profile.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/token.rbs +0 -0
- /data/sig/{terminal-shop → terminal_shop}/resources/view.rbs +0 -0
data/README.md
CHANGED
@@ -1,34 +1,32 @@
|
|
1
1
|
# Terminal Ruby API library
|
2
2
|
|
3
|
-
The Terminal Ruby library provides convenient access to the Terminal REST API from any Ruby 3.
|
3
|
+
The Terminal Ruby library provides convenient access to the Terminal REST API from any Ruby 3.1.0+ application.
|
4
4
|
|
5
5
|
It is generated with [Stainless](https://www.stainless.com/).
|
6
6
|
|
7
7
|
## Documentation
|
8
8
|
|
9
|
-
Documentation for
|
9
|
+
Documentation for releases of this gem can be found [on RubyDoc](https://gemdocs.org/gems/terminal-shop).
|
10
10
|
|
11
|
-
The
|
11
|
+
The REST API documentation can be found on [terminal.shop](https://terminal.shop/docs).
|
12
12
|
|
13
13
|
## Installation
|
14
14
|
|
15
15
|
To use this gem, install via Bundler by adding the following to your application's `Gemfile`:
|
16
16
|
|
17
|
+
<!-- x-release-please-start-version -->
|
18
|
+
|
17
19
|
```ruby
|
18
|
-
gem "terminal-shop", "~>
|
20
|
+
gem "terminal-shop", "~> 3.5.0"
|
19
21
|
```
|
20
22
|
|
21
|
-
|
22
|
-
|
23
|
-
```sh
|
24
|
-
bundle install
|
25
|
-
```
|
23
|
+
<!-- x-release-please-end -->
|
26
24
|
|
27
25
|
## Usage
|
28
26
|
|
29
27
|
```ruby
|
30
28
|
require "bundler/setup"
|
31
|
-
require "
|
29
|
+
require "terminal_shop"
|
32
30
|
|
33
31
|
terminal = TerminalShop::Client.new(
|
34
32
|
bearer_token: "My Bearer Token", # defaults to ENV["TERMINAL_BEARER_TOKEN"]
|
@@ -40,14 +38,24 @@ products = terminal.product.list
|
|
40
38
|
puts(products.data)
|
41
39
|
```
|
42
40
|
|
41
|
+
## Sorbet
|
42
|
+
|
43
|
+
This library is written with [Sorbet type definitions](https://sorbet.org/docs/rbi). However, there is no runtime dependency on the `sorbet-runtime`.
|
44
|
+
|
45
|
+
When using sorbet, it is recommended to use model classes as below. This provides stronger type checking and tooling integration.
|
46
|
+
|
47
|
+
```ruby
|
48
|
+
terminal.product.list
|
49
|
+
```
|
50
|
+
|
43
51
|
### Errors
|
44
52
|
|
45
|
-
When the library is unable to connect to the API, or if the API returns a non-success status code (i.e., 4xx or 5xx response), a subclass of `TerminalShop::
|
53
|
+
When the library is unable to connect to the API, or if the API returns a non-success status code (i.e., 4xx or 5xx response), a subclass of `TerminalShop::Errors::APIError` will be thrown:
|
46
54
|
|
47
55
|
```ruby
|
48
56
|
begin
|
49
57
|
product = terminal.product.list
|
50
|
-
rescue TerminalShop::
|
58
|
+
rescue TerminalShop::Errors::APIError => e
|
51
59
|
puts(e.status) # 400
|
52
60
|
end
|
53
61
|
```
|
@@ -63,7 +71,7 @@ Error codes are as followed:
|
|
63
71
|
| HTTP 409 | `ConflictError` |
|
64
72
|
| HTTP 422 | `UnprocessableEntityError` |
|
65
73
|
| HTTP 429 | `RateLimitError` |
|
66
|
-
| HTTP >=500
|
74
|
+
| HTTP >= 500 | `InternalServerError` |
|
67
75
|
| Other HTTP error | `APIStatusError` |
|
68
76
|
| Timeout | `APITimeoutError` |
|
69
77
|
| Network error | `APIConnectionError` |
|
@@ -104,27 +112,51 @@ terminal = TerminalShop::Client.new(
|
|
104
112
|
terminal.product.list(request_options: {timeout: 5})
|
105
113
|
```
|
106
114
|
|
107
|
-
##
|
115
|
+
## Model DSL
|
108
116
|
|
109
|
-
|
117
|
+
This library uses a simple DSL to represent request parameters and response shapes in `lib/terminal_shop/models`.
|
110
118
|
|
111
|
-
|
112
|
-
|
113
|
-
What this means is that while you can use Sorbet to type check your code statically, and benefit from the [Sorbet Language Server](https://sorbet.org/docs/lsp) in your editor, there is no runtime type checking and execution overhead from Sorbet itself.
|
114
|
-
|
115
|
-
Due to limitations with the Sorbet type system, where a method otherwise can take an instance of `TerminalShop::BaseModel` class, you will need to use the `**` splat operator to pass the arguments:
|
119
|
+
With the right [editor plugins](https://shopify.github.io/ruby-lsp), you can ctrl-click on elements of the DSL to navigate around and explore the library.
|
116
120
|
|
117
|
-
|
121
|
+
In all places where a `BaseModel` type is specified, vanilla Ruby `Hash` can also be used. For example, the following are interchangeable as arguments:
|
118
122
|
|
119
123
|
```ruby
|
120
|
-
|
124
|
+
# This has tooling readability, for auto-completion, static analysis, and goto definition with supported language services
|
125
|
+
params = TerminalShop::Models::ProductListParams.new
|
121
126
|
|
122
|
-
|
127
|
+
# This also works
|
128
|
+
params = {
|
129
|
+
|
130
|
+
}
|
123
131
|
```
|
124
132
|
|
125
|
-
##
|
133
|
+
## Editor support
|
134
|
+
|
135
|
+
A combination of [Shopify LSP](https://shopify.github.io/ruby-lsp) and [Solargraph](https://solargraph.org/) is recommended for non-[Sorbet](https://sorbet.org) users. The former is especially good at go to definition, while the latter has much better auto-completion support.
|
136
|
+
|
137
|
+
## Advanced concepts
|
138
|
+
|
139
|
+
### Making custom/undocumented requests
|
140
|
+
|
141
|
+
#### Undocumented request params
|
142
|
+
|
143
|
+
If you want to explicitly send an extra param, you can do so with the `extra_query`, `extra_body`, and `extra_headers` under the `request_options:` parameter when making a requests as seen in examples above.
|
144
|
+
|
145
|
+
#### Undocumented endpoints
|
126
146
|
|
127
|
-
|
147
|
+
To make requests to undocumented endpoints, you can make requests using `client.request`. Options on the client will be respected (such as retries) when making this request.
|
148
|
+
|
149
|
+
```ruby
|
150
|
+
response = client.request(
|
151
|
+
method: :post,
|
152
|
+
path: '/undocumented/endpoint',
|
153
|
+
query: {"dog": "woof"},
|
154
|
+
headers: {"useful-header": "interesting-value"},
|
155
|
+
body: {"he": "llo"},
|
156
|
+
)
|
157
|
+
```
|
158
|
+
|
159
|
+
### Concurrency & connection pooling
|
128
160
|
|
129
161
|
The `TerminalShop::Client` instances are thread-safe, and should be re-used across multiple threads. By default, each `Client` have their own HTTP connection pool, with a maximum number of connections equal to thread count.
|
130
162
|
|
@@ -134,6 +166,30 @@ Unless otherwise specified, other classes in the SDK do not have locks protectin
|
|
134
166
|
|
135
167
|
Currently, `TerminalShop::Client` instances are only fork-safe if there are no in-flight HTTP requests.
|
136
168
|
|
169
|
+
### Sorbet
|
170
|
+
|
171
|
+
#### Enums
|
172
|
+
|
173
|
+
Sorbet's typed enums require sub-classing of the [`T::Enum` class](https://sorbet.org/docs/tenum) from the `sorbet-runtime` gem.
|
174
|
+
|
175
|
+
Since this library does not depend on `sorbet-runtime`, it uses a [`T.all` intersection type](https://sorbet.org/docs/intersection-types) with a ruby primitive type to construct a "tagged alias" instead.
|
176
|
+
|
177
|
+
```ruby
|
178
|
+
module TerminalShop::Models::Region
|
179
|
+
# This alias aids language service driven navigation.
|
180
|
+
TaggedSymbol = T.type_alias { T.all(Symbol, TerminalShop::Models::Region) }
|
181
|
+
end
|
182
|
+
```
|
183
|
+
|
184
|
+
#### Argument passing trick
|
185
|
+
|
186
|
+
It is possible to pass a compatible model / parameter class to a method that expects keyword arguments by using the `**` splat operator.
|
187
|
+
|
188
|
+
```ruby
|
189
|
+
params = TerminalShop::Models::ProductListParams.new
|
190
|
+
terminal.product.list(**params)
|
191
|
+
```
|
192
|
+
|
137
193
|
## Versioning
|
138
194
|
|
139
195
|
This package follows [SemVer](https://semver.org/spec/v2.0.0.html) conventions. As the library is in initial development and has a major version of `0`, APIs may change at any time.
|
@@ -142,4 +198,8 @@ This package considers improvements to the (non-runtime) `*.rbi` and `*.rbs` typ
|
|
142
198
|
|
143
199
|
## Requirements
|
144
200
|
|
145
|
-
Ruby 3.
|
201
|
+
Ruby 3.1.0 or higher.
|
202
|
+
|
203
|
+
## Contributing
|
204
|
+
|
205
|
+
See [the contributing documentation](https://github.com/terminaldotshop/terminal-sdk-ruby/tree/main/CONTRIBUTING.md).
|
data/SECURITY.md
ADDED
@@ -0,0 +1,27 @@
|
|
1
|
+
# Security Policy
|
2
|
+
|
3
|
+
## Reporting Security Issues
|
4
|
+
|
5
|
+
This SDK is generated by [Stainless Software Inc](http://stainless.com). Stainless takes security seriously, and encourages you to report any security vulnerability promptly so that appropriate action can be taken.
|
6
|
+
|
7
|
+
To report a security issue, please contact the Stainless team at security@stainless.com.
|
8
|
+
|
9
|
+
## Responsible Disclosure
|
10
|
+
|
11
|
+
We appreciate the efforts of security researchers and individuals who help us maintain the security of
|
12
|
+
SDKs we generate. If you believe you have found a security vulnerability, please adhere to responsible
|
13
|
+
disclosure practices by allowing us a reasonable amount of time to investigate and address the issue
|
14
|
+
before making any information public.
|
15
|
+
|
16
|
+
## Reporting Non-SDK Related Security Issues
|
17
|
+
|
18
|
+
If you encounter security issues that are not directly related to SDKs but pertain to the services
|
19
|
+
or products provided by Terminal please follow the respective company's security reporting guidelines.
|
20
|
+
|
21
|
+
### Terminal Terms and Policies
|
22
|
+
|
23
|
+
Please contact dev@terminal.com for any questions or concerns regarding security of our services.
|
24
|
+
|
25
|
+
---
|
26
|
+
|
27
|
+
Thank you for helping us keep the SDKs and systems they interact with secure.
|
@@ -1,7 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module TerminalShop
|
4
|
-
class Client < TerminalShop::Transport::BaseClient
|
4
|
+
class Client < TerminalShop::Internal::Transport::BaseClient
|
5
5
|
# Default max number of retries to attempt after a failed retryable request.
|
6
6
|
DEFAULT_MAX_RETRIES = 2
|
7
7
|
|
@@ -70,18 +70,19 @@ module TerminalShop
|
|
70
70
|
|
71
71
|
# Creates and returns a new client for interacting with the API.
|
72
72
|
#
|
73
|
-
# @param
|
73
|
+
# @param bearer_token [String, nil] Defaults to `ENV["TERMINAL_BEARER_TOKEN"]`
|
74
74
|
#
|
75
|
-
#
|
75
|
+
# @param app_id [String, nil]
|
76
76
|
#
|
77
|
-
#
|
78
|
-
# - `dev` corresponds to `https://api.dev.terminal.shop`
|
77
|
+
# @param environment [:production, :dev, nil] Specifies the environment to use for the API.
|
79
78
|
#
|
80
|
-
#
|
79
|
+
# Each environment maps to a different base URL:
|
81
80
|
#
|
82
|
-
#
|
81
|
+
# - `production` corresponds to `https://api.terminal.shop`
|
82
|
+
# - `dev` corresponds to `https://api.dev.terminal.shop`
|
83
83
|
#
|
84
|
-
# @param
|
84
|
+
# @param base_url [String, nil] Override the default base URL for the API, e.g.,
|
85
|
+
# `"https://api.example.com/v2/"`. Defaults to `ENV["TERMINAL_BASE_URL"]`
|
85
86
|
#
|
86
87
|
# @param max_retries [Integer] Max number of retries to attempt after a failed retryable request.
|
87
88
|
#
|
@@ -91,28 +92,22 @@ module TerminalShop
|
|
91
92
|
#
|
92
93
|
# @param max_retry_delay [Float]
|
93
94
|
def initialize(
|
94
|
-
environment: nil,
|
95
|
-
base_url: nil,
|
96
95
|
bearer_token: ENV["TERMINAL_BEARER_TOKEN"],
|
97
96
|
app_id: nil,
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
97
|
+
environment: nil,
|
98
|
+
base_url: ENV["TERMINAL_BASE_URL"],
|
99
|
+
max_retries: TerminalShop::Client::DEFAULT_MAX_RETRIES,
|
100
|
+
timeout: TerminalShop::Client::DEFAULT_TIMEOUT_IN_SECONDS,
|
101
|
+
initial_retry_delay: TerminalShop::Client::DEFAULT_INITIAL_RETRY_DELAY,
|
102
|
+
max_retry_delay: TerminalShop::Client::DEFAULT_MAX_RETRY_DELAY
|
102
103
|
)
|
103
|
-
|
104
|
-
|
105
|
-
raise ArgumentError.new(
|
106
|
-
in [Symbol | String, nil]
|
107
|
-
base_url = ENVIRONMENTS.fetch(environment.to_sym) do
|
108
|
-
raise ArgumentError.new("environment must be one of #{ENVIRONMENTS.keys}, got #{environment}")
|
109
|
-
end
|
110
|
-
else
|
111
|
-
base_url ||= ENVIRONMENTS.fetch(:production)
|
104
|
+
base_url ||= TerminalShop::Client::ENVIRONMENTS.fetch(environment&.to_sym || :production) do
|
105
|
+
message = "environment must be one of #{TerminalShop::Client::ENVIRONMENTS.keys}, got #{environment}"
|
106
|
+
raise ArgumentError.new(message)
|
112
107
|
end
|
113
108
|
|
114
109
|
if bearer_token.nil?
|
115
|
-
raise ArgumentError.new("bearer_token is required")
|
110
|
+
raise ArgumentError.new("bearer_token is required, and can be set via environ: \"TERMINAL_BEARER_TOKEN\"")
|
116
111
|
end
|
117
112
|
|
118
113
|
headers = {
|
@@ -0,0 +1,192 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module TerminalShop
|
4
|
+
module Errors
|
5
|
+
class Error < StandardError
|
6
|
+
# @!parse
|
7
|
+
# # @return [StandardError, nil]
|
8
|
+
# attr_accessor :cause
|
9
|
+
end
|
10
|
+
|
11
|
+
class ConversionError < TerminalShop::Errors::Error
|
12
|
+
end
|
13
|
+
|
14
|
+
class APIError < TerminalShop::Errors::Error
|
15
|
+
# @return [URI::Generic]
|
16
|
+
attr_accessor :url
|
17
|
+
|
18
|
+
# @return [Integer, nil]
|
19
|
+
attr_accessor :status
|
20
|
+
|
21
|
+
# @return [Object, nil]
|
22
|
+
attr_accessor :body
|
23
|
+
|
24
|
+
# @api private
|
25
|
+
#
|
26
|
+
# @param url [URI::Generic]
|
27
|
+
# @param status [Integer, nil]
|
28
|
+
# @param body [Object, nil]
|
29
|
+
# @param request [nil]
|
30
|
+
# @param response [nil]
|
31
|
+
# @param message [String, nil]
|
32
|
+
def initialize(url:, status: nil, body: nil, request: nil, response: nil, message: nil)
|
33
|
+
@url = url
|
34
|
+
@status = status
|
35
|
+
@body = body
|
36
|
+
@request = request
|
37
|
+
@response = response
|
38
|
+
super(message)
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
class APIConnectionError < TerminalShop::Errors::APIError
|
43
|
+
# @!parse
|
44
|
+
# # @return [nil]
|
45
|
+
# attr_accessor :status
|
46
|
+
|
47
|
+
# @!parse
|
48
|
+
# # @return [nil]
|
49
|
+
# attr_accessor :body
|
50
|
+
|
51
|
+
# @api private
|
52
|
+
#
|
53
|
+
# @param url [URI::Generic]
|
54
|
+
# @param status [nil]
|
55
|
+
# @param body [nil]
|
56
|
+
# @param request [nil]
|
57
|
+
# @param response [nil]
|
58
|
+
# @param message [String, nil]
|
59
|
+
def initialize(
|
60
|
+
url:,
|
61
|
+
status: nil,
|
62
|
+
body: nil,
|
63
|
+
request: nil,
|
64
|
+
response: nil,
|
65
|
+
message: "Connection error."
|
66
|
+
)
|
67
|
+
super
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
class APITimeoutError < TerminalShop::Errors::APIConnectionError
|
72
|
+
# @api private
|
73
|
+
#
|
74
|
+
# @param url [URI::Generic]
|
75
|
+
# @param status [nil]
|
76
|
+
# @param body [nil]
|
77
|
+
# @param request [nil]
|
78
|
+
# @param response [nil]
|
79
|
+
# @param message [String, nil]
|
80
|
+
def initialize(
|
81
|
+
url:,
|
82
|
+
status: nil,
|
83
|
+
body: nil,
|
84
|
+
request: nil,
|
85
|
+
response: nil,
|
86
|
+
message: "Request timed out."
|
87
|
+
)
|
88
|
+
super
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
class APIStatusError < TerminalShop::Errors::APIError
|
93
|
+
# @api private
|
94
|
+
#
|
95
|
+
# @param url [URI::Generic]
|
96
|
+
# @param status [Integer]
|
97
|
+
# @param body [Object, nil]
|
98
|
+
# @param request [nil]
|
99
|
+
# @param response [nil]
|
100
|
+
# @param message [String, nil]
|
101
|
+
#
|
102
|
+
# @return [TerminalShop::Errors::APIStatusError]
|
103
|
+
def self.for(url:, status:, body:, request:, response:, message: nil)
|
104
|
+
kwargs = {
|
105
|
+
url: url,
|
106
|
+
status: status,
|
107
|
+
body: body,
|
108
|
+
request: request,
|
109
|
+
response: response,
|
110
|
+
message: message
|
111
|
+
}
|
112
|
+
|
113
|
+
case status
|
114
|
+
in 400
|
115
|
+
TerminalShop::Errors::BadRequestError.new(**kwargs)
|
116
|
+
in 401
|
117
|
+
TerminalShop::Errors::AuthenticationError.new(**kwargs)
|
118
|
+
in 403
|
119
|
+
TerminalShop::Errors::PermissionDeniedError.new(**kwargs)
|
120
|
+
in 404
|
121
|
+
TerminalShop::Errors::NotFoundError.new(**kwargs)
|
122
|
+
in 409
|
123
|
+
TerminalShop::Errors::ConflictError.new(**kwargs)
|
124
|
+
in 422
|
125
|
+
TerminalShop::Errors::UnprocessableEntityError.new(**kwargs)
|
126
|
+
in 429
|
127
|
+
TerminalShop::Errors::RateLimitError.new(**kwargs)
|
128
|
+
in (500..)
|
129
|
+
TerminalShop::Errors::InternalServerError.new(**kwargs)
|
130
|
+
else
|
131
|
+
TerminalShop::Errors::APIStatusError.new(**kwargs)
|
132
|
+
end
|
133
|
+
end
|
134
|
+
|
135
|
+
# @!parse
|
136
|
+
# # @return [Integer]
|
137
|
+
# attr_accessor :status
|
138
|
+
|
139
|
+
# @api private
|
140
|
+
#
|
141
|
+
# @param url [URI::Generic]
|
142
|
+
# @param status [Integer]
|
143
|
+
# @param body [Object, nil]
|
144
|
+
# @param request [nil]
|
145
|
+
# @param response [nil]
|
146
|
+
# @param message [String, nil]
|
147
|
+
def initialize(url:, status:, body:, request:, response:, message: nil)
|
148
|
+
message ||= {url: url.to_s, status: status, body: body}
|
149
|
+
super(
|
150
|
+
url: url,
|
151
|
+
status: status,
|
152
|
+
body: body,
|
153
|
+
request: request,
|
154
|
+
response: response,
|
155
|
+
message: message&.to_s
|
156
|
+
)
|
157
|
+
end
|
158
|
+
end
|
159
|
+
|
160
|
+
class BadRequestError < TerminalShop::Errors::APIStatusError
|
161
|
+
HTTP_STATUS = 400
|
162
|
+
end
|
163
|
+
|
164
|
+
class AuthenticationError < TerminalShop::Errors::APIStatusError
|
165
|
+
HTTP_STATUS = 401
|
166
|
+
end
|
167
|
+
|
168
|
+
class PermissionDeniedError < TerminalShop::Errors::APIStatusError
|
169
|
+
HTTP_STATUS = 403
|
170
|
+
end
|
171
|
+
|
172
|
+
class NotFoundError < TerminalShop::Errors::APIStatusError
|
173
|
+
HTTP_STATUS = 404
|
174
|
+
end
|
175
|
+
|
176
|
+
class ConflictError < TerminalShop::Errors::APIStatusError
|
177
|
+
HTTP_STATUS = 409
|
178
|
+
end
|
179
|
+
|
180
|
+
class UnprocessableEntityError < TerminalShop::Errors::APIStatusError
|
181
|
+
HTTP_STATUS = 422
|
182
|
+
end
|
183
|
+
|
184
|
+
class RateLimitError < TerminalShop::Errors::APIStatusError
|
185
|
+
HTTP_STATUS = 429
|
186
|
+
end
|
187
|
+
|
188
|
+
class InternalServerError < TerminalShop::Errors::APIStatusError
|
189
|
+
HTTP_STATUS = (500..)
|
190
|
+
end
|
191
|
+
end
|
192
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module TerminalShop
|
4
|
+
class FilePart
|
5
|
+
# @return [Pathname, StringIO, IO, String]
|
6
|
+
attr_reader :content
|
7
|
+
|
8
|
+
# @return [String, nil]
|
9
|
+
attr_reader :content_type
|
10
|
+
|
11
|
+
# @return [String, nil]
|
12
|
+
attr_reader :filename
|
13
|
+
|
14
|
+
# @api private
|
15
|
+
#
|
16
|
+
# @return [String]
|
17
|
+
private def read
|
18
|
+
case content
|
19
|
+
in Pathname
|
20
|
+
content.read(binmode: true)
|
21
|
+
in StringIO
|
22
|
+
content.string
|
23
|
+
in IO
|
24
|
+
content.read
|
25
|
+
in String
|
26
|
+
content
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
# @param a [Object]
|
31
|
+
#
|
32
|
+
# @return [String]
|
33
|
+
def to_json(*a) = read.to_json(*a)
|
34
|
+
|
35
|
+
# @param a [Object]
|
36
|
+
#
|
37
|
+
# @return [String]
|
38
|
+
def to_yaml(*a) = read.to_yaml(*a)
|
39
|
+
|
40
|
+
# @param content [Pathname, StringIO, IO, String]
|
41
|
+
# @param filename [String, nil]
|
42
|
+
# @param content_type [String, nil]
|
43
|
+
def initialize(content, filename: nil, content_type: nil)
|
44
|
+
@content = content
|
45
|
+
@filename =
|
46
|
+
case content
|
47
|
+
in Pathname
|
48
|
+
filename.nil? ? content.basename.to_path : File.basename(filename)
|
49
|
+
else
|
50
|
+
filename.nil? ? nil : File.basename(filename)
|
51
|
+
end
|
52
|
+
@content_type = content_type
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|