ehbrs-tools 0.23.0 → 0.23.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/exe/ehbrs +2 -2
- data/lib/ehbrs/tools/runner.rb +21 -0
- data/lib/ehbrs/tools/runner/cooking_book.rb +32 -0
- data/lib/ehbrs/tools/runner/cooking_book/build.rb +52 -0
- data/lib/ehbrs/{runner/videos/series.rb → tools/runner/finances.rb} +4 -4
- data/lib/ehbrs/tools/runner/finances/bb_browser.rb +37 -0
- data/lib/ehbrs/tools/runner/fs.rb +18 -0
- data/lib/ehbrs/tools/runner/fs/selected.rb +81 -0
- data/lib/ehbrs/tools/runner/fs/used_space.rb +161 -0
- data/lib/ehbrs/tools/runner/google.rb +18 -0
- data/lib/ehbrs/tools/runner/google/translate.rb +89 -0
- data/lib/ehbrs/tools/runner/music.rb +18 -0
- data/lib/ehbrs/tools/runner/music/selected.rb +28 -0
- data/lib/ehbrs/tools/runner/self.rb +18 -0
- data/lib/ehbrs/tools/runner/self/test.rb +27 -0
- data/lib/ehbrs/tools/runner/telegram.rb +28 -0
- data/lib/ehbrs/tools/runner/telegram/send_message.rb +31 -0
- data/lib/ehbrs/tools/runner/vg.rb +18 -0
- data/lib/ehbrs/tools/runner/vg/ips.rb +134 -0
- data/lib/ehbrs/tools/runner/vg/wii.rb +74 -0
- data/lib/ehbrs/{runner/web_utils → tools/runner}/videos.rb +3 -3
- data/lib/ehbrs/tools/runner/videos/extract.rb +70 -0
- data/lib/ehbrs/tools/runner/videos/probe.rb +34 -0
- data/lib/ehbrs/tools/runner/videos/series.rb +20 -0
- data/lib/ehbrs/tools/runner/videos/series/rename.rb +74 -0
- data/lib/ehbrs/tools/runner/videos/unsupported.rb +61 -0
- data/lib/ehbrs/tools/runner/web_utils.rb +26 -0
- data/lib/ehbrs/tools/runner/web_utils/videos.rb +20 -0
- data/lib/ehbrs/tools/runner/web_utils/videos/download.rb +65 -0
- data/lib/ehbrs/tools/runner/web_utils/videos/upload.rb +77 -0
- data/lib/ehbrs/tools/version.rb +1 -1
- data/vendor/aranha-parsers/lib/aranha/parsers/source_address.rb +10 -8
- data/vendor/aranha-parsers/lib/aranha/parsers/version.rb +1 -1
- data/vendor/eac_docker/eac_docker.gemspec +1 -1
- data/vendor/eac_docker/lib/eac_docker/debug.rb +15 -0
- data/vendor/eac_docker/lib/eac_docker/images/coded.rb +4 -0
- data/vendor/eac_docker/lib/eac_docker/images/templatized.rb +12 -2
- data/vendor/eac_docker/lib/eac_docker/version.rb +1 -1
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/boolean.rb +1 -1
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/version.rb +1 -1
- data/vendor/ehbrs_ruby_utils/ehbrs_ruby_utils.gemspec +3 -2
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/version.rb +1 -1
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/videos/stream.rb +11 -1
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec.rb +14 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_attachment.source.yaml +28 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_attachment.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_audio.source.yaml +49 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_audio.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_subtitle.source.yaml +43 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_subtitle.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_video.source.yaml +59 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_video.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/rubocop_check_spec.rb +1 -5
- data/vendor/ehbrs_ruby_utils/spec/spec_helper.rb +3 -0
- metadata +42 -32
- data/lib/ehbrs/runner.rb +0 -19
- data/lib/ehbrs/runner/cooking_book.rb +0 -30
- data/lib/ehbrs/runner/cooking_book/build.rb +0 -50
- data/lib/ehbrs/runner/finances.rb +0 -16
- data/lib/ehbrs/runner/finances/bb_browser.rb +0 -35
- data/lib/ehbrs/runner/fs.rb +0 -16
- data/lib/ehbrs/runner/fs/selected.rb +0 -79
- data/lib/ehbrs/runner/fs/used_space.rb +0 -159
- data/lib/ehbrs/runner/google.rb +0 -16
- data/lib/ehbrs/runner/google/translate.rb +0 -87
- data/lib/ehbrs/runner/music.rb +0 -16
- data/lib/ehbrs/runner/music/selected.rb +0 -26
- data/lib/ehbrs/runner/self.rb +0 -16
- data/lib/ehbrs/runner/self/test.rb +0 -25
- data/lib/ehbrs/runner/telegram.rb +0 -26
- data/lib/ehbrs/runner/telegram/send_message.rb +0 -29
- data/lib/ehbrs/runner/vg.rb +0 -16
- data/lib/ehbrs/runner/vg/ips.rb +0 -132
- data/lib/ehbrs/runner/vg/wii.rb +0 -72
- data/lib/ehbrs/runner/videos.rb +0 -16
- data/lib/ehbrs/runner/videos/extract.rb +0 -68
- data/lib/ehbrs/runner/videos/probe.rb +0 -32
- data/lib/ehbrs/runner/videos/series/rename.rb +0 -72
- data/lib/ehbrs/runner/videos/unsupported.rb +0 -59
- data/lib/ehbrs/runner/web_utils.rb +0 -24
- data/lib/ehbrs/runner/web_utils/videos/download.rb +0 -63
- data/lib/ehbrs/runner/web_utils/videos/upload.rb +0 -75
@@ -3,13 +3,13 @@
|
|
3
3
|
require 'eac_cli/core_ext'
|
4
4
|
|
5
5
|
module Ehbrs
|
6
|
-
|
7
|
-
class
|
6
|
+
module Tools
|
7
|
+
class Runner
|
8
8
|
class Videos
|
9
9
|
require_sub __FILE__
|
10
10
|
|
11
11
|
runner_with :help, :subcommands do
|
12
|
-
desc '
|
12
|
+
desc 'Video tools for EHB/RS.'
|
13
13
|
subcommands
|
14
14
|
end
|
15
15
|
end
|
@@ -0,0 +1,70 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs/videos/extract/package'
|
5
|
+
|
6
|
+
module Ehbrs
|
7
|
+
module Tools
|
8
|
+
class Runner
|
9
|
+
class Videos
|
10
|
+
class Extract
|
11
|
+
require_sub __FILE__
|
12
|
+
|
13
|
+
DEFAULT_QUALITIES = %w[1080 720 web webrip hdtv].freeze
|
14
|
+
|
15
|
+
runner_with :help do
|
16
|
+
desc 'Extrai arquivos de seriados.'
|
17
|
+
arg_opt '-d', '--dir', 'Extraí para diretório.'
|
18
|
+
bool_opt '-D', '--delete', 'Remove o pacote após o processamento.'
|
19
|
+
arg_opt '-q', '--qualities', 'Lista de qualidades.'
|
20
|
+
pos_arg 'packages', repeat: true
|
21
|
+
end
|
22
|
+
|
23
|
+
def run
|
24
|
+
start_banner
|
25
|
+
packages.each do |package|
|
26
|
+
infov 'Package', package
|
27
|
+
package.run(parsed.delete?)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
private
|
32
|
+
|
33
|
+
def packages_uncached
|
34
|
+
parsed.packages?.map do |p|
|
35
|
+
::Ehbrs::Videos::Extract::Package.new(p, target_dir, qualities)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
def qualities_uncached
|
40
|
+
(parsed.qualities.to_s.split(',') + DEFAULT_QUALITIES).uniq
|
41
|
+
end
|
42
|
+
|
43
|
+
def start_banner
|
44
|
+
infov 'Packages', packages.count
|
45
|
+
infov 'Qualities', qualities
|
46
|
+
infov 'Target directory', target_dir
|
47
|
+
end
|
48
|
+
|
49
|
+
def target_dir_uncached
|
50
|
+
parsed.dir.if_present(&:to_pathname) || default_target_dir
|
51
|
+
end
|
52
|
+
|
53
|
+
def default_target_dir
|
54
|
+
r = parsed.packages.first.to_pathname.basename('.*')
|
55
|
+
return r unless r.exist?
|
56
|
+
|
57
|
+
r = r.basename_sub { |b| "#{b}_extract" }
|
58
|
+
index = 0
|
59
|
+
loop do
|
60
|
+
return r unless r.exist?
|
61
|
+
|
62
|
+
index += 1
|
63
|
+
r = r.basename_sub { |b| "#{b}_#{index}" }
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'ehbrs_ruby_utils/videos/container'
|
4
|
+
require 'eac_ruby_base0/core_ext'
|
5
|
+
require 'eac_ruby_utils/yaml'
|
6
|
+
|
7
|
+
module Ehbrs
|
8
|
+
module Tools
|
9
|
+
class Runner
|
10
|
+
class Videos
|
11
|
+
class Probe
|
12
|
+
runner_with :help, :output do
|
13
|
+
desc 'FFProbe em um arquivo de vídeo.'
|
14
|
+
pos_arg :file_path
|
15
|
+
end
|
16
|
+
|
17
|
+
def run
|
18
|
+
run_output
|
19
|
+
end
|
20
|
+
|
21
|
+
def output_content
|
22
|
+
::EacRubyUtils::Yaml.dump(container_file.probe_data)
|
23
|
+
end
|
24
|
+
|
25
|
+
private
|
26
|
+
|
27
|
+
def container_file_uncached
|
28
|
+
::EhbrsRubyUtils::Videos::Container.new(parsed.file_path)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
|
5
|
+
module Ehbrs
|
6
|
+
module Tools
|
7
|
+
class Runner
|
8
|
+
class Videos
|
9
|
+
class Series
|
10
|
+
require_sub __FILE__
|
11
|
+
|
12
|
+
runner_with :help, :subcommands do
|
13
|
+
desc 'Ferramentas para seriados.'
|
14
|
+
subcommands
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,74 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs/videos/series/rename/file'
|
5
|
+
require 'ehbrs/videos/series/rename/file/options'
|
6
|
+
require 'ehbrs/videos/series/rename/results_builder'
|
7
|
+
|
8
|
+
module Ehbrs
|
9
|
+
module Tools
|
10
|
+
class Runner
|
11
|
+
class Videos
|
12
|
+
class Series
|
13
|
+
class Rename
|
14
|
+
include ::EacRubyUtils::Fs::Traversable
|
15
|
+
|
16
|
+
runner_with :help do
|
17
|
+
desc 'Renomeia arquivos de séries.'
|
18
|
+
bool_opt '-r', '--recursive', 'Recursivo.'
|
19
|
+
bool_opt '-c', '--confirm', 'Confirmação a renomeação.'
|
20
|
+
arg_opt '-k', '--kernel', 'Determina o kernel para os nomes dos arquivos.'
|
21
|
+
arg_opt '-E', '--extension', 'Substitui a extensão dos arquivos.'
|
22
|
+
arg_opt '-e', '--episode-increment', 'Aumenta o número do episódio.'
|
23
|
+
pos_arg 'paths', repeat: true, optional: true
|
24
|
+
end
|
25
|
+
|
26
|
+
def run
|
27
|
+
banner
|
28
|
+
show_results
|
29
|
+
rename_files
|
30
|
+
end
|
31
|
+
|
32
|
+
def banner
|
33
|
+
infov 'Paths', paths.count
|
34
|
+
infov 'Files found', files.count
|
35
|
+
end
|
36
|
+
|
37
|
+
def files_uncached
|
38
|
+
@files = []
|
39
|
+
paths.each { |path| traverser_check_path(path) }
|
40
|
+
@files
|
41
|
+
end
|
42
|
+
|
43
|
+
def paths
|
44
|
+
parsed.paths.if_present(['.'])
|
45
|
+
end
|
46
|
+
|
47
|
+
def traverser_recursive
|
48
|
+
parsed.recursive
|
49
|
+
end
|
50
|
+
|
51
|
+
def traverser_check_file(path)
|
52
|
+
@files << ::Ehbrs::Videos::Series::Rename::File.new(path, series_file_options)
|
53
|
+
end
|
54
|
+
|
55
|
+
def series_file_options_uncached
|
56
|
+
::Ehbrs::Videos::Series::Rename::File::Options.new(parsed)
|
57
|
+
end
|
58
|
+
|
59
|
+
def show_results
|
60
|
+
::Ehbrs::Videos::Series::Rename::ResultsBuilder.new(files).show(0)
|
61
|
+
end
|
62
|
+
|
63
|
+
def rename_files
|
64
|
+
return unless series_file_options.confirm
|
65
|
+
|
66
|
+
infom 'Renaming files...'
|
67
|
+
files.each(&:rename)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
@@ -0,0 +1,61 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs/videos/unsupported/check_set'
|
5
|
+
require 'ehbrs/videos/unsupported/search'
|
6
|
+
require 'ehbrs/videos/unsupported/profiles'
|
7
|
+
|
8
|
+
module Ehbrs
|
9
|
+
module Tools
|
10
|
+
class Runner
|
11
|
+
class Videos
|
12
|
+
class Unsupported
|
13
|
+
PROFILES = %w[aoc philco samsung].freeze
|
14
|
+
|
15
|
+
runner_with :help do
|
16
|
+
desc 'Procura e converte vídeos não suportados pelas TVs de EHB/RS.'
|
17
|
+
bool_opt '-f', '--fix', 'Converte vídeos para o formato apropriado.'
|
18
|
+
arg_opt '-p', '--profiles', "Seleciona os perfis (#{PROFILES.join(', ')})."
|
19
|
+
pos_arg 'paths', repeat: true
|
20
|
+
end
|
21
|
+
|
22
|
+
def run
|
23
|
+
infov 'Profiles', profiles.join(', ')
|
24
|
+
infov 'Paths', paths
|
25
|
+
paths.each do |d|
|
26
|
+
::Ehbrs::Videos::Unsupported::Search.new(d, file_options)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
private
|
31
|
+
|
32
|
+
def file_check_set_uncached
|
33
|
+
::Ehbrs::Videos::Unsupported::CheckSet.build(profiles, :file)
|
34
|
+
end
|
35
|
+
|
36
|
+
def track_check_set_uncached
|
37
|
+
::Ehbrs::Videos::Unsupported::CheckSet.build(profiles, :track)
|
38
|
+
end
|
39
|
+
|
40
|
+
def paths
|
41
|
+
parsed.paths
|
42
|
+
end
|
43
|
+
|
44
|
+
def file_options
|
45
|
+
{ file_check_set: file_check_set, track_check_set: track_check_set,
|
46
|
+
fix: parsed.fix? }
|
47
|
+
end
|
48
|
+
|
49
|
+
def profiles_uncached
|
50
|
+
parsed.profiles.if_present(PROFILES) { |v| v.split(',').map(&:strip) }
|
51
|
+
.map { |name| profile_class(name).instance }
|
52
|
+
end
|
53
|
+
|
54
|
+
def profile_class(profile_name)
|
55
|
+
::Ehbrs::Videos::Unsupported::Profiles.const_get(profile_name.camelize)
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs_ruby_utils/web_utils/instance'
|
5
|
+
|
6
|
+
module Ehbrs
|
7
|
+
module Tools
|
8
|
+
class Runner
|
9
|
+
class WebUtils
|
10
|
+
require_sub __FILE__
|
11
|
+
|
12
|
+
runner_with :help, :subcommands do
|
13
|
+
desc 'Ferramentas para EHB/RS Utils.'
|
14
|
+
pos_arg :instance_id
|
15
|
+
subcommands
|
16
|
+
end
|
17
|
+
|
18
|
+
private
|
19
|
+
|
20
|
+
def instance_uncached
|
21
|
+
::EhbrsRubyUtils::WebUtils::Instance.by_id(parsed.instance_id)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
|
5
|
+
module Ehbrs
|
6
|
+
module Tools
|
7
|
+
class Runner
|
8
|
+
class WebUtils
|
9
|
+
class Videos
|
10
|
+
require_sub __FILE__
|
11
|
+
|
12
|
+
runner_with :help, :subcommands do
|
13
|
+
desc 'Ferramentas de vídeos para EHB/RS Utils.'
|
14
|
+
subcommands
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,65 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs_ruby_utils/web_utils/videos/file'
|
5
|
+
|
6
|
+
module Ehbrs
|
7
|
+
module Tools
|
8
|
+
class Runner
|
9
|
+
class WebUtils
|
10
|
+
class Videos
|
11
|
+
class Download
|
12
|
+
runner_with :help do
|
13
|
+
desc 'Importa informações de arquivos de vídeo de uma instância EHB/RS Utils.'
|
14
|
+
bool_opt '-c', '--confirm', 'Confirma as mudanças'
|
15
|
+
end
|
16
|
+
|
17
|
+
def run
|
18
|
+
start_banner
|
19
|
+
to_rename.each { |file| process_rename_file(file) }
|
20
|
+
to_delete.each { |file| process_delete_file(file) }
|
21
|
+
end
|
22
|
+
|
23
|
+
private
|
24
|
+
|
25
|
+
def start_banner
|
26
|
+
infov 'Files downloaded', files.count
|
27
|
+
infov 'To rename', to_rename.count
|
28
|
+
infov 'To delete', to_delete.count
|
29
|
+
end
|
30
|
+
|
31
|
+
def process_rename_file(file)
|
32
|
+
infov " * #{file.new_path}", file.original_path
|
33
|
+
file.rename if parsed.confirm?
|
34
|
+
end
|
35
|
+
|
36
|
+
def process_delete_file(file)
|
37
|
+
infov " * #{file.new_path}", 'REMOVE'
|
38
|
+
file.remove if parsed.confirm?
|
39
|
+
end
|
40
|
+
|
41
|
+
def files_uncached
|
42
|
+
data.map { |file_data| ::EhbrsRubyUtils::WebUtils::Videos::File.new(file_data) }
|
43
|
+
end
|
44
|
+
|
45
|
+
def to_rename_uncached
|
46
|
+
files.select(&:path_changed?)
|
47
|
+
end
|
48
|
+
|
49
|
+
def to_delete_uncached
|
50
|
+
files.reject { |f| f.type == 'Videos::SeriesDirectory' }.select(&:unwanted)
|
51
|
+
end
|
52
|
+
|
53
|
+
def data_uncached
|
54
|
+
::JSON.parse(raw_content)
|
55
|
+
end
|
56
|
+
|
57
|
+
def raw_content
|
58
|
+
runner_context.call(:instance).http_request('/videos/files/export').body
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
@@ -0,0 +1,77 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs_ruby_utils/web_utils/videos/files_list'
|
5
|
+
require 'json'
|
6
|
+
require 'yaml'
|
7
|
+
|
8
|
+
module Ehbrs
|
9
|
+
module Tools
|
10
|
+
class Runner
|
11
|
+
class WebUtils
|
12
|
+
class Videos
|
13
|
+
class Upload
|
14
|
+
runner_with :help do
|
15
|
+
desc 'Exporta informações de arquivos de vídeo para uma instância EHB/RS Utils.'
|
16
|
+
bool_opt '-P', '--no-ffprobe', 'Não recupera dados com "ffprobe".'
|
17
|
+
end
|
18
|
+
|
19
|
+
def run
|
20
|
+
%w[movies series].each { |type| upload_files_list(type) }
|
21
|
+
end
|
22
|
+
|
23
|
+
def upload_files_list(type)
|
24
|
+
infom "Uploading \"#{type}\" files list..."
|
25
|
+
files_list_path = send("#{type}_files_list")
|
26
|
+
infov 'Path', files_list_path
|
27
|
+
process_response(upload_request(files_list_path))
|
28
|
+
end
|
29
|
+
|
30
|
+
def upload_request(files_list_path)
|
31
|
+
runner_context.call(:instance).http_request(
|
32
|
+
'/videos/files/import',
|
33
|
+
method: :put,
|
34
|
+
body: {
|
35
|
+
'videos_tableless_local_import_list[list_file]' => ::File.new(files_list_path)
|
36
|
+
},
|
37
|
+
header: {
|
38
|
+
'Accept' => 'application/json'
|
39
|
+
}
|
40
|
+
)
|
41
|
+
end
|
42
|
+
|
43
|
+
def process_response(response)
|
44
|
+
infov 'Response status', response.status
|
45
|
+
if response.status == 200
|
46
|
+
pp ::JSON.parse(response.body)
|
47
|
+
else
|
48
|
+
error_file = '/tmp/ehbrsutils.html'
|
49
|
+
::File.write(error_file, response.body)
|
50
|
+
system('firefox', error_file)
|
51
|
+
fatal_error('Retornou com status de erro: ' + error_file)
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
def series_files_list_uncached
|
56
|
+
write_files_list('Videos::SeriesDirectory', :series_directory)
|
57
|
+
end
|
58
|
+
|
59
|
+
def movies_files_list_uncached
|
60
|
+
write_files_list('Videos::MovieFile', :movies_directory)
|
61
|
+
end
|
62
|
+
|
63
|
+
def write_files_list(file_class, read_entry)
|
64
|
+
files_list = ::EhbrsRubyUtils::WebUtils::Videos::FilesList.new(
|
65
|
+
file_class,
|
66
|
+
runner_context.call(:instance).read_entry(read_entry),
|
67
|
+
ffprobe: !parsed.no_ffprobe?
|
68
|
+
)
|
69
|
+
infov 'Files found', files_list.data.fetch(:files).count
|
70
|
+
files_list.write_to
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|