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 +4 -4
- data/CHANGELOG.md +13 -0
- data/README.md +2 -0
- data/docs/.gitignore +1 -0
- data/docs/Gemfile +1 -0
- data/docs/_config.yml +2 -0
- data/docs/_includes/banner/foot.html +2 -0
- data/docs/_includes/banner/head.html +5 -0
- data/docs/_includes/cfn-customize.md +14 -0
- data/docs/_includes/footer.html +6 -12
- data/docs/_layouts/default.html +2 -0
- data/docs/bin/web +1 -1
- data/lib/template/.ufo/settings.yml.tt +2 -2
- data/lib/ufo/setting/profile.rb +17 -1
- data/lib/ufo/stack/helper.rb +8 -1
- data/lib/ufo/version.rb +1 -1
- data/lib/ufo.rb +1 -1
- data/ufo.gemspec +1 -1
- metadata +9 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 0c57c6028e4210f60469d12a9c8fcf7fad4e5b200d8a6fef3b19401323bf612e
|
4
|
+
data.tar.gz: 8ccb219639a58f509502b3ed451cb120dfbc83dc4b4fd892e1f82eb0f0fdd40e
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
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
data/docs/Gemfile
CHANGED
data/docs/_config.yml
CHANGED
@@ -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.
|
data/docs/_includes/footer.html
CHANGED
@@ -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="
|
10
|
-
<li><a href="
|
11
|
-
<li><a href="
|
12
|
-
<li><a href="
|
13
|
-
<li><a href="https://
|
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>
|
data/docs/_layouts/default.html
CHANGED
@@ -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
@@ -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:
|
16
|
-
auto_camelize: false
|
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
|
data/lib/ufo/setting/profile.rb
CHANGED
@@ -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
|
-
|
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
|
data/lib/ufo/stack/helper.rb
CHANGED
@@ -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 "
|
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
data/lib/ufo.rb
CHANGED
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.
|
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:
|
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:
|
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:
|
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.
|
720
|
+
rubygems_version: 3.2.32
|
719
721
|
signing_key:
|
720
722
|
specification_version: 4
|
721
723
|
summary: AWS ECS Deploy Tool
|