Class: Zavudev::Resources::SubAccounts

Inherits:
Object
  • Object
show all
Defined in:
lib/zavudev/resources/sub_accounts.rb,
lib/zavudev/resources/sub_accounts/api_keys.rb

Defined Under Namespace

Classes: APIKeys

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client:) ⇒ SubAccounts

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of SubAccounts.

Parameters:



163
164
165
166
# File 'lib/zavudev/resources/sub_accounts.rb', line 163

def initialize(client:)
  @client = client
  @api_keys = Zavudev::Resources::SubAccounts::APIKeys.new(client: client)
end

Instance Attribute Details

#api_keysZavudev::Resources::SubAccounts::APIKeys (readonly)



7
8
9
# File 'lib/zavudev/resources/sub_accounts.rb', line 7

def api_keys
  @api_keys
end

Instance Method Details

#create(name:, credit_limit: nil, external_id: nil, metadata: nil, request_options: {}) ⇒ Zavudev::Models::SubAccountCreateResponse

Some parameter documentations has been truncated, see Models::SubAccountCreateParams for more details.

Create a new sub-account (project) with its own API key. All charges are billed to the parent team’s balance. Use creditLimit to set a spending cap. The sub-account’s API key is returned only in the creation response.

Parameters:

  • name (String)

    Name of the sub-account.

  • credit_limit (Integer)

    Spending cap in cents. When reached, messages from this sub-account will be bloc

  • external_id (String)

    External reference ID for your own tracking.

  • metadata (Hash{Symbol=>Object})
  • request_options (Zavudev::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



31
32
33
34
35
36
37
38
39
40
# File 'lib/zavudev/resources/sub_accounts.rb', line 31

def create(params)
  parsed, options = Zavudev::SubAccountCreateParams.dump_request(params)
  @client.request(
    method: :post,
    path: "v1/sub-accounts",
    body: parsed,
    model: Zavudev::Models::SubAccountCreateResponse,
    options: options
  )
end

#deactivate(id, request_options: {}) ⇒ Zavudev::Models::SubAccountDeactivateResponse

Deactivate a sub-account. Remaining balance is returned to the parent team and all API keys are revoked.

Parameters:

Returns:

See Also:



130
131
132
133
134
135
136
137
# File 'lib/zavudev/resources/sub_accounts.rb', line 130

def deactivate(id, params = {})
  @client.request(
    method: :delete,
    path: ["v1/sub-accounts/%1$s", id],
    model: Zavudev::Models::SubAccountDeactivateResponse,
    options: params[:request_options]
  )
end

#get_balance(id, request_options: {}) ⇒ Zavudev::Models::SubAccountGetBalanceResponse

Get spending information for a sub-account. Returns the parent team’s balance, the sub-account’s total spending, and its credit limit (spending cap).

Parameters:

Returns:

See Also:



151
152
153
154
155
156
157
158
# File 'lib/zavudev/resources/sub_accounts.rb', line 151

def get_balance(id, params = {})
  @client.request(
    method: :get,
    path: ["v1/sub-accounts/%1$s/balance", id],
    model: Zavudev::Models::SubAccountGetBalanceResponse,
    options: params[:request_options]
  )
end

#list(cursor: nil, limit: nil, request_options: {}) ⇒ Zavudev::Internal::Cursor<Zavudev::Models::SubAccount>

List sub-accounts for this team.

Parameters:

Returns:

See Also:



105
106
107
108
109
110
111
112
113
114
115
116
# File 'lib/zavudev/resources/sub_accounts.rb', line 105

def list(params = {})
  parsed, options = Zavudev::SubAccountListParams.dump_request(params)
  query = Zavudev::Internal::Util.encode_query_params(parsed)
  @client.request(
    method: :get,
    path: "v1/sub-accounts",
    query: query,
    page: Zavudev::Internal::Cursor,
    model: Zavudev::SubAccount,
    options: options
  )
end

#retrieve(id, request_options: {}) ⇒ Zavudev::Models::SubAccountRetrieveResponse

Get sub-account

Parameters:

Returns:

See Also:



53
54
55
56
57
58
59
60
# File 'lib/zavudev/resources/sub_accounts.rb', line 53

def retrieve(id, params = {})
  @client.request(
    method: :get,
    path: ["v1/sub-accounts/%1$s", id],
    model: Zavudev::Models::SubAccountRetrieveResponse,
    options: params[:request_options]
  )
end

#update(id, credit_limit: nil, external_id: nil, metadata: nil, name: nil, status: nil, request_options: {}) ⇒ Zavudev::Models::SubAccountUpdateResponse

Update sub-account

Parameters:

Returns:

See Also:



83
84
85
86
87
88
89
90
91
92
# File 'lib/zavudev/resources/sub_accounts.rb', line 83

def update(id, params = {})
  parsed, options = Zavudev::SubAccountUpdateParams.dump_request(params)
  @client.request(
    method: :patch,
    path: ["v1/sub-accounts/%1$s", id],
    body: parsed,
    model: Zavudev::Models::SubAccountUpdateResponse,
    options: options
  )
end