1 # Copyright (C) The Arvados Authors. All rights reserved.
3 # SPDX-License-Identifier: AGPL-3.0
5 class Arvados::V1::ContainersController < ApplicationController
6 accept_attribute_as_json :environment, Hash
7 accept_attribute_as_json :mounts, Hash
8 accept_attribute_as_json :runtime_constraints, Hash
9 accept_attribute_as_json :runtime_status, Hash
10 accept_attribute_as_json :command, Array
11 accept_attribute_as_json :scheduling_parameters, Hash
13 skip_before_filter :find_object_by_uuid, only: [:current]
14 skip_before_filter :render_404_if_no_object, only: [:current]
17 if @object.locked_by_uuid != Thread.current[:api_client_authorization].uuid
18 raise ArvadosModel::PermissionDeniedError.new("Not locked by your token")
20 @object = @object.auth
31 def find_objects_for_index
33 if action_name == 'lock' || action_name == 'unlock'
34 # Avoid loading more fields than we need
35 @objects = @objects.select(:id, :uuid, :state, :priority, :auth_uuid, :locked_by_uuid)
36 @select = %w(uuid state priority auth_uuid locked_by_uuid)
51 if Thread.current[:api_client_authorization].nil?
52 send_error("Not logged in", status: 401)
54 c = Container.where(auth_uuid: Thread.current[:api_client_authorization].uuid).first
56 send_error("Token is not associated with a container.", status: 404)
67 @object.auth_uuid == Thread.current[:api_client_authorization].uuid
68 send_json({"secret_mounts" => @object.secret_mounts})
70 send_error("Token is not associated with this container.", status: 403)