ufo 5.0.2 → 5.0.6

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d69cb0cf10e5170348b79e5ca64a6a593196c7e820a50d2c76e3ba667a4093cb
4
- data.tar.gz: 60f41ec8d10fdf1a17265c6a6f3ad7a95777943c6246e7ee04be038241bdd2bb
3
+ metadata.gz: 0c57c6028e4210f60469d12a9c8fcf7fad4e5b200d8a6fef3b19401323bf612e
4
+ data.tar.gz: 8ccb219639a58f509502b3ed451cb120dfbc83dc4b4fd892e1f82eb0f0fdd40e
5
5
  SHA512:
6
- metadata.gz: '08b075b165b296f5efd8c45493bd5d0f71db161272a9fd7f41dfd91f9ed18d92287179029ac961f7b892c8c92e86f0a856b85fbe87d595c011cc04de89cd92e3'
7
- data.tar.gz: ed0559461a50e6701d93b37bc5484c7366ddf7f9ad56f613b728b43ee1c06a3f9863bab267793f6d6977a2ce9a4ce5aac689a606021390ad69e1bb2ca3ea8cf4
6
+ metadata.gz: 405616d32c0e9d9d6a630497388040df553ac825e64f94f221495401c75c62a02e6df9b820f2d138380c68d2cc2607afee8258ef0cd4503a9a0c68f429c85bc3
7
+ data.tar.gz: 92b2942e8524d8eb760ff43b279c7c41ab8ec02b4381e671a6c2068389966aae14c7dc53aeb663c7d2a43b48672a2e0b1ef6f44e079dc80f2b11c10ac54c87c9
data/CHANGELOG.md CHANGED
@@ -3,6 +3,19 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  This project *tries* to adhere to [Semantic Versioning](http://semver.org/), even before v1.0.
5
5
 
6
+ ## [5.0.6] - 2021-12-16
7
+ - [#120](https://github.com/tongueroo/ufo/pull/120) new stack_naming: append_ufo_env default to fix append_env bug
8
+ - [#122](https://github.com/tongueroo/ufo/pull/122) require active_support all
9
+
10
+ ## [5.0.5] - 2021-01-23
11
+ - allow base profile without a default profile
12
+
13
+ ## [5.0.4] - 2021-01-23
14
+ - [#119](https://github.com/tongueroo/ufo/pull/119) layer base profiles with env-specific or default profile
15
+
16
+ ## [5.0.3] - 2020-12-10
17
+ - [#118](https://github.com/tongueroo/ufo/pull/118) update aws-mfa-secure with require singleton fix
18
+
6
19
  ## [5.0.2]
7
20
  - #111 Add support of credsStore
8
21
  - #112 Add support for bridge network mode
data/README.md CHANGED
@@ -10,6 +10,8 @@
10
10
 
11
11
  [![BoltOps Badge](https://img.boltops.com/boltops/badges/boltops-badge.png)](https://www.boltops.com)
12
12
 
13
+ Please **watch/star** this repo to help grow and support the project.
14
+
13
15
  Ufo is a tool that builds Docker images and deploys them to [AWS ECS](https://aws.amazon.com/ecs/). The main command is `ufo ship`. Here's summary of what it does:
14
16
 
15
17
  1. Builds a docker image.
data/docs/.gitignore CHANGED
@@ -2,3 +2,4 @@ _site
2
2
  .sass-cache
3
3
  .jekyll-metadata
4
4
  Gemfile.lock
5
+ _config-dev.yml
data/docs/Gemfile CHANGED
@@ -1,3 +1,4 @@
1
1
  source "https://rubygems.org"
2
2
 
3
3
  gem "jekyll"
4
+ gem "webrick"
data/docs/_config.yml CHANGED
@@ -71,3 +71,5 @@ defaults:
71
71
 
72
72
  plugins_dir:
73
73
  - jekyll-coffeescript
74
+
75
+ ads_url: "https://ads.boltops.com"
@@ -0,0 +1,2 @@
1
+ <div id="foot-banner" class="foot-banner">
2
+ </div>
@@ -0,0 +1,5 @@
1
+ {% assign buildtime = "now" | date: "%Y%m%d%H%M%S" %}
2
+ <link rel="preload" href="{{ site.ads_url }}/ads/{{ site.time | date: '%s' }}.js" as="script" />
3
+ <script data-cfasync="false" async src="{{ site.ads_url }}/ads/{{ site.time | date: '%s' }}.js"></script>
4
+
5
+ <div id="head-banner" class="head-banner"></div>
@@ -36,4 +36,18 @@ Here's a list of the resources in the [cfn/stack.yml](https://github.com/tonguer
36
36
  * Listener
37
37
  * TargetGroup
38
38
 
39
+ ## Layering Support
40
+
41
+ The `base.yml` profile files always get evaluated and env-specific ENV.yml file are layered or merged together. This miminizes duplication. For example, these files are merged:
42
+
43
+ * .ufo/settings/cfn/base.yml
44
+ * .ufo/settings/cfn/development.yml
45
+
46
+ The settings in `development.yml` override the settings in `base.yml`. Here's another example:
47
+
48
+ * .ufo/settings/network/base.yml
49
+ * .ufo/settings/network/development.yml
50
+
51
+ Note, this feature is available in v5.0.5+.
52
+
39
53
  For the most up to date list check out the [cfn/stack.yml](https://github.com/tongueroo/ufo/blob/master/lib/cfn/stack.yml) source code directly.
@@ -6,11 +6,12 @@
6
6
  <div class="footer-col col-md-4">
7
7
  <h3>More Tools</h3>
8
8
  <ul class="list-unstyled tools">
9
- <li><a href="http://rubyonjets.com">Jets</a></li>
10
- <li><a href="http://lono.cloud">Lono</a></li>
11
- <li><a href="http://sonic-screwdriver.cloud">Sonic</a></li>
12
- <li><a href="http://jack-eb.com">Jack</a></li>
13
- <li><a href="https://boltops.com/toolbelt">Toolbelt</a></li>
9
+ <li><a href="https://terraspace.cloud">Terraspace</a></li>
10
+ <li><a href="https://kubes.guru">Kubes</a></li>
11
+ <li><a href="https://rubyonjets.com">Jets</a></li>
12
+ <li><a href="https://lono.cloud">Lono</a></li>
13
+ <li><a href="https://sonic-screwdriver.cloud">Sonic</a></li>
14
+ <li><a href="https://jack-eb.com">Jack</a></li>
14
15
  </ul>
15
16
  </div>
16
17
  <div class="footer-col col-md-4">
@@ -41,10 +42,3 @@
41
42
  </div>
42
43
  </div>
43
44
  </footer>
44
-
45
- <!-- Scroll to Top Button (Only visible on small and extra-small screen sizes) -->
46
- <div class="scroll-top page-scroll visible-xs visible-sm">
47
- <a id="next" class="btn btn-primary" href="#page-top">
48
- <i class="fa fa-chevron-up"></i>
49
- </a>
50
- </div>
@@ -2,10 +2,12 @@
2
2
  <html>
3
3
  {% include head.html %}
4
4
  <body id="page-top" class="index">
5
+ {% include banner/head.html %}
5
6
  {% include nav.html %}
6
7
  {% include content.html %}
7
8
  {% include footer.html %}
8
9
  {% include modals.html %}
10
+ {% include banner/foot.html %}
9
11
  {% include js.html %}
10
12
  </body>
11
13
  </html>
data/docs/bin/web CHANGED
@@ -1,4 +1,4 @@
1
1
  #!/bin/bash -ex
2
2
 
3
3
  bundle exec jekyll clean
4
- exec bundle exec jekyll serve --host 0.0.0.0 "$@"
4
+ exec bundle exec jekyll serve --trace --config _config.yml,_config-dev.yml "$@"
@@ -12,8 +12,8 @@ base:
12
12
  # There are some cavaets with this. Updating properties on resources that require
13
13
  # replacment might not work. For example, adding and removing a load balancer.
14
14
  # In these cases, you must delete the entire ecs service and recreate it.
15
- stack_naming: append_env
16
- auto_camelize: false # new default setting in ufo v5
15
+ stack_naming: append_ufo_env # new default setting in ufo v5.0.6
16
+ auto_camelize: false # new default setting in ufo v5
17
17
 
18
18
  development:
19
19
  # cluster: development
@@ -12,6 +12,7 @@ class Ufo::Setting
12
12
  @profile, # user specified
13
13
  Ufo.env, # conventional based on env
14
14
  "default", # fallback to default
15
+ "base", # finally fallback to base
15
16
  ].compact.uniq
16
17
  paths = names.map { |name| "#{Ufo.root}/.ufo/settings/#{@type}/#{name}.yml" }
17
18
  found = paths.find { |p| File.exist?(p) }
@@ -21,8 +22,23 @@ class Ufo::Setting
21
22
  end
22
23
 
23
24
  text = RenderMePretty.result(found)
24
- YAML.load(text).deep_symbolize_keys
25
+ specific_data = yaml_load(text)
26
+
27
+ base = "#{Ufo.root}/.ufo/settings/#{@type}/base.yml"
28
+ base_data = if File.exist?(base)
29
+ text = RenderMePretty.result(base)
30
+ yaml_load(text)
31
+ else
32
+ {}
33
+ end
34
+
35
+ base_data.deep_merge(specific_data)
25
36
  end
26
37
  memoize :data
38
+
39
+ def yaml_load(text)
40
+ result = YAML.load(text) # yaml file can contain nothing but comments
41
+ result.is_a?(Hash) ? result.deep_symbolize_keys : {}
42
+ end
27
43
  end
28
44
  end
@@ -28,10 +28,17 @@ class Ufo::Stack
28
28
  parts = case settings[:stack_naming]
29
29
  when "prepend_cluster" # ufo v4.3 and below
30
30
  [cluster, service, Ufo.env_extra] # legacy
31
- when "append_env", "append_cluster" # ufo v4.5
31
+ when "append_cluster" # ufo v4.5
32
32
  # append_env will be removed in the next major version in favor of append_cluster to avoid confusion with
33
33
  # append_ufo_env
34
34
  [service, cluster, Ufo.env_extra]
35
+ when "append_env" # ufo v5.0.3 and below: append_env is a bug, it appends cluster name instead of env name
36
+ puts "WARN: Deprecation: The append_env is depreciated .ufo/settings.yaml".color(:yellow)
37
+ puts "It appends the cluster env instead of the UFO_ENV env. This is unexpected behavior. "
38
+ puts "To been fix this, please `stack_naming: append_ufo_env` instead. "
39
+ [service, cluster, Ufo.env_extra] # bug - kept for backward compatibility
40
+ when "append_ufo_env" # v5.1.0 fixes bug where append_env would append cluster name instead
41
+ [service, Ufo.env, Ufo.env_extra]
35
42
  when "append_nothing", "prepend_nothing"
36
43
  [service, Ufo.env_extra]
37
44
  else # new default. ufo v4.5 and above
data/lib/ufo/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Ufo
2
- VERSION = "5.0.2"
2
+ VERSION = "5.0.6"
3
3
  end
data/lib/ufo.rb CHANGED
@@ -1,7 +1,7 @@
1
1
  $stdout.sync = true unless ENV["UFO_STDOUT_SYNC"] == "0"
2
2
 
3
3
  $:.unshift(File.expand_path('../', __FILE__))
4
- require 'active_support/core_ext/class'
4
+ require 'active_support/all'
5
5
  require 'deep_merge/rails_compat'
6
6
  require 'fileutils'
7
7
  require 'memoist'
data/ufo.gemspec CHANGED
@@ -19,7 +19,7 @@ Gem::Specification.new do |spec|
19
19
  spec.require_paths = ["lib"]
20
20
 
21
21
  spec.add_dependency "aws-logs"
22
- spec.add_dependency "aws-mfa-secure"
22
+ spec.add_dependency "aws-mfa-secure", "~> 0.4.3"
23
23
  spec.add_dependency "aws-sdk-cloudformation"
24
24
  spec.add_dependency "aws-sdk-cloudwatchlogs"
25
25
  spec.add_dependency "aws-sdk-ec2"
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ufo
3
3
  version: !ruby/object:Gem::Version
4
- version: 5.0.2
4
+ version: 5.0.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - Tung Nguyen
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-08-02 00:00:00.000000000 Z
11
+ date: 2021-12-16 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: aws-logs
@@ -28,16 +28,16 @@ dependencies:
28
28
  name: aws-mfa-secure
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
- - - ">="
31
+ - - "~>"
32
32
  - !ruby/object:Gem::Version
33
- version: '0'
33
+ version: 0.4.3
34
34
  type: :runtime
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
- - - ">="
38
+ - - "~>"
39
39
  - !ruby/object:Gem::Version
40
- version: '0'
40
+ version: 0.4.3
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: aws-sdk-cloudformation
43
43
  requirement: !ruby/object:Gem::Requirement
@@ -398,6 +398,8 @@ files:
398
398
  - docs/_docs/upgrading/upgrade5.md
399
399
  - docs/_docs/variables.md
400
400
  - docs/_includes/about.html
401
+ - docs/_includes/banner/foot.html
402
+ - docs/_includes/banner/head.html
401
403
  - docs/_includes/cfn-customize.md
402
404
  - docs/_includes/commands.html
403
405
  - docs/_includes/contact.html
@@ -715,7 +717,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
715
717
  - !ruby/object:Gem::Version
716
718
  version: '0'
717
719
  requirements: []
718
- rubygems_version: 3.1.2
720
+ rubygems_version: 3.2.32
719
721
  signing_key:
720
722
  specification_version: 4
721
723
  summary: AWS ECS Deploy Tool