Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .fern/metadata.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,6 @@
"webrick": ">= 1.0"
}
},
"originGitCommit": "a3057c10aa6a1daa708dc714c89ce943f67a722a",
"sdkVersion": "1.4.3"
"originGitCommit": "ad1cc528e658e3693935b819c9d22eed02d49017",
"sdkVersion": "1.4.4"
}
503 changes: 501 additions & 2 deletions .fern/replay.lock

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions Gemfile.lock
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
PATH
remote: .
specs:
schematichq (1.4.3)
schematichq (1.4.4)
wasmtime (>= 19.0)
websocket (>= 1.2)

Expand All @@ -18,7 +18,7 @@ GEM
rexml
hashdiff (1.2.1)
io-console (0.8.2)
json (2.19.7)
json (2.19.8)
language_server-protocol (3.17.0.5)
lint_roller (1.1.0)
method_source (1.1.0)
Expand Down
24 changes: 20 additions & 4 deletions lib/schematic.rb
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@
require_relative "schematic/types/account_member_response_data"
require_relative "schematic/accounts/types/list_account_members_response"
require_relative "schematic/accounts/types/get_account_member_response"
require_relative "schematic/accounts/types/count_account_members_params"
require_relative "schematic/types/count_response"
require_relative "schematic/accounts/types/count_account_members_response"
require_relative "schematic/accounts/types/list_api_keys_params"
require_relative "schematic/types/integration_state"
require_relative "schematic/types/integration_type"
Expand All @@ -57,7 +60,6 @@
require_relative "schematic/types/delete_response"
require_relative "schematic/accounts/types/delete_api_key_response"
require_relative "schematic/accounts/types/count_api_keys_params"
require_relative "schematic/types/count_response"
require_relative "schematic/accounts/types/count_api_keys_response"
require_relative "schematic/types/actor_type"
require_relative "schematic/accounts/types/list_audit_logs_params"
Expand Down Expand Up @@ -203,12 +205,14 @@
require_relative "schematic/credits/types/count_billing_plan_credit_grants_response"
require_relative "schematic/types/credit_event_type"
require_relative "schematic/credits/types/list_credit_event_ledger_params"
require_relative "schematic/types/credit_usage_reason"
require_relative "schematic/types/credit_event_ledger_response_data"
require_relative "schematic/credits/types/list_credit_event_ledger_response"
require_relative "schematic/credits/types/count_credit_event_ledger_params"
require_relative "schematic/credits/types/count_credit_event_ledger_response"
require_relative "schematic/types/checkout_subscription"
require_relative "schematic/checkout/types/checkout_internal_response"
require_relative "schematic/types/billing_credit_ledger_authority"
require_relative "schematic/types/credit_currency_price"
require_relative "schematic/types/billing_credit_view"
require_relative "schematic/types/billing_linked_resource_response_data"
Expand All @@ -217,6 +221,7 @@
require_relative "schematic/types/billing_subscription_discount_view"
require_relative "schematic/types/billing_subscription_view"
require_relative "schematic/types/charge_type"
require_relative "schematic/types/checkout_field_with_value"
require_relative "schematic/types/metric_period"
require_relative "schematic/types/metric_period_month_reset"
require_relative "schematic/types/company_event_period_metrics_response_data"
Expand Down Expand Up @@ -536,6 +541,7 @@
require_relative "schematic/integrationsapi/types/list_integrations_params"
require_relative "schematic/types/clerk_integration_config"
require_relative "schematic/types/integration_capabilities"
require_relative "schematic/types/metronome_integration_config"
require_relative "schematic/types/orb_integration_config"
require_relative "schematic/types/stripe_integration_config"
require_relative "schematic/types/work_os_integration_config"
Expand All @@ -544,11 +550,19 @@
require_relative "schematic/integrationsapi/types/list_integrations_response"
require_relative "schematic/types/integration_webhook_url_response_data"
require_relative "schematic/integrationsapi/types/get_integration_webhook_url_response"
require_relative "schematic/types/company_matching_criteria"
require_relative "schematic/types/integration_install_config"
require_relative "schematic/types/integration_response_data"
require_relative "schematic/types/integration_install_response_data"
require_relative "schematic/integrationsapi/types/install_integration_response"
require_relative "schematic/integrationsapi/types/start_data_import_response"
require_relative "schematic/types/integrations_data_set_response_data"
require_relative "schematic/integrationsapi/types/load_sample_data_set_v_2_response"
require_relative "schematic/integrationsapi/types/load_sample_data_set_response"
require_relative "schematic/integrationsapi/types/assume_stripe_installed_response"
require_relative "schematic/integrationsapi/types/install_stripe_response"
require_relative "schematic/integrationsapi/types/uninstall_integration_response"
require_relative "schematic/plangroups/types/get_plan_group_params"
require_relative "schematic/types/checkout_field_response_data"
require_relative "schematic/types/checkout_settings_response_data"
require_relative "schematic/types/component_settings_response_data"
require_relative "schematic/types/custom_plan_view_config_response_data"
Expand Down Expand Up @@ -620,14 +634,15 @@
require_relative "schematic/types/billing_subscription_discount"
require_relative "schematic/types/capture_raw_event"
require_relative "schematic/types/capture_raw_event_batch"
require_relative "schematic/types/checkout_field_value"
require_relative "schematic/types/update_add_on_request_body"
require_relative "schematic/types/update_auto_topup_override_request_body"
require_relative "schematic/types/update_credit_bundle_request_body"
require_relative "schematic/types/update_pay_in_advance_request_body"
require_relative "schematic/types/change_subscription_internal_request_body"
require_relative "schematic/types/change_subscription_request_body"
require_relative "schematic/types/check_flag_request_body"
require_relative "schematic/types/company_matching_criteria"
require_relative "schematic/types/checkout_field_input"
require_relative "schematic/types/company_membership_response_data"
require_relative "schematic/types/component_hydrate_response_data"
require_relative "schematic/types/condition_group_response_data"
Expand Down Expand Up @@ -671,7 +686,7 @@
require_relative "schematic/types/flag_view"
require_relative "schematic/types/feature_view"
require_relative "schematic/types/feature_usage_legacy_response_data"
require_relative "schematic/types/integration_response_data"
require_relative "schematic/types/install_integration_request_body"
require_relative "schematic/types/invoice_request_body"
require_relative "schematic/types/keys_request_body"
require_relative "schematic/types/plan_selection"
Expand Down Expand Up @@ -728,6 +743,7 @@
require_relative "schematic/client"
require_relative "schematic/accounts/client"
require_relative "schematic/accounts/types/list_account_members_request"
require_relative "schematic/accounts/types/count_account_members_request"
require_relative "schematic/accounts/types/list_api_keys_request"
require_relative "schematic/accounts/types/create_api_key_request_body"
require_relative "schematic/accounts/types/update_api_key_request_body"
Expand Down
44 changes: 44 additions & 0 deletions lib/schematic/accounts/client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,50 @@ def get_account_member(request_options: {}, **params)
end
end

# @param request_options [Hash]
# @param params [Hash]
# @option request_options [String] :base_url
# @option request_options [Hash{String => Object}] :additional_headers
# @option request_options [Hash{String => Object}] :additional_query_parameters
# @option request_options [Hash{String => Object}] :additional_body_parameters
# @option request_options [Integer] :timeout_in_seconds
# @option params [String, nil] :ids
# @option params [String, nil] :q
# @option params [Integer, nil] :limit
# @option params [Integer, nil] :offset
#
# @return [Schematic::Accounts::Types::CountAccountMembersResponse]
def count_account_members(request_options: {}, **params)
params = Schematic::Internal::Types::Utils.normalize_keys(params)
query_param_names = %i[ids q limit offset]
query_params = {}
query_params["ids"] = params[:ids] if params.key?(:ids)
query_params["q"] = params[:q] if params.key?(:q)
query_params["limit"] = params[:limit] if params.key?(:limit)
query_params["offset"] = params[:offset] if params.key?(:offset)
params.except(*query_param_names)

request = Schematic::Internal::JSON::Request.new(
base_url: request_options[:base_url],
method: "GET",
path: "account-members/count",
query: query_params,
request_options: request_options
)
begin
response = @client.send(request)
rescue Net::HTTPRequestTimeout
raise Schematic::Errors::TimeoutError
end
code = response.code.to_i
if code.between?(200, 299)
Schematic::Accounts::Types::CountAccountMembersResponse.load(response.body)
else
error_class = Schematic::Errors::ResponseError.subclass_for_code(code)
raise error_class.new(response.body, code: code)
end
end

# @param request_options [Hash]
# @param params [Hash]
# @option request_options [String] :base_url
Expand Down
15 changes: 15 additions & 0 deletions lib/schematic/accounts/types/count_account_members_params.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# frozen_string_literal: true

module Schematic
module Accounts
module Types
# Input parameters
class CountAccountMembersParams < Internal::Types::Model
field :ids, -> { Internal::Types::Array[String] }, optional: true, nullable: false
field :limit, -> { Integer }, optional: true, nullable: false
field :offset, -> { Integer }, optional: true, nullable: false
field :q, -> { String }, optional: true, nullable: false
end
end
end
end
14 changes: 14 additions & 0 deletions lib/schematic/accounts/types/count_account_members_request.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# frozen_string_literal: true

module Schematic
module Accounts
module Types
class CountAccountMembersRequest < Internal::Types::Model
field :ids, -> { String }, optional: true, nullable: false
field :q, -> { String }, optional: true, nullable: false
field :limit, -> { Integer }, optional: true, nullable: false
field :offset, -> { Integer }, optional: true, nullable: false
end
end
end
end
12 changes: 12 additions & 0 deletions lib/schematic/accounts/types/count_account_members_response.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# frozen_string_literal: true

module Schematic
module Accounts
module Types
class CountAccountMembersResponse < Internal::Types::Model
field :data, -> { Schematic::Types::CountResponse }, optional: false, nullable: false
field :params, -> { Schematic::Accounts::Types::CountAccountMembersParams }, optional: false, nullable: false
end
end
end
end
2 changes: 1 addition & 1 deletion lib/schematic/client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ def initialize(api_key:, base_url: nil)
@raw_client = Schematic::Internal::Http::RawClient.new(
base_url: base_url || Schematic::Environment::DEFAULT,
headers: {
"User-Agent" => "schematichq/1.4.3",
"User-Agent" => "schematichq/1.4.4",
"X-Fern-Language" => "Ruby",
"X-Schematic-Api-Key" => api_key.to_s
}
Expand Down
102 changes: 99 additions & 3 deletions lib/schematic/integrationsapi/client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,38 @@ def get_integration_webhook_url(request_options: {}, **params)
end
end

# @param request_options [Hash]
# @param params [Schematic::Types::InstallIntegrationRequestBody]
# @option request_options [String] :base_url
# @option request_options [Hash{String => Object}] :additional_headers
# @option request_options [Hash{String => Object}] :additional_query_parameters
# @option request_options [Hash{String => Object}] :additional_body_parameters
# @option request_options [Integer] :timeout_in_seconds
#
# @return [Schematic::Integrationsapi::Types::InstallIntegrationResponse]
def install_integration(request_options: {}, **params)
params = Schematic::Internal::Types::Utils.normalize_keys(params)
request = Schematic::Internal::JSON::Request.new(
base_url: request_options[:base_url],
method: "POST",
path: "integrations/install",
body: Schematic::Types::InstallIntegrationRequestBody.new(params).to_h,
request_options: request_options
)
begin
response = @client.send(request)
rescue Net::HTTPRequestTimeout
raise Schematic::Errors::TimeoutError
end
code = response.code.to_i
if code.between?(200, 299)
Schematic::Integrationsapi::Types::InstallIntegrationResponse.load(response.body)
else
error_class = Schematic::Errors::ResponseError.subclass_for_code(code)
raise error_class.new(response.body, code: code)
end
end

# @param request_options [Hash]
# @param params [Schematic::Integrationsapi::Types::StartDataImportRequestBody]
# @option request_options [String] :base_url
Expand Down Expand Up @@ -164,8 +196,8 @@ def start_data_import(request_options: {}, **params)
# @option request_options [Hash{String => Object}] :additional_body_parameters
# @option request_options [Integer] :timeout_in_seconds
#
# @return [Schematic::Integrationsapi::Types::LoadSampleDataSetV2Response]
def load_sample_data_set_v_2(request_options: {}, **params)
# @return [Schematic::Integrationsapi::Types::LoadSampleDataSetResponse]
def load_sample_data_set(request_options: {}, **params)
Schematic::Internal::Types::Utils.normalize_keys(params)
request = Schematic::Internal::JSON::Request.new(
base_url: request_options[:base_url],
Expand All @@ -180,7 +212,71 @@ def load_sample_data_set_v_2(request_options: {}, **params)
end
code = response.code.to_i
if code.between?(200, 299)
Schematic::Integrationsapi::Types::LoadSampleDataSetV2Response.load(response.body)
Schematic::Integrationsapi::Types::LoadSampleDataSetResponse.load(response.body)
else
error_class = Schematic::Errors::ResponseError.subclass_for_code(code)
raise error_class.new(response.body, code: code)
end
end

# @param request_options [Hash]
# @param params [Schematic::Types::InstallIntegrationRequestBody]
# @option request_options [String] :base_url
# @option request_options [Hash{String => Object}] :additional_headers
# @option request_options [Hash{String => Object}] :additional_query_parameters
# @option request_options [Hash{String => Object}] :additional_body_parameters
# @option request_options [Integer] :timeout_in_seconds
#
# @return [Schematic::Integrationsapi::Types::AssumeStripeInstalledResponse]
def assume_stripe_installed(request_options: {}, **params)
params = Schematic::Internal::Types::Utils.normalize_keys(params)
request = Schematic::Internal::JSON::Request.new(
base_url: request_options[:base_url],
method: "POST",
path: "integrations/stripe/v2/assume-installed",
body: Schematic::Types::InstallIntegrationRequestBody.new(params).to_h,
request_options: request_options
)
begin
response = @client.send(request)
rescue Net::HTTPRequestTimeout
raise Schematic::Errors::TimeoutError
end
code = response.code.to_i
if code.between?(200, 299)
Schematic::Integrationsapi::Types::AssumeStripeInstalledResponse.load(response.body)
else
error_class = Schematic::Errors::ResponseError.subclass_for_code(code)
raise error_class.new(response.body, code: code)
end
end

# @param request_options [Hash]
# @param params [Schematic::Types::InstallIntegrationRequestBody]
# @option request_options [String] :base_url
# @option request_options [Hash{String => Object}] :additional_headers
# @option request_options [Hash{String => Object}] :additional_query_parameters
# @option request_options [Hash{String => Object}] :additional_body_parameters
# @option request_options [Integer] :timeout_in_seconds
#
# @return [Schematic::Integrationsapi::Types::InstallStripeResponse]
def install_stripe(request_options: {}, **params)
params = Schematic::Internal::Types::Utils.normalize_keys(params)
request = Schematic::Internal::JSON::Request.new(
base_url: request_options[:base_url],
method: "POST",
path: "integrations/stripe/v2/install",
body: Schematic::Types::InstallIntegrationRequestBody.new(params).to_h,
request_options: request_options
)
begin
response = @client.send(request)
rescue Net::HTTPRequestTimeout
raise Schematic::Errors::TimeoutError
end
code = response.code.to_i
if code.between?(200, 299)
Schematic::Integrationsapi::Types::InstallStripeResponse.load(response.body)
else
error_class = Schematic::Errors::ResponseError.subclass_for_code(code)
raise error_class.new(response.body, code: code)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# frozen_string_literal: true

module Schematic
module Integrationsapi
module Types
class AssumeStripeInstalledResponse < Internal::Types::Model
field :data, -> { Schematic::Types::IntegrationInstallResponseData }, optional: false, nullable: false
field :params, -> { Internal::Types::Hash[String, Object] }, optional: false, nullable: false
end
end
end
end
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# frozen_string_literal: true

module Schematic
module Integrationsapi
module Types
class InstallIntegrationResponse < Internal::Types::Model
field :data, -> { Schematic::Types::IntegrationInstallResponseData }, optional: false, nullable: false
field :params, -> { Internal::Types::Hash[String, Object] }, optional: false, nullable: false
end
end
end
end
12 changes: 12 additions & 0 deletions lib/schematic/integrationsapi/types/install_stripe_response.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# frozen_string_literal: true

module Schematic
module Integrationsapi
module Types
class InstallStripeResponse < Internal::Types::Model
field :data, -> { Schematic::Types::IntegrationInstallResponseData }, optional: false, nullable: false
field :params, -> { Internal::Types::Hash[String, Object] }, optional: false, nullable: false
end
end
end
end
Loading