forj 0.0.48 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,42 @@
1
+ # encoding: UTF-8
2
+
3
+ # (c) Copyright 2014 Hewlett-Packard Development Company, L.P.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # This file is given as an example.
18
+
19
+ class Mycloud # This class is automatically derived from ForjCloudBase and ForjProcess
20
+
21
+ def provider_compute_new
22
+ # My fog connection
23
+ # hget_cloudObjMapping() is a ForjCloudBase function which will build a
24
+ # hash from data required with needed mapped keys(see core.rb)
25
+ Fog::Compute.new({:provider => :mycloud}.merge(hget_cloudObjMapping()))
26
+
27
+ # If you do not want to get data mapped automatically, you can use
28
+ # @oForjAccount.get()
29
+ # This means in following declaration in your core.rb:
30
+ # obj_needs(:data, :<CloudDataKey},{:mapping => :<MyCloudKeyMapped>})
31
+ # can be updated by removing the mapping => <Value>
32
+ Fog::Compute.new({
33
+ :provider => :mycloud,
34
+ :user => @oForjAccount.get(:account_id),
35
+ :pwd => @oForjAccount.get(:account_key),
36
+ :auth_uri => @oForjAccount.get(:auth_uri),
37
+ :project => @oForjAccount.get(:tenant),
38
+ :compute_service => @oForjAccount.get(:compute),
39
+ })
40
+
41
+ end
42
+ end
@@ -0,0 +1,61 @@
1
+ # encoding: UTF-8
2
+
3
+ # (c) Copyright 2014 Hewlett-Packard Development Company, L.P.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+
18
+ # This file is given as an example.
19
+
20
+ require File.join($PROVIDER_PATH, "compute.rb")
21
+ require File.join($PROVIDER_PATH, "network.rb")
22
+
23
+ # Defines Meta MyCloud object
24
+ class Mycloud
25
+
26
+ # Defines Object structure and function stored on the Hpcloud class object.
27
+
28
+ # ForjCloud has a list of predefined object, like compute_connection, network, ...
29
+ # See lib/providers/core/cloud_data_pref.rb
30
+
31
+ # Compute Object
32
+ define_obj :compute_connection
33
+ # Defines Data used by compute.
34
+ obj_needs(:data, :account_id, { :mapping => :user})
35
+ obj_needs(:data, :account_key, { :mapping => :pwd})
36
+ obj_needs(:data, :auth_uri, { :mapping => :auth_uri})
37
+ obj_needs(:data, :tenant, { :mapping => :project})
38
+ obj_needs(:data, :compute, { :mapping => :compute_service})
39
+
40
+ define_obj :network_connection
41
+ obj_needs(:data, :account_id, { :mapping => :user})
42
+ obj_needs(:data, :account_key, { :mapping => :pwd})
43
+ obj_needs(:data, :auth_uri, { :mapping => :auth_uri})
44
+ obj_needs(:data, :tenant, { :mapping => :project})
45
+ obj_needs(:data, :network, { :mapping => :network_service})
46
+
47
+ define_obj :network
48
+ obj_needs(:CloudObject, :network_connection)
49
+ obj_needs(:data, :network_name)
50
+
51
+ # defines setup Cloud data
52
+ # This definition is required only if you need to change the predefined data.
53
+ # To get details on what kind of parameters can be applied to a CloudData, see lib/defaults.yaml
54
+ define_data(:account_id, {:provisioned_by => :setup, :desc => 'MyCloud username'})
55
+ define_data(:account_key, {:provisioned_by => :setup, :desc => 'HPCloud secret Key'})
56
+ define_data(:auth_uri, {:provisioned_by => :setup, :desc => 'HPCloud Authentication service URL'})
57
+ define_data(:tenant, {:provisioned_by => :setup, :desc => 'HPCloud Tenant ID'})
58
+ define_data(:compute, {:provisioned_by => :setup, :desc => 'HPCloud Compute service zone (Ex: region-a.geo-1)'})
59
+ define_data(:network, {:provisioned_by => :setup, :desc => 'HPCloud Network service zone (Ex: region-a.geo-1)'})
60
+
61
+ end
@@ -1,4 +1,3 @@
1
- #!/usr/bin/env ruby
2
1
  # encoding: UTF-8
3
2
 
4
3
  # (c) Copyright 2014 Hewlett-Packard Development Company, L.P.
@@ -15,31 +14,20 @@
15
14
  # See the License for the specific language governing permissions and
16
15
  # limitations under the License.
17
16
 
18
- require 'rubygems'
19
- require 'yaml'
20
- #require_relative 'log.rb'
21
- #include Logging
17
+ # This file is given as an example.
22
18
 
23
- #
24
- # YamlParse module
25
- #
26
- module YamlParse
27
- def get_values(path_to_yaml)
28
- begin
29
- Logging.info('getting values from defaults.yaml, this will be a service catalog.forj.io')
30
- YAML.load_file(path_to_yaml)
31
- rescue => e
32
- Logging.error("%s\n%s" % [e.message, e.backtrace.join("\n")])
33
- end
34
- end
19
+ class Mycloud # This class is automatically derived from ForjCloudBase and ForjProcess
20
+
21
+ def provider_network_new
22
+ Fog::Network.new({:provider => :mycloud}.merge(hget_cloudObjMapping()))
23
+ end
24
+
25
+ def provider_query_network(oNetwork, name)
26
+ oNetwork.networks.all(:name => name)
27
+ end
28
+
29
+ def provider_create_network(oNetwork, name)
30
+ oNetwork.networks.create(:name => name)
31
+ end
35
32
 
36
- def dump_values(string, path)
37
- begin
38
- File.open(path, 'w') do |out|
39
- YAML.dump(string, out)
40
- end
41
- rescue => e
42
- Logging.error("%s\n%s" % [e.message, e.backtrace.join("\n")])
43
- end
44
- end
45
33
  end
data/lib/log.rb CHANGED
@@ -21,6 +21,7 @@
21
21
  require 'rubygems'
22
22
  require 'logger'
23
23
  require 'ansi'
24
+ require 'ansi/logger'
24
25
 
25
26
  require 'require_relative'
26
27
 
@@ -58,7 +59,17 @@ module Logging
58
59
  @level = level
59
60
  @oOutLogger.level = @level
60
61
  @oOutLogger.formatter = proc do |severity, datetime, progname, msg|
61
- severity == 'ANY'?"#{msg} \n":"#{severity}: #{msg} \n"
62
+ case severity
63
+ when 'ANY'
64
+ str = "#{msg} \n"
65
+ when "ERROR", "FATAL"
66
+ str = ANSI.bold(ANSI.red("#{severity}!!!")) + ": #{msg} \n"
67
+ when "WARN"
68
+ str = ANSI.bold(ANSI.yellow("WARNING")) + ": #{msg} \n"
69
+ else
70
+ str = "#{severity}: #{msg} \n"
71
+ end
72
+ str
62
73
  end
63
74
  end
64
75
 
data/lib/repositories.rb CHANGED
@@ -18,12 +18,6 @@
18
18
  require 'rubygems'
19
19
  require 'git'
20
20
  require 'fileutils'
21
- require 'require_relative'
22
-
23
- require_relative 'yaml_parse.rb'
24
- include YamlParse
25
- #require_relative 'log.rb'
26
- #include Logging
27
21
 
28
22
  #
29
23
  # Repositories module
data/lib/ssh.rb CHANGED
@@ -23,25 +23,28 @@ include SecurityGroup
23
23
  # ssh module
24
24
  #
25
25
  module Ssh
26
- def connect(name, server, oConfig)
27
- msg = 'logging into %s : %s' % [name, server]
28
- Logging.info(msg)
26
+ def connect(name, server, oConfig)
27
+ # Following line to remove as soon as ssh function is implemented with forj-lib framework
28
+ Logging.warning("This function may not work appropriately. Currenty under development. Thank you for your understanding.")
29
29
 
30
- oForjAccount = ForjAccount.new(oConfig)
30
+ msg = 'logging into %s : %s' % [name, server]
31
+ Logging.info(msg)
31
32
 
32
- oForjAccount.ac_load()
33
+ oForjAccount = ForjAccount.new(oConfig)
33
34
 
34
- oKey = SecurityGroup.keypair_detect(oForjAccount.get(:keypair_name), oForjAccount.get(:keypair_path))
35
+ oForjAccount.ac_load()
35
36
 
36
- update = '%s/ssh.sh -u %s' % [ $LIB_PATH, oConfig.get(:account_name)]
37
- connection = '%s/ssh.sh %s %s %s' % [$LIB_PATH, name, server, File.join(oKey[:keypair_path],oKey[:private_key_name]) ]
37
+ oKey = SecurityGroup.keypair_detect(oForjAccount.get(:keypair_name), oForjAccount.get(:keypair_path))
38
38
 
39
- # update the list of servers
40
- Logging.debug("Executing '%s'" % update)
41
- Kernel.system(update)
39
+ update = '%s/ssh.sh -u %s' % [ $LIB_PATH, oConfig.get(:account_name)]
40
+ connection = '%s/ssh.sh %s %s %s' % [$LIB_PATH, name, server, File.join(oKey[:keypair_path],oKey[:private_key_name]) ]
42
41
 
43
- # connect to the server
44
- Logging.debug("Executing '%s'" % connection)
45
- Kernel.system(connection)
46
- end
42
+ # update the list of servers
43
+ Logging.debug("Executing '%s'" % update)
44
+ Kernel.system(update)
45
+
46
+ # connect to the server
47
+ Logging.debug("Executing '%s'" % connection)
48
+ Kernel.system(connection)
49
+ end
47
50
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: forj
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.48
4
+ version: 1.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - forj team
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-10-20 00:00:00.000000000 Z
11
+ date: 2014-10-27 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: thor
@@ -136,6 +136,20 @@ dependencies:
136
136
  - - '='
137
137
  - !ruby/object:Gem::Version
138
138
  version: 1.3.0
139
+ - !ruby/object:Gem::Dependency
140
+ name: json
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - '='
144
+ - !ruby/object:Gem::Version
145
+ version: 1.7.5
146
+ type: :runtime
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - '='
151
+ - !ruby/object:Gem::Version
152
+ version: 1.7.5
139
153
  description: forj cli - See https://www.forj.io for documentation/information
140
154
  email:
141
155
  - forj@forj.io
@@ -149,13 +163,10 @@ files:
149
163
  - lib/connection.rb
150
164
  - lib/network.rb
151
165
  - lib/security.rb
152
- - lib/yaml_parse.rb
153
166
  - lib/defaults.yaml
154
167
  - lib/down.rb
155
- - lib/boot.rb
156
168
  - lib/appinit.rb
157
169
  - lib/forj-settings.rb
158
- - lib/setup.rb
159
170
  - lib/repositories.rb
160
171
  - lib/ssh.rb
161
172
  - lib/ssh.sh
@@ -163,6 +174,25 @@ files:
163
174
  - lib/helpers.rb
164
175
  - lib/forj-config.rb
165
176
  - lib/forj-account.rb
177
+ - lib/build_tmpl/bootstrap_build.sh
178
+ - lib/build_tmpl/write-mime-multipart.py
179
+ - lib/forj/ForjCore.rb
180
+ - lib/forj/ForjCli.rb
181
+ - lib/forj/process/ForjProcess.rb
182
+ - lib/lib-forj/lib/providers/templates/compute.rb
183
+ - lib/lib-forj/lib/providers/templates/network.rb
184
+ - lib/lib-forj/lib/providers/templates/core.rb
185
+ - lib/lib-forj/lib/providers/hpcloud/security_groups.rb
186
+ - lib/lib-forj/lib/providers/hpcloud/Hpcloud.rb
187
+ - lib/lib-forj/lib/providers/hpcloud/compute.rb
188
+ - lib/lib-forj/lib/providers/hpcloud/network.rb
189
+ - lib/lib-forj/lib/core_process/global_process.rb
190
+ - lib/lib-forj/lib/core_process/CloudProcess.rb
191
+ - lib/lib-forj/lib/core_process/network_process.rb
192
+ - lib/lib-forj/lib/core/definition.rb
193
+ - lib/lib-forj/lib/core/core.rb
194
+ - lib/lib-forj/lib/core/definition_internal.rb
195
+ - lib/lib-forj/lib/lib-forj.rb
166
196
  - spec/boot_spec.rb
167
197
  - spec/connection_spec.rb
168
198
  - spec/down_spec.rb
@@ -171,7 +201,6 @@ files:
171
201
  - spec/setup_spec.rb
172
202
  - spec/spec_helper.rb
173
203
  - spec/ssh_spec.rb
174
- - spec/yaml_parse_spec.rb
175
204
  - spec/forj-config_spec.rb
176
205
  - Rakefile
177
206
  - Gemfile
data/lib/boot.rb DELETED
@@ -1,263 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- # (c) Copyright 2014 Hewlett-Packard Development Company, L.P.
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
-
18
-
19
- require_relative 'network.rb'
20
- include Network
21
- require_relative 'yaml_parse.rb'
22
- include YamlParse
23
- require_relative 'security.rb'
24
- include SecurityGroup
25
- require_relative 'repositories.rb'
26
- include Repositories
27
- #require_relative 'log.rb'
28
- #include Logging
29
- require_relative 'helpers.rb'
30
- include Helpers
31
-
32
-
33
- #
34
- # Boot module
35
- #
36
- module Boot
37
- def boot(blueprint, name, build, boothook, box_name, oConfig)
38
- begin
39
-
40
- Logging.fatal(1, 'FORJ account not specified. Did you used `forj setup`, before?') if not oConfig.get(:account_name)
41
-
42
- # Check options and set data
43
- cloud_provider = oConfig.get(:provider_name, 'hpcloud')
44
-
45
- if cloud_provider != 'hpcloud'
46
- Logging.fatal(1, "forj setup support only hpcloud. '%s' is currently not supported." % cloud_provider)
47
- end
48
-
49
- initial_msg = "booting %s on %s\nCheck log with `tail -f ~/.forj/forj.log`.\nUse --verbose or --debug for more boot status on screen" % [blueprint , cloud_provider]
50
- Logging.high_level_msg(initial_msg) #################
51
-
52
- # Initialize defaults
53
- maestro_url = oConfig.get(:maestro_url)
54
-
55
- infra_dir = File.expand_path(oConfig.get(:infra_repo))
56
-
57
- # Ask information if needed.
58
- if not Dir.exist?(File.expand_path(infra_dir))
59
- Logging.warning(<<-END
60
- Your infra workspace directory is missing.
61
-
62
- Forj uses an infra workspace directory to store any kind of data that are private to you.
63
- We provides ways to send those data securily to your new Forge instance, as metadata.
64
- In production case, we suggest you to keep it safe in your SCM preferred database.
65
-
66
- If you already have an existing infra workspace, use 'forj set infra_repo=<PathToYourRepo>' to set it and restart.
67
-
68
- Otherwise, we will build a new one with some predefined data, you can review and update later.
69
- END
70
- )
71
- sAsk = "Do you want to create a new one from Maestro (yes/no)?" % [infra_dir]
72
- bBuildInfra=agree(sAsk)
73
- if not bBuildInfra
74
- puts 'Process aborted on your demand.'
75
- exit 0
76
- end
77
- else
78
- # Check about infra repo compatibility with forj cli
79
- bBuildInfra = Repositories.infra_rebuild_required?(oConfig, infra_dir)
80
- end
81
-
82
- # Get FORJ DNS setting
83
- yDNS = rhGet(oConfig.hAccountData, :dns)
84
- Logging.fatal(1, "DNS or domain name are missing. Please execute forj setup %s" % oConfig.getAccountData(:account, 'name')) if not yDNS
85
-
86
- branch = oConfig.get(:branch, 'master')
87
-
88
- # Step Maestro Clone
89
- if not oConfig.get(:maestro_repo)
90
- Logging.state("cloning maestro repo from '%s' - branch '%s'" % [maestro_url, branch])
91
- Repositories.clone_repo(maestro_url, oConfig)
92
- maestro_repo=File.expand_path('~/.forj/maestro')
93
- else
94
- maestro_repo=File.expand_path(oConfig.get(:maestro_repo))
95
- if not File.exists?('%s/templates/infra/maestro.box.master.env' % [maestro_repo])
96
- msg = <<-END
97
- '#{maestro_repo}' is not a recognized Maestro repository or is too old. forj cli searched for templates/infra/maestro.box.master.env
98
-
99
- Suggestion:
100
- 1. Clone #{maestro_url} to a different location.
101
- $ mkdir -p ~/src/forj-oss
102
- $ cd ~/src/forj-oss
103
- $ git clone #{maestro_url}
104
- 2. Use this master branch of maestro repository with forj
105
- $ forj set maestro_repo=~/src/forj-oss/maestro
106
-
107
- then retry your boot.
108
- END
109
- Logging.fatal(1, msg)
110
- end
111
- Logging.info("Using your maestro cloned repo '%s'" % maestro_repo)
112
- end
113
-
114
- bBuildInfra = Repositories.infra_rebuild(oConfig, infra_dir) unless bBuildInfra
115
-
116
- if bBuildInfra
117
- Logging.info("Building your infra... in '%s'" % [infra_dir])
118
- Repositories.create_infra(maestro_repo, branch)
119
- else
120
- Logging.info("Re-using your infra... in '%s'" % [infra_dir]) if not bBuildInfra
121
- end
122
-
123
- Repositories.ensure_build_env_file(maestro_url, maestro_repo, branch)
124
-
125
- # Connect to services
126
- oFC=ForjConnection.new(oConfig)
127
-
128
- Logging.info('Configuring network \'%s\'' % [oConfig.get('network_name')])
129
- begin
130
- network = Network.get_or_create_network(oFC, oConfig.get('network_name'))
131
- subnet = Network.get_or_create_subnet(oFC, network.id, network.name)
132
- Network.get_or_create_router(oFC, network, subnet)
133
- rescue => e
134
- Logging.fatal(1, "Network properly configured is required.", e)
135
- end
136
-
137
- Logging.info('Configuring keypair \'%s\'' % [oConfig.get('keypair_name')])
138
- SecurityGroup.hpc_import_key(oConfig)
139
-
140
-
141
- Logging.info('Configuring Security Group \'%s\'' % [oConfig.get('security_group')])
142
- security_group = SecurityGroup.get_or_create_security_group(oFC, oConfig.get('security_group'))
143
- ports = oConfig.get(:ports)
144
-
145
- ports.each do |port|
146
- port = port.to_s if port.class != String
147
- if not (/^\d+(-\d+)?$/ =~ port)
148
- Logging.error("Port '%s' is not valid. Must be <Port> or <PortMin>-<PortMax>" % [port])
149
- else
150
- mPortFound = /^(\d+)(-(\d+))?$/.match(port)
151
- portmin = mPortFound[1]
152
- portmax = (mPortFound[3]) ? (mPortFound[3]) : (portmin)
153
- Network.get_or_create_rule(oFC, security_group.id, 'tcp', portmin, portmax)
154
- end
155
- end
156
-
157
-
158
-
159
- oBuildEnv = BuildEnv.new(oConfig)
160
- ENV['FORJ_CLI_ENV'] = oBuildEnv.sBuildEnvFile
161
- oBuildEnv.set('FORJ_HPC', oFC.sAccountName)
162
- oBuildEnv.set('FORJ_HPC_NET', network.name)
163
- oBuildEnv.set('FORJ_SECURITY_GROUP', oConfig.get('security_group'))
164
- oBuildEnv.set('FORJ_KEYPAIR', oConfig.get('keypair_name'))
165
- oBuildEnv.set('FORJ_HPC_NOVA_KEYPUB', oConfig.get('keypair_path') + '.pub')
166
- oBuildEnv.set('FORJ_BASE_IMG', oConfig.get('image_name'))
167
- oBuildEnv.set('FORJ_FLAVOR', oConfig.get('flavor_name'))
168
- oBuildEnv.set('FORJ_BP_FLAVOR', oConfig.get('bp_flavor'))
169
- oBuildEnv.set('FORJ_TENANT_NAME', oConfig.get(:tenant_name))
170
- oBuildEnv.set('FORJ_HPC_COMPUTE', rhGet(oConfig.oConfig.ExtraGet(:hpc_accounts, oFC.sAccountName, :regions), :compute))
171
-
172
-
173
- oBuildEnv.set('FORJ_DOMAIN', yDNS[:domain_name])
174
-
175
- if yDNS[:tenant_id]
176
- oBuildEnv.set('FORJ_DNS_TENANTID', yDNS[:tenant_id])
177
- oBuildEnv.set('FORJ_DNS_ZONE', yDNS[:service])
178
- end
179
- oBuildEnv.save()
180
-
181
- # run build.sh to boot maestro
182
- puts
183
-
184
- build = 'bin/build.sh' unless build
185
-
186
- build_config = oConfig.get('build_config')
187
- box_name = oConfig.get('box_name')
188
-
189
- arg = '--meta blueprint=%s ' % [blueprint]
190
- arg += "--test-box '%s' " % oConfig.get(:test_box) if oConfig.exist?(:test_box)
191
-
192
- command = '%s --build_ID %s --box-name %s --build-conf-dir %s --build-config %s --gitBranch %s --debug-box %s' % [build, name, box_name, infra_dir, build_config, branch, arg]
193
-
194
- maestro_build_path = File.join(maestro_repo, 'build')
195
-
196
- current_dir = Dir.pwd
197
- Dir.chdir(maestro_build_path)
198
-
199
- Logging.info("Calling '%s' from '%s'" % [build, Dir.pwd])
200
- Logging.debug("%s=%s %s" % ['FORJ_CLI_ENV', ENV['FORJ_CLI_ENV'], command])
201
- Kernel.system(ENV, command)
202
- Dir.chdir(current_dir)
203
-
204
- # if test
205
- # Logging.debug 'test flag is on, deleting objects'
206
- # Network.delete_router_interface(subnet.id, router)
207
- # Network.delete_subnet(subnet.id)
208
- # Network.delete_network(network.name)
209
- # end
210
-
211
- rescue Interrupt
212
- Logging.message("\n'%s' boot from '%s' interrupted by user" % [name, blueprint])
213
- rescue => e
214
- Logging.error("%s\n%s" % [e.message, e.backtrace.join("\n")])
215
- end
216
- end
217
-
218
- end
219
-
220
-
221
- class BuildEnv
222
-
223
- attr_reader :sBuildEnvFile
224
-
225
- def initialize(oConfig)
226
-
227
- oConfig.oConfig.fatal_if_inexistent(:infra_repo)
228
- oConfig.oConfig.fatal_if_inexistent(:account_name)
229
-
230
- sBuildDir = File.expand_path(File.join(oConfig.get(:infra_repo),'build'))
231
- @sBuildEnvFile = File.join(sBuildDir, oConfig.get(:account_name)+'.build.env')
232
- AppInit.ensure_dir_exists(sBuildDir)
233
- @yBuildEnvVar = {}
234
- @oConfig = oConfig
235
- end
236
-
237
- def set(key, value)
238
- # This file creates the in-memory data required to configure specific project build_env.
239
- # Name : ~/.forj/account/<Account>.build.env
240
- if value
241
- Logging.debug("Setting '%s' = '%s'" % [key, value])
242
- @yBuildEnvVar[key] = value
243
- else
244
- Logging.debug("'%s' is not set" % [key])
245
- end
246
- end
247
-
248
- def save()
249
- begin
250
- File.open(@sBuildEnvFile, 'w') do |out|
251
- @yBuildEnvVar.each do | key, value |
252
- desc = @oConfig.oConfig.getAppDefault(:description, key)
253
- out.write("# %s - %s\n" % [key, desc]) if desc
254
- value = "" if not value
255
- out.write("%s='%s'\n\n" % [key, value])
256
- end
257
- end
258
- Logging.debug("'%s' written." % [@sBuildEnvFile])
259
- rescue => e
260
- Logging.error("%s\n%s" % [e.message, e.backtrace.join("\n")])
261
- end
262
- end
263
- end
data/lib/setup.rb DELETED
@@ -1,45 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- # (c) Copyright 2014 Hewlett-Packard Development Company, L.P.
5
- #
6
- # Licensed under the Apache License, Version 2.0 (the "License");
7
- # you may not use this file except in compliance with the License.
8
- # You may obtain a copy of the License at
9
- #
10
- # http://www.apache.org/licenses/LICENSE-2.0
11
- #
12
- # Unless required by applicable law or agreed to in writing, software
13
- # distributed under the License is distributed on an "AS IS" BASIS,
14
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- # See the License for the specific language governing permissions and
16
- # limitations under the License.
17
-
18
- require 'rubygems'
19
-
20
-
21
- #
22
- # Setup module call the hpcloud functions
23
- #
24
- module Setup
25
- def setup(oConfig)
26
-
27
- # TODO: Provide a way to re-edit all or partially elements set up by this function.
28
- begin
29
- oForjAccount = ForjAccount.new(oConfig)
30
-
31
- oForjAccount.ac_load()
32
- # TODO: Provide a way to update partially some account data.
33
- oForjAccount.setup() # any kind of setup, ask from users.
34
-
35
- oForjAccount.set(:flavor_name, 'standard.medium') if oForjAccount.exist?(:flavor_name) != oForjAccount.sAccountName
36
- oForjAccount.set(:bp_flavor, 'standard.small') if oForjAccount.exist?(:bp_flavor) != oForjAccount.sAccountName
37
- oForjAccount.ac_save()
38
-
39
- rescue RuntimeError => e
40
- Logging.fatal(1,e.message)
41
- rescue => e
42
- Logging.fatal(1,"Unable to run setup" , e)
43
- end
44
- end
45
- end