bosh-director 1.5.0.pre.1226 → 1.5.0.pre.1244

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,30 +1,47 @@
1
+ require 'json'
1
2
  require 'bosh/director/api/controllers/base_controller'
2
3
  require 'bosh/director/api/stemcell_manager'
3
4
  require 'bosh/director/compiled_package_group'
4
5
  require 'bosh/director/compiled_packages_exporter'
6
+ require 'bosh/director/stale_file_killer'
5
7
 
6
8
  module Bosh::Director
7
9
  module Api::Controllers
8
10
  class CompiledPackagesController < BaseController
9
- get '/stemcells/:stemcell_name/:stemcell_version/releases/:release_name/:release_version/compiled_packages' do
10
- stemcell_manager = Api::StemcellManager.new
11
- stemcell = stemcell_manager.find_by_name_and_version(params[:stemcell_name], params[:stemcell_version])
12
-
13
- release_manager = Api::ReleaseManager.new
14
- release = release_manager.find_by_name(params[:release_name])
15
- release_version = release_manager.find_version(release, params[:release_version])
11
+ post '/compiled_package_groups/export', consumes: [:json] do
12
+ stemcell = find_stemcell_by_name_and_version
13
+ release_version = find_release_version_by_name_and_version
16
14
 
17
- compiled_packages = CompiledPackageGroup.new(release_version, stemcell)
18
15
  output_dir = File.join(Dir.tmpdir, 'compiled_packages')
19
16
  FileUtils.mkdir_p(output_dir)
17
+
20
18
  killer = StaleFileKiller.new(output_dir)
21
19
  killer.kill
22
- exporter = CompiledPackagesExporter.new(compiled_packages, App.instance.blobstores.blobstore)
20
+
21
+ compiled_packages = CompiledPackageGroup.new(release_version, stemcell)
22
+ blobstore_client = App.instance.blobstores.blobstore
23
+ exporter = CompiledPackagesExporter.new(compiled_packages, blobstore_client)
23
24
 
24
25
  output_path = File.join(output_dir, "compiled_packages_#{Time.now.to_f}.tar.gz")
25
26
  exporter.export(output_path)
26
27
 
27
- send_file output_path, type: :tgz
28
+ send_file(output_path, type: :tgz)
29
+ end
30
+
31
+ def find_stemcell_by_name_and_version
32
+ stemcell_manager = Api::StemcellManager.new
33
+ stemcell_manager.find_by_name_and_version(
34
+ body_params['stemcell_name'], body_params['stemcell_version'])
35
+ end
36
+
37
+ def find_release_version_by_name_and_version
38
+ release_manager = Api::ReleaseManager.new
39
+ release = release_manager.find_by_name(body_params['release_name'])
40
+ release_manager.find_version(release, body_params['release_version'])
41
+ end
42
+
43
+ def body_params
44
+ @body_params ||= JSON.load(request.body)
28
45
  end
29
46
  end
30
47
  end
@@ -1,9 +1,7 @@
1
- require 'bosh/director'
2
- require 'bosh/director/compiled_package_yaml_writer'
3
-
4
1
  require 'fileutils'
5
2
  require 'tmpdir'
6
- require 'pathname'
3
+ require 'bosh/director'
4
+ require 'bosh/director/compiled_package_manifest'
7
5
 
8
6
  module Bosh::Director
9
7
  class CompiledPackageDownloader
@@ -13,25 +11,23 @@ module Bosh::Director
13
11
  end
14
12
 
15
13
  def download
16
- @download_dir = Pathname.new(Dir.mktmpdir)
14
+ @download_dir = Dir.mktmpdir
17
15
 
18
- blobs_path = @download_dir.join('compiled_packages', 'blobs')
19
- blobs_path.mkpath
16
+ blobs_path = File.join(@download_dir, 'compiled_packages', 'blobs')
17
+ FileUtils.mkpath(blobs_path)
20
18
 
21
19
  @compiled_package_group.compiled_packages.each do |compiled_package|
22
20
  blobstore_id = compiled_package.blobstore_id
23
-
24
- compiled_package_blob = blobs_path.join(blobstore_id).open('w')
25
- @blobstore_client.get(blobstore_id, compiled_package_blob)
26
- compiled_package_blob.close
21
+ File.open(File.join(blobs_path, blobstore_id), 'w') do |f|
22
+ @blobstore_client.get(blobstore_id, f, sha1: compiled_package.sha1)
23
+ end
27
24
  end
28
25
 
29
- CompiledPackageYamlWriter.new(@compiled_package_group, @download_dir.join('compiled_packages')).write
30
26
  @download_dir
31
27
  end
32
28
 
33
29
  def cleanup
34
- @download_dir.rmtree
30
+ FileUtils.rm_rf(@download_dir)
35
31
  end
36
32
  end
37
33
  end
@@ -0,0 +1,27 @@
1
+ require 'yaml'
2
+ require 'bosh/director'
3
+
4
+ module Bosh::Director
5
+ class CompiledPackageManifest
6
+ def initialize(group)
7
+ @compiled_package_group = group
8
+ end
9
+
10
+ def to_h
11
+ {
12
+ 'compiled_packages' => @compiled_package_group.compiled_packages.map do |compiled_package|
13
+ {
14
+ 'package_name' => compiled_package.package.name,
15
+ 'package_fingerprint' => compiled_package.package.fingerprint,
16
+ 'stemcell_sha1' => @compiled_package_group.stemcell_sha1,
17
+ 'blobstore_id' => compiled_package.blobstore_id,
18
+ }
19
+ end
20
+ }
21
+ end
22
+
23
+ def write(dest_path)
24
+ File.open(dest_path, 'w') { |f| f.write(YAML.dump(to_h)) }
25
+ end
26
+ end
27
+ end
@@ -12,11 +12,13 @@ module Bosh::Director
12
12
  downloader = CompiledPackageDownloader.new(@compiled_package_group, @blobstore_client)
13
13
  download_dir = downloader.download
14
14
 
15
- TarGzipper.new.compress(download_dir, 'compiled_packages', output_path)
15
+ manifest = CompiledPackageManifest.new(@compiled_package_group)
16
+ manifest.write(File.join(download_dir, 'compiled_packages.MF'))
16
17
 
18
+ archiver = TarGzipper.new
19
+ archiver.compress(download_dir, ['compiled_packages', 'compiled_packages.MF'], output_path)
20
+ ensure
17
21
  downloader.cleanup
18
-
19
- nil
20
22
  end
21
23
  end
22
24
  end
@@ -38,6 +38,7 @@ module Bosh::Director
38
38
  end
39
39
 
40
40
  private
41
+
41
42
  def tar(base_dir, dest, sources)
42
43
  out, err, status = Open3.capture3('tar', '-C', base_dir, '-czf', dest, *sources)
43
44
  raise("tar exited #{status.exitstatus}, output: '#{out}', error: '#{err}'") unless status.success?
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Bosh
4
4
  module Director
5
- VERSION = '1.5.0.pre.1226'
5
+ VERSION = '1.5.0.pre.1244'
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bosh-director
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.5.0.pre.1226
4
+ version: 1.5.0.pre.1244
5
5
  prerelease: 6
6
6
  platform: ruby
7
7
  authors:
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2013-11-01 00:00:00.000000000 Z
12
+ date: 2013-11-04 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: bcrypt-ruby
@@ -34,7 +34,7 @@ dependencies:
34
34
  requirements:
35
35
  - - ~>
36
36
  - !ruby/object:Gem::Version
37
- version: 1.5.0.pre.1226
37
+ version: 1.5.0.pre.1244
38
38
  type: :runtime
39
39
  prerelease: false
40
40
  version_requirements: !ruby/object:Gem::Requirement
@@ -42,7 +42,7 @@ dependencies:
42
42
  requirements:
43
43
  - - ~>
44
44
  - !ruby/object:Gem::Version
45
- version: 1.5.0.pre.1226
45
+ version: 1.5.0.pre.1244
46
46
  - !ruby/object:Gem::Dependency
47
47
  name: bosh-core
48
48
  requirement: !ruby/object:Gem::Requirement
@@ -50,7 +50,7 @@ dependencies:
50
50
  requirements:
51
51
  - - ~>
52
52
  - !ruby/object:Gem::Version
53
- version: 1.5.0.pre.1226
53
+ version: 1.5.0.pre.1244
54
54
  type: :runtime
55
55
  prerelease: false
56
56
  version_requirements: !ruby/object:Gem::Requirement
@@ -58,7 +58,7 @@ dependencies:
58
58
  requirements:
59
59
  - - ~>
60
60
  - !ruby/object:Gem::Version
61
- version: 1.5.0.pre.1226
61
+ version: 1.5.0.pre.1244
62
62
  - !ruby/object:Gem::Dependency
63
63
  name: bosh_common
64
64
  requirement: !ruby/object:Gem::Requirement
@@ -66,7 +66,7 @@ dependencies:
66
66
  requirements:
67
67
  - - ~>
68
68
  - !ruby/object:Gem::Version
69
- version: 1.5.0.pre.1226
69
+ version: 1.5.0.pre.1244
70
70
  type: :runtime
71
71
  prerelease: false
72
72
  version_requirements: !ruby/object:Gem::Requirement
@@ -74,7 +74,7 @@ dependencies:
74
74
  requirements:
75
75
  - - ~>
76
76
  - !ruby/object:Gem::Version
77
- version: 1.5.0.pre.1226
77
+ version: 1.5.0.pre.1244
78
78
  - !ruby/object:Gem::Dependency
79
79
  name: bosh_cpi
80
80
  requirement: !ruby/object:Gem::Requirement
@@ -82,7 +82,7 @@ dependencies:
82
82
  requirements:
83
83
  - - ~>
84
84
  - !ruby/object:Gem::Version
85
- version: 1.5.0.pre.1226
85
+ version: 1.5.0.pre.1244
86
86
  type: :runtime
87
87
  prerelease: false
88
88
  version_requirements: !ruby/object:Gem::Requirement
@@ -90,7 +90,7 @@ dependencies:
90
90
  requirements:
91
91
  - - ~>
92
92
  - !ruby/object:Gem::Version
93
- version: 1.5.0.pre.1226
93
+ version: 1.5.0.pre.1244
94
94
  - !ruby/object:Gem::Dependency
95
95
  name: bosh_openstack_cpi
96
96
  requirement: !ruby/object:Gem::Requirement
@@ -98,7 +98,7 @@ dependencies:
98
98
  requirements:
99
99
  - - ~>
100
100
  - !ruby/object:Gem::Version
101
- version: 1.5.0.pre.1226
101
+ version: 1.5.0.pre.1244
102
102
  type: :runtime
103
103
  prerelease: false
104
104
  version_requirements: !ruby/object:Gem::Requirement
@@ -106,7 +106,7 @@ dependencies:
106
106
  requirements:
107
107
  - - ~>
108
108
  - !ruby/object:Gem::Version
109
- version: 1.5.0.pre.1226
109
+ version: 1.5.0.pre.1244
110
110
  - !ruby/object:Gem::Dependency
111
111
  name: bosh_aws_cpi
112
112
  requirement: !ruby/object:Gem::Requirement
@@ -114,7 +114,7 @@ dependencies:
114
114
  requirements:
115
115
  - - ~>
116
116
  - !ruby/object:Gem::Version
117
- version: 1.5.0.pre.1226
117
+ version: 1.5.0.pre.1244
118
118
  type: :runtime
119
119
  prerelease: false
120
120
  version_requirements: !ruby/object:Gem::Requirement
@@ -122,7 +122,7 @@ dependencies:
122
122
  requirements:
123
123
  - - ~>
124
124
  - !ruby/object:Gem::Version
125
- version: 1.5.0.pre.1226
125
+ version: 1.5.0.pre.1244
126
126
  - !ruby/object:Gem::Dependency
127
127
  name: bosh_vsphere_cpi
128
128
  requirement: !ruby/object:Gem::Requirement
@@ -130,7 +130,7 @@ dependencies:
130
130
  requirements:
131
131
  - - ~>
132
132
  - !ruby/object:Gem::Version
133
- version: 1.5.0.pre.1226
133
+ version: 1.5.0.pre.1244
134
134
  type: :runtime
135
135
  prerelease: false
136
136
  version_requirements: !ruby/object:Gem::Requirement
@@ -138,7 +138,7 @@ dependencies:
138
138
  requirements:
139
139
  - - ~>
140
140
  - !ruby/object:Gem::Version
141
- version: 1.5.0.pre.1226
141
+ version: 1.5.0.pre.1244
142
142
  - !ruby/object:Gem::Dependency
143
143
  name: eventmachine
144
144
  requirement: !ruby/object:Gem::Requirement
@@ -445,7 +445,7 @@ dependencies:
445
445
  version: '1.0'
446
446
  description: ! 'BOSH Director
447
447
 
448
- 21ba44'
448
+ 1e7603'
449
449
  email: support@cloudfoundry.com
450
450
  executables:
451
451
  - bosh-director
@@ -527,7 +527,7 @@ files:
527
527
  - lib/bosh/director/compile_task.rb
528
528
  - lib/bosh/director/compiled_package_downloader.rb
529
529
  - lib/bosh/director/compiled_package_group.rb
530
- - lib/bosh/director/compiled_package_yaml_writer.rb
530
+ - lib/bosh/director/compiled_package_manifest.rb
531
531
  - lib/bosh/director/compiled_packages_exporter.rb
532
532
  - lib/bosh/director/config.rb
533
533
  - lib/bosh/director/configuration_hasher.rb
@@ -1,24 +0,0 @@
1
- require 'bosh/director'
2
-
3
- module Bosh::Director
4
- class CompiledPackageYamlWriter
5
- def initialize(group, dir)
6
- @compiled_package_group = group
7
- @dir = dir
8
- end
9
-
10
- def write
11
- hashes = @compiled_package_group.compiled_packages.map do |compiled_package|
12
- {
13
- 'package_name' => compiled_package.package.name,
14
- 'package_fingerprint' => compiled_package.package.fingerprint,
15
- 'stemcell_sha1' => @compiled_package_group.stemcell_sha1,
16
- 'blobstore_id' => compiled_package.blobstore_id,
17
- }
18
- end
19
- File.open(File.join(@dir, 'compiled_packages.yml'), 'w') do |f|
20
- f.write(YAML.dump('compiled_packages' => hashes))
21
- end
22
- end
23
- end
24
- end