Class: AdminModule::Rake::DcTasks

Inherits:
Object
  • Object
show all
Includes:
Rake::DSL
Defined in:
lib/admin_module/rake/dc_tasks.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(task_name = 'dcs_task', desc = "Modify DC definition(s)") {|_self| ... } ⇒ DcTasks

Returns a new instance of DcTasks.

Yields:

  • (_self)

Yield Parameters:



25
26
27
28
29
30
31
32
33
34
# File 'lib/admin_module/rake/dc_tasks.rb', line 25

def initialize(task_name = 'dcs_task', desc = "Modify DC definition(s)")
  @valid_actions = ['import', 'export', 'read', 'list', 'rename']
  @task_name, @desc = task_name, desc

  @stop_on_exception = true

  yield self if block_given?

  define_task
end

Instance Attribute Details

#actionObject

Returns the value of attribute action.



21
22
23
# File 'lib/admin_module/rake/dc_tasks.rb', line 21

def action
  @action
end

#envObject

Returns the value of attribute env.



17
18
19
# File 'lib/admin_module/rake/dc_tasks.rb', line 17

def env
  @env
end

#nameObject

Returns the value of attribute name.



18
19
20
# File 'lib/admin_module/rake/dc_tasks.rb', line 18

def name
  @name
end

#pathObject

Returns the value of attribute path.



20
21
22
# File 'lib/admin_module/rake/dc_tasks.rb', line 20

def path
  @path
end

#stop_on_exceptionObject

Returns the value of attribute stop_on_exception.



23
24
25
# File 'lib/admin_module/rake/dc_tasks.rb', line 23

def stop_on_exception
  @stop_on_exception
end

#toObject

Returns the value of attribute to.



19
20
21
# File 'lib/admin_module/rake/dc_tasks.rb', line 19

def to
  @to
end

#valid_actionsObject (readonly)

Returns the value of attribute valid_actions.



22
23
24
# File 'lib/admin_module/rake/dc_tasks.rb', line 22

def valid_actions
  @valid_actions
end

Class Method Details

.installObject



166
167
168
# File 'lib/admin_module/rake/dc_tasks.rb', line 166

def install
  new.install
end

Instance Method Details

#assert_env_is_configured(arg) ⇒ Object



133
134
135
136
137
138
139
# File 'lib/admin_module/rake/dc_tasks.rb', line 133

def assert_env_is_configured arg
  unless AdminModule.configuration.credentials.key? arg
    init_msg = "Have you initialized your config file?\n Try: admin_module config init <filedir>"
    env_msg = "Have you configured your environments?\n Try: admin_module config add env <envname> <url>"
    raise "Unknown environment: #{arg}\n#{init_msg}\n\n#{env_msg}"
  end
end

#assert_provided(value, msg) ⇒ Object



127
128
129
130
131
# File 'lib/admin_module/rake/dc_tasks.rb', line 127

def assert_provided value, msg
  if value.nil? || value.empty?
    raise msg
  end
end

#commitObject



62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# File 'lib/admin_module/rake/dc_tasks.rb', line 62

def commit
  validate_params

  client = AdminModule::Client.new
  client.env = env

  if self.respond_to? action
    self.send(action, client)
    return
  else
    raise "Unknown action - #{action}"
  end

rescue Exception => e
  raise e if stop_on_exception == true
ensure
  client.quit
end

#define_taskObject

:nodoc:



36
37
38
39
40
41
42
# File 'lib/admin_module/rake/dc_tasks.rb', line 36

def define_task #:nodoc:
  desc @desc
  task(@task_name, required_args_for_action) do |t,args|
    set_vars args
    commit  # Call method to perform when invoked.
  end
end

#export(client) ⇒ Object



96
97
98
# File 'lib/admin_module/rake/dc_tasks.rb', line 96

def export client
  $stdout << client.dcs.export(path)
end

#import(client) ⇒ Object



92
93
94
# File 'lib/admin_module/rake/dc_tasks.rb', line 92

def import client
  $stdout << client.dcs.import(path)
end

#installObject



171
172
173
174
175
176
177
178
179
180
# File 'lib/admin_module/rake/dc_tasks.rb', line 171

def install
  AdminModule.configuration.credentials.keys.each do |e|
    valid_actions.each do |action|
      AdminModule::Rake::DcTasks.new("am:#{e}:dc:#{action}", "#{action} #{e} DC defn(s)") do |t|
        t.env = e
        t.action = action
      end
    end
  end
end

#list(client) ⇒ Object



81
82
83
84
# File 'lib/admin_module/rake/dc_tasks.rb', line 81

def list client
  $stdout << client.dcs.list.join("\n")
  $stdout << "\n"
end

#read(client) ⇒ Object



86
87
88
89
90
# File 'lib/admin_module/rake/dc_tasks.rb', line 86

def read client
  result = {}
  result[name] = client.dcs.read(name)
  $stdout << result.to_yaml
end

#rename(client) ⇒ Object



100
101
102
# File 'lib/admin_module/rake/dc_tasks.rb', line 100

def rename client
  $stdout << client.dcs.rename(name, to)
end

#required_args_for_actionObject



141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
# File 'lib/admin_module/rake/dc_tasks.rb', line 141

def required_args_for_action
  args = []

  case action
  when 'read'
    args << :name

  when 'rename'
    args << :name
    args << :to

  when 'import'
    args << :path

  when 'export'
    args << :path

  else
    # Noop
  end

  args
end

#set_vars(args) ⇒ Object



44
45
46
47
48
49
50
# File 'lib/admin_module/rake/dc_tasks.rb', line 44

def set_vars args
  args.each do |arg,val|
    instance_variable_set "@#{arg}", val
  end

  args
end

#validate_paramsObject



104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# File 'lib/admin_module/rake/dc_tasks.rb', line 104

def validate_params
  assert_provided env, 'Missing "env"'
  assert_provided action, 'Missing "action"'

  case action
  when 'import'
    assert_provided path, 'Missing "path"'

  when 'export'
    assert_provided path, 'Missing "path"'

  when 'read'
    assert_provided name, 'Missing "name"'

  when 'rename'
    assert_provided name, 'Missing "name"'
    assert_provided to, 'Missing "to"'

  end

  assert_env_is_configured env
end