Class: Zavudev::Resources::Senders::Agent::Tools

Inherits:
Object
  • Object
show all
Defined in:
lib/zavudev/resources/senders/agent/tools.rb

Instance Method Summary collapse

Constructor Details

#initialize(client:) ⇒ Tools

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 Tools.

Parameters:



191
192
193
# File 'lib/zavudev/resources/senders/agent/tools.rb', line 191

def initialize(client:)
  @client = client
end

Instance Method Details

#create(sender_id, description:, name:, parameters:, webhook_url:, enabled: nil, webhook_secret: nil, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolCreateResponse

Create a new tool for an agent. Tools allow the agent to call external webhooks.

Parameters:

Returns:

See Also:



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

def create(sender_id, params)
  parsed, options = Zavudev::Senders::Agent::ToolCreateParams.dump_request(params)
  @client.request(
    method: :post,
    path: ["v1/senders/%1$s/agent/tools", sender_id],
    body: parsed,
    model: Zavudev::Models::Senders::Agent::ToolCreateResponse,
    options: options
  )
end

#delete(tool_id, sender_id:, request_options: {}) ⇒ nil

Delete a tool.

Parameters:

Returns:

  • (nil)

See Also:



144
145
146
147
148
149
150
151
152
153
154
155
156
# File 'lib/zavudev/resources/senders/agent/tools.rb', line 144

def delete(tool_id, params)
  parsed, options = Zavudev::Senders::Agent::ToolDeleteParams.dump_request(params)
  sender_id =
    parsed.delete(:sender_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :delete,
    path: ["v1/senders/%1$s/agent/tools/%2$s", sender_id, tool_id],
    model: NilClass,
    options: options
  )
end

#list(sender_id, cursor: nil, enabled: nil, limit: nil, request_options: {}) ⇒ Zavudev::Internal::Cursor<Zavudev::Models::Senders::Agent::AgentTool>

List tools for an agent.

Parameters:

  • sender_id (String)
  • cursor (String)
  • enabled (Boolean)
  • limit (Integer)
  • request_options (Zavudev::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



120
121
122
123
124
125
126
127
128
129
130
131
# File 'lib/zavudev/resources/senders/agent/tools.rb', line 120

def list(sender_id, params = {})
  parsed, options = Zavudev::Senders::Agent::ToolListParams.dump_request(params)
  query = Zavudev::Internal::Util.encode_query_params(parsed)
  @client.request(
    method: :get,
    path: ["v1/senders/%1$s/agent/tools", sender_id],
    query: query,
    page: Zavudev::Internal::Cursor,
    model: Zavudev::Senders::Agent::AgentTool,
    options: options
  )
end

#retrieve(tool_id, sender_id:, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolRetrieveResponse

Get a specific tool.

Parameters:

Returns:

See Also:



53
54
55
56
57
58
59
60
61
62
63
64
65
# File 'lib/zavudev/resources/senders/agent/tools.rb', line 53

def retrieve(tool_id, params)
  parsed, options = Zavudev::Senders::Agent::ToolRetrieveParams.dump_request(params)
  sender_id =
    parsed.delete(:sender_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :get,
    path: ["v1/senders/%1$s/agent/tools/%2$s", sender_id, tool_id],
    model: Zavudev::Models::Senders::Agent::ToolRetrieveResponse,
    options: options
  )
end

#test_(tool_id, sender_id:, test_params:, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolTestResponse

Test a tool by triggering its webhook with test parameters.

Parameters:

  • tool_id (String)

    Path param

  • sender_id (String)

    Path param

  • test_params (Hash{Symbol=>Object})

    Body param: Parameters to pass to the tool for testing.

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

Returns:

See Also:



173
174
175
176
177
178
179
180
181
182
183
184
185
186
# File 'lib/zavudev/resources/senders/agent/tools.rb', line 173

def test_(tool_id, params)
  parsed, options = Zavudev::Senders::Agent::ToolTestParams.dump_request(params)
  sender_id =
    parsed.delete(:sender_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :post,
    path: ["v1/senders/%1$s/agent/tools/%2$s/test", sender_id, tool_id],
    body: parsed,
    model: Zavudev::Models::Senders::Agent::ToolTestResponse,
    options: options
  )
end

#update(tool_id, sender_id:, description: nil, enabled: nil, name: nil, parameters: nil, webhook_secret: nil, webhook_url: nil, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolUpdateResponse

Update a tool.

Parameters:

  • tool_id (String)

    Path param

  • sender_id (String)

    Path param

  • description (String)

    Body param

  • enabled (Boolean)

    Body param

  • name (String)

    Body param

  • parameters (Zavudev::Models::Senders::Agent::ToolParameters)

    Body param

  • webhook_secret (String, nil)

    Body param

  • webhook_url (String)

    Body param

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

Returns:

See Also:



92
93
94
95
96
97
98
99
100
101
102
103
104
105
# File 'lib/zavudev/resources/senders/agent/tools.rb', line 92

def update(tool_id, params)
  parsed, options = Zavudev::Senders::Agent::ToolUpdateParams.dump_request(params)
  sender_id =
    parsed.delete(:sender_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :patch,
    path: ["v1/senders/%1$s/agent/tools/%2$s", sender_id, tool_id],
    body: parsed,
    model: Zavudev::Models::Senders::Agent::ToolUpdateResponse,
    options: options
  )
end