eco-helpers 3.0.25 → 3.0.26

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 209a98dac82894462d5ba24f82a85965cb10c14513d617e86d09fcfb96d3f81a
4
- data.tar.gz: 288706b5a0f8a3aa81376edd2a42d61d690aae49cf6be6af9b7be5b52f34764a
3
+ metadata.gz: 50ae7636d8e6f36c3b26dc7aebfbbf39b75c47c42b9da32d5e5f92329a70667f
4
+ data.tar.gz: b1a0d59be014014420e7a063f66c10f6a46fa3ce1aeb2edbf23bc4f4ee4486a6
5
5
  SHA512:
6
- metadata.gz: 3507855864665cf289361e803d5e9a835b9eb24d06e66a7249b4b8f9e0388eb65b51f5d8f634c0141a4562979dd69fb2df96c753de9325ef350351a6719be7f6
7
- data.tar.gz: 8ef26aec84fd8ceb559fbf4a938f30f2b06f2abc73ce9fdf09b70e48fb3d4f7e0f0904ef65c5cd1dc81d1d143b1888d24c50e884884a34c321baf54022547dd4
6
+ metadata.gz: b2d5d5a7af32d5e0f10b485975420898f707960ea90fa53382b76a944f9402c34907250e2dc9a61dfc04821dda08ab97948f62af46501514d2b7d2e951e298f5
7
+ data.tar.gz: 61cae6581d83b846e4fae519be1e9809fbc413ed100b7e8506bc7bc8da76cb152066438056d0f111c3f697d8e6feba1a5c4ad536ceb5f8f32f001ca12d34d4fd
data/CHANGELOG.md CHANGED
@@ -6,6 +6,11 @@ All notable changes to this project will be documented in this file.
6
6
 
7
7
  ### Added
8
8
 
9
+ - default constant for `FILE_PATTERN`
10
+ - `Loaders::Base` **added**:
11
+ - `#api_space` and `#api_space_default?`
12
+ - `GROUP_ID` constant to also spot the sftp **gid**
13
+
9
14
  ### Changed
10
15
 
11
16
  ### Fixed
@@ -32,6 +32,18 @@ module Eco
32
32
 
33
33
  private
34
34
 
35
+ def api_space_default?
36
+ space = api_space
37
+ return true if space.nil?
38
+ return true if space == :default
39
+
40
+ false
41
+ end
42
+
43
+ def api_space
44
+ options.dig(:api, :space)
45
+ end
46
+
35
47
  def simulate?
36
48
  options[:simulate] || options[:dry_run]
37
49
  end
@@ -1,3 +1,4 @@
1
+ # rubocop:disable Naming/MethodParameterName
1
2
  module Eco
2
3
  module API
3
4
  module Common
@@ -35,7 +36,7 @@ module Eco
35
36
  private
36
37
 
37
38
  def credentials
38
- raise "You must implement this method"
39
+ raise 'You must implement this method'
39
40
  end
40
41
 
41
42
  def fetch_from(value = nil)
@@ -59,3 +60,5 @@ module Eco
59
60
  end
60
61
  end
61
62
  end
63
+
64
+ # rubocop:enable Naming/MethodParameterName
@@ -47,8 +47,11 @@ module Eco
47
47
  next unless response
48
48
 
49
49
  to_addr = serv.fetch_to(to)
50
- # msg = "Sent email (MessageId: #{response.message_id}) to #{fetch_destination(to: to, cc: cc, bcc: bcc)}"
51
- msg = "Sent email #{ProviderBase.to_desc(to: to_addr, cc: cc, bcc: bcc)}"
50
+ msg = "Sent email #{ProviderBase.to_desc(
51
+ to: to_addr,
52
+ cc: cc,
53
+ bcc: bcc
54
+ )}"
52
55
  puts msg
53
56
  log(:debug) { msg }
54
57
  end
@@ -75,7 +75,7 @@ module Eco
75
75
  def missing_api_message(name, space: space_option)
76
76
  space ||= space_option
77
77
 
78
- msg = "Missing credentials for "
78
+ msg = 'Missing credentials for '
79
79
  msg << "#{full_name(name, space: space)} Api env."
80
80
 
81
81
  if enviro_spaces?(name)
@@ -4,6 +4,10 @@ module Eco
4
4
  class Config
5
5
  class Apis
6
6
  module SpaceHelpers
7
+ def set_options_space!(space)
8
+ ASSETS.cli.options.deep_merge!(api: {space: space})
9
+ end
10
+
7
11
  def space_option?
8
12
  SCR.get_arg('-space')
9
13
  end
@@ -20,10 +24,6 @@ module Eco
20
24
  end
21
25
  end
22
26
 
23
- def set_options_space!(space)
24
- ASSETS.cli.options.deep_merge!(api: {space: space})
25
- end
26
-
27
27
  private
28
28
 
29
29
  def to_space(...)
@@ -72,7 +72,7 @@ module Eco
72
72
  space ||= space_option
73
73
 
74
74
  msg = missing_api_message(name, space: space)
75
- raise UndefinedApi, msg unless self.api?(name, space: space)
75
+ raise UndefinedApi, msg unless api?(name, space: space)
76
76
 
77
77
  self['active-name'] = name
78
78
  self['active-api'] = apis(space)[name]
@@ -29,6 +29,8 @@ module Eco::API::UseCases::Lib
29
29
  rescue NameError
30
30
  self.class.const_get(fpc)
31
31
  end
32
+ elsif self.class.const_defined?(:FILE_PATTERN)
33
+ self.class::FILE_PATTERN
32
34
  end
33
35
  rescue NameError
34
36
  raise WrongConst, "(#{self.class}) Unknown constant: #{fpc}"
@@ -18,10 +18,12 @@ module Eco::API::UseCases::Lib
18
18
  alias_method :sftp_upload, :upload
19
19
 
20
20
  def sftp_group_id
21
- if self.class.const_defined?(:SFTP_GROUP)
22
- self.class.const_get(:SFTP_GROUP)
23
- elsif (group_id = options.dig(:sftp, :group))
21
+ if (group_id = options.dig(:sftp, :group))
24
22
  group_id
23
+ elsif self.class.const_defined?(:SFTP_GROUP)
24
+ self.class.const_get(:SFTP_GROUP)
25
+ elsif self.class.const_defined?(:GROUP_ID)
26
+ self.class.const_get(:GROUP_ID)
25
27
  end
26
28
  end
27
29
 
@@ -106,6 +108,16 @@ module Eco::API::UseCases::Lib
106
108
  end
107
109
  end
108
110
 
111
+ def local_folder
112
+ if (local_dir = options.dig(:sftp, :local_folder))
113
+ local_dir
114
+ elsif self.class.const_defined?(:LOCAL_FOLDER)
115
+ self.class::LOCAL_FOLDER
116
+ else
117
+ '.'
118
+ end
119
+ end
120
+
109
121
  def to_remote_path(file, subfolder: remote_subfolder)
110
122
  [remote_folder(subfolder), file].join('/')
111
123
  end
@@ -132,16 +144,6 @@ module Eco::API::UseCases::Lib
132
144
  raise UnspecifiedRemoteFolder, msg
133
145
  end
134
146
 
135
- def local_folder
136
- if (local_dir = options.dig(:sftp, :local_folder))
137
- local_dir
138
- elsif self.class.const_defined?(:LOCAL_FOLDER)
139
- self.class::LOCAL_FOLDER
140
- else
141
- '.'
142
- end
143
- end
144
-
145
147
  # @param subfolder [String] the subfolder.
146
148
  def with_remote_files(subfolder: remote_subfolder, pattern: nil)
147
149
  sftp.files(remote_folder(subfolder), pattern: pattern).each do |remote_file|
data/lib/eco/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Eco
2
- VERSION = '3.0.25'.freeze
2
+ VERSION = '3.0.26'.freeze
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: eco-helpers
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.0.25
4
+ version: 3.0.26
5
5
  platform: ruby
6
6
  authors:
7
7
  - Oscar Segura
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-03-22 00:00:00.000000000 Z
11
+ date: 2025-03-23 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rake