22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
# File 'lib/yadecli/command/composer/composer_log_command.rb', line 22
def execute
composer_project_client = Yade::Composer::Rest::Client::ComposerProjectClient.new
composer_service_client = Yade::Composer::Rest::Client::ComposerServiceClient.new
composer_container_client = Yade::Composer::Rest::Client::ComposerContainerClient.new
composer_project = composer_project_client.get_by_name(project_name)
composer_services = composer_service_client.get_by_composer_project_id(composer_project.id)
composer_service = composer_services.select { |s| s.name == service_name }.first
composer_containers = composer_container_client.get_by_composer_service_id(composer_service.id)
container_names = composer_containers.map(&:name).join(' ')
begin
cmdline = 'docker-compose logs'
cmdline += ' -f' if options[:follow]
cmdline += " #{container_names}"
cmd = TTY::Command.new(uuid: false)
cmd.run(cmdline, chdir: composer_project.install_dir)
rescue TTY::Command::ExitError => e
puts e
end
'Yade composer service successfully logged'
end
|