During setup of an existing user, create oid login permission, if it does not already...
[arvados.git] / services / api / app / controllers / arvados / v1 / nodes_controller.rb
1 class Arvados::V1::NodesController < ApplicationController
2   skip_before_filter :require_auth_scope_all, :only => :ping
3   skip_before_filter :find_object_by_uuid, :only => :ping
4   skip_before_filter :render_404_if_no_object, :only => :ping
5
6   def create
7     @object = Node.new
8     @object.save!
9     @object.start!(lambda { |h| arvados_v1_ping_node_url(h) })
10     show
11   end
12
13   def self._ping_requires_parameters
14     { ping_secret: true }
15   end
16   def ping
17     @object = Node.where(uuid: (params[:id] || params[:uuid])).first
18     if !@object
19       return render_not_found
20     end
21     @object.ping({ ip: params[:local_ipv4] || request.env['REMOTE_ADDR'],
22                    ping_secret: params[:ping_secret],
23                    ec2_instance_id: params[:instance_id] })
24     if @object.info[:ping_secret] == params[:ping_secret]
25       render json: @object.as_api_response(:superuser)
26     else
27       raise "Invalid ping_secret after ping"
28     end
29   end
30
31   def find_objects_for_index
32     if current_user.andand.is_admin || !current_user.andand.is_active
33       super
34     else
35       # active non-admin users can list nodes that are (or were
36       # recently) working
37       @objects = model_class.where('last_ping_at >= ?', Time.now - 1.hours)
38     end
39   end
40 end