mjml-ruby 0.1.2 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/mjml.rb +17 -0
- data/lib/mjml/logger.rb +17 -0
- data/lib/mjml/parser.rb +6 -0
- data/lib/mjml/version.rb +1 -1
- metadata +2 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 96eb2fb2cdf9e7b6a84efc3a208e01130994a464
|
4
|
+
data.tar.gz: 0ee34e9e712afbe03d5d71b57d49e3e791c9670a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1d09aad69ade8d2e736f35bff62a25b53c250d2e9487435e2decce997d5ab1b43cc4b2929f0f795c5f0de588d8172295ce80e0a264aff6455e12fa311860f8ba
|
7
|
+
data.tar.gz: 94192c8a562b1d2ed8bfe17d87a8d758b924460cfb47c040d7ae282276a58c1f97e4d503b049b173fe55a2d6692156287c10aeff8bbb9b1913984c51a96c95f0
|
data/lib/mjml.rb
CHANGED
@@ -10,11 +10,15 @@ module MJML
|
|
10
10
|
extend Dry::Configurable
|
11
11
|
# Available settings
|
12
12
|
setting :bin_path
|
13
|
+
setting :debug
|
14
|
+
setting :logger
|
13
15
|
|
14
16
|
def self.setup!
|
15
17
|
# Init config
|
16
18
|
configure do |config|
|
17
19
|
config.bin_path = find_executable
|
20
|
+
config.logger = choose_logger
|
21
|
+
config.debug = false
|
18
22
|
end
|
19
23
|
end
|
20
24
|
|
@@ -28,6 +32,19 @@ module MJML
|
|
28
32
|
ver, _status = Open3.capture2(find_executable, '-V')
|
29
33
|
(ver =~ VERSION_REGEX).nil? ? nil : ver
|
30
34
|
end
|
35
|
+
|
36
|
+
def self.choose_logger
|
37
|
+
if defined?(Rails)
|
38
|
+
Rails.logger
|
39
|
+
else
|
40
|
+
require 'mjml/logger'
|
41
|
+
MJML::Logger.setup!(STDOUT)
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
def self.logger
|
46
|
+
config.logger
|
47
|
+
end
|
31
48
|
end
|
32
49
|
|
33
50
|
MJML.setup!
|
data/lib/mjml/logger.rb
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
require 'logger'
|
2
|
+
|
3
|
+
module MJML
|
4
|
+
# Simple logger for debugging MJML
|
5
|
+
class Logger < ::Logger
|
6
|
+
def self.setup!(destination)
|
7
|
+
logger = new(destination)
|
8
|
+
logger.level = ::Logger::DEBUG
|
9
|
+
|
10
|
+
logger.formatter = proc do |severity, datetime, _progname, msg|
|
11
|
+
"[#{datetime}] #{severity} -- MJML: #{msg}" if MJML.config.debug
|
12
|
+
end
|
13
|
+
|
14
|
+
logger
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
data/lib/mjml/parser.rb
CHANGED
@@ -9,6 +9,8 @@ module MJML
|
|
9
9
|
ROOT_TAGS_REGEX = %r{<mjml>.*<\/mjml>}im
|
10
10
|
|
11
11
|
def initialize
|
12
|
+
MJML.logger.debug("Path: #{mjml_bin};" \
|
13
|
+
"Version: #{MJML.executable_version}")
|
12
14
|
raise ExecutableNotFound if MJML.executable_version.nil?
|
13
15
|
end
|
14
16
|
|
@@ -25,10 +27,14 @@ module MJML
|
|
25
27
|
private
|
26
28
|
|
27
29
|
def exec!(template)
|
30
|
+
MJML.logger.debug("Template:\n #{template}")
|
28
31
|
raise InvalidTemplate if template.empty?
|
32
|
+
|
33
|
+
MJML.logger.debug("Partial: #{partial?(template)}")
|
29
34
|
return template if partial?(template)
|
30
35
|
|
31
36
|
out, err, _status = Open3.capture3(build_cmd(template))
|
37
|
+
MJML.logger.debug("Output:\n #{out};\n\n Errors:\n #{err}")
|
32
38
|
|
33
39
|
raise InvalidTemplate unless err.empty?
|
34
40
|
out
|
data/lib/mjml/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: mjml-ruby
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Mykola Basov
|
@@ -126,6 +126,7 @@ extensions: []
|
|
126
126
|
extra_rdoc_files: []
|
127
127
|
files:
|
128
128
|
- lib/mjml.rb
|
129
|
+
- lib/mjml/logger.rb
|
129
130
|
- lib/mjml/parser.rb
|
130
131
|
- lib/mjml/railtie.rb
|
131
132
|
- lib/mjml/version.rb
|