Class: Telnyx::Resources::AI::Missions::Runs

Inherits:
Object
  • Object
show all
Defined in:
lib/telnyx/resources/ai/missions/runs.rb,
lib/telnyx/resources/ai/missions/runs/plan.rb,
lib/telnyx/resources/ai/missions/runs/events.rb,
lib/telnyx/resources/ai/missions/runs/telnyx_agents.rb

Defined Under Namespace

Classes: Events, Plan, TelnyxAgents

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client:) ⇒ Runs

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

Parameters:



250
251
252
253
254
255
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 250

def initialize(client:)
  @client = client
  @events = Telnyx::Resources::AI::Missions::Runs::Events.new(client: client)
  @plan = Telnyx::Resources::AI::Missions::Runs::Plan.new(client: client)
  @telnyx_agents = Telnyx::Resources::AI::Missions::Runs::TelnyxAgents.new(client: client)
end

Instance Attribute Details

#eventsTelnyx::Resources::AI::Missions::Runs::Events (readonly)



9
10
11
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 9

def events
  @events
end

#planTelnyx::Resources::AI::Missions::Runs::Plan (readonly)



12
13
14
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 12

def plan
  @plan
end

#telnyx_agentsTelnyx::Resources::AI::Missions::Runs::TelnyxAgents (readonly)



15
16
17
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 15

def telnyx_agents
  @telnyx_agents
end

Instance Method Details

#cancel_run(run_id, mission_id:, request_options: {}) ⇒ Telnyx::Models::AI::Missions::RunCancelRunResponse

Cancel a running or paused run

Parameters:

  • run_id (String)

    Unique identifier of the run.

  • mission_id (String)

    Unique identifier of the mission.

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

Returns:

See Also:



151
152
153
154
155
156
157
158
159
160
161
162
163
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 151

def cancel_run(run_id, params)
  parsed, options = Telnyx::AI::Missions::RunCancelRunParams.dump_request(params)
  mission_id =
    parsed.delete(:mission_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :post,
    path: ["ai/missions/%1$s/runs/%2$s/cancel", mission_id, run_id],
    model: Telnyx::Models::AI::Missions::RunCancelRunResponse,
    options: options
  )
end

#create(mission_id, input: nil, metadata: nil, request_options: {}) ⇒ Telnyx::Models::AI::Missions::RunCreateResponse

Start a new run for a mission

Parameters:

  • mission_id (String)

    Unique identifier of the mission.

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

Returns:

See Also:



32
33
34
35
36
37
38
39
40
41
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 32

def create(mission_id, params = {})
  parsed, options = Telnyx::AI::Missions::RunCreateParams.dump_request(params)
  @client.request(
    method: :post,
    path: ["ai/missions/%1$s/runs", mission_id],
    body: parsed,
    model: Telnyx::Models::AI::Missions::RunCreateResponse,
    options: options
  )
end

#list(mission_id, page_number: nil, page_size: nil, status: nil, request_options: {}) ⇒ Telnyx::Internal::DefaultFlatPagination<Telnyx::Models::AI::Missions::MissionRunData>

List all runs for a specific mission

Parameters:

  • mission_id (String)

    Unique identifier of the mission.

  • page_number (Integer)

    Page number (1-based)

  • page_size (Integer)

    Number of items per page

  • status (String)

    Filter results by status.

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

Returns:

See Also:



125
126
127
128
129
130
131
132
133
134
135
136
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 125

def list(mission_id, params = {})
  parsed, options = Telnyx::AI::Missions::RunListParams.dump_request(params)
  query = Telnyx::Internal::Util.encode_query_params(parsed)
  @client.request(
    method: :get,
    path: ["ai/missions/%1$s/runs", mission_id],
    query: query.transform_keys(page_number: "page[number]", page_size: "page[size]"),
    page: Telnyx::Internal::DefaultFlatPagination,
    model: Telnyx::AI::Missions::MissionRunData,
    options: options
  )
end

#list_runs(page_number: nil, page_size: nil, status: nil, request_options: {}) ⇒ Telnyx::Internal::DefaultFlatPagination<Telnyx::Models::AI::Missions::MissionRunData>

List recent runs across all missions

Parameters:

  • page_number (Integer)

    Page number (1-based)

  • page_size (Integer)

    Number of items per page

  • status (String)

    Filter results by status.

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

Returns:

See Also:



180
181
182
183
184
185
186
187
188
189
190
191
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 180

def list_runs(params = {})
  parsed, options = Telnyx::AI::Missions::RunListRunsParams.dump_request(params)
  query = Telnyx::Internal::Util.encode_query_params(parsed)
  @client.request(
    method: :get,
    path: "ai/missions/runs",
    query: query.transform_keys(page_number: "page[number]", page_size: "page[size]"),
    page: Telnyx::Internal::DefaultFlatPagination,
    model: Telnyx::AI::Missions::MissionRunData,
    options: options
  )
end

#pause_run(run_id, mission_id:, request_options: {}) ⇒ Telnyx::Models::AI::Missions::RunPauseRunResponse

Pause a running run

Parameters:

  • run_id (String)

    Unique identifier of the run.

  • mission_id (String)

    Unique identifier of the mission.

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

Returns:

See Also:



206
207
208
209
210
211
212
213
214
215
216
217
218
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 206

def pause_run(run_id, params)
  parsed, options = Telnyx::AI::Missions::RunPauseRunParams.dump_request(params)
  mission_id =
    parsed.delete(:mission_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :post,
    path: ["ai/missions/%1$s/runs/%2$s/pause", mission_id, run_id],
    model: Telnyx::Models::AI::Missions::RunPauseRunResponse,
    options: options
  )
end

#resume_run(run_id, mission_id:, request_options: {}) ⇒ Telnyx::Models::AI::Missions::RunResumeRunResponse

Resume a paused run

Parameters:

  • run_id (String)

    Unique identifier of the run.

  • mission_id (String)

    Unique identifier of the mission.

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

Returns:

See Also:



233
234
235
236
237
238
239
240
241
242
243
244
245
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 233

def resume_run(run_id, params)
  parsed, options = Telnyx::AI::Missions::RunResumeRunParams.dump_request(params)
  mission_id =
    parsed.delete(:mission_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :post,
    path: ["ai/missions/%1$s/runs/%2$s/resume", mission_id, run_id],
    model: Telnyx::Models::AI::Missions::RunResumeRunResponse,
    options: options
  )
end

#retrieve(run_id, mission_id:, request_options: {}) ⇒ Telnyx::Models::AI::Missions::RunRetrieveResponse

Get details of a specific run

Parameters:

  • run_id (String)

    Unique identifier of the run.

  • mission_id (String)

    Unique identifier of the mission.

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

Returns:

See Also:



56
57
58
59
60
61
62
63
64
65
66
67
68
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 56

def retrieve(run_id, params)
  parsed, options = Telnyx::AI::Missions::RunRetrieveParams.dump_request(params)
  mission_id =
    parsed.delete(:mission_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :get,
    path: ["ai/missions/%1$s/runs/%2$s", mission_id, run_id],
    model: Telnyx::Models::AI::Missions::RunRetrieveResponse,
    options: options
  )
end

#update(run_id, mission_id:, error: nil, metadata: nil, result_payload: nil, result_summary: nil, status: nil, request_options: {}) ⇒ Telnyx::Models::AI::Missions::RunUpdateResponse

Update run status and/or result

Parameters:

  • run_id (String)

    Path param: Unique identifier of the run.

  • mission_id (String)

    Path param: Unique identifier of the mission.

  • error (String)

    Body param

  • metadata (Hash{Symbol=>Object})

    Body param

  • result_payload (Hash{Symbol=>Object})

    Body param

  • result_summary (String)

    Body param

  • status (Symbol, Telnyx::Models::AI::Missions::RunUpdateParams::Status)

    Body param

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

Returns:

See Also:



93
94
95
96
97
98
99
100
101
102
103
104
105
106
# File 'lib/telnyx/resources/ai/missions/runs.rb', line 93

def update(run_id, params)
  parsed, options = Telnyx::AI::Missions::RunUpdateParams.dump_request(params)
  mission_id =
    parsed.delete(:mission_id) do
      raise ArgumentError.new("missing required path argument #{_1}")
    end
  @client.request(
    method: :patch,
    path: ["ai/missions/%1$s/runs/%2$s", mission_id, run_id],
    body: parsed,
    model: Telnyx::Models::AI::Missions::RunUpdateResponse,
    options: options
  )
end