dry-stack 0.0.79 → 0.0.81

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: 8823f4774a66a511374052a8358d1f55b5fdd9828fe5de1805078ca2d6ed6e6f
4
- data.tar.gz: 92c42ce074daa1565f3b927eeee50c90721741be2ec1748c220016d53c5e21a7
3
+ metadata.gz: 758974f16669de0183b226fe54b60a63ff0f83dce670049922d86968b5d4d7ad
4
+ data.tar.gz: afeaef4ec662565cda18cd38deef6b7e55977ab8b96838622665d2ac0e4c88f4
5
5
  SHA512:
6
- metadata.gz: fe64f228952239381ea0babe811d65f2f0a868e4f21a8452e3568314f0b89f2baf2da28c220620f4d7c46a8af586e3e417c1f35856f891f52164a6008e54ca3b
7
- data.tar.gz: 4ab470216298a7d48417a5db86b1c5d955ab1eaf393aa4f3ec4b746c41995bfb098ffca4a19c896218d5f27fbb269c8b2954b225f9f30071212570fb0957527a
6
+ metadata.gz: '09f0cbddbcc9ccc2465352bf5dd1365e0b0cb2a2f5788536b09e4018c7b4b5f9cb7677930540ab6e82c064724e1aa805c88c18a79e6a2e66bc27388f72b33ea0'
7
+ data.tar.gz: 4d1a5fe073d29742e48a8d26eef50620f37ff4f7a3d42b9c899d303824f64e472900ae9545d6b76d733cc0521b95ec9386afb78375820af91d5727a89fc2a2e7
@@ -11,7 +11,9 @@ Dry::CommandLine::COMMANDS[:to_compose] = Class.new do
11
11
  _params[:'no-env'] ? $stdout.puts(yaml) : system("echo \"#{yaml.gsub("`", '\\\`')}\"")
12
12
  end
13
13
 
14
- def help = 'Print stack in docker compose format'
14
+ def help = ['Print stack in docker compose format',
15
+ '[... to_compose <deploy name>] ']
16
+
15
17
  end.new
16
18
 
17
19
 
@@ -33,7 +33,7 @@ Dry::CommandLine::COMMANDS[:swarm_deploy] = Class.new do
33
33
  end
34
34
 
35
35
  # substitute ENV variables
36
- yaml = stack.to_compose(_params).lines[1..].join
36
+ yaml = stack.to_compose(_params, c_name).lines[1..].join
37
37
  yaml = _params[:'no-env'] ? yaml : `echo \"#{yaml.gsub("`", '\\\`')}\"`
38
38
  system " echo \"#{yaml.gsub("`", '\\\`')}\"" if _params[:v]
39
39
  # system " echo \"#{yaml.gsub("`", '\\\`')}\" | docker stack deploy -c - #{stack.name} --prune --resolve-image changed"
@@ -3,6 +3,7 @@ require 'yaml'
3
3
  require 'json'
4
4
  require 'optparse'
5
5
  require 'digest'
6
+ require 'bcrypt'
6
7
 
7
8
  # class TrueClass
8
9
  # def encode_with(coder) = coder.represent_scalar('tag:yaml.org,2002:str', 'true')
@@ -56,6 +57,7 @@ module Dry
56
57
  def logging(opts) = (@service[:logging] ||= {}).merge! opts
57
58
  def user(user) = @service[:user] = user # "${UID}:${GID}", "www-data:www-data"
58
59
  def network(names) = (@service[:networks] ||= []) << names
60
+ def basic_auth(user_and_password) = @service[:basic_auth] = user_and_password
59
61
  end
60
62
 
61
63
  class SwarmFunction
@@ -126,6 +128,7 @@ module Dry
126
128
 
127
129
  opts.merge! @swarm_deploy[deploy_name][:options]
128
130
  end
131
+
129
132
  compose = {
130
133
  # name: @name.to_s, # https://docs.docker.com/compose/compose-file/#name-top-level-element
131
134
  # Not allowed by docker stack deploy
@@ -146,6 +149,14 @@ module Dry
146
149
  service[:deploy][:labels] ||= []
147
150
  service[:deploy][:labels] += @labels.map { "#{_1}=#{_2}" }
148
151
 
152
+ if service[:basic_auth]
153
+ ba_user, ba_password = service[:basic_auth].split ':'
154
+ hashed_password = BCrypt::Password.create ba_password
155
+ service[:deploy][:labels] << "traefik.http.middlewares.%{service-name}_auth.basicauth.users=#{ba_user}:#{hashed_password.gsub('$','$$')}"
156
+ service[:deploy][:labels] << "traefik.http.routers.%{service-name}.middlewares=%{service-name}_auth"
157
+ service.delete :basic_auth
158
+ end
159
+
149
160
  if ingress[0] && (opts[:ingress] || opts[:traefik] || opts[:traefik_tls])
150
161
  service[:networks] ||= []
151
162
  service[:networks] << 'default' if service[:networks].empty?
data/lib/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  module Dry
2
2
  class Stack
3
- VERSION = '0.0.79'
3
+ VERSION = '0.0.81'
4
4
  end
5
5
  end
metadata CHANGED
@@ -1,15 +1,29 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: dry-stack
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.79
4
+ version: 0.0.81
5
5
  platform: ruby
6
6
  authors:
7
7
  - Artyom B
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-06-12 00:00:00.000000000 Z
11
+ date: 2024-06-19 00:00:00.000000000 Z
12
12
  dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bcrypt
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
13
27
  - !ruby/object:Gem::Dependency
14
28
  name: rake
15
29
  requirement: !ruby/object:Gem::Requirement