Class: Zavudev::Resources::Senders::Agent::Tools
- Inherits:
-
Object
- Object
- Zavudev::Resources::Senders::Agent::Tools
- Defined in:
- lib/zavudev/resources/senders/agent/tools.rb
Instance Method Summary collapse
-
#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.
-
#delete(tool_id, sender_id:, request_options: {}) ⇒ nil
Delete a tool.
-
#initialize(client:) ⇒ Tools
constructor
private
A new instance of Tools.
-
#list(sender_id, cursor: nil, enabled: nil, limit: nil, request_options: {}) ⇒ Zavudev::Internal::Cursor<Zavudev::Models::Senders::Agent::AgentTool>
List tools for an agent.
-
#retrieve(tool_id, sender_id:, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolRetrieveResponse
Get a specific tool.
-
#test_(tool_id, sender_id:, test_params:, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolTestResponse
Test a tool by triggering its webhook with test parameters.
-
#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.
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.
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.
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, = 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: ) end |
#delete(tool_id, sender_id:, request_options: {}) ⇒ nil
Delete a tool.
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, = 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: ) 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.
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, = 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: ) end |
#retrieve(tool_id, sender_id:, request_options: {}) ⇒ Zavudev::Models::Senders::Agent::ToolRetrieveResponse
Get a specific tool.
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, = 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: ) 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.
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, = 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: ) 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.
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, = 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: ) end |