avm 0.30.0 → 0.31.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/avm/instances/base/auto_values/install.rb +48 -0
- data/lib/avm/instances/base/auto_values.rb +1 -1
- data/lib/avm/instances/base.rb +4 -4
- data/lib/avm/instances/entry_keys.rb +7 -6
- data/lib/avm/instances.rb +3 -2
- data/lib/avm/scms/base.rb +2 -2
- data/lib/avm/source_generators/base.rb +2 -2
- data/lib/avm/sources/base.rb +4 -4
- data/lib/avm/version.rb +1 -1
- data/lib/avm/with/application_stereotype.rb +35 -0
- data/lib/avm/with/extra_subcommands.rb +44 -0
- metadata +9 -9
- data/lib/avm/instances/base/auto_values/access.rb +0 -40
- data/lib/avm/with_application_stereotype.rb +0 -33
- data/lib/avm/with_dynamic_runners.rb +0 -42
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: aea575c3e0ebcc43678325a4a682ea17c915ecae1eb6d133335b3e94ace56ca3
|
4
|
+
data.tar.gz: 2ed8fc21068a44f5ae816aa098a866650f32511b09afca2e75af2b620cd89f9b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3c87d398c755f55f71a827167bfbe0131d08d5df55af5497ccc7fd239cd059e59c9f251dbe448ca13df30c31da76e147dc2bd8e0d1501130000a219313b5e39d
|
7
|
+
data.tar.gz: e188963cfc504522f52eb86e7de7490427c194496c61e2d6771bdfdd697de9d9e6647cc0c1c772c6f19b3799bdd05c3054f999caa8168708a29e910d19398431
|
@@ -0,0 +1,48 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'avm/instances/entry_keys'
|
4
|
+
|
5
|
+
module Avm
|
6
|
+
module Instances
|
7
|
+
class Base
|
8
|
+
module AutoValues
|
9
|
+
module Install
|
10
|
+
def auto_access
|
11
|
+
read_entry_optional(::Avm::Instances::EntryKeys::INSTALL_URL).present? ? 'ssh' : 'local'
|
12
|
+
end
|
13
|
+
|
14
|
+
def auto_install_hostname
|
15
|
+
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID,
|
16
|
+
::Avm::Instances::EntryKeys::INSTALL_HOSTNAME)
|
17
|
+
end
|
18
|
+
|
19
|
+
def auto_install_port
|
20
|
+
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID,
|
21
|
+
::Avm::Instances::EntryKeys::INSTALL_PORT) || 22
|
22
|
+
end
|
23
|
+
|
24
|
+
def auto_install_username
|
25
|
+
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID,
|
26
|
+
::Avm::Instances::EntryKeys::INSTALL_USERNAME)
|
27
|
+
end
|
28
|
+
|
29
|
+
def auto_install_url
|
30
|
+
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID,
|
31
|
+
::Avm::Instances::EntryKeys::INSTALL_URL) ||
|
32
|
+
auto_install_url_by_parts
|
33
|
+
end
|
34
|
+
|
35
|
+
def auto_install_url_by_parts
|
36
|
+
read_entry_optional(::Avm::Instances::EntryKeys::INSTALL_HOSTNAME).if_present do |a|
|
37
|
+
a = read_entry_optional(::Avm::Instances::EntryKeys::INSTALL_USERNAME)
|
38
|
+
.if_present(a) { |v| "#{v}@#{a}" }
|
39
|
+
a = read_entry_optional(::Avm::Instances::EntryKeys::INSTALL_PORT)
|
40
|
+
.if_present(a) { |v| "#{a}:#{v}" }
|
41
|
+
"ssh://#{a}"
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
@@ -10,7 +10,7 @@ module Avm
|
|
10
10
|
extend ::ActiveSupport::Concern
|
11
11
|
|
12
12
|
included do
|
13
|
-
%w[
|
13
|
+
%w[Admin Data Database Filesystem Install Mailer Ruby Source System Web]
|
14
14
|
.each do |class_name|
|
15
15
|
include const_get(class_name)
|
16
16
|
end
|
data/lib/avm/instances/base.rb
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require 'avm/
|
4
|
-
require 'avm/
|
3
|
+
require 'avm/with/application_stereotype'
|
4
|
+
require 'avm/with/extra_subcommands'
|
5
5
|
require 'eac_ruby_utils/require_sub'
|
6
6
|
require 'eac_ruby_utils/simple_cache'
|
7
7
|
require 'avm/instances/entries'
|
@@ -14,8 +14,8 @@ module Avm
|
|
14
14
|
enable_simple_cache
|
15
15
|
require_sub __FILE__, include_modules: true
|
16
16
|
include ::Avm::Instances::Entries
|
17
|
-
include ::Avm::
|
18
|
-
include ::Avm::
|
17
|
+
include ::Avm::With::ExtraSubcommands
|
18
|
+
include ::Avm::With::ApplicationStereotype
|
19
19
|
|
20
20
|
lists.add_string :access, :local, :ssh
|
21
21
|
|
@@ -5,6 +5,8 @@ require 'eac_ruby_utils/core_ext'
|
|
5
5
|
module Avm
|
6
6
|
module Instances
|
7
7
|
module EntryKeys
|
8
|
+
URI_FIELDS = %i[fragment hostname password path port query scheme url username].freeze
|
9
|
+
|
8
10
|
class << self
|
9
11
|
def all
|
10
12
|
all_keys.to_a
|
@@ -43,17 +45,16 @@ module Avm
|
|
43
45
|
|
44
46
|
{
|
45
47
|
'' => %w[data_fs_path fs_path host_id name source_instance_id],
|
46
|
-
admin: %w[
|
47
|
-
database: %w[id
|
48
|
+
admin: URI_FIELDS + %w[api_key],
|
49
|
+
database: URI_FIELDS + %w[id limit name system timeout extra],
|
48
50
|
docker: %w[registry],
|
49
51
|
fs: %w[url],
|
52
|
+
install: URI_FIELDS,
|
50
53
|
mailer: {
|
51
54
|
'' => %w[id from reply_to],
|
52
|
-
smtp: %w[address
|
53
|
-
starttls_auto tls]
|
55
|
+
smtp: URI_FIELDS + %w[address domain authentication openssl_verify_mode starttls_auto tls]
|
54
56
|
},
|
55
|
-
|
56
|
-
web: %w[authority hostname path port scheme url userinfo]
|
57
|
+
web: URI_FIELDS + %w[authority userinfo]
|
57
58
|
}.each { |prefix, suffixes| keys_consts_set(prefix, suffixes) }
|
58
59
|
end
|
59
60
|
end
|
data/lib/avm/instances.rb
CHANGED
data/lib/avm/scms/base.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require 'avm/
|
3
|
+
require 'avm/with/application_stereotype'
|
4
4
|
require 'eac_ruby_utils/core_ext'
|
5
5
|
|
6
6
|
module Avm
|
@@ -8,7 +8,7 @@ module Avm
|
|
8
8
|
class Base
|
9
9
|
enable_abstract_methods
|
10
10
|
enable_simple_cache
|
11
|
-
include ::Avm::
|
11
|
+
include ::Avm::With::ApplicationStereotype
|
12
12
|
abstract_methods :update, :valid?
|
13
13
|
common_constructor :path do
|
14
14
|
self.path = path.to_pathname
|
@@ -1,12 +1,12 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require 'avm/
|
3
|
+
require 'avm/with/application_stereotype'
|
4
4
|
require 'eac_ruby_utils/core_ext'
|
5
5
|
|
6
6
|
module Avm
|
7
7
|
module SourceGenerators
|
8
8
|
class Base
|
9
|
-
include ::Avm::
|
9
|
+
include ::Avm::With::ApplicationStereotype
|
10
10
|
common_constructor :target_path do
|
11
11
|
self.target_path = target_path.to_pathname
|
12
12
|
end
|
data/lib/avm/sources/base.rb
CHANGED
@@ -2,8 +2,8 @@
|
|
2
2
|
|
3
3
|
require 'avm/registry'
|
4
4
|
require 'avm/scms/null'
|
5
|
-
require 'avm/
|
6
|
-
require 'avm/
|
5
|
+
require 'avm/with/application_stereotype'
|
6
|
+
require 'avm/with/extra_subcommands'
|
7
7
|
require 'eac_git'
|
8
8
|
require 'eac_ruby_utils/core_ext'
|
9
9
|
|
@@ -11,8 +11,8 @@ module Avm
|
|
11
11
|
module Sources
|
12
12
|
class Base
|
13
13
|
require_sub __FILE__, include_modules: true
|
14
|
-
include ::Avm::
|
15
|
-
include ::Avm::
|
14
|
+
include ::Avm::With::ApplicationStereotype
|
15
|
+
include ::Avm::With::ExtraSubcommands
|
16
16
|
compare_by :path
|
17
17
|
enable_abstract_methods
|
18
18
|
enable_simple_cache
|
data/lib/avm/version.rb
CHANGED
@@ -0,0 +1,35 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_ruby_utils/core_ext'
|
4
|
+
|
5
|
+
module Avm
|
6
|
+
module With
|
7
|
+
module ApplicationStereotype
|
8
|
+
common_concern do
|
9
|
+
include ClassMethods
|
10
|
+
end
|
11
|
+
|
12
|
+
module ClassMethods
|
13
|
+
# @return [Avm::ApplicationStereotype::Base]
|
14
|
+
def application_stereotype
|
15
|
+
@application_stereotype ||=
|
16
|
+
::Avm::Registry.application_stereotypes.detect(application_stereotype_name)
|
17
|
+
end
|
18
|
+
|
19
|
+
# @return [String]
|
20
|
+
def application_stereotype_name
|
21
|
+
stereotype_namespace_module.name.demodulize
|
22
|
+
end
|
23
|
+
|
24
|
+
# @return [Module]
|
25
|
+
def stereotype_namespace_module
|
26
|
+
module_parent.module_parent
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def stereotype_namespace_module
|
31
|
+
self.class.stereotype_namespace_module
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/runner_with/subcommands'
|
4
|
+
require 'eac_ruby_utils/core_ext'
|
5
|
+
|
6
|
+
module Avm
|
7
|
+
module With
|
8
|
+
module ExtraSubcommands
|
9
|
+
# @return [Hash<String, EacCli::Runner>]
|
10
|
+
def extra_available_subcommands
|
11
|
+
extra_available_subcommands_from_runners_module
|
12
|
+
end
|
13
|
+
|
14
|
+
# @return [Hash<String, EacCli::Runner>]
|
15
|
+
def extra_available_subcommands_from_runners_module
|
16
|
+
self.class.ancestors.reverse.inject({}) do |a, e|
|
17
|
+
a.merge(RunnersFromModule.new(e).result)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
class RunnersFromModule
|
22
|
+
enable_simple_cache
|
23
|
+
common_constructor :the_module
|
24
|
+
|
25
|
+
# @return [Hash<String, EacCli::Runner>]
|
26
|
+
def result
|
27
|
+
return {} if runners_module.blank?
|
28
|
+
|
29
|
+
::EacCli::RunnerWith::Subcommands.subcommands_from_module(runners_module)
|
30
|
+
end
|
31
|
+
|
32
|
+
def runners_module_uncached
|
33
|
+
return nil if the_module.module_parent.blank?
|
34
|
+
|
35
|
+
begin
|
36
|
+
the_module.module_parent.const_get('Runners')
|
37
|
+
rescue ::NameError
|
38
|
+
nil
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: avm
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.31.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Eduardo H. Bogoni
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-
|
11
|
+
date: 2022-08-01 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: eac_cli
|
@@ -36,14 +36,14 @@ dependencies:
|
|
36
36
|
requirements:
|
37
37
|
- - "~>"
|
38
38
|
- !ruby/object:Gem::Version
|
39
|
-
version: '0.
|
39
|
+
version: '0.10'
|
40
40
|
type: :runtime
|
41
41
|
prerelease: false
|
42
42
|
version_requirements: !ruby/object:Gem::Requirement
|
43
43
|
requirements:
|
44
44
|
- - "~>"
|
45
45
|
- !ruby/object:Gem::Version
|
46
|
-
version: '0.
|
46
|
+
version: '0.10'
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: eac_docker
|
49
49
|
requirement: !ruby/object:Gem::Requirement
|
@@ -78,14 +78,14 @@ dependencies:
|
|
78
78
|
requirements:
|
79
79
|
- - "~>"
|
80
80
|
- !ruby/object:Gem::Version
|
81
|
-
version: '0.
|
81
|
+
version: '0.97'
|
82
82
|
type: :runtime
|
83
83
|
prerelease: false
|
84
84
|
version_requirements: !ruby/object:Gem::Requirement
|
85
85
|
requirements:
|
86
86
|
- - "~>"
|
87
87
|
- !ruby/object:Gem::Version
|
88
|
-
version: '0.
|
88
|
+
version: '0.97'
|
89
89
|
- !ruby/object:Gem::Dependency
|
90
90
|
name: eac_templates
|
91
91
|
requirement: !ruby/object:Gem::Requirement
|
@@ -217,11 +217,11 @@ files:
|
|
217
217
|
- lib/avm/instances.rb
|
218
218
|
- lib/avm/instances/base.rb
|
219
219
|
- lib/avm/instances/base/auto_values.rb
|
220
|
-
- lib/avm/instances/base/auto_values/access.rb
|
221
220
|
- lib/avm/instances/base/auto_values/admin.rb
|
222
221
|
- lib/avm/instances/base/auto_values/data.rb
|
223
222
|
- lib/avm/instances/base/auto_values/database.rb
|
224
223
|
- lib/avm/instances/base/auto_values/filesystem.rb
|
224
|
+
- lib/avm/instances/base/auto_values/install.rb
|
225
225
|
- lib/avm/instances/base/auto_values/mailer.rb
|
226
226
|
- lib/avm/instances/base/auto_values/ruby.rb
|
227
227
|
- lib/avm/instances/base/auto_values/source.rb
|
@@ -288,8 +288,8 @@ files:
|
|
288
288
|
- lib/avm/sync.rb
|
289
289
|
- lib/avm/version.rb
|
290
290
|
- lib/avm/version_number.rb
|
291
|
-
- lib/avm/
|
292
|
-
- lib/avm/
|
291
|
+
- lib/avm/with/application_stereotype.rb
|
292
|
+
- lib/avm/with/extra_subcommands.rb
|
293
293
|
homepage:
|
294
294
|
licenses: []
|
295
295
|
metadata: {}
|
@@ -1,40 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Avm
|
4
|
-
module Instances
|
5
|
-
class Base
|
6
|
-
module AutoValues
|
7
|
-
module Access
|
8
|
-
def auto_access
|
9
|
-
read_entry_optional('ssh.url').present? ? 'ssh' : 'local'
|
10
|
-
end
|
11
|
-
|
12
|
-
def auto_ssh_hostname
|
13
|
-
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID, 'ssh.hostname')
|
14
|
-
end
|
15
|
-
|
16
|
-
def auto_ssh_port
|
17
|
-
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID, 'ssh.port') || 22
|
18
|
-
end
|
19
|
-
|
20
|
-
def auto_ssh_username
|
21
|
-
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID, 'ssh.username')
|
22
|
-
end
|
23
|
-
|
24
|
-
def auto_ssh_url
|
25
|
-
inherited_entry_value(::Avm::Instances::EntryKeys::HOST_ID, 'ssh.url') ||
|
26
|
-
auto_ssh_url_by_parts
|
27
|
-
end
|
28
|
-
|
29
|
-
def auto_ssh_url_by_parts
|
30
|
-
read_entry_optional('ssh.hostname').if_present do |a|
|
31
|
-
a = read_entry_optional('ssh.username').if_present(a) { |v| "#{v}@#{a}" }
|
32
|
-
a = read_entry_optional('ssh.port').if_present(a) { |v| "#{a}:#{v}" }
|
33
|
-
"ssh://#{a}"
|
34
|
-
end
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
@@ -1,33 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'eac_ruby_utils/core_ext'
|
4
|
-
|
5
|
-
module Avm
|
6
|
-
module WithApplicationStereotype
|
7
|
-
common_concern do
|
8
|
-
include ClassMethods
|
9
|
-
end
|
10
|
-
|
11
|
-
module ClassMethods
|
12
|
-
# @return [Avm::ApplicationStereotype::Base]
|
13
|
-
def application_stereotype
|
14
|
-
@application_stereotype ||=
|
15
|
-
::Avm::Registry.application_stereotypes.detect(application_stereotype_name)
|
16
|
-
end
|
17
|
-
|
18
|
-
# @return [String]
|
19
|
-
def application_stereotype_name
|
20
|
-
stereotype_namespace_module.name.demodulize
|
21
|
-
end
|
22
|
-
|
23
|
-
# @return [Module]
|
24
|
-
def stereotype_namespace_module
|
25
|
-
module_parent.module_parent
|
26
|
-
end
|
27
|
-
end
|
28
|
-
|
29
|
-
def stereotype_namespace_module
|
30
|
-
self.class.stereotype_namespace_module
|
31
|
-
end
|
32
|
-
end
|
33
|
-
end
|
@@ -1,42 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'eac_cli/runner_with/subcommands'
|
4
|
-
require 'eac_ruby_utils/core_ext'
|
5
|
-
|
6
|
-
module Avm
|
7
|
-
module WithDynamicRunners
|
8
|
-
# @return [Hash<String, EacCli::Runner>]
|
9
|
-
def extra_available_subcommands
|
10
|
-
extra_available_subcommands_from_runners_module
|
11
|
-
end
|
12
|
-
|
13
|
-
# @return [Hash<String, EacCli::Runner>]
|
14
|
-
def extra_available_subcommands_from_runners_module
|
15
|
-
self.class.ancestors.reverse.inject({}) do |a, e|
|
16
|
-
a.merge(RunnersFromModule.new(e).result)
|
17
|
-
end
|
18
|
-
end
|
19
|
-
|
20
|
-
class RunnersFromModule
|
21
|
-
enable_simple_cache
|
22
|
-
common_constructor :the_module
|
23
|
-
|
24
|
-
# @return [Hash<String, EacCli::Runner>]
|
25
|
-
def result
|
26
|
-
return {} if runners_module.blank?
|
27
|
-
|
28
|
-
::EacCli::RunnerWith::Subcommands.subcommands_from_module(runners_module)
|
29
|
-
end
|
30
|
-
|
31
|
-
def runners_module_uncached
|
32
|
-
return nil if the_module.module_parent.blank?
|
33
|
-
|
34
|
-
begin
|
35
|
-
the_module.module_parent.const_get('Runners')
|
36
|
-
rescue ::NameError
|
37
|
-
nil
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
41
|
-
end
|
42
|
-
end
|