This file is indexed.

/usr/lib/one/mads/one_hm.rb is in opennebula 3.4.1-4.1ubuntu1.

This file is owned by root:root, with mode 0o755.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#!/usr/bin/env ruby

# -------------------------------------------------------------------------- #
# Copyright 2002-2012, OpenNebula Project Leads (OpenNebula.org)             #
#                                                                            #
# Licensed under the Apache License, Version 2.0 (the "License"); you may    #
# not use this file except in compliance with the License. You may obtain    #
# a copy of the License at                                                   #
#                                                                            #
# http://www.apache.org/licenses/LICENSE-2.0                                 #
#                                                                            #
# Unless required by applicable law or agreed to in writing, software        #
# distributed under the License is distributed on an "AS IS" BASIS,          #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #
# See the License for the specific language governing permissions and        #
# limitations under the License.                                             #
#--------------------------------------------------------------------------- #

ONE_LOCATION=ENV["ONE_LOCATION"]

if !ONE_LOCATION
    RUBY_LIB_LOCATION="/usr/lib/one/ruby"
    ETC_LOCATION="/etc/one/"
else
    RUBY_LIB_LOCATION=ONE_LOCATION+"/lib/ruby"
    ETC_LOCATION=ONE_LOCATION+"/etc/"
end

$: << RUBY_LIB_LOCATION

require 'OpenNebulaDriver'

class HookManagerDriver < OpenNebulaDriver
    def initialize(options)
        @options={
            :concurrency => 15,
            :threaded => true,
            :retries => 0
        }.merge!(options)

        super('', @options)

        register_action(:EXECUTE, method("action_execute"))
    end

    def action_execute(number, hook_name, host, script, *arguments)
        cmd=nil
        cmd_string="#{script} #{arguments.join(' ')}"

        if host.upcase=="LOCAL"
            cmd=LocalCommand.run(cmd_string, log_method(number))
        else
            cmd=SSHCommand.run("'#{cmd_string}'", host, log_method(number))
        end

        if cmd.code==0
            message = "#{hook_name}: #{cmd.stdout}"
            send_message("EXECUTE", RESULT[:success], number, message)
        else
            message = "#{hook_name}: #{cmd.get_error_message}"
            send_message("EXECUTE", RESULT[:failure], number, message)
        end
    end
end

hm=HookManagerDriver.new(:concurrency => 15)
hm.start_driver